:root {
  --coral: #E8614E;
  --blue: #2B4A70;
  --charcoal: #1E1E1E;
  --mid: #555;
  --light: #F5F4F2;
  --white: #FFFFFF;
  --border: #E0DDD8;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Archivo',sans-serif;color:var(--charcoal);background:var(--white);overflow-x:hidden;}

/* ── NAV ── */
nav{position:fixed;top:0;width:100%;z-index:1000;background:rgba(255,255,255,0.97);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);transition:all .3s;}
.nav-inner{max-width:1440px;margin:0 auto;padding:0 3rem;height:72px;display:flex;align-items:center;justify-content:space-between;}
.logo{display:flex;align-items:center;gap:.9rem;text-decoration:none;}
.logo-icon{height:32px;width:auto;}
.logo-wordmark{height:28px;width:auto;}
.nav-links{display:flex;gap:2.5rem;list-style:none;align-items:center;}
.nav-links a{text-decoration:none;color:var(--charcoal);font-size:.82rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;transition:color .2s;}
.nav-links a:hover{color:var(--coral);}
.nav-cta{background:var(--coral);color:var(--white)!important;padding:.6rem 1.5rem;font-size:.8rem!important;}
.nav-cta:hover{background:var(--blue)!important;color:var(--white)!important;}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;}
.hamburger span{display:block;width:24px;height:2px;background:var(--charcoal);transition:all .3s;}
.mobile-menu{display:none;position:fixed;top:72px;left:0;right:0;background:var(--white);border-bottom:1px solid var(--border);padding:2rem 3rem;z-index:999;}
.mobile-menu.open{display:block;}
.mobile-menu a{display:block;padding:.8rem 0;color:var(--charcoal);text-decoration:none;font-weight:600;font-size:.9rem;letter-spacing:.05em;text-transform:uppercase;border-bottom:1px solid var(--border);}

/* ── HERO ── */
.hero{position:relative;height:100vh;min-height:600px;overflow:hidden;margin-top:72px;}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 1.2s ease;background-size:cover;background-position:center;}
.hero-slide.active{opacity:1;}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(27,37,55,.75) 0%,rgba(27,37,55,.3) 60%,transparent 100%);}
.hero-content{position:absolute;inset:0;display:flex;align-items:flex-end;padding:0 4rem 5rem;}
.hero-text{max-width:680px;}
.hero-tag{font-family:'IBM Plex Mono',monospace;font-size:.78rem;color:var(--coral);letter-spacing:.15em;text-transform:uppercase;margin-bottom:1.2rem;}
.hero h1{font-size:clamp(2.8rem,5vw,5rem);font-weight:800;color:var(--white);line-height:1.05;letter-spacing:-.02em;margin-bottom:1.5rem;}
.hero-sub{font-size:1.1rem;color:rgba(255,255,255,.85);line-height:1.7;margin-bottom:2.5rem;max-width:520px;}
.hero-btns{display:flex;gap:1rem;flex-wrap:wrap;}
.btn-primary{background:var(--coral);color:var(--white);padding:.9rem 2.2rem;font-size:.85rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;text-decoration:none;transition:all .25s;display:inline-block;}
.btn-primary:hover{background:var(--white);color:var(--charcoal);}
.btn-outline{border:2px solid rgba(255,255,255,.7);color:var(--white);padding:.9rem 2.2rem;font-size:.85rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;text-decoration:none;transition:all .25s;display:inline-block;}
.btn-outline:hover{background:rgba(255,255,255,.15);}
.hero-label{position:absolute;bottom:2rem;right:2rem;font-family:'IBM Plex Mono',monospace;font-size:.72rem;color:rgba(255,255,255,.6);letter-spacing:.1em;text-transform:uppercase;}
.hero-dots{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);display:flex;gap:.6rem;}
.hero-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.35);cursor:pointer;transition:all .3s;}
.hero-dot.active{background:var(--coral);width:24px;border-radius:4px;}
.hero-stats{position:absolute;bottom:0;right:0;background:var(--white);display:grid;grid-template-columns:repeat(3,1fr);}
.hero-stat{padding:1.8rem 2rem;border-left:1px solid var(--border);}
.hero-stat:first-child{border-left:none;}
.stat-num{font-family:'IBM Plex Mono',monospace;font-size:2rem;font-weight:700;color:var(--coral);line-height:1;}
.stat-lbl{font-size:.75rem;color:var(--mid);text-transform:uppercase;letter-spacing:.08em;margin-top:.4rem;}

