/* Discoveries Corporate Site — manufacturing (full original CSS) */

:root{
  --c-bg:#FFFFFF; --c-bg-alt:#FBFBFD; --c-bg-deep:#F5F5F7;
  --c-indigo:#0066CC; --c-indigo-d:#004FA3; --c-indigo-l:#E8F0FD;
  --c-violet:#7B3FF2;
  --c-grad:linear-gradient(135deg,#0066CC 0%,#7B3FF2 100%);
  --c-grad-sub:linear-gradient(135deg,#004FA3 0%,#5B2DD1 100%);
  --c-blue:#1A73E8; --c-green:#34A853; --c-red:#EA4335; --c-yellow:#FBBC04;
  --c-blue-bg:#E8F0FE; --c-green-bg:#E6F4EA; --c-red-bg:#FCE8E6; --c-yellow-bg:#FEF7E0;
  --c-navy:#1A3560;
  --c-ink:#1D1D1F; --c-ink-2:#424245; --c-ink-3:#6E6E73; --c-ink-4:#86868B;
  --c-line:#D2D2D7; --c-line-l:#F5F5F7;
  --c-notify:#1E5790;  --c-notify-l:#E4EDF6;
  --c-story:#14B8B8;   --c-story-l:#DFF6F6;
  --c-people:#E68552;  --c-people-l:#FCEADE;
  --c-vs:#8A9BE0;      --c-vs-l:#ECEFFB;

  --f-serif:'Instrument Serif','Noto Serif JP',Georgia,serif;
  --f-display:'Plus Jakarta Sans','Noto Sans JP',sans-serif;
  --f-body:'Noto Sans JP','Plus Jakarta Sans',sans-serif;

  --t-xs:11px; --t-sm:13px; --t-base:15px; --t-md:17px; --t-lg:21px;
  --t-xl:28px; --t-2xl:36px; --t-3xl:48px; --t-4xl:64px;

  --fw-l:300; --fw-r:400; --fw-m:500; --fw-sb:600; --fw-b:700; --fw-xb:800;
  --lh-tight:1.05; --lh-snug:1.2; --lh-normal:1.45; --lh-relax:1.7;
  --ls-tight:-0.04em; --ls-snug:-0.025em; --ls-normal:-0.01em;
  --ls-wide:0.06em; --ls-wider:0.12em;

  --sp-1:4px; --sp-2:8px; --sp-3:12px; --sp-4:16px; --sp-5:20px; --sp-6:24px;
  --sp-8:32px; --sp-10:40px; --sp-12:48px; --sp-16:64px; --sp-20:80px; --sp-24:96px;
  --py-section:120px;
  --container:1180px;

  --r-sm:8px; --r-md:12px; --r-lg:16px; --r-xl:20px; --r-2xl:28px; --r-full:9999px;

  --sh-sm:0 2px 8px rgba(0,0,0,.08);
  --sh-md:0 4px 16px rgba(0,0,0,.10);
  --sh-lg:0 8px 32px rgba(0,0,0,.12);
  --sh-xl:0 16px 48px rgba(0,0,0,.14);
  --sh-color-l:0 4px 20px rgba(0,102,204,.15);

  --ease-apple:cubic-bezier(0.4,0,0.2,1);
  --ease-out:cubic-bezier(0,0,0.2,1);
  --dur-fast:160ms; --dur-base:240ms; --dur-reveal:800ms;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--f-body);font-size:var(--t-base);font-weight:var(--fw-r);line-height:var(--lh-relax);color:var(--c-ink);background:var(--c-bg);overflow-x:hidden;-webkit-font-smoothing:antialiased;font-feature-settings:"palt" 1}
a{text-decoration:none;color:inherit}
ul,ol{list-style:none}
img{display:block;max-width:100%}
button{font:inherit;background:none;border:none;cursor:pointer}

.container{max-width:var(--container);margin:0 auto;padding:0 var(--sp-6)}

.t-h1{font-family:var(--f-display);font-size:clamp(36px,4.5vw,60px);font-weight:var(--fw-b);line-height:var(--lh-snug);letter-spacing:var(--ls-snug);color:var(--c-ink)}
.t-grad{background:var(--c-grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

.eyebrow{display:inline-block;font-family:var(--f-display);font-size:var(--t-xs);font-weight:var(--fw-b);letter-spacing:var(--ls-wider);text-transform:uppercase;color:var(--c-indigo);margin-bottom:var(--sp-4)}

.section{padding:var(--py-section) 0}
.section-alt{padding:var(--py-section) 0;background:var(--c-bg-alt)}
.section-deep{padding:var(--py-section) 0;background:var(--c-bg-deep)}
.section-head{text-align:center;max-width:720px;margin:0 auto var(--sp-16)}
.section-title{font-family:var(--f-display);font-size:clamp(28px,3.2vw,44px);font-weight:var(--fw-b);line-height:var(--lh-snug);letter-spacing:var(--ls-snug);color:var(--c-ink);margin-bottom:var(--sp-5)}
.section-lead{font-size:var(--t-md);color:var(--c-ink-3);line-height:var(--lh-relax);max-width:620px;margin:0 auto}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);font-family:var(--f-display);font-weight:var(--fw-m);border-radius:var(--r-full);transition:all var(--dur-fast) var(--ease-out);white-space:nowrap;cursor:pointer;letter-spacing:-0.01em}
.btn:hover{transform:scale(1.03)}
.btn:active{transform:scale(.97)}
.btn-primary{background:var(--c-indigo);color:#fff;padding:14px 28px;font-size:var(--t-base);box-shadow:var(--sh-color-l)}
.btn-primary:hover{background:var(--c-indigo-d)}
.btn-gradient{background:var(--c-grad);color:#fff;padding:16px 32px;font-size:var(--t-md);font-weight:var(--fw-sb);box-shadow:0 4px 24px rgba(0,102,204,.35)}
.btn-gradient:hover{background:var(--c-grad-sub)}
.btn-ghost{background:transparent;color:var(--c-ink);padding:13px 27px;font-size:var(--t-base);border:1.5px solid var(--c-line)}
.btn-ghost:hover{background:var(--c-bg-alt);border-color:var(--c-ink-3)}
.btn-ghost-w{background:transparent;color:#fff;padding:13px 27px;font-size:var(--t-base);border:1.5px solid rgba(255,255,255,.35)}
.btn-ghost-w:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.6)}

.hero-pill{display:inline-flex;align-items:center;gap:var(--sp-3);background:var(--c-indigo-l);border:1px solid rgba(0,102,204,.2);border-radius:var(--r-full);padding:var(--sp-2) var(--sp-4) var(--sp-2) var(--sp-3);font-family:var(--f-display);font-size:var(--t-sm);font-weight:var(--fw-m);color:var(--c-indigo);margin-bottom:var(--sp-6);letter-spacing:-0.01em}
.hero-pill-dot{width:6px;height:6px;border-radius:50%;background:var(--c-indigo);flex-shrink:0;animation:pulse 2.5s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.7)}}

