/* Wozoli Contractors — bespoke stylesheet (v3) */
:root{
  --ink:#0e0b1a; --ink-2:#1a1530;
  --paper:#f6f3ec; --paper-2:#ece6d8;
  --line:rgba(14,11,26,.10);
  --muted:#5a5468;
  --brand:#5b2a86; --brand-2:#7d3fb0; --brand-deep:#3a1657;
  --gold:#c69b4a; --gold-2:#e3c07a;
  --wa:#25D366; --wa-2:#128C7E;
  --shadow-1:0 1px 2px rgba(14,11,26,.06), 0 8px 24px rgba(14,11,26,.06);
  --shadow-2:0 30px 60px -20px rgba(58,22,87,.35);
  --radius:14px; --radius-lg:22px; --maxw:1240px;
  --serif:"Fraunces","Cormorant Garamond",Georgia,serif;
  --display:"Manrope","Inter","Helvetica Neue",Arial,sans-serif;
  --sans:"Inter","Helvetica Neue",Arial,sans-serif;
}
[data-theme="dark"]{
  --ink:#f3eee3; --ink-2:#e6dfd1;
  --paper:#0e0b1a; --paper-2:#171127;
  --line:rgba(243,238,227,.12);
  --muted:#b3acbe;
  --brand:#a479d6; --brand-2:#c8a4ec; --brand-deep:#221036;
  --shadow-1:0 1px 2px rgba(0,0,0,.4), 0 8px 24px rgba(0,0,0,.35);
  --shadow-2:0 30px 60px -20px rgba(0,0,0,.6);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0; font-family:var(--sans); color:var(--ink); background:var(--paper);
  font-size:16px; line-height:1.6; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;}
img{max-width:100%; display:block; height:auto}
a{color:var(--brand); text-decoration:none} a:hover{color:var(--brand-2)}
.container{max-width:var(--maxw); margin:0 auto; padding:0 28px}
@media (max-width:720px){ .container{padding:0 20px} }
section{padding:84px 0}
h1,h2,h3,h4{font-family:var(--serif); font-weight:600; color:var(--ink); letter-spacing:-.01em; line-height:1.15; margin:0 0 .6em}
h1{font-size:clamp(2.1rem, 5vw + .5rem, 4.4rem); font-weight:500}
h2{font-size:clamp(1.7rem, 2.2vw + 1rem, 2.8rem)}
h3{font-size:1.35rem}
p{margin:0 0 1em}
ul.bullet{padding-left:1.1rem; color:var(--muted)} ul.bullet li{margin:.35rem 0}
.muted{color:var(--muted)} .small{font-size:.88rem} .mt-0{margin-top:0}

.eyebrow{display:inline-flex; align-items:center; gap:.55rem; font-family:var(--display);
  font-size:.78rem; font-weight:700; text-transform:uppercase; letter-spacing:.22em; color:var(--brand);}
.eyebrow::before{content:""; width:28px; height:1px; background:var(--brand)}
.lede{font-size:1.075rem; color:var(--muted); max-width:62ch}

/* Buttons */
.btn{display:inline-flex; align-items:center; gap:.55rem; padding:.9rem 1.35rem;
  border-radius:999px; font-weight:600; font-size:.94rem; border:1px solid transparent;
  cursor:pointer; transition:all .25s ease; font-family:var(--display);}