/* ── SECTIONS ── */
.section{padding:6rem 3rem;}
.section-inner{max-width:1440px;margin:0 auto;}
.section-tag{font-family:'IBM Plex Mono',monospace;font-size:.75rem;color:var(--coral);letter-spacing:.18em;text-transform:uppercase;margin-bottom:1rem;}
.section-title{font-size:clamp(2rem,4vw,3.5rem);font-weight:800;letter-spacing:-.02em;line-height:1.1;margin-bottom:1.5rem;}
.section-lead{font-size:1.15rem;color:var(--mid);line-height:1.8;max-width:720px;}

/* ── INTRO ── */
.intro{background:var(--light);}
.intro-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:0;margin-top:4rem;}
.intro-card{padding:3rem;border-top:3px solid var(--border);position:relative;transition:border-color .3s;}
.intro-card:hover{border-color:var(--coral);}
.intro-card:nth-child(2){border-left:1px solid var(--border);border-right:1px solid var(--border);}
.intro-num{font-family:'IBM Plex Mono',monospace;font-size:3rem;font-weight:700;color:var(--coral);opacity:.15;line-height:1;margin-bottom:1rem;}
.intro-title{font-size:1.4rem;font-weight:700;margin-bottom:.8rem;}
.intro-text{color:var(--mid);line-height:1.75;font-size:.95rem;}

/* ── SERVICES ── */
.services-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;margin-top:4rem;}
.service{border-top:2px solid var(--charcoal);padding-top:2rem;}
.service-title{font-size:1.6rem;font-weight:700;margin-bottom:.8rem;}
.service-text{color:var(--mid);line-height:1.8;margin-bottom:1rem;}
.service-note{font-family:'IBM Plex Mono',monospace;font-size:.78rem;color:var(--mid);font-style:italic;}

/* ── VERIFIED VIEWS ── */
.verified{background:var(--blue);color:var(--white);}
.verified .section-tag{color:var(--coral);}
.verified .section-title{color:var(--white);}
.verified .section-lead{color:rgba(255,255,255,.8);}
.verified-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;margin-top:4rem;align-items:start;}
.verified-list{list-style:none;margin-top:2rem;}
.verified-list li{padding:.9rem 0;border-bottom:1px solid rgba(255,255,255,.1);display:flex;gap:1rem;align-items:flex-start;font-size:.95rem;color:rgba(255,255,255,.9);}
.verified-list li::before{content:'→';color:var(--coral);font-weight:700;flex-shrink:0;margin-top:.1rem;}
.avr-box{background:rgba(255,255,255,.06);border-left:4px solid var(--coral);padding:2.5rem;}
.avr-box h3{color:var(--coral);font-size:1rem;text-transform:uppercase;letter-spacing:.12em;margin-bottom:2rem;font-family:'IBM Plex Mono',monospace;}
.avr-level{margin-bottom:1.5rem;}
.avr-level-tag{font-family:'IBM Plex Mono',monospace;font-size:.75rem;color:var(--coral);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.3rem;}
.avr-level-text{color:rgba(255,255,255,.85);font-size:.95rem;}
.avr-note{font-size:.85rem;color:rgba(255,255,255,.6);line-height:1.7;margin-top:2rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,.1);}
.standards{margin-top:2.5rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,.1);}
.standards h4{font-size:.8rem;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.5);margin-bottom:1rem;font-family:'IBM Plex Mono',monospace;}
.standards p{font-size:.85rem;color:rgba(255,255,255,.65);line-height:1.7;}

