/* ============================================================
   Home page specific styles — hero scene, journey, explore,
   honesty promise, impact.  Loads after site.css
   ============================================================ */

/* ---------------- HERO ---------------- */
.hero{
  position:relative;overflow:hidden;color:#eaf3f1;
  background:
    radial-gradient(820px 460px at 88% -8%, rgba(40,116,206,.34), transparent 62%),
    radial-gradient(700px 520px at -6% 112%, rgba(70,150,230,.20), transparent 60%),
    linear-gradient(158deg,#173f6e,#10294d 46%,#0a1f3d);
  padding:54px 0 0;
}
.hero::after{
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.45;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='150' height='150'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.05'/%3E%3C/svg%3E");
}
.hero .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.04fr .96fr;gap:36px;align-items:center;padding-bottom:54px;}
@media (max-width:940px){.hero .wrap{grid-template-columns:1fr;gap:14px;}}

.hero .badge{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:#a9c8ee;border:1px solid rgba(169,200,238,.4);border-radius:30px;padding:7px 15px;margin-bottom:22px;}
.hero .badge .ic{width:14px;height:14px;}
.hero h2{font-family:var(--display);font-weight:700;font-size:clamp(38px,5.6vw,66px);line-height:.98;letter-spacing:-.025em;margin:0 0 20px;color:#fff;text-wrap:balance;}
.hero h2 em{font-style:italic;color:var(--accent);position:relative;white-space:nowrap;}
.hero h2 em::after{content:"";position:absolute;left:0;right:0;bottom:.02em;height:.10em;background:linear-gradient(90deg,var(--accent),transparent);border-radius:3px;}
.hero p.dek{font-size:19.5px;max-width:560px;margin:0 0 26px;color:#cfe0dd;font-style:italic;text-wrap:pretty;}

.hero .startbox{display:flex;flex-direction:column;gap:14px;max-width:560px;}
.hero .startrow{display:flex;gap:11px;flex-wrap:wrap;}
.hero .big-cta{flex:1;min-width:230px;font-family:var(--mono);font-size:14px;letter-spacing:.01em;background:var(--accent);color:#fff;border:0;border-radius:13px;padding:16px 22px;display:inline-flex;align-items:center;justify-content:center;gap:11px;cursor:pointer;box-shadow:var(--shadow-saffron);transition:.2s var(--ease);}
.hero .big-cta:hover{background:var(--accent-2);transform:translateY(-2px);box-shadow:0 18px 38px rgba(23,99,176,.42);}
.hero .big-cta .arw{transition:transform .2s;}
.hero .big-cta:hover .arw{transform:translateX(4px);}
.hero .alt-cta{font-family:var(--mono);font-size:13px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.2);color:#fff;border-radius:13px;padding:16px 20px;cursor:pointer;transition:.18s;display:inline-flex;align-items:center;gap:9px;}
.hero .alt-cta:hover{background:rgba(255,255,255,.13);border-color:rgba(255,255,255,.4);}

.hero .picker{display:flex;gap:9px;align-items:center;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16);border-radius:13px;padding:8px;backdrop-filter:blur(6px);}
.hero .picker svg{margin-left:7px;color:#9fb6d4;flex:0 0 auto;}
.hero .picker select{flex:1;font-family:var(--mono);font-size:13px;background:transparent;color:#fff;border:0;padding:9px 6px;cursor:pointer;}
.hero .picker select option{color:#13333b;}
.hero .picker button{font-family:var(--mono);font-size:13px;background:#fff;color:var(--deep);border:0;border-radius:9px;padding:11px 17px;cursor:pointer;transition:.16s;display:inline-flex;gap:7px;align-items:center;}
.hero .picker button:hover{background:var(--accent);color:#fff;}

.hstats{display:flex;gap:30px;flex-wrap:wrap;margin-top:30px;border-top:1px solid rgba(255,255,255,.14);padding-top:20px;}
.hstats .v{font-family:var(--display);font-weight:700;font-size:28px;color:#fff;line-height:1;}
.hstats .v span{color:var(--accent);}
.hstats .l{font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:#9fb6b2;margin-top:6px;}

/* ---- the animated 3D journey scene ---- */
.scene{position:relative;width:100%;aspect-ratio:1/1;max-width:540px;margin:0 auto;}
@media (max-width:940px){.scene{max-width:420px;margin-top:8px;}}
.scene svg{width:100%;height:100%;overflow:visible;display:block;}
.scene .glow{position:absolute;inset:8% 8% 18% 8%;border-radius:50%;background:radial-gradient(circle at 50% 45%,rgba(70,150,230,.26),rgba(40,116,206,.16) 55%,transparent 72%);filter:blur(8px);z-index:0;}
.scene .globe-wrap{position:relative;z-index:1;width:100%;height:100%;}

.spin-slow{transform-box:fill-box;transform-origin:center;animation:spin 70s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
@media (prefers-reduced-motion:reduce){.spin-slow{animation:none;}}

.path-dash{stroke-dasharray:3 7;animation:dash 2.6s linear infinite;}
@keyframes dash{to{stroke-dashoffset:-20;}}
@media (prefers-reduced-motion:reduce){.path-dash{animation:none;}}

/* travelling dots along journey arcs */
.traveller{fill:#fff;filter:drop-shadow(0 0 5px rgba(255,255,255,.9));}
.t1{offset-path:path('M 270 300 C 200 180, 150 120, 96 96');offset-rotate:auto;animation:travel 5s ease-in-out infinite;}
.t2{offset-path:path('M 270 300 C 320 170, 380 150, 452 120');offset-rotate:auto;animation:travel 6.2s ease-in-out .7s infinite;}
.t3{offset-path:path('M 270 300 C 360 300, 430 280, 486 250');offset-rotate:auto;animation:travel 5.6s ease-in-out 1.4s infinite;}
.t4{offset-path:path('M 270 300 C 340 380, 400 430, 452 470');offset-rotate:auto;animation:travel 6.8s ease-in-out .3s infinite;}
.t5{offset-path:path('M 270 300 C 180 360, 130 420, 92 452');offset-rotate:auto;animation:travel 5.2s ease-in-out 1.1s infinite;}
@keyframes travel{0%{offset-distance:0%;opacity:0;}8%{opacity:1;}88%{opacity:1;}100%{offset-distance:100%;opacity:0;}}
@media (prefers-reduced-motion:reduce){.traveller{display:none;}}

.dest-pin{transform-box:fill-box;transform-origin:center bottom;animation:bob 4s ease-in-out infinite;}
.dest-pin:nth-of-type(2){animation-delay:.6s;}
.dest-pin:nth-of-type(3){animation-delay:1.2s;}
.dest-pin:nth-of-type(4){animation-delay:1.8s;}
.dest-pin:nth-of-type(5){animation-delay:2.4s;}
@keyframes bob{0%,100%{transform:translateY(0);}50%{transform:translateY(-5px);}}
@media (prefers-reduced-motion:reduce){.dest-pin{animation:none;}}

.home-pulse{transform-box:fill-box;transform-origin:center;animation:homepulse 2.4s ease-out infinite;}
@keyframes homepulse{0%{transform:scale(.6);opacity:.7;}100%{transform:scale(2.6);opacity:0;}}

/* floating chips over scene */
.scene .chip{position:absolute;z-index:3;display:flex;align-items:center;gap:8px;background:rgba(255,253,248,.94);border:1px solid var(--line);border-radius:30px;padding:6px 12px 6px 7px;box-shadow:var(--shadow-md);font-family:var(--mono);font-size:11px;color:var(--deep);white-space:nowrap;animation:floaty 6s ease-in-out infinite;}
.scene .chip .fl{font-size:15px;}
.scene .chip b{font-family:var(--display);font-weight:600;font-size:12.5px;}
.scene .chip.c1{top:6%;left:-4%;}
.scene .chip.c2{top:40%;right:-7%;animation-delay:1.5s;}
.scene .chip.c3{bottom:8%;left:-2%;animation-delay:3s;}
@keyframes floaty{0%,100%{transform:translateY(0);}50%{transform:translateY(-9px);}}
@media (prefers-reduced-motion:reduce){.scene .chip{animation:none;}}
@media (max-width:480px){.scene .chip{display:none;}}

/* trust ribbon under hero */
.hero-foot{position:relative;z-index:3;border-top:1px solid rgba(255,255,255,.14);background:var(--deep-2);}
.hero-foot .wrap{display:flex;align-items:center;justify-content:center;gap:36px;flex-wrap:wrap;padding:16px 28px;}
.hero-foot .tf{display:flex;align-items:center;gap:9px;font-family:var(--mono);font-size:11.5px;letter-spacing:.04em;color:#d6e6e3;}
.hero-foot .tf svg{color:var(--green);flex:0 0 auto;}

/* ---------------- QUICK ACTIONS ---------------- */
.quick{background:var(--paper);margin-top:-30px;z-index:1;}
.qgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;}
@media (max-width:880px){.qgrid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:480px){.qgrid{grid-template-columns:1fr;}}
.qcard{position:relative;display:block;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:24px 22px 22px;box-shadow:var(--shadow);transition:transform .22s var(--ease),box-shadow .22s,border-color .22s;overflow:hidden;}
.qcard::before{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:var(--qc,var(--accent));transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease);}
.qcard:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--qc,var(--accent));}
.qcard:hover::before{transform:scaleX(1);}
.qcard .qi{width:50px;height:50px;border-radius:14px;background:var(--qbg,var(--accent-soft));display:flex;align-items:center;justify-content:center;margin-bottom:16px;color:var(--qc,var(--accent-ink));}
.qcard .qstep{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--qc,var(--accent-ink));}
.qcard h3{font-family:var(--display);font-weight:600;font-size:20px;margin:7px 0 7px;color:var(--deep);}
.qcard p{margin:0;font-size:14.5px;color:var(--ink-soft);line-height:1.5;}
.qcard .go{margin-top:14px;font-family:var(--mono);font-size:12px;color:var(--qc,var(--accent-ink));display:inline-flex;align-items:center;gap:6px;}
.qcard .go .arw{transition:transform .2s;}
.qcard:hover .go .arw{transform:translateX(4px);}

/* ---------------- CHALLENGE ---------------- */
.challenge{background:linear-gradient(180deg,#10294d,#0a1f3d);color:#cfe0dd;}
.challenge .eyebrow{color:#a9c8ee;}
.challenge h2.sec{color:#fff;}.challenge h2.sec em{color:var(--accent);}
.challenge .lead{color:#9fb6b2;}
.cgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
@media (max-width:780px){.cgrid{grid-template-columns:1fr;}}
.ccard{background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.11);border-radius:var(--r-md);padding:26px;transition:.22s var(--ease);}
.ccard:hover{background:rgba(255,255,255,.08);transform:translateY(-4px);}
.ccard .ci{width:48px;height:48px;border-radius:13px;background:rgba(40,116,206,.18);display:flex;align-items:center;justify-content:center;color:#a9c8ee;margin-bottom:14px;}
.ccard h4{font-family:var(--display);font-weight:600;font-size:19px;color:#fff;margin:0 0 9px;}
.ccard p{margin:0;font-size:14.5px;color:#aebfbb;line-height:1.55;}
.persona{margin-top:28px;background:linear-gradient(120deg,rgba(40,116,206,.16),rgba(40,116,206,.10));border:1px solid rgba(40,116,206,.32);border-radius:var(--r-lg);padding:28px 30px;display:grid;grid-template-columns:auto 1fr;gap:22px;align-items:center;}
@media (max-width:600px){.persona{grid-template-columns:1fr;}}
.persona .pav{width:74px;height:74px;border-radius:18px;background:linear-gradient(150deg,var(--accent),var(--terracotta));display:flex;align-items:center;justify-content:center;color:#fff;flex:0 0 auto;box-shadow:0 10px 24px rgba(0,0,0,.25);}
.persona h4{font-family:var(--display);font-weight:600;font-size:21px;color:#fff;margin:0 0 7px;}
.persona p{margin:0 0 7px;font-size:15px;color:#cfe0dd;}
.persona .tagline{font-family:var(--mono);font-size:12.5px;color:var(--accent);letter-spacing:.02em;}

/* ---------------- JOURNEY ---------------- */
.journey-sec{background:var(--paper);}
.journey{position:relative;max-width:920px;margin:8px auto 0;}
.jline{position:absolute;left:39px;top:30px;bottom:40px;width:3px;background:var(--line-2);border-radius:3px;overflow:hidden;}
.jline .fill{position:absolute;inset:0 0 auto 0;height:var(--prog,0%);background:linear-gradient(180deg,var(--accent),var(--green));border-radius:3px;transition:height .2s linear;}
@media (max-width:680px){.jline{left:27px;}}
.jstep{display:grid;grid-template-columns:80px 1fr;gap:24px;padding-bottom:26px;position:relative;}
@media (max-width:680px){.jstep{grid-template-columns:56px 1fr;gap:16px;}}
.jnum{width:80px;height:80px;border-radius:50%;background:var(--card);border:3px solid var(--line-2);color:var(--deep);display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:var(--shadow);position:relative;z-index:2;transition:.3s var(--ease);}
.jnum .n{font-family:var(--display);font-weight:700;font-size:26px;line-height:1;}
.jnum .ic{position:absolute;top:-9px;right:-9px;width:30px;height:30px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow);}
@media (max-width:680px){.jnum{width:56px;height:56px;}.jnum .n{font-size:20px;}.jnum .ic{width:24px;height:24px;}}
.jstep.in .jnum{border-color:var(--accent);transform:scale(1.04);}
.jbody{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:22px 24px;box-shadow:var(--shadow);transition:transform .22s var(--ease),box-shadow .22s;}
.jstep:hover .jbody{transform:translateY(-3px);box-shadow:var(--shadow-md);}
.jbody .jt{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent-ink);}
.jbody h4{font-family:var(--display);font-weight:600;font-size:21px;margin:7px 0 8px;color:var(--deep);}
.jbody p{margin:0 0 12px;font-size:15px;color:var(--ink-soft);line-height:1.55;}
.jbody .q{font-style:italic;font-size:14px;color:var(--muted);border-left:3px solid var(--accent);padding-left:13px;margin-bottom:12px;}
.jbody .more{font-family:var(--mono);font-size:12px;color:var(--accent-ink);display:inline-flex;align-items:center;gap:6px;}
.jbody .more .arw{transition:transform .2s;}
.jbody .more:hover .arw{transform:translateX(4px);}

/* ---------------- EXPLORE ---------------- */
.band{background:linear-gradient(180deg,#f1e8d6,#ece1cd);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.cards2{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;}
@media (max-width:780px){.cards2{grid-template-columns:1fr;}}
.xcard{display:block;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:28px;position:relative;overflow:hidden;box-shadow:var(--shadow);transition:transform .22s var(--ease),box-shadow .22s,border-color .22s;}
.xcard::before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:var(--ca,var(--accent));}
.xcard:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--ca,var(--accent));}
.xcard .flags{font-size:27px;letter-spacing:3px;}
.xcard .ct{font-family:var(--display);font-weight:700;font-size:25px;margin:13px 0 5px;color:var(--deep);}
.xcard .cn{font-family:var(--mono);font-size:11px;color:var(--ca,var(--accent-ink));letter-spacing:.03em;margin-bottom:11px;}
.xcard .cd{font-size:15px;color:var(--ink-soft);line-height:1.55;}
.xcard .go{margin-top:16px;font-family:var(--mono);font-size:12.5px;color:var(--ca,var(--accent-ink));display:inline-flex;align-items:center;gap:7px;font-weight:500;}
.xcard .go .arw{transition:transform .2s;}
.xcard:hover .go .arw{transform:translateX(5px);}
.xcard .emerg{font-size:12px;font-style:italic;color:var(--accent-ink);}

/* ---------------- TRUST PILLARS ---------------- */
.trip{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
@media (max-width:780px){.trip{grid-template-columns:1fr;}}
.pcard{background:var(--card);border:1px solid var(--line);border-radius:var(--r-md);padding:26px;box-shadow:var(--shadow);transition:transform .22s var(--ease);}
.pcard:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);}
.pcard .pi{width:52px;height:52px;border-radius:14px;background:linear-gradient(150deg,var(--accent-soft),#f6d3b3);display:flex;align-items:center;justify-content:center;color:var(--accent-ink);margin-bottom:15px;}
.pcard.g .pi{background:linear-gradient(150deg,var(--green-soft),#aed9c3);color:var(--green-ink);}
.pcard h4{font-family:var(--display);font-weight:600;font-size:20px;margin:0 0 8px;color:var(--deep);}
.pcard p{margin:0;font-size:14.5px;color:var(--ink-soft);line-height:1.55;}
.pcard .tagk{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-ink);margin-top:12px;}

/* ---------------- HONESTY PROMISE (disclaimer) ---------------- */
.honesty{background:linear-gradient(180deg,#fffdf8,#f8f1e6);}
.honesty-card{background:var(--card);border:1px solid var(--line-2);border-radius:var(--r-xl);box-shadow:var(--shadow-md);overflow:hidden;}
.honesty-card .hc-top{display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:center;padding:30px 34px;background:linear-gradient(110deg,#10294d,#173f6e);color:#eaf3f1;}
.honesty-card .hc-top .seal{width:60px;height:60px;border-radius:16px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;color:var(--accent);flex:0 0 auto;}
.honesty-card .hc-top .kick{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:#9fb6d4;}
.honesty-card .hc-top h3{font-family:var(--display);font-weight:600;font-size:25px;margin:5px 0 0;color:#fff;}
.honesty-card .hc-top p{margin:5px 0 0;font-size:14.5px;color:#bcd0cc;font-style:italic;}
.hpoints{display:grid;grid-template-columns:1fr 1fr;gap:0;}
@media (max-width:720px){.hpoints{grid-template-columns:1fr;}}
.hpt{padding:26px 30px;border-top:1px solid var(--line);border-right:1px solid var(--line);}
.hpt:nth-child(even){border-right:0;}
.hpt h4{font-family:var(--display);font-weight:600;font-size:17px;margin:0 0 9px;color:var(--deep);display:flex;gap:11px;align-items:flex-start;line-height:1.3;}
.hpt h4 .num{flex:0 0 auto;font-family:var(--mono);font-size:11px;color:#fff;background:var(--accent);border-radius:7px;padding:2px 8px;margin-top:2px;}
.hpt p{margin:0;font-size:14px;color:var(--ink-soft);line-height:1.6;}
.hpt p b{color:var(--deep);}

/* ---------------- IMPACT ---------------- */
.impact{background:linear-gradient(180deg,#f1e8d6,#ece1cd);border-top:1px solid var(--line);}
.impact .pcard{text-align:center;}
.impact .big{font-family:var(--display);font-weight:700;font-size:46px;color:var(--accent-ink);line-height:1;margin-bottom:6px;}

/* ---------------- CTA BAND ---------------- */
.ctaband{position:relative;overflow:hidden;color:#fff;text-align:center;
  background:radial-gradient(680px 320px at 50% -36%, rgba(40,116,206,.42), transparent 60%),linear-gradient(158deg,#173f6e,#0a1f3d);}
.ctaband h2{font-family:var(--display);font-weight:700;font-size:clamp(30px,4.4vw,48px);margin:0 0 14px;letter-spacing:-.02em;color:#fff;}
.ctaband p{color:#cfe0dd;font-style:italic;margin:0 auto 28px;max-width:580px;font-size:19px;}
.ctaband .row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}
