/* Discoveries Corporate Site — retail (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-navy-d:#0F2447;
  --c-ink:#1D1D1F; --c-ink-2:#424245; --c-ink-3:#6E6E73; --c-ink-4:#86868B;
  --c-line:#D2D2D7; --c-line-l:#F5F5F7;
  /* layer colors matching original illustration */
  --c-layer-hq:#F5C7D8; --c-layer-hq-bg:#FCE8EE;
  --c-layer-store:#BBDDF2; --c-layer-store-bg:#E5F2FB;
  --c-layer-staff:#C5DDB6; --c-layer-staff-bg:#EAF3E2;
  /* product brand colors */
  --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)}
.eyebrow.on-dark{color:#7AB7FF}

.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-dark{padding:var(--py-section) 0;background:var(--c-navy);color:#fff;position:relative;overflow:hidden}
.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-title.on-dark{color:#fff}
.section-lead{font-size:var(--t-md);color:var(--c-ink-3);line-height:var(--lh-relax);max-width:620px;margin:0 auto}
.section-lead.on-dark{color:rgba(255,255,255,.7)}

.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-roadmap{background:var(--c-yellow-bg);border-color:rgba(251,188,4,.35);color:#8A6000}
.chip-hq{background:var(--c-layer-hq-bg);border-color:rgba(212,118,153,.35);color:#A8487B}
.chip-store{background:var(--c-layer-store-bg);border-color:rgba(98,160,210,.35);color:#1E5C90}
.chip-staff{background:var(--c-layer-staff-bg);border-color:rgba(124,170,89,.35);color:#3D7019}

/* 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:480px;margin:0 auto;border-radius:var(--r-2xl);overflow:hidden;background:#000;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;pointer-events:none;background:linear-gradient(180deg,transparent 55%,rgba(0,0,0,.35) 100%);border-radius:inherit}
.hv-tag-row{position:absolute;top:20px;left:20px;right:20px;display:flex;gap:var(--sp-2);flex-wrap:wrap;z-index:2}
.hv-tag{background:rgba(255,255,255,.92);backdrop-filter:blur(8px);border-radius:var(--r-full);padding:6px 12px;font-family:var(--f-display);font-size:var(--t-xs);font-weight:var(--fw-sb);color:var(--c-ink);display:inline-flex;align-items:center;gap:6px;box-shadow:var(--sh-sm);letter-spacing:-0.01em}
.hv-tag-dot{width:6px;height:6px;border-radius:50%}
.hv-ai-card{position:absolute;bottom:20px;left:20px;right:20px;background:rgba(255,255,255,.96);backdrop-filter:blur(12px);border-radius:var(--r-lg);padding:12px 16px 12px 12px;display:flex;align-items:center;gap:12px;box-shadow:var(--sh-md);z-index:2;border:1px solid rgba(255,255,255,.6)}
.hv-ai-img{width:40px;height:40px;border-radius:50%;object-fit:cover;display:block;flex-shrink:0;border:2px solid #fff;box-shadow:0 2px 6px rgba(0,0,0,.12)}
.hv-ai-content{flex:1;min-width:0}
.hv-ai-label{font-family:var(--f-display);font-size:9px;font-weight:var(--fw-b);letter-spacing:var(--ls-wider);text-transform:uppercase;color:var(--c-indigo);line-height:1}
.hv-ai-text{font-family:var(--f-display);font-size:var(--t-sm);font-weight:var(--fw-sb);color:var(--c-ink);letter-spacing:-0.01em;margin-top:3px;line-height:1.3}
.hv-ai-pulse{width:8px;height:8px;border-radius:50%;background:var(--c-green);flex-shrink:0;animation:pulse 2s ease-in-out infinite;box-shadow:0 0 0 4px rgba(52,168,83,.2)}

/* Partner 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 section with 3-layer illustration */
.problem-illustration{margin:0 auto var(--sp-16);max-width:780px;background:#fff;border:1px solid var(--c-line-l);border-radius:var(--r-2xl);padding:var(--sp-10) var(--sp-8);box-shadow:var(--sh-sm);text-align:center}
.problem-illustration img{max-width:100%;height:auto;margin:0 auto;display:block}
.problem-illustration-caption{font-family:var(--f-display);font-size:var(--t-sm);color:var(--c-ink-4);margin-top:var(--sp-4);letter-spacing:0.02em}

.problem-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-6)}
@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);position:relative;overflow:hidden}
.problem-card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg);border-color:transparent}
.problem-character{height:160px;margin:calc(-1 * var(--sp-4)) auto var(--sp-5);display:flex;align-items:center;justify-content:center;background:var(--char-bg,#FCE8EE);border-radius:var(--r-lg)}
.problem-character img{height:140px;width:auto;object-fit:contain}
.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)}

/* Mobile experience showcase */
.section-dark::before{content:'';position:absolute;top:-40%;left:-10%;width:60vw;height:60vw;border-radius:50%;background:radial-gradient(circle,rgba(0,102,204,.2) 0%,transparent 60%);pointer-events:none}
.section-dark::after{content:'';position:absolute;bottom:-40%;right:-10%;width:50vw;height:50vw;border-radius:50%;background:radial-gradient(circle,rgba(123,63,242,.18) 0%,transparent 60%);pointer-events:none}
.section-dark > .container{position:relative;z-index:1}
.showcase-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--sp-8);margin-top:var(--sp-10)}
@media (max-width:860px){.showcase-grid{grid-template-columns:1fr}}
.showcase-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-2xl);padding:var(--sp-8);text-align:center;backdrop-filter:blur(8px);transition:all var(--dur-base) var(--ease-apple)}
.showcase-card:hover{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.18);transform:translateY(-4px)}
.showcase-img{display:block;max-width:100%;height:auto;margin:0 auto var(--sp-5)}
.showcase-tag{display:inline-block;font-family:var(--f-display);font-size:var(--t-xs);font-weight:var(--fw-sb);letter-spacing:var(--ls-wider);text-transform:uppercase;color:#7AB7FF;margin-bottom:var(--sp-3)}
.showcase-title{font-family:var(--f-display);font-size:var(--t-xl);font-weight:var(--fw-b);color:#fff;line-height:1.3;letter-spacing:-0.02em;margin-bottom:var(--sp-3)}
.showcase-desc{font-size:var(--t-sm);color:rgba(255,255,255,.7);line-height:var(--lh-relax)}
.showcase-apps{display:flex;gap:var(--sp-2);justify-content:center;flex-wrap:wrap;margin-top:var(--sp-5)}
.showcase-apps .chip{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.15);color:rgba(255,255,255,.85)}

/* Scene cards with happy character */
.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-row{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-4)}
.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-character{height:60px;display:flex;align-items:center;justify-content:flex-end}
.scene-character img{height:100%;width:auto;object-fit:contain}
.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{position:relative;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;overflow:hidden}
@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);position:relative;z-index:1}
.rag-node{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);background:#fff;border-radius:var(--r-md);border:1px solid var(--c-line);box-shadow:var(--sh-sm)}
.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{position:relative;z-index:2;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:0 12px 40px rgba(0,102,204,.35)}
.rag-center::before{content:'';position:absolute;inset:-8px;border-radius:var(--r-xl);background:var(--c-grad);opacity:.2;filter:blur(20px);z-index:-1;animation:ragGlow 3s ease-in-out infinite}
@keyframes ragGlow{0%,100%{opacity:.15;transform:scale(1)}50%{opacity:.35;transform:scale(1.04)}}