/* ── GALLERY — natural ratio masonry ── */
.gallery-columns{column-count:4;column-gap:5px;margin-top:3rem;padding:0 3rem;}
.gallery-item{break-inside:avoid;margin-bottom:5px;position:relative;cursor:pointer;overflow:hidden;display:block;}
.gallery-item img{width:100%;height:auto;display:block;transition:transform .5s ease;}
.gallery-item:hover img{transform:scale(1.04);}
.gallery-item-label{position:absolute;bottom:0;left:0;right:0;padding:.8rem 1rem;background:linear-gradient(transparent,rgba(0,0,0,.7));color:white;font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;opacity:0;transition:opacity .3s;}
.gallery-item:hover .gallery-item-label{opacity:1;}

/* ── LIGHTBOX ── */
.lightbox{display:none;position:fixed;inset:0;background:rgba(0,0,0,.95);z-index:9999;align-items:center;justify-content:center;}
.lightbox.open{display:flex;}
.lightbox-img{max-width:90vw;max-height:88vh;object-fit:contain;}
.lightbox-close{position:absolute;top:1.5rem;right:2rem;color:white;font-size:2rem;cursor:pointer;background:none;border:none;opacity:.7;transition:opacity .2s;}
.lightbox-close:hover{opacity:1;}
.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);color:white;font-size:3rem;cursor:pointer;background:none;border:none;padding:1rem;opacity:.5;transition:opacity .2s;line-height:1;}
.lightbox-nav:hover{opacity:1;}
.lightbox-prev{left:1rem;}
.lightbox-next{right:1rem;}
.lightbox-label{position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.6);font-family:'IBM Plex Mono',monospace;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;white-space:nowrap;}
.lightbox-counter{position:absolute;top:1.5rem;left:2rem;color:rgba(255,255,255,.5);font-family:'IBM Plex Mono',monospace;font-size:.8rem;}

/* ── CASE STUDY CARDS on index ── */
.cases{background:var(--light);}
.cases-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px;margin-top:3rem;}
.case-card{position:relative;overflow:hidden;text-decoration:none;display:block;}
.case-card img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;transition:transform .6s ease;}
.case-card:hover img{transform:scale(1.05);}
.case-card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.75) 0%,rgba(0,0,0,.1) 60%,transparent 100%);transition:background .3s;}
.case-card:hover .case-card-overlay{background:linear-gradient(to top,rgba(0,0,0,.85) 0%,rgba(0,0,0,.2) 60%,transparent 100%);}
.case-card-body{position:absolute;bottom:0;left:0;right:0;padding:2rem;}
.case-card-type{font-family:'IBM Plex Mono',monospace;font-size:.72rem;color:var(--white);background:var(--coral);text-transform:uppercase;letter-spacing:.12em;margin-bottom:.6rem;display:inline-block;padding:.25rem .6rem;font-weight:700;}
.case-card-title{font-size:1.3rem;font-weight:800;color:var(--white);line-height:1.2;margin-bottom:.3rem;}
.case-card-loc{font-size:.82rem;color:rgba(255,255,255,.7);}
.case-card-arrow{position:absolute;top:1.5rem;right:1.5rem;width:36px;height:36px;background:var(--coral);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s;color:white;font-size:1.2rem;font-weight:700;}
.case-card:hover .case-card-arrow{opacity:1;}

/* ── CLIENTS ── */
.clients-wrap{margin-top:4rem;}
.client-list{display:flex;flex-wrap:wrap;gap:1.5rem 3rem;align-items:center;}
.client-name{font-size:.82rem;font-weight:700;color:var(--charcoal);opacity:.35;text-transform:uppercase;letter-spacing:.06em;transition:opacity .2s;cursor:default;}
.client-name:hover{opacity:.9;}

/* ── CONTACT ── */
.contact{background:var(--charcoal);color:var(--white);}
.contact .section-tag{color:var(--coral);}
.contact .section-title{color:var(--white);}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;margin-top:4rem;}
.contact-block h3{font-size:1rem;text-transform:uppercase;letter-spacing:.12em;color:var(--coral);margin-bottom:2rem;font-family:'IBM Plex Mono',monospace;}
.contact-item{margin-bottom:1.5rem;}
.contact-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.4);margin-bottom:.4rem;font-family:'IBM Plex Mono',monospace;}
.contact-value{color:var(--white);font-size:.97rem;line-height:1.6;}
.contact-value a{color:var(--white);text-decoration:none;transition:color .2s;}
.contact-value a:hover{color:var(--coral);}
.contact-tagline{font-size:1.4rem;font-weight:700;color:var(--white);margin-bottom:1.5rem;line-height:1.4;}
.contact-desc{color:rgba(255,255,255,.6);line-height:1.8;margin-bottom:1.5rem;font-size:.95rem;}
.social-links{display:flex;gap:1.5rem;margin-top:1rem;}
.social-links a{font-family:'IBM Plex Mono',monospace;font-size:.75rem;color:rgba(255,255,255,.5);text-decoration:none;text-transform:uppercase;letter-spacing:.1em;transition:color .2s;}
.social-links a:hover{color:var(--coral);}

