:root{
  --primary:#0E4B47; --primary-deep:#0A3935; --primary-soft:#13615b;
  --secondary:#E7DCC6; --secondary-deep:#dccfb2;
  --accent:#D9612C; --accent-deep:#bf4f1f; --accent-soft:#f0c9b3;
  --bg:#F6F1E7; --bg-warm:#efe7d6;
  --fg:#15302C; --ink:#15302C;
  --muted:#4a5f59; --muted-soft:#6b7d77;
  --on-teal:#F3ECDD; --on-teal-soft:#cdd9d4;
  --line:#e0d6c0; --line-teal:rgba(243,236,221,.16);
  --white:#ffffff;
  --radius:14px;
  --measure:65ch;
  --shadow:0 1px 2px rgba(21,48,44,.05), 0 18px 40px -24px rgba(21,48,44,.28);
  --shadow-lg:0 30px 70px -38px rgba(10,57,53,.55);
  --ease:cubic-bezier(0.16,1,0.3,1);
  --font-display:'Trirong',Georgia,serif;
  --font-body:'Mozilla Text',system-ui,-apple-system,Segoe UI,sans-serif;
  --font-mono:'Nanum Gothic Coding',ui-monospace,monospace;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{margin:0;background:var(--bg);color:var(--fg);font-family:var(--font-body);font-size:17px;line-height:1.7;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:var(--accent-deep);text-decoration-thickness:1px;text-underline-offset:2px}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;line-height:1.08;letter-spacing:-.01em;color:var(--ink);margin:0}
p{margin:0 0 1.1em}
.wrap{width:min(1180px,92vw);margin-inline:auto}
.measure{max-width:var(--measure)}

/* ---- Accessibility ---- */
.skip{position:absolute;left:-999px;top:0;z-index:200;background:var(--accent);color:#fff;padding:.7rem 1.1rem;border-radius:0 0 var(--radius) 0;font-weight:600}
.skip:focus{left:0}
:where(a,button,input,textarea,summary,[tabindex]):focus-visible{outline:3px solid var(--accent);outline-offset:3px;border-radius:4px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

/* ---- Eyebrow ---- */
.eyebrow{display:inline-flex;align-items:center;gap:.55rem;font-size:.72rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--accent-deep);margin:0 0 1.1rem}
.eyebrow::before{content:"";width:26px;height:1.5px;background:var(--accent)}
.on-teal .eyebrow{color:var(--accent)}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-body);font-weight:600;font-size:.96rem;padding:.85rem 1.5rem;border-radius:var(--radius);border:1.5px solid transparent;cursor:pointer;text-decoration:none;transition:transform .3s var(--ease),background .3s var(--ease),box-shadow .3s var(--ease),color .3s var(--ease);line-height:1}
.btn-accent{background:var(--accent);color:#fff;box-shadow:0 12px 26px -14px rgba(217,97,44,.8)}
.btn-accent:hover{background:var(--accent-deep);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--primary);border-color:var(--primary)}
.btn-ghost:hover{background:var(--primary);color:var(--on-teal);transform:translateY(-2px)}
.on-teal .btn-ghost{color:var(--on-teal);border-color:var(--line-teal)}
.on-teal .btn-ghost:hover{background:var(--on-teal);color:var(--primary)}
.btn-lg{padding:1rem 1.9rem;font-size:1.02rem}

