/* ============================================================================
   Rund — landing styles (v2: row-by-row onboarding parity + waitlist)
   Design DNA from the in-app onboarding: light cream surface, cool lava-lamp
   blobs, magenta #FF2296 + violet #8B5CF6, Space Grotesk + Inter. The motif
   animations live inside each SVG as SMIL (loop natively, in sync); this file
   handles page chrome, layout, the waitlist form, and scroll reveals.
   ========================================================================== */

:root {
  --bg:#FAFAFA; --bg-tint:#F4F4F5; --surface:#FFFFFF; --surface-alt:#F4F4F5;
  --ink:#0F172A; --mid:#334155; --lo:#64748B; --faint:#94A3B8;
  --primary:#FF2296; --primary-2:#FF5DAE; --accent:#FF6B35; --violet:#8B5CF6; --violet-2:#A78BFA; --success:#10B981;
  --line:rgba(15,23,42,.07); --line-strong:rgba(15,23,42,.14);
  --r-xs:10px; --r-sm:14px; --r-md:20px; --r-lg:28px; --r-xl:36px;
  --shadow-card:0 1px 2px rgba(15,23,42,.04), 0 12px 32px rgba(15,23,42,.07);
  --shadow-lift:0 2px 6px rgba(15,23,42,.06), 0 24px 56px rgba(15,23,42,.12);
  --shadow-glow:0 14px 40px rgba(255,34,150,.34);
  --maxw:1140px; --gutter:clamp(20px,5vw,48px);
  --font-display:"Sora",system-ui,-apple-system,sans-serif;
  --font-body:"Inter",system-ui,-apple-system,"SF Pro Text",sans-serif;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--font-body);color:var(--ink);background:var(--bg);line-height:1.6;font-size:17px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;overflow-x:hidden}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer}
:focus-visible{outline:2px solid var(--primary);outline-offset:3px;border-radius:6px}
h1,h2,h3{font-family:var(--font-display);font-weight:700;color:var(--ink);margin:0;letter-spacing:-.02em;overflow-wrap:break-word;text-wrap:balance}
p{text-wrap:pretty}

.skip-link{position:absolute;left:-999px;top:8px;z-index:200;background:var(--ink);color:#fff;padding:10px 16px;border-radius:8px}
.skip-link:focus{left:16px}

.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
section{position:relative}
section[id],[id]{scroll-margin-top:88px}
.section-pad{padding-block:clamp(64px,10vw,128px)}

.eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-display);font-weight:600;font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--primary)}
.eyebrow::before{content:"";width:18px;height:2px;border-radius:2px;background:currentColor;opacity:.6}

.section-head{max-width:720px;margin-inline:auto;text-align:center;margin-bottom:clamp(40px,6vw,72px)}
.section-head h2{font-size:clamp(30px,4.6vw,50px);line-height:1.06;margin:14px 0 0}
.section-head p{color:var(--mid);font-size:clamp(16px,1.6vw,19px);margin:16px auto 0;max-width:56ch}

/* ── Lava-lamp background ────────────────────────────────────────────────── */
.lava{position:fixed;inset:0;z-index:-2;overflow:hidden;pointer-events:none;background:radial-gradient(120% 80% at 50% 120%,rgba(59,130,246,.06),transparent 60%)}
.lava::after{content:"";position:absolute;left:0;right:0;bottom:0;height:55%;background:linear-gradient(to top,rgba(56,189,248,.10),transparent)}
.blob{position:absolute;border-radius:50%;filter:blur(8px);will-change:transform,opacity;opacity:0;animation:rise linear infinite}
.blob.b1{width:560px;height:560px;left:6%;background:radial-gradient(circle at 40% 40%,hsla(210,85%,62%,.26),transparent 68%);animation-duration:86s}
.blob.b2{width:440px;height:440px;left:58%;background:radial-gradient(circle at 40% 40%,hsla(200,90%,66%,.22),transparent 68%);animation-duration:70s;animation-delay:-12s}
.blob.b3{width:320px;height:320px;left:26%;background:radial-gradient(circle at 40% 40%,hsla(178,68%,60%,.20),transparent 68%);animation-duration:58s;animation-delay:-26s}
.blob.b4{width:240px;height:240px;left:72%;background:radial-gradient(circle at 40% 40%,hsla(238,70%,68%,.18),transparent 68%);animation-duration:46s;animation-delay:-34s}
.blob.b5{width:180px;height:180px;left:44%;background:radial-gradient(circle at 40% 40%,hsla(162,60%,66%,.16),transparent 68%);animation-duration:38s;animation-delay:-50s}
@keyframes rise{0%{transform:translate(0,110vh) scale(.85);opacity:0}14%{opacity:1}50%{transform:translate(28px,46vh) scale(1.12)}86%{opacity:1}100%{transform:translate(-20px,-30vh) scale(.9);opacity:0}}