/* ── NAV SOCIAL ICONS ── */
.nav-social{display:flex;gap:1rem;align-items:center;margin-left:1rem;}
.nav-social a{display:flex;align-items:center;color:var(--charcoal);opacity:.5;transition:all .2s;}
.nav-social a:hover{opacity:1;color:var(--coral);}
.nav-social svg{width:18px;height:18px;}

/* ── CONTACT FORM ── */
.contact-form{margin-top:2rem;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem;}
.form-group{display:flex;flex-direction:column;gap:.4rem;}
.form-group.full{grid-column:span 2;}
.form-group label{font-family:'IBM Plex Mono',monospace;font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.45);}
.form-group input,.form-group textarea,.form-group select{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.15);color:var(--white);padding:.85rem 1rem;font-family:'Archivo',sans-serif;font-size:.95rem;transition:border-color .2s;outline:none;width:100%;}
.form-group input::placeholder,.form-group textarea::placeholder{color:rgba(255,255,255,.25);}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--coral);}
.form-group select option{background:var(--charcoal);color:var(--white);}
.form-group textarea{resize:vertical;min-height:130px;}
.form-submit{background:var(--coral);color:var(--white);border:none;padding:1rem 2.5rem;font-family:'Archivo',sans-serif;font-size:.88rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:background .2s;margin-top:.5rem;}
.form-submit:hover{background:#d4503f;}
.form-success{display:none;background:rgba(255,255,255,.08);border-left:3px solid var(--coral);padding:1rem 1.5rem;color:rgba(255,255,255,.8);font-size:.95rem;margin-top:1rem;}
.form-success.show{display:block;}

/* ── FOOTER ── */
footer{background:#111;color:rgba(255,255,255,.35);padding:2rem 3rem;font-size:.8rem;font-family:'IBM Plex Mono',monospace;}
.footer-inner{max-width:1440px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;}
.footer-logo{height:14px;width:auto;opacity:.3;filter:invert(1);}

/* ══════════════════════════════════════
   CASE STUDY PAGES
══════════════════════════════════════ */
.case-page{margin-top:72px;}
.case-hero{background:var(--charcoal);position:relative;}
.case-hero-img{width:100%;height:75vh;object-fit:cover;object-position:center;display:block;}
.case-back{position:absolute;top:1.5rem;left:2rem;font-family:'IBM Plex Mono',monospace;font-size:.75rem;color:rgba(255,255,255,.65);text-decoration:none;letter-spacing:.1em;text-transform:uppercase;transition:color .2s;display:flex;align-items:center;gap:.5rem;z-index:10;}
.case-back:hover{color:var(--coral);}
.case-header{padding:4rem 3rem 2rem;border-bottom:1px solid var(--border);}
.case-header-inner{max-width:1440px;margin:0 auto;display:grid;grid-template-columns:1fr auto;gap:4rem;align-items:start;}
.case-type-tag{font-family:'IBM Plex Mono',monospace;font-size:.78rem;color:var(--coral);letter-spacing:.15em;text-transform:uppercase;margin-bottom:.8rem;}
.case-h1{font-size:clamp(2.2rem,4vw,3.8rem);font-weight:800;letter-spacing:-.02em;line-height:1.05;margin-bottom:.5rem;}
.case-h1-loc{font-family:'IBM Plex Mono',monospace;font-size:.88rem;color:var(--mid);letter-spacing:.08em;text-transform:uppercase;}
.case-meta-box{background:var(--light);padding:2rem;min-width:300px;}
.case-meta-row{padding:.75rem 0;border-bottom:1px solid var(--border);display:grid;grid-template-columns:110px 1fr;gap:1rem;align-items:baseline;}
.case-meta-row:last-child{border-bottom:none;}
.case-meta-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--mid);}
.case-meta-value{font-size:.9rem;color:var(--charcoal);line-height:1.4;}
.case-body{max-width:1440px;margin:0 auto;padding:4rem 3rem;}
.case-body-grid{display:grid;grid-template-columns:1fr 340px;gap:5rem;align-items:start;}
.case-desc-text{font-size:1.1rem;color:var(--mid);line-height:1.85;margin-bottom:2.5rem;}
.case-details-list{list-style:none;}
.case-details-list li{padding:.6rem 0;border-bottom:1px solid var(--border);font-size:.9rem;display:flex;align-items:center;gap:.8rem;}
.case-details-list li::before{content:'';width:6px;height:6px;background:var(--coral);border-radius:50%;flex-shrink:0;}
.case-sidebar-title{font-family:'IBM Plex Mono',monospace;font-size:.75rem;color:var(--mid);text-transform:uppercase;letter-spacing:.12em;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--charcoal);}

