/* ============ CAREON · Warm Humane theme ============ */
:root{
  --cream:#FAF7F2; --cream-2:#F3EEE4; --surface:#ffffff; --mint:#E8F2EE; --mint-2:#DCEDE6;
  --teal:#3AA8A0; --teal-d:#2E8A83; --teal-dd:#236C66;
  --coral:#F4A261; --coral-d:#E08B45; --coral-soft:#FBE7D2;
  --ink:#33403D; --muted:#6B7B76; --line:#E7E0D6;
  --shadow:0 22px 50px -26px rgba(46,138,131,.34);
  --shadow-sm:0 10px 28px -18px rgba(46,138,131,.30);
  --shadow-lg:0 40px 80px -40px rgba(46,138,131,.42);
  --r:26px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:"Noto Sans TC","Poppins",sans-serif;background:var(--cream);color:var(--ink);line-height:1.75;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,.en{font-family:"Poppins","Noto Sans TC",sans-serif}
.serif{font-family:"Noto Serif TC",serif}
.wrap{max-width:1180px;margin:0 auto;padding:0 28px}
a{text-decoration:none;color:inherit}
img{max-width:100%}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-family:"Poppins";font-size:13px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--teal-d)}
.eyebrow::before{content:"";width:22px;height:1.5px;background:var(--coral)}
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:16px;padding:15px 28px;border-radius:100px;border:none;cursor:pointer;transition:transform .25s,box-shadow .25s,background .25s;font-family:inherit;position:relative;overflow:hidden}
.btn-coral{background:var(--coral);color:#fff;box-shadow:0 14px 28px -12px rgba(224,139,69,.7)}
.btn-coral:hover{background:var(--coral-d);transform:translateY(-3px);box-shadow:0 20px 36px -14px rgba(224,139,69,.75)}
.btn-ghost{background:#fff;color:var(--teal-d);border:1.5px solid var(--mint-2)}
.btn-ghost:hover{border-color:var(--teal);background:var(--mint);transform:translateY(-2px)}
.btn svg{width:18px;height:18px;transition:transform .25s}
.btn-coral:hover svg{transform:translateX(4px)}

/* scroll progress */
.progress{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,var(--teal),var(--coral));z-index:100;transition:width .1s linear}

/* nav */
header{position:sticky;top:0;z-index:60;background:rgba(250,247,242,.8);backdrop-filter:blur(14px);border-bottom:1px solid rgba(231,224,214,.7)}
nav{display:flex;align-items:center;justify-content:space-between;height:76px}
.logo{font-family:"Poppins";font-weight:700;font-size:22px;letter-spacing:-.025em;display:inline-flex;align-items:center;gap:11px;color:var(--ink)}
.logo-mark{width:30px;height:30px;flex-shrink:0;display:inline-grid;place-items:center;filter:drop-shadow(0 3px 8px rgba(244,162,97,.28))}
.logo-mark svg,.logo-mark img{width:100%;height:100%;overflow:visible;object-fit:contain;transition:transform 1.1s cubic-bezier(.5,.1,.2,1)}
.logo:hover .logo-mark svg,.logo:hover .logo-mark img{transform:rotate(360deg)}
.logo-word{line-height:1}
.logo-word b{color:var(--teal);font-weight:700}
.logo-zh{font-family:"Noto Sans TC","Poppins",sans-serif;font-size:.78em;font-weight:700;letter-spacing:.04em;margin-left:9px;opacity:.95}
.navlinks{display:flex;gap:30px;align-items:center}
.navlinks a{font-size:15px;font-weight:500;color:var(--muted);transition:.2s;position:relative}
.navlinks a:not(.nav-cta)::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;background:var(--coral);border-radius:2px;transition:width .25s}
.navlinks a:not(.nav-cta):hover{color:var(--ink)}
.navlinks a:not(.nav-cta):hover::after{width:100%}
.navlinks a.active{color:var(--teal-d)}
.navlinks a.nav-cta{background:var(--teal);color:#fff;padding:10px 20px;border-radius:100px;font-weight:600;font-size:14px;transition:.25s}
.navlinks a.nav-cta:hover{background:var(--teal-d);transform:translateY(-1px);box-shadow:0 10px 22px -10px rgba(46,138,131,.7)}
/* language switch (中文 / English dropdown) */
.lang-switch{position:relative;margin-left:2px;font-family:"Poppins",sans-serif}
.lang-trigger{display:inline-flex;align-items:center;gap:7px;background:#fff;border:1.5px solid var(--mint-2);color:var(--teal-d);font-family:inherit;font-weight:600;font-size:13px;padding:9px 12px;border-radius:100px;cursor:pointer;transition:border-color .2s,background .2s,box-shadow .2s;line-height:1}
.lang-trigger:hover{border-color:var(--teal);background:var(--mint)}
.lang-trigger .globe{width:15px;height:15px;flex-shrink:0}
.lang-trigger .chev{width:11px;height:11px;opacity:.65;transition:transform .25s}
.lang-switch[data-open="true"] .lang-trigger{border-color:var(--teal);background:var(--mint);box-shadow:0 8px 18px -10px rgba(46,138,131,.55)}
.lang-switch[data-open="true"] .lang-trigger .chev{transform:rotate(180deg)}
.lang-menu{position:absolute;top:calc(100% + 9px);right:0;min-width:148px;background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:6px;display:flex;flex-direction:column;gap:2px;opacity:0;transform:translateY(-7px) scale(.96);transform-origin:top right;pointer-events:none;transition:opacity .2s,transform .2s cubic-bezier(.2,.8,.2,1);z-index:80}
.lang-switch[data-open="true"] .lang-menu{opacity:1;transform:none;pointer-events:auto}
.lang-opt{display:flex;align-items:center;gap:10px;width:100%;background:none;border:none;font-family:inherit;font-weight:600;font-size:14px;color:var(--muted);padding:10px 12px;border-radius:11px;cursor:pointer;text-align:left;transition:background .18s,color .18s}
.lang-opt:hover{background:var(--mint);color:var(--ink)}
.lang-opt .tick{width:7px;height:7px;border-radius:50%;background:transparent;flex-shrink:0;transition:background .2s,box-shadow .2s}
.lang-opt .sub{margin-left:auto;font-size:11px;font-weight:600;color:#b9c6c1;letter-spacing:.04em}
.lang-opt[aria-selected="true"]{color:var(--teal-d);background:var(--mint)}
.lang-opt[aria-selected="true"] .tick{background:var(--coral);box-shadow:0 0 0 4px rgba(244,162,97,.18)}
.nav-cluster{display:flex;align-items:center;gap:14px}
.menu-btn{display:none;background:none;border:none;cursor:pointer;padding:6px;border-radius:10px;transition:background .2s}
.menu-btn:hover{background:var(--mint)}
@media(max-width:900px){
  .menu-btn{display:grid;place-items:center}
  .navlinks{position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:4px;background:rgba(250,247,242,.98);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);box-shadow:var(--shadow);padding:12px 22px 18px;opacity:0;transform:translateY(-12px);pointer-events:none;transition:opacity .22s,transform .22s}
  header[data-menu="open"] .navlinks{opacity:1;transform:none;pointer-events:auto}
  .navlinks a:not(.nav-cta){display:block;padding:13px 6px;font-size:16px;color:var(--ink);border-bottom:1px solid var(--line)}
  .navlinks a:not(.nav-cta)::after{display:none}
  .navlinks a.nav-cta{display:flex;justify-content:center;width:100%;margin-top:10px;padding:14px;font-size:15.5px}
}

/* ===== hero ===== */
.hero{position:relative;padding:90px 0 76px;overflow:hidden}
.blob{position:absolute;border-radius:50%;filter:blur(10px);z-index:0;will-change:transform}
.blob.a{width:460px;height:460px;background:radial-gradient(circle,#cfe9e2,transparent 70%);top:-120px;right:-90px;opacity:.6}
.blob.b{width:340px;height:340px;background:radial-gradient(circle,#fbe2c9,transparent 70%);bottom:-90px;left:-80px;opacity:.55}
.blob.c{width:200px;height:200px;background:radial-gradient(circle,#d9efe8,transparent 70%);top:40%;left:46%;opacity:.5}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center;position:relative;z-index:1}
.hero h1{font-size:clamp(32px,5vw,56px);line-height:1.14;font-weight:700;letter-spacing:-.01em;margin:20px 0 22px}
.hero h1 .word{white-space:nowrap}
.hero h1 .hl{color:var(--teal);position:relative;display:inline-block}
.hero h1 .hl::after{content:"";position:absolute;left:0;right:0;bottom:.08em;height:.18em;background:rgba(244,162,97,.32);border-radius:6px;z-index:-1;transform:scaleX(0);transform-origin:left;animation:underline 1s .9s cubic-bezier(.2,.7,.2,1) forwards}
@keyframes underline{to{transform:scaleX(1)}}
.word{display:inline-block;animation:wordin .7s cubic-bezier(.2,.8,.2,1) forwards}
@keyframes wordin{from{opacity:0;transform:translateY(18px) rotate(2deg)}to{opacity:1;transform:none}}
.hero p.sub{font-size:19px;color:var(--muted);max-width:520px;margin-bottom:34px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.trust{display:flex;gap:22px;margin-top:36px;flex-wrap:wrap}
.trust div{display:flex;align-items:center;gap:9px;font-size:14px;color:var(--muted);font-weight:500}
.trust .ic{width:32px;height:32px;border-radius:10px;background:var(--mint);display:grid;place-items:center;color:var(--teal-d)}
.trust svg{width:16px;height:16px}
.hero-visual{position:relative}
.hero-card{background:#fff;border-radius:var(--r);box-shadow:var(--shadow-lg);padding:22px;position:relative;z-index:1;transition:transform .5s cubic-bezier(.2,.7,.2,1),box-shadow .5s}
.hero-card .glow{position:absolute;inset:-14px;border-radius:34px;background:radial-gradient(60% 60% at 30% 20%,rgba(58,168,160,.16),transparent 70%),radial-gradient(55% 55% at 80% 90%,rgba(244,162,97,.14),transparent 70%);z-index:-1;filter:blur(6px)}
.ph{background:repeating-linear-gradient(135deg,#eef4f1,#eef4f1 11px,#e4efe9 11px,#e4efe9 22px);border-radius:18px;display:grid;place-items:center;color:#9bb0a9;font-family:"Poppins",monospace;font-size:13px;letter-spacing:.04em;text-align:center;padding:16px}
.hero-card .ph{aspect-ratio:4/3.4}
.float-chip{position:absolute;background:#fff;border-radius:16px;box-shadow:var(--shadow-sm);padding:13px 16px;display:flex;align-items:center;gap:11px;font-size:14px;font-weight:600;z-index:2}
.float-chip .ic{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;flex-shrink:0}
.fc-1{top:-22px;left:-26px;animation:floaty 7s ease-in-out infinite}
.fc-2{bottom:30px;right:-30px;animation:floaty 7s ease-in-out infinite 1.4s}
.fc-3{bottom:-18px;left:30px;animation:floaty 7s ease-in-out infinite 2.8s}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}
.scrollcue{position:absolute;left:50%;bottom:20px;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:6px;color:var(--muted);font-size:11px;letter-spacing:.2em;z-index:2}
.scrollcue .mouse{width:22px;height:34px;border:1.5px solid var(--muted);border-radius:12px;position:relative}
.scrollcue .mouse::after{content:"";position:absolute;top:6px;left:50%;transform:translateX(-50%);width:3px;height:7px;background:var(--coral);border-radius:3px;animation:scrolldot 1.6s infinite}
@keyframes scrolldot{0%{opacity:0;transform:translate(-50%,0)}40%{opacity:1}80%{opacity:0;transform:translate(-50%,10px)}}
@media(max-width:900px){.hero-grid{grid-template-columns:1fr}.fc-1{left:-6px}.fc-2{right:-6px}.scrollcue{display:none}}

/* ===== sections ===== */
section{padding:92px 0;position:relative}
.sec-head{text-align:center;max-width:700px;margin:0 auto 56px}
.sec-head.left{text-align:left;margin-left:0}
.sec-head h2{font-size:clamp(30px,4.2vw,44px);font-weight:700;letter-spacing:-.01em;margin:16px 0 16px;line-height:1.25}
.sec-head p{color:var(--muted);font-size:17.5px;text-wrap:pretty}
.eyebrow.center{justify-content:center}

/* persona intro */
.persona{background:var(--mint)}
.persona-wrap{display:grid;grid-template-columns:.9fr 1.1fr;gap:50px;align-items:center}
.persona-vis{position:relative}
.persona-vis .ph{aspect-ratio:4/4.2;border-radius:var(--r);box-shadow:var(--shadow);border:6px solid #fff}
.persona-vis .tag{position:absolute;bottom:18px;left:18px;background:#fff;border-radius:14px;padding:11px 16px;box-shadow:var(--shadow-sm);font-size:13.5px;font-weight:600;display:flex;align-items:center;gap:9px}
.persona-vis .tag .d{width:9px;height:9px;border-radius:50%;background:var(--coral)}
.persona-txt .q{font-size:clamp(24px,3vw,33px);line-height:1.5;font-weight:500;color:var(--ink);margin-bottom:24px}
.persona-txt .q b{color:var(--teal-d);font-weight:700}
.persona-txt p{color:var(--muted);font-size:16.5px;margin-bottom:14px}
@media(max-width:880px){.persona-wrap{grid-template-columns:1fr;gap:30px}}

/* ===== pain — editorial journey list ===== */
.pain-layout{display:grid;grid-template-columns:.82fr 1.18fr;gap:64px;align-items:start}
.pain-aside{position:sticky;top:112px}
.pain-aside h2{font-size:clamp(28px,3.3vw,40px);font-weight:700;letter-spacing:-.01em;line-height:1.24;margin:16px 0 18px}
.pain-aside p{color:var(--muted);font-size:16.5px;max-width:360px}
.pain-aside-foot{display:flex;align-items:baseline;gap:13px;margin-top:32px;padding-top:26px;border-top:1px solid var(--line)}
.pain-aside-foot .big{font-family:"Poppins";font-weight:700;font-size:56px;color:var(--coral);line-height:.8}
.pain-aside-foot .txt{color:var(--muted);font-size:15px;font-weight:600}
.pain-track{list-style:none;position:relative}
.pain-track::before{content:"";position:absolute;left:91px;top:52px;bottom:52px;width:2px;background:linear-gradient(var(--mint-2),var(--coral-soft));z-index:0}
.ptk-item{position:relative;z-index:1;display:grid;grid-template-columns:64px 56px 1fr;align-items:center;gap:0 22px;padding:22px 18px;border-radius:18px;border-bottom:1px solid var(--line);transition:background .35s,transform .35s,box-shadow .35s}
.pain-track .ptk-item:last-child{border-bottom:none}
.ptk-item:hover{background:#fff;transform:translateX(8px);box-shadow:var(--shadow-sm)}
.ptk-num{font-family:"Poppins";font-weight:700;font-size:26px;color:#cfe0d9;transition:color .35s}
.ptk-item:hover .ptk-num{color:var(--coral)}
.ptk-ic{width:56px;height:56px;border-radius:16px;background:#fff;border:1px solid var(--line);display:grid;place-items:center;color:var(--teal-d);transition:.35s}
.ptk-item:hover .ptk-ic{background:var(--teal);border-color:var(--teal);color:#fff;transform:rotate(-6deg)}
.ptk-ic svg{width:26px;height:26px}
.ptk-role{display:inline-block;font-family:"Poppins";font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--teal-d);background:var(--mint);padding:4px 11px;border-radius:100px;margin-bottom:8px}
.ptk-body h3{font-size:18.5px;font-weight:700;line-height:1.45}
@media(max-width:880px){
  .pain-layout{grid-template-columns:1fr;gap:34px}
  .pain-aside{position:static}
  .pain-track::before{display:none}
  .ptk-item{grid-template-columns:46px 50px 1fr;gap:0 14px;padding:18px 0;border-radius:0}
  .ptk-item:hover{transform:none;background:transparent;box-shadow:none}
  .ptk-num{font-size:20px}
}

/* ===== products — zigzag feature blocks ===== */
.prod-zig{display:flex;flex-direction:column;gap:28px}
.pz{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center;background:#fff;border-radius:var(--r);border:1px solid var(--line);box-shadow:var(--shadow-sm);overflow:hidden;transition:box-shadow .4s,transform .4s}
.pz:hover{box-shadow:var(--shadow);transform:translateY(-4px)}
.pz.reverse .pz-vis{order:2}
.pz-vis{position:relative;padding:18px;display:flex}
.pz-vis .ph{aspect-ratio:16/11;width:100%;border-radius:18px;transition:transform .5s}
.pz:hover .pz-vis .ph{transform:scale(1.03)}
.pz-step{position:absolute;top:32px;left:32px;background:#fff;border-radius:100px;font-family:"Poppins";font-weight:700;font-size:12px;color:var(--teal-d);padding:6px 14px;box-shadow:var(--shadow-sm)}
.pz-txt{padding:18px 44px 18px 10px}
.pz.reverse .pz-txt{padding:18px 10px 18px 44px}
.pz-idx{font-family:"Poppins";font-weight:700;font-size:13px;letter-spacing:.14em;color:var(--coral);display:block;margin-bottom:14px}
.pz-txt .badge{margin-bottom:14px}
.pz-txt h3{font-size:26px;font-weight:700;letter-spacing:-.01em;margin-bottom:12px}
.pz-txt p{color:var(--muted);font-size:15.5px}
.pz-txt .for{margin-top:18px;padding-top:16px;border-top:1px dashed var(--line);font-size:14px;color:var(--teal-d);font-weight:600;display:flex;align-items:center;gap:8px}
.pz-txt .for svg{width:16px;height:16px}
@media(max-width:880px){.pz{grid-template-columns:1fr;gap:0}.pz.reverse .pz-vis{order:0}.pz-txt,.pz.reverse .pz-txt{padding:6px 28px 30px}}

/* ===== why — asymmetric bento ===== */
.why-bento{display:grid;grid-template-columns:1.05fr 1fr 1fr;grid-template-rows:auto auto;gap:20px}
.why-head{grid-column:1;grid-row:1 / span 2;align-self:center;padding-right:18px}
.why-head h2{font-size:clamp(28px,3.4vw,40px);font-weight:700;line-height:1.24;letter-spacing:-.01em;margin:16px 0 14px}
.why-head p{color:var(--muted);font-size:16px}
.why-feature{grid-column:2 / span 2;grid-row:1;display:grid;grid-template-columns:1.05fr .95fr;gap:28px;align-items:center;background:linear-gradient(150deg,var(--teal-d),var(--teal));color:#fff;border-radius:var(--r);padding:36px;box-shadow:var(--shadow)}
.wf-ic{width:56px;height:56px;border-radius:16px;background:rgba(255,255,255,.18);display:grid;place-items:center;margin-bottom:16px}
.wf-ic svg{width:28px;height:28px}
.wf-tag{display:inline-block;font-family:"Poppins";font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;background:rgba(255,255,255,.16);color:#fff;padding:4px 11px;border-radius:100px;margin-bottom:12px}
.why-feature h3{color:#fff;font-size:23px;font-weight:700;margin-bottom:10px}
.why-feature p{color:rgba(255,255,255,.9);font-size:15px}
.wf-ph{aspect-ratio:4/3.3;border-radius:16px;background:repeating-linear-gradient(135deg,rgba(255,255,255,.1),rgba(255,255,255,.1) 11px,rgba(255,255,255,.17) 11px,rgba(255,255,255,.17) 22px);display:grid;place-items:center;color:rgba(255,255,255,.82);font-size:12px;text-align:center;padding:14px;line-height:1.5}
.why-small{grid-row:2;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:30px;box-shadow:var(--shadow-sm);transition:transform .3s,box-shadow .3s}
.why-small:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.why-small .wf-ic{background:var(--coral);box-shadow:0 12px 24px -12px rgba(224,139,69,.7)}
.why-small h3{font-size:20px;font-weight:700;margin-bottom:9px}
.why-small p{color:var(--muted);font-size:14.5px}
@media(max-width:880px){
  .why-bento{grid-template-columns:1fr}
  .why-head,.why-feature,.why-small{grid-column:1;grid-row:auto}
  .why-feature{grid-template-columns:1fr}
}

/* products */
.prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.prod-card{background:#fff;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--line);transition:transform .35s,box-shadow .35s;display:flex;flex-direction:column}
.prod-card:hover{transform:translateY(-10px);box-shadow:var(--shadow-lg)}
.prod-card .top{padding:14px;position:relative;overflow:hidden}
.prod-card .ph{aspect-ratio:16/10;transition:transform .5s}
.prod-card:hover .ph{transform:scale(1.04)}
.prod-card .step-pill{position:absolute;top:24px;left:24px;background:#fff;border-radius:100px;font-family:"Poppins";font-weight:700;font-size:12px;color:var(--teal-d);padding:5px 12px;box-shadow:var(--shadow-sm)}
.prod-card .body{padding:8px 26px 28px;display:flex;flex-direction:column;flex:1}
.badge{display:inline-flex;align-items:center;gap:7px;align-self:flex-start;background:var(--mint);color:var(--teal-dd);font-weight:700;font-size:12.5px;padding:6px 13px;border-radius:100px;margin-bottom:14px}
.badge .d{width:7px;height:7px;border-radius:50%;background:var(--teal)}
.prod-card h3{font-size:21px;font-weight:700;margin-bottom:10px;letter-spacing:-.01em}
.prod-card p{color:var(--muted);font-size:15px;flex:1}
.prod-card .for{margin-top:16px;padding-top:16px;border-top:1px dashed var(--line);font-size:13.5px;color:var(--teal-d);font-weight:600;display:flex;align-items:center;gap:8px}
.prod-card .for svg{width:16px;height:16px}
@media(max-width:900px){.prod-grid{grid-template-columns:1fr}}

/* ===== story scrolly ===== */
.story{background:linear-gradient(180deg,var(--cream),var(--mint))}
.story-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:56px;align-items:start}
.story-sticky{position:sticky;top:110px}
.scene{background:#fff;border-radius:var(--r);box-shadow:var(--shadow);padding:18px;position:relative;overflow:hidden}
.scene .ph{aspect-ratio:4/3.7;transition:opacity .4s}
.scene .scene-label{position:absolute;top:30px;left:30px;background:#fff;border-radius:100px;padding:8px 16px;font-weight:700;font-size:13.5px;color:var(--teal-d);box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:9px}
.scene .scene-label .d{width:8px;height:8px;border-radius:50%;background:var(--coral);box-shadow:0 0 0 4px rgba(244,162,97,.2)}
.scene .timechip{position:absolute;bottom:30px;right:30px;background:var(--teal);color:#fff;border-radius:14px;padding:10px 16px;font-family:"Poppins";font-weight:700;font-size:15px;box-shadow:var(--shadow-sm);transition:.4s}
.story-steps{display:flex;flex-direction:column;gap:18px}
.story-step{background:rgba(255,255,255,.5);border:1px solid transparent;border-radius:20px;padding:26px 28px;transition:.4s;opacity:.5}
.story-step.on{background:#fff;border-color:var(--mint-2);box-shadow:var(--shadow);opacity:1;transform:translateX(6px)}
.story-step .head{display:flex;align-items:center;gap:14px;margin-bottom:8px}
.story-step .ic{width:46px;height:46px;border-radius:13px;background:var(--mint);display:grid;place-items:center;color:var(--teal-d);flex-shrink:0;transition:.4s}
.story-step.on .ic{background:var(--coral);color:#fff}
.story-step .ic svg{width:24px;height:24px}
.story-step .num{font-family:"Poppins";font-weight:700;font-size:13px;color:var(--coral);letter-spacing:.08em}
.story-step h3{font-size:21px;font-weight:700}
.story-step p{color:var(--muted);font-size:15.5px;padding-left:60px}
@media(max-width:880px){.story-grid{grid-template-columns:1fr;gap:30px}.story-sticky{position:static}.story-step{opacity:1}.story-step p{padding-left:0}}

/* ===== animated loop ===== */
.loop{background:#fff}
.ringwrap{position:relative;max-width:660px;margin:10px auto 0}
.ring{position:relative;aspect-ratio:1}
.ring svg.track{position:absolute;inset:0;width:100%;height:100%;overflow:visible}
.ring .hub{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:33%;aspect-ratio:1;border-radius:50%;background:radial-gradient(circle at 35% 30%,var(--teal),var(--teal-dd));color:#fff;display:grid;place-items:center;text-align:center;padding:20px;box-shadow:0 24px 56px -22px rgba(46,138,131,.8)}
.ring .hub::before{content:"";position:absolute;inset:-10px;border-radius:50%;border:1.5px dashed rgba(58,168,160,.35)}
.ring .hub b{font-family:"Poppins";font-size:clamp(17px,2.4vw,23px);font-weight:700;display:block;line-height:1.2}
.ring .hub span{font-size:12.5px;opacity:.85;margin-top:5px;letter-spacing:.05em}
.node{position:absolute;width:31%;background:#fff;border-radius:20px;box-shadow:var(--shadow-sm);padding:18px 16px;text-align:center;border:1.5px solid transparent;transition:transform .4s,box-shadow .4s,border-color .4s}
.node .ic{width:48px;height:48px;border-radius:14px;background:var(--mint);color:var(--teal-d);display:grid;place-items:center;margin:0 auto 10px;transition:.4s}
.node .ic svg{width:25px;height:25px}
.node b{display:block;font-size:15.5px;font-weight:700;margin-bottom:3px}
.node small{color:var(--muted);font-size:12.5px;line-height:1.45;display:block}
.node.active{transform:scale(1.07);box-shadow:var(--shadow-lg);border-color:var(--coral)}
.node.active .ic{background:var(--coral);color:#fff;transform:rotate(-6deg) scale(1.05)}
.node.n1{top:-2%;left:50%;transform:translateX(-50%)}
.node.n1.active{transform:translateX(-50%) scale(1.07)}
.node.n2{top:50%;right:-2%;transform:translateY(-50%)}
.node.n2.active{transform:translateY(-50%) scale(1.07)}
.node.n3{bottom:-2%;left:50%;transform:translateX(-50%)}
.node.n3.active{transform:translateX(-50%) scale(1.07)}
.node.n4{top:50%;left:-2%;transform:translateY(-50%)}
.node.n4.active{transform:translateY(-50%) scale(1.07)}
.loop-list{display:none;flex-direction:column;gap:14px;max-width:520px;margin:10px auto 0}
.ll-item{display:flex;gap:16px;align-items:flex-start;background:#fff;border-radius:18px;padding:18px;box-shadow:var(--shadow-sm)}
.ll-item .ic{width:44px;height:44px;border-radius:12px;background:var(--mint);display:grid;place-items:center;color:var(--teal-d);flex-shrink:0}
.ll-item b{font-size:16px}.ll-item small{color:var(--muted);font-size:13.5px}
@media(max-width:720px){.ringwrap{display:none}.loop-list{display:flex}}

/* why */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.why-card{padding:8px}
.why-card .ic{width:60px;height:60px;border-radius:18px;background:var(--coral);color:#fff;display:grid;place-items:center;margin-bottom:20px;box-shadow:0 14px 28px -14px rgba(224,139,69,.8);transition:.35s}
.why-card:hover .ic{transform:translateY(-4px) rotate(-5deg)}
.why-card .ic svg{width:30px;height:30px}
.why-card h3{font-size:21px;font-weight:700;margin-bottom:10px}
.why-card p{color:var(--muted);font-size:15.5px}
@media(max-width:900px){.why-grid{grid-template-columns:1fr}}

/* mission */
.mission{background:var(--ink);color:#e9efed;position:relative;overflow:hidden}
.mission .blob{filter:blur(20px)}
.mission .mb1{width:420px;height:420px;background:radial-gradient(circle,rgba(58,168,160,.3),transparent 70%);top:-160px;left:-100px;opacity:.5}
.mission .mb2{width:340px;height:340px;background:radial-gradient(circle,rgba(244,162,97,.22),transparent 70%);bottom:-140px;right:-80px;opacity:.5}
.mission-in{position:relative;z-index:1;max-width:920px;margin:0 auto;text-align:center}
.mission .eyebrow{color:var(--coral);justify-content:center}
.mission .eyebrow::before{background:var(--coral)}
.mission .big{font-size:clamp(26px,3.6vw,40px);line-height:1.5;font-weight:500;margin:20px 0 14px;text-wrap:pretty}
.mission .big b{color:var(--teal);font-weight:700}
.mission .vis-line{color:#9fb1ac;font-size:17px;max-width:620px;margin:0 auto 48px}
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;text-align:left}
.value{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:30px 26px;transition:.3s}
.value:hover{background:rgba(255,255,255,.07);transform:translateY(-5px)}
.value .ic{width:50px;height:50px;border-radius:14px;background:var(--teal);color:#fff;display:grid;place-items:center;margin-bottom:18px}
.value .ic svg{width:26px;height:26px}
.value h3{color:#fff;font-size:19px;font-weight:700;margin-bottom:9px}
.value p{color:#9fb1ac;font-size:14.5px}
@media(max-width:880px){.values{grid-template-columns:1fr}}

/* solutions entry */
.sol{background:var(--mint)}
.sol-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.sol-card{background:#fff;border-radius:var(--r);padding:32px 28px;box-shadow:var(--shadow-sm);transition:transform .3s,box-shadow .3s;display:flex;flex-direction:column;gap:6px;position:relative;overflow:hidden}
.sol-card::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--teal);transform:scaleX(0);transform-origin:left;transition:.35s}
.sol-card:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.sol-card:hover::before{transform:scaleX(1)}
.sol-card .ic{width:56px;height:56px;border-radius:16px;display:grid;place-items:center;margin-bottom:14px;transition:.3s}
.sol-card:hover .ic{transform:rotate(-6deg)}
.sol-card h3{font-size:22px;font-weight:700}
.sol-card p{color:var(--muted);font-size:15px;flex:1;margin-bottom:14px}
.sol-card .go{font-weight:700;color:var(--teal-d);display:flex;align-items:center;gap:8px;font-size:15px}
.sol-card:hover .go svg{transform:translateX(6px)}
.sol-card .go svg{transition:.25s;width:18px;height:18px}
@media(max-width:900px){.sol-grid{grid-template-columns:1fr}}

/* cta */
.cta-band{padding:70px 0}
.cta-box{background:linear-gradient(120deg,var(--teal-d),var(--teal));border-radius:36px;padding:66px 48px;text-align:center;color:#fff;position:relative;overflow:hidden}
.cta-box .glow{position:absolute;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(244,162,97,.42),transparent 70%);top:-140px;right:-60px}
.cta-box .glow2{position:absolute;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.12),transparent 70%);bottom:-120px;left:-40px}
.cta-box h2{font-size:clamp(28px,4.2vw,42px);font-weight:700;margin-bottom:16px;position:relative;line-height:1.3}
.cta-box p{font-size:17.5px;opacity:.94;max-width:580px;margin:0 auto 32px;position:relative}
.cta-box .btn-coral{position:relative}

/* footer */
footer{background:#2b3733;color:#cfd8d5;padding:60px 0 30px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;margin-bottom:42px}
footer .logo{color:#fff;margin-bottom:14px}
footer .logo-mark{filter:drop-shadow(0 3px 10px rgba(244,162,97,.4))}
footer p.desc{font-size:14.5px;color:#9aa8a3;max-width:320px}
.foot-col h4{font-family:"Poppins";font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:#8a9893;margin-bottom:16px}
.foot-col a{display:block;color:#cfd8d5;font-size:14.5px;margin-bottom:11px;transition:.2s}
.foot-col a:hover{color:var(--coral);transform:translateX(3px)}
.foot-bottom{border-top:1px solid #3c4844;padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:13px;color:#8a9893}
@media(max-width:760px){.foot-grid{grid-template-columns:1fr 1fr}}

/* reveal */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}.reveal[data-d="2"]{transition-delay:.16s}.reveal[data-d="3"]{transition-delay:.24s}

/* ===== UX polish ===== */
:focus-visible{outline:2.5px solid var(--teal);outline-offset:3px;border-radius:4px}
.btn,.nav-cta,.sol-card,.navlinks a{-webkit-tap-highlight-color:transparent}
.btn:focus-visible{outline-offset:4px}
::selection{background:var(--coral-soft);color:var(--coral-d)}
.btn::after{content:"";position:absolute;inset:0;border-radius:inherit;background:radial-gradient(circle at center,rgba(255,255,255,.5),transparent 60%);opacity:0;transform:scale(.4);transition:opacity .4s,transform .4s}
.btn:active::after{opacity:.5;transform:scale(1);transition:0s}
.btn:active{transform:translateY(0) scale(.98)}
/* gentle scrollbar */
@media(min-width:900px){
  html{scrollbar-width:thin;scrollbar-color:var(--mint-2) transparent}
  ::-webkit-scrollbar{width:11px}
  ::-webkit-scrollbar-thumb{background:var(--mint-2);border-radius:10px;border:3px solid var(--cream)}
  ::-webkit-scrollbar-thumb:hover{background:var(--teal)}
}

/* ===== real photos filling placeholder boxes ===== */
.ph,.wf-ph{position:relative;overflow:hidden}
.ph>img,.wf-ph>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.ph-note{font-size:12px;line-height:1.55;color:var(--muted);text-align:center;margin:10px 6px 0;opacity:.85}
.pz-vis{flex-direction:column}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition-duration:.01ms!important}
  .reveal{opacity:1;transform:none}
  .word{opacity:1;transform:none}
  .hero h1 .hl::after{transform:scaleX(1)}
}
