/* ========= 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 1fr 1.3fr 1.3fr;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;white-space:nowrap}
footer.site .footer-cta .btn{white-space:nowrap}

/* 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){
  .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}
}


/* ======= MOBILE NAVIGATION (hamburger, CSS-only via checkbox hack) ======= */
nav.primary > ul > li.mobile-quote{display:none}
.mobile-nav-toggle-input{display:none}
.mobile-nav-toggle-label{display:none;cursor:pointer;padding:10px;margin-right:-10px;z-index:50;position:relative}
.mobile-nav-toggle-label span{display:block;width:26px;height:2px;background:var(--ink);margin:5px 0;transition:transform .3s ease,opacity .3s ease,background .3s ease;border-radius:1px}

@media (max-width:900px){
  .mobile-nav-toggle-label{display:block}
  nav.primary{display:block;position:fixed;top:0;right:-100%;width:min(82vw,360px);height:100vh;background:#0b0b0b;border-left:1px solid var(--line);padding:88px 0 40px;overflow-y:auto;transition:right .35s cubic-bezier(.25,.8,.25,1);z-index:45;box-shadow:-16px 0 40px rgba(0,0,0,.6)}
  .mobile-nav-toggle-input:checked ~ nav.primary{right:0}
  .mobile-nav-toggle-input:checked ~ .mobile-nav-toggle-label span:nth-child(1){transform:translateY(7px) rotate(45deg);background:var(--gold)}
  .mobile-nav-toggle-input:checked ~ .mobile-nav-toggle-label span:nth-child(2){opacity:0}
  .mobile-nav-toggle-input:checked ~ .mobile-nav-toggle-label span:nth-child(3){transform:translateY(-7px) rotate(-45deg);background:var(--gold)}
  nav.primary > ul{flex-direction:column;gap:0;align-items:stretch}
  nav.primary > ul > li{border-bottom:1px solid var(--line)}
  nav.primary > ul > li > a{display:block;padding:18px 28px;font-size:.88rem}
  nav.primary > ul > li > a::after{display:none}
  nav.primary .chev{margin-left:auto}
  nav.primary .submenu{position:static;opacity:1;visibility:visible;transform:none;background:#141312;border:0;padding:0;min-width:0;display:none}
  nav.primary li.dropdown:hover > .submenu,nav.primary li.dropdown:focus-within > .submenu{display:block}
  nav.primary .submenu a{padding:14px 48px;font-size:.78rem}
  /* Backdrop when menu is open */
  .mobile-nav-toggle-input:checked ~ nav.primary::before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:-1}
  /* Keep Get a Quote button visible in header on small tablets */
  header .btn{font-size:.66rem;padding:10px 16px;letter-spacing:.16em}
}
@media (max-width:600px){
  /* Move the quote button INTO the mobile menu since it no longer fits */
  header > .wrap > .btn{display:none}
  nav.primary > ul::after{content:"";display:block;padding:28px;margin-top:16px;border-top:1px solid var(--line)}
  nav.primary > ul > li.mobile-quote{display:block;padding:20px 28px}
  nav.primary > ul > li.mobile-quote a{background:var(--gold);color:#0b0b0b;padding:14px 26px;text-align:center;display:block;font-weight:600;letter-spacing:.18em;font-size:.72rem}
}

/* ============================================================
   MOBILE-FRIENDLY ADDENDUM (added 2026-04-28)
   Additive only - does not modify or remove existing rules.
   Targets: tap-target sizing, text scaling, overflow control,
   small-screen typography, iOS auto-resize prevention.
   ============================================================ */

html { -webkit-text-size-adjust: 100%; text-size-adjust: 100%; }
body { overflow-x: hidden; }
img, video, picture, svg, iframe { max-width: 100%; height: auto; }
table { max-width: 100%; }
pre, code { max-width: 100%; overflow-x: auto; word-wrap: break-word; }

/* Touch / tap optimization on all interactive elements */
a, button, .btn, input[type="submit"], input[type="button"], input[type="checkbox"], input[type="radio"], select, summary, [role="button"] {
  touch-action: manipulation;
}

/* Min 44x44 tap targets on small screens (Apple HIG + WCAG 2.1 AA) */
@media (max-width: 768px) {
  a.btn, button, .btn, input[type="submit"], input[type="button"] {
    min-height: 44px;
    padding-top: 12px;
    padding-bottom: 12px;
  }
  nav.primary > ul > li > a,
  nav.primary .submenu a,
  footer.site a {
    min-height: 44px;
    display: flex;
    align-items: center;
  }
  /* Prevent any element from forcing horizontal scroll */
  .wrap, main, section, article, footer { max-width: 100vw; }
  /* Tighten container padding on narrow screens so content does not get crushed against borders */
  .wrap { padding-left: 16px !important; padding-right: 16px !important; }
}

/* Phone-sized screens (iPhone SE through iPhone 16 Pro) */
@media (max-width: 480px) {
  body { font-size: 16px; line-height: 1.55; }
  h1 { font-size: clamp(1.8rem, 8vw, 2.6rem); line-height: 1.2; }
  h2 { font-size: clamp(1.4rem, 6.5vw, 2rem); line-height: 1.25; }
  h3 { font-size: clamp(1.15rem, 5vw, 1.5rem); }
  p, li, blockquote { font-size: 1rem; }
  /* Hero typography on phones */
  .hero h1 { font-size: clamp(2rem, 8vw, 3rem) !important; }
  .hero .copy { padding: 60px 24px !important; }
  .page-hero h1 { font-size: clamp(1.8rem, 7vw, 2.6rem) !important; }
  /* Service-detail sidebar drops below content */
  .service-detail .sidebar { position: static !important; margin-top: 32px; }
  /* Pad service cards a touch more */
  .service-card, .testimonial { padding: 24px 22px !important; }
  /* Footer columns full width and breathable */
  footer.site .col h4 { margin-top: 24px; }
}

/* Very narrow / older small phones (320px-360px) */
@media (max-width: 360px) {
  h1 { font-size: 1.7rem; }
  h2 { font-size: 1.3rem; }
  .btn { font-size: .68rem; padding: 12px 18px; }
  .wrap { padding-left: 14px !important; padding-right: 14px !important; }
}

/* Footer trademark logo - prevent left-edge cutoff on mobile.
   Inline style on the <img> uses margin:0 0 24px -40px which pushes the logo 40px
   to the left of its column. On mobile-width footer columns the negative offset
   moves the logo partially off-screen. Override the negative margin and shrink size
   on mobile only; desktop placement intact. */
@media (max-width: 768px) {
  footer.site .col.brand img[src*="site_logo-2.png"] {
    margin-left: 0 !important;
    width: 90px !important;
  }
}


/* Related Articles section on blog posts */
.related-articles{margin-top:64px;padding-top:48px;border-top:1px solid var(--line)}
.related-articles h2{font-family:var(--serif);font-size:1.6rem;color:var(--ink);margin-bottom:24px}
.related-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.related-article-card{display:block;padding:24px;background:var(--bg-panel);border:1px solid var(--line);text-decoration:none;transition:border-color .2s ease,transform .2s ease}
.related-article-card:hover{border-color:var(--gold);transform:translateY(-2px)}
.related-article-card h3{font-family:var(--serif);font-size:1.15rem;color:var(--ink);margin-bottom:10px;line-height:1.3}
.related-article-card p{font-size:.86rem;color:var(--ink-soft);line-height:1.55;margin-bottom:14px;max-width:unset}
.related-cta{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-weight:700}
@media (max-width:768px){.related-grid{grid-template-columns:1fr}}
/* LA page: portrait variant for the .two-col bottom image */
.two-col .art.art-portrait{aspect-ratio:2/3}