/* Full image gallery on case page */
.case-full-gallery{max-width:1440px;margin:0 auto;padding:0 3rem 6rem;}
.case-full-gallery h2{font-size:1rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid var(--charcoal);font-family:'IBM Plex Mono',monospace;color:var(--mid);}
.case-gallery-masonry{columns:2;column-gap:5px;}
.case-gal-item{break-inside:avoid;margin-bottom:5px;cursor:pointer;overflow:hidden;position:relative;}
.case-gal-item img{width:100%;height:auto;display:block;transition:transform .4s ease;}
.case-gal-item:hover img{transform:scale(1.03);}

/* Prev/Next navigation */
.case-nav-strip{background:var(--charcoal);padding:3rem;}
.case-nav-strip-inner{max-width:1440px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;}
.case-nav-lnk{text-decoration:none;display:flex;flex-direction:column;gap:.4rem;}
.case-nav-lnk span{font-family:'IBM Plex Mono',monospace;font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.4);}
.case-nav-lnk strong{font-size:1.1rem;font-weight:700;color:var(--white);transition:color .2s;}
.case-nav-lnk:hover strong{color:var(--coral);}
.case-nav-lnk.next{text-align:right;}

/* ── RESPONSIVE ── */
@media(max-width:1200px){
  .gallery-columns{column-count:3;}
  .cases-grid{grid-template-columns:1fr 1fr;}
}
@media(max-width:1024px){
  .intro-grid{grid-template-columns:1fr 1fr;}
  .intro-card:nth-child(2){border-right:none;}
  .intro-card:nth-child(3){border-left:none;grid-column:span 2;}
  .services-grid{grid-template-columns:1fr;}
  .verified-grid{grid-template-columns:1fr;}
  .contact-grid{grid-template-columns:1fr;}
  .case-header-inner{grid-template-columns:1fr;}
  .case-body-grid{grid-template-columns:1fr;}
  .case-gallery-masonry{columns:2;}
}
@media(max-width:768px){
  .nav-links{display:none;}
  .hamburger{display:flex;}
  .hero-stats{display:none;}
  .hero-content{padding:0 2rem 4rem;}
  .section{padding:4rem 1.5rem;}
  .gallery-columns{column-count:2;padding:0 1.5rem;}
  .cases-grid{grid-template-columns:1fr;}
  .intro-grid{grid-template-columns:1fr;}
  .intro-card:nth-child(2){border-left:none;border-right:none;}
  .intro-card:nth-child(3){grid-column:span 1;}
  .nav-inner{padding:0 1.5rem;}
  .case-header{padding:2rem 1.5rem 1.5rem;}
  .case-body{padding:2rem 1.5rem;}
  .case-full-gallery{padding:0 1.5rem 4rem;}
  .case-gallery-masonry{columns:1;}
  .case-nav-strip{padding:2rem 1.5rem;}
  .case-nav-strip-inner{flex-direction:column;gap:1.5rem;align-items:flex-start;}
}
