/* =============================================================
   WordlyNomad — Homepage stylesheet (Direction 8)
   Loaded only by /index.html. Per-app pages use css/style.css.
   ============================================================= */

:root{
  --canvas:#f6f5f2;
  --canvas-2:#efeeea;
  --canvas-3:#e7e5df;
  --ink:#161616;
  --ink-2:#3b3b3b;
  --ink-3:#555555;      /* WCAG AA body on --canvas */
  --ink-4:#6a6a6a;      /* WCAG AA body on --canvas (used for labels/eyebrows) */
  --rule:rgba(20,20,20,.08);
  --rule-2:rgba(20,20,20,.14);
  --r-lg:28px;
  --r-md:20px;
  --r-sm:14px;

  /* per-app palettes */
  --wf-1:#0a2342; --wf-2:#3a6b9f; --wf-glow:#7cc4ff;
  --wp-1:#102a1a; --wp-2:#446b54; --wp-glow:#9ad9b1;
  --uc-1:#3a1414; --uc-2:#7a2e2e; --uc-glow:#f7b9a3;
  --mp-1:#1a1547; --mp-2:#4d4cb8; --mp-glow:#ffd166;

  --rail:#161616;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--canvas);
  color:var(--ink);
  font-family:"Schibsted Grotesk",-apple-system,system-ui,sans-serif;
  font-feature-settings:"ss01";
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  letter-spacing:-.005em;
}
.mono{font-family:"JetBrains Mono",ui-monospace,monospace;letter-spacing:0}
a{color:inherit;text-decoration:none}
.wrap{max-width:1280px;margin:0 auto;padding:0 32px;width:100%}

/* ---------- COLOR RAIL ---------- */
.rail{
  position:fixed;left:18px;top:50%;transform:translateY(-50%);
  width:3px;height:42vh;border-radius:99px;z-index:30;
  background:linear-gradient(180deg,var(--rule-2),var(--rule-2));
  overflow:hidden;
  pointer-events:none;
}
.rail i{
  position:absolute;left:0;right:0;top:0;
  height:100%;
  background:var(--rail);
  transition:background .8s cubic-bezier(.2,.7,.2,1);
  transform-origin:top;
  transform:scaleY(var(--rail-progress,0));
}
.rail-label{
  position:fixed;left:14px;top:50%;transform:translateY(calc(-50% + 26vh)) rotate(-90deg);
  transform-origin:left top;
  font-family:"JetBrains Mono",monospace;
  font-size:10px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--ink-4);z-index:30;white-space:nowrap;pointer-events:none;
}
@media (max-width:900px){
  .rail,.rail-label{display:none}
}