.chip{display:inline-flex;align-items:center;gap:var(--sp-2);font-family:var(--f-display);font-size:var(--t-xs);font-weight:var(--fw-m);padding:5px 12px;border-radius:var(--r-full);border:1px solid var(--c-line);color:var(--c-ink-2);background:var(--c-bg)}
.chip-notify{background:var(--c-notify-l);border-color:rgba(30,87,144,.2);color:var(--c-notify)}
.chip-story{background:var(--c-story-l);border-color:rgba(20,184,184,.25);color:#0E8B8B}
.chip-people{background:var(--c-people-l);border-color:rgba(230,133,82,.25);color:#B55F2E}
.chip-vs{background:var(--c-vs-l);border-color:rgba(138,155,224,.3);color:#5466B5}
.chip-indigo{background:var(--c-indigo-l);border-color:rgba(0,102,204,.25);color:var(--c-indigo)}
.chip-navy{background:#E8EFF8;border-color:rgba(26,53,96,.2);color:var(--c-navy)}
.chip-roadmap{background:var(--c-yellow-bg);border-color:rgba(251,188,4,.35);color:#8A6000}

/* Hero */
.page-hero{position:relative;overflow:hidden;padding:140px 0 var(--sp-16);background:var(--c-bg)}
.hero-mesh{position:absolute;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.hero-mesh::before{content:'';position:absolute;top:-30%;left:-20%;width:80vw;height:80vw;border-radius:50%;background:radial-gradient(circle,rgba(0,102,204,.08) 0%,rgba(123,63,242,.05) 50%,transparent 70%);animation:meshFloat 20s ease-in-out infinite alternate}
.hero-mesh::after{content:'';position:absolute;bottom:-20%;right:-10%;width:60vw;height:60vw;border-radius:50%;background:radial-gradient(circle,rgba(123,63,242,.06) 0%,rgba(0,102,204,.04) 50%,transparent 70%);animation:meshFloat 25s ease-in-out infinite alternate-reverse}
@keyframes meshFloat{0%{transform:translate(0,0) scale(1)}100%{transform:translate(2%,3%) scale(1.05)}}
.hero-content{position:relative;z-index:1}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:var(--sp-16);align-items:center}
@media (max-width:860px){.hero-grid{grid-template-columns:1fr;gap:var(--sp-10)}}
.hero-lead{font-size:var(--t-md);color:var(--c-ink-3);line-height:var(--lh-relax);max-width:540px;margin-top:var(--sp-6);margin-bottom:var(--sp-8)}
.hero-cta{display:flex;gap:var(--sp-3);flex-wrap:wrap}

.hero-visual{position:relative;aspect-ratio:1/1;max-width:520px;margin:0 auto;border-radius:var(--r-2xl);overflow:hidden;box-shadow:var(--sh-xl)}
.hero-visual img{width:100%;height:100%;object-fit:cover;display:block}
.hero-visual::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(0,30,60,.45) 100%);pointer-events:none}
.hero-visual-cap{position:absolute;left:var(--sp-6);right:var(--sp-6);bottom:var(--sp-5);z-index:1;display:flex;align-items:center;gap:var(--sp-3);font-family:var(--f-display);font-size:var(--t-xs);font-weight:var(--fw-sb);letter-spacing:0.04em;color:#fff;text-transform:uppercase}
.hero-visual-cap::before{content:'';width:32px;height:1px;background:rgba(255,255,255,.6);flex-shrink:0}
.hv-node{position:absolute;background:#fff;border-radius:var(--r-lg);padding:10px 14px;box-shadow:var(--sh-md);font-family:var(--f-display);font-size:var(--t-xs);font-weight:var(--fw-sb);display:flex;align-items:center;gap:8px}
.hv-node-dot{width:8px;height:8px;border-radius:50%}
.hv-hq{top:28px;left:50%;transform:translateX(-50%)}
.hv-mgr{top:42%;left:22px}
.hv-staff{top:42%;right:22px}
.hv-ai{bottom:28px;left:50%;transform:translateX(-50%);background:#fff;display:flex;align-items:center;gap:10px;padding:8px 16px 8px 8px;border:1px solid rgba(0,102,204,.15)}
.hv-ai-img{width:36px;height:36px;border-radius:50%;object-fit:cover;display:block}
.hv-ai-text{font-family:var(--f-display);font-size:var(--t-sm);font-weight:var(--fw-sb);color:var(--c-indigo);letter-spacing:-0.01em}
.hv-line{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:80%;height:80%;border-radius:50%;border:2px dashed rgba(0,102,204,.3);animation:rotate 30s linear infinite}
@keyframes rotate{to{transform:translate(-50%,-50%) rotate(360deg)}}

/* Partner logo strip */
.partner-strip{padding:var(--sp-12) 0 var(--sp-16);background:var(--c-bg);border-bottom:1px solid var(--c-line-l)}
.partner-inner{max-width:var(--container);margin:0 auto;padding:0 var(--sp-6);text-align:center}
.partner-label{font-family:var(--f-display);font-size:var(--t-xs);font-weight:var(--fw-sb);letter-spacing:var(--ls-wider);text-transform:uppercase;color:var(--c-ink-4);margin-bottom:var(--sp-6)}
.partner-logos{display:flex;justify-content:center;align-items:center;gap:var(--sp-10);flex-wrap:wrap}
.partner-card{background:#000;border-radius:var(--r-md);padding:12px 24px;height:64px;display:flex;align-items:center;justify-content:center;box-shadow:var(--sh-sm);transition:transform var(--dur-base) var(--ease-apple)}
.partner-card:hover{transform:translateY(-2px);box-shadow:var(--sh-md)}
.partner-card img{max-height:36px;width:auto;display:block}
.partner-card.line{background:#fff;border:1px solid var(--c-line);padding:8px}
.partner-card.line img{max-height:48px;border-radius:8px}

/* Problem cards */
.problem-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-6);margin-top:var(--sp-10)}
@media (max-width:860px){.problem-grid{grid-template-columns:1fr}}
.problem-card{background:#fff;border:1px solid var(--c-line);border-radius:var(--r-xl);padding:var(--sp-8);transition:all var(--dur-base) var(--ease-apple)}
.problem-card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg);border-color:transparent}
.problem-num{font-family:var(--f-display);font-size:var(--t-xs);font-weight:var(--fw-b);letter-spacing:var(--ls-wider);color:var(--c-indigo);margin-bottom:var(--sp-3)}
.problem-title{font-family:var(--f-display);font-size:var(--t-lg);font-weight:var(--fw-sb);color:var(--c-ink);margin-bottom:var(--sp-4);line-height:1.4}
.problem-list{display:flex;flex-direction:column;gap:var(--sp-3)}
.problem-item{display:flex;gap:var(--sp-3);font-size:var(--t-sm);line-height:1.6;color:var(--c-ink-2)}
.problem-item::before{content:'';flex-shrink:0;width:6px;height:6px;border-radius:50%;background:var(--c-red);margin-top:8px}

/* Solution cards */
.solution-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--sp-6);margin-top:var(--sp-10)}
@media (max-width:860px){.solution-grid{grid-template-columns:1fr}}
.sol-card{position:relative;background:#fff;border:1px solid var(--c-line);border-radius:var(--r-2xl);padding:var(--sp-8);overflow:hidden;transition:all var(--dur-base) var(--ease-apple);display:flex;flex-direction:column}
.sol-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--cc,var(--c-indigo))}
.sol-card:hover{transform:translateY(-6px);box-shadow:var(--sh-xl);border-color:transparent}
.sol-logo{height:40px;margin-bottom:var(--sp-5);display:flex;align-items:center}
.sol-logo img{height:100%;width:auto;max-width:220px;object-fit:contain;object-position:left center}
.sol-num{font-family:var(--f-display);font-size:var(--t-xs);font-weight:var(--fw-b);letter-spacing:var(--ls-wider);color:var(--c-ink-4);text-transform:uppercase;margin-bottom:var(--sp-3)}
.sol-tagline{font-size:var(--t-sm);color:var(--cc,var(--c-indigo));font-weight:var(--fw-sb);margin-bottom:var(--sp-4);letter-spacing:-0.01em}
.sol-desc{font-size:var(--t-base);color:var(--c-ink-3);line-height:var(--lh-relax);margin-bottom:var(--sp-5)}
.sol-features{display:flex;flex-direction:column;gap:var(--sp-3);padding-top:var(--sp-5);border-top:1px solid var(--c-line-l);flex:1}
.sol-f{display:flex;gap:var(--sp-3);font-size:var(--t-sm);color:var(--c-ink-2);line-height:1.5}
.sol-f::before{content:'';flex-shrink:0;width:16px;height:16px;border-radius:50%;background:var(--cc-bg,var(--c-indigo-l));background-image:radial-gradient(circle at center,var(--cc,var(--c-indigo)) 30%,transparent 35%);margin-top:3px}
.sol-link{display:inline-flex;align-items:center;gap:var(--sp-1);color:var(--cc,var(--c-indigo));font-size:var(--t-sm);font-weight:var(--fw-sb);font-family:var(--f-display);margin-top:var(--sp-5);transition:gap var(--dur-fast) var(--ease-out)}
.sol-link::after{content:'→'}
.sol-link:hover{gap:var(--sp-3)}

/* Scene cards */
.scene-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-6);margin-top:var(--sp-10)}
@media (max-width:860px){.scene-grid{grid-template-columns:1fr}}
.scene-card{background:#fff;border-radius:var(--r-2xl);padding:var(--sp-8);border:1px solid var(--c-line);transition:all var(--dur-base) var(--ease-apple);display:flex;flex-direction:column;gap:var(--sp-4)}
.scene-card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg);border-color:transparent}
.scene-num{display:inline-flex;align-items:center;gap:var(--sp-3)}
.scene-num-badge{width:40px;height:40px;border-radius:var(--r-md);background:var(--c-grad);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-family:var(--f-display);font-size:var(--t-md);font-weight:var(--fw-b);letter-spacing:-0.02em;box-shadow:var(--sh-color-l)}
.scene-num-label{font-family:var(--f-display);font-size:var(--t-xs);font-weight:var(--fw-b);letter-spacing:var(--ls-wider);text-transform:uppercase;color:var(--c-indigo)}
.scene-title{font-family:var(--f-display);font-size:var(--t-lg);font-weight:var(--fw-sb);color:var(--c-ink);line-height:1.4;letter-spacing:-0.01em}
.scene-desc{font-size:var(--t-sm);color:var(--c-ink-3);line-height:var(--lh-relax)}
.scene-tools{display:flex;gap:var(--sp-2);flex-wrap:wrap;margin-top:auto;padding-top:var(--sp-4);border-top:1px solid var(--c-line-l)}

