/* ============================================================
   TECHSPEAK TECHNOLOGIES — Theme Stylesheet
   Design system: Editorial light. Fraunces + Inter.
   ============================================================ */

:root{
  --bg:#FAF8F4; --bg-tint:#F1EDE3; --ink:#101A2E; --ink-soft:#2A3550;
  --muted:#5A6478; --accent:#D9831A; --accent-2:#E8A94B; --accent-soft:#F4E3C8;
  --line:rgba(16,26,46,.12); --line-dark:rgba(250,248,244,.16); --cream:#FAF8F4;
  --display:"Fraunces",Georgia,serif; --body:"Inter",-apple-system,sans-serif;
  --max:1300px; --sec-pad:clamp(64px,8vw,104px);
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:var(--body);background:var(--bg);color:var(--ink);font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;position:relative;}
body::before{content:"";position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.4;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.035'/%3E%3C/svg%3E");}
img{max-width:100%;display:block;height:auto;}
a{color:inherit;text-decoration:none;}
.wrap{width:100%;max-width:var(--max);margin:0 auto;padding:0 clamp(24px,4vw,48px);position:relative;z-index:2;}
.ts-section{position:relative;z-index:2;}

/* TYPE */
h1,h2,h3,.serif{font-family:var(--display);font-weight:500;line-height:1.12;letter-spacing:-.01em;}
.eyebrow{font-family:var(--body);font-size:12px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);display:inline-flex;align-items:center;gap:10px;margin-bottom:22px;}
.eyebrow::before{content:"";width:26px;height:1.5px;background:var(--accent);display:inline-block;}
.lead{font-size:clamp(17px,1.6vw,20px);color:var(--muted);max-width:560px;}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--body);font-size:15px;font-weight:600;padding:16px 30px;border-radius:100px;transition:all .25s ease;border:1.5px solid var(--ink);cursor:pointer;}
.btn-solid{background:var(--ink);color:var(--cream);}
.btn-solid:hover{background:var(--accent);border-color:var(--accent);transform:translateY(-2px);box-shadow:0 12px 28px -12px rgba(217,131,26,.6);}
.btn-ghost{background:transparent;color:var(--ink);}
.btn-ghost:hover{background:var(--ink);color:var(--cream);}
.btn-light{border-color:var(--cream);background:var(--cream);color:var(--ink);}
.btn-light:hover{background:var(--accent);border-color:var(--accent);color:var(--cream);transform:translateY(-2px);}
.arrow{transition:transform .25s ease;}
.btn:hover .arrow{transform:translateX(4px);}

/* NAV */
.nav{position:sticky;top:0;z-index:100;background:rgba(250,248,244,.88);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);}
.nav-inner{max-width:var(--max);margin:0 auto;padding:16px 24px;display:flex;align-items:center;justify-content:space-between;gap:32px;}
.logo{display:flex;align-items:center;gap:10px;}
.logo svg{flex:none;}
.logo .txt{display:flex;flex-direction:column;line-height:1;}
.logo .mark{font-family:var(--display);font-size:21px;font-weight:600;letter-spacing:-.01em;}
.logo .sub{font-size:8.5px;font-weight:600;letter-spacing:.34em;text-transform:uppercase;color:var(--muted);margin-top:3px;}
.nav-links{display:flex;gap:30px;font-size:14.5px;font-weight:500;color:var(--ink-soft);list-style:none;align-items:center;}
.nav-links a{position:relative;padding:4px 0;display:block;}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:1.5px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .25s ease;}
.nav-links a:hover::after,.nav-links .current-menu-item>a::after{transform:scaleX(1);}
.nav .btn{padding:11px 22px;font-size:14px;}
.nav-toggle{display:none;background:none;border:none;font-size:24px;cursor:pointer;color:var(--ink);}
.nav-mobile{display:none;flex-direction:column;gap:4px;padding:10px 24px 22px;border-top:1px solid var(--line);list-style:none;}
.nav-mobile.open{display:flex;}
.nav-mobile a{padding:11px 0;font-size:16px;font-weight:500;border-bottom:1px solid var(--line);display:block;}

/* HERO */
.hero{padding:clamp(40px,5vw,68px) 0 0;text-align:center;}
.hero h1{font-size:clamp(40px,6.6vw,80px);font-weight:500;max-width:1000px;margin:0 auto 22px;}
.hero .line2{display:inline-flex;align-items:baseline;gap:.28em;flex-wrap:wrap;justify-content:center;}
.word-search{position:relative;display:inline-block;}
.word-search::after{content:"";position:absolute;left:-3%;top:54%;width:106%;height:.07em;border-radius:2px;background:var(--ink);transform:scaleX(0);transform-origin:left center;}
.word-search.struck::after{animation:strike .45s cubic-bezier(.65,0,.35,1) forwards;}
@keyframes strike{to{transform:scaleX(1);}}
.word-ask{font-style:italic;color:var(--accent);position:relative;display:inline-block;min-width:.5ch;}
.word-ask .caret{display:inline-block;width:.06em;height:1em;background:var(--accent);margin-left:.04em;transform:translateY(.12em);animation:blink .8s step-end infinite;}
.word-ask.done .caret{animation:none;opacity:0;}
@keyframes blink{50%{opacity:0;}}
.hero .lead{margin:0 auto 30px;max-width:600px;}
.hero-ctas{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}

/* STATS */
.stats{width:100%;max-width:var(--max);margin:clamp(44px,6vw,72px) auto 0;padding:0 clamp(24px,4vw,48px);position:relative;z-index:2;}
.stats-inner{border-top:1px solid var(--line);display:grid;grid-template-columns:repeat(4,1fr);}
.stat{padding:34px 16px 0;text-align:center;border-left:1px solid var(--line);}
.stat:first-child{border-left:none;}
.stat b{font-family:var(--display);font-weight:500;font-size:clamp(30px,3.4vw,44px);display:block;}
.stat span{font-size:13px;font-weight:500;color:var(--muted);letter-spacing:.04em;}