/* ---- Header ---- */
.site-head{position:sticky;top:0;z-index:100;background:rgba(246,241,231,.82);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.head-inner{display:flex;align-items:center;gap:1.6rem;height:74px}
.brand{display:inline-flex;align-items:center;gap:.6rem;text-decoration:none;color:var(--ink);font-family:var(--font-display);font-weight:600;font-size:1.3rem;letter-spacing:-.01em}
.brand-mark{display:inline-flex;width:38px;height:38px;align-items:center;justify-content:center;background:var(--primary);color:var(--accent);border-radius:11px}
.brand-mark svg{width:22px;height:22px}
.brand-name{white-space:nowrap}
.nav{margin-inline-start:auto}
.nav ul{display:flex;gap:1.7rem;list-style:none;margin:0;padding:0}
.nav a{text-decoration:none;color:var(--muted);font-weight:500;font-size:.97rem;position:relative;padding:.3rem 0;transition:color .25s var(--ease)}
.nav a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:2px;background:var(--accent);transition:right .35s var(--ease)}
.nav a:hover,.nav a[aria-current="page"]{color:var(--ink)}
.nav a:hover::after,.nav a[aria-current="page"]::after{right:0}
.head-cta{padding:.65rem 1.2rem}
.nav-toggle,.nav-close{display:none;background:none;border:0;color:var(--ink);cursor:pointer;padding:.3rem}
.mobile-nav{position:fixed;inset:0;background:var(--primary);z-index:150;padding:5rem 2rem 2rem;display:flex}
.mobile-nav ul{list-style:none;margin:auto 0;padding:0;display:flex;flex-direction:column;gap:1.3rem;width:100%}
.mobile-nav a{color:var(--on-teal);text-decoration:none;font-family:var(--font-display);font-size:1.7rem}
.mobile-nav .btn{font-family:var(--font-body);font-size:1rem;justify-content:center}
.nav-close{display:block;position:absolute;top:1.5rem;right:1.5rem;color:var(--on-teal)}

/* ---- Hero ---- */
.hero{position:relative;padding:clamp(4rem,9vw,8rem) 0 clamp(3.5rem,7vw,6rem);overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0;pointer-events:none}
.hero-bg .blob{position:absolute;border-radius:50%;filter:blur(8px);opacity:.5}
.hero-bg .b1{width:520px;height:520px;top:-180px;right:-120px;background:radial-gradient(circle at 30% 30%,rgba(14,75,71,.16),transparent 70%)}
.hero-bg .b2{width:420px;height:420px;bottom:-160px;left:-100px;background:radial-gradient(circle at 50% 50%,rgba(217,97,44,.1),transparent 70%)}
.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.hero-display{font-size:clamp(2.7rem,6vw,4.6rem);line-height:1.02;letter-spacing:-.022em;margin:0 0 1.4rem}
.hero-display em{font-style:italic;color:var(--primary)}
.hero-sub{font-size:1.18rem;color:var(--muted);max-width:46ch;margin:0 0 2rem}
.hero-cta{display:flex;flex-wrap:wrap;gap:.9rem;align-items:center}
.hero-note{margin:1.4rem 0 0;font-size:.86rem;color:var(--muted-soft);display:flex;align-items:center;gap:.5rem}
.hero-note::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--accent)}
.hero-media{position:relative}
.hero-figure{position:relative;border-radius:calc(var(--radius) + 8px);overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:4/5}
.hero-figure img{width:100%;height:100%;object-fit:cover}
.hero-figure::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(10,57,53,.34))}
.hero-badge{position:absolute;left:-18px;bottom:34px;z-index:2;background:var(--white);border-radius:var(--radius);padding:1rem 1.2rem;box-shadow:var(--shadow);display:flex;align-items:center;gap:.85rem;max-width:240px}
.hero-badge .hb-ic{flex:0 0 auto;width:42px;height:42px;border-radius:11px;background:var(--secondary);color:var(--primary);display:inline-flex;align-items:center;justify-content:center}
.hero-badge .hb-ic svg{width:22px;height:22px}
.hero-badge b{display:block;font-family:var(--font-display);font-size:1.05rem;color:var(--ink)}
.hero-badge span{font-size:.8rem;color:var(--muted)}