/* RAG diagram */
.rag-diagram{background:#fff;border:1px solid var(--c-line);border-radius:var(--r-2xl);padding:var(--sp-12) var(--sp-8);margin-top:var(--sp-10);display:grid;grid-template-columns:1fr auto 1fr;gap:var(--sp-8);align-items:center}
@media (max-width:860px){.rag-diagram{grid-template-columns:1fr;gap:var(--sp-6);padding:var(--sp-8) var(--sp-5)}}
.rag-col-label{font-family:var(--f-display);font-size:var(--t-xs);font-weight:var(--fw-b);letter-spacing:var(--ls-wider);text-transform:uppercase;color:var(--c-ink-4);margin-bottom:var(--sp-4);display:flex;align-items:center;gap:var(--sp-2);flex-wrap:wrap}
.rag-col{display:flex;flex-direction:column;gap:var(--sp-3)}
.rag-node{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);background:var(--c-bg-alt);border-radius:var(--r-md);border:1px solid var(--c-line-l)}
.rn-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.rn-name{font-family:var(--f-display);font-size:var(--t-sm);font-weight:var(--fw-sb);color:var(--c-ink)}
.rn-sub{font-size:var(--t-xs);color:var(--c-ink-3)}
.rag-center{text-align:center;padding:var(--sp-6) var(--sp-5);background:var(--c-grad);border-radius:var(--r-xl);color:#fff;min-width:200px;box-shadow:var(--sh-lg)}
.rag-center-avatar{width:72px;height:72px;border-radius:50%;margin:0 auto var(--sp-3);display:block;object-fit:cover;border:3px solid rgba(255,255,255,.4);box-shadow:0 4px 12px rgba(0,0,0,.2)}
.rag-center-name{font-family:var(--f-display);font-size:var(--t-lg);font-weight:var(--fw-b);letter-spacing:-0.02em}
.rag-center-sub{font-size:var(--t-xs);opacity:.8;margin-top:4px;letter-spacing:0.04em;text-transform:uppercase}
.rag-q{background:var(--c-bg-alt);border-radius:var(--r-md);padding:var(--sp-4);border:1px solid var(--c-line-l)}
.rag-q-title{font-family:var(--f-display);font-size:var(--t-sm);font-weight:var(--fw-sb);color:var(--c-ink);margin-bottom:4px}
.rag-q-desc{font-size:var(--t-xs);color:var(--c-ink-3);line-height:1.5}
.rag-note{max-width:920px;margin:var(--sp-6) auto 0;padding:var(--sp-4) var(--sp-5);background:var(--c-yellow-bg);border:1px solid rgba(251,188,4,.35);border-radius:var(--r-md);font-size:var(--t-sm);color:#6B4A00;line-height:var(--lh-relax);display:flex;gap:var(--sp-3);align-items:flex-start}
.rag-note-icon{flex-shrink:0;font-weight:var(--fw-b);color:#8A6000}

/* VS highlight */
.vs-highlight{background:linear-gradient(135deg,#FFFFFF 0%,var(--c-vs-l) 100%);border:1px solid rgba(138,155,224,.3);border-radius:var(--r-2xl);padding:var(--sp-10);margin-top:var(--sp-10);display:grid;grid-template-columns:auto 1fr auto;gap:var(--sp-8);align-items:center;box-shadow:var(--sh-md)}
@media (max-width:860px){.vs-highlight{grid-template-columns:1fr;text-align:center;padding:var(--sp-8)}}
.vs-avatar-wrap{position:relative;flex-shrink:0}
.vs-avatar{width:120px;height:120px;border-radius:50%;object-fit:cover;display:block;border:4px solid #fff;box-shadow:var(--sh-lg)}
.vs-badge-float{position:absolute;bottom:-8px;right:-8px;background:var(--c-grad);color:#fff;font-family:var(--f-display);font-size:var(--t-xs);font-weight:var(--fw-b);padding:6px 12px;border-radius:var(--r-full);box-shadow:var(--sh-md);letter-spacing:-0.01em}
@media (max-width:860px){.vs-avatar-wrap{margin:0 auto}.vs-badge-float{right:auto;left:50%;transform:translateX(-50%)}}
.vs-text h3{font-family:var(--f-display);font-size:var(--t-xl);font-weight:var(--fw-b);color:var(--c-ink);margin-bottom:var(--sp-3);letter-spacing:-0.02em;line-height:1.3}
.vs-text p{font-size:var(--t-base);color:var(--c-ink-2);line-height:var(--lh-relax)}
.vs-text strong{color:var(--c-ink);font-weight:var(--fw-sb)}

/* Case studies */
.case-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-6);margin-top:var(--sp-10)}
@media (max-width:860px){.case-grid{grid-template-columns:1fr}}
.case-card{background:#fff;border:1px solid var(--c-line);border-radius:var(--r-2xl);overflow:hidden;transition:all var(--dur-base) var(--ease-apple);display:flex;flex-direction:column;position:relative}
.case-card.featured{border:2px solid var(--c-indigo);box-shadow:0 8px 24px rgba(0,102,204,.1)}
.case-card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg)}
.case-card.featured:hover{border-color:var(--c-indigo)}
.case-tag-row{position:absolute;top:var(--sp-4);left:var(--sp-4);z-index:2;display:flex;gap:var(--sp-2)}
.case-logo-wrap{height:140px;display:flex;align-items:center;justify-content:center;background:var(--c-bg-alt);border-bottom:1px solid var(--c-line-l);padding:var(--sp-6)}
.case-logo-wrap img{max-height:80px;max-width:80%;object-fit:contain}
.case-body{padding:var(--sp-6);display:flex;flex-direction:column;gap:var(--sp-3);flex:1}
.case-company{font-family:var(--f-display);font-size:var(--t-base);font-weight:var(--fw-sb);color:var(--c-ink);letter-spacing:-0.01em}
.case-title{font-size:var(--t-sm);color:var(--c-ink-2);line-height:1.55;font-weight:var(--fw-m)}
.case-desc{font-size:var(--t-xs);color:var(--c-ink-3);line-height:1.65;flex:1}
.case-link{font-family:var(--f-display);font-size:var(--t-xs);font-weight:var(--fw-sb);color:var(--c-indigo);display:inline-flex;align-items:center;gap:4px;margin-top:auto;transition:gap var(--dur-fast) var(--ease-out)}
.case-link::after{content:'→'}
.case-link:hover{gap:var(--sp-2)}

/* FAQ */
.faq-list{max-width:820px;margin:var(--sp-10) auto 0;display:flex;flex-direction:column;gap:var(--sp-3)}
.faq-item{background:#fff;border:1px solid var(--c-line);border-radius:var(--r-lg);overflow:hidden;transition:all var(--dur-base) var(--ease-apple)}
.faq-item:hover{border-color:var(--c-ink-4)}
.faq-q{padding:var(--sp-5) var(--sp-6);cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-family:var(--f-display);font-weight:var(--fw-sb);font-size:var(--t-base);color:var(--c-ink);gap:var(--sp-4);transition:color var(--dur-fast) var(--ease-out)}
.faq-icon{width:28px;height:28px;border-radius:50%;background:var(--c-indigo-l);color:var(--c-indigo);display:flex;align-items:center;justify-content:center;font-size:var(--t-md);flex-shrink:0;transition:transform var(--dur-base) var(--ease-apple)}
.faq-item.open .faq-icon{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height var(--dur-base) var(--ease-apple)}
.faq-item.open .faq-a{max-height:500px}
.faq-a p{padding:0 var(--sp-6) var(--sp-5);font-size:var(--t-sm);color:var(--c-ink-3);line-height:var(--lh-relax)}

/* CTA */
.cta-section{background:var(--c-navy);color:#fff;padding:var(--py-section) 0;position:relative;overflow:hidden;text-align:center}
.cta-section::before{content:'';position:absolute;top:-40%;left:-10%;width:60vw;height:60vw;border-radius:50%;background:radial-gradient(circle,rgba(0,102,204,.3) 0%,transparent 60%);pointer-events:none}
.cta-section::after{content:'';position:absolute;bottom:-40%;right:-10%;width:50vw;height:50vw;border-radius:50%;background:radial-gradient(circle,rgba(123,63,242,.25) 0%,transparent 60%);pointer-events:none}
.cta-inner{position:relative;max-width:720px;margin:0 auto;padding:0 var(--sp-6)}
.cta-pill{display:inline-flex;align-items:center;gap:var(--sp-2);background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:var(--r-full);padding:6px 14px;font-family:var(--f-display);font-size:var(--t-sm);color:rgba(255,255,255,.85);margin-bottom:var(--sp-6)}
.cta-title{font-family:var(--f-display);font-size:clamp(32px,4vw,52px);font-weight:var(--fw-b);line-height:1.2;letter-spacing:-0.02em;color:#fff;margin-bottom:var(--sp-5)}
.cta-title em{font-style:normal;background:linear-gradient(135deg,#64B4FF 0%,#B088FF 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.cta-sub{font-size:var(--t-md);color:rgba(255,255,255,.72);max-width:560px;margin:0 auto var(--sp-8);line-height:var(--lh-relax)}
.cta-btns{display:flex;gap:var(--sp-3);justify-content:center;flex-wrap:wrap}
.btn-cta-primary{background:#fff;color:var(--c-navy);padding:16px 32px;font-size:var(--t-md);font-weight:var(--fw-sb);font-family:var(--f-display);border-radius:var(--r-full);display:inline-flex;align-items:center;gap:var(--sp-2);transition:transform var(--dur-fast) var(--ease-out)}
.btn-cta-primary:hover{transform:scale(1.04)}
.cta-checks{display:flex;gap:var(--sp-6);justify-content:center;flex-wrap:wrap;margin-top:var(--sp-10);font-size:var(--t-sm);color:rgba(255,255,255,.6)}
.cta-checks .cc{display:inline-flex;align-items:center;gap:var(--sp-2)}
.cta-checks .cc::before{content:'✓';color:#64B4FF;font-weight:700}

.reveal{opacity:0;transform:translateY(20px);transition:opacity var(--dur-reveal) var(--ease-apple),transform var(--dur-reveal) var(--ease-apple)}
.reveal.in{opacity:1;transform:translateY(0)}
.d1{transition-delay:80ms} .d2{transition-delay:160ms} .d3{transition-delay:240ms} .d4{transition-delay:320ms}

.breadcrumb{font-family:var(--f-display);font-size:var(--t-xs);color:var(--c-ink-4);margin-bottom:var(--sp-6);display:flex;align-items:center;gap:var(--sp-2);letter-spacing:0.02em}
.breadcrumb a{color:var(--c-ink-3);transition:color var(--dur-fast) var(--ease-out)}
.breadcrumb a:hover{color:var(--c-indigo)}
.breadcrumb-sep{color:var(--c-line);margin:0 2px}