/* MARQUEE (client logos) */
.marquee-sec{padding:clamp(56px,7vw,88px) 0;overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.marquee-label{text-align:center;font-size:12px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-bottom:34px;}
.marquee{display:flex;width:max-content;animation:scroll 38s linear infinite;}
.marquee:hover{animation-play-state:paused;}
.m-track{display:flex;align-items:center;}
.m-item{font-family:var(--display);font-size:21px;font-weight:500;color:var(--ink-soft);padding:0 34px;white-space:nowrap;display:flex;align-items:center;gap:34px;}
.m-item::after{content:"·";color:var(--accent);font-size:26px;}
@keyframes scroll{to{transform:translateX(-50%);}}

/* SECTION HEAD */
.sec-head{margin-bottom:clamp(36px,4.5vw,54px);}
.sec-head h2{font-size:clamp(32px,4.2vw,52px);max-width:660px;}
.sec-head.split{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;flex-wrap:wrap;}

/* SERVICES */
.services{padding:var(--sec-pad) 0;}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.svc{border:1px solid var(--line);border-radius:18px;padding:32px 30px;background:var(--bg);transition:all .3s ease;display:flex;flex-direction:column;gap:14px;}
.svc:hover{border-color:var(--ink);transform:translateY(-4px);box-shadow:0 20px 44px -28px rgba(16,26,46,.3);}
.svc .ico{width:46px;height:46px;display:grid;place-items:center;border-radius:12px;background:var(--accent-soft);color:var(--accent);}
.svc .ico svg{width:24px;height:24px;}
.svc h3{font-size:23px;}
.svc p{font-size:15px;color:var(--muted);line-height:1.6;flex:1;}
.svc .tags{font-size:12.5px;font-weight:500;color:var(--ink-soft);letter-spacing:.02em;}
.svc-link{font-size:14px;font-weight:600;color:var(--accent);display:inline-flex;align-items:center;gap:6px;}
.svc.flagship{grid-column:span 2;background:var(--ink);color:var(--cream);border-color:var(--ink);position:relative;overflow:hidden;}
.svc.flagship::after{content:"";position:absolute;right:-60px;top:-60px;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(217,131,26,.22),transparent 68%);}
.svc.flagship .ico{background:rgba(217,131,26,.2);}
.svc.flagship p{color:rgba(250,248,244,.72);}
.svc.flagship .tags{color:rgba(250,248,244,.85);}
.svc.flagship .flag-badge{align-self:flex-start;font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--accent-2);border:1px solid rgba(217,131,26,.45);padding:6px 14px;border-radius:100px;}
.svc.flagship h3{font-size:30px;}

/* ABOUT / IMAGE */
.about{padding:var(--sec-pad) 0;background:var(--bg-tint);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.about-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(40px,6vw,80px);align-items:center;}
.about-copy h2{font-size:clamp(30px,3.8vw,46px);margin-bottom:22px;}
.about-copy p{color:var(--muted);margin-bottom:16px;}
.about-sign{font-family:var(--display);font-style:italic;font-size:20px;color:var(--ink);margin-top:24px;}
.img-slot{position:relative;border-radius:20px;overflow:hidden;aspect-ratio:4/3.4;background:linear-gradient(135deg,#1a2740,#101a2e 60%);border:1px solid var(--line);display:grid;place-items:center;color:rgba(250,248,244,.5);}
.img-slot img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.img-slot .ph{text-align:center;padding:20px;}
.img-slot .ph svg{width:40px;height:40px;margin:0 auto 12px;opacity:.6;}
.img-slot .ph small{font-size:12px;letter-spacing:.05em;}
.img-float{position:absolute;left:18px;bottom:18px;background:var(--cream);color:var(--ink);border-radius:14px;padding:14px 18px;box-shadow:0 16px 40px -20px rgba(0,0,0,.5);z-index:2;}
.img-float b{font-family:var(--display);font-size:30px;font-weight:500;display:block;line-height:1;color:var(--accent);}
.img-float span{font-size:12px;color:var(--muted);}

/* GEO / ANSWER CARD */
.geo{padding:var(--sec-pad) 0;}
.geo-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,90px);align-items:center;}
.geo-copy h2{font-size:clamp(30px,3.8vw,46px);margin-bottom:22px;}
.geo-copy p{color:var(--muted);margin-bottom:18px;}
.geo-points{list-style:none;margin-top:28px;display:flex;flex-direction:column;gap:14px;}
.geo-points li{display:flex;gap:14px;font-size:15.5px;font-weight:500;align-items:baseline;}
.geo-points li::before{content:"\2192";color:var(--accent);font-weight:600;}
.answer-card{background:#fff;border:1px solid var(--line);border-radius:20px;padding:30px;box-shadow:0 30px 70px -34px rgba(16,26,46,.32);}
.ac-query{display:flex;gap:12px;align-items:center;font-size:15px;font-weight:500;padding-bottom:18px;border-bottom:1px solid var(--line);margin-bottom:18px;color:var(--ink-soft);}
.ac-query .dot{width:9px;height:9px;border-radius:50%;background:var(--accent);flex:none;animation:pulse 2.2s ease infinite;}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:.35;}}
.ac-body{font-size:15px;line-height:1.7;color:var(--ink-soft);}
.ac-body mark{background:var(--accent-soft);padding:1px 5px;border-radius:4px;font-weight:600;color:var(--ink);}
.ac-cite{margin-top:18px;display:flex;gap:8px;flex-wrap:wrap;}
.ac-cite span{font-size:12px;font-weight:500;color:var(--muted);border:1px solid var(--line);border-radius:100px;padding:5px 12px;}
.ac-note{font-size:12px;color:var(--muted);margin-top:16px;font-style:italic;}

/* RESULTS (DARK) */
.results{background:var(--ink);color:var(--cream);padding:var(--sec-pad) 0;}
.results .eyebrow{color:var(--accent-2);}
.results .eyebrow::before{background:var(--accent-2);}
.results .sec-head p{color:rgba(250,248,244,.6);max-width:480px;}
.case-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.case{border:1px solid var(--line-dark);border-radius:18px;padding:32px 30px;display:flex;flex-direction:column;gap:8px;transition:all .3s ease;}
.case:hover{border-color:rgba(250,248,244,.45);background:rgba(250,248,244,.03);}
.case .c-tag{font-size:11.5px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:rgba(250,248,244,.5);}
.case h3{font-size:24px;margin:6px 0 20px;}
.case .metric{padding:16px 0;border-top:1px solid var(--line-dark);}
.case .metric b{font-family:var(--display);font-weight:500;font-size:clamp(34px,3.6vw,46px);color:var(--accent-2);display:block;line-height:1;}
.case .metric span{font-size:13px;color:rgba(250,248,244,.6);}
.results-cta{margin-top:54px;text-align:center;}

