/* ========= Gallery Noir — Vidro Art Storage (Shared) ========= */
:root{
  --bg:#0b0b0b; --bg-soft:#111110; --bg-panel:#141312;
  --ink:#f3eee3; --ink-soft:#d8d3c6; --mute:#8f8a7f; --line:#1f1d18;
  --gold:#c9a25a; --gold-deep:#7a5a1f; --gold-dim:rgba(201,162,90,0.12);
  --light-bg:#f4f1e8; --light-ink:#0b0b0b; --light-mute:#5a554b; --light-line:#d6d1c4;
  --serif:'Cormorant Garamond','Playfair Display',Georgia,serif;
  --sans:'Inter','Helvetica Neue',Arial,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1.65;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none;transition:color .25s ease}
a:hover{color:var(--gold)}
img{max-width:100%;display:block}
h1,h2,h3,h4{font-family:var(--serif);font-weight:400;letter-spacing:.01em;color:var(--ink)}
h1{font-size:clamp(2.6rem,5vw,4.6rem);line-height:1.05}
h2{font-size:clamp(1.8rem,3vw,2.6rem);line-height:1.2}
h3{font-size:1.35rem;line-height:1.3}
p{color:var(--ink-soft);max-width:65ch}
.wrap{max-width:1400px;margin:0 auto;padding:0 clamp(20px,4vw,56px)}
.eyebrow{display:inline-block;font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin-bottom:18px;font-weight:500}
/* HEADER */
header{padding:20px 0;border-bottom:1px solid var(--line);position:sticky;top:0;background:rgba(11,11,11,.96);backdrop-filter:blur(8px);z-index:40}
header .wrap{display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;line-height:1}
.brand .name{font-family:var(--serif);font-size:1.7rem;letter-spacing:.04em;color:var(--ink);font-weight:500}
.brand .sub{font-family:var(--sans);font-size:.65rem;letter-spacing:.32em;text-transform:uppercase;color:var(--mute);margin-top:4px}