/* ---------- NAV ---------- */
nav.top{
  position:fixed;top:18px;left:0;right:0;z-index:40;
  display:flex;justify-content:center;pointer-events:none;
}
.nav-pill{
  pointer-events:auto;
  display:flex;align-items:center;gap:36px;
  height:54px;padding:0 8px 0 22px;
  background:rgba(246,245,242,.72);
  backdrop-filter:saturate(160%) blur(22px);
  -webkit-backdrop-filter:saturate(160%) blur(22px);
  border:1px solid var(--rule);
  border-radius:999px;
  box-shadow:0 1px 0 rgba(255,255,255,.7) inset, 0 14px 32px -18px rgba(0,0,0,.18);
}
.brand{display:flex;align-items:center;gap:10px;font-weight:600;font-size:15px;letter-spacing:-.01em}
.brand .mark{
  width:22px;height:22px;border-radius:7px;
  background:conic-gradient(from 200deg,#ffb692,#a5b8ff,#9ad9b1,#ffb692);
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.05),0 4px 12px -4px rgba(20,20,20,.2);
}
.nav-links{display:flex;gap:24px;font-size:13.5px;color:var(--ink-2)}
.nav-links a{position:relative;padding:6px 2px}
.nav-links a:hover{color:var(--ink)}
.nav-links a.active{color:var(--ink)}
.nav-links a.active::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;border-radius:2px;
  background:var(--rail);transition:background .6s ease;
}
.nav-cta{
  height:40px;padding:0 16px;display:inline-flex;align-items:center;gap:8px;
  background:var(--ink);color:var(--canvas);font-size:13px;font-weight:500;
  border-radius:999px;
}
.nav-cta:hover{background:#2a2a2a}
@media (max-width:680px){
  .nav-pill{gap:14px;padding:0 6px 0 14px;height:48px}
  .nav-links{gap:12px;font-size:12px}
  .nav-cta{height:36px;padding:0 12px;font-size:12px}
}

/* ---------- PANEL FRAMEWORK ---------- */
.panel{
  position:relative;
  min-height:100vh;
  width:100%;
  display:flex;align-items:center;
  padding:120px 0 80px;
}
.panel + .panel{border-top:1px solid var(--rule)}
.panel .eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  padding:6px 12px;border-radius:999px;
  background:rgba(20,20,20,.04);border:1px solid var(--rule);
  font-size:11px;color:var(--ink-2);letter-spacing:.14em;text-transform:uppercase;
  font-family:"JetBrains Mono",monospace;
}
.panel .eyebrow .dot{width:6px;height:6px;border-radius:50%;background:#22a06b}
.panel-index{
  position:absolute;top:120px;right:32px;
  font-family:"JetBrains Mono",monospace;font-size:11px;
  letter-spacing:.22em;color:var(--ink-4);text-transform:uppercase;
}
.panel-index span{color:var(--ink-2)}

/* fade-in primitive */
.fade{opacity:0;transform:translateY(22px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
.fade.in{opacity:1;transform:none}
.fade.d1{transition-delay:.05s}
.fade.d2{transition-delay:.18s}
.fade.d3{transition-delay:.31s}
.fade.d4{transition-delay:.44s}
.fade.d5{transition-delay:.57s}
.fade.d6{transition-delay:.70s}

/* ---------- PANEL 1 · BRAND HERO ---------- */
#brand{
  background:
    radial-gradient(120% 80% at 80% 10%, rgba(124,196,255,.10), transparent 55%),
    radial-gradient(80% 60% at 10% 90%, rgba(247,185,163,.10), transparent 60%),
    var(--canvas);
}
.brand-grid{
  display:grid;grid-template-columns:1fr;gap:48px;
}
h1.headline{
  font-size:clamp(60px,9.6vw,160px);
  line-height:.92;letter-spacing:-.048em;font-weight:700;
  margin:28px 0 0;max-width:14ch;color:var(--ink);
}
h1.headline .gradient{
  background:linear-gradient(100deg,#0a2342 0%,#4d4cb8 28%,#7a2e2e 56%,#446b54 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.thesis-row{
  display:flex;justify-content:space-between;align-items:end;gap:64px;
  margin-top:8px;flex-wrap:wrap;
}
.thesis-row p.thesis{
  font-size:clamp(18px,1.6vw,22px);line-height:1.45;color:var(--ink-2);
  max-width:52ch;margin:0;font-weight:400;
}
.meta{display:flex;gap:44px;align-items:end;flex-wrap:wrap}
.meta div .k{font-size:10px;color:var(--ink-4);letter-spacing:.18em;text-transform:uppercase;margin-bottom:6px;font-family:"JetBrains Mono",monospace}
.meta div .v{font-size:30px;font-weight:600;letter-spacing:-.022em}
.scroll-cue{
  position:absolute;left:50%;bottom:42px;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:10px;
  color:var(--ink-3);font-size:10px;letter-spacing:.28em;text-transform:uppercase;
  font-family:"JetBrains Mono",monospace;
}
.scroll-cue .line{
  width:1px;height:36px;background:linear-gradient(180deg,var(--ink-3),transparent);
  animation:cue 2.4s ease-in-out infinite;transform-origin:top;
}
@keyframes cue{0%,100%{transform:scaleY(.4);opacity:.5}50%{transform:scaleY(1);opacity:1}}

/* ---------- PANEL 2 · APPS GRID ---------- */
#apps{
  background:
    radial-gradient(60% 50% at 0% 0%, rgba(20,20,20,.025), transparent 60%),
    var(--canvas);
}
.section-head{
  display:flex;align-items:end;justify-content:space-between;gap:32px;
  margin-bottom:56px;flex-wrap:wrap;
}
.section-head .lhs{max-width:42ch}
.section-head h2{
  font-size:clamp(40px,5.6vw,72px);line-height:1;letter-spacing:-.035em;
  font-weight:600;margin:18px 0 0;
}
.section-head .rhs{
  font-size:14px;color:var(--ink-3);line-height:1.55;max-width:32ch;
  border-left:1px solid var(--rule);padding-left:20px;
}

.app-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(min(420px, 100%), 1fr));
  gap:20px;
}
.card{
  position:relative;
  aspect-ratio: 4 / 3;
  border-radius:var(--r-lg);
  overflow:hidden;
  color:#fff;
  padding:28px;
  display:grid;
  grid-template-rows:auto 1fr auto;
  row-gap:18px;
  border:1px solid rgba(255,255,255,.06);
  box-shadow:0 1px 0 rgba(255,255,255,.04) inset, 0 20px 40px -28px rgba(20,20,20,.35);
  transition:transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s ease;
  isolation:isolate;
}
.card:hover{transform:translateY(-6px);box-shadow:0 1px 0 rgba(255,255,255,.05) inset, 0 36px 56px -28px rgba(20,20,20,.45)}
.card .top{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;z-index:2;position:relative}
.card .icon{
  width:56px;height:56px;border-radius:14px;overflow:hidden;
  box-shadow:0 12px 26px -10px rgba(0,0,0,.5), 0 0 0 1px rgba(255,255,255,.18);
  background:rgba(255,255,255,.05);flex-shrink:0;
}
.card .icon img{width:100%;height:100%;display:block}
.card .corner{
  font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.22em;
  text-transform:uppercase;color:rgba(255,255,255,.65);text-align:right;line-height:1.5;
}
.card .corner .n{display:block;color:rgba(255,255,255,.4);margin-bottom:2px}

