﻿:root{
  --yellow:#FFE600;
  --black:#0A0A0A;
  --white:#FFFFFF;
  --offwhite:#FBFAF4;
  --grey-card:#F4F2EA;
  --grey-text:#555555;
  --muted:#9B9580;
  --gold:#C9A400;
  --radius-sm:6px;
  --radius-md:10px;
  --radius-lg:16px;
  --radius-pill:100px;
  --font:'Helvetica Neue',Arial,sans-serif;
  --serif:Georgia,'Times New Roman',serif;
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:var(--font);color:var(--black);background:var(--white);line-height:1.5;}
.container{max-width:1200px;margin:0 auto;padding:0 24px;}
a{color:inherit;text-decoration:none;}
ul{list-style:none;}
img{max-width:100%;display:block;}
h1,h2,h3{font-family:var(--font);font-weight:800;line-height:1.15;}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:6px;font-weight:700;font-size:14px;padding:13px 22px;border-radius:var(--radius-pill);border:none;cursor:pointer;transition:transform .15s ease, background .15s ease;text-align:center;font-variant-emoji:text;}
.arrow,.btn,.nav-cta,.direct-line{font-variant-emoji:text;}
.btn:hover{transform:translateY(-1px);}
.btn:active{transform:scale(0.97);}
.btn-dark{background:var(--black);color:var(--yellow);}
.btn-yellow{background:var(--yellow);color:var(--black);}
.btn-outline{background:transparent;border:2px solid var(--black);color:var(--black);}
.btn-pill{border-radius:var(--radius-pill);}

/* Header */
.site-header{position:sticky;top:0;z-index:50;background:var(--yellow);border-bottom:1px solid rgba(10,10,10,.12);}
.nav-row{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;gap:24px;}
.logo{font-weight:800;font-size:16px;letter-spacing:.5px;white-space:nowrap;}
.logo-accent{font-weight:400;opacity:.7;}

.main-nav ul{display:flex;align-items:center;gap:22px;}
.nav-link{font-size:14px;font-weight:700;background:none;border:none;cursor:pointer;color:var(--black);display:inline-flex;align-items:center;gap:4px;}
.has-dropdown{position:relative;}
.caret{font-size:10px;}

.dropdown-panel{
  position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(-8px);
  width:560px;background:#FFFDF2;border:1px solid #F0E8B0;border-radius:var(--radius-lg);
  box-shadow:0 18px 40px rgba(0,0,0,.12);opacity:0;visibility:hidden;transition:opacity .2s ease, transform .2s ease;
  padding:26px;z-index:60;
}
.has-dropdown:hover .dropdown-panel,
.has-dropdown:focus-within .dropdown-panel,
.has-dropdown.dropdown-open .dropdown-panel{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);}
.dropdown-inner{display:block;}
.dropdown-list{flex:1.1;display:flex;flex-direction:column;gap:10px;}
.dropdown-label{font-size:11px;font-weight:700;color:var(--gold);letter-spacing:1px;margin-bottom:6px;}
.dropdown-item{font-size:17px;font-weight:700;color:var(--black);display:flex;align-items:center;gap:6px;}
.dropdown-item:hover{color:var(--gold);}
.dropdown-item .arrow{font-size:13px;}
.all-services{margin-top:8px;font-size:13px;font-weight:700;text-decoration:underline;text-decoration-color:var(--yellow);text-underline-offset:5px;}
.dropdown-image{display:none;}