/* ---- Marquee stats ---- */
.statband{background:var(--primary);color:var(--on-teal)}
.statband .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;padding:clamp(2.2rem,4vw,3rem) 0}
.stat .num{font-family:var(--font-display);font-size:clamp(2rem,4vw,2.8rem);color:#fff;line-height:1}
.stat .num .u{color:var(--accent)}
.stat .lbl{margin-top:.5rem;font-size:.9rem;color:var(--on-teal-soft);max-width:22ch}

/* ---- Section base ---- */
.section{padding:clamp(4.5rem,9vw,8rem) 0}
.section-head{max-width:60ch;margin-bottom:clamp(2.4rem,4vw,3.4rem)}
.section-head.center{margin-inline:auto;text-align:center}
.section-title{font-size:clamp(2rem,4.4vw,3.2rem);letter-spacing:-.02em}
.section-title em{font-style:italic;color:var(--accent-deep)}
.on-teal .section-title em{color:var(--accent)}
.lead{font-size:1.15rem;color:var(--muted);margin-top:1.1rem;max-width:58ch}
.center .lead{margin-inline:auto}
.on-teal{background:var(--primary);color:var(--on-teal)}
.on-teal .section-title,.on-teal h2,.on-teal h3{color:#fff}
.on-teal .lead,.on-teal p{color:var(--on-teal-soft)}

/* ---- Intro / asymmetric editorial ---- */
.intro-grid{display:grid;grid-template-columns:1fr 1.25fr;gap:clamp(2rem,5vw,4.5rem);align-items:start}
.intro-aside{position:sticky;top:100px}
.dropcap::first-letter{font-family:var(--font-display);font-weight:600;float:left;font-size:4.1rem;line-height:.78;padding:.35rem .5rem 0 0;color:var(--accent-deep)}
.intro-body p{max-width:var(--measure);color:var(--muted)}
.intro-body .lead-p{font-size:1.22rem;color:var(--ink);font-family:var(--font-display);font-weight:400;line-height:1.45}
.pull{margin:2.2rem 0;padding:1.4rem 0 1.4rem 1.8rem;border-left:3px solid var(--accent);font-family:var(--font-display);font-style:italic;font-size:1.5rem;line-height:1.3;color:var(--primary);max-width:30ch}

/* ---- Services cards ---- */
.svc-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:1.4rem}
.svc-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:2rem 1.9rem;position:relative;overflow:hidden;transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .4s var(--ease)}
.svc-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--secondary-deep)}
.svc-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent);transform:scaleY(0);transform-origin:top;transition:transform .45s var(--ease)}
.svc-card:hover::before{transform:scaleY(1)}
.svc-card .ico{width:54px;height:54px;border-radius:13px;background:var(--secondary);color:var(--primary);display:inline-flex;align-items:center;justify-content:center;margin-bottom:1.3rem}
.svc-card h3{font-size:1.4rem;margin-bottom:.6rem}
.svc-card p{color:var(--muted);font-size:.98rem;margin-bottom:1.1rem}
.svc-points{list-style:none;margin:0 0 1.3rem;padding:0;display:flex;flex-direction:column;gap:.55rem}
.svc-points li{position:relative;padding-left:1.5rem;font-size:.95rem;color:var(--muted)}
.svc-points li::before{content:"";position:absolute;left:0;top:.55em;width:8px;height:8px;border-radius:50%;border:2px solid var(--accent)}
.svc-link{display:inline-flex;align-items:center;gap:.45rem;font-weight:600;color:var(--accent-deep);text-decoration:none;font-size:.95rem}
.svc-link svg{transition:transform .3s var(--ease)}
.svc-link:hover svg{transform:translateX(4px)}
.svc-feature{grid-column:span 6}
.svc-half{grid-column:span 6}
.svc-third{grid-column:span 4}

/* ---- Approach (numbered) ---- */
.approach-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.appr{padding:2rem 1.7rem;border-radius:var(--radius);background:var(--secondary);position:relative;overflow:hidden}
.appr .n{font-family:var(--font-mono);font-size:.85rem;color:var(--accent-deep);letter-spacing:.1em}
.appr .ic{width:48px;height:48px;border-radius:12px;background:var(--white);color:var(--primary);display:inline-flex;align-items:center;justify-content:center;margin:1rem 0 1.1rem}
.appr .ic svg{width:24px;height:24px}
.appr h3{font-size:1.3rem;margin-bottom:.5rem}
.appr p{color:var(--muted);font-size:.95rem;margin:0}