/* PROCESS */
.process{padding:var(--sec-pad) 0;}
.proc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(28px,4vw,56px);}
.step{position:relative;padding-top:26px;}
.step::before{content:attr(data-n);position:absolute;top:-14px;left:0;font-family:var(--display);font-size:64px;font-weight:400;font-style:italic;color:transparent;-webkit-text-stroke:1px rgba(16,26,46,.25);line-height:1;}
.step h3{font-size:22px;margin-bottom:12px;padding-top:34px;}
.step p{font-size:15px;color:var(--muted);}

/* INDUSTRIES */
.industries{padding:0 0 var(--sec-pad);}
.ind-strip{display:flex;flex-wrap:wrap;gap:10px;}
.ind-strip span{font-size:14px;font-weight:500;border:1px solid var(--line);border-radius:100px;padding:11px 22px;transition:all .25s ease;cursor:default;display:inline-flex;align-items:center;gap:9px;}
.ind-strip span svg{width:16px;height:16px;color:var(--accent);}
.ind-strip span:hover{background:var(--ink);color:var(--cream);border-color:var(--ink);}
.ind-strip span:hover svg{color:var(--accent-2);}

/* INSIGHTS */
.insights{padding:0 0 var(--sec-pad);}
.ins-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.ins{border-top:2px solid var(--ink);padding:26px 4px 0;transition:border-color .25s ease;}
.ins:hover{border-color:var(--accent);}
.ins .i-tag{font-size:11.5px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);}
.ins h3{font-size:21px;margin:12px 0 10px;line-height:1.3;}
.ins p{font-size:14.5px;color:var(--muted);}
.ins .read{display:inline-block;margin-top:16px;font-size:13.5px;font-weight:600;}

/* CTA BAND */
.cta-band{background:var(--ink);color:var(--cream);padding:var(--sec-pad) 0;text-align:center;position:relative;overflow:hidden;}
.cta-band::after{content:"";position:absolute;left:50%;top:-40%;width:560px;height:560px;transform:translateX(-50%);border-radius:50%;background:radial-gradient(circle,rgba(217,131,26,.16),transparent 65%);}
.cta-band h2{font-size:clamp(36px,5.5vw,66px);max-width:760px;margin:0 auto 26px;position:relative;z-index:2;}
.cta-band .ask{font-style:italic;color:var(--accent-2);}
.cta-band p{color:rgba(250,248,244,.65);max-width:520px;margin:0 auto 42px;position:relative;z-index:2;}
.cta-band .btn{position:relative;z-index:2;}

/* PAGE / POST CONTENT */
.page-hero{padding:clamp(48px,6vw,84px) 0 clamp(26px,3vw,40px);border-bottom:1px solid var(--line);}
.page-hero h1{font-size:clamp(38px,5.5vw,68px);max-width:840px;}
.page-hero .lead{margin-top:18px;}
.content-area{padding:clamp(48px,6vw,84px) 0;}
.prose{max-width:720px;margin:0 auto;}
.prose h2{font-size:clamp(26px,3vw,38px);margin:48px 0 16px;}
.prose h3{font-size:22px;margin:34px 0 12px;}
.prose p{margin-bottom:20px;color:var(--ink-soft);}
.prose ul,.prose ol{margin:0 0 20px 22px;color:var(--ink-soft);}
.prose li{margin-bottom:8px;}
.prose a{color:var(--accent);text-decoration:underline;text-underline-offset:3px;}
.prose img{border-radius:14px;margin:28px 0;}
.prose blockquote{border-left:3px solid var(--accent);padding-left:22px;margin:28px 0;font-family:var(--display);font-style:italic;font-size:21px;color:var(--ink);}

/* FAQ ACCORDION (GEO schema) */
.faq{padding:var(--sec-pad) 0;background:var(--bg-tint);border-top:1px solid var(--line);}
.faq-list{max-width:760px;margin:0 auto;}
.faq-item{border-bottom:1px solid var(--line);}
.faq-q{width:100%;text-align:left;background:none;border:none;cursor:pointer;font-family:var(--display);font-size:20px;font-weight:500;color:var(--ink);padding:24px 40px 24px 0;position:relative;display:flex;}
.faq-q::after{content:"+";position:absolute;right:4px;top:22px;font-size:26px;color:var(--accent);transition:transform .25s ease;}
.faq-item.open .faq-q::after{transform:rotate(45deg);}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease;}
.faq-a-inner{padding:0 0 24px;color:var(--muted);font-size:15.5px;line-height:1.7;}

/* ARCHIVE / CARDS */
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.post-card{border:1px solid var(--line);border-radius:18px;overflow:hidden;transition:all .3s ease;background:var(--bg);}
.post-card:hover{transform:translateY(-4px);box-shadow:0 20px 44px -28px rgba(16,26,46,.3);}
.post-card .thumb{aspect-ratio:16/10;background:var(--bg-tint);overflow:hidden;}
.post-card .thumb img{width:100%;height:100%;object-fit:cover;}
.post-card .body{padding:26px;}
.post-card .i-tag{font-size:11.5px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);}
.post-card h3{font-size:21px;margin:12px 0 10px;line-height:1.3;}
.post-card p{font-size:14.5px;color:var(--muted);}

/* PAGINATION */
.pagination{display:flex;gap:8px;justify-content:center;margin-top:54px;}
.pagination .page-numbers{padding:10px 16px;border:1px solid var(--line);border-radius:10px;font-weight:500;font-size:14px;}
.pagination .current{background:var(--ink);color:var(--cream);border-color:var(--ink);}

/* FOOTER */
.site-footer{padding:70px 0 36px;border-top:1px solid var(--line);}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:40px;margin-bottom:56px;}
.foot-grid h4{font-size:12px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:18px;}
.foot-grid ul{list-style:none;display:flex;flex-direction:column;gap:10px;font-size:14.5px;}
.foot-grid a:hover{color:var(--accent);}
.foot-tag{font-family:var(--display);font-size:22px;font-style:italic;margin:14px 0 6px;}
.foot-loc{font-size:13.5px;color:var(--muted);}
.foot-base{border-top:1px solid var(--line);padding-top:28px;display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;font-size:13px;color:var(--muted);}

