/* dckp Studio — shared landing CSS for index.html + 404.html.
 * --violet-* tokens are the brand accents. */

:root{
  --bg-0:#0a0b14;
  --bg-1:#0d0f1c;
  --bg-2:#11132c;
  --panel:#141632;
  --panel-2:#181a3a;
  --line:rgba(167,139,250,0.16);
  --line-strong:rgba(167,139,250,0.26);
  --ink:#f1f1fa;
  --ink-2:#c4c5d4;
  --ink-3:#7a7d94;
  --ink-4:#4a4d68;
  --violet-50:#f5f3ff;
  --violet-100:#ede9fe;
  --violet-200:#c4b5fd;
  --violet-300:#a78bfa;
  --violet-400:#8b5cf6;
  --violet-500:#8b5cf6;
  --violet-600:#7c3aed;
  --violet-700:#6d28d9;
  --violet-800:#5b21b6;
  --radius-lg:18px;
  --radius-md:12px;
  --radius-sm:8px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg-0);color:var(--ink);font-family:"Inter",ui-sans-serif,system-ui,-apple-system,sans-serif;font-weight:400;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-feature-settings:"ss01","cv11","ss03"}
html{scroll-behavior:smooth}

/* premium type helpers */
.h-display{font-family:"Inter",ui-sans-serif,system-ui,sans-serif;font-weight:500}
body{
  background:
    radial-gradient(1200px 700px at 82% -10%, rgba(139,92,246,0.10), transparent 60%),
    radial-gradient(900px 600px at -10% 18%, rgba(124,58,237,0.07), transparent 60%),
    radial-gradient(1100px 800px at 100% 60%, rgba(91,33,182,0.10), transparent 60%),
    linear-gradient(180deg, #0a0b14 0%, #0a0b14 50%, #0a0b14 100%);
  min-height:100vh;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* Subtle grain overlay */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;mix-blend-mode:overlay;opacity:.22;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 0.35 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}
/* ============ CONTACT MODAL ============ */
.modal-root{
  position:fixed;inset:0;z-index:200;
  display:none;
  align-items:center;justify-content:center;
  padding:20px;
}
.modal-root.open{display:flex}
.modal-backdrop{
  position:absolute;inset:0;
  background:radial-gradient(60% 60% at 50% 30%, rgba(124,58,237,0.18), rgba(10,11,20,0.85) 70%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
          backdrop-filter:blur(14px) saturate(140%);
  opacity:0;transition:opacity .35s ease;
}
.modal-root.open .modal-backdrop{opacity:1}

.modal{
  position:relative;z-index:1;
  width:min(560px, 100%);
  max-height:min(92vh, 820px);
  overflow:auto;
  border-radius:22px;
  border:1px solid rgba(167,139,250,0.22);
  background:
    radial-gradient(70% 50% at 20% 0%, rgba(139,92,246,0.18), transparent 60%),
    radial-gradient(60% 50% at 100% 0%, rgba(109,40,217,0.12), transparent 60%),
    linear-gradient(180deg, #141632 0%, #0f1124 100%);
  box-shadow:
    0 40px 100px -20px rgba(0,0,0,0.7),
    0 0 0 1px rgba(167,139,250,0.08),
    inset 0 1px 0 rgba(255,255,255,0.05);
  transform:translateY(18px) scale(0.98);
  opacity:0;transition:transform .45s cubic-bezier(.2,.8,.2,1), opacity .35s ease;
}
.modal-root.open .modal{transform:translateY(0) scale(1);opacity:1}
.modal::before{
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background-image:
    linear-gradient(rgba(167,139,250,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(167,139,250,0.04) 1px, transparent 1px);
  background-size:40px 40px;
  -webkit-mask-image:radial-gradient(60% 80% at 50% 0%, #000, transparent 80%);
          mask-image:radial-gradient(60% 80% at 50% 0%, #000, transparent 80%);
}
.modal-head{
  padding:32px 36px 18px;position:relative;
  border-bottom:1px solid rgba(167,139,250,0.10);
}
.modal-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;color:#a78bfa;font-weight:500;margin-bottom:14px;
}
.modal-eyebrow .ping{
  width:7px;height:7px;border-radius:50%;background:#a78bfa;
  box-shadow:0 0 0 4px rgba(167,139,250,0.18);
  animation:mp 2.2s ease-in-out infinite;
}
@keyframes mp{0%,100%{box-shadow:0 0 0 4px rgba(167,139,250,0.18)}50%{box-shadow:0 0 0 8px rgba(167,139,250,0.06)}}
.modal h3{
  margin:0 0 10px;font-family:"Inter",sans-serif;font-weight:700;
  font-size:28px;line-height:1.1;letter-spacing:-0.03em;color:var(--ink);
}
.modal h3 .accent{
  background:linear-gradient(135deg, #c4b5fd 0%, #a78bfa 50%, #8b5cf6 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.modal-sub{margin:0;color:var(--ink-3);font-size:14px;line-height:1.55;max-width:440px}
.modal-close{
  position:absolute;top:20px;right:20px;
  width:36px;height:36px;border-radius:10px;
  background:rgba(255,255,255,0.03);
  border:1px solid rgba(167,139,250,0.14);
  color:var(--ink-2);cursor:pointer;display:grid;place-items:center;
  transition:all .2s;
}
.modal-close:hover{background:rgba(167,139,250,0.10);color:#fff;border-color:rgba(167,139,250,0.32)}
.modal-close svg{width:14px;height:14px}

.modal-body{padding:24px 36px 8px;position:relative;z-index:1}
.field{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field label{
  font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.20em;
  text-transform:uppercase;color:var(--ink-3);font-weight:500;
}
.field input, .field select, .field textarea{
  width:100%;
  background:rgba(10,11,20,0.5);
  border:1px solid rgba(167,139,250,0.14);
  border-radius:10px;
  padding:12px 14px;
  font-family:"Inter",sans-serif;font-size:14px;color:var(--ink);
  outline:none;transition:all .2s;
  font-weight:400;
}
.field textarea{resize:vertical;min-height:96px;line-height:1.5}
.field input::placeholder, .field textarea::placeholder{color:var(--ink-4)}
.field input:focus, .field select:focus, .field textarea:focus{
  border-color:rgba(167,139,250,0.5);
  background:rgba(20,16,40,0.6);
  box-shadow:0 0 0 4px rgba(139,92,246,0.10);
}
.field select{appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'><path d='M1 1l5 5 5-5' stroke='%23a78bfa' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat:no-repeat;background-position:right 14px center;background-color:rgba(10,11,20,0.5);
  padding-right:36px;cursor:pointer;
}
.field select option{background:#141632;color:var(--ink)}

.budget-chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{
  display:inline-flex;align-items:center;gap:6px;
  padding:9px 14px;border-radius:999px;
  background:rgba(10,11,20,0.5);
  border:1px solid rgba(167,139,250,0.14);
  color:var(--ink-2);font-size:13px;font-weight:500;cursor:pointer;
  transition:all .18s;
  user-select:none;
}
.chip:hover{border-color:rgba(167,139,250,0.32);color:#fff}
.chip.active{
  background:linear-gradient(180deg, rgba(139,92,246,0.20), rgba(124,58,237,0.10));
  border-color:rgba(167,139,250,0.55);
  color:#fff;
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.05), 0 0 0 1px rgba(139,92,246,0.18);
}

.modal-foot{
  padding:14px 36px 32px;
  display:flex;flex-direction:column;gap:12px;
  position:relative;z-index:1;
}
.modal-submit{
  width:100%;display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:16px 22px;border:none;cursor:pointer;
  font-family:"Inter",sans-serif;font-weight:600;font-size:15px;color:#fff;
  border-radius:12px;
  background:linear-gradient(180deg, #8b5cf6 0%, #7c3aed 100%);
  border:1px solid rgba(196,181,253,0.4);
  box-shadow:
    0 0 0 1px rgba(139,92,246,0.25),
    0 14px 36px -10px rgba(124,58,237,0.6),
    inset 0 1px 0 rgba(255,255,255,0.30);
  transition:transform .15s, box-shadow .2s;
}
.modal-submit:hover{transform:translateY(-1px);box-shadow:0 0 0 1px rgba(139,92,246,0.4),0 18px 44px -10px rgba(124,58,237,0.7),inset 0 1px 0 rgba(255,255,255,0.4)}
.modal-submit:disabled{opacity:.7;cursor:wait;transform:none}
.modal-submit .arr{transition:transform .2s}
.modal-submit:hover .arr{transform:translate(2px,-2px)}
.modal-foot .meta{
  display:flex;justify-content:center;gap:18px;color:var(--ink-4);
  font-size:12px;font-family:"JetBrains Mono",monospace;letter-spacing:.04em;
}
.modal-foot .meta span{display:inline-flex;align-items:center;gap:6px}
.modal-foot .meta .dot{width:6px;height:6px;border-radius:50%;background:#a78bfa;box-shadow:0 0 8px #a78bfa}

/* Success state */
.modal-success{
  display:none;padding:48px 36px 56px;text-align:center;position:relative;z-index:1;
}
.modal-root.success .modal-body, .modal-root.success .modal-foot{display:none}
.modal-root.success .modal-success{display:block}
.modal-success .ic{
  width:64px;height:64px;border-radius:50%;margin:0 auto 18px;display:grid;place-items:center;
  background:radial-gradient(closest-side, rgba(139,92,246,0.30), transparent 70%);
  color:#a78bfa;
}
.modal-success h4{margin:0 0 8px;font-size:22px;font-weight:700;letter-spacing:-0.02em;color:var(--ink)}
.modal-success p{margin:0;color:var(--ink-3);font-size:14px;line-height:1.55}

@media (max-width:560px){
  .modal-head{padding:26px 22px 16px}
  .modal-body{padding:18px 22px 6px}
  .modal-foot{padding:12px 22px 24px}
  .field-row{grid-template-columns:1fr}
  .modal h3{font-size:22px}
}

/* Top accent vignette */
.bg-vignette{position:fixed;inset:0;pointer-events:none;z-index:0}
.bg-vignette::before{
  content:"";position:absolute;inset:auto -10% -50% -10%;height:80vh;
  background:radial-gradient(60% 60% at 50% 0%, rgba(139,92,246,0.12), transparent 70%);
  filter:blur(20px);
}

.wrap{max-width:1280px;margin:0 auto;padding:0 40px;position:relative;z-index:2}

/* ---------- Eyebrow / mono labels ---------- */
.eyebrow{
  font-family:"JetBrains Mono",ui-monospace,monospace;
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--violet-300);font-weight:500;
  display:inline-flex;align-items:center;gap:10px;
}
/* Symmetric dashes around any .eyebrow; .no-line kills them. */
.eyebrow::before,
.eyebrow::after{
  content:"";width:18px;height:1px;
}
.eyebrow::before{background:linear-gradient(90deg, transparent, var(--violet-400))}
.eyebrow::after {background:linear-gradient(90deg, var(--violet-400), transparent)}
.eyebrow.no-line::before,
.eyebrow.no-line::after{display:none}

/* ---------- NAV ---------- */
.nav{
  position:relative;z-index:5;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 0;
}
.brand{display:flex;align-items:center}
.brand-logo{width:168px;height:auto;display:block}
@media (max-width:600px){.brand-logo{width:120px}}

.nav-links{
  display:flex;gap:2px;
  padding:5px;
  border-radius:999px;
  background:rgba(255,255,255,0.018);
  border:1px solid var(--line);
  -webkit-backdrop-filter:blur(16px) saturate(160%);
  backdrop-filter:blur(16px) saturate(160%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.025);
}
.nav-links a{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 16px;border-radius:999px;
  color:var(--ink-3);font-size:13px;font-weight:500;letter-spacing:0.005em;
  border:1px solid transparent;
  background:transparent;
  transition:color .2s ease, background .2s ease, border-color .2s ease;
  position:relative;
}
.nav-links a:hover{
  color:var(--ink);
  background:rgba(167,139,250,0.04);
}
.nav-links a.active{
  color:var(--violet-200);
  background:linear-gradient(180deg, rgba(167,139,250,0.08), rgba(167,139,250,0.03));
  border-color:var(--line-strong);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.04);
}

.cta-ghost{
  display:inline-flex;align-items:center;gap:10px;
  padding:11px 18px;border-radius:999px;
  border:1px solid var(--line-strong);
  background:linear-gradient(180deg, rgba(167,139,250,0.06), rgba(167,139,250,0.02));
  color:var(--ink);font-size:14px;font-weight:500;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
  transition:all .2s;
}
.cta-ghost:hover{border-color:var(--violet-400);color:var(--violet-200)}
.cta-ghost .arr{display:inline-block;transition:transform .2s}
.cta-ghost:hover .arr{transform:translate(2px,-2px)}

/* ---------- MORPH CTA ---------- */
/* invisible slots that the floating CTA snaps to */
.cta-slot{display:inline-block;visibility:hidden;border-radius:999px}
.cta-slot.top{width:140px;height:44px}
.cta-slot.bottom{width:100%;height:60px;display:block}

.morph-cta{
  position:fixed;left:0;top:0;
  display:flex;align-items:center;justify-content:center;gap:10px;
  font-family:"Inter",sans-serif;font-weight:600;
  white-space:nowrap;cursor:pointer;
  z-index:90;will-change:transform,width,height;
  color:#ffffff;
  background:linear-gradient(180deg, #8b5cf6 0%, #7c3aed 100%);
  border:1px solid rgba(196,181,253,0.4);
  border-radius:999px;
  box-shadow:
    0 0 0 1px rgba(139,92,246,0.25),
    0 14px 40px -10px rgba(124,58,237,0.55),
    inset 0 1px 0 rgba(255,255,255,0.35);
  font-size:14px;
  transition:
    background .45s ease,
    color .45s ease,
    border-color .45s ease,
    border-radius .55s cubic-bezier(.65,0,.35,1),
    box-shadow .45s ease,
    font-size .35s ease,
    padding .55s cubic-bezier(.65,0,.35,1);
  padding:0 22px;
  text-decoration:none;
  pointer-events:auto;
}
.morph-cta .ic-arr{width:14px;height:14px;transition:transform .25s}
.morph-cta:hover .ic-arr{transform:translate(2px,-2px)}

/* TOP state: solid purple pill (matches float/cta) */
.morph-cta[data-state="top"]{
  background:linear-gradient(180deg, #8b5cf6 0%, #7c3aed 100%);
  color:#ffffff;
  border:1px solid rgba(196,181,253,0.4);
  box-shadow:
    0 0 0 1px rgba(139,92,246,0.25),
    0 8px 24px -8px rgba(124,58,237,0.55),
    inset 0 1px 0 rgba(255,255,255,0.30);
  font-weight:600;
  font-size:14px;
  padding:0 20px;
}
/* FLOAT state: solid violet pill */
.morph-cta[data-state="float"]{
  border-radius:999px;
  padding:0 22px;
}
/* CTA state: large block primary */
.morph-cta[data-state="cta"]{
  border-radius:14px;
  font-size:15px;
  padding:0 28px;
  box-shadow:
    0 0 0 1px rgba(139,92,246,0.30),
    0 22px 60px -12px rgba(124,58,237,0.65),
    inset 0 1px 0 rgba(255,255,255,0.40);
}

/* the cross-fading labels (so text can morph too) */
.morph-cta .m-label{position:relative;display:inline-flex;align-items:center;gap:10px}
.morph-cta .m-text{display:inline-block;transition:opacity .25s ease}
.morph-cta .m-text.fade{opacity:0}

/* ---------- HERO ---------- */
.hero{
  padding:64px 0 90px;
  display:flex;flex-direction:column;align-items:center;text-align:center;
  gap:72px;position:relative;
}
.hero-copy{
  display:flex;flex-direction:column;align-items:center;
  width:100%;max-width:820px;
}
.hero-eyebrow{margin-bottom:26px}
.hero h1{
  font-family:"Inter",ui-sans-serif,sans-serif;
  font-weight:700;
  font-size:72px;
  line-height:1.08; /* >1.0 so descenders (g, p, y) aren't clipped */
  letter-spacing:-0.04em;
  margin:0 0 28px;
  color:var(--ink);
  text-wrap:balance;
}
.hero h1 .accent{
  display:block;
  font-family:"Inter",sans-serif;
  font-style:normal;font-weight:700;
  font-size:72px;line-height:1.08;
  background:linear-gradient(135deg, #c4b5fd 0%, #a78bfa 45%, #8b5cf6 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  letter-spacing:-0.04em;margin-top:6px;
  padding-bottom:0.08em; /* keep descenders inside gradient-clip box */
}
.hero p.lede{
  color:var(--ink-2);font-size:16.5px;line-height:1.65;
  max-width:560px;margin:0 auto 36px;
}

.hero-ctas{display:flex;gap:14px;margin-bottom:54px;flex-wrap:wrap;justify-content:center}
.btn-primary{
  position:relative;display:inline-flex;align-items:center;gap:12px;
  padding:14px 22px;border-radius:12px;
  background:linear-gradient(180deg, #8b5cf6 0%, #7c3aed 100%);
  color:#ffffff;font-weight:600;font-size:14.5px;
  border:1px solid rgba(196,181,253,0.4);
  box-shadow:
    0 0 0 1px rgba(139,92,246,0.25),
    0 10px 30px -10px rgba(124,58,237,0.55),
    inset 0 1px 0 rgba(255,255,255,0.35);
  transition:transform .2s, box-shadow .2s;
}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 0 0 1px rgba(139,92,246,0.4),0 14px 36px -10px rgba(124,58,237,0.7),inset 0 1px 0 rgba(255,255,255,0.4)}
.btn-primary .arr{transition:transform .2s}
.btn-primary:hover .arr{transform:translate(2px,-2px)}

.btn-secondary{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 22px;border-radius:12px;
  background:rgba(255,255,255,0.02);
  border:1px solid var(--line-strong);
  color:var(--ink);font-weight:500;font-size:14.5px;
  transition:all .2s;
}
.btn-secondary:hover{border-color:var(--violet-300);background:rgba(167,139,250,0.05)}

.feature-row{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:680px;margin:0 auto;text-align:left}
.feature-row .feat{display:flex;gap:12px;align-items:flex-start}
.feature-row .feat .ic{
  flex:none;width:32px;height:32px;border-radius:8px;display:grid;place-items:center;
  background:linear-gradient(180deg, rgba(167,139,250,0.12), rgba(167,139,250,0.04));
  border:1px solid var(--line-strong);
  color:var(--violet-300);
}
.feature-row .feat .ft{font-size:13.5px;font-weight:600;color:var(--ink);margin:0 0 3px;letter-spacing:-0.01em}
.feature-row .feat .fd{font-size:12px;color:var(--ink-3);line-height:1.45;margin:0}

/* ---------- HERO PRODUCT MOCK ---------- */
.product-stage{position:relative;height:560px;width:100%;max-width:820px;margin:0 auto}
.glow{
  position:absolute;inset:auto;width:420px;height:420px;border-radius:50%;
  right:-40px;top:30px;
  background:radial-gradient(closest-side, rgba(139,92,246,0.30), rgba(139,92,246,0) 70%);
  filter:blur(8px);z-index:0;pointer-events:none;
}
/* glow.b: kept inside stage box — wider bleed washed out card borders below. */
.glow.b{right:-30px;top:240px;width:260px;height:260px;background:radial-gradient(closest-side, rgba(109,40,217,0.30), transparent 70%)}

/* Dashboard mock */
.mock-dashboard{
  position:absolute;left:0;top:30px;width:640px;height:430px;
  background:linear-gradient(180deg, #10122a 0%, #10122a 100%);
  border:1px solid var(--line-strong);
  border-radius:16px;
  box-shadow:
    0 30px 80px -20px rgba(0,0,0,0.6),
    0 0 0 1px rgba(167,139,250,0.05),
    inset 0 1px 0 rgba(255,255,255,0.04);
  overflow:hidden;
  transform:perspective(1800px) rotateY(-6deg) rotateX(2deg);
}
.mock-dashboard::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg, rgba(167,139,250,0.06), transparent 40%);
  pointer-events:none;
}
.dash-grid{display:grid;grid-template-columns:160px 1fr;height:100%}
.dash-side{
  border-right:1px solid var(--line);
  padding:14px 10px;background:rgba(4,18,16,0.6);
}
.dash-logo{display:flex;align-items:center;gap:8px;padding:6px 8px;margin-bottom:18px}
.dash-logo-d{width:22px;height:22px;border-radius:6px;background:linear-gradient(135deg,#a78bfa,#7c3aed);display:grid;place-items:center;color:#ffffff;font-weight:700;font-size:12px}
.dash-side .label{font-family:"JetBrains Mono",monospace;font-size:8.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-4);padding:0 8px;margin:14px 0 6px}
.dash-nav-item{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:6px;font-size:11.5px;color:var(--ink-3);margin-bottom:2px}
.dash-nav-item.active{background:linear-gradient(180deg, rgba(167,139,250,0.10), rgba(167,139,250,0.04));color:var(--violet-200);border:1px solid var(--line-strong)}
.dash-nav-item .nd{width:12px;height:12px;display:grid;place-items:center;color:currentColor}

.dash-main{padding:14px 16px;overflow:hidden;position:relative}
.dash-topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
/* Mock dashboard headings are non-semantic — use the *-title div in markup. */
.dash-topbar-title,.dash-topbar h4{margin:0;font-size:13px;font-weight:500;color:var(--ink)}
.dash-pill{display:flex;gap:6px;align-items:center;font-family:"JetBrains Mono",monospace;font-size:9px;color:var(--ink-3);background:rgba(167,139,250,0.06);border:1px solid var(--line);padding:3px 8px;border-radius:999px}
.dash-pill .dot{width:6px;height:6px;border-radius:50%;background:var(--violet-400);box-shadow:0 0 8px var(--violet-400)}
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:12px}
.stat-card{background:rgba(11,28,25,0.5);border:1px solid var(--line);border-radius:8px;padding:10px}
.stat-card .lbl{font-size:9.5px;color:var(--ink-4);letter-spacing:.04em;margin-bottom:6px}
.stat-card .val{font-size:14px;color:var(--ink);font-weight:600;letter-spacing:-0.02em}
.stat-card .delta{font-size:9.5px;color:var(--violet-300);margin-top:3px;font-family:"JetBrains Mono",monospace}
.stat-card .delta.neg{color:#f87171}

.chart-card{background:rgba(11,28,25,0.4);border:1px solid var(--line);border-radius:8px;padding:10px;margin-bottom:8px}
.chart-card-title,.chart-card h5{margin:0 0 6px;font-size:10.5px;font-weight:500;color:var(--ink-2)}
.chart-card .y{display:flex;gap:6px;align-items:baseline}
.chart-card .y .big{font-size:16px;font-weight:600;color:var(--ink);letter-spacing:-0.02em}
.chart-card .y .when{font-family:"JetBrains Mono",monospace;font-size:9px;color:var(--ink-4)}

.bottom-row{display:grid;grid-template-columns:1.3fr 1fr;gap:8px}
.txn-card{background:rgba(11,28,25,0.4);border:1px solid var(--line);border-radius:8px;padding:10px}
.txn-card-title,.txn-card h5{margin:0 0 6px;font-size:10.5px;color:var(--ink-2);font-weight:500}
.txn{display:flex;justify-content:space-between;align-items:center;padding:4px 0;border-bottom:1px dashed rgba(167,139,250,0.06);font-size:10px}
.txn:last-child{border-bottom:0}
.txn .lh{display:flex;gap:6px;align-items:center;color:var(--ink-3)}
.txn .lh .ico{width:14px;height:14px;border-radius:4px;background:rgba(167,139,250,0.10);display:grid;place-items:center;color:var(--violet-300);font-size:8px}
.txn .v{font-family:"JetBrains Mono",monospace;color:var(--violet-300);font-size:10px}
.txn .v.neg{color:#f87171}

/* Phone mock */
.mock-phone{
  position:absolute;right:80px;bottom:0;width:240px;height:480px;
  background:linear-gradient(180deg, #141632, #0d0f1c);
  border:1px solid var(--line-strong);
  border-radius:34px;
  padding:10px;
  box-shadow:
    0 40px 100px -20px rgba(0,0,0,0.7),
    0 0 0 1px rgba(167,139,250,0.06),
    inset 0 1px 0 rgba(255,255,255,0.05);
  transform:perspective(1800px) rotateY(-9deg) rotateX(2deg);
  z-index:3;
}
.phone-screen{
  width:100%;height:100%;border-radius:26px;
  background:linear-gradient(180deg, #10122a, #0a0b14);
  overflow:hidden;position:relative;
  border:1px solid rgba(167,139,250,0.06);
}
.phone-notch{position:absolute;left:50%;top:8px;transform:translateX(-50%);width:78px;height:18px;background:#000;border-radius:12px;z-index:3}
.phone-statusbar{display:flex;justify-content:space-between;padding:7px 16px 0;font-family:"JetBrains Mono",monospace;font-size:9px;color:var(--ink-2);position:relative;z-index:2}
.phone-body{padding:34px 14px 14px;height:100%;display:flex;flex-direction:column;gap:10px}
.wallet-card{
  background:linear-gradient(135deg, rgba(167,139,250,0.10), rgba(109,40,217,0.05));
  border:1px solid var(--line-strong);
  border-radius:14px;padding:12px;
  position:relative;overflow:hidden;
}
.wallet-card::after{
  content:"";position:absolute;right:-30px;top:-30px;width:80px;height:80px;border-radius:50%;
  background:radial-gradient(closest-side, rgba(167,139,250,0.25), transparent 70%);
}
.wallet-card .lbl{font-size:10px;color:var(--ink-3);margin-bottom:4px}
.wallet-card .amt{font-size:24px;font-weight:600;color:var(--ink);letter-spacing:-0.02em}
.wallet-card .amt .small{font-size:14px;color:var(--ink-3)}
.wallet-tabs{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:10px;position:relative;z-index:1}
.wallet-tab{padding:7px;border-radius:8px;text-align:center;font-size:10.5px;font-weight:500}
.wallet-tab.active{background:linear-gradient(180deg, var(--violet-400), var(--violet-600));color:#ffffff;box-shadow:0 4px 14px -2px rgba(124,58,237,0.5)}
.wallet-tab.alt{background:rgba(255,255,255,0.04);border:1px solid var(--line);color:var(--ink-2)}

.quick-actions{margin-top:4px}
.quick-actions-title,.quick-actions h5{font-size:11px;color:var(--ink-2);font-weight:500;margin:0 0 6px}
.qa-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}
.qa-tile{background:rgba(11,28,25,0.5);border:1px solid var(--line);border-radius:8px;padding:8px 4px;display:flex;flex-direction:column;align-items:center;gap:4px}
.qa-tile .ic{width:18px;height:18px;display:grid;place-items:center;color:var(--violet-300)}
.qa-tile .nm{font-size:8.5px;color:var(--ink-3)}

.recent{margin-top:4px;flex:1}
.recent-head{display:flex;justify-content:space-between;align-items:center}
.recent-head-title,.recent-head h5{font-size:10.5px;color:var(--ink-2);font-weight:500;margin:0 0 6px}
.recent-head .view{font-size:9px;color:var(--violet-300);font-family:"JetBrains Mono",monospace}
.recent-item{display:flex;justify-content:space-between;align-items:center;padding:5px 0;font-size:9.5px;border-bottom:1px dashed rgba(167,139,250,0.06)}
.recent-item .lh{display:flex;gap:6px;align-items:center;color:var(--ink-3)}
.recent-item .lh .ico{width:16px;height:16px;border-radius:5px;background:rgba(167,139,250,0.10);display:grid;place-items:center;color:var(--violet-300);font-size:8px}
.recent-item .when{font-size:8px;color:var(--ink-4);margin-top:1px;display:block}
.recent-item .v{font-family:"JetBrains Mono",monospace;color:var(--violet-300)}

/* ---------- TRUST LOGOS ---------- */
.trust{
  padding:48px 0 60px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  position:relative;
}
.trust-label{text-align:center;margin-bottom:34px;color:var(--ink-3);font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.32em}
.trust-row{display:grid;grid-template-columns:repeat(5,1fr);align-items:center;gap:20px}
.trust-logo{display:flex;align-items:center;justify-content:center;gap:10px;color:var(--ink-3);opacity:.75;filter:saturate(.5);transition:all .25s}
.trust-logo:hover{opacity:1;filter:saturate(1);color:var(--violet-200)}
.trust-logo .nm{font-weight:700;font-size:18px;letter-spacing:.06em}

/* ---------- SERVICES ---------- */
.section{padding:90px 0;position:relative}
/* All section headers centered; .left wraps eyebrow+h2, .right an optional chip. */
.section-head{
  display:flex;flex-direction:column;align-items:center;
  text-align:center;
  max-width:760px;margin:0 auto 42px;gap:14px;
}
.section-head .left{display:flex;flex-direction:column;align-items:center}
.section-head .left .eyebrow{margin-bottom:18px}
.section-head h2{
  margin:0;font-size:48px;line-height:1.04;letter-spacing:-0.035em;
  font-family:"Inter",sans-serif;
  font-weight:700;color:var(--ink);max-width:660px;text-wrap:balance;
}
.section-head h2 em{font-family:"Inter",sans-serif;font-style:normal;font-weight:700;color:var(--violet-300);font-size:1.1em;letter-spacing:-0.01em}
.section-head .right{padding-top:4px}
.link-more{display:inline-flex;align-items:center;gap:10px;font-size:14px;color:var(--violet-300);font-weight:500;border-bottom:1px solid rgba(167,139,250,0.3);padding-bottom:4px;transition:all .2s}
.link-more:hover{border-color:var(--violet-300);gap:14px}

.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.svc{
  position:relative;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:24px 22px 22px;background:
    linear-gradient(180deg, rgba(11,28,25,0.55), rgba(8,24,20,0.30));
  overflow:hidden;transition:all .25s;
  min-height:202px;
}
.svc::before{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background:radial-gradient(120% 80% at 0% 0%, rgba(167,139,250,0.08), transparent 50%);
  opacity:0;transition:opacity .25s;pointer-events:none;
}
.svc:hover::before{opacity:1}
.svc:hover{border-color:var(--line-strong);transform:translateY(-2px)}
.svc .ic{
  width:44px;height:44px;border-radius:12px;
  background:linear-gradient(135deg, rgba(167,139,250,0.18), rgba(109,40,217,0.06));
  border:1px solid var(--line-strong);
  display:grid;place-items:center;color:var(--violet-300);
  margin-bottom:24px;position:relative;
}
.svc .ic::after{
  content:"";position:absolute;inset:-1px;border-radius:inherit;
  background:linear-gradient(135deg, rgba(167,139,250,0.3), transparent 50%);
  -webkit-mask:linear-gradient(#000,#000) content-box,linear-gradient(#000,#000);mask-composite:exclude;-webkit-mask-composite:xor;
  padding:1px;pointer-events:none;
}
.svc h3{margin:0 0 8px;font-size:16.5px;font-weight:600;letter-spacing:-0.01em;color:var(--ink)}
.svc p{margin:0;font-size:13.5px;line-height:1.55;color:var(--ink-3)}
.svc .num{
  position:absolute;top:18px;right:22px;
  font-family:"Inter",sans-serif;font-style:italic;
  font-size:14px;color:var(--ink-4);
}

/* ---------- WHY DCKP ---------- */
.why{display:grid;grid-template-columns:1fr 1.25fr;gap:60px;align-items:center}
.why-left .eyebrow{margin-bottom:18px}
.why-left h2{margin:0 0 22px;font-size:44px;line-height:1.06;letter-spacing:-0.04em;font-weight:500;color:var(--ink);font-family:"Inter",sans-serif;text-wrap:balance}
.why-left h2 em{font-family:"Inter",sans-serif;font-style:normal;font-weight:700;color:var(--violet-300)}
.why-left p{margin:0 0 32px;color:var(--ink-2);font-size:15px;line-height:1.7;max-width:480px}

.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;background:linear-gradient(180deg, rgba(11,28,25,0.6), rgba(8,24,20,0.30))}
.stat{padding:28px 22px;position:relative;border-right:1px solid var(--line)}
.stat:last-child{border-right:0}
.stat .ic{
  width:36px;height:36px;border-radius:10px;
  background:linear-gradient(135deg, rgba(167,139,250,0.18), rgba(109,40,217,0.06));
  border:1px solid var(--line-strong);
  display:grid;place-items:center;color:var(--violet-300);
  margin-bottom:18px;
}
.stat .big{
  font-family:"Inter",sans-serif;font-style:normal;font-weight:700;
  font-size:54px;line-height:1;color:var(--ink);letter-spacing:-0.02em;
  background:linear-gradient(180deg, #f5f3ff 0%, #a78bfa 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.stat .lbl{font-size:12px;color:var(--ink-3);margin-top:10px;line-height:1.45;max-width:120px}

/* ---------- SELECTED WORK ---------- */
.work-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.work-card{
  position:relative;border:1px solid var(--line);border-radius:var(--radius-lg);
  background:linear-gradient(180deg, rgba(11,28,25,0.55), rgba(8,24,20,0.30));
  overflow:hidden;transition:all .3s;
  display:flex;flex-direction:column;
}
.work-card::before{
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:radial-gradient(120% 80% at 0% 0%, rgba(167,139,250,0.10), transparent 55%);
  opacity:0;transition:opacity .3s;
}
.work-card:hover::before{opacity:1}
.work-card:hover{border-color:var(--line-strong);transform:translateY(-3px);box-shadow:0 30px 60px -30px rgba(0,0,0,0.5)}
.work-thumb{
  position:relative;height:280px;overflow:hidden;
  border-bottom:1px solid var(--line);
  background:linear-gradient(135deg, #141632 0%, #10122a 100%);
}
.work-thumb svg{display:block;width:100%;height:100%}
.work-thumb::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(80% 50% at 50% 100%, rgba(2,12,10,0.6), transparent 70%);
  pointer-events:none;
}
.work-body{padding:26px 28px 28px;display:flex;flex-direction:column;gap:14px}
.work-tags{display:flex;gap:8px;flex-wrap:wrap}
.work-tag{
  font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.16em;text-transform:uppercase;
  padding:5px 10px;border-radius:999px;
  background:rgba(167,139,250,0.06);border:1px solid var(--line);color:var(--violet-200);
}
.work-title{margin:0;font-size:26px;font-weight:500;letter-spacing:-0.03em;color:var(--ink);line-height:1.1;font-family:"Inter",sans-serif;text-wrap:balance}
.work-title em{font-family:"Inter",sans-serif;font-style:normal;font-weight:700;color:var(--violet-300)}
.work-desc{margin:0;font-size:14px;line-height:1.6;color:var(--ink-3);max-width:520px}
.work-foot{
  display:flex;justify-content:space-between;align-items:flex-end;gap:20px;
  margin-top:8px;padding-top:18px;border-top:1px dashed var(--line);
}
.work-metrics{display:flex;gap:22px}
.work-metric .m-num{
  font-family:"Inter",sans-serif;font-style:normal;font-weight:700;
  font-size:28px;line-height:1;letter-spacing:-0.02em;
  background:linear-gradient(180deg, #f5f3ff 0%, #a78bfa 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.work-metric .m-num .sup{font-size:.55em;vertical-align:super;color:var(--violet-300);font-style:normal}
.work-metric .m-lbl{font-size:11px;color:var(--ink-3);margin-top:6px;letter-spacing:.02em}
.work-link{
  display:inline-flex;align-items:center;gap:8px;
  font-size:13px;color:var(--violet-300);font-weight:500;white-space:nowrap;
  border-bottom:1px solid rgba(167,139,250,0.25);padding-bottom:3px;transition:all .2s;
}
.work-link:hover{gap:12px;border-color:var(--violet-300)}

/* ---------- FOOTER CTA  + footer ---------- */
.cta-band{
  margin:30px 0 0;
  padding:70px 60px;
  border:1px solid var(--line-strong);
  border-radius:24px;
  background:
    radial-gradient(60% 100% at 80% 50%, rgba(139,92,246,0.16), transparent 60%),
    radial-gradient(50% 100% at 20% 0%, rgba(109,40,217,0.16), transparent 60%),
    linear-gradient(180deg, #171a36 0%, #0d0f1c 100%);
  position:relative;overflow:hidden;
  display:grid;grid-template-columns:1.4fr 1fr;gap:40px;align-items:center;
}
.cta-band::before{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background-image:
    linear-gradient(rgba(167,139,250,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(167,139,250,0.04) 1px, transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(60% 80% at 50% 50%, #000, transparent 80%);
  -webkit-mask-image:radial-gradient(60% 80% at 50% 50%, #000, transparent 80%);
  pointer-events:none;
}
.cta-band h3{margin:0 0 14px;font-size:44px;line-height:1.04;letter-spacing:-0.04em;font-weight:500;color:var(--ink);position:relative;font-family:"Inter",sans-serif;text-wrap:balance}
.cta-band h3 em{font-family:"Inter",sans-serif;font-style:normal;font-weight:700;color:var(--violet-300)}
.cta-band p{margin:0;color:var(--ink-2);font-size:15px;line-height:1.65;max-width:520px;position:relative}
.cta-band-right{display:flex;flex-direction:column;gap:14px;position:relative}
.cta-band-right .btn-primary{justify-content:center;padding:18px 24px;font-size:15px}
.cta-band-right .meta{display:flex;gap:18px;justify-content:center;color:var(--ink-3);font-size:12px;font-family:"JetBrains Mono",monospace;letter-spacing:.04em}
.cta-band-right .meta span{display:flex;align-items:center;gap:6px}
.cta-band-right .meta .dot{width:6px;height:6px;border-radius:50%;background:var(--violet-400);box-shadow:0 0 8px var(--violet-400)}

footer{padding:60px 0 40px;border-top:1px solid var(--line);margin-top:60px}
.foot-row{display:flex;justify-content:space-between;align-items:center;color:var(--ink-4);font-size:12.5px}
.foot-row .links{display:flex;gap:24px}
.foot-row .links a:hover{color:var(--violet-300)}

/* tiny premium ornament */
.ornament{
  position:absolute;left:50%;top:-1px;transform:translateX(-50%);
  width:80px;height:1px;background:linear-gradient(90deg,transparent,var(--violet-400),transparent);
}

/* ---------- 404 ERROR PAGE ---------- */
.err-shell{
  padding:120px 0 100px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;gap:24px;min-height:60vh;
}
.err-eyebrow{
  font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.32em;
  text-transform:uppercase;color:var(--violet-300);
  padding:8px 14px;border:1px solid var(--line-strong);border-radius:999px;
  background:rgba(124,58,237,0.06);
}
.err-code{
  font-family:"Inter",sans-serif;font-weight:700;
  font-size:clamp(96px, 18vw, 220px);line-height:1;letter-spacing:-0.04em;
  background:linear-gradient(180deg, #f1f1fa 0%, #a78bfa 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;margin:0;
}
.err-code .dot{color:var(--violet-300);-webkit-text-fill-color:var(--violet-300)}
.err-title{
  font-family:"Inter",sans-serif;font-weight:600;
  font-size:clamp(28px, 4.2vw, 44px);line-height:1.15;letter-spacing:-0.015em;
  margin:0;color:var(--ink);text-wrap:balance;
}
.err-title em{font-style:normal;color:var(--violet-300);font-weight:700}
.err-lede{
  font-size:17px;line-height:1.6;color:var(--ink-2);max-width:520px;margin:0;
}
.err-ctas{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:8px}

/* ---------- Visually-hidden helper (for SR-only labels) ---------- */
.visually-hidden{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0;
}

@media (max-width: 1100px){
  .product-stage{height:520px;max-width:640px}
  .why{grid-template-columns:1fr;gap:40px}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  /* iPad-range: work cards stay 2-col with smaller chrome. */
  .work-thumb{height:220px}
  .work-body{padding:22px 22px 22px}
  .work-title{font-size:22px}
  .work-desc{font-size:13.5px}
  .work-foot{padding-top:14px}
  .stats{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(2){border-right:0}
  .stat:nth-child(1),.stat:nth-child(2){border-bottom:1px solid var(--line)}
  .cta-band{grid-template-columns:1fr;padding:50px 32px}
  .hero h1{font-size:54px}
  .hero h1 .accent{font-size:64px}
}
@media (max-width:720px){
  .wrap{padding:0 22px}
  .nav-links{display:none}
  .hero h1{font-size:42px}
  .hero h1 .accent{font-size:50px}
  .services-grid{grid-template-columns:1fr}
  .work-grid{grid-template-columns:1fr}
  .trust-row{grid-template-columns:repeat(2,1fr);gap:30px}
  .feature-row{grid-template-columns:1fr}
  .section-head h2{font-size:34px}

  /* 640×520 hero mockup overflows phone viewports — hide on mobile. */
  .product-stage{display:none}
  .hero{gap:0}

  .section{padding:60px 0}
  .section-head{margin-bottom:28px}

  .cta-band{padding:40px 24px;border-radius:18px;margin-top:0}
  .cta-band h3{font-size:30px}
  .cta-band p{font-size:14px;line-height:1.55}

  /* Reserve footer space so the floating CTA pill never overlays it. */
  footer{padding:32px 0 110px;margin-top:30px}
  .foot-row{flex-direction:column;gap:12px;align-items:flex-start;font-size:12px}
  .foot-row .links{gap:18px}

  .morph-cta[data-state="float"]{padding:0 18px;font-size:13px}
}

/* Very small screens — tighten further so the form modal fits comfortably. */
@media (max-width:430px){
  .hero h1{font-size:36px}
  .hero h1 .accent{font-size:42px}
  .section-head h2{font-size:28px}
  .cta-band{padding:34px 20px}
  .cta-band h3{font-size:26px}
  .work-tags{gap:8px !important}
  .work-tag{font-size:9.5px;padding:4px 9px}
}

@media (max-width:600px){
  .err-shell{padding:80px 0 60px;min-height:50vh}
}

/* ---------- Reduced motion ---------- */
/* Disable transforms/transitions. JS bumps morph-cta lerp to 1 (instant). */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:0.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:0.001ms !important;
    scroll-behavior:auto !important;
  }
  html{scroll-behavior:auto}
  .mock-dashboard,.mock-phone{transform:none}
  .modal-eyebrow .ping{animation:none}
}