/* Use the real Vidro trademark logo (blue brushstroke) instead of text */
header .brand::before{content:"";display:block;width:56px;height:60px;background:url('https://vidroartstorage.com/uploads/2023/06/site_logo-2.png') no-repeat center;background-size:contain;mix-blend-mode:screen}
header .brand .name, header .brand .sub{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
nav.primary > ul{list-style:none;display:flex;gap:38px;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase}
nav.primary > ul > li{position:relative}
nav.primary > ul > li > a{position:relative;padding:10px 0;color:var(--ink);display:inline-flex;align-items:center;gap:6px;font-weight:500}
nav.primary > ul > li > a::after{content:"";position:absolute;left:0;right:0;bottom:4px;height:1px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .35s ease}
nav.primary > ul > li > a:hover::after,nav.primary > ul > li.active > a::after{transform:scaleX(1)}
nav.primary .chev{font-size:.6rem;opacity:.7}
nav.primary .submenu{position:absolute;top:100%;left:-20px;background:#141312;border:1px solid var(--line);padding:12px 0;min-width:300px;opacity:0;visibility:hidden;transform:translateY(-8px);transition:all .25s ease;list-style:none}
nav.primary li:hover > .submenu{opacity:1;visibility:visible;transform:translateY(0)}
nav.primary .submenu a{display:block;padding:10px 24px;font-size:.74rem;letter-spacing:.08em;color:var(--ink-soft)}
nav.primary .submenu a::after{display:none}
nav.primary .submenu a:hover{background:var(--gold-dim);color:var(--gold)}
.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 26px;border:1px solid var(--gold);color:var(--gold);font-family:var(--sans);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;background:transparent;cursor:pointer;transition:background .3s ease,color .3s ease;font-weight:500}
.btn:hover{background:var(--gold);color:#0b0b0b}
.btn.solid{background:var(--gold);color:#0b0b0b}
.btn.solid:hover{background:transparent;color:var(--gold)}
.btn.light{border-color:var(--ink);color:var(--ink)}
.btn.light:hover{background:var(--ink);color:#0b0b0b}

/* PAGE HERO (for non-home pages) */
.page-hero{padding:80px 0 50px;background:#0b0b0b;position:relative;overflow:hidden;border-bottom:1px solid var(--line)}
.page-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 60% at 80% 20%,rgba(201,162,90,0.12),transparent 60%);pointer-events:none}
.page-hero .wrap{position:relative}
.page-hero h1{font-size:clamp(2.4rem,5vw,4rem);max-width:900px}
.page-hero h1 .accent{color:var(--gold);font-style:italic}
.page-hero .lead{font-size:1.05rem;margin-top:18px;max-width:700px;color:var(--ink-soft)}
.breadcrumb{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--mute);margin-bottom:24px}
.breadcrumb a{color:var(--mute)}
.breadcrumb a:hover{color:var(--gold)}
.breadcrumb .sep{margin:0 10px;color:var(--line)}

/* SERVICE DETAIL */
.service-detail{padding:80px 0}
.service-detail .wrap{display:grid;grid-template-columns:2fr 1fr;gap:72px;max-width:1280px}
.service-detail .main h2{margin:40px 0 18px;font-size:1.9rem}
.service-detail .main h2:first-child{margin-top:0}
.service-detail .main p{margin-bottom:18px;font-size:1rem}
.service-detail .main ul.feat{margin:20px 0 28px;padding-left:0;list-style:none}
.service-detail .main ul.feat li{padding:12px 0 12px 28px;position:relative;color:var(--ink-soft);border-bottom:1px solid var(--line)}
.service-detail .main ul.feat li::before{content:"";position:absolute;left:0;top:17px;width:14px;height:14px;border:1px solid var(--gold);border-radius:50%;background:radial-gradient(circle,var(--gold) 3px,transparent 4px)}
.service-detail .hero-img{aspect-ratio:16/9;background:#1a1917;border:1px solid var(--line);overflow:hidden;margin-bottom:40px}
.service-detail .hero-img img{width:100%;height:100%;object-fit:cover}
.service-detail .sidebar{background:var(--bg-panel);border:1px solid var(--line);padding:36px 32px;position:sticky;top:110px;align-self:start}
.service-detail .sidebar h3{margin-bottom:14px;font-family:var(--serif);font-size:1.4rem}
.service-detail .sidebar p{font-size:.9rem;color:var(--ink-soft);margin-bottom:22px}
.service-detail .sidebar .line{padding:14px 0;border-bottom:1px solid var(--line);font-size:.88rem}
.service-detail .sidebar .line:last-of-type{border-bottom:0}
.service-detail .sidebar .label{font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--mute);margin-bottom:4px;font-weight:500}
.service-detail .sidebar .value{color:var(--ink)}
.service-detail .sidebar .btn{width:100%;justify-content:center;margin-top:22px}

/* RELATED SERVICES */
.related-services{padding:60px 0 90px;background:var(--bg-soft)}
.related-services h2{margin-bottom:32px;text-align:center}
.related-services .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.related-card{background:var(--bg-panel);border:1px solid var(--line);padding:28px 24px;transition:border-color .3s ease,transform .3s ease}
.related-card:hover{border-color:var(--gold);transform:translateY(-3px)}
.related-card h3{font-family:var(--serif);font-size:1.1rem;margin-bottom:10px}
.related-card p{font-size:.85rem;color:var(--ink-soft);margin-bottom:16px}
.related-card .link{font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);font-weight:500}
.related-card .link::after{content:" →"}

/* ABOUT / INFO SECTIONS */
.content-section{padding:80px 0}
.content-section.alt{background:var(--bg-soft)}
.content-section.light{background:var(--light-bg);color:var(--light-ink)}
.content-section.light h1,.content-section.light h2{color:var(--light-ink)}
.content-section.light p{color:var(--light-mute)}
.content-section.light .eyebrow{color:var(--gold-deep)}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.two-col .art{aspect-ratio:4/3;border:1px solid var(--line);overflow:hidden;background:#1a1917}
.two-col .art img{width:100%;height:100%;object-fit:cover}

/* FORMS (Quote / Contact) */
.form-section{padding:60px 0 90px}
.form-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:64px;align-items:start}
.form-info p{margin-bottom:22px}
.form-info .line{border-bottom:1px solid var(--line);padding:16px 0}
.form-info .line .label{font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--mute);margin-bottom:4px;font-weight:500}
.form-info .line .value{color:var(--ink);font-size:1rem}
.form{background:var(--bg-panel);border:1px solid var(--line);padding:40px 36px}
.form label{display:block;font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--mute);margin-bottom:8px;margin-top:20px;font-weight:500}
.form label:first-of-type{margin-top:0}
.form label .req{color:var(--gold);margin-left:4px}
.form input,.form textarea,.form select{width:100%;background:transparent;border:0;border-bottom:1px solid var(--line);color:var(--ink);font-family:var(--sans);font-size:1rem;padding:10px 0;transition:border-color .25s ease}
.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-bottom-color:var(--gold)}
.form textarea{min-height:120px;resize:vertical}
.form .btn{margin-top:30px;width:100%;justify-content:center}
.form .msg{margin-top:18px;padding:14px 18px;font-size:.88rem;display:none}
.form .msg.ok{background:rgba(201,162,90,0.15);border-left:2px solid var(--gold);color:var(--gold);display:block}
.form .msg.err{background:rgba(193,122,74,0.15);border-left:2px solid #c17a4a;color:#c17a4a;display:block}

/* BLOG */
.blog-landing{padding:80px 0}
.blog-landing .wrap{max-width:1000px}
.blog-landing .post-list{margin-top:48px}
.post-item{display:grid;grid-template-columns:1fr 2.5fr;gap:48px;padding:36px 0;border-bottom:1px solid var(--line);align-items:start}
.post-item .date{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold)}
.post-item .category{font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--mute);margin-top:8px;font-weight:500}
.post-item h2{font-size:1.7rem;line-height:1.25;margin-bottom:14px;font-family:var(--serif)}
.post-item h2 a:hover{color:var(--gold)}
.post-item p{font-size:.94rem;margin-bottom:18px}
.post-item .read-more{font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);font-weight:500}
.post-item .read-more::after{content:" →"}

