/* Kaspa Safe — кованый сейф для серебра.
   База OfficeForge (iron/steel, Oswald/Golos/JetBrains Mono) × патина Kaspa #00C1AF.
   Тревожный красный — ТОЛЬКО отмена вывода. */

:root{
  --iron:#0E1116; --steel:#161B22; --plate:#1B222C;
  --bd:rgba(255,255,255,.085); --bd-soft:rgba(255,255,255,.05);
  --ingot:#ECEFF4; --ash:#9AA7BC; --ash2:#6c7a90;
  --kaspa:#00C1AF; --kaspa-soft:#33D6C6; --patina:#0A7C72; --patina-ink:#03302C;
  --silver:#C9D4D2; --silver-dim:#8f9c9a;
  --alarm:#E63A0B;
  --disp:"Oswald",Impact,"Arial Narrow",sans-serif;
  --body:"Golos Text",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --mono:"JetBrains Mono",ui-monospace,Menlo,monospace;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--iron);color:var(--ingot);font-family:var(--body);line-height:1.6;
  -webkit-font-smoothing:antialiased;min-height:100vh}
a{color:var(--kaspa);text-decoration:none}
a:hover{color:var(--kaspa-soft)}
:focus-visible{outline:2px solid var(--kaspa);outline-offset:2px;border-radius:2px}
::selection{background:rgba(0,193,175,.28)}

.wrap{max-width:1080px;margin:0 auto;padding:0 22px}

/* ── шапка ── */
.top{display:flex;align-items:center;gap:14px;padding:20px 0;border-bottom:1px solid var(--bd-soft)}
.top .brand{display:flex;align-items:center;gap:10px;color:var(--ingot)}
.brand-k{width:26px;height:26px;flex:none}
.brand-name{font-family:var(--disp);font-weight:600;font-size:17px;letter-spacing:.06em;text-transform:uppercase}
.brand-name b{color:var(--kaspa);font-weight:600}
.top nav{margin-left:auto;display:flex;gap:22px;align-items:center}
.top nav a{font-family:var(--mono);font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ash)}
.top nav a:hover{color:var(--kaspa)}
.top nav a.cta{color:var(--patina-ink);background:var(--kaspa);padding:8px 14px;border-radius:4px;font-weight:700}
.top nav a.cta:hover{background:var(--kaspa-soft)}

.eyebrow{font-family:var(--mono);font-size:11.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--kaspa)}
h1,h2{font-family:var(--disp);font-weight:600;text-transform:uppercase;letter-spacing:.02em;line-height:1.12}
h1{font-size:clamp(34px,5.4vw,58px)}
h2{font-size:clamp(22px,3vw,30px);margin-bottom:14px}
.lead{color:var(--ash);font-size:17px;max-width:56ch}
.mono{font-family:var(--mono)}

/* ── монета-индикатор (сигнатура) ── */
.coin{position:relative;width:var(--coin-size,240px);height:var(--coin-size,240px);flex:none}
.coin svg{width:100%;height:100%;display:block}
.coin .ring-track{stroke:rgba(255,255,255,.07)}
.coin .ring-window{stroke:var(--kaspa);stroke-linecap:round;transform:rotate(-90deg);transform-origin:50% 50%;
  transition:stroke-dashoffset .6s ease}