.card .mock{position:relative;align-self:stretch;display:flex;flex-direction:column;justify-content:center;z-index:2}

.card .titleblock{z-index:2;position:relative}
.card h3{
  font-size:30px;line-height:1.04;letter-spacing:-.028em;font-weight:600;
  margin:0 0 8px;
}
.card .tag{
  font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:rgba(255,255,255,.7);margin:0 0 12px;
  font-family:"JetBrains Mono",monospace;
}
.card p.desc{
  font-size:13.5px;line-height:1.5;color:rgba(255,255,255,.78);margin:0 0 14px;max-width:38ch;
}
.card .cta{
  display:inline-flex;align-items:center;gap:10px;
  font-size:12.5px;font-weight:500;color:#fff;
  padding-top:14px;border-top:1px solid rgba(255,255,255,.14);
}
.card .cta .arrow{transition:transform .25s ease;font-family:"JetBrains Mono",monospace}
.card:hover .cta .arrow{transform:translateX(4px)}

/* ---- WiseFolio mockup ---- */
.card.wisefolio .ticks{
  display:grid;grid-template-columns:repeat(4,1fr);gap:7px;
}
.card.wisefolio .ticks .t{
  padding:9px 9px;border-radius:10px;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);
  backdrop-filter:blur(6px);
}
.card.wisefolio .ticks .t .s{font-size:8.5px;letter-spacing:.12em;text-transform:uppercase;opacity:.7;font-family:"JetBrains Mono",monospace}
.card.wisefolio .ticks .t .p{font-size:13.5px;margin-top:3px;font-weight:600;letter-spacing:-.01em;line-height:1.1}
.card.wisefolio .ticks .t .d{font-size:10px;color:var(--wf-glow);margin-top:2px;font-family:"JetBrains Mono",monospace}
.card.wisefolio .ticks .t .d.dn{color:#ff9c9c}
.card.wisefolio .chartwrap{
  position:absolute;left:0;right:0;bottom:0;
  height:62%;
  pointer-events:none;
  z-index:0;
  overflow:hidden;
}
.card.wisefolio .chartwrap svg{position:absolute;inset:0;width:100%;height:100%;opacity:.85}

/* ---- WorthPilot mockup ---- */
.card.worthpilot .meter{
  display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;
}
.card.worthpilot .meter .m{padding:12px 12px;border-radius:12px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1)}
.card.worthpilot .meter .m .k{font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;opacity:.7;font-family:"JetBrains Mono",monospace}
.card.worthpilot .meter .m .v{font-size:20px;font-weight:600;margin-top:6px;letter-spacing:-.015em;line-height:1}
.card.worthpilot .meter .m .v .gl{color:var(--wp-glow)}