.blog-post{padding:80px 0}
.blog-post .wrap{max-width:780px}
.blog-post .post-meta{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
.blog-post h1{font-size:clamp(2rem,4vw,3rem);line-height:1.15;margin-bottom:24px}
.blog-post .lead{font-size:1.15rem;color:var(--ink);margin-bottom:28px;font-family:var(--serif);font-style:italic}
.blog-post h2{margin:44px 0 16px;font-size:1.6rem;color:var(--gold)}
.blog-post p{font-size:1rem;line-height:1.8;margin-bottom:20px;color:var(--ink-soft)}
.blog-post em{font-style:italic;color:var(--ink)}
.blog-post .cta-box{background:var(--bg-panel);border-left:2px solid var(--gold);padding:32px 36px;margin:44px 0}
.blog-post .cta-box h3{margin-bottom:12px;font-family:var(--serif);font-size:1.4rem;color:var(--gold)}
.blog-post .cta-box p{margin-bottom:18px;font-size:.95rem}
.blog-post .cta-box a{color:var(--gold)}
.blog-post .next-up{border-top:1px solid var(--line);padding-top:28px;margin-top:44px;font-style:italic;color:var(--mute);font-size:.95rem}

/* FOOTER */
footer.site{background:#0b0b0b;border-top:1px solid var(--line);padding:72px 0 32px;margin-top:0}
footer.site .wrap{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.3fr 1fr;gap:48px;max-width:1400px}
footer.site .col h4{font-family:var(--sans);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:20px;font-weight:700}
footer.site .col.brand .name{font-family:var(--serif);font-size:1.7rem;letter-spacing:.04em;color:var(--ink);font-weight:500}
footer.site .col.brand .sub{font-size:.65rem;letter-spacing:.32em;text-transform:uppercase;color:var(--mute);margin-top:4px}

/* Footer: trademark is now a real <img> inside .col.brand (see HTML on each page) */
footer.site .col.brand p{font-size:.85rem;margin-top:0;color:var(--ink-soft);max-width:unset;line-height:1.6}
footer.site ul{list-style:none}
footer.site li{padding:5px 0;font-size:.85rem}
footer.site a{color:var(--ink-soft)}
footer.site a:hover{color:var(--gold)}
footer.site .contact-line{padding:6px 0;font-size:.85rem;color:var(--ink-soft);display:flex;align-items:flex-start;gap:10px}
footer.site .contact-line .ico{color:var(--gold);width:16px;height:16px;flex-shrink:0;margin-top:3px}
footer.site .social{display:flex;gap:12px;margin-top:10px}
footer.site .social a{width:38px;height:38px;border:1px solid var(--line);display:grid;place-items:center;transition:border-color .25s ease,color .25s ease;color:var(--ink-soft)}
footer.site .social a:hover{border-color:var(--gold);color:var(--gold)}
footer.site .social svg{width:16px;height:16px}
footer.site .footer-cta{text-align:right}
footer.site .bottom{border-top:1px solid var(--line);padding-top:24px;margin-top:60px;display:flex;justify-content:space-between;font-size:.76rem;color:var(--mute);letter-spacing:.06em;flex-wrap:wrap;gap:16px}
footer.site .bottom .legal a{margin-left:24px}

/* RESPONSIVE */
@media (max-width:1100px){
  footer.site .wrap{grid-template-columns:1fr 1fr}
  .service-detail .wrap{grid-template-columns:1fr;gap:48px}
  .service-detail .sidebar{position:static}
  .related-services .grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:900px){
  nav.primary{display:none}
  .two-col{grid-template-columns:1fr;gap:40px}
  .form-grid{grid-template-columns:1fr;gap:40px}
  .post-item{grid-template-columns:1fr;gap:14px}
}
@media (max-width:600px){
  footer.site .wrap{grid-template-columns:1fr}
  footer.site .footer-cta{text-align:left}
  .related-services .grid{grid-template-columns:1fr}
  header .btn{display:none}
}