/* REVEAL */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease;}
.reveal.in{opacity:1;transform:none;}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important;}
  .reveal{opacity:1;transform:none;}
  .word-search::after{transform:scaleX(1);}
  .word-ask .caret{display:none;}
}

/* RESPONSIVE */
@media (max-width:980px){
  .svc-grid,.case-grid,.ins-grid,.card-grid{grid-template-columns:1fr 1fr;}
  .svc.flagship{grid-column:span 2;}
  .geo-grid,.about-grid{grid-template-columns:1fr;}
  .proc-grid{grid-template-columns:1fr;gap:40px;}
  .foot-grid{grid-template-columns:1fr 1fr;}
}
@media (max-width:860px){
  .nav-links,.nav .btn{display:none;}
  .nav-toggle{display:block;}
}
@media (max-width:640px){
  .stats-inner{grid-template-columns:1fr 1fr;}
  .stat{border-left:none;border-top:1px solid var(--line);}
  .stat:nth-child(-n+2){border-top:none;}
  .svc-grid,.case-grid,.ins-grid,.card-grid{grid-template-columns:1fr;}
  .svc.flagship{grid-column:span 1;}
  .foot-grid{grid-template-columns:1fr;}
}

/* ============================================================
   SERVICE PAGE ADDITIONS (GEO + Video)
   ============================================================ */
.svc-intro{padding:var(--sec-pad) 0 0;}
.svc-intro .grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,90px);align-items:start;}
.svc-intro h2{font-size:clamp(28px,3.4vw,42px);}
.svc-intro p{color:var(--muted);margin-bottom:16px;}
.svc-intro .lead-stat{font-family:var(--display);font-size:clamp(40px,5vw,64px);font-weight:500;color:var(--accent);line-height:1;margin-bottom:8px;}

/* deliverables list */
.deliver{padding:var(--sec-pad) 0;}
.deliver-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;}
.deliver-item{border:1px solid var(--line);border-radius:16px;padding:28px 28px;display:flex;gap:18px;transition:all .3s ease;background:var(--bg);}
.deliver-item:hover{border-color:var(--ink);transform:translateY(-3px);}
.deliver-item .ico{width:42px;height:42px;flex:none;display:grid;place-items:center;border-radius:11px;background:var(--accent-soft);color:var(--accent);}
.deliver-item .ico svg{width:22px;height:22px;}
.deliver-item h3{font-size:20px;margin-bottom:6px;}
.deliver-item p{font-size:14.5px;color:var(--muted);line-height:1.6;}