.coin .disk{fill:url(#patina)}
.coin .rim{stroke:var(--silver-dim);opacity:.8}
.coin .karrow{fill:none;stroke:var(--patina-ink);stroke-width:7;stroke-linecap:round;stroke-linejoin:round}
.coin .glint{opacity:.35}
.coin--vault .disk-wrap{animation:breathe 5.5s ease-in-out infinite}
.coin--empty{filter:grayscale(.9) brightness(.6)}
.coin--unvaulting .disk-wrap{animation:tick 1.6s ease-in-out infinite}
.coin-label{position:absolute;inset:auto 0 -34px 0;text-align:center;font-family:var(--mono);
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ash)}
.coin--vault .coin-label{color:var(--kaspa)}
@keyframes breathe{0%,100%{transform:scale(1)}50%{transform:scale(1.015)}}
@keyframes tick{0%,100%{transform:rotate(0deg)}8%{transform:rotate(-1.4deg)}16%{transform:rotate(1.1deg)}24%{transform:rotate(0)}}
@media (prefers-reduced-motion:reduce){
  .coin--vault .disk-wrap,.coin--unvaulting .disk-wrap{animation:none}
  html{scroll-behavior:auto}
}

/* ── плашки/карты ── */
.plate{background:var(--steel);border:1px solid var(--bd);border-radius:10px;padding:26px}
.plate + .plate{margin-top:16px}
.grid{display:grid;gap:16px}
@media(min-width:840px){.grid.cols-3{grid-template-columns:repeat(3,1fr)}.grid.cols-2{grid-template-columns:repeat(2,1fr)}}

/* ── кнопки ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;border:none;cursor:pointer;
  font-family:var(--mono);font-weight:700;font-size:13px;letter-spacing:.08em;text-transform:uppercase;
  padding:14px 22px;border-radius:6px;transition:.18s;text-align:center}
.btn:disabled{opacity:.45;cursor:not-allowed}
.btn-kaspa{background:linear-gradient(90deg,var(--kaspa-soft),var(--kaspa) 60%,var(--patina));color:var(--patina-ink)}
.btn-kaspa:not(:disabled):hover{box-shadow:0 0 22px rgba(0,193,175,.35);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--ash);border:1px solid var(--bd)}
.btn-ghost:not(:disabled):hover{color:var(--kaspa);border-color:var(--kaspa)}
/* отмена вывода: единственное место тревожного красного + «кузнечная» штриховка */
.btn-alarm{background:var(--alarm);color:#fff;position:relative;overflow:hidden}
.btn-alarm::before{content:"";position:absolute;inset:0;opacity:.16;
  background:repeating-linear-gradient(-45deg,#000 0 10px,transparent 10px 20px)}
.btn-alarm:not(:disabled):hover{box-shadow:0 0 26px rgba(230,58,11,.45)}

/* ── формы ── */
label{display:block;font-family:var(--mono);font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--ash);margin:16px 0 6px}
input[type=text],input[type=password],select{width:100%;background:var(--iron);border:1px solid var(--bd);
  border-radius:6px;color:var(--ingot);padding:12px 13px;font-family:var(--mono);font-size:13.5px}
input:focus,select:focus{outline:none;border-color:var(--kaspa)}
.check{display:flex;gap:10px;align-items:flex-start;margin-top:14px;color:var(--ash);font-size:14px}
.check input{accent-color:var(--kaspa);margin-top:4px}

/* ── адреса/код ── */
.addr{display:flex;gap:8px;align-items:stretch;margin-top:8px}
.addr code{flex:1;min-width:0;padding:12px 13px;font-family:var(--mono);font-size:12px;background:var(--iron);
  border:1px solid var(--bd);border-radius:6px;word-break:break-all;color:var(--silver)}
.addr button{flex:none;background:var(--plate);border:1px solid var(--bd);border-radius:6px;color:var(--ash);
  font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;padding:0 14px;cursor:pointer}
.addr button:hover{color:var(--kaspa-soft);border-color:var(--kaspa)}

/* ── статусные строки ── */
.kv{display:flex;justify-content:space-between;gap:14px;padding:9px 0;border-bottom:1px dashed var(--bd-soft);font-size:14px}
.kv:last-child{border-bottom:none}
.kv .k{color:var(--ash2);font-family:var(--mono);font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;padding-top:2px}
.kv .v{font-family:var(--mono);font-size:13px;text-align:right;word-break:break-all}
.ok{color:var(--kaspa)} .warn{color:#E0A93E} .bad{color:var(--alarm)}

/* ── шаги визарда ── */
.step{border-left:2px solid var(--bd);padding:6px 0 30px 26px;position:relative}
.step::before{content:attr(data-n);position:absolute;left:-17px;top:0;width:32px;height:32px;border-radius:50%;
  background:var(--steel);border:1px solid var(--bd);display:flex;align-items:center;justify-content:center;
  font-family:var(--disp);font-size:15px;color:var(--ash)}
.step.active{border-left-color:var(--kaspa)}
.step.active::before{background:var(--kaspa);color:var(--patina-ink);border-color:var(--kaspa)}
.step.done::before{content:"✓";background:var(--patina);color:#fff;border-color:var(--patina)}
.step h3{font-family:var(--disp);text-transform:uppercase;letter-spacing:.04em;font-size:19px;margin-bottom:8px}
.step .body{display:none}
.step.active .body{display:block}
.step .hint{color:var(--ash);font-size:14.5px;max-width:62ch}

/* ── ключи ── */
.keycard{background:var(--iron);border:1px solid var(--bd);border-radius:8px;padding:14px 16px;margin-top:10px}
.keycard .kc-role{display:flex;gap:10px;align-items:center;font-family:var(--mono);font-size:11px;
  letter-spacing:.14em;text-transform:uppercase;color:var(--kaspa)}
.keycard .kc-role .dot{width:8px;height:8px;border-radius:50%;background:currentColor;flex:none}
.keycard.kc-alarm .kc-role{color:var(--alarm)}
.keycard code{display:block;margin-top:8px;font-size:11.5px;word-break:break-all;color:var(--silver)}
.keycard .kc-note{font-size:12.5px;color:var(--ash2);margin-top:6px}

/* ── предупреждения ── */
.note{border:1px solid var(--bd);border-left:3px solid var(--kaspa);border-radius:6px;background:var(--plate);
  padding:14px 16px;font-size:14px;color:var(--ash);margin:14px 0}
.note.alarm{border-left-color:var(--alarm)}
.note b{color:var(--ingot)}

/* ── как работает (3 пути) ── */
.path{position:relative;padding:22px;background:var(--steel);border:1px solid var(--bd);border-radius:10px}
.path .glyph{font-family:var(--disp);font-size:15px;letter-spacing:.1em;text-transform:uppercase;color:var(--kaspa);
  display:flex;align-items:center;gap:10px;margin-bottom:8px}
.path p{color:var(--ash);font-size:14.5px}
.path.alarm .glyph{color:var(--alarm)}

/* окно отмены — линейка */
.window-bar{margin:26px 0 8px;position:relative;height:46px}
.window-bar .rail{position:absolute;left:0;right:0;top:20px;height:4px;border-radius:2px;
  background:linear-gradient(90deg,var(--kaspa) 0 68%,var(--silver-dim) 68% 100%)}
.window-bar .tick{position:absolute;top:12px;width:2px;height:20px;background:var(--ingot)}
.window-bar .lbl{position:absolute;top:38px;font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--ash2);white-space:nowrap}
.window-bar .lbl.mid{transform:translateX(-50%)}
.window-bar .lbl.end{right:0;left:auto}

/* ── футер ── */
footer{margin-top:70px;border-top:1px solid var(--bd-soft);padding:26px 0 40px;color:var(--ash2);font-size:13px}
footer .row{display:flex;flex-wrap:wrap;gap:18px;align-items:center}
footer img{height:34px;opacity:.85}

/* ── QR ── */
.qr{background:#fff;border-radius:8px;padding:10px;width:fit-content;margin-top:12px}
.qr img{display:block;width:168px;height:168px;image-rendering:pixelated}

/* ── лендинг hero ── */
.hero{display:flex;gap:48px;align-items:center;padding:64px 0 40px;flex-wrap:wrap}
.hero .txt{flex:1 1 420px}
.hero .coin{margin:0 auto}
.hero .actions{display:flex;gap:14px;margin-top:28px;flex-wrap:wrap}
.hero .sub{margin-top:18px;font-family:var(--mono);font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ash2)}
.hero .sub b{color:var(--kaspa);font-weight:500}

section{margin-top:64px}
@media(max-width:640px){
  .hero{padding-top:36px;gap:36px}
  .coin{--coin-size:190px}
  .top nav{gap:12px}
  .top nav a:not(.cta){display:none}
}