/* ---- Insights ---- */
.ins-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.8rem}
.ins-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.ins-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.ins-figure{aspect-ratio:16/9;overflow:hidden;background:var(--secondary)}
.ins-figure img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.ins-card:hover .ins-figure img{transform:scale(1.05)}
.ins-body{padding:1.6rem 1.7rem 1.8rem;display:flex;flex-direction:column;flex:1}
.ins-meta{display:flex;gap:1rem;align-items:center;font-size:.8rem;color:var(--muted-soft);margin-bottom:.8rem;font-family:var(--font-mono)}
.ins-meta .tag{color:var(--accent-deep);text-transform:uppercase;letter-spacing:.1em}
.ins-meta .rt{display:inline-flex;align-items:center;gap:.35rem}
.ins-card h3{font-size:1.45rem;line-height:1.15;margin-bottom:.6rem}
.ins-card h3 a{color:var(--ink);text-decoration:none}
.ins-card h3 a:hover{color:var(--accent-deep)}
.ins-card p{color:var(--muted);font-size:.96rem;margin-bottom:1.2rem}
.ins-more{margin-top:auto}

/* ---- Resources blogroll ---- */
.res-list{display:grid;gap:0;border-top:1px solid var(--line-teal)}
.res-row{display:grid;grid-template-columns:auto 1fr auto;gap:1.4rem;align-items:center;padding:1.5rem 0;border-bottom:1px solid var(--line-teal);text-decoration:none;transition:padding .35s var(--ease)}
.res-row:hover{padding-inline:.8rem}
.res-row .rnum{font-family:var(--font-mono);font-size:.85rem;color:var(--accent)}
.res-row .rmain b{display:block;font-family:var(--font-display);font-size:1.3rem;color:#fff;font-weight:500}
.res-row .rmain span{font-size:.9rem;color:var(--on-teal-soft)}
.res-row .rgo{color:var(--accent);display:inline-flex}
.res-row:hover .rgo{transform:translateX(4px)}

/* ---- Testimonials ---- */
.tst-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.tst{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:2rem 1.8rem;display:flex;flex-direction:column}
.tst .qm{color:var(--accent-soft)}
.tst .qm svg{width:40px;height:40px;color:var(--secondary-deep)}
.tst blockquote{margin:.6rem 0 1.4rem;font-family:var(--font-display);font-size:1.18rem;line-height:1.4;color:var(--ink)}
.tst .who{margin-top:auto;display:flex;align-items:center;gap:.8rem}
.tst .av{width:44px;height:44px;border-radius:50%;background:var(--primary);color:var(--on-teal);display:inline-flex;align-items:center;justify-content:center;font-weight:600;font-size:.9rem}
.tst .who b{display:block;color:var(--ink);font-size:.97rem}
.tst .who span{font-size:.85rem;color:var(--muted-soft)}

/* ---- CTA band ---- */
.cta-band{position:relative;background:var(--primary);color:var(--on-teal);border-radius:calc(var(--radius) + 10px);padding:clamp(3rem,6vw,5rem);overflow:hidden;text-align:center}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 20%,rgba(217,97,44,.22),transparent 55%)}
.cta-band > *{position:relative}
.cta-band h2{font-size:clamp(2rem,4.5vw,3rem);color:#fff;margin-bottom:1rem}
.cta-band p{max-width:48ch;margin:0 auto 2rem;color:var(--on-teal-soft)}

/* ---- Page hero (inner) ---- */
.page-hero{background:var(--primary);color:var(--on-teal);padding:clamp(3.5rem,7vw,6rem) 0 clamp(3rem,6vw,5rem);position:relative;overflow:hidden}
.page-hero::after{content:"";position:absolute;right:-10%;top:-30%;width:560px;height:560px;border-radius:50%;background:radial-gradient(circle,rgba(217,97,44,.16),transparent 65%)}
.page-hero .wrap{position:relative}
.page-hero h1{font-size:clamp(2.4rem,5.5vw,4rem);color:#fff;margin-bottom:1.1rem;max-width:18ch}
.page-hero h1 em{font-style:italic;color:var(--accent)}
.page-hero p{max-width:54ch;color:var(--on-teal-soft);font-size:1.15rem}
.crumb{display:flex;gap:.5rem;align-items:center;font-size:.82rem;color:var(--on-teal-soft);margin-bottom:1.3rem;font-family:var(--font-mono)}
.crumb a{color:var(--on-teal-soft);text-decoration:none}
.crumb a:hover{color:#fff}
.crumb .sep{color:var(--accent)}

/* ---- About ---- */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.about-figure{border-radius:calc(var(--radius)+6px);overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:1/1}
.about-figure img{width:100%;height:100%;object-fit:cover}
.values-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.2rem}
.val{padding:1.6rem 1.5rem;border-radius:var(--radius);background:var(--white);border:1px solid var(--line)}
.val .ic{width:44px;height:44px;border-radius:11px;background:var(--secondary);color:var(--primary);display:inline-flex;align-items:center;justify-content:center;margin-bottom:.9rem}
.val .ic svg{width:22px;height:22px}
.val h3{font-size:1.2rem;margin-bottom:.4rem}
.val p{color:var(--muted);font-size:.93rem;margin:0}
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.member{text-align:center;padding:2rem 1.6rem;border-radius:var(--radius);background:var(--secondary)}
.member .av{width:74px;height:74px;border-radius:50%;background:var(--primary);color:var(--on-teal);display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:1.4rem;margin:0 auto 1.1rem}
.member h3{font-size:1.25rem;margin-bottom:.2rem}
.member .role{color:var(--accent-deep);font-size:.85rem;font-weight:600;letter-spacing:.04em;margin-bottom:.7rem}
.member p{color:var(--muted);font-size:.9rem;margin:0}

/* ---- Contact ---- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.form-card{background:var(--white);border:1px solid var(--line);border-radius:calc(var(--radius)+4px);padding:clamp(1.8rem,3.5vw,2.6rem);box-shadow:var(--shadow)}
.field{margin-bottom:1.3rem}
.field label{display:block;font-weight:600;font-size:.9rem;margin-bottom:.45rem;color:var(--ink)}
.field input,.field textarea{width:100%;font-family:var(--font-body);font-size:1rem;padding:.85rem 1rem;border:1.5px solid var(--line);border-radius:var(--radius);background:var(--bg);color:var(--ink);transition:border-color .25s var(--ease),box-shadow .25s var(--ease)}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(217,97,44,.18)}
.field textarea{resize:vertical;min-height:140px}
.form-card .btn{width:100%;justify-content:center}
.form-ok{display:none;margin-top:1.2rem;padding:1rem 1.2rem;border-radius:var(--radius);background:var(--secondary);color:var(--primary);font-weight:600;border-left:3px solid var(--accent)}
.form-ok.show{display:block}
.contact-aside .ci{display:flex;gap:1rem;padding:1.3rem 0;border-bottom:1px solid var(--line)}
.contact-aside .ci:last-child{border-bottom:0}
.contact-aside .ci .ic{flex:0 0 auto;width:46px;height:46px;border-radius:12px;background:var(--secondary);color:var(--primary);display:inline-flex;align-items:center;justify-content:center}
.contact-aside .ci .ic svg{width:22px;height:22px}
.contact-aside .ci b{display:block;color:var(--ink);font-family:var(--font-display);font-size:1.05rem}
.contact-aside .ci a{color:var(--accent-deep);text-decoration:none}
.contact-aside .ci span{color:var(--muted);font-size:.93rem}

/* ---- Article ---- */
.article{padding:clamp(3rem,6vw,5rem) 0 clamp(4rem,8vw,7rem)}
.article-wrap{width:min(720px,92vw);margin-inline:auto}
.article-hero-fig{width:min(1000px,92vw);margin:0 auto clamp(2.5rem,5vw,4rem);border-radius:calc(var(--radius)+6px);overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:16/8}
.article-hero-fig img{width:100%;height:100%;object-fit:cover}
.article-body{font-size:1.08rem;line-height:1.78;color:var(--fg)}
.article-body p{max-width:var(--measure)}
.article-body h2{font-size:clamp(1.7rem,3.4vw,2.3rem);margin:2.4rem 0 1rem;letter-spacing:-.015em}
.article-body h2:first-of-type{margin-top:.5rem}
.article-body h3{font-size:1.32rem;margin:1.9rem 0 .7rem;color:var(--primary)}
.article-body a{color:var(--accent-deep);font-weight:600;text-underline-offset:3px}
.article-body a:hover{color:var(--accent)}
.article-body strong{color:var(--ink)}
.article-body em{font-style:italic}
.article-body ul,.article-body ol{max-width:var(--measure);padding-left:1.3rem;margin:0 0 1.3em}
.article-body li{margin-bottom:.5em}
.article-body img{border-radius:var(--radius);margin:2rem auto;box-shadow:var(--shadow)}
.article-body section{margin:1.2rem 0}
.article-body section h2{margin-top:2.4rem}
.article-body section h3{margin-top:1.6rem;color:var(--ink);font-size:1.18rem}
.article-body [itemprop="text"]{color:var(--muted)}
.article-head{width:min(720px,92vw);margin:0 auto clamp(2rem,4vw,3rem);text-align:center}
.article-head h1{font-size:clamp(2.1rem,5vw,3.4rem);margin-bottom:1rem;letter-spacing:-.02em}
.article-meta{display:inline-flex;gap:1.2rem;align-items:center;font-family:var(--font-mono);font-size:.82rem;color:var(--muted-soft);justify-content:center}
.article-meta .tag{color:var(--accent-deep);text-transform:uppercase;letter-spacing:.1em}
.article-meta .rt{display:inline-flex;gap:.35rem;align-items:center}
.article-source{margin-top:clamp(3rem,5vw,4rem);padding:1.8rem 2rem;background:var(--secondary);border-radius:var(--radius);border-left:3px solid var(--accent)}
.article-source h2{font-size:1.2rem;margin-bottom:.6rem}
.article-source a{color:var(--accent-deep);font-weight:600;display:inline-flex;align-items:center;gap:.4rem}
.article-back{display:inline-flex;align-items:center;gap:.5rem;margin-top:2.5rem;color:var(--primary);font-weight:600;text-decoration:none}
.article-back svg{transform:rotate(180deg)}
.article-foot-cta{margin-top:clamp(3rem,6vw,5rem)}

/* ---- Reveal animation ---- */
.reveal{opacity:0;transform:translateY(26px)}
.reveal.in{opacity:1;transform:none;transition:opacity .9s var(--ease),transform .9s var(--ease)}
.clip-reveal{clip-path:inset(0 100% 0 0)}
.clip-reveal.in{clip-path:inset(0 0 0 0);transition:clip-path 1.1s var(--ease)}

/* ---- Responsive ---- */
@media (max-width:980px){
  .nav,.head-cta{display:none}
  .nav-toggle{display:block}
  .hero-grid{grid-template-columns:1fr;gap:2.5rem}
  .hero-media{max-width:440px}
  .intro-grid{grid-template-columns:1fr}
  .intro-aside{position:static}
  .about-grid,.contact-grid{grid-template-columns:1fr}
  .statband .wrap{grid-template-columns:repeat(2,1fr)}
  .approach-grid,.tst-grid,.team-grid{grid-template-columns:1fr}
  .ins-grid{grid-template-columns:1fr}
  .svc-feature,.svc-half,.svc-third{grid-column:span 12}
  .values-grid{grid-template-columns:1fr}
}
@media (max-width:560px){
  body{font-size:16px}
  .statband .wrap{grid-template-columns:1fr 1fr}
  .hero-badge{left:8px}
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important}
  .reveal{opacity:1!important;transform:none!important}
  .clip-reveal{clip-path:inset(0 0 0 0)!important}
  .ins-card:hover,.svc-card:hover,.tst:hover,.btn:hover{transform:none}
}