/* showreel / video slots */
.reel-grid{display:grid;grid-template-columns:2fr 1fr;gap:14px;}
.reel{position:relative;border-radius:18px;overflow:hidden;aspect-ratio:16/9;background:linear-gradient(135deg,#1a2740,#101a2e 65%);border:1px solid var(--line);display:grid;place-items:center;cursor:pointer;transition:transform .3s ease;}
.reel:hover{transform:translateY(-3px);}
.reel.tall{aspect-ratio:9/16;grid-row:span 2;}
.reel .play{width:64px;height:64px;border-radius:50%;background:rgba(250,248,244,.12);backdrop-filter:blur(4px);display:grid;place-items:center;border:1.5px solid rgba(250,248,244,.4);transition:all .3s ease;}
.reel:hover .play{background:var(--accent);border-color:var(--accent);}
.reel .play svg{width:24px;height:24px;color:var(--cream);margin-left:3px;}
.reel .r-label{position:absolute;left:18px;bottom:16px;font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:rgba(250,248,244,.7);}
.reel-note{font-size:12px;color:var(--muted);margin-top:14px;font-style:italic;}
@media (max-width:980px){
  .svc-intro .grid{grid-template-columns:1fr;}
  .deliver-grid{grid-template-columns:1fr;}
  .reel-grid{grid-template-columns:1fr;}
  .reel.tall{aspect-ratio:16/9;grid-row:auto;}
}

/* ============================================================
   MOBILE HARDENING
   ============================================================ */
html,body{overflow-x:hidden;max-width:100%;}
h1,h2,h3{overflow-wrap:break-word;word-break:normal;}
.btn{min-height:44px;}            /* comfortable tap target */
.faq-q{min-height:44px;}
.nav-toggle{min-width:44px;min-height:44px;}
img,svg,video{max-width:100%;}
@media (max-width:480px){
  :root{--sec-pad:clamp(48px,11vw,72px);}
  .hero h1{font-size:clamp(34px,8.5vw,44px);}
  .page-hero h1{font-size:clamp(32px,8vw,42px);}
  .hero-ctas{flex-direction:column;}
  .hero-ctas .btn,.cta-band .btn{width:100%;justify-content:center;}
  .sec-head.split{flex-direction:column;align-items:flex-start;}
  .wrap{padding:0 20px;}
}

/* ============================================================
   KEY PAGES (Contact, About, Results, Thank-You)
   ============================================================ */
/* contact */
.contact-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:clamp(40px,6vw,72px);align-items:start;}
.ts-form{display:flex;flex-direction:column;gap:18px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.field{display:flex;flex-direction:column;gap:7px;position:relative;}
.field label{font-size:13px;font-weight:600;letter-spacing:.02em;color:var(--ink-soft);}
.field input,.field select,.field textarea{font-family:var(--body);font-size:15.5px;color:var(--ink);background:var(--bg);border:1px solid var(--line);border-radius:12px;padding:14px 16px;transition:border-color .2s ease;width:100%;}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(217,131,26,.12);}
.field textarea{min-height:130px;resize:vertical;}
.hp{position:absolute!important;left:-9999px!important;height:0;overflow:hidden;}
.form-note{font-size:13px;color:var(--muted);}
.form-error{background:#fbe9d8;border:1px solid var(--accent);color:#8a4d05;padding:12px 16px;border-radius:12px;font-size:14px;}
.contact-aside{display:flex;flex-direction:column;gap:14px;}
.cdetail{border:1px solid var(--line);border-radius:14px;padding:20px 22px;}
.cdetail h4{font-size:12px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:8px;}
.cdetail a,.cdetail p{font-family:var(--display);font-size:19px;color:var(--ink);}
.cal-slot{border:1px dashed rgba(16,26,46,.3);border-radius:14px;padding:30px 22px;text-align:center;color:var(--muted);background:var(--bg-tint);}
.cal-slot svg{width:34px;height:34px;margin:0 auto 10px;color:var(--accent);}
.cal-slot b{display:block;color:var(--ink);font-family:var(--display);font-size:18px;margin-bottom:4px;}

/* about: values + team */
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.value-item{border-top:2px solid var(--ink);padding:24px 4px 0;}
.value-item h3{font-size:21px;margin-bottom:10px;}
.value-item p{font-size:15px;color:var(--muted);}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
.team-card .photo{aspect-ratio:1/1;border-radius:16px;background:linear-gradient(135deg,#1a2740,#101a2e);display:grid;place-items:center;overflow:hidden;margin-bottom:14px;}
.team-card .photo img{width:100%;height:100%;object-fit:cover;}
.team-card .photo svg{width:34px;height:34px;color:rgba(250,248,244,.4);}
.team-card h3{font-size:18px;}
.team-card span{font-size:13.5px;color:var(--muted);}

/* results: metric mini-cards inside dark band */
.metric-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.mcard{border:1px solid var(--line-dark);border-radius:16px;padding:24px;}
.mcard b{font-family:var(--display);font-weight:500;font-size:clamp(26px,3vw,38px);color:var(--accent-2);display:block;line-height:1;}
.mcard .pct{font-size:13px;font-weight:600;color:#7fd6a8;margin-top:6px;display:block;}
.mcard span{font-size:12.5px;color:rgba(250,248,244,.55);display:block;margin-top:6px;}
.results-block{margin-bottom:clamp(40px,5vw,64px);}
.results-block:last-child{margin-bottom:0;}
.rb-head{display:flex;align-items:baseline;gap:14px;margin-bottom:22px;flex-wrap:wrap;}
.rb-head h3{font-size:24px;color:var(--cream);}
.rb-head .tag{font-size:11.5px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:rgba(250,248,244,.5);}

/* thank you */
.ty{min-height:55vh;display:grid;place-items:center;text-align:center;padding:var(--sec-pad) 0;}
.ty .check{width:72px;height:72px;border-radius:50%;background:var(--accent-soft);display:grid;place-items:center;margin:0 auto 24px;}
.ty .check svg{width:34px;height:34px;color:var(--accent);}
.ty h1{font-size:clamp(34px,5vw,56px);margin-bottom:16px;}
.ty p{color:var(--muted);max-width:480px;margin:0 auto 30px;}

@media (max-width:980px){
  .contact-grid{grid-template-columns:1fr;}
  .values-grid{grid-template-columns:1fr;}
  .team-grid{grid-template-columns:1fr 1fr;}
  .metric-row{grid-template-columns:1fr 1fr;}
}
@media (max-width:640px){
  .form-row{grid-template-columns:1fr;}
  .team-grid{grid-template-columns:1fr 1fr;}
  .metric-row{grid-template-columns:1fr 1fr;}
}

/* case studies filter */
.cs-f{cursor:pointer;}
.cs-f.is-active{background:var(--ink);color:var(--cream);border-color:var(--ink);}

/* ============================================================
   PRODUCTS (homepage band + Products page)
   ============================================================ */
.products{padding:var(--sec-pad) 0;background:var(--bg-tint);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.pcard{position:relative;display:flex;flex-direction:column;background:var(--bg);border:1px solid var(--line);border-radius:18px;padding:30px;transition:all .3s ease;overflow:hidden;}
.pcard:hover{transform:translateY(-4px);border-color:var(--ink);box-shadow:0 22px 48px -28px rgba(16,26,46,.32);}
.pcard::after{content:"";position:absolute;right:-50px;top:-50px;width:160px;height:160px;border-radius:50%;background:radial-gradient(circle,var(--pa,rgba(217,131,26,.16)),transparent 68%);opacity:.7;}
.pcard .ptop{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px;position:relative;z-index:2;}
.pcard .pdot{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;font-family:var(--display);font-weight:600;font-size:17px;color:#fff;}
.pcard .pcat{font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);}
.pcard h3{font-size:23px;margin-bottom:4px;position:relative;z-index:2;}
.pcard .ptag{font-size:14px;color:var(--ink-soft);font-weight:500;margin-bottom:14px;position:relative;z-index:2;}
.pcard p{font-size:14.5px;color:var(--muted);line-height:1.6;flex:1;position:relative;z-index:2;}
.pcard .plink{margin-top:18px;font-size:14px;font-weight:600;display:inline-flex;align-items:center;gap:7px;position:relative;z-index:2;}
.pcard .soon{font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);border:1px solid var(--line);border-radius:100px;padding:5px 12px;}

/* products page: full detail rows */
.pdetail{padding:clamp(48px,6vw,80px) 0;border-bottom:1px solid var(--line);}
.pdetail:last-of-type{border-bottom:none;}
.pdetail-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,80px);align-items:center;}
.pdetail.alt .pdetail-grid{direction:rtl;}
.pdetail.alt .pdetail-grid>*{direction:ltr;}
.pd-copy .pcat-row{display:flex;align-items:center;gap:12px;margin-bottom:18px;}
.pd-copy .pdot{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;font-family:var(--display);font-weight:600;font-size:19px;color:#fff;}
.pd-copy h2{font-size:clamp(28px,3.6vw,44px);margin-bottom:8px;}
.pd-copy .ptag{font-size:17px;color:var(--ink-soft);font-weight:500;margin-bottom:18px;}
.pd-copy p{color:var(--muted);margin-bottom:20px;}
.pd-points{list-style:none;display:flex;flex-direction:column;gap:12px;margin-bottom:26px;}
.pd-points li{display:flex;gap:12px;font-size:15px;font-weight:500;align-items:baseline;}
.pd-points li::before{content:"\2192";color:var(--accent);font-weight:700;}
.pd-stats{display:flex;gap:26px;flex-wrap:wrap;margin-bottom:26px;}
.pd-stats .s b{font-family:var(--display);font-weight:500;font-size:30px;display:block;line-height:1;}
.pd-stats .s span{font-size:12.5px;color:var(--muted);}
.pd-shot{border-radius:18px;overflow:hidden;border:1px solid var(--line);aspect-ratio:4/3;background:linear-gradient(135deg,#f4f1ea,#e7e1d4);display:grid;place-items:center;position:relative;}
.pd-shot img{width:100%;height:100%;object-fit:cover;object-position:top;}
.pd-shot .ph{text-align:center;color:var(--muted);padding:20px;}
.pd-shot .ph svg{width:38px;height:38px;margin:0 auto 10px;opacity:.5;}
.pd-shot .badge{position:absolute;left:16px;top:16px;font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;background:var(--ink);color:var(--cream);padding:5px 12px;border-radius:100px;}
@media (max-width:980px){
  .prod-grid{grid-template-columns:1fr;}
  .pdetail-grid,.pdetail.alt .pdetail-grid{grid-template-columns:1fr;direction:ltr;}
}

/* flagship cards span 2 of the 3 columns (the "big" cards: SEO row 1, Video row 3) */
.svc.flagship{grid-column:span 2;}
@media (max-width:980px){
  .svc.flagship{grid-column:span 2;}   /* 2-col layout: flagship fills the row */
}
@media (max-width:640px){
  .svc.flagship{grid-column:span 1;}   /* single column on phones */
}

/* social icons (footer) */
.social-icons{display:flex;gap:10px;align-items:center;}
.social-ico{width:38px;height:38px;border:1px solid var(--line);border-radius:50%;display:grid;place-items:center;color:var(--ink-soft);transition:all .25s ease;}
.social-ico svg{width:18px;height:18px;}
.social-ico:hover{background:var(--ink);border-color:var(--ink);color:var(--cream);transform:translateY(-2px);}
@media (max-width:640px){.foot-base{flex-direction:column;align-items:flex-start;gap:16px;}}

/* logo icon slot: fixed square, holds the T mark or an uploaded square logo */
.logo-icon{width:40px;height:40px;flex:none;display:block;border-radius:10px;overflow:hidden;}
.logo-icon svg{width:40px;height:40px;display:block;}
.logo-icon .logo-img{width:40px;height:40px;object-fit:cover;display:block;border-radius:10px;}
.site-footer .logo-icon,.site-footer .logo-icon svg,.site-footer .logo-icon .logo-img{width:40px;height:40px;}

/* ============================================================
   DROPDOWN SUB-MENUS (header)
   ============================================================ */
/* desktop: hover dropdown */
.nav-links{position:relative;}
.nav-links .menu-item-has-children{position:relative;}
.nav-links .menu-item-has-children>a::after{content:"";display:inline-block;width:6px;height:6px;margin-left:7px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:rotate(45deg) translateY(-2px);opacity:.55;transition:transform .2s ease;}
.nav-links .menu-item-has-children:hover>a::after{transform:rotate(225deg) translateY(-1px);}
.nav-links .sub-menu{
  position:absolute;top:calc(100% + 14px);left:0;min-width:220px;
  background:var(--bg);border:1px solid var(--line);border-radius:14px;
  padding:8px;list-style:none;display:flex;flex-direction:column;gap:2px;
  box-shadow:0 24px 50px -24px rgba(16,26,46,.3);
  opacity:0;visibility:hidden;transform:translateY(8px);transition:all .22s ease;z-index:120;
}
.nav-links .sub-menu::before{content:"";position:absolute;top:-14px;left:0;right:0;height:14px;} /* hover bridge */
.nav-links .menu-item-has-children:hover>.sub-menu,
.nav-links .menu-item-has-children:focus-within>.sub-menu{opacity:1;visibility:visible;transform:translateY(0);}
.nav-links .sub-menu a{display:block;padding:10px 14px;border-radius:9px;font-size:14.5px;color:var(--ink-soft);white-space:nowrap;}
.nav-links .sub-menu a::after{display:none;}
.nav-links .sub-menu a:hover{background:var(--bg-tint);color:var(--accent);}
.nav-links .sub-menu .sub-menu{position:static;box-shadow:none;border:none;padding:0 0 0 10px;opacity:1;visibility:visible;transform:none;} /* third level inline */

/* mobile: collapsible accordion sub-menus (tap parent to expand) */
.nav-mobile .menu-item-has-children{position:relative;}
.nav-mobile .menu-item-has-children>a{position:relative;padding-right:44px;}
.nav-mobile .submenu-toggle{
  position:absolute;right:0;top:50%;transform:translateY(-50%);
  width:44px;height:44px;border:none;background:none;cursor:pointer;
  display:grid;place-items:center;color:var(--ink);
}
.nav-mobile .submenu-toggle::before{
  content:"";width:9px;height:9px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;
  transform:rotate(45deg) translate(-2px,-2px);transition:transform .25s ease;
}
.nav-mobile .menu-item-has-children.open>a .submenu-toggle::before,
.nav-mobile .menu-item-has-children.open .submenu-toggle::before{transform:rotate(-135deg) translate(-1px,-1px);}
.nav-mobile .sub-menu{
  list-style:none;padding:0 0 0 14px;margin:0;display:flex;flex-direction:column;
  max-height:0;overflow:hidden;transition:max-height .28s ease;
}
.nav-mobile .menu-item-has-children.open>.sub-menu{max-height:600px;}
.nav-mobile .sub-menu a{font-size:15px;font-weight:400;color:var(--muted);border-bottom:none;padding:10px 0;}

/* ============================================================
   SINGLE POST (editorial blog layout)
   ============================================================ */
/* breadcrumbs */
.breadcrumb{display:flex;flex-wrap:wrap;gap:8px;align-items:center;font-size:13px;color:var(--muted);margin-bottom:22px;}
.breadcrumb a{color:var(--muted);transition:color .2s ease;}
.breadcrumb a:hover{color:var(--accent);}
.breadcrumb .sep{opacity:.5;}
.breadcrumb .current{color:var(--ink-soft);font-weight:500;}

/* post header meta */
.post-head .eyebrow{margin-bottom:18px;}
.post-meta{display:flex;flex-wrap:wrap;align-items:center;gap:16px;margin-top:22px;font-size:14px;color:var(--muted);}
.post-meta .avatar{width:38px;height:38px;border-radius:50%;background:var(--bg-tint);overflow:hidden;display:grid;place-items:center;flex:none;}
.post-meta .avatar img{width:100%;height:100%;object-fit:cover;}
.post-meta .avatar svg{width:20px;height:20px;color:var(--muted);}
.post-meta b{color:var(--ink);font-weight:600;}
.post-meta .dot{width:3px;height:3px;border-radius:50%;background:var(--muted);opacity:.5;}

.post-feat{margin:38px 0 0;border-radius:18px;overflow:hidden;border:1px solid var(--line);}
.post-feat img{width:100%;display:block;}

/* two-column layout */
.post-layout{display:grid;grid-template-columns:1fr 320px;gap:clamp(36px,5vw,64px);align-items:start;}
.post-main{min-width:0;}

/* sticky sidebar */
.post-sidebar{position:sticky;top:96px;display:flex;flex-direction:column;gap:20px;}
.widget{border:1px solid var(--line);border-radius:16px;padding:24px;background:var(--bg);}
.widget h4{font-size:12px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:16px;}
.widget-search form{display:flex;gap:8px;}
.widget-search input[type=search]{flex:1;min-width:0;font-family:var(--body);font-size:14.5px;border:1px solid var(--line);border-radius:10px;padding:11px 14px;background:var(--bg);}
.widget-search input[type=search]:focus{outline:none;border-color:var(--accent);}
.widget-search button{border:none;background:var(--ink);color:var(--cream);border-radius:10px;padding:0 14px;cursor:pointer;display:grid;place-items:center;}
.widget-search button svg{width:18px;height:18px;}
.recent-list{display:flex;flex-direction:column;gap:14px;}
.recent-item{display:flex;gap:12px;align-items:flex-start;}
.recent-item .thumb{width:56px;height:56px;border-radius:10px;overflow:hidden;background:var(--bg-tint);flex:none;}
.recent-item .thumb img{width:100%;height:100%;object-fit:cover;}
.recent-item h5{font-family:var(--display);font-size:15px;font-weight:500;line-height:1.3;}
.recent-item h5 a:hover{color:var(--accent);}
.recent-item span{font-size:12px;color:var(--muted);}
/* sidebar CTA (rotating service) */
.side-cta{background:var(--ink);color:var(--cream);border-radius:16px;padding:26px 24px;position:relative;overflow:hidden;}
.side-cta::after{content:"";position:absolute;right:-40px;top:-40px;width:150px;height:150px;border-radius:50%;background:radial-gradient(circle,rgba(217,131,26,.22),transparent 68%);}
.side-cta .eyebrow{color:var(--accent-2);margin-bottom:12px;}
.side-cta .eyebrow::before{background:var(--accent-2);}
.side-cta h4{font-family:var(--display);font-size:21px;font-weight:500;color:var(--cream);letter-spacing:normal;text-transform:none;margin-bottom:10px;position:relative;z-index:2;}
.side-cta p{font-size:14px;color:rgba(250,248,244,.72);margin-bottom:18px;position:relative;z-index:2;}
.side-cta .btn{position:relative;z-index:2;}

/* author box */
.author-box{display:flex;gap:20px;align-items:flex-start;border:1px solid var(--line);border-radius:18px;padding:28px;margin:48px 0 0;background:var(--bg-tint);}
.author-box .ava{width:64px;height:64px;border-radius:50%;overflow:hidden;background:var(--bg);flex:none;display:grid;place-items:center;}
.author-box .ava img{width:100%;height:100%;object-fit:cover;}
.author-box .ava svg{width:30px;height:30px;color:var(--muted);}
.author-box .ab-name{font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:4px;}
.author-box h4{font-family:var(--display);font-size:22px;font-weight:500;margin-bottom:8px;}
.author-box p{font-size:14.5px;color:var(--muted);line-height:1.6;}

/* related posts */
.related{padding:var(--sec-pad) 0;background:var(--bg-tint);border-top:1px solid var(--line);}

/* comments */
.comments{margin:54px 0 0;}
.comments h3{font-size:24px;margin-bottom:24px;}
.comment-list{list-style:none;display:flex;flex-direction:column;gap:22px;margin-bottom:36px;}
.comment-list .comment{border:1px solid var(--line);border-radius:14px;padding:20px 22px;}
.comment-list .comment-author{font-weight:600;font-size:15px;}
.comment-list .comment-meta{font-size:12.5px;color:var(--muted);margin-bottom:8px;}
.comment-list .comment-body{font-size:14.5px;color:var(--ink-soft);}
.comment-list .children{list-style:none;margin:18px 0 0 26px;display:flex;flex-direction:column;gap:18px;}
.comment-respond{border:1px solid var(--line);border-radius:16px;padding:26px;}
.comment-respond .comment-reply-title{font-family:var(--display);font-size:22px;font-weight:500;margin-bottom:16px;}
.comment-form{display:flex;flex-direction:column;gap:16px;}
.comment-form p{display:flex;flex-direction:column;gap:7px;margin:0;}
.comment-form label{font-size:13px;font-weight:600;color:var(--ink-soft);}
.comment-form input,.comment-form textarea{font-family:var(--body);font-size:15px;border:1px solid var(--line);border-radius:11px;padding:13px 15px;background:var(--bg);width:100%;}
.comment-form input:focus,.comment-form textarea:focus{outline:none;border-color:var(--accent);}
.comment-form textarea{min-height:120px;resize:vertical;}
.comment-form .form-submit input{background:var(--ink);color:var(--cream);border:none;border-radius:100px;padding:14px 30px;font-weight:600;cursor:pointer;width:auto;}
.comment-form .form-submit input:hover{background:var(--accent);}

@media (max-width:980px){
  .post-layout{grid-template-columns:1fr;}
  .post-sidebar{position:static;flex-direction:column;}
}

/* ============================================================
   SINGLE POST SPACING FIX (tighter header, no double gap)
   ============================================================ */
/* compact header: breadcrumb/category + title only */
.single .post-head,
.post-head{
  padding:clamp(28px,3.5vw,44px) 0 clamp(18px,2.2vw,26px);
  border-bottom:none;
}
.post-topline{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:18px;}
.post-topline .breadcrumb{margin:0;}
.post-topline .eyebrow{margin:0;}
/* featured image right under the title */
.post-feat{margin-top:clamp(20px,3vw,30px);}
/* meta row sits below the image, lightly separated */
.single .post-meta{margin-top:22px;padding-top:20px;border-top:1px solid var(--line);}
/* body should hug the meta, not add a big section gap */
.single .content-area.has-feat,
.single .content-area.no-feat{padding-top:clamp(22px,3vw,34px);}

/* ============================================================
   BLOG HUB (archive)
   ============================================================ */
.blog-layout{display:grid;grid-template-columns:1fr 320px;gap:clamp(36px,5vw,64px);align-items:start;}
.blog-main{min-width:0;}

/* featured lead post */
.feat-post{display:grid;grid-template-columns:1.1fr 1fr;gap:0;border:1px solid var(--line);border-radius:20px;overflow:hidden;margin-bottom:40px;background:var(--bg);transition:box-shadow .3s ease;}
.feat-post:hover{box-shadow:0 26px 56px -30px rgba(16,26,46,.32);}
.feat-post .fp-img{aspect-ratio:auto;min-height:280px;background:linear-gradient(135deg,#1a2740,#101a2e);overflow:hidden;}
.feat-post .fp-img img{width:100%;height:100%;object-fit:cover;}
.feat-post .fp-body{padding:clamp(28px,3.5vw,44px);display:flex;flex-direction:column;justify-content:center;}
.feat-post .fp-badge{font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin-bottom:14px;display:inline-flex;align-items:center;gap:8px;}
.feat-post .fp-badge::before{content:"";width:22px;height:1.5px;background:var(--accent);}
.feat-post h2{font-size:clamp(26px,3vw,38px);line-height:1.15;margin-bottom:14px;}
.feat-post p{color:var(--muted);font-size:15.5px;margin-bottom:20px;}
.feat-post .fp-meta{font-size:13px;color:var(--muted);display:flex;gap:12px;align-items:center;}
.feat-post .fp-meta .dot{width:3px;height:3px;border-radius:50%;background:var(--muted);opacity:.5;}

/* category filter */
.blog-filter{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:32px;}
.blog-filter a{font-size:13.5px;font-weight:500;border:1px solid var(--line);border-radius:100px;padding:9px 18px;color:var(--ink-soft);transition:all .25s ease;}
.blog-filter a:hover,.blog-filter a.active{background:var(--ink);color:var(--cream);border-color:var(--ink);}

/* card meta line */
.post-card .card-meta{font-size:12.5px;color:var(--muted);margin-top:12px;display:flex;gap:10px;align-items:center;}
.post-card .card-meta .dot{width:3px;height:3px;border-radius:50%;background:var(--muted);opacity:.5;}

.blog-main .card-grid{grid-template-columns:1fr 1fr;}

@media (max-width:980px){
  .blog-layout{grid-template-columns:1fr;}
  .feat-post{grid-template-columns:1fr;}
  .feat-post .fp-img{min-height:220px;}
}
@media (max-width:640px){.blog-main .card-grid{grid-template-columns:1fr;}}

/* calendly inline embed (contact page) */
.cal-embed{border:1px solid var(--line);border-radius:14px;padding:20px;background:var(--bg);}
.cal-embed .calendly-inline-widget{border-radius:10px;overflow:hidden;}

/* ============================================================
   CONTACT PAGE — REVAMPED
   ============================================================ */
/* quick contact chips under hero */
.contact-chips{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px;}
.contact-chips a{display:inline-flex;align-items:center;gap:10px;border:1px solid var(--line);border-radius:100px;padding:11px 20px;font-size:14.5px;font-weight:500;color:var(--ink-soft);transition:all .25s ease;}
.contact-chips a:hover{border-color:var(--ink);transform:translateY(-2px);}
.contact-chips svg{width:17px;height:17px;color:var(--accent);}

/* form + aside two-column (no calendar here anymore) */
.contact-form-wrap{display:grid;grid-template-columns:1.3fr .7fr;gap:clamp(36px,5vw,64px);align-items:start;}
.contact-form-card{border:1px solid var(--line);border-radius:20px;padding:clamp(28px,4vw,44px);background:var(--bg);}
.contact-form-card .fc-head{margin-bottom:24px;}
.contact-form-card .fc-head h2{font-size:clamp(24px,2.6vw,32px);margin-bottom:6px;}
.contact-form-card .fc-head p{font-size:15px;color:var(--muted);}
.contact-side{display:flex;flex-direction:column;gap:14px;}
.contact-side .cdetail{display:flex;gap:14px;align-items:flex-start;}
.contact-side .cdetail .ci{width:40px;height:40px;border-radius:11px;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;flex:none;}
.contact-side .cdetail .ci svg{width:19px;height:19px;}
.contact-side .cdetail h4{margin-bottom:3px;}
.contact-side .cdetail a,.contact-side .cdetail p{font-family:var(--display);font-size:18px;color:var(--ink);}

/* full-width calendly section */
.booking{padding:var(--sec-pad) 0;background:var(--bg-tint);border-top:1px solid var(--line);}
.booking .sec-head{text-align:center;}
.booking .sec-head h2{margin:0 auto;}
.booking .sec-head .eyebrow{justify-content:center;}
.booking-frame{max-width:1000px;margin:0 auto;background:var(--bg);border:1px solid var(--line);border-radius:20px;padding:14px;box-shadow:0 30px 70px -40px rgba(16,26,46,.3);overflow:hidden;}
.booking-frame .calendly-inline-widget{min-width:320px;height:700px;border-radius:14px;overflow:hidden;}

@media (max-width:980px){
  .contact-form-wrap{grid-template-columns:1fr;}
  .booking-frame .calendly-inline-widget{height:1000px;}
}
@media (max-width:640px){
  .booking-frame{padding:8px;}
  .booking-frame .calendly-inline-widget{height:1050px;}
}

/* services hub: large icon visual panel (mirrors .pd-shot) */
.svc-visual{width:100%;display:grid;place-items:center;}
.svc-visual-icon{width:120px;height:120px;display:grid;place-items:center;background:rgba(255,255,255,.55);border-radius:30px;box-shadow:0 20px 50px -24px rgba(16,26,46,.3);}
.svc-visual-icon svg{width:58px;height:58px;}