/* ---- Citizenship mockup ---- */
.card.citizenship .flag{
  position:relative;border-radius:12px;overflow:hidden;
  background:linear-gradient(135deg, rgba(58,20,20,.6), rgba(122,46,46,.55));
  border:1px solid rgba(255,255,255,.12);
  padding:14px 14px 0;height:78px;
}
.card.citizenship .flag .star-field{
  position:absolute;top:14px;left:14px;height:22px;width:80px;opacity:.55;
  background:
    radial-gradient(circle, #fff 1.2px, transparent 1.5px) 0 0/14px 8px,
    radial-gradient(circle, #fff 1.2px, transparent 1.5px) 7px 4px/14px 8px;
}
.card.citizenship .flag .bars{
  position:absolute;left:0;right:0;bottom:0;height:26px;
  background:repeating-linear-gradient(0deg, rgba(255,255,255,.16) 0 4px, transparent 4px 8px);
}
.card.citizenship .progress{margin-top:14px}
.card.citizenship .progress .row{display:flex;justify-content:space-between;font-size:10px;letter-spacing:.16em;text-transform:uppercase;opacity:.78;margin-bottom:8px;font-family:"JetBrains Mono",monospace}
.card.citizenship .progress .bar{height:6px;border-radius:99px;background:rgba(255,255,255,.14);overflow:hidden}
.card.citizenship .progress .bar i{display:block;height:100%;width:73%;background:linear-gradient(90deg,var(--uc-glow),#fff);border-radius:99px}

/* ---- MatchPulse mockup ---- */
.card.matchpulse .fixtures{display:grid;gap:8px}
.card.matchpulse .fix{
  display:grid;grid-template-columns:48px 1fr auto;align-items:center;gap:10px;
  padding:9px 12px;border-radius:11px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  font-size:12px;line-height:1.2;
}
.card.matchpulse .fix .d{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.12em;opacity:.7;text-transform:uppercase}
.card.matchpulse .fix .m{font-weight:500;font-size:12.5px;letter-spacing:-.005em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.card.matchpulse .fix .m .vs{opacity:.55;margin:0 5px;font-style:italic}
.card.matchpulse .fix .when{font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--mp-glow);letter-spacing:.1em;white-space:nowrap}

/* per-app washes */
.card.wisefolio{
  background:
    radial-gradient(120% 80% at 100% 0%, rgba(124,196,255,.55), transparent 55%),
    radial-gradient(80% 60% at 0% 100%, rgba(58,107,159,.55), transparent 60%),
    linear-gradient(155deg,#0a2342 0%, #173964 65%, #1f4a82 100%);
}

.card.worthpilot{
  background:
    radial-gradient(80% 80% at 0% 0%, rgba(154,217,177,.45), transparent 60%),
    radial-gradient(60% 70% at 100% 100%, rgba(68,107,84,.55), transparent 60%),
    linear-gradient(155deg,#102a1a 0%, #1f4631 60%, #2c5d40 100%);
}
.card.worthpilot::after{
  content:"";position:absolute;right:-30%;top:-20%;width:80%;height:80%;
  background:radial-gradient(closest-side, rgba(154,217,177,.18), transparent 70%);
  pointer-events:none;z-index:-1;
}

.card.citizenship{
  background:
    radial-gradient(70% 90% at 100% 100%, rgba(247,185,163,.45), transparent 60%),
    linear-gradient(155deg,#3a1414 0%, #5e2222 55%, #7a2e2e 100%);
}
.card.citizenship .stars{
  position:absolute;top:32px;left:32px;height:14px;width:96px;opacity:.22;
  background:
    radial-gradient(circle, #fff 1.1px, transparent 1.4px) 0 0/14px 7px,
    radial-gradient(circle, #fff 1.1px, transparent 1.4px) 7px 3.5px/14px 7px;
  pointer-events:none;
}
.card.citizenship .stripe{
  position:absolute;left:0;right:0;bottom:0;height:6px;
  background:repeating-linear-gradient(90deg, rgba(255,255,255,.14) 0 12.5%, transparent 12.5% 25%);
  pointer-events:none;
}

.card.matchpulse{
  background:
    radial-gradient(80% 70% at 100% 0%, rgba(255,209,102,.42), transparent 60%),
    radial-gradient(60% 60% at 0% 100%, rgba(77,76,184,.55), transparent 65%),
    linear-gradient(155deg,#1a1547 0%, #2d2a78 60%, #3f3da3 100%);
}
.card.matchpulse::after{
  content:"";position:absolute;top:32px;right:32px;width:10px;height:10px;border-radius:50%;
  background:var(--mp-glow);
  box-shadow:0 0 0 0 rgba(255,209,102,.6);
  animation:pulse 2.4s ease-out infinite;
  pointer-events:none;
}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(255,209,102,.55)}
  70%{box-shadow:0 0 0 18px rgba(255,209,102,0)}
  100%{box-shadow:0 0 0 0 rgba(255,209,102,0)}
}

/* ---------- PANEL 3 · HOW WE BUILD ---------- */
#build{
  background:
    radial-gradient(80% 60% at 100% 0%, rgba(20,20,20,.04), transparent 60%),
    var(--canvas-2);
}
.manifesto-head{
  font-size:clamp(40px,5.2vw,68px);line-height:1.02;letter-spacing:-.035em;
  font-weight:600;margin:18px 0 64px;max-width:18ch;
}
.tenets{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(min(280px, 100%), 1fr));
  gap:0;
  border-top:1px solid var(--rule-2);
}
.tenet{
  padding:36px 28px 36px 0;
  border-bottom:1px solid var(--rule-2);
  border-right:1px solid var(--rule-2);
  position:relative;
}
.tenet:last-child{border-right:none}
.tenet:nth-child(4n){border-right:none}
.tenet .n{
  font-family:"JetBrains Mono",monospace;font-size:11px;
  letter-spacing:.22em;color:var(--ink-4);text-transform:uppercase;margin-bottom:18px;
}
.tenet h4{
  font-size:24px;line-height:1.18;letter-spacing:-.022em;font-weight:600;margin:0 0 10px;
}
.tenet p{
  font-size:14.5px;line-height:1.55;color:var(--ink-3);margin:0;max-width:32ch;
}
.tenet:nth-child(4n) p,.tenet:nth-child(4n) h4{padding-right:0}

/* ---------- PANEL 4 · CLOSING CTA ---------- */
#close{
  background:
    radial-gradient(80% 60% at 50% 0%, rgba(247,185,163,.10), transparent 60%),
    radial-gradient(60% 50% at 50% 100%, rgba(124,196,255,.10), transparent 60%),
    var(--canvas);
  text-align:center;
}
.close-block{max-width:880px;margin:0 auto;text-align:center}
.close-block h2{
  font-size:clamp(54px,8vw,128px);line-height:.94;letter-spacing:-.045em;
  font-weight:700;margin:24px 0 0;
}
.close-block h2 .gradient{
  background:linear-gradient(100deg,#0a2342 0%, #4d4cb8 28%, #7a2e2e 56%, #446b54 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.close-block p{
  font-size:18px;color:var(--ink-2);line-height:1.5;margin:28px auto 0;max-width:48ch;
}
.close-actions{
  display:flex;justify-content:center;gap:14px;margin-top:44px;flex-wrap:wrap;
}
.close-actions a{
  height:52px;padding:0 24px;display:inline-flex;align-items:center;gap:10px;
  border-radius:999px;font-size:14px;font-weight:500;
}
.btn-primary{background:var(--ink);color:var(--canvas)}
.btn-primary:hover{background:#2a2a2a}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--rule-2)}
.btn-ghost:hover{background:rgba(20,20,20,.04)}

/* ---------- FOOTER ---------- */
footer{
  padding:80px 0 40px;border-top:1px solid var(--rule);
  background:var(--canvas-2);
}
.foot-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.foot-top p{font-size:14px;color:var(--ink-2);line-height:1.6;margin:14px 0 0;max-width:36ch}
.foot-top h5{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-4);margin:0 0 16px;font-family:"JetBrains Mono",monospace}
.foot-top a{display:block;font-size:14px;color:var(--ink-2);margin-bottom:9px}
.foot-top a:hover{color:var(--ink)}
.foot-row{
  border-top:1px solid var(--rule);padding-top:24px;
  display:flex;justify-content:space-between;align-items:center;
  font-size:11px;color:var(--ink-4);letter-spacing:.16em;text-transform:uppercase;
}

@media (max-width:900px){
  .wrap{padding:0 22px}
  .panel{padding:120px 0 60px}
  .panel-index{right:22px;top:96px}
  .thesis-row{flex-direction:column;align-items:start;gap:32px}
  .section-head{flex-direction:column;align-items:start}
  .section-head .rhs{border-left:none;padding-left:0;border-top:1px solid var(--rule);padding-top:20px}
  .tenets{grid-template-columns:1fr 1fr}
  .tenet:nth-child(4n){border-right:1px solid var(--rule-2)}
  .tenet:nth-child(2n){border-right:none}
  .foot-top{grid-template-columns:1fr 1fr;gap:32px}
}
@media (max-width:560px){
  h1.headline{font-size:clamp(48px,12vw,84px)}
  .tenets{grid-template-columns:1fr}
  .tenet{border-right:none !important}
  .card{aspect-ratio:auto;min-height:340px}
}

@media (prefers-reduced-motion: reduce){
  .fade{opacity:1;transform:none;transition:none}
  .scroll-cue .line{animation:none}
  .card.matchpulse::after{animation:none}
  .rail i{transition:none}
  .nav-links a.active::after{transition:none}
  .card,.card .cta .arrow{transition:none}
  html{scroll-behavior:auto}
}
