/* ============================================================
   Dr.A Device Clinic — main.css
   Design system ported from the dra-3c.tw static site,
   extended for the WordPress theme (diagnostic card, modal, etc.)
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  --primary:#1e9df1; --primary-deep:#1280cf; --primary-ink:#0e6db6;
  --ink:#0f1419; --ink-2:#3c4a57; --ink-3:#6a7884; --ink-4:#97a3ad;
  --bg:#ffffff; --card:#f7f8f8; --accent:#e3ecf6; --accent-2:#f0f6fc;
  --border:#e1eaef; --border-soft:#edf2f6;
  --navy:#0a1019; --navy-2:#0f1722; --navy-glow:#143047;
  --r-xl:34px; --r-lg:26px; --r-md:18px; --r-sm:13px; --r-pill:999px;
  --shadow-xs:0 1px 2px rgba(15,20,25,.05); --shadow-sm:0 2px 10px rgba(15,20,25,.05);
  --shadow:0 14px 40px -18px rgba(15,20,25,.18); --shadow-lg:0 30px 70px -28px rgba(15,20,25,.28);
  --glow:0 20px 60px -22px rgba(30,157,241,.45); --glow-soft:0 14px 44px -20px rgba(30,157,241,.30);
  --sans:"Open Sans","Noto Sans TC",system-ui,-apple-system,sans-serif;
  --tc:"Noto Sans TC","Open Sans",system-ui,sans-serif;
  --maxw:1200px; --gutter:clamp(20px,5vw,64px); --section-y:clamp(84px,11vw,148px);
}

/* ---------- Reset / base ---------- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--sans);background:var(--bg);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:clip}
img,svg{display:block;max-width:100%}
img[width]{height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{list-style:none}
::selection{background:rgba(30,157,241,.18)}

.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:var(--section-y);position:relative}
.tc{font-family:var(--tc)}
.muted{color:var(--ink-3)}

.screen-reader-text{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
.skip-link{position:absolute;left:-999px;top:0;z-index:200}
.skip-link:focus{left:8px;top:8px;background:#fff;color:var(--ink);padding:10px 16px;border-radius:8px;box-shadow:var(--shadow)}
:focus-visible{outline:2px solid var(--primary);outline-offset:3px;border-radius:4px}

/* ---------- Ambient background ---------- */
.ambient{position:fixed;inset:0;z-index:-1;overflow:hidden;pointer-events:none}
.ambient .blob{position:absolute;border-radius:50%}
.ambient .b1{width:760px;height:760px;top:-300px;right:-220px;background:radial-gradient(circle at 50% 50%,rgba(30,157,241,.16),rgba(30,157,241,0) 68%)}
.ambient .b2{width:640px;height:640px;top:34%;left:-300px;background:radial-gradient(circle at 50% 50%,rgba(227,236,246,.85),rgba(227,236,246,0) 70%)}
.ambient .b3{width:680px;height:680px;bottom:-260px;right:-160px;background:radial-gradient(circle at 50% 50%,rgba(30,157,241,.10),rgba(30,157,241,0) 70%)}
.ambient .grid{position:absolute;inset:0;background-image:radial-gradient(rgba(15,20,25,.035) 1px,transparent 1px);background-size:38px 38px;-webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 0%,#000 30%,transparent 75%);mask-image:radial-gradient(ellipse 80% 60% at 50% 0%,#000 30%,transparent 75%)}

/* ---------- Typography ---------- */
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:12.5px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--primary-ink)}
.eyebrow::before{content:"";width:22px;height:1.5px;border-radius:2px;background:linear-gradient(90deg,var(--primary),transparent)}
.eyebrow.center::after{content:"";width:22px;height:1.5px;border-radius:2px;background:linear-gradient(270deg,var(--primary),transparent)}
.eyebrow-dk{display:inline-flex;align-items:center;gap:9px;font-size:12.5px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:#74c5fb}
.eyebrow-dk::before{content:"";width:22px;height:1.5px;border-radius:2px;background:linear-gradient(90deg,#74c5fb,transparent)}
h1,h2,h3{font-family:var(--tc);font-weight:700;line-height:1.12;letter-spacing:-.01em;color:var(--ink)}
.h-display{font-size:clamp(2.5rem,5.4vw,4.1rem);font-weight:800;line-height:1.06;letter-spacing:-.025em}
.h-section{font-size:clamp(1.9rem,3.6vw,2.85rem);font-weight:700;letter-spacing:-.02em}
.h-section.dark,h2.dark{color:#fff}
.lede{font-size:clamp(1.02rem,1.4vw,1.18rem);color:var(--ink-2);line-height:1.7}
.section-head{max-width:660px}
.section-head.center{margin-inline:auto;text-align:center}
.section-head .h-section{margin-top:18px}
.section-head p{margin-top:16px}

/* ---------- Buttons ---------- */
.btn{--h:54px;display:inline-flex;align-items:center;justify-content:center;gap:9px;height:var(--h);padding-inline:26px;border-radius:var(--r-pill);font-family:var(--tc);font-size:1rem;font-weight:700;letter-spacing:.01em;white-space:nowrap;transition:transform .25s cubic-bezier(.2,.8,.2,1),box-shadow .25s,background .2s,color .2s,border-color .2s}
.btn svg{width:18px;height:18px}
.btn-primary{background:linear-gradient(180deg,#36abf6,var(--primary));color:#fff;box-shadow:var(--glow)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 26px 70px -20px rgba(30,157,241,.6)}
.btn-ghost{background:rgba(255,255,255,.7);color:var(--ink);border:1px solid var(--border);backdrop-filter:blur(10px);box-shadow:var(--shadow-xs)}
.btn-ghost:hover{transform:translateY(-2px);border-color:#cfdcea;box-shadow:var(--shadow-sm)}
.btn-sm{--h:44px;padding-inline:20px;font-size:.94rem}
.btn-lg{--h:60px;padding-inline:34px;font-size:1.06rem}
.link-arrow{display:inline-flex;align-items:center;gap:6px;font-family:var(--tc);font-weight:700;font-size:.9rem;color:var(--primary-ink);transition:gap .2s;margin-top:14px}
.link-arrow svg{width:15px;height:15px;transition:transform .2s}
.link-arrow:hover{gap:9px}
.link-arrow:hover svg{transform:translateX(2px)}

/* ---------- Navbar ---------- */
.nav-shell{position:fixed;top:0;left:0;right:0;z-index:100;padding-top:18px;transition:padding .3s}
.nav{display:flex;align-items:center;gap:18px;height:64px;padding:8px 8px 8px 22px;border-radius:var(--r-pill);background:rgba(255,255,255,.62);border:1px solid rgba(255,255,255,.7);backdrop-filter:blur(22px) saturate(180%);-webkit-backdrop-filter:blur(22px) saturate(180%);box-shadow:0 10px 36px -18px rgba(15,20,25,.22),inset 0 1px 0 rgba(255,255,255,.7);transition:box-shadow .3s,background .3s,transform .3s}
.nav-shell.scrolled{padding-top:12px}
.nav-shell.scrolled .nav{background:rgba(255,255,255,.82);box-shadow:0 16px 44px -20px rgba(15,20,25,.3),inset 0 1px 0 rgba(255,255,255,.8)}
.nav-shell.over-dark .nav{background:rgba(14,24,38,.46);border-color:rgba(140,185,225,.16);box-shadow:0 12px 40px -20px rgba(0,0,0,.65),inset 0 1px 0 rgba(255,255,255,.08)}
.nav-shell.over-dark.scrolled .nav{background:rgba(12,20,32,.66)}

.brand{display:flex;align-items:center;gap:11px;font-family:var(--tc);font-weight:800}
.brand .custom-logo{height:46px;width:auto}
.brand .mark{width:40px;height:40px;border-radius:12px;flex:none;display:grid;place-items:center;color:#fff;background:linear-gradient(150deg,#36abf6,var(--primary-deep));box-shadow:var(--glow-soft);position:relative;overflow:hidden}
.brand .mark::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.35),transparent 50%)}
.brand .mark svg{width:21px;height:21px;position:relative}
.brand-lockup{display:flex;flex-direction:column;line-height:1}
.brand .name{font-size:1.24rem;letter-spacing:-.02em;color:var(--ink)}
.brand .name b{color:var(--primary-ink)}
.brand .tag{font-size:10.5px;font-weight:600;letter-spacing:.12em;color:var(--ink-4);text-transform:uppercase;margin-top:3px;white-space:nowrap}
.nav-shell.over-dark .brand .name{color:#fff}
.nav-shell.over-dark .brand .name b{color:#6fc3fb}
.nav-shell.over-dark .brand .tag{color:rgba(160,190,215,.7)}

.nav-links{display:flex;align-items:center;gap:4px;margin-left:auto}
.nav-links li{display:flex}
.nav-links a{font-family:var(--tc);font-weight:600;font-size:.96rem;color:var(--ink-2);padding:9px 15px;border-radius:var(--r-pill);transition:color .2s,background .2s}
.nav-links a:hover,.nav-links a.active,.nav-links .current-menu-item>a{color:var(--primary);background:rgba(30,157,241,.07)}
.nav-shell.over-dark .nav-links a{color:rgba(206,224,242,.82)}
.nav-shell.over-dark .nav-links a:hover{color:#fff;background:rgba(255,255,255,.08)}
.nav-cta{display:flex;align-items:center;gap:8px}
.nav-shell.over-dark .nav-cta .btn-ghost{background:rgba(255,255,255,.1);color:#fff;border-color:rgba(255,255,255,.2)}
.nav-burger{display:none;width:44px;height:44px;border-radius:50%;align-items:center;justify-content:center;color:var(--ink)}
.nav-burger svg{width:22px;height:22px}
.nav-shell.over-dark .nav-burger{color:#fff}

/* Mobile menu panel */
.mobile-menu{position:fixed;top:90px;left:var(--gutter);right:var(--gutter);z-index:99;display:flex;flex-direction:column;gap:6px;padding:18px;border-radius:var(--r-lg);background:rgba(255,255,255,.92);backdrop-filter:blur(22px);border:1px solid var(--border);box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transform:translateY(-12px) scale(.98);transform-origin:top;transition:opacity .25s,transform .25s,visibility .25s}
.mobile-menu.show{opacity:1;visibility:visible;transform:translateY(0) scale(1)}
.mobile-menu a{font-family:var(--tc);font-weight:600;font-size:1.02rem;color:var(--ink);padding:13px 14px;border-radius:var(--r-md)}
.mobile-menu a:hover{background:var(--accent-2);color:var(--primary-ink)}
.mobile-menu .mobile-links{display:flex;flex-direction:column;gap:6px}
.mobile-menu .btn{margin-top:8px}

/* ---------- Inner-page top spacing (clears fixed navbar) ---------- */
body:not(.dra-has-dark-hero) #main > .section:first-child{padding-top:clamp(120px,14vw,165px)}

/* ---------- Hero ---------- */
.hero{padding-top:clamp(120px,15vw,180px);padding-bottom:clamp(56px,8vw,80px);position:relative;color:#fff;overflow:hidden;isolation:isolate;background:radial-gradient(58% 50% at 80% 46%,rgba(30,157,241,.20),rgba(30,157,241,0) 62%),radial-gradient(70% 60% at 88% 8%,rgba(40,120,190,.28),rgba(40,120,190,0) 55%),radial-gradient(80% 80% at 8% 96%,rgba(18,40,62,.7),rgba(18,40,62,0) 60%),linear-gradient(168deg,#0c1623,#070d16 55%,#0a1019)}
.hero::before{content:"";position:absolute;inset:0;z-index:-2;pointer-events:none;background-image:linear-gradient(rgba(120,170,210,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(120,170,210,.05) 1px,transparent 1px);background-size:48px 48px;-webkit-mask-image:radial-gradient(120% 92% at 50% 28%,#000 42%,transparent 82%);mask-image:radial-gradient(120% 92% at 50% 28%,#000 42%,transparent 82%)}
.hero>.wrap{position:relative;z-index:1}
.hero-grid{display:grid;grid-template-columns:1.04fr .96fr;gap:clamp(32px,4vw,64px);align-items:center}
.hero-copy{max-width:560px}
.hero .eyebrow{color:#74c5fb}
.hero .eyebrow::before{background:linear-gradient(90deg,#74c5fb,transparent)}
.hero h1{margin:22px 0 0;color:#fff}
.hero h1 .accent{color:#5cbcf8}
.hero .lede{margin-top:22px;max-width:480px;color:rgba(206,224,242,.82)}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
.hero .btn-ghost{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(160,195,225,.28);backdrop-filter:blur(10px)}
.hero .btn-ghost:hover{background:rgba(255,255,255,.14);border-color:rgba(180,210,235,.5)}
.hero-trust{display:flex;align-items:center;gap:20px;margin-top:40px;flex-wrap:wrap}
.hero-trust .stars{color:#f5b53e;letter-spacing:2px;font-size:.95rem}
.hero-trust .t-item{display:flex;flex-direction:column;line-height:1.25}
.hero-trust .t-item b{font-family:var(--tc);font-weight:800;font-size:1.18rem;color:#fff}
.hero-trust .t-item span{font-size:.8rem;color:rgba(170,196,220,.72)}
.hero-trust .divider{width:1px;height:34px;background:rgba(150,185,215,.22)}
.hero-support{position:relative;z-index:1;margin-top:48px;padding-top:26px;border-top:1px solid rgba(120,170,210,.14);display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.hero-support-label{font-family:var(--tc);font-weight:700;font-size:.82rem;letter-spacing:.1em;color:#74c5fb;white-space:nowrap}
.hero-support-list{font-size:.9rem;color:rgba(190,212,232,.72);line-height:1.7}

/* ---------- Hero signature: AI diagnostics card ---------- */
.hero-visual{width:100%;max-width:430px;margin-left:auto}
.diag-card{background:#fff;border:1px solid rgba(219,234,243,.9);border-radius:var(--r-lg);padding:24px 22px 18px;box-shadow:0 40px 90px -30px rgba(0,0,0,.6),0 0 0 1px rgba(255,255,255,.04);position:relative}
.diag-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px}
.diag-status{display:inline-flex;align-items:center;gap:8px;font-size:11px;font-weight:700;letter-spacing:.1em;color:var(--primary-ink)}
.diag-status .dot{width:8px;height:8px;border-radius:50%;background:#45d483;box-shadow:0 0 0 4px rgba(69,212,131,.18);animation:pulseDot 2.4s ease-in-out infinite}
.diag-no{font-family:"Open Sans",monospace;font-size:11px;letter-spacing:.08em;color:var(--ink-4)}
@keyframes pulseDot{0%,100%{box-shadow:0 0 0 3px rgba(69,212,131,.22)}50%{box-shadow:0 0 0 7px rgba(69,212,131,.04)}}

.diag-device{display:flex;align-items:center;gap:20px;padding:14px 4px 18px;border-bottom:1px dashed var(--border)}
.diag-phone{position:relative;width:64px;height:122px;flex:none;border-radius:16px;background:linear-gradient(155deg,#13202f,#0a1019);border:2px solid #1f3346;overflow:hidden;box-shadow:inset 0 0 0 3px rgba(30,157,241,.06)}
.diag-phone .notch{position:absolute;top:7px;left:50%;transform:translateX(-50%);width:24px;height:5px;border-radius:3px;background:#26405a}
.diag-phone .scan{position:absolute;left:0;right:0;height:34%;background:linear-gradient(180deg,rgba(30,157,241,0),rgba(30,157,241,.45));border-bottom:1.5px solid #5cbcf8;animation:scanMove 2.6s ease-in-out infinite}
@keyframes scanMove{0%,100%{top:-34%}50%{top:100%}}
.diag-ring{position:relative;width:96px;height:96px;border-radius:50%;flex:none;background:conic-gradient(var(--primary) 0 98%,#e6eef5 98% 100%);display:grid;place-items:center}
.diag-ring::before{content:"";position:absolute;inset:9px;border-radius:50%;background:#fff}
.ring-val{position:relative;font-family:var(--tc);font-weight:800;font-size:1.5rem;color:var(--ink);line-height:1}
.ring-val i{font-size:.8rem;font-style:normal;color:var(--primary-ink)}
.ring-lbl{position:relative;font-size:.62rem;color:var(--ink-3);margin-top:2px;letter-spacing:.04em}
.diag-ring{flex-direction:column}

.diag-rows{display:flex;flex-direction:column;gap:2px;padding:14px 2px}
.diag-rows li{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:7px 0;font-size:.86rem}
.diag-rows .k{color:var(--ink-2);font-weight:600}
.diag-rows .v{font-family:var(--tc);font-weight:700;font-size:.78rem;padding:3px 11px;border-radius:var(--r-pill)}
.diag-rows .v.ok{background:rgba(69,212,131,.12);color:#1f9d63}
.diag-rows .v.warn{background:rgba(245,181,62,.16);color:#b9791a}

.diag-foot{display:flex;gap:10px;padding-top:14px;border-top:1px dashed var(--border)}
.diag-foot .chip{flex:1;display:flex;flex-direction:column;gap:2px;padding:10px 14px;border-radius:var(--r-md);background:var(--accent-2);border:1px solid var(--border-soft)}
.diag-foot .chip span{font-size:.7rem;color:var(--ink-3)}
.diag-foot .chip b{font-family:var(--tc);font-weight:800;font-size:.96rem;color:var(--ink)}

.diag-barcode{display:flex;align-items:flex-end;gap:2px;height:34px;margin-top:16px;padding-top:14px;border-top:1px solid var(--border-soft);position:relative}
.diag-barcode span{flex:1;background:#0f1419;height:60%}
.diag-barcode span:nth-child(odd){height:90%}
.diag-barcode span:nth-child(3n){height:45%;background:#3c4a57}
.diag-barcode span:nth-child(4n){height:100%}
.diag-barcode em{position:absolute;right:0;bottom:-2px;font-size:.56rem;letter-spacing:.12em;color:var(--ink-4);font-style:normal;background:#fff;padding-left:6px}

/* ---------- OUR CRAFT (dark) ---------- */
.craft{background:var(--navy);overflow:hidden}
.craft::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(120,170,210,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(120,170,210,.04) 1px,transparent 1px);background-size:48px 48px;pointer-events:none}
.craft>.wrap{position:relative;z-index:1}
.craft-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,100px);align-items:center}
.craft-copy h2{font-family:var(--tc);font-size:clamp(1.9rem,3.6vw,3rem);font-weight:800;line-height:1.1;letter-spacing:-.025em;color:#fff;margin:18px 0}
.craft-copy h2 em{color:#5cbcf8;font-style:normal}
.craft-copy p{font-size:1.05rem;color:rgba(200,222,242,.72);line-height:1.75;margin-bottom:28px}
.craft-stats{display:flex;gap:32px;flex-wrap:wrap}
.craft-stat b{display:block;font-family:var(--tc);font-weight:800;font-size:2rem;color:#fff;line-height:1}
.craft-stat span{font-size:.82rem;color:rgba(150,185,215,.65);margin-top:4px;display:block}
.craft-visual{position:relative;height:480px}
.img-stack{position:relative;width:100%;height:100%}
.img-card{position:absolute;border-radius:20px;overflow:hidden;box-shadow:0 32px 80px -20px rgba(0,0,0,.8);border:1px solid rgba(120,170,210,.15)}
.img-card.ic-main{width:62%;height:78%;top:0;left:0;z-index:3;animation:imgFloat1 8s ease-in-out infinite}
.img-card.ic-side{width:52%;height:64%;bottom:0;right:0;z-index:4;animation:imgFloat2 9s ease-in-out infinite}
.img-card.ic-back{width:46%;height:56%;top:12%;right:4%;z-index:2;filter:brightness(.6);animation:imgFloat3 11s ease-in-out infinite}
@keyframes imgFloat1{0%,100%{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-14px) rotate(-2deg)}}
@keyframes imgFloat2{0%,100%{transform:translateY(0) rotate(2deg)}50%{transform:translateY(-10px) rotate(2deg)}}
@keyframes imgFloat3{0%,100%{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-8px) rotate(-1deg)}}
.img-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#0d1f31,#143047 50%,#0a1828);display:flex;align-items:center;justify-content:center;color:rgba(120,175,220,.4);font-family:var(--tc);font-size:.8rem;font-weight:700;letter-spacing:.08em}
.img-badge{position:absolute;z-index:10;display:flex;align-items:center;gap:9px;padding:10px 16px;border-radius:var(--r-pill);background:rgba(10,18,30,.75);border:1px solid rgba(120,170,210,.25);backdrop-filter:blur(12px);color:#fff;font-family:var(--tc);font-size:.82rem;font-weight:700;white-space:nowrap;box-shadow:0 8px 32px rgba(0,0,0,.4);animation:badgeFloat 7s ease-in-out infinite}
.img-badge svg{width:15px;height:15px;color:var(--primary);flex-shrink:0}
.img-badge .badge-dot{width:8px;height:8px;border-radius:50%;background:#45d483;box-shadow:0 0 0 3px rgba(69,212,131,.2);flex-shrink:0;animation:pulseDot 2.4s ease-in-out infinite}
.img-badge.b1{top:-16px;right:8%;animation-delay:-1s}
.img-badge.b2{bottom:32%;left:-16px;animation-delay:-3s}
.img-badge.b3{bottom:-16px;right:16%;animation-delay:-5s}
@keyframes badgeFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

/* ---------- Services ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:54px}
.svc-card{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;transition:transform .35s cubic-bezier(.2,.8,.2,1),box-shadow .35s,border-color .35s;display:flex;flex-direction:column}
.svc-card:hover{transform:translateY(-8px);box-shadow:0 30px 60px -20px rgba(15,20,25,.2);border-color:#cfe2f4}
.svc-img{height:150px;position:relative;overflow:visible}
.svc-img img{width:100%;height:100%;object-fit:cover}
.svc-img-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#0d1f31,#143047 55%,#0a1828)}
.svc-img-icon{position:absolute;bottom:-20px;right:20px;width:46px;height:46px;background:linear-gradient(150deg,#36abf6,var(--primary-deep));border-radius:14px;display:grid;place-items:center;color:#fff;box-shadow:0 8px 24px rgba(30,157,241,.4);border:3px solid #fff;z-index:2}
.svc-img-icon svg{width:22px;height:22px}
.svc-body{padding:28px 24px 24px;flex:1;display:flex;flex-direction:column}
.svc-body h3{font-family:var(--tc);font-size:1.1rem;font-weight:700;color:var(--ink);margin-bottom:10px}
.svc-body p{font-size:.9rem;color:var(--ink-3);line-height:1.65;flex:1}
.svc-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:14px}
.svc-tags span{font-size:.72rem;background:var(--accent);color:var(--primary-ink);padding:3px 10px;border-radius:99px;font-weight:600}

/* ---------- Reminders ---------- */
.reminder-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:54px}
.reminder-item{text-align:left;background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);padding:26px 24px 22px;position:relative;display:flex;flex-direction:column;gap:8px;transition:transform .3s,box-shadow .3s,border-color .3s}
.reminder-item:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:#cfe2f4}
.reminder-no{font-family:var(--tc);font-weight:800;font-size:1.5rem;color:var(--accent);transition:color .3s}
.reminder-item:hover .reminder-no{color:var(--primary)}
.reminder-title{font-family:var(--tc);font-weight:700;font-size:1.06rem;color:var(--ink)}
.reminder-teaser{font-size:.88rem;color:var(--ink-3);line-height:1.6;flex:1}
.reminder-go{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;background:var(--accent-2);color:var(--primary-ink);margin-top:6px;transition:background .3s,transform .3s}
.reminder-go svg{width:16px;height:16px}
.reminder-item:hover .reminder-go{background:var(--primary);color:#fff;transform:translateX(3px)}

/* ---------- Why (dark) ---------- */
.why{background:radial-gradient(70% 60% at 82% 0%,rgba(30,157,241,.16),rgba(30,157,241,0) 60%),linear-gradient(165deg,#0c1623,#0a1019)}
.why::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(120,170,210,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(120,170,210,.04) 1px,transparent 1px);background-size:48px 48px;-webkit-mask-image:radial-gradient(100% 80% at 50% 0%,#000 40%,transparent 85%);mask-image:radial-gradient(100% 80% at 50% 0%,#000 40%,transparent 85%);pointer-events:none}
.why>.wrap{position:relative;z-index:1}
.why-lede{color:rgba(200,222,242,.72)}
.why-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:54px}
.why-item{background:rgba(255,255,255,.03);border:1px solid rgba(120,170,210,.14);border-radius:var(--r-lg);padding:30px 28px;transition:background .3s,border-color .3s}
.why-item:hover{background:rgba(30,157,241,.06);border-color:rgba(92,188,248,.3)}
.why-no{font-family:var(--tc);font-weight:800;font-size:.95rem;color:#5cbcf8;letter-spacing:.05em}
.why-no i{font-style:normal;color:rgba(150,185,215,.5);font-weight:600}
.why-item h3{color:#fff;font-size:1.2rem;margin:12px 0 10px}
.why-item p{font-size:.94rem;color:rgba(196,218,238,.74);line-height:1.7}
.why-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:36px;justify-content:center}
.why-tags span{font-family:var(--tc);font-weight:600;font-size:.84rem;color:rgba(206,224,242,.85);padding:8px 16px;border-radius:var(--r-pill);background:rgba(255,255,255,.05);border:1px solid rgba(120,170,210,.18)}

/* ---------- Process ---------- */
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:54px}
.process-step{position:relative;text-align:center;padding:8px}
.step-no{width:64px;height:64px;margin:0 auto 18px;display:grid;place-items:center;border-radius:50%;font-family:var(--tc);font-weight:800;font-size:1.5rem;color:#fff;background:linear-gradient(150deg,#36abf6,var(--primary-deep));box-shadow:var(--glow-soft)}
.process-step h3{font-size:1.12rem;margin-bottom:8px}
.process-step p{font-size:.9rem;color:var(--ink-3);line-height:1.65;max-width:220px;margin-inline:auto}
.step-arrow{position:absolute;top:18px;right:-12px;color:#cfe0ee}
.step-arrow svg{width:24px;height:24px}
.process-cta{text-align:center;margin-top:48px}

/* ---------- Reviews ---------- */
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:54px}
.review-card{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);padding:30px 28px;display:flex;flex-direction:column;gap:16px;box-shadow:var(--shadow-sm)}
.review-stars{color:#f5b53e;letter-spacing:2px;font-size:1rem}
.review-card blockquote{font-size:.98rem;color:var(--ink-2);line-height:1.8;flex:1}
.review-card figcaption{display:flex;flex-direction:column;gap:2px;border-top:1px solid var(--border-soft);padding-top:16px}
.review-name{font-family:var(--tc);font-weight:700;color:var(--ink)}
.review-item{font-size:.82rem;color:var(--primary-ink)}

/* ---------- FAQ ---------- */
.faq-wrap{max-width:820px}
.faq-list{margin-top:48px;display:flex;flex-direction:column;gap:14px}
.faq{background:#fff;border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;transition:border-color .3s,box-shadow .3s}
.faq.open{border-color:#cfe2f4;box-shadow:var(--shadow-sm)}
.faq-q{margin:0;font-size:inherit;font-weight:inherit;line-height:inherit}
.faq-q button{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:22px 24px;text-align:left;font-family:var(--tc);font-weight:700;font-size:1.04rem;color:var(--ink)}
.faq-ic{width:20px;height:20px;flex:none;color:var(--primary-ink);transition:transform .3s}
.faq.open .faq-ic{transform:rotate(180deg)}
.ans{max-height:0;overflow:hidden;transition:max-height .35s ease}
.ans-inner{padding:0 24px 24px;color:var(--ink-2);line-height:1.8;font-size:.96rem}
.ans-inner p+p{margin-top:10px}
.ans-ol{margin:10px 0;padding-left:22px;list-style:decimal}
.ans-ol li{margin:4px 0}

/* ---------- Final CTA (dark) ---------- */
.final-cta{background:radial-gradient(60% 60% at 50% 0%,rgba(30,157,241,.22),rgba(30,157,241,0) 60%),linear-gradient(165deg,#0c1623,#070d16 60%,#0a1019);text-align:center;overflow:hidden}
.final-cta::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(120,170,210,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(120,170,210,.05) 1px,transparent 1px);background-size:48px 48px;-webkit-mask-image:radial-gradient(80% 80% at 50% 30%,#000 35%,transparent 80%);mask-image:radial-gradient(80% 80% at 50% 30%,#000 35%,transparent 80%);pointer-events:none}
.final-inner{position:relative;z-index:1;max-width:720px;margin-inline:auto}
.center-eyebrow{justify-content:center}
.final-title{font-family:var(--tc);font-weight:800;font-size:clamp(2rem,4.2vw,3.2rem);line-height:1.12;letter-spacing:-.025em;color:#fff;margin:20px 0 18px}
.final-lede{font-size:1.08rem;color:rgba(200,222,242,.78);line-height:1.75;max-width:560px;margin:0 auto 34px}
.final-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.final-cta .btn-ghost{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(160,195,225,.28)}
.final-cta .btn-ghost:hover{background:rgba(255,255,255,.14)}

/* ---------- Footer ---------- */
.site-footer{background:var(--navy);color:rgba(206,224,242,.7);padding-block:clamp(56px,7vw,84px) 0}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px}
.footer-logo .name{font-family:var(--tc);font-weight:800;font-size:1.5rem;color:#fff}
.footer-logo .name b{color:#5cbcf8}
.footer-logo .tag{display:block;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:rgba(150,185,215,.6);margin-top:4px}
.footer-brand p{font-size:.92rem;line-height:1.8;margin:18px 0 22px;max-width:340px}
.footer-col h4{font-family:var(--tc);font-weight:700;font-size:1rem;color:#fff;margin-bottom:18px}
.footer-links{display:flex;flex-direction:column;gap:11px}
.footer-links a{font-size:.92rem;color:rgba(196,218,238,.7);transition:color .2s}
.footer-links a:hover{color:#5cbcf8}
.footer-bottom{margin-top:clamp(40px,5vw,64px);padding-block:26px;border-top:1px solid rgba(120,170,210,.12)}
.footer-bottom p{font-size:.82rem;color:rgba(150,185,215,.55)}

/* ---------- Modal ---------- */
.modal-overlay{position:fixed;inset:0;z-index:300;display:flex;align-items:center;justify-content:center;padding:24px;background:rgba(8,14,22,.6);backdrop-filter:blur(6px);opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s}
.modal-overlay.active{opacity:1;visibility:visible}
.modal{position:relative;width:100%;max-width:520px;max-height:88vh;overflow-y:auto;background:#fff;border-radius:var(--r-lg);padding:40px 36px 36px;box-shadow:var(--shadow-lg);transform:translateY(16px) scale(.98);transition:transform .3s}
.modal-overlay.active .modal{transform:translateY(0) scale(1)}
.modal-close{position:absolute;top:16px;right:16px;width:38px;height:38px;border-radius:50%;display:grid;place-items:center;color:var(--ink-3);background:var(--card);transition:background .2s,color .2s}
.modal-close:hover{background:var(--accent);color:var(--ink)}
.modal-eyebrow{font-family:var(--tc);font-weight:700;font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--primary-ink);margin-bottom:12px}
.modal h3{font-family:var(--tc);font-size:1.5rem;font-weight:800;color:var(--ink);margin-bottom:16px;line-height:1.3}
.modal h3 em{color:var(--primary);font-style:normal}
.modal p{font-size:.98rem;color:var(--ink-2);line-height:1.8;margin-bottom:12px}
.modal .highlight{margin-top:16px;padding:16px 18px;border-radius:var(--r-md);background:var(--accent-2);border:1px solid var(--border);border-left:4px solid var(--primary);font-size:.92rem;color:var(--ink-2);line-height:1.7}
.modal.final-modal{text-align:center}
.final-brand{margin-bottom:18px}
.final-brand .brand-name{font-family:var(--tc);font-weight:800;font-size:1.8rem;color:var(--ink)}
.final-brand .brand-name b{color:var(--primary)}
.final-brand .brand-sub{display:block;font-size:.78rem;letter-spacing:.14em;color:var(--ink-3);text-transform:uppercase;margin-top:2px}
.modal .signature{font-family:var(--tc);font-weight:700;color:var(--primary-ink);margin:16px 0 8px}
.qr-block{margin-top:22px;padding-top:22px;border-top:1px dashed var(--border)}
.qr-label{font-family:var(--tc);font-weight:700;color:var(--ink);margin-bottom:14px}
.qr-img-wrap{width:200px;height:200px;margin:0 auto 12px;border-radius:var(--r-md);background:var(--accent-2);border:1px solid var(--border);display:grid;place-items:center;overflow:hidden}
.qr-img-wrap img{width:100%;height:100%;object-fit:contain}
.qr-placeholder{font-size:.78rem;color:var(--ink-3);text-align:center;padding:16px;line-height:1.6}
.qr-hint{font-size:.84rem;color:var(--ink-3);line-height:1.6}
.modal .btn{margin-top:8px}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.2,.8,.2,1),transform .7s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.06s}
.reveal.d2{transition-delay:.12s}
.reveal.d3{transition-delay:.18s}
.reveal.d4{transition-delay:.24s}

/* ---------- Responsive ---------- */
@media(max-width:1024px){
  .hero-grid{grid-template-columns:1fr;gap:48px}
  .hero-visual{margin:0 auto;max-width:400px}
  .craft-grid{grid-template-columns:1fr}
  .craft-visual{height:380px}
  .footer-grid{grid-template-columns:1fr 1fr}
  .footer-brand{grid-column:1 / -1}
}
@media(max-width:860px){
  .nav-links,.nav-cta{display:none}
  .nav-burger{display:flex}
  .svc-grid,.reminder-grid,.reviews-grid{grid-template-columns:1fr 1fr}
  .why-grid{grid-template-columns:1fr}
  .process-grid{grid-template-columns:1fr 1fr;gap:36px 20px}
  .step-arrow{display:none}
}
@media(max-width:560px){
  .svc-grid,.reminder-grid,.reviews-grid,.process-grid{grid-template-columns:1fr}
  .craft-visual{height:300px}
  .hero-trust{gap:14px}
  .hero-trust .divider{display:none}
  .footer-grid{grid-template-columns:1fr}
  .modal{padding:34px 24px 28px}
  .diag-foot{flex-direction:column}
}

/* ---------- Reduced motion ---------- */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}