/* ── Header ──────────────────────────────────────────────────────────────── */
.site-header{position:sticky;top:0;z-index:100;transition:background .3s var(--ease),border-color .3s var(--ease);border-bottom:1px solid transparent}
.site-header.scrolled{background:rgba(250,250,250,.72);backdrop-filter:saturate(160%) blur(14px);-webkit-backdrop-filter:saturate(160%) blur(14px);border-bottom-color:var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px;gap:20px}
.brand{display:inline-flex;align-items:center}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{color:var(--mid);font-weight:500;font-size:15px;transition:color .2s}
.nav-links a:hover{color:var(--ink)}
.nav-actions{display:flex;align-items:center;gap:12px}
/* Logo lives on the RIGHT, grouped with the CTA; margin-left:auto keeps it
   right-aligned even when the nav links are hidden on mobile. */
.nav-right{display:flex;align-items:center;gap:18px;margin-left:auto}
.short{display:none}

/* ── Buttons ─────────────────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:var(--font-display);font-weight:600;font-size:15.5px;padding:13px 22px;border-radius:999px;border:1px solid transparent;transition:transform .18s var(--ease),box-shadow .25s var(--ease),background .2s;white-space:nowrap}
.btn-primary{color:#fff;background:linear-gradient(135deg,var(--primary),var(--primary-2));box-shadow:var(--shadow-glow)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 20px 52px rgba(255,34,150,.46)}
.btn-primary:active{transform:translateY(0)}
.btn-ghost{color:var(--ink);background:rgba(255,255,255,.6);border-color:var(--line-strong)}
.btn-ghost:hover{background:#fff;transform:translateY(-2px);box-shadow:var(--shadow-card)}
.btn-sm{padding:10px 17px;font-size:14px}
.btn-lg{padding:16px 28px;font-size:17px}

/* ── Hero ────────────────────────────────────────────────────────────────── */
.hero{position:relative;min-height:clamp(720px,calc(100svh - 72px),900px);padding:0;overflow:hidden;background:#F8FBFF;display:flex;align-items:stretch}
.hero::before{content:"";position:absolute;inset:0;z-index:0;background-image:url("/assets/hero/sydney-claim-hero.jpg?v=2026060401");background-size:cover;background-position:center right;transform:scale(1.012);will-change:transform;animation:hero-drift 18s ease-in-out infinite alternate}
.hero::after{content:"";position:absolute;inset:0;background:
  linear-gradient(90deg,rgba(250,250,250,.96) 0%,rgba(250,250,250,.86) 30%,rgba(250,250,250,.36) 52%,rgba(250,250,250,.05) 76%,rgba(250,250,250,0) 100%),
  linear-gradient(180deg,rgba(250,250,250,.48) 0%,rgba(250,250,250,0) 42%,rgba(250,250,250,.78) 100%);
pointer-events:none;z-index:2}
.hero-grid{position:relative;z-index:3;display:grid;grid-template-columns:minmax(0,.9fr) minmax(320px,1.1fr);gap:clamp(32px,5vw,72px);align-items:center;min-height:inherit}
.hero-copy{max-width:42ch;padding-block:clamp(64px,8vw,96px);text-shadow:0 1px 22px rgba(255,255,255,.68)}
.hero h1{font-size:clamp(46px,8vw,92px);line-height:.98;letter-spacing:-.045em;margin:18px 0 0}
.hero h1 .grad{background:linear-gradient(115deg,var(--primary) 10%,var(--violet) 90%);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero .lead{font-size:clamp(17px,1.9vw,21px);color:var(--mid);margin:22px 0 0;line-height:1.55}
.hero-bg-focus{min-height:560px}
@keyframes hero-drift{0%{transform:scale(1.012) translate3d(0,0,0)}100%{transform:scale(1.045) translate3d(-16px,-8px,0)}}
.frame-badge{position:absolute;top:-14px;left:24px;display:inline-flex;align-items:center;gap:7px;background:var(--ink);color:#fff;font-size:12px;font-weight:600;padding:7px 13px;border-radius:999px;box-shadow:var(--shadow-card);font-family:var(--font-display);z-index:2}

/* ── Hero claim markers — one persona pinned to the centre of each painted zone.
   Positions are set in JS from the background image's cover geometry, so every
   marker tracks its zone across viewports; this layer shares the hero-drift
   transform so the pins stay glued to the map as it slowly pans. ──────────── */
.hero-claims{position:absolute;inset:0;z-index:1;pointer-events:none;visibility:hidden;transform:scale(1.012);transform-origin:50% 50%;will-change:transform;animation:hero-drift 18s ease-in-out infinite alternate}
.hero-claims.ready{visibility:visible}
.claim{position:absolute;transform:translate(-50%,-50%);--sz:58px}
.claim--lg{--sz:74px}
.claim--sm{--sz:46px}
.claim-inner{position:relative;display:flex;flex-direction:column;align-items:center;opacity:0;will-change:transform,opacity}
.hero-claims.ready .claim-inner{animation:claim-in .72s cubic-bezier(.2,.85,.25,1) both var(--d,0s),claim-bob var(--bd,6.8s) ease-in-out infinite calc(var(--d,0s) + .8s)}
.claim-avatar{position:relative;width:var(--sz);height:var(--sz);border-radius:50%;background:#fff;padding:3px;box-shadow:0 0 0 2.5px var(--ring),0 16px 30px -12px rgba(15,23,42,.6),0 0 26px -4px var(--ring)}
.claim-avatar .clip{display:block;width:100%;height:100%;border-radius:50%;overflow:hidden;background:#e7edf5}
.claim-avatar img{width:100%;height:100%;object-fit:cover;display:block;transform:scale(1.16);filter:blur(2.8px) saturate(1.08) brightness(1.03)}
.claim--lg .claim-avatar img{filter:blur(3.4px) saturate(1.08) brightness(1.03)}
.claim-nick{position:absolute;top:calc(100% + 9px);left:50%;transform:translateX(-50%);white-space:nowrap;font-family:var(--font-display,Inter,sans-serif);font-weight:700;font-size:12.5px;letter-spacing:-.01em;color:#1f2a37;background:rgba(255,255,255,.97);padding:5px 11px 6px;border-radius:999px;box-shadow:0 7px 18px -7px rgba(15,23,42,.5),0 0 0 1px rgba(15,23,42,.05),inset 0 0 0 1.4px var(--ring);-webkit-backdrop-filter:blur(6px) saturate(150%);backdrop-filter:blur(6px) saturate(150%)}
.claim--lg .claim-nick{font-size:13.5px;top:calc(100% + 11px)}
.claim--sm .claim-nick{font-size:11.5px;top:calc(100% + 7px)}
@keyframes claim-in{from{opacity:0;transform:translateY(14px) scale(.8)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes claim-bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
/* The claim pills are a desktop layer. They sit UNDER the hero scrim, so pins
   over the copy fade into the mist instead of clashing — which lets them show
   on narrow desktops too. Below 920px the hero stacks into a glass card and the
   cover-crop would push pins off-screen, so they're hidden there. */
@media (max-width:920px){.hero-claims{display:none}}

/* ── Waitlist form ───────────────────────────────────────────────────────── */
.waitlist{margin-top:30px;max-width:480px}
.waitlist.center{margin-inline:auto;margin-top:30px}
.waitlist-row{display:flex;gap:10px}
.waitlist.center .waitlist-row{justify-content:center}
.waitlist-input{flex:1;min-width:0;font:inherit;font-size:16px;padding:14px 18px;border-radius:999px;border:1px solid var(--line-strong);background:#fff;color:var(--ink);transition:border-color .2s,box-shadow .2s}
.waitlist-input::placeholder{color:var(--faint)}
.waitlist-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px rgba(255,34,150,.12)}
.waitlist .btn{padding:14px 24px;flex:none}
.waitlist-msg{min-height:20px;margin:12px 2px 0;font-size:14px;font-weight:500}
.waitlist-msg.ok{color:var(--success)}
.waitlist-msg.err{color:var(--accent)}
.waitlist-note{margin:10px 2px 0;font-size:13.5px;color:var(--lo)}
.waitlist.center .waitlist-msg{text-align:center}
.waitlist.is-done .waitlist-row{display:none}

/* ── Proof strip ─────────────────────────────────────────────────────────── */
.strip{border-block:1px solid var(--line);background:rgba(255,255,255,.5)}
.strip-track{display:flex;gap:40px;align-items:center;padding:18px 0;flex-wrap:wrap;justify-content:center}
.strip-item{display:inline-flex;align-items:center;gap:9px;color:var(--mid);font-weight:500;font-size:15px}
.strip-item svg{width:18px;height:18px;color:var(--primary)}

/* ── Rows (the 7 onboarding steps) ───────────────────────────────────────── */
.row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,80px);align-items:center}
.row+.row{margin-top:clamp(64px,9vw,120px)}
.row.flip .row-art{order:-1}
.step-tag{font-family:var(--font-display);font-weight:600;font-size:12.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--primary)}
.row-copy h3{font-size:clamp(26px,3.4vw,40px);line-height:1.1;margin:12px 0 0}
.row-copy p{color:var(--mid);font-size:clamp(16px,1.5vw,18.5px);margin:16px 0 0;max-width:42ch}
.mini-list{list-style:none;padding:0;margin:22px 0 0;display:grid;gap:12px}
.mini-list li{display:flex;gap:11px;align-items:flex-start;color:var(--mid);font-size:15.5px}
.mini-list svg{flex:none;width:20px;height:20px;margin-top:1px;color:var(--primary)}
@media (max-width:920px){.mini-list{max-width:420px;margin-inline:auto;text-align:left}}
.row-art{display:flex;justify-content:center}
/* No card behind the animations — they play directly on the page background. */
.stage{position:relative;width:min(460px,100%);aspect-ratio:1;display:flex;align-items:center;justify-content:center}
.art-svg{width:100%;height:100%;display:block;overflow:visible}

/* Deed — faithful recreation of the in-app "Neighborhood Founder Title Deed":
   warm parchment ground, double gold foil frame, corner dots, founder portrait,
   crown seal, mahalle hierarchy, ruled register, rund.run footer. */
.deed{position:relative;width:min(360px,100%);padding:24px 24px 20px;border-radius:24px;text-align:center;overflow:hidden;transition:transform .25s var(--ease);
  background:linear-gradient(135deg,#FFFDF7 0%,#FBF4E2 55%,#F3E6C8 100%);
  border:1.5px solid #C8A042;box-shadow:0 16px 44px rgba(90,74,30,.30)}
.deed:hover{transform:translateY(-5px)}
.deed-frame{position:absolute;inset:6px;border:1px solid rgba(200,160,66,.42);border-radius:19px;pointer-events:none}
.deed-corner{position:absolute;width:9px;height:9px;border:1px solid #E4CE97;border-radius:50%}
.deed-corner::after{content:"";position:absolute;inset:2.6px;border-radius:50%;background:#C8A042}
.deed-seal{position:absolute;top:30px;right:14px;line-height:0}
.deed-eyebrow{font-family:var(--font-display);font-weight:600;font-size:10.5px;letter-spacing:.26em;line-height:1.5;color:#9A7726;text-transform:uppercase;margin-top:2px}
.deed-rule{display:flex;align-items:center;justify-content:center;gap:8px;margin:10px 0 14px}
.deed-rule i{height:1px;width:46px;background:rgba(200,160,66,.55)}
.deed-rule b{width:6px;height:6px;background:#C8A042;transform:rotate(45deg)}
.deed-portrait{width:92px;height:92px;margin:6px auto 14px;border-radius:50%;border:2.5px solid #C8A042;padding:3px;background:#fff;box-shadow:0 0 0 6px rgba(255,34,150,.10),0 8px 18px rgba(90,74,30,.22)}
.deed-portrait img{width:100%;height:100%;border-radius:50%;object-fit:cover;display:block}
.deed-name{font-family:var(--font-display);font-weight:700;font-size:20px;letter-spacing:-.01em;color:#4A3713}
.deed-mlabel{font-size:9px;letter-spacing:.18em;font-weight:600;color:#8A7642;text-transform:uppercase;margin-top:20px}
.deed-mahalle{font-family:var(--font-display);font-weight:700;font-size:30px;line-height:1.1;color:#4A3713;margin-top:3px}
.deed-hier{font-size:11.5px;letter-spacing:.04em;color:#8A7642;margin-top:5px}
.deed-fields{margin-top:20px;padding:0 4px}
.deed-field{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:7px 0;border-top:1px solid rgba(122,111,87,.26)}
.deed-field span{font-size:10px;letter-spacing:.12em;font-weight:600;color:#8A7642;text-transform:uppercase}
.deed-field b{font-size:13.5px;font-weight:600;color:#4A3713}
.deed-field b.mono{font-family:var(--font-display);letter-spacing:.08em;color:#9A7726;font-size:12.5px}
.deed-footer{display:flex;align-items:center;justify-content:center;gap:7px;margin-top:16px;color:#9A7726}
.deed-logo{height:11px;width:auto}
.deed-footer i{width:3px;height:3px;border-radius:50%;background:#C8A042}
.deed-footer span{font-size:10.5px;letter-spacing:.05em;font-weight:600;color:#9A7726}

/* ── How it works ────────────────────────────────────────────────────────── */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.step{position:relative;padding:28px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--shadow-card)}
.step .num{font-family:var(--font-display);font-weight:700;font-size:15px;width:38px;height:38px;border-radius:50%;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,var(--primary),var(--violet));margin-bottom:16px}
.step h3{font-size:20px}
.step p{color:var(--mid);font-size:15px;margin:8px 0 0}

/* ── FAQ ─────────────────────────────────────────────────────────────────── */
.faq{max-width:800px;margin-inline:auto;display:grid;gap:12px}
.faq details{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-sm);padding:4px 22px;transition:box-shadow .2s,border-color .2s}
.faq details[open]{box-shadow:var(--shadow-card);border-color:var(--line-strong)}
.faq summary{list-style:none;cursor:pointer;padding:18px 0;display:flex;align-items:center;justify-content:space-between;gap:16px;font-family:var(--font-display);font-weight:600;font-size:17.5px;color:var(--ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary .chev{flex:none;width:22px;height:22px;color:var(--lo);transition:transform .25s var(--ease)}
.faq details[open] summary .chev{transform:rotate(180deg);color:var(--primary)}
.faq .faq-body{padding:0 0 20px;color:var(--mid);font-size:16px;line-height:1.65}
.faq .faq-body a{color:var(--primary);font-weight:600}

/* ── CTA band ────────────────────────────────────────────────────────────── */
.cta-band{text-align:center}
.cta-inner{position:relative;overflow:hidden;border-radius:var(--r-xl);padding:clamp(48px,8vw,84px) var(--gutter);background:radial-gradient(80% 120% at 20% 0%,rgba(255,34,150,.12),transparent 60%),radial-gradient(80% 120% at 100% 100%,rgba(139,92,246,.14),transparent 60%),var(--surface);border:1px solid var(--line);box-shadow:var(--shadow-card)}
.cta-inner h2{font-size:clamp(32px,5vw,58px);line-height:1.02}
.cta-grad{background:linear-gradient(115deg,var(--primary),var(--violet));-webkit-background-clip:text;background-clip:text;color:transparent}
.cta-inner p{color:var(--mid);font-size:clamp(16px,1.8vw,20px);margin:16px auto 0;max-width:50ch}

/* ── Footer ──────────────────────────────────────────────────────────────── */
.site-footer{border-top:1px solid var(--line);padding-block:48px;margin-top:clamp(60px,9vw,120px)}
.footer-grid{display:flex;flex-wrap:wrap;gap:28px 56px;justify-content:space-between}
.footer-brand{max-width:280px}
.footer-brand p{color:var(--lo);font-size:14.5px;margin:14px 0 0}
.footer-cols{display:flex;flex-wrap:wrap;gap:44px}
.footer-col h4{font-family:var(--font-display);font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);margin:0 0 14px}
.footer-col a{display:block;color:var(--mid);font-size:14.5px;padding:5px 0;transition:color .2s}
.footer-col a:hover{color:var(--primary)}
.footer-bottom{margin-top:36px;padding-top:22px;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;color:var(--faint);font-size:13.5px}

/* ── Scroll-reveal (JS-gated; no-JS shows everything) ────────────────────── */
.js .reveal{opacity:0;transform:translateY(14px);transition:opacity .5s var(--ease),transform .5s var(--ease)}
.reveal.in{opacity:1;transform:none}
/* Failsafe — set by the <head> script only if app.js never boots. Guarantees
   content is never left hidden below the hero. */
.js-failsafe .reveal{opacity:1 !important;transform:none !important}

/* ── Responsive ──────────────────────────────────────────────────────────── */
@media (max-width:920px){
  .hero{min-height:clamp(720px,100svh,860px)}
  .hero::before{background-position:62% center}
  .hero::after{background:
    linear-gradient(180deg,rgba(250,250,250,.70) 0%,rgba(250,250,250,.24) 46%,rgba(250,250,250,.80) 100%),
    linear-gradient(90deg,rgba(250,250,250,.28),rgba(250,250,250,.06) 70%)}
  .hero-grid{grid-template-columns:1fr;text-align:center}
  .hero-copy{max-width:42ch;margin-inline:auto;padding:clamp(28px,6vw,42px);border-radius:32px;background:rgba(255,255,255,.66);border:1px solid rgba(255,255,255,.62);box-shadow:0 18px 60px rgba(15,23,42,.10);backdrop-filter:blur(18px) saturate(140%);-webkit-backdrop-filter:blur(18px) saturate(140%)}
  .waitlist{margin-inline:auto}
  .hero-bg-focus{display:none}
  .row{grid-template-columns:1fr}
  .row.flip .row-art{order:0}
  .row-copy{text-align:center}
  .row-copy p{margin-inline:auto}
  .steps{grid-template-columns:1fr}
  .nav-links{display:none}
}
@media (max-width:560px){
  body{font-size:16px}
  .full{display:none}.short{display:inline}
  .waitlist-row{flex-direction:column}
  .waitlist .btn{width:100%}
}

/* ── Diyar Kartı — faithful port of card-mockup.html v11 / DiyarKart.tsx ────
   Namespaced (dk-) so it never collides with the page's own .stage/.card.
   The card floats, the outline foil flows, the reflection sweeps, and it tilts
   toward the cursor (hover handler in app.js) — exactly like the app. */
.cd-aura{position:absolute;inset:0;z-index:1;pointer-events:none}      /* treasure glow — behind the card */
.cd-confetti{position:absolute;inset:0;z-index:3;pointer-events:none}  /* confetti — IN FRONT of the card */
.dk-stage{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;perspective:1300px;z-index:2;pointer-events:none}
/* Reveal — the card springs in after the burst, holds, then loops with it. Own
   wrapper so its scale never fights the float (child) or the hover (grandchild). */
.dk-reveal{animation:dk-reveal 4.8s ease-out infinite;transform-style:preserve-3d}
/* Timeline (4.8s): 0–0.2s empty · burst at ~0.2s · card starts ~0.5s later
   (~0.7s) · settles ~1.5s · holds ~3s · fades ~4.3–4.7s · loop. */
@keyframes dk-reveal{
  0%{opacity:0;transform:scale(.45)}
  15%{opacity:0;transform:scale(.45)}   /* empty through burst + 0.5s delay (~0.7s) */
  22%{opacity:1}                          /* quick fade-in */
  25%{transform:scale(1.08)}              /* overshoot pop */
  29%{transform:scale(.98)}
  32%{transform:scale(1)}                 /* settled (~1.5s) */
  90%{opacity:1;transform:scale(1)}       /* hold ~3s */
  97%{opacity:0;transform:scale(.93)}     /* fade out */
  100%{opacity:0;transform:scale(.45)}
}
.dk-float{animation:dk-float var(--driftDur,6s) ease-in-out infinite var(--driftDelay,0s);transform-style:preserve-3d;position:relative}
@keyframes dk-float{0%,100%{transform:translateY(0) rotateY(-3.5deg)}50%{transform:translateY(-14px) rotateY(4deg)}}
.dk-float::after{content:"";position:absolute;left:14%;right:14%;bottom:-24px;height:22px;border-radius:50%;background:radial-gradient(ellipse,rgba(15,23,42,.22),transparent 70%);filter:blur(5px);z-index:-1;animation:dk-shadow var(--driftDur,6s) ease-in-out infinite var(--driftDelay,0s)}
@keyframes dk-shadow{0%,100%{transform:translateX(-5px) scale(1);opacity:.5}50%{transform:translateX(6px) scale(.82);opacity:.3}}
.dk-card{position:relative;width:238px;height:340px;border-radius:24px;padding:var(--fw,3.5px);background:var(--frame);background-size:240% 240%;background-position:8% 8%;animation:dk-frameFoil var(--driftDur,6s) ease-in-out infinite var(--driftDelay,0s);transform:rotateX(8deg) rotateY(-12deg) translateZ(0);transform-style:preserve-3d;transition:transform .18s ease-out;cursor:pointer;pointer-events:auto;box-shadow:0 24px 50px -18px rgba(15,23,42,.42),0 0 var(--glowsize,30px) -6px var(--glow)}
@keyframes dk-frameFoil{0%,100%{background-position:8% 14%}50%{background-position:92% 86%}}
.dk-face{position:relative;height:100%;border-radius:21px;overflow:hidden;padding:14px 14px 12px;background:var(--face);box-shadow:inset 0 1px 0 var(--innerHi,rgba(255,255,255,.5)),inset 0 0 0 .5px rgba(15,23,42,.05)}
.dk-face::before,.dk-face::after{content:"";position:absolute;inset:0;pointer-events:none;z-index:1}
.dk-content{position:relative;z-index:2;display:flex;flex-direction:column;height:100%}
.dk-topbar{display:flex;align-items:center;justify-content:space-between}
.dk-pill{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:9.5px;letter-spacing:1.3px;padding:4px 9px;border-radius:999px;color:var(--pillfg,#fff);background:var(--rpill)}
.dk-serial{font-family:'Space Grotesk',sans-serif;font-size:9px;letter-spacing:.8px;color:var(--faint)}
.dk-emblem{flex:1;display:flex;align-items:center;justify-content:center;position:relative}
.dk-leke{width:158px;height:130px;overflow:visible}
.dk-name{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:22px;letter-spacing:-.5px;line-height:1;text-align:center;color:var(--ink,#0F172A)}
.dk-name.long{font-size:16.5px}
.dk-path{text-align:center;color:var(--inklo,#64748B);font-size:10.5px;letter-spacing:.3px;margin-top:5px;min-height:13px}
.dk-footer{display:flex;align-items:center;justify-content:space-between;margin-top:10px;min-height:24px}
.dk-wordmark{position:absolute;bottom:7px;left:0;right:0;text-align:center;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:8px;letter-spacing:3px;color:var(--faint);z-index:2}
/* legendary holographic polish */
.dk-legcard .dk-face::before{background:radial-gradient(90px 120px at 22% 17%,rgba(255,103,185,.24),transparent 68%),radial-gradient(130px 110px at 78% 19%,rgba(80,210,255,.24),transparent 66%),radial-gradient(170px 190px at 54% 72%,rgba(139,92,246,.18),transparent 70%)}
.dk-legcard .dk-face::after{background:linear-gradient(118deg,transparent 0 18%,rgba(255,255,255,.2) 46%,transparent 78%),repeating-linear-gradient(118deg,rgba(126,220,255,.1) 0 1px,transparent 1px 14px);opacity:.24}
.dk-legcard .dk-pill{box-shadow:inset 0 1px 0 rgba(255,255,255,.48),0 8px 18px -10px rgba(139,92,246,.8)}
.dk-legcard .dk-leke{filter:drop-shadow(0 12px 18px rgba(102,91,220,.28))}
.dk-legcard .dk-name{color:#211A58;text-shadow:0 1px 0 rgba(255,255,255,.85),0 10px 22px rgba(112,84,214,.18)}
.dk-legcard .dk-path{color:#605987}
/* reflection — wide soft gloss, off-card at both ends → seamless loop */
.dk-sheen{position:absolute;inset:0;border-radius:24px;overflow:hidden;z-index:5;pointer-events:none}
.dk-sheen::before{content:"";position:absolute;top:-35%;height:170%;width:var(--bandW,62%);left:0;background:var(--band);opacity:var(--sheenOpacity,.38);transform:translateX(-320%) skewX(-12deg);animation:dk-sweep var(--sweepDur,4.6s) ease-in-out infinite;will-change:transform}
@keyframes dk-sweep{0%,12%{transform:translateX(-320%) skewX(-12deg)}88%,100%{transform:translateX(500%) skewX(-12deg)}}

/* ── 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}
  .blob{opacity:.5}
  .reveal{opacity:1;transform:none}
}