.btn-primary{background:var(--ink); color:var(--paper)}
.btn-primary:hover{background:var(--brand); color:#fff; transform:translateY(-1px)}
.btn-ghost{background:transparent; color:var(--ink); border-color:var(--ink)}
.btn-ghost:hover{background:var(--ink); color:var(--paper)}
.btn-wa{background:var(--wa); color:#fff; border-color:var(--wa)}
.btn-wa:hover{background:var(--wa-2); color:#fff; transform:translateY(-1px)}

/* Header */
.site-header{position:sticky; top:0; z-index:50;
  background:color-mix(in oklab, var(--paper) 92%, transparent);
  backdrop-filter:saturate(140%) blur(10px); -webkit-backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--line);}
.nav{display:flex; align-items:center; justify-content:space-between; padding:14px 0; gap:1rem}
.brand{display:flex; align-items:center; gap:.7rem; min-width:0}
.brand img{height:44px; width:auto}
.brand-text{display:flex; flex-direction:column; line-height:1}
.brand-text b{font-family:var(--serif); font-size:1.15rem; color:var(--ink); letter-spacing:.02em}
.brand-text span{font-size:.7rem; color:var(--muted); letter-spacing:.12em; text-transform:uppercase; margin-top:3px}
.nav-links{display:flex; align-items:center; gap:.25rem; list-style:none; padding:0; margin:0}
.nav-links a{color:var(--ink); padding:.55rem .85rem; border-radius:8px; font-weight:500; font-size:.93rem; font-family:var(--display); position:relative}
.nav-links a:hover{color:var(--brand); background:color-mix(in oklab, var(--brand) 8%, transparent)}
.nav-links a.active{color:var(--brand)}
.nav-links a.active::after{content:""; position:absolute; left:14px; right:14px; bottom:6px; height:2px; background:var(--brand); border-radius:2px;}
.nav-cta{display:flex; align-items:center; gap:.5rem}
.icon-btn{width:40px; height:40px; border-radius:50%; border:1px solid var(--line);
  background:transparent; color:var(--ink); display:inline-flex; align-items:center; justify-content:center; cursor:pointer; transition:all .2s;}
.icon-btn:hover{background:var(--ink); color:var(--paper)}
.hamburger{display:none; width:46px; height:46px; border-radius:50%; border:1px solid var(--line);
  background:var(--paper); cursor:pointer; padding:0; align-items:center; justify-content:center; position:relative; z-index:75; transition:background .25s, transform .35s}
.hamburger span{display:block; width:18px; height:2px; background:var(--ink); position:relative; transition:.25s}
.hamburger span::before, .hamburger span::after{content:""; position:absolute; left:0; width:18px; height:2px; background:var(--ink); transition:.25s}
.hamburger span::before{top:-6px} .hamburger span::after{top:6px}
body.menu-open .hamburger{background:var(--brand)}
body.menu-open .hamburger span,
body.menu-open .hamburger span::before,
body.menu-open .hamburger span::after{background:#fff}
.scroll-bar{position:fixed; left:0; top:0; height:3px; width:0%; background:linear-gradient(90deg,var(--brand),var(--gold)); z-index:60; transition:width .1s}

/* Mobile arc menu */
.mobile-menu{position:fixed; inset:0; z-index:70; pointer-events:none; overflow:hidden;
  background:radial-gradient(circle at calc(100% - 46px) 36px, color-mix(in oklab, var(--brand-deep) 92%, transparent) 0%, color-mix(in oklab, var(--ink) 88%, transparent) 55%, transparent 110%);
  opacity:0; transition:opacity .35s ease;}
body.menu-open .mobile-menu{opacity:1; pointer-events:auto}
.mobile-menu a, .mobile-menu .m-cta a{
  position:absolute; top:36px; right:46px;
  display:inline-flex; align-items:center; justify-content:center;
  min-width:60px; height:60px; padding:0 16px; border-radius:999px;
  background:#fff; color:#0e0b1a; font-family:var(--display); font-size:.92rem; font-weight:600;
  box-shadow:0 14px 30px rgba(0,0,0,.35); border:0; white-space:nowrap;
  opacity:0; transform:translate(0,0) scale(.5); pointer-events:none;
  transition:transform .55s cubic-bezier(.34,1.56,.5,1), opacity .35s ease;}
[data-theme="dark"] .mobile-menu a, [data-theme="dark"] .mobile-menu .m-cta a{background:#f6f3ec; color:#0e0b1a;}
.mobile-menu .m-cta{display:contents}
body.menu-open .mobile-menu a, body.menu-open .mobile-menu .m-cta a{opacity:1; pointer-events:auto}
.mobile-menu > a:nth-of-type(1){--ang:96deg;  --r:135px}
.mobile-menu > a:nth-of-type(2){--ang:112deg; --r:175px}
.mobile-menu > a:nth-of-type(3){--ang:128deg; --r:205px}
.mobile-menu > a:nth-of-type(4){--ang:144deg; --r:220px}
.mobile-menu > a:nth-of-type(5){--ang:160deg; --r:220px}
.mobile-menu > a:nth-of-type(6){--ang:176deg; --r:205px}
.mobile-menu .m-cta a:nth-of-type(1){--ang:192deg; --r:170px}
.mobile-menu .m-cta a:nth-of-type(2){--ang:208deg; --r:130px; background:var(--wa); color:#fff}
body.menu-open .mobile-menu a{transform:rotate(var(--ang)) translate(var(--r)) rotate(calc(-1 * var(--ang))) scale(1);}
.mobile-menu > a:nth-of-type(1){transition-delay:.05s}
.mobile-menu > a:nth-of-type(2){transition-delay:.10s}
.mobile-menu > a:nth-of-type(3){transition-delay:.15s}
.mobile-menu > a:nth-of-type(4){transition-delay:.20s}
.mobile-menu > a:nth-of-type(5){transition-delay:.25s}
.mobile-menu > a:nth-of-type(6){transition-delay:.30s}
.mobile-menu .m-cta a:nth-of-type(1){transition-delay:.35s}
.mobile-menu .m-cta a:nth-of-type(2){transition-delay:.40s}
.mobile-menu a:hover{background:var(--brand); color:#fff}
.close-menu{position:absolute; top:18px; right:24px; width:52px; height:52px; border-radius:50%;
  background:#fff; color:#0e0b1a; border:0; font-size:1.6rem; line-height:1; cursor:pointer;
  display:flex; align-items:center; justify-content:center; box-shadow:0 14px 30px rgba(0,0,0,.4);
  opacity:0; transform:scale(.7); transition:opacity .3s ease, transform .35s cubic-bezier(.34,1.56,.5,1) .1s;}
body.menu-open .close-menu{opacity:1; transform:scale(1)}

/* Hero */
.hero{position:relative; min-height:88vh; display:flex; align-items:center; color:#fff; overflow:hidden; isolation:isolate;
  background:#0e0b1a url("/images/hero-bg.jpg") center 30%/cover no-repeat;}
@media (max-width:720px){
  .hero{background-image:url("/images/hero-bg-mobile.jpg"); background-position:center top; min-height:74vh;}
}
.hero::before{content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(115deg, rgba(14,11,26,.88) 0%, rgba(58,22,87,.72) 45%, rgba(14,11,26,.2) 100%), linear-gradient(0deg, rgba(14,11,26,.55), transparent 60%);}
.hero::after{content:""; position:absolute; left:0; right:0; bottom:-1px; height:90px; z-index:-1;
  background:linear-gradient(180deg, transparent, var(--paper));}
.hero .container{padding-top:80px; padding-bottom:80px; max-width:1100px; margin:0 auto}
.hero .eyebrow{color:var(--gold-2)} .hero .eyebrow::before{background:var(--gold-2)}
.hero h1{color:#fff; max-width:18ch}
.hero h1 span.accent{background:linear-gradient(120deg, var(--gold-2) 10%, var(--brand-2) 70%);
  -webkit-background-clip:text; background-clip:text; color:transparent; font-style:italic; font-weight:500;}
.hero p.lede{color:rgba(255,255,255,.85); max-width:48ch}
.hero-cta{display:flex; gap:.7rem; margin-top:28px; flex-wrap:wrap}
.hero .btn-primary{background:#fff; color:var(--brand-deep)}
.hero .btn-primary:hover{background:var(--gold); color:#1a1305}
.hero .btn-ghost{color:#fff; border-color:rgba(255,255,255,.55)}
.hero .btn-ghost:hover{background:#fff; color:var(--brand-deep)}
.hero-stats{display:flex; gap:36px; margin-top:44px; flex-wrap:wrap}
.hero-stats div{border-left:2px solid var(--gold-2); padding-left:14px}
.hero-stats b{font-family:var(--serif); font-size:1.55rem; display:block; color:#fff}
.hero-stats span{font-size:.74rem; color:rgba(255,255,255,.75); text-transform:uppercase; letter-spacing:.14em}

/* Trust strip */
.trust{border-top:1px solid var(--line); border-bottom:1px solid var(--line); background:var(--paper); padding:22px 0;}
.trust-row{display:flex; flex-wrap:wrap; gap:24px 32px; justify-content:space-between; align-items:center; font-family:var(--display); font-size:.88rem; color:var(--ink-2);}
.ti{display:inline-flex; align-items:center; gap:.6rem}
.ti svg{color:var(--brand)}

/* Section head */
.section-head{margin-bottom:36px}

/* Services grid */
.services-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
.s-card{position:relative; padding:24px; border-radius:var(--radius-lg); border:1px solid var(--line); background:var(--paper); transition:all .3s;}
.s-card:hover{transform:translateY(-3px); box-shadow:var(--shadow-1); border-color:var(--brand)}
.s-card .num{font-family:var(--serif); font-style:italic; color:var(--brand); font-size:1.2rem; margin-bottom:.4rem}
.s-card h3{margin:.4rem 0 .35rem; font-family:var(--serif)}
.s-card p{color:var(--muted); font-size:.93rem; margin:0}

/* Split */
.split{display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center}

/* Coverage grid */
.cov-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:14px}
.cov{padding:18px; border-radius:14px; background:var(--paper); border-left:3px solid var(--brand)}
.cov b{font-family:var(--serif); display:block} .cov span{color:var(--muted); font-size:.86rem}

/* Projects */
.proj-filters{display:flex; flex-wrap:wrap; gap:8px; margin-bottom:26px}
.chip{padding:.55rem 1rem; border-radius:999px; border:1px solid var(--line); background:transparent; cursor:pointer; font-size:.88rem; color:var(--ink); font-family:var(--display);}
.chip.active, .chip:hover{background:var(--ink); color:var(--paper); border-color:var(--ink)}
.proj-grid{display:grid; grid-template-columns:repeat(12,1fr); gap:18px}
.proj{position:relative; border-radius:var(--radius-lg); overflow:hidden; aspect-ratio:4/3; background:var(--ink-2); cursor:zoom-in;}
.proj img{width:100%; height:100%; object-fit:cover; transition:transform .8s ease}
.proj:hover img{transform:scale(1.05)}
.proj .meta{position:absolute; left:0; right:0; bottom:0; padding:18px 20px; background:linear-gradient(0deg, rgba(14,11,26,.85), transparent); color:#fff}
.proj .meta small{display:block; font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold-2); margin-bottom:4px}
.proj .meta b{font-family:var(--serif); font-size:1.05rem; font-weight:500}
.proj.span6{grid-column:span 6} .proj.span4{grid-column:span 4} .proj.span8{grid-column:span 8} .proj.span12{grid-column:span 12}

/* Lightbox */
.lightbox{position:fixed; inset:0; background:rgba(8,5,18,.92); z-index:90; display:none; align-items:center; justify-content:center; padding:24px}
.lightbox.open{display:flex}
.lightbox figure{max-width:1100px; width:100%; margin:0}
.lightbox img{width:100%; max-height:78vh; object-fit:contain; border-radius:10px}
.lightbox figcaption{color:#f3eee3; text-align:center; margin-top:14px; font-family:var(--serif); font-size:1.05rem}
.lightbox .close{position:absolute; top:18px; right:20px; width:42px; height:42px; border-radius:50%; background:#fff; color:#000; border:0; cursor:pointer; font-size:1.4rem}

/* Slider / testimonials */
.slider{position:relative; overflow:hidden; border-radius:var(--radius-lg); box-shadow:var(--shadow-2)}
.slider-track{display:flex; transition:transform .7s cubic-bezier(.65,.05,.2,1)}
.slide{flex:0 0 100%; position:relative; min-height:280px; background:var(--paper-2)}
.t-slide{padding:48px 96px; display:flex; align-items:center; justify-content:center; text-align:center}
.t-slide blockquote{margin:0; max-width:62ch}
.t-slide p{font-family:var(--serif); font-size:1.25rem; line-height:1.55; color:var(--ink); margin:0 0 1rem}
.t-slide cite{display:block; font-style:normal; color:var(--muted); font-size:.92rem; font-family:var(--display)}
.t-slide cite b{display:block; color:var(--ink); font-family:var(--display); font-size:.98rem; font-weight:700; margin-bottom:2px}
.slider .nav-btn{position:absolute; top:50%; transform:translateY(-50%); width:38px; height:38px; border-radius:50%;
  background:rgba(255,255,255,.92); color:#000; border:0; cursor:pointer; font-size:.95rem; z-index:3;
  display:flex; align-items:center; justify-content:center; box-shadow:0 6px 16px rgba(0,0,0,.2);}
.slider .prev{left:10px} .slider .next{right:10px}
.dots{display:flex; gap:8px; justify-content:center; padding:14px 0 0}
.dots button{width:8px; height:8px; border-radius:50%; border:0; background:var(--line); cursor:pointer; padding:0}
.dots button.active{background:var(--brand); width:26px; border-radius:999px}
@media (max-width:720px){
  .slider .nav-btn{width:30px; height:30px; font-size:.78rem; opacity:.85}
  .t-slide{padding:34px 44px}
  .t-slide p{font-size:1.05rem}
}

/* CTA */
.cta-band{background:linear-gradient(120deg, var(--brand-deep), var(--brand) 70%, var(--gold) 140%);
  color:#fff; border-radius:28px; padding:44px; display:flex; align-items:center; justify-content:space-between; gap:32px; box-shadow:var(--shadow-2);}
.cta-band h2{color:#fff; margin:0}
.cta-band p{color:rgba(255,255,255,.85); max-width:50ch; margin:.5rem 0 0}
.cta-band .btn-primary{background:#fff; color:var(--brand-deep)}
.cta-band .btn-primary:hover{background:var(--gold); color:var(--brand-deep)}

/* Forms */
.form{display:grid; grid-template-columns:1fr 1fr; gap:14px; position:relative}
.form .full{grid-column:span 2}
.field{display:flex; flex-direction:column; gap:6px}
.field label{font-size:.82rem; color:var(--muted); letter-spacing:.04em; font-family:var(--display); font-weight:600}
.field label .count{color:var(--muted); font-weight:400}
.field input, .field textarea, .field select{
  width:100%; padding:.9rem 1rem; border-radius:12px; border:1px solid var(--line);
  background:var(--paper); color:var(--ink); font-family:var(--sans); font-size:1rem; transition:border-color .2s, box-shadow .2s;}
.field input:focus, .field textarea:focus, .field select:focus{
  outline:none; border-color:var(--brand); box-shadow:0 0 0 3px color-mix(in oklab, var(--brand) 22%, transparent);}
.field textarea{min-height:130px; resize:vertical}
.form-small{font-size:.8rem; color:var(--muted); margin:.4rem 0 0}

/* Contact */
.contact-grid{display:grid; grid-template-columns:1.15fr .85fr; gap:36px}
.contact-cards{display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:18px}
.cc{padding:16px; border:1px solid var(--line); border-radius:14px; background:var(--paper-2)}
.cc small{color:var(--muted); font-size:.74rem; letter-spacing:.12em; text-transform:uppercase; font-family:var(--display); font-weight:600}
.cc b{display:block; margin-top:6px; font-family:var(--serif); font-size:1.02rem; color:var(--ink); font-weight:500}
.cc a{color:var(--ink)} .cc a:hover{color:var(--brand)}
.map-wrap{position:relative; aspect-ratio:4/3; border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-2); background:var(--paper-2)}
.map-wrap iframe{position:absolute; inset:0; width:100%; height:100%; border:0}
.wa-invite{margin-top:26px; padding:22px; border-radius:var(--radius-lg);
  background:linear-gradient(135deg, var(--wa) 0%, var(--wa-2) 100%); color:#fff;
  display:flex; gap:16px; align-items:flex-start; box-shadow:0 24px 50px -20px rgba(37,211,102,.45);}
.wa-invite h3, .wa-invite p, .wa-invite .kicker{color:#fff}
.wa-invite p{color:rgba(255,255,255,.92); margin:0 0 12px}
.wa-invite .kicker{font-size:.7rem; letter-spacing:.24em; text-transform:uppercase; opacity:.85; display:block; margin-bottom:6px; font-family:var(--display); font-weight:700}
.wa-invite .wa-icon{flex-shrink:0; width:54px; height:54px; border-radius:50%; background:rgba(255,255,255,.18); display:flex; align-items:center; justify-content:center;}
.wa-invite .btn-wa{background:#fff; color:var(--wa-2); border-color:#fff}
.wa-invite .btn-wa:hover{background:#0e0b1a; color:#fff; border-color:#0e0b1a}

/* Careers */
.apply-card{padding:28px; border-radius:var(--radius-lg); background:var(--paper-2); border:1px solid var(--line);}
.apply-card .kicker{font-size:.72rem; letter-spacing:.22em; text-transform:uppercase; color:var(--brand); font-family:var(--display); font-weight:700}

/* Footer — compact, columns side by side */
.site-footer{background:linear-gradient(180deg, #1f1638 0%, #120e22 100%); color:#efe9dc; padding:48px 0 24px; margin-top:0;}
[data-theme="dark"] .site-footer{background:linear-gradient(180deg, #281d49 0%, #120e22 100%); color:#f6f0e2;}
.site-footer h4{color:#fff; font-family:var(--serif); font-size:1rem; margin-bottom:.6rem}
.f-grid{display:grid; grid-template-columns:1.4fr 2.4fr; gap:36px; align-items:start}
.f-cols{display:grid; grid-template-columns:repeat(3, 1fr); gap:28px}
.f-grid a{color:#f6f0e2} .f-grid a:hover{color:var(--gold-2)}
.f-grid ul{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:6px; font-size:.9rem}
.f-grid ul li{color:#d9d2c2}
.f-brand p{color:#d9d2c2; font-size:.9rem; max-width:40ch; margin-bottom:14px}
.f-bottom{border-top:1px solid rgba(255,255,255,.14); margin-top:30px; padding-top:18px;
  display:flex; flex-wrap:wrap; gap:14px; justify-content:space-between; color:#b9b2c5; font-size:.82rem}
.f-bottom a{color:#f0e9da}
.socials{display:flex; gap:8px; flex-wrap:wrap}
.socials a{width:34px; height:34px; border-radius:50%; background:rgba(255,255,255,.10); display:inline-flex; align-items:center; justify-content:center; color:#fff;}
.socials a:hover{background:var(--brand)}

/* WhatsApp FAB */
.wa-fab{position:fixed; right:20px; bottom:20px; z-index:55; width:58px; height:58px; border-radius:50%;
  background:var(--wa); color:#fff; display:flex; align-items:center; justify-content:center;
  box-shadow:0 14px 30px rgba(37,211,102,.45); animation:pulse 2.4s infinite;}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,.5)} 70%{box-shadow:0 0 0 18px rgba(37,211,102,0)} 100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}

/* Reveal */
.reveal{opacity:0; transform:translateY(20px); transition:opacity .8s ease, transform .8s ease}
.reveal.in{opacity:1; transform:none}

/* Page hero (inner) — contain image so subject not cropped */
.page-hero{position:relative; padding:96px 0 64px; color:#fff; overflow:hidden; isolation:isolate;
  background:#1a1530 var(--page-hero-img, none) center/cover no-repeat;}
.page-hero::before{content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(115deg, rgba(14,11,26,.92) 0%, rgba(58,22,87,.74) 55%, rgba(14,11,26,.55) 100%);}
.page-hero h1{font-size:clamp(2rem,3.6vw + .5rem,3.4rem); margin-bottom:.4rem; color:#fff; max-width:22ch}
.page-hero .page-lede{font-family:var(--display); font-weight:500; color:rgba(255,255,255,.92); font-size:1.05rem; max-width:54ch; margin:0;}
.page-hero p{color:rgba(255,255,255,.85); max-width:60ch}
.page-hero .eyebrow{color:var(--gold-2)} .page-hero .eyebrow::before{background:var(--gold-2)}
.crumbs{font-size:.84rem; color:rgba(255,255,255,.7); margin-bottom:.8rem; font-family:var(--display)}
.crumbs a{color:rgba(255,255,255,.8)} .crumbs a:hover{color:var(--gold-2)}
.hero-search{margin-top:18px; max-width:520px}
.hero-search input{width:100%; padding:.9rem 1rem; border-radius:14px; border:1px solid rgba(255,255,255,.25); background:rgba(255,255,255,.08); color:#fff; font-size:1rem}
.hero-search input::placeholder{color:rgba(255,255,255,.6)}

/* About values */
.values{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
.value{padding:24px; border-left:3px solid var(--brand); background:var(--paper); border-radius:0 14px 14px 0; box-shadow:var(--shadow-1)}
.value h4{font-family:var(--serif); margin:0 0 .3rem}
.value p{color:var(--muted); margin:0; font-size:.95rem}

/* Editorial home */
.editorial{display:grid; grid-template-columns:1.05fr .95fr; gap:56px; align-items:start}
.editorial .ed-lead{position:sticky; top:90px}
.editorial .ed-lead .big-num{font-family:var(--serif); font-style:italic; font-weight:500; font-size:clamp(5rem,12vw,9.5rem); line-height:.85;
  background:linear-gradient(135deg,var(--brand) 10%,var(--gold) 90%); -webkit-background-clip:text; background-clip:text; color:transparent; margin:.4rem 0 .6rem;}
.editorial .ed-feature{position:relative; border-radius:24px; overflow:hidden; aspect-ratio:4/5; box-shadow:var(--shadow-2)}
.editorial .ed-feature img{width:100%; height:100%; object-fit:cover; transition:transform 1.4s ease}
.editorial .ed-feature:hover img{transform:scale(1.04)}
.editorial .ed-feature .tag{position:absolute; left:18px; top:18px; padding:.45rem .8rem; border-radius:999px; background:rgba(14,11,26,.55); color:#fff; font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; backdrop-filter:blur(8px);}
.editorial .ed-feature .ed-cap{position:absolute; left:0; right:0; bottom:0; padding:24px 26px; color:#fff; background:linear-gradient(0deg, rgba(0,0,0,.85), transparent);}
.editorial .ed-feature .ed-cap b{font-family:var(--serif); font-size:1.2rem; font-weight:500; display:block}
.editorial .ed-feature .ed-cap small{display:block; letter-spacing:.16em; font-size:.7rem; text-transform:uppercase; color:var(--gold-2); margin-bottom:6px}
.ed-list{list-style:none; padding:0; margin:28px 0 0; border-top:1px solid var(--line)}
.ed-list li{border-bottom:1px solid var(--line)}
.ed-list a{display:grid; grid-template-columns:64px 1fr auto; gap:18px; align-items:center; padding:18px 4px; color:var(--ink); transition:padding .3s ease, color .25s ease;}
.ed-list a:hover{padding-left:14px; color:var(--brand)}
.ed-list .n{font-family:var(--serif); font-style:italic; color:var(--brand); font-size:1.15rem}
.ed-list .t{font-family:var(--serif); font-size:1.3rem; font-weight:500; line-height:1.2}
.ed-list .t em{font-style:normal; display:block; font-family:var(--sans); font-size:.86rem; color:var(--muted); margin-top:4px; font-weight:400}
.ed-list .ar{width:38px; height:38px; border-radius:50%; border:1px solid var(--line); display:inline-flex; align-items:center; justify-content:center; transition:all .25s;}
.ed-list a:hover .ar{background:var(--brand); border-color:var(--brand); color:#fff; transform:rotate(-45deg)}

/* Responsive */
@media (max-width: 980px){
  section{padding:60px 0}
  .hero{min-height:78vh} .hero .container{padding-top:48px; padding-bottom:60px}
  .hero-stats{gap:22px; margin-top:32px}
  .page-hero{padding:80px 0 50px; background-size:cover;
    background-image:var(--page-hero-img-mobile, var(--page-hero-img, none))}
  .split{grid-template-columns:1fr; gap:36px}
  .services-grid{grid-template-columns:1fr 1fr}
  .values{grid-template-columns:1fr}
  .cov-grid{grid-template-columns:repeat(2,1fr)}
  .editorial{grid-template-columns:1fr; gap:36px}
  .editorial .ed-lead{position:static}
  .editorial .ed-feature{aspect-ratio:4/3}
  .cta-band{flex-direction:column; align-items:flex-start; padding:30px}
  .contact-grid{grid-template-columns:1fr}
  .proj.span4, .proj.span6, .proj.span8{grid-column:span 6}
  .proj.span12{grid-column:span 12}
  .f-grid{grid-template-columns:1fr; gap:24px}
}
@media (max-width: 720px){
  .nav-links, .hide-sm{display:none}
  .hamburger{display:inline-flex}
  .services-grid{grid-template-columns:1fr}
  .form{grid-template-columns:1fr} .form .full{grid-column:span 1}
  .contact-cards{grid-template-columns:1fr 1fr}
  .f-cols{grid-template-columns:repeat(2,1fr)}
  .proj.span4, .proj.span6, .proj.span8, .proj.span12{grid-column:span 12}
  .brand-text{display:none} .brand img{height:44px}
  .site-header .container.nav{padding-left:22px; padding-right:14px}
  .editorial .ed-feature.ed-feature--hero{aspect-ratio:3/4; border-radius:18px; margin:0 -4px}
  .editorial .ed-feature.ed-feature--hero img{filter:none}
  h1{font-size:clamp(2rem,7vw,2.55rem)}
}
@media (max-width: 420px){
  .contact-cards{grid-template-columns:1fr}
  .f-cols{grid-template-columns:1fr 1fr}
}
@media (prefers-reduced-motion: reduce){*{animation:none !important; transition:none !important} html{scroll-behavior:auto}}

/* Anniversary modal */
.anniv-modal{position:fixed; inset:0; z-index:120; background:rgba(8,5,18,.78); backdrop-filter:blur(6px);
  display:none; align-items:center; justify-content:center; padding:18px; opacity:0; transition:opacity .35s ease;}
.anniv-modal.show{display:flex; opacity:1}
.anniv-card{position:relative; max-width:520px; width:100%; overflow:hidden; border-radius:24px;
  padding:40px 32px 32px; text-align:center; color:#fff;
  background:radial-gradient(circle at 80% 0%, rgba(255,255,255,.20), transparent 55%),
             radial-gradient(circle at 0% 100%, rgba(198,155,74,.35), transparent 55%),
             linear-gradient(140deg, #2a0f44 0%, #5b2a86 55%, #8a4cc0 100%);
  box-shadow:0 40px 80px -20px rgba(0,0,0,.6), inset 0 0 0 1px rgba(255,255,255,.08);
  transform:translateY(20px) scale(.96); transition:transform .5s cubic-bezier(.34,1.56,.5,1);}
.anniv-modal.show .anniv-card{transform:none}
.anniv-card::before{content:""; position:absolute; inset:12px; border-radius:18px; border:1px dashed rgba(255,255,255,.25); pointer-events:none;}
.anniv-card .ten{font-family:var(--serif); font-style:italic; font-weight:500; font-size:4.6rem; line-height:1; margin:0 0 4px;
  background:linear-gradient(135deg, var(--gold-2), #fff 70%, var(--gold-2)); -webkit-background-clip:text; background-clip:text; color:transparent;}
.anniv-card .ten sup{font-size:1.4rem; margin-left:6px; -webkit-text-fill-color:#fff}
.anniv-card .kicker{display:inline-block; font-family:var(--display); font-size:.7rem; letter-spacing:.26em; text-transform:uppercase;
  color:var(--gold-2); padding:5px 12px; border:1px solid rgba(255,255,255,.25); border-radius:999px; margin-bottom:14px; font-weight:700;}
.anniv-card h2{color:#fff; font-family:var(--serif); font-weight:500; font-size:1.45rem; margin:0 0 .35em; max-width:24ch; margin-left:auto; margin-right:auto}
.anniv-card p{color:rgba(255,255,255,.88); margin:0 0 18px; font-size:.95rem}
.anniv-card .years{font-family:var(--serif); letter-spacing:.18em; font-size:.78rem; color:var(--gold-2); margin-bottom:14px;}
.anniv-card .years span{margin:0 8px; opacity:.6}
.anniv-card .anniv-actions{display:flex; gap:10px; flex-wrap:wrap; justify-content:center}
.anniv-card .btn{padding:.8rem 1.2rem}
.anniv-card .btn-ghost{background:transparent; color:#fff; border-color:rgba(255,255,255,.45)}
.anniv-card .btn-ghost:hover{background:#fff; color:var(--brand-deep)}
.anniv-card .close-anniv{position:absolute; top:12px; right:12px; width:34px; height:34px; border-radius:50%; border:0;
  background:rgba(0,0,0,.30); color:#fff; cursor:pointer; font-size:1.1rem; display:flex; align-items:center; justify-content:center;}
.anniv-card .close-anniv:hover{background:rgba(0,0,0,.55)}
@media (max-width:520px){
  .anniv-card{padding:30px 20px 22px; border-radius:20px}
  .anniv-card .ten{font-size:3.4rem; margin-bottom:2px}
  .anniv-card .ten sup{font-size:1.1rem}
  .anniv-card .kicker{margin-bottom:10px}
  .anniv-card h2{font-size:1.2rem; margin-bottom:.3em}
  .anniv-card p{font-size:.88rem; margin-bottom:12px}
  .anniv-card .years{margin-bottom:10px; font-size:.72rem}
  .anniv-card .anniv-actions .btn{padding:.7rem 1rem; font-size:.88rem}
}


/* Consent checkbox */
.consent-label{display:flex; align-items:flex-start; gap:.6rem; font-size:.92rem; line-height:1.4; cursor:pointer;}
.consent-label input[type=checkbox]{width:18px; height:18px; margin-top:2px; accent-color:var(--brand); flex-shrink:0; cursor:pointer;}
.field.consent{margin-top:4px;}
.btn[disabled]{opacity:.45; cursor:not-allowed; pointer-events:none;}
.f-bottom a{color:#f0e9da; text-decoration:underline; text-underline-offset:3px;}
.f-bottom a:hover{color:#fff}

/* Privacy page typography */
.legal h2{margin-top:2rem}
.legal p, .legal li{color:var(--ink-2); line-height:1.7}
.legal ul{padding-left:1.2rem; margin:.4rem 0 1rem}

/* Email departments — footer compact */
.email-dept{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:10px}
.email-dept li{display:flex; flex-direction:column; gap:2px; padding:8px 12px; border-left:2px solid var(--gold-2); background:rgba(255,255,255,.04); border-radius:6px}
.email-dept li b{color:#fff; font-family:var(--display); font-size:.78rem; letter-spacing:.08em; text-transform:uppercase}
.email-dept li a{color:#f6f0e2; font-size:.86rem; word-break:break-all}
.email-dept li small{color:#b9b2c5; font-size:.74rem}

/* Email departments — contact page detailed grid */
.email-departments{padding-top:8px}
.dept-grid{display:grid; grid-template-columns:repeat(2,1fr); gap:14px}
.dept{padding:18px; border:1px solid var(--line); border-radius:14px; background:var(--paper); transition:all .25s}
.dept:hover{border-color:var(--brand); transform:translateY(-2px); box-shadow:var(--shadow-1)}
.dept small{color:var(--brand); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; font-family:var(--display); font-weight:700; display:block; margin-bottom:6px}
.dept h3{font-family:var(--serif); font-size:1.05rem; font-weight:600; margin:0 0 8px; word-break:break-all; line-height:1.3}
.dept h3 span{color:var(--muted); font-weight:400}
.dept p{color:var(--muted); font-size:.86rem; margin:0 0 12px}
.dept .btn{padding:.55rem .9rem; font-size:.82rem}
@media (max-width:720px){ .dept-grid{grid-template-columns:1fr} }

/* Hero contextual blurb (services page) */
.hero-contextual{font-size:.88rem; color:rgba(255,255,255,.85); margin:14px 0 0; max-width:520px}
.hero-contextual a{color:var(--gold-2); text-decoration:underline; text-underline-offset:3px}

/* === Final patch: footer wrapping, featured image overlay & sizing === */
.site-footer .contact-list a,
.site-footer .email-dept a{ word-break: break-word; overflow-wrap:anywhere; }
.site-footer .contact-list li,
.site-footer .email-dept li{ overflow-wrap:anywhere; word-break:break-word; }
.site-footer .f-cols{ display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
@media (max-width: 880px){
  .site-footer .f-cols{ grid-template-columns:1fr 1fr; gap:22px; }
  .site-footer .f-cols > div:last-child{ grid-column:1 / -1; }
}
@media (max-width: 520px){
  .site-footer .f-cols{ grid-template-columns:1fr; }
  .site-footer .container{ padding-left:18px; padding-right:18px; }
}

/* Featured "Our team" image: mask low-quality source + scale down on mobile */
.editorial .ed-feature--hero{ position:relative; }
.editorial .ed-feature--hero img{
  filter: saturate(1.05) contrast(1.04);
}
.editorial .ed-feature--hero::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:
    radial-gradient(120% 80% at 50% 30%, transparent 40%, rgba(14,11,26,.45) 100%),
    linear-gradient(180deg, rgba(91,42,134,.18) 0%, rgba(14,11,26,.55) 100%);
  mix-blend-mode: multiply;
}
.editorial .ed-feature--hero::before{
  content:""; position:absolute; inset:0; pointer-events:none; z-index:1;
  box-shadow: inset 0 0 80px rgba(14,11,26,.55);
  border-radius:inherit;
}
@media (max-width: 760px){
  .editorial .ed-feature.ed-feature--hero{
    aspect-ratio: 4/3;
    max-width: 88%;
    margin: 0 auto;
    border-radius: 14px;
  }
}