.nav-actions{display:flex;align-items:center;gap:12px;flex-shrink:0;}
.lang-dropdown{position:relative;}
.lang-btn{font-size:11px;font-weight:800;letter-spacing:.5px;color:var(--black);background:none;border:1.5px solid rgba(10,10,10,.22);border-radius:100px;padding:5px 13px;cursor:pointer;display:flex;align-items:center;gap:4px;white-space:nowrap;transition:border-color .15s,background .15s;}
.lang-btn:hover{border-color:var(--black);background:rgba(10,10,10,.04);}
.lang-btn .caret{font-size:9px;transition:transform .2s;}
.lang-dropdown.open .lang-btn .caret{transform:rotate(180deg);}
.lang-menu{display:none;position:absolute;right:0;top:calc(100% + 8px);background:#fff;border:1px solid #e8e3d8;border-radius:10px;box-shadow:0 4px 20px rgba(0,0,0,.1);min-width:110px;overflow:hidden;z-index:300;}
.lang-dropdown.open .lang-menu{display:block;}
.lang-menu a{display:block;padding:9px 16px;font-size:13px;font-weight:600;color:#111;text-decoration:none;transition:background .12s;}
.lang-menu a:hover{background:#f5f2ea;}
.lang-menu a.lang-active{font-weight:800;}
.nav-cta{flex-shrink:0;}
.mobile-menu-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;}
.mobile-menu-toggle span{width:22px;height:2px;background:var(--black);display:block;}
.mobile-nav{display:none;flex-direction:column;background:var(--yellow);border-top:1px solid rgba(10,10,10,.12);padding:16px 24px 22px;gap:14px;}
.mobile-nav a{font-size:15px;font-weight:700;}
.mobile-nav.open{display:flex;}
.mobile-services-trigger{background:none;border:none;font-size:15px;font-weight:700;color:var(--black);text-align:left;padding:0;cursor:pointer;display:flex;justify-content:space-between;width:100%;}
.mobile-services-submenu{display:none;flex-direction:column;gap:10px;padding:12px 0 0 14px;}
.mobile-services-submenu.open{display:flex;}
.mobile-services-submenu a{font-size:13px;font-weight:600;opacity:.8;}

/* Hero */
.hero{background:var(--yellow);padding:60px 0 0;overflow:hidden;}
/* ── HERO V2 ── */
.hero-v2{position:relative;min-height:340px;display:flex;flex-direction:column;justify-content:center;background:var(--black);overflow:hidden;}
.hero-v2-bg{position:absolute;inset:0;}
.hero-v2-bgimg{width:100%;height:100%;object-fit:cover;object-position:center center;opacity:.65;}
.hero-v2-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(10,10,10,.75) 0%,rgba(10,10,10,.45) 60%,rgba(10,10,10,.05) 100%);}
.hero-v2-inner{position:relative;z-index:2;display:flex;flex-direction:column;justify-content:center;padding:60px 0 40px;min-height:340px;}
.hero-v2-copy{max-width:700px;}
.hero-eyebrow-light{display:block;font-size:12px;font-weight:800;letter-spacing:2px;color:var(--yellow);margin-bottom:18px;}
.hero-v2 h1{font-size:clamp(44px,6.5vw,88px);letter-spacing:-2px;line-height:1.0;color:#fff;margin-bottom:22px;}
.hero-v2 .hero-sub{font-size:17px;color:rgba(255,255,255,.7);max-width:560px;line-height:1.65;margin-bottom:34px;}
.hero-v2 .hero-ctas{display:flex;gap:14px;flex-wrap:wrap;}
.btn-yellow{background:var(--yellow);color:var(--black);font-weight:800;}
.btn-yellow:hover{background:#f0d800;}
.btn-outline-light{border:2px solid rgba(255,255,255,.4);color:#fff;font-weight:700;padding:12px 24px;border-radius:100px;transition:border-color .15s;}
.btn-outline-light:hover{border-color:#fff;}
.hero-v2-stats{display:flex;gap:40px;margin-top:56px;flex-wrap:wrap;}
.hstat{display:flex;flex-direction:column;}
.hstat strong{font-size:32px;font-weight:800;color:var(--yellow);line-height:1;}
.hstat span{font-size:11px;font-weight:700;letter-spacing:1px;color:rgba(255,255,255,.5);margin-top:4px;text-transform:uppercase;}

.eyebrow{display:block;font-size:12px;font-weight:700;letter-spacing:1px;color:var(--black);opacity:.6;margin-bottom:10px;}
.eyebrow-light{color:var(--yellow);opacity:1;}
.hero-sub{font-size:16px;max-width:420px;margin-bottom:26px;}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:18px;}
.contact-prompt{font-size:13px;font-weight:600;opacity:.7;margin-bottom:10px;}
.contact-icons{display:flex;gap:10px;}
.icon-btn{width:40px;height:40px;border-radius:50%;background:var(--black);color:var(--yellow);display:flex;align-items:center;justify-content:center;font-size:16px;transition:transform .15s ease;}
.icon-btn:hover{transform:scale(1.08);}
.hero-scene{position:relative;height:320px;background:var(--black);border-radius:var(--radius-lg);overflow:hidden;}
.hero-scene-img{display:block;width:100%;height:100%;object-fit:cover;object-position:center;}

.marquee-wrap{overflow:hidden;border-top:1px solid rgba(10,10,10,.15);padding:18px 0;}
.marquee{display:flex;gap:40px;white-space:nowrap;width:max-content;animation:marquee 16s linear infinite;font-size:14px;font-weight:800;opacity:.65;}
.marquee span{padding:0 4px;}
@keyframes marquee{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}

/* Services — sliding panels */
.services-scroll{padding:70px 0 0;background:var(--white);}
.section-label{font-family:var(--serif);font-size:24px;font-weight:700;margin-bottom:10px;}
.section-intro{font-size:14px;color:var(--grey-text);max-width:480px;margin-bottom:0;}

.scroll-pin-wrap{position:relative;height:400vh;}
.scroll-pin{position:sticky;top:0;height:100vh;display:flex;align-items:center;background:var(--white);overflow:hidden;width:100%;}
.pin-shell{display:flex;flex-direction:column;align-items:flex-start;width:100%;}

.slide-track{display:flex;width:400%;flex-shrink:0;transition:transform .5s cubic-bezier(.65,0,.35,1);}
.slide{width:25%;flex-shrink:0;}
.pin-shell > .container{width:100%;flex-shrink:0;}
.slide-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch;height:calc(100vh - 160px);max-height:560px;}

.slide-visual{position:relative;overflow:hidden;border-radius:20px;background:#111;min-height:320px;}
.slide-visual-img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;border-radius:20px;}

.slide-text-col{display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:0 48px;}
.step-counter{display:block;font-size:12px;font-weight:800;letter-spacing:2px;color:var(--gold);margin-bottom:14px;text-transform:uppercase;}
.slide-text-col h3{font-size:clamp(26px,3.5vw,42px);line-height:1.15;font-weight:800;margin-bottom:16px;}
.slide-text-col p{font-size:15px;color:var(--grey-text);line-height:1.65;max-width:340px;margin-bottom:18px;}
.slide-tags{display:flex;flex-wrap:wrap;gap:8px;}
.slide-tags span{font-size:11px;font-weight:700;letter-spacing:.5px;background:var(--black);color:var(--yellow);padding:5px 14px;border-radius:100px;}

/* legacy slide-left/right — keep for mobile compat */
.slide-left{text-align:right;}
.slide-right p{font-size:15px;color:var(--grey-text);line-height:1.6;}

.dots{display:flex;gap:6px;margin-top:30px;}
.dots span{width:7px;height:7px;border-radius:50%;background:#ddd;cursor:pointer;}
.dots span.active{background:var(--black);}

/* Work + media */
.work-media{padding:70px 0;background:var(--offwhite);}
.case-marquee-wrap, .media-marquee-wrap{overflow:hidden;margin-top:24px;}
.case-marquee{display:flex;gap:14px;width:max-content;animation:caseScroll 24s linear infinite;padding:0 24px;}
.case-card{width:130px;height:190px;border-radius:14px;flex-shrink:0;background-size:cover;background-position:center;position:relative;overflow:hidden;}
.case-card-label{position:absolute;bottom:0;left:0;right:0;padding:8px 10px;background:linear-gradient(transparent,rgba(0,0,0,.75));color:#fff;font-size:10px;font-weight:800;letter-spacing:.5px;}
.cc-yellow{background-color:var(--yellow);}
.cc-black{background-color:var(--black);}
.cc-grey{background-color:var(--grey-card);}
@keyframes caseScroll{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}

/* Sub-page package highlight block */
.subpage-pkg{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid #E8E6DC;border-bottom:1px solid #E8E6DC;}
.subpage-pkg-photo{position:relative;overflow:hidden;min-height:380px;background:#e8e6dc;}
.subpage-pkg-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;display:block;}
.subpage-pkg-text{display:flex;flex-direction:column;justify-content:center;gap:16px;padding:52px 48px;background:var(--offwhite);}
.subpage-pkg-text .pkg-num{font-size:10px;font-weight:700;letter-spacing:2px;color:#999;text-transform:uppercase;}
.subpage-pkg-text h2{font-size:clamp(22px,2.8vw,36px);font-weight:800;line-height:1.1;color:var(--black);}
.subpage-pkg-text .pkg-desc{font-size:14px;color:#555;line-height:1.65;max-width:380px;}
.subpage-pkg-checklist{list-style:none;display:flex;flex-direction:column;gap:8px;}
.subpage-pkg-checklist li{display:flex;align-items:flex-start;gap:8px;font-size:13px;line-height:1.4;}
.subpage-pkg-checklist .chk{background:var(--yellow);border-radius:50%;width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;font-weight:800;font-size:9px;}
.btn-enquire{display:inline-flex;align-items:center;gap:6px;background:var(--black);color:var(--yellow);font-weight:800;font-size:14px;padding:14px 24px;border-radius:100px;text-decoration:none;width:fit-content;transition:transform .15s;}
.btn-enquire:hover{transform:translateY(-2px);}
@media(max-width:860px){.subpage-pkg{grid-template-columns:1fr;}.subpage-pkg-photo{min-height:240px;}.subpage-pkg-text{padding:36px 24px;}}

/* Global pkg-checklist (used in packages.html inline and now globally) */
.pkg-checklist{list-style:none;display:flex;flex-direction:column;gap:10px;}
.pkg-checklist li{display:flex;align-items:flex-start;gap:10px;font-size:14px;line-height:1.5;}
.chk{background:var(--yellow);border-radius:50%;width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;font-weight:800;font-size:10px;}

.media-block{border-top:1px solid rgba(10,10,10,.1);padding-top:24px;margin-top:40px;}
.media-label{display:block;font-size:11px;font-weight:700;letter-spacing:1px;color:#999;margin-bottom:16px;}
.media-marquee-wrap{overflow:hidden;}
.media-marquee{display:flex;gap:34px;width:max-content;animation:logoScroll 14s linear infinite;font-size:13px;font-weight:800;opacity:.55;}
@keyframes logoScroll{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}

/* Insights preview */
.insights-preview{padding:70px 0;background:var(--white);}
.insights-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:30px;flex-wrap:wrap;}
.see-all{font-size:13px;font-weight:700;text-decoration:underline;text-decoration-color:var(--yellow);text-underline-offset:5px;flex-shrink:0;}
.insights-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;}
.insight-card{display:block;}
.insight-thumb{height:120px;border-radius:var(--radius-md);margin-bottom:12px;background-size:cover;background-position:center;}
.thumb-yellow{background:var(--yellow);}
.thumb-black{background:var(--black);}
.thumb-grey{background:var(--grey-card);}
.insight-cat{display:block;font-size:10px;font-weight:700;color:#999;letter-spacing:.5px;margin-bottom:6px;}
.insight-card h3{font-family:var(--font);font-size:14px;font-weight:700;line-height:1.4;}

/* Footer / contact */
.footer-contact{background:var(--black);color:var(--white);padding:60px 0;}
.contact-top{display:flex;justify-content:space-between;align-items:flex-start;gap:30px;margin:18px 0 30px;flex-wrap:wrap;}
.contact-top h2{font-family:var(--serif);font-size:32px;max-width:420px;}
.contact-top-right{max-width:300px;text-align:right;}
.contact-top-right p{font-size:14px;color:#bbb;margin-bottom:14px;}
.footer-contact hr{border:none;border-top:1px solid rgba(255,255,255,.15);margin-bottom:24px;}
.contact-bottom{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;}
.direct-line{font-size:14px;font-weight:700;margin-bottom:12px;}
.social-row{display:flex;gap:8px;}
.social-circle{width:32px;height:32px;border-radius:50%;background:#1a1a1a;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;cursor:default;}
.capture-form p{font-size:12px;color:#bbb;margin-bottom:8px;}
.capture-fields{display:flex;gap:8px;flex-wrap:wrap;}
.capture-fields input{background:#1a1a1a;border:none;border-radius:6px;padding:10px 12px;font-size:13px;color:#fff;width:110px;}
.capture-fields input::placeholder{color:#777;}
.capture-fields button{background:transparent;border:1px solid rgba(255,255,255,.3);border-radius:6px;width:38px;height:38px;color:#fff;font-size:14px;cursor:pointer;}

/* ===== Shared sub-page components ===== */

/* Simple page hero (About / People / Work list / News list / Service pages) */
.page-hero{background:var(--yellow);padding:60px 0 50px;}
.page-hero .eyebrow{margin-bottom:14px;}
.page-hero h1{font-size:44px;letter-spacing:-1px;max-width:680px;}
.page-hero p.lede{font-size:16px;max-width:560px;margin-top:18px;}
.page-hero.dark{background:var(--black);color:var(--white);}
.page-hero.dark .eyebrow{color:var(--yellow);opacity:1;}

/* Two-column text+image content row (service pages, about) */
.content-row{display:grid;grid-template-columns:1.1fr 1fr;gap:30px;align-items:center;padding:60px 0;}
.content-row.reverse{grid-template-columns:1fr 1.1fr;}
.content-row.reverse .content-media{order:-1;}
.content-row h2{font-family:var(--serif);font-size:26px;margin-bottom:14px;}
.content-row p{font-size:14px;color:var(--grey-text);line-height:1.7;}
.content-media{border-radius:var(--radius-lg);min-height:220px;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;}
.content-media::before{content:'';width:46px;height:46px;border-radius:10px;background:rgba(10,10,10,.08);transform:rotate(45deg);}
.media-yellow{background:var(--yellow);}
.media-yellow::before{background:rgba(10,10,10,.12);}
.media-black{background:var(--black);}
.media-black::before{background:rgba(255,255,255,.12);}
.media-grey{background:var(--grey-card);}

/* Solutions list (service pages) */
.solutions-list{display:flex;flex-direction:column;}
.solutions-list .solution-row{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;padding:18px 0;border-top:1px solid rgba(10,10,10,.1);}
.solutions-list a.solution-row{cursor:pointer;transition:opacity .15s ease;}
.solutions-list a.solution-row:hover{opacity:.7;}
.solutions-list a.solution-row:hover .solution-arrow{background:var(--black);color:var(--yellow);}
.solutions-list .solution-row:last-child{border-bottom:1px solid rgba(10,10,10,.1);}
.solution-row h4{font-size:15px;font-weight:700;margin-bottom:4px;}
.solution-row p{font-size:12px;color:#777;}
.solution-arrow{width:26px;height:26px;border-radius:6px;background:var(--yellow);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:12px;}

/* Stat grid (About) */
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;padding:30px 0;border-top:1px solid rgba(10,10,10,.1);}
.stat-grid div{text-align:left;}
.stat-num{font-size:26px;font-weight:800;display:block;}
.stat-label{font-size:12px;color:#888;}

.capability-row{display:flex;gap:10px;flex-wrap:wrap;margin:24px 0 40px;}
.capability-pill{font-size:12px;font-weight:800;padding:10px 16px;border-radius:var(--radius-pill);}
.capability-pill.yellow{background:var(--yellow);color:var(--black);}
.capability-pill.black{background:var(--black);color:var(--yellow);}

/* Work listing */
.work-tabs{display:flex;gap:20px;align-items:baseline;margin-bottom:20px;flex-wrap:wrap;}
.work-tabs .tab{font-family:var(--serif);font-size:18px;font-weight:700;color:#aaa;cursor:pointer;}
.work-tabs .tab.active{color:var(--black);text-decoration:underline;text-decoration-color:var(--yellow);text-underline-offset:6px;}
.work-filter{font-size:12px;font-weight:600;color:var(--black);display:inline-flex;align-items:center;gap:6px;margin-left:auto;cursor:pointer;}

.work-map{background:var(--black);border-radius:var(--radius-lg);padding:30px 24px;margin-bottom:50px;}
.work-map h2{color:#fff;font-family:var(--serif);font-size:22px;margin-bottom:18px;}
.map-canvas{background:#181818;border-radius:14px;height:240px;position:relative;}
.map-dot{position:absolute;width:10px;height:10px;background:var(--yellow);border-radius:50%;cursor:pointer;transition:transform .2s, box-shadow .2s;}
.map-dot:hover{transform:scale(1.4);box-shadow:0 0 0 14px rgba(255,230,0,.25);}
.map-region-label{font-size:10px;font-weight:700;color:#ccc;text-align:center;margin-top:6px;}

.work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.work-card{display:block;}
.work-thumb{height:150px;border-radius:var(--radius-md);position:relative;margin-bottom:10px;background-size:cover;background-position:center;}
.work-thumb .go-arrow{position:absolute;bottom:8px;right:8px;background:var(--black);color:var(--yellow);width:24px;height:24px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:11px;}
.work-card .cat{display:block;font-size:10px;font-weight:700;color:#999;letter-spacing:.5px;margin-bottom:3px;}
.work-card h3{font-size:14px;font-weight:800;}

/* Case detail page */
.case-hero{position:relative;background:var(--black);min-height:460px;display:flex;align-items:flex-end;overflow:hidden;}
.case-hero .container{position:relative;z-index:2;padding-top:0;padding-bottom:64px;}
.case-hero .eyebrow{color:var(--yellow);opacity:1;}
.case-hero h1{color:#fff;font-size:clamp(28px,4.5vw,56px);max-width:700px;margin-bottom:0;font-family:var(--font);}
.case-hero-media{display:none;}
.page-hero-bg{position:absolute;inset:0;}
.page-hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;opacity:0.45;}
.page-hero-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(10,10,10,.85) 0%,rgba(10,10,10,.55) 55%,rgba(10,10,10,.12) 100%);}

.case-body{display:grid;grid-template-columns:0.7fr 1.3fr;gap:40px;padding:60px 0;}
.case-meta dt{font-size:10px;font-weight:700;color:#999;letter-spacing:.5px;margin-bottom:4px;}
.case-meta dd{font-size:13px;margin-bottom:20px;line-height:1.6;}
.case-content p{font-size:14px;color:#333;line-height:1.8;margin-bottom:16px;}
.case-content h3{font-size:16px;margin:24px 0 10px;}

/* People page */
.team-narrative{padding:60px 0;max-width:760px;}
.team-narrative p{font-size:16px;line-height:1.85;color:#333;margin-bottom:20px;}

/* News list */
.news-tabs{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:30px;}
.news-tabs button{background:transparent;border:1px solid #ccc;border-radius:6px;padding:8px 14px;font-size:12px;font-weight:700;color:var(--black);cursor:pointer;}
.news-tabs button.active{background:var(--black);color:#fff;border-color:var(--black);}
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}

/* Article detail page */
.article-hero{padding:60px 0 0;}
.article-hero h1{font-family:var(--serif);font-size:30px;max-width:640px;margin:14px 0 16px;}
.article-meta{display:flex;gap:16px;font-size:12px;color:#888;flex-wrap:wrap;margin-bottom:24px;}
.article-meta strong{color:var(--black);}
.article-thumb{background:var(--grey-card);border-radius:var(--radius-lg);height:220px;margin-bottom:30px;}
.article-body{max-width:680px;padding-bottom:60px;}
.article-body p{font-size:15px;line-height:1.8;color:#222;margin-bottom:18px;}
.article-body h3{font-size:18px;margin:30px 0 12px;}
.article-back{display:inline-block;font-size:12px;color:#888;border-top:1px solid #eee;padding-top:16px;margin-top:20px;}

/* Packages */
.packages-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(255,255,255,.08);border-top:1px solid rgba(255,255,255,.08);}
.package-card{background:var(--black);padding:36px 30px;position:relative;border-top:3px solid var(--yellow);}
.package-card.alt{border-top-color:#fff;}
.package-icon{width:46px;height:46px;border-radius:10px;background:rgba(255,230,0,.12);display:flex;align-items:center;justify-content:center;margin-bottom:20px;font-size:20px;}
.package-card h3{color:#fff;font-size:22px;margin-bottom:6px;}
.package-card .sub{color:#999;font-size:13px;margin-bottom:22px;}
.package-checklist{display:flex;flex-direction:column;gap:14px;margin-bottom:28px;}
.package-checklist div{display:flex;align-items:flex-start;gap:10px;color:#ddd;font-size:13px;}
.package-checklist .check{width:18px;height:18px;border-radius:50%;background:var(--yellow);color:#000;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;margin-top:1px;}
.package-cta{display:flex;align-items:center;gap:14px;flex-wrap:wrap;}
.package-price{color:#999;font-size:12px;font-weight:600;}

.package-hero{background:var(--black);padding:50px 0;}
.package-hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center;}
.package-hero-media{background:#181818;border-radius:16px;height:340px;}
.package-hero h1{color:#fff;font-size:38px;margin-bottom:18px;}
.package-hero p.lede{color:#999;font-size:15px;margin-bottom:26px;}

/* Footer sitemap */
.footer-sitemap{display:grid;grid-template-columns:1.2fr 1fr 1fr 1fr;gap:20px;border-top:1px solid rgba(255,255,255,.12);padding-top:34px;margin-top:30px;}
.footer-sitemap h4{color:#fff;font-weight:400;font-size:15px;margin-bottom:18px;}
.footer-sitemap a{display:block;color:#bbb;font-size:13px;font-weight:600;text-decoration:underline;text-decoration-color:rgba(255,255,255,.25);text-underline-offset:4px;margin-bottom:14px;}
.footer-sitemap a:hover{color:#fff;}

/* Sub-service deep-dive pages */
.subservice-hero{position:relative;background:var(--black);min-height:460px;display:flex;align-items:flex-end;overflow:hidden;}
.subservice-hero .container{position:relative;z-index:2;padding-top:0;padding-bottom:64px;}
.subservice-hero .eyebrow{color:var(--yellow);opacity:1;}
.subservice-hero h1{color:#fff;font-size:clamp(28px,4.5vw,56px);max-width:700px;margin-bottom:0;font-family:var(--font);}
.subservice-banner{display:none;}

.subservice-intro{background:var(--offwhite);padding:60px 0;}
.subservice-intro-grid{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;flex-wrap:wrap;}
.subservice-intro p.lead{font-size:22px;line-height:1.5;max-width:680px;color:#111;margin-bottom:18px;}
.subservice-intro p.sub{font-size:14px;color:#555;max-width:560px;line-height:1.7;}
.subservice-intro .btn{flex-shrink:0;}

.howwebuild{background:var(--offwhite);padding:20px 0 70px;position:relative;}
.howwebuild-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:40px;}
.howwebuild h2{font-family:var(--serif);font-size:34px;max-width:520px;}
.howwebuild-nav{display:flex;gap:8px;}
.howwebuild-nav button{width:38px;height:38px;border:1px solid #ccc;border-radius:8px;background:#fff;cursor:pointer;font-size:14px;}
.howwebuild-track{display:flex;overflow-x:auto;scroll-behavior:smooth;gap:0;scrollbar-width:none;}
.howwebuild-track::-webkit-scrollbar{display:none;}
.howwebuild-card{flex:0 0 260px;padding:0 28px;border-right:1px solid #ddd;}
.howwebuild-card:first-child{padding-left:0;}
.howwebuild-card h3{font-size:19px;font-weight:600;margin-bottom:18px;}
.howwebuild-card p{font-size:13px;color:#555;line-height:1.75;}

.subservice-work{background:var(--white);padding:50px 0 60px;}
.subservice-work h2{font-family:var(--serif);font-size:26px;margin-bottom:6px;}

.subservice-packages{background:var(--offwhite);padding:20px 0 70px;}
.subservice-packages h2{font-family:var(--serif);font-size:26px;margin-bottom:20px;}
.subservice-packages-placeholder{border:1px dashed #ccc;border-radius:16px;padding:50px 24px;text-align:center;color:#999;font-size:13px;}

/* Responsive */
@media (max-width: 980px){
  .main-nav, .nav-actions{display:none;}
  .mobile-nav .lang-switch-mobile{font-size:13px;font-weight:700;opacity:.6;}
  .mobile-nav .lang-switch-mobile.lang-active{opacity:1;font-weight:800;}
  .mobile-menu-toggle{display:flex;}
  .hero-grid{grid-template-columns:1fr;}
  .hero-scene{order:-1;height:220px;}
  .hero h1{font-size:38px;}
  .slide-grid{grid-template-columns:1fr;text-align:center;gap:18px;}
  .slide-left{text-align:center;}
  .slide-right{text-align:center;}
  .dots{justify-content:center;}
  .insights-grid{grid-template-columns:1fr 1fr;}
  .contact-top{flex-direction:column;}
  .contact-top-right{text-align:left;}
  .contact-bottom{flex-direction:column;align-items:flex-start;}

  .page-hero h1{font-size:32px;}
  .content-row, .content-row.reverse{grid-template-columns:1fr;}
  .content-row.reverse .content-media{order:0;}
  .stat-grid{grid-template-columns:1fr 1fr;}
  .work-grid, .news-grid{grid-template-columns:1fr 1fr;}
  .case-body{grid-template-columns:1fr;}
  .work-filter{margin-left:0;}
  .packages-grid{grid-template-columns:1fr;}
  .package-hero-grid{grid-template-columns:1fr;}
  .package-hero-media{order:-1;height:220px;}
  .subservice-banner{height:180px;}
  .subservice-intro p.lead{font-size:18px;}
  .howwebuild-card{flex:0 0 220px;}
}

@media (max-width: 600px){
  .nav-row{padding:14px 18px;}
  .hero h1{font-size:30px;}
  .hero{padding-top:30px;}
  .capture-fields input{width:100px;}
  .insights-grid{grid-template-columns:1fr;}
  .work-grid, .news-grid{grid-template-columns:1fr;}
  .page-hero h1{font-size:26px;}
}