/* Animated flow lines from sources to Virtual Staff */
.rag-flow-svg{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:0;overflow:visible}
@media (max-width:860px){.rag-flow-svg{display:none}}
.rag-flow-track{fill:none;stroke:var(--c-line);stroke-width:1.5;vector-effect:non-scaling-stroke;opacity:.4}
.rag-flow-dash{fill:none;stroke-width:2.5;stroke-linecap:round;stroke-dasharray:0 6 4 14;vector-effect:non-scaling-stroke;opacity:.85;animation:ragFlow 2.4s linear infinite}
@keyframes ragFlow{to{stroke-dashoffset:-24}}
.rag-flow-dash.notify{stroke:var(--c-notify);animation-delay:0s}
.rag-flow-dash.story{stroke:var(--c-story);animation-delay:-0.6s}
.rag-flow-dash.people{stroke:var(--c-people);animation-delay:-1.2s}
.rag-flow-dash.meetup{stroke:#D4A82B;animation-delay:-1.8s}
.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)}

/* Cases */
.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{display:flex;gap:var(--sp-2);flex-wrap:wrap;margin-top:var(--sp-2);padding-top:var(--sp-3);border-top:1px solid var(--c-line-l)}
.case-photo-wrap{position:relative;height:200px;overflow:hidden;background:var(--c-bg-alt)}
.case-photo{width:100%;height:100%;object-fit:cover;display:block}
.case-photo-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.35) 100%);pointer-events:none}
.case-logo-badge{position:absolute;bottom:var(--sp-3);left:var(--sp-3);background:#fff;border-radius:var(--r-sm);padding:6px 12px;height:38px;display:flex;align-items:center;justify-content:center;box-shadow:var(--sh-md);max-width:140px}
.case-logo-badge img{max-height:24px;width:auto;display:block;object-fit:contain}
.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}
