/* ==========================================================================
   NoKYCSwap — single stylesheet for all pages.
   Organised: tokens → base → primitives → header → footer → landing →
   widget → modals → exchange page → order page → mobile.
   ========================================================================== */

/* -------------------------------------------------------- Tokens */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#050510;
  --bg-2:#0a0a1a;
  --surface:rgba(255,255,255,.04);
  --surface-2:rgba(255,255,255,.07);
  --surface-3:rgba(255,255,255,.11);
  --border:rgba(255,255,255,.08);
  --border-2:rgba(255,255,255,.14);
  --border-3:rgba(255,255,255,.22);

  /* Text scale — bumped for legibility on dark gradient backgrounds */
  --text:#f7f7fb;          /* primary — headlines, values, input text */
  --text-2:#dcdce6;        /* secondary — body, descriptions */
  --text-3:#b4b4c6;        /* tertiary — labels, captions (was #a8a8bc) */
  --text-4:#8d8da3;        /* quaternary — placeholders, disabled */

  --brand:#6366f1;
  --brand-2:#818cf8;
  --brand-3:#4f46e5;
  --violet:#a855f7;
  --cyan:#06b6d4;
  --pos:#22c55e;
  --neg:#ef4444;
  --warn:#f59e0b;

  --card:rgba(18,18,36,.72);
  --card-2:rgba(24,24,46,.82);
  --modal:linear-gradient(180deg,rgba(26,26,50,.98) 0%,rgba(14,14,32,.99) 100%);
  --modal-border:rgba(255,255,255,.18);

  --max:1280px;
  --max-sm:1080px;
  --mono:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  --radius:16px;
  --radius-lg:22px;
  --shadow-lg:0 30px 80px -20px rgba(0,0,0,.8);
  --shadow-md:0 16px 40px -16px rgba(0,0,0,.6);
  --ease:cubic-bezier(.4,0,.2,1);
}

html{font-family:'Inter',system-ui,-apple-system,Segoe UI,sans-serif;font-size:16px;line-height:1.5;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-feature-settings:"ss01","cv11";scroll-behavior:smooth;scroll-padding-top:80px}
body{min-height:100vh;overflow-x:hidden;position:relative}
body::before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;background:radial-gradient(ellipse 80% 60% at 20% -10%,rgba(99,102,241,.22),transparent 60%),radial-gradient(ellipse 70% 50% at 85% 10%,rgba(168,85,247,.16),transparent 60%),radial-gradient(ellipse 60% 40% at 50% 110%,rgba(6,182,212,.10),transparent 60%)}
body::after{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/><feColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 0.04 0'/></filter><rect width='240' height='240' filter='url(%23n)'/></svg>");opacity:.5;mix-blend-mode:overlay}
main,header,footer,section{position:relative;z-index:1}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit;letter-spacing:inherit}
input,select,textarea{font:inherit;color:inherit;background:none;border:none;outline:none;width:100%}
img,svg{display:block;max-width:100%}
::selection{background:var(--brand);color:#fff}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:10px;border:2px solid var(--bg)}
::-webkit-scrollbar-thumb:hover{background:var(--border-3)}

/* -------------------------------------------------------- Layout */
.wrap{width:100%;max-width:var(--max);margin:0 auto;padding:0 28px}
.wrap-sm{width:100%;max-width:var(--max-sm);margin:0 auto;padding:0 28px}
@media(max-width:640px){.wrap,.wrap-sm{padding:0 18px}}

/* -------------------------------------------------------- Typography */
.display{font-weight:800;letter-spacing:-.045em;line-height:.98}
.h1{font-size:clamp(44px,6.8vw,92px)}
.h2{font-size:clamp(30px,4.6vw,58px);line-height:1.04;letter-spacing:-.035em;font-weight:800}
.h3{font-size:clamp(22px,2.4vw,28px);line-height:1.18;letter-spacing:-.02em;font-weight:700}
.h4{font-size:17px;font-weight:700;letter-spacing:-.01em}
.lede{font-size:clamp(16px,1.4vw,19px);line-height:1.6;color:var(--text-2);font-weight:400;letter-spacing:-.005em}
.mono{font-family:var(--mono);font-feature-settings:"tnum","zero"}
.grad-text{background:linear-gradient(120deg,#c4b5fd 0%,#f0abfc 45%,#67e8f9 100%);-webkit-background-clip:text;background-clip:text;color:transparent}
.grad-text-2{background:linear-gradient(100deg,#a5b4fc 0%,#e9d5ff 100%);-webkit-background-clip:text;background-clip:text;color:transparent}
.muted{color:var(--text-3)}
.muted-sm{color:var(--text-3);font-size:13px}
.kicker{display:inline-flex;align-items:center;gap:10px;padding:6px 14px;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-2);background:var(--surface);border:1px solid var(--border-2);border-radius:100px;font-weight:600}
.kicker .dot{width:6px;height:6px;border-radius:50%;background:var(--pos);box-shadow:0 0 12px var(--pos),0 0 0 3px rgba(34,197,94,.2);animation:pulse 2.2s ease-in-out infinite}
.kicker .dot.warn{background:var(--warn);box-shadow:0 0 12px var(--warn),0 0 0 3px rgba(245,158,11,.22)}
.kicker .dot.neg{background:var(--neg);box-shadow:0 0 12px var(--neg),0 0 0 3px rgba(239,68,68,.22)}
.kicker .dot.done{background:var(--cyan);box-shadow:0 0 12px var(--cyan),0 0 0 3px rgba(6,182,212,.22);animation:none}
.kicker b{color:var(--text);font-weight:700}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
@keyframes slideIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:none}}
@keyframes spin{to{transform:rotate(360deg)}}

/* -------------------------------------------------------- Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;border-radius:100px;font-size:14px;font-weight:600;letter-spacing:-.005em;transition:.18s var(--ease);border:1px solid transparent;white-space:nowrap;min-height:44px;position:relative;isolation:isolate;user-select:none}
.btn:active{transform:translateY(1px)}
.btn:focus-visible{outline:2px solid var(--brand-2);outline-offset:2px}
.btn-primary{background:linear-gradient(135deg,var(--brand) 0%,var(--violet) 100%);color:#fff;box-shadow:0 0 0 1px rgba(255,255,255,.12) inset,0 10px 30px -8px rgba(99,102,241,.6),0 0 50px -10px rgba(168,85,247,.3)}
.btn-primary:hover{box-shadow:0 0 0 1px rgba(255,255,255,.18) inset,0 14px 40px -8px rgba(99,102,241,.8),0 0 70px -10px rgba(168,85,247,.5);transform:translateY(-1px)}
.btn-glass{background:var(--surface-2);color:var(--text);border-color:var(--border-2);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.btn-glass:hover{background:var(--surface-3);border-color:var(--border-3)}
.btn-ghost{color:var(--text-2)}
.btn-ghost:hover{color:var(--text);background:var(--surface)}
.btn-lg{padding:15px 26px;font-size:15px;min-height:50px}
.btn-xl{padding:18px 30px;font-size:16px;min-height:56px;border-radius:16px}
.btn-sm{padding:8px 14px;font-size:12.5px;min-height:36px}
.btn-block{width:100%}
.btn[disabled],.btn.is-loading{opacity:.55;pointer-events:none}
.btn.is-loading::after{content:"";width:14px;height:14px;margin-left:4px;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:spin .7s linear infinite}
.btn svg{width:14px;height:14px;transition:transform .2s}
.btn:hover svg.arr{transform:translateX(3px)}

/* -------------------------------------------------------- Inputs & fields */
.field{display:block;margin-bottom:18px}
.field:last-child{margin-bottom:0}
.field .lbl{display:flex;align-items:center;gap:6px;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-2);margin-bottom:10px;font-weight:700}
.field .lbl .opt{font-size:10.5px;color:var(--text-3);text-transform:none;letter-spacing:.02em;font-weight:500}
.field .hint{font-size:13px;color:var(--text-2);line-height:1.55;margin-top:8px}
.field .hint .em{color:var(--text);font-weight:600}
.inp{display:block;width:100%;padding:14px 16px;background:rgba(0,0,0,.4);border:1.5px solid var(--border-2);border-radius:12px;font-size:15px;font-family:var(--mono);color:var(--text);transition:.15s var(--ease);min-height:50px}
.inp:hover{border-color:var(--border-3)}
.inp:focus{border-color:var(--brand-2);background:rgba(0,0,0,.55);box-shadow:0 0 0 4px rgba(99,102,241,.15)}
.inp::placeholder{color:var(--text-4);opacity:.8}
.inp-wrap{position:relative}
.inp-wrap .inp{padding-right:84px}
.inp-wrap .paste{position:absolute;right:6px;top:50%;transform:translateY(-50%);padding:9px 14px;font-size:12px;color:var(--brand-2);background:rgba(99,102,241,.10);border:1px solid rgba(99,102,241,.30);border-radius:8px;font-family:var(--mono);font-weight:700;letter-spacing:.04em;text-transform:uppercase;cursor:pointer;transition:.15s}
.inp-wrap .paste:hover{background:rgba(99,102,241,.20);color:#fff;border-color:rgba(99,102,241,.5)}
.field.is-invalid .inp{border-color:var(--warn);background:rgba(245,158,11,.05)}
.field .err{font-size:12.5px;color:var(--warn);margin-top:8px;display:none;font-weight:500}
.field.is-invalid .err{display:block}

/* -------------------------------------------------------- Cards */
.card{background:var(--card);border:1px solid var(--border-2);border-radius:var(--radius-lg);padding:26px;backdrop-filter:blur(20px) saturate(140%);-webkit-backdrop-filter:blur(20px) saturate(140%);box-shadow:var(--shadow-md)}
.card-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:18px;flex-wrap:wrap}
.card-head .ttl{display:flex;align-items:center;gap:10px;font-size:17px;font-weight:700;letter-spacing:-.01em;color:var(--text)}
.card-head .ttl .num{width:26px;height:26px;border-radius:8px;background:linear-gradient(135deg,var(--brand) 0%,var(--violet) 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-weight:700;font-size:13px;box-shadow:0 4px 12px -2px rgba(99,102,241,.5)}
.card-sub{color:var(--text-2);font-size:14px;line-height:1.55;margin-bottom:18px}
.card + .card{margin-top:18px}

/* -------------------------------------------------------- Header */
.hdr{position:sticky;top:0;z-index:50;backdrop-filter:saturate(160%) blur(14px);-webkit-backdrop-filter:saturate(160%) blur(14px);background:rgba(5,5,16,.75);border-bottom:1px solid var(--border)}
.hdr-inner{display:flex;align-items:center;height:68px;gap:28px}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:17px;letter-spacing:-.02em;color:var(--text)}
.brand-mark{width:28px;height:28px;background:linear-gradient(135deg,var(--brand) 0%,var(--violet) 100%);color:#fff;display:flex;align-items:center;justify-content:center;border-radius:8px;box-shadow:0 0 0 1px rgba(255,255,255,.1) inset,0 8px 24px -4px rgba(99,102,241,.5)}
.brand-mark svg{width:15px;height:15px}
.nav{display:flex;align-items:center;gap:2px;margin-left:20px}
.nav a{padding:8px 14px;border-radius:8px;font-size:13.5px;color:var(--text-2);transition:.15s;font-weight:500}
.nav a:hover{color:var(--text);background:var(--surface)}
.hdr-right{margin-left:auto;display:flex;align-items:center;gap:8px}
.hamburger{display:none;width:40px;height:40px;border-radius:10px;align-items:center;justify-content:center;color:var(--text);background:var(--surface);border:1px solid var(--border-2)}
.hamburger:hover{background:var(--surface-2);border-color:var(--border-3)}
.hamburger svg{width:18px;height:18px}
@media(max-width:860px){.nav{display:none}.hdr-right .btn-ghost{display:none}.hamburger{display:flex}}

.mnav{position:fixed;inset:0;z-index:90;background:rgba(5,5,16,.98);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);display:none;flex-direction:column;padding:84px 28px 28px}
.mnav.open{display:flex}
.mnav-close{position:absolute;top:16px;right:16px;width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:var(--surface-2);border:1px solid var(--border-2);color:var(--text)}
.mnav a{display:block;padding:18px 0;font-size:22px;font-weight:600;letter-spacing:-.02em;border-bottom:1px solid var(--border);color:var(--text)}
.mnav-actions{margin-top:auto;display:flex;flex-direction:column;gap:10px;padding-top:24px}

/* -------------------------------------------------------- Hero (landing) */
.hero{padding:72px 0 64px}
.hero-grid{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,460px);gap:72px;align-items:center}
@media(max-width:1024px){.hero-grid{grid-template-columns:1fr;gap:48px}}
.hero h1{margin-top:24px}
.hero .lede{margin-top:22px;max-width:52ch}
.hero-cta{display:flex;gap:12px;margin-top:36px;flex-wrap:wrap}
.trust{display:flex;gap:24px;margin-top:44px;font-size:13.5px;color:var(--text-2);flex-wrap:wrap}
.trust-item{display:flex;align-items:center;gap:8px}
.trust-item .ic{width:20px;height:20px;border-radius:50%;background:rgba(34,197,94,.15);color:var(--pos);display:flex;align-items:center;justify-content:center;box-shadow:0 0 12px rgba(34,197,94,.2);flex-shrink:0}
.trust-item .ic svg{width:12px;height:12px}
.trust-item b{color:var(--text);font-weight:600}

/* -------------------------------------------------------- Swap widget */
.swap-outer{position:relative;isolation:isolate}
.swap-outer::before{content:"";position:absolute;inset:-2px;border-radius:24px;background:conic-gradient(from 120deg at 50% 50%,rgba(99,102,241,.6),rgba(168,85,247,.3),rgba(6,182,212,.4),rgba(99,102,241,.6));filter:blur(30px);opacity:.5;z-index:-1;animation:rotate 14s linear infinite}
@keyframes rotate{to{transform:rotate(360deg)}}
.swap{background:linear-gradient(180deg,rgba(22,22,44,.82) 0%,rgba(12,12,28,.94) 100%);backdrop-filter:blur(24px) saturate(140%);-webkit-backdrop-filter:blur(24px) saturate(140%);border:1px solid var(--border-2);border-radius:22px;padding:22px;box-shadow:var(--shadow-lg),0 0 0 1px rgba(255,255,255,.05) inset}
.swap-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:10px;flex-wrap:wrap}
.swap-ttl{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-2);font-weight:700}
.swap-modes{display:inline-flex;padding:3px;background:rgba(0,0,0,.35);border:1px solid var(--border);border-radius:100px}
.swap-mode{padding:7px 14px;border-radius:100px;font-size:12px;font-weight:600;color:var(--text-3);transition:.15s;cursor:pointer;letter-spacing:-.005em;min-height:32px}
.swap-mode.active{background:linear-gradient(135deg,var(--brand) 0%,var(--violet) 100%);color:#fff;box-shadow:0 4px 12px -2px rgba(99,102,241,.5)}
.swap-mode:not(.active):hover{color:var(--text)}

.leg{background:rgba(0,0,0,.3);border:1px solid var(--border-2);border-radius:16px;padding:16px;transition:border-color .15s,background .15s}
.leg:hover,.leg:focus-within{border-color:var(--border-3);background:rgba(0,0,0,.4)}
.leg.is-invalid{border-color:rgba(245,158,11,.5);background:rgba(245,158,11,.04)}
.leg-lbl{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-2);margin-bottom:10px;display:flex;justify-content:space-between;align-items:center;font-weight:700}
.leg-min{color:var(--text-3);font-weight:500;cursor:pointer;transition:.12s}
.leg-min:hover{color:var(--text)}
.leg-row{display:flex;align-items:center;gap:12px}
.leg-amt{flex:1;min-width:0;font-family:var(--mono);font-weight:500;font-size:30px;letter-spacing:-.02em;color:var(--text);background:transparent;width:100%;line-height:1.1}
.leg-amt::placeholder{color:var(--text-4)}
.leg-amt:read-only{cursor:default}
.coin-btn{display:inline-flex;align-items:center;gap:8px;padding:8px 12px 8px 8px;background:var(--surface-2);border:1px solid var(--border-2);border-radius:100px;font-weight:600;font-size:14px;cursor:pointer;transition:.15s;flex-shrink:0;color:var(--text);min-height:40px}
.coin-btn:hover{background:var(--surface-3);border-color:var(--border-3)}
.coin-btn img{width:24px;height:24px;border-radius:50%;background:rgba(255,255,255,.04)}
.coin-btn .chev{color:var(--text-3);margin-left:2px}
.leg-usd{font-family:var(--mono);font-size:11.5px;color:var(--text-2);margin-top:10px;display:flex;justify-content:space-between;gap:10px;align-items:center}
.leg-usd .net{padding:3px 9px;background:var(--surface-2);border:1px solid var(--border-2);border-radius:6px;color:var(--text);font-size:10.5px;letter-spacing:.04em;text-transform:uppercase;font-weight:600}

.mid{display:flex;justify-content:center;margin:-12px 0;position:relative;z-index:2}
.mid button{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,rgba(30,30,55,.95) 0%,rgba(15,15,35,.95) 100%);border:1px solid var(--border-3);color:var(--text);display:flex;align-items:center;justify-content:center;transition:.25s;cursor:pointer;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);box-shadow:0 4px 12px rgba(0,0,0,.4)}
.mid button:hover{border-color:var(--brand);color:var(--brand-2);box-shadow:0 4px 16px rgba(99,102,241,.3),0 0 0 4px rgba(99,102,241,.08)}
.mid button svg{width:14px;height:14px;transition:transform .3s}
.mid button:hover svg{transform:rotate(180deg)}

.rate-line{display:flex;justify-content:space-between;align-items:center;padding:14px 4px 4px;font-family:var(--mono);font-size:12.5px;color:var(--text-2);margin-top:14px;border-top:1px dashed var(--border-2);gap:10px;flex-wrap:wrap}
.rate-line .rate-v{color:var(--text);font-weight:600}
.rate-line .live{display:inline-flex;align-items:center;gap:6px;color:var(--pos);font-weight:600}
.rate-line .live::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--pos);box-shadow:0 0 8px var(--pos);animation:pulse 2s infinite}
.rate-line .live.warn{color:var(--warn)}
.rate-line .live.warn::before{background:var(--warn);box-shadow:0 0 8px var(--warn)}

.swap-hint{font-family:var(--mono);font-size:12px;color:var(--warn);padding:10px 12px;margin-top:10px;background:rgba(245,158,11,.08);border:1px solid rgba(245,158,11,.28);border-radius:10px;display:none;line-height:1.5;font-weight:500}
.swap-hint.show{display:block}

.exchange-btn{display:flex;align-items:center;justify-content:center;width:100%;margin-top:14px;padding:17px;border-radius:14px;font-size:15px;font-weight:700;letter-spacing:-.01em;background:linear-gradient(135deg,var(--brand) 0%,var(--violet) 100%);color:#fff;transition:.2s;box-shadow:0 10px 30px -8px rgba(99,102,241,.5),0 0 0 1px rgba(255,255,255,.12) inset;cursor:pointer;gap:8px;border:none;min-height:56px}
.exchange-btn:hover{transform:translateY(-1px);box-shadow:0 16px 40px -8px rgba(99,102,241,.75),0 0 0 1px rgba(255,255,255,.18) inset,0 0 60px -10px rgba(168,85,247,.4)}
.exchange-btn[disabled]{opacity:.55;cursor:not-allowed;transform:none}
.exchange-btn svg{width:16px;height:16px;transition:transform .2s}
.exchange-btn:hover svg{transform:translateX(3px)}

.swap-foot{display:flex;align-items:center;justify-content:center;gap:18px;margin-top:16px;font-size:11px;color:var(--text-2);font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;font-weight:600;flex-wrap:wrap}
.swap-foot span{display:inline-flex;align-items:center;gap:5px}
.swap-foot svg{width:12px;height:12px;color:var(--text-3)}

/* -------------------------------------------------------- Ticker */
.ticker{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:rgba(0,0,0,.25);overflow:hidden;font-family:var(--mono);font-size:12.5px}
.ticker-inner{display:flex;white-space:nowrap;animation:tick 80s linear infinite;min-height:44px;align-items:center}
.ticker:hover .ticker-inner{animation-play-state:paused}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.tick-item{padding:12px 24px;display:inline-flex;align-items:center;gap:10px;border-right:1px solid var(--border)}
.tick-pair{color:var(--text);font-weight:600}
.tick-val{color:var(--text-2)}

/* -------------------------------------------------------- Sections */
.sec{padding:100px 0}
@media(max-width:720px){.sec{padding:64px 0}}
.sec-head{text-align:center;max-width:740px;margin:0 auto 56px}
.sec-head .kicker{margin-bottom:18px}
.sec-head .h2{margin-bottom:14px}

.pairs{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:900px){.pairs{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.pairs{grid-template-columns:1fr}}
.pair{background:var(--surface);border:1px solid var(--border-2);border-radius:16px;padding:20px;transition:.2s;cursor:pointer;position:relative;overflow:hidden;display:block}
.pair::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(99,102,241,.08),transparent 50%);opacity:0;transition:.2s}
.pair:hover{border-color:var(--border-3);background:var(--surface-2);transform:translateY(-2px)}
.pair:hover::before{opacity:1}
.pair-head{display:flex;align-items:center;gap:8px;margin-bottom:14px;position:relative}
.pair-icons{display:flex;position:relative}
.pair-icons img{width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,.05)}
.pair-icons img:last-child{margin-left:-10px;border:2px solid var(--bg)}
.pair-sym{font-weight:700;font-size:15px;letter-spacing:-.01em;color:var(--text)}
.pair-sym .to{color:var(--text-2);font-weight:500}
.pair-arr{margin-left:auto;color:var(--text-3);opacity:0;transition:.2s;transform:translateX(-4px)}
.pair:hover .pair-arr{opacity:1;transform:translateX(0);color:var(--brand-2)}
.pair-val{font-family:var(--mono);font-weight:600;font-size:22px;letter-spacing:-.015em;margin-bottom:6px;color:var(--text);position:relative}
.pair-meta{display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:11.5px;position:relative;color:var(--text-2)}
.pair-meta .vol{color:var(--text-3);letter-spacing:.04em;text-transform:uppercase}

.features{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:900px){.features{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.features{grid-template-columns:1fr}}
.feat{background:var(--surface);border:1px solid var(--border-2);border-radius:20px;padding:26px 28px;transition:.25s;position:relative;overflow:hidden}
.feat::before{content:"";position:absolute;top:0;left:0;right:0;height:120px;background:radial-gradient(ellipse at 50% 0%,rgba(99,102,241,.14),transparent 70%);opacity:0;transition:.25s;pointer-events:none}
.feat:hover{border-color:var(--border-3);background:var(--surface-2);transform:translateY(-3px)}
.feat:hover::before{opacity:1}
.feat-head{display:flex;align-items:center;gap:12px;margin-bottom:10px;position:relative}
.feat-ic{flex-shrink:0;width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(99,102,241,.2),rgba(168,85,247,.1));border:1px solid var(--border-2);color:var(--brand-2);box-shadow:0 0 24px -6px rgba(99,102,241,.3)}
.feat-ic svg{width:18px;height:18px}
.feat h3{margin:0;color:var(--text)}
.feat p{color:var(--text-2);font-size:14px;line-height:1.6;position:relative}

.stats{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:rgba(0,0,0,.22);backdrop-filter:blur(20px)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.stat{padding:42px 20px;text-align:center;border-right:1px solid var(--border)}
.stat:last-child{border-right:none}
.stat-v{font-family:var(--mono);font-size:clamp(28px,4vw,42px);font-weight:600;letter-spacing:-.025em;line-height:1;color:var(--text)}
.stat-v.grad{background:linear-gradient(120deg,#c4b5fd 0%,#f0abfc 100%);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat-l{font-size:13px;color:var(--text-2);margin-top:10px;font-weight:500;letter-spacing:-.005em}
@media(max-width:720px){.stats-grid{grid-template-columns:repeat(2,1fr)}.stat:nth-child(odd){border-right:1px solid var(--border)}.stat:nth-child(even){border-right:none}.stat:nth-child(-n+2){border-bottom:1px solid var(--border)}}

.steps{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.steps > li{list-style:none}
@media(max-width:860px){.steps{grid-template-columns:1fr}}
.step{background:var(--surface);border:1px solid var(--border-2);border-radius:20px;padding:28px;transition:.25s}
.step:hover{border-color:var(--border-3);background:var(--surface-2)}
.step-head{display:flex;align-items:center;gap:14px;margin-bottom:10px}
.step-num{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;background:linear-gradient(135deg,var(--brand) 0%,var(--violet) 100%);color:#fff;border-radius:8px;font-family:var(--mono);font-weight:700;font-size:13px;box-shadow:0 6px 18px -4px rgba(99,102,241,.5)}
.step h3{margin:0;color:var(--text)}
.step p{color:var(--text-2);font-size:14px;line-height:1.6}

.faq{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px 16px;align-items:start}
@media(max-width:820px){.faq{grid-template-columns:1fr;gap:10px}}
.faq-item{background:var(--surface);border:1px solid var(--border-2);border-radius:14px;overflow:hidden;transition:.2s}
.faq-item[open]{border-color:var(--border-3);background:var(--surface-2)}
.faq-item summary{list-style:none;display:flex;justify-content:space-between;align-items:center;padding:20px 24px;cursor:pointer;gap:20px;font-size:15.5px;font-weight:600;letter-spacing:-.01em;color:var(--text)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:hover{color:var(--brand-2)}
.faq-item .mk{width:28px;height:28px;border-radius:50%;background:var(--surface-2);border:1px solid var(--border-3);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text-2);transition:.2s;font-family:var(--mono);font-size:16px;line-height:1;font-weight:600}
.faq-item[open] .mk{transform:rotate(45deg);background:linear-gradient(135deg,var(--brand) 0%,var(--violet) 100%);color:#fff;border-color:transparent}
.faq-item .ans{padding:0 24px 24px;font-size:14.5px;line-height:1.65;color:var(--text-2)}

.finale{padding:100px 0;text-align:center;position:relative;overflow:hidden}
.finale::before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:900px;height:600px;background:radial-gradient(ellipse,rgba(99,102,241,.22),transparent 70%);pointer-events:none;z-index:0;filter:blur(20px)}
.finale > *{position:relative;z-index:1}
.finale .h2{max-width:20ch;margin:0 auto 14px}
.finale .lede{max-width:52ch;margin:0 auto 36px}
.finale-cta{display:inline-flex;gap:12px;flex-wrap:wrap;justify-content:center}

.foot{border-top:1px solid var(--border);padding:72px 0 36px;background:rgba(0,0,0,.4);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:56px}
@media(max-width:860px){.foot-grid{grid-template-columns:1fr 1fr;gap:40px}.foot-brand{grid-column:span 2}}
@media(max-width:520px){.foot-grid{grid-template-columns:1fr}.foot-brand{grid-column:span 1}}
.foot-brand p{margin-top:14px;max-width:38ch;color:var(--text-2);font-size:14px;line-height:1.55}
.foot-col h5{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-2);margin-bottom:18px;font-weight:700}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:11px}
.foot-col a,.foot-col button{color:var(--text-2);font-size:14px;transition:.12s;text-align:left;display:inline-block;padding:0;background:none;border:none;cursor:pointer}
.foot-col a:hover,.foot-col button:hover{color:var(--text)}
.foot-bot{display:flex;justify-content:space-between;align-items:center;padding-top:28px;border-top:1px solid var(--border);font-family:var(--mono);font-size:11.5px;color:var(--text-3);letter-spacing:.04em;gap:16px;flex-wrap:wrap}
.foot-bot a{color:var(--text-2);transition:.12s}
.foot-bot a:hover{color:var(--text)}
.foot-wordmark{font-family:'Inter';font-weight:900;font-size:clamp(56px,14vw,192px);line-height:.88;letter-spacing:-.055em;margin:48px 0 36px;background:linear-gradient(180deg,rgba(255,255,255,.18) 0%,rgba(255,255,255,.02) 100%);-webkit-background-clip:text;background-clip:text;color:transparent;user-select:none}

/* -------------------------------------------------------- Modals (picker, track only) */
.mod-back{position:fixed;inset:0;background:rgba(5,5,16,.78);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);z-index:400;display:none;align-items:flex-start;justify-content:center;padding:72px 16px 16px;animation:fadeIn .18s}
.mod-back.open{display:flex}
.mod{background:var(--modal);width:100%;max-width:480px;max-height:calc(100vh - 120px);display:flex;flex-direction:column;border:1px solid var(--modal-border);border-radius:20px;box-shadow:0 40px 100px -20px rgba(0,0,0,.9),0 0 0 1px rgba(255,255,255,.06) inset;animation:slideUp .22s var(--ease);color:var(--text)}
.mod-head{padding:20px 22px 16px;border-bottom:1px solid var(--border-2);flex-shrink:0}
.mod-ttl{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;font-size:15px;font-weight:700;color:var(--text);letter-spacing:-.01em}
.mod-ttl .sub{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);font-weight:600}
.mod-close{width:34px;height:34px;display:flex;align-items:center;justify-content:center;color:var(--text-2);border-radius:8px;transition:.15s;cursor:pointer;background:var(--surface);border:1px solid var(--border-2)}
.mod-close:hover{color:var(--text);background:var(--surface-2);border-color:var(--border-3)}
.mod-body{padding:18px 22px;overflow-y:auto;flex:1;min-height:0}
.mod-foot{padding:16px 22px 20px;border-top:1px solid var(--border-2);display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap;flex-shrink:0}

.pk-search-wrap{position:relative;margin-top:4px}
.pk-search-wrap svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--text-3);pointer-events:none}
.pk-search{width:100%;padding:12px 14px 12px 40px;background:rgba(0,0,0,.4);border:1.5px solid var(--border-2);border-radius:10px;font-size:15px;transition:.15s;color:var(--text);min-height:48px}
.pk-search:focus{border-color:var(--brand-2);background:rgba(0,0,0,.55)}
.pk-search::placeholder{color:var(--text-4)}
.pk-list{overflow-y:auto;padding:6px 0;flex:1;min-height:0}
.pk-empty{padding:32px 22px;text-align:center;color:var(--text-3);font-size:14px}
.pk-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:10px;cursor:pointer;transition:.12s;min-height:56px}
.pk-item:hover,.pk-item.is-focus{background:var(--surface-2)}
.pk-item img{width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.05);flex-shrink:0}
.pk-item .info{flex:1;min-width:0}
.pk-item .sym{font-weight:700;font-size:14.5px;color:var(--text);display:flex;align-items:center;gap:6px}
.pk-item .sym .full{font-family:var(--mono);color:var(--text-3);font-size:11.5px;font-weight:500;letter-spacing:.02em}
.pk-item .nm{font-size:13px;color:var(--text-2);margin-top:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pk-item .nt{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--text);padding:4px 8px;background:var(--surface-2);border:1px solid var(--border-3);border-radius:6px;font-weight:600;white-space:nowrap;flex-shrink:0}

/* -------------------------------------------------------- Toast */
.toast{position:fixed;right:20px;bottom:20px;padding:12px 16px;background:var(--modal);border:1px solid var(--modal-border);border-radius:12px;font-size:13.5px;font-weight:500;z-index:500;backdrop-filter:blur(12px);color:var(--text);animation:slideIn .2s var(--ease);max-width:calc(100vw - 40px);box-shadow:var(--shadow-md)}
.toast.pos{color:var(--pos);border-color:rgba(34,197,94,.4)}
.toast.neg{color:var(--neg);border-color:rgba(239,68,68,.4)}
.toast.warn{color:var(--warn);border-color:rgba(245,158,11,.4)}
@media(max-width:520px){.toast{right:12px;bottom:12px;left:12px;text-align:center}}

/* ==========================================================================
   Exchange page — /exchange.php
   ========================================================================== */

.xc-wrap{padding:32px 0 80px}
.xc-crumb{display:flex;align-items:center;gap:8px;font-size:13.5px;color:var(--text-2);margin-bottom:14px;flex-wrap:wrap}
.xc-crumb a{color:var(--text-2);transition:.12s}
.xc-crumb a:hover{color:var(--text)}
.xc-crumb .sep{color:var(--text-4)}

.xc-stepper{display:flex;align-items:center;gap:0;margin-bottom:32px;padding:16px 0;font-family:var(--mono);font-size:12px;flex-wrap:wrap}
.xc-stepper .s{display:flex;align-items:center;gap:10px;color:var(--text-3)}
.xc-stepper .s.done,.xc-stepper .s.active{color:var(--text)}
.xc-stepper .s .n{width:26px;height:26px;border-radius:50%;background:var(--surface-2);border:1.5px solid var(--border-2);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;color:var(--text-2)}
.xc-stepper .s.done .n{background:var(--pos);border-color:var(--pos);color:#fff}
.xc-stepper .s.active .n{background:linear-gradient(135deg,var(--brand) 0%,var(--violet) 100%);border-color:transparent;color:#fff;box-shadow:0 0 0 4px rgba(99,102,241,.18)}
.xc-stepper .s-lbl{letter-spacing:.04em;text-transform:uppercase;font-weight:600}
.xc-stepper .bar{flex:1;height:2px;background:var(--border-2);margin:0 14px;border-radius:2px;min-width:20px}
.xc-stepper .s.done + .bar,.xc-stepper .s.active + .bar{background:linear-gradient(90deg,var(--brand),var(--border-2))}

.xc-grid{display:grid;grid-template-columns:minmax(0,1fr) 380px;gap:28px;align-items:start}
@media(max-width:980px){.xc-grid{grid-template-columns:1fr}}

.xc-main{display:flex;flex-direction:column;gap:18px;min-width:0}
.xc-aside{position:sticky;top:84px;display:flex;flex-direction:column;gap:14px}
@media(max-width:980px){.xc-aside{position:static;order:-1}}

/* Rate preview in exchange page */
.xc-rate{display:grid;grid-template-columns:1fr auto 1fr;gap:14px;align-items:center;padding:22px;background:linear-gradient(180deg,rgba(99,102,241,.06) 0%,rgba(168,85,247,.02) 100%);border:1px solid var(--border-2);border-radius:18px;margin-bottom:18px}
.xc-rate .side{min-width:0}
.xc-rate .side .label{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-3);font-weight:700;margin-bottom:10px}
.xc-rate .side .amt{font-family:var(--mono);font-size:clamp(22px,3.6vw,32px);font-weight:600;letter-spacing:-.02em;color:var(--text);line-height:1.1;word-break:break-all}
.xc-rate .side .coin{display:flex;align-items:center;gap:7px;margin-top:8px;font-size:13px;color:var(--text-2)}
.xc-rate .side .coin img{width:20px;height:20px;border-radius:50%;flex-shrink:0}
.xc-rate .side .coin b{color:var(--text);font-weight:700}
.xc-rate .side .coin .net{padding:2px 7px;background:var(--surface-2);border:1px solid var(--border-2);border-radius:5px;font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;text-transform:uppercase;color:var(--text-2);font-weight:600;margin-left:4px}
.xc-rate .arr{width:36px;height:36px;border-radius:10px;background:var(--surface-2);border:1px solid var(--border-2);color:var(--text-2);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.xc-rate .arr svg{width:16px;height:16px}
@media(max-width:540px){.xc-rate{grid-template-columns:1fr;gap:10px}.xc-rate .arr{transform:rotate(90deg);margin:0 auto}}

.xc-rate-meta{display:flex;justify-content:space-between;align-items:center;margin-top:14px;padding-top:14px;border-top:1px dashed var(--border-2);font-family:var(--mono);font-size:12.5px;color:var(--text-2);gap:10px;flex-wrap:wrap}
.xc-rate-meta .rate{color:var(--text);font-weight:600}
.xc-rate-meta .live{display:inline-flex;align-items:center;gap:6px;color:var(--pos);font-weight:600}
.xc-rate-meta .live::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--pos);box-shadow:0 0 8px var(--pos);animation:pulse 2s infinite}

.xc-tip{display:flex;gap:10px;padding:12px 14px;background:rgba(99,102,241,.06);border:1px solid rgba(99,102,241,.22);border-radius:10px;font-size:13px;color:var(--text-2);line-height:1.55;margin-top:10px}
.xc-tip .icn{flex-shrink:0;color:var(--brand-2);margin-top:1px}
.xc-tip b{color:var(--text);font-weight:600}

.xc-details{margin-top:12px}
.xc-details summary{display:flex;align-items:center;gap:8px;padding:12px 0;cursor:pointer;color:var(--text-2);font-size:14px;font-weight:600;list-style:none}
.xc-details summary::-webkit-details-marker{display:none}
.xc-details summary:hover{color:var(--text)}
.xc-details summary::before{content:"";display:inline-block;width:6px;height:6px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(-45deg);transition:transform .18s;margin-right:4px}
.xc-details[open] summary::before{transform:rotate(45deg);margin-top:-4px}

/* Summary sidebar */
.xc-summary{padding:22px}
.xc-summary h3{font-size:15px;font-weight:700;color:var(--text);margin-bottom:16px}
.xc-summary .row{display:flex;justify-content:space-between;align-items:baseline;padding:8px 0;font-size:13.5px;border-bottom:1px dashed var(--border);gap:10px}
.xc-summary .row:last-child{border-bottom:none}
.xc-summary .row .k{color:var(--text-2);font-weight:500}
.xc-summary .row .v{color:var(--text);font-weight:600;font-family:var(--mono);text-align:right;word-break:break-word}
.xc-summary .row.total .k,.xc-summary .row.total .v{color:var(--text);font-size:15px}
.xc-summary .row.total{padding-top:14px;border-top:1px solid var(--border-2);margin-top:6px}
.xc-summary .row.total .v{font-size:18px}

.xc-trust{display:flex;flex-direction:column;gap:10px;padding:18px 22px;background:var(--surface);border:1px solid var(--border-2);border-radius:var(--radius)}
.xc-trust .t{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text-2)}
.xc-trust .t .ic{width:22px;height:22px;border-radius:50%;background:rgba(34,197,94,.14);color:var(--pos);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.xc-trust .t .ic svg{width:12px;height:12px}
.xc-trust .t b{color:var(--text);font-weight:600}

.xc-fee-break{display:grid;grid-template-columns:1fr auto;gap:6px 16px;font-size:12.5px;font-family:var(--mono);color:var(--text-2);padding:12px 14px;background:rgba(0,0,0,.28);border-radius:10px;margin-top:10px}
.xc-fee-break .k{color:var(--text-3)}
.xc-fee-break .v{color:var(--text);text-align:right}

.xc-actions{display:flex;gap:10px;margin-top:12px;flex-direction:column}
.xc-actions .disclaimer{font-size:12px;color:var(--text-3);line-height:1.5;text-align:center;padding:0 10px}
.xc-actions .disclaimer a{color:var(--text-2);border-bottom:1px dotted var(--border-3)}

/* Exchange edit-amount — read+edit combo */
.xc-edit-amt{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}
.xc-edit-amt input{font-family:var(--mono);font-size:clamp(22px,3.6vw,32px);font-weight:600;letter-spacing:-.02em;color:var(--text);background:transparent;border:none;width:100%;max-width:280px;padding:0;min-height:auto}
.xc-edit-amt input:focus{outline:none;color:var(--brand-2)}

/* ==========================================================================
   Order page — /order.php
   ========================================================================== */

.order-wrap{padding:32px 0 80px}
.order-hero{text-align:center;margin-bottom:28px}
.order-hero .kicker{margin-bottom:16px}
.order-hero h1{font-size:clamp(24px,3.4vw,36px);line-height:1.1;font-weight:800;letter-spacing:-.025em;margin-bottom:10px;color:var(--text)}
.order-hero .to-arrow{color:var(--text-3);margin:0 4px;font-weight:600;display:inline-block;transform:translateY(-2px)}
.order-meta{font-family:var(--mono);font-size:13px;color:var(--text-2);letter-spacing:.02em;display:flex;justify-content:center;gap:12px;flex-wrap:wrap}
.order-meta b{color:var(--text);font-weight:700}
.order-meta .sep{color:var(--text-4)}

.order-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:20px;margin-bottom:24px}
@media(max-width:860px){.order-grid{grid-template-columns:1fr}}

.deposit-card .amount-big{font-family:var(--mono);font-size:clamp(26px,3.6vw,36px);font-weight:600;letter-spacing:-.02em;line-height:1.15;color:var(--text);margin-bottom:4px;word-break:break-all}
.deposit-card .amount-sub{color:var(--text-2);font-size:12.5px;letter-spacing:.04em;text-transform:uppercase;margin-bottom:20px;font-family:var(--mono);font-weight:600}
.deposit-card .amount-sub span{color:var(--text)}

.timer{padding:6px 12px;background:rgba(245,158,11,.14);border:1px solid rgba(245,158,11,.35);color:var(--warn);border-radius:100px;font-size:12px;font-weight:700;font-family:var(--mono);letter-spacing:.02em}

.addr-wrap{display:flex;gap:8px;align-items:stretch}
.addr{flex:1;background:rgba(0,0,0,.4);border:1.5px solid var(--border-2);border-radius:12px;padding:14px;font-size:13.5px;word-break:break-all;line-height:1.5;color:var(--text);font-family:var(--mono)}
.addr-row{display:flex;gap:8px;margin-top:6px}
.addr-warn{font-family:var(--mono);font-size:11px;color:var(--warn);letter-spacing:.1em;text-transform:uppercase;margin-top:20px;margin-bottom:8px;display:flex;align-items:center;gap:6px;font-weight:700}

.qr-wrap{display:flex;justify-content:center;margin-top:22px}
.qr-wrap img{width:200px;height:200px;padding:12px;background:#fff;border-radius:14px;box-shadow:0 10px 30px -10px rgba(0,0,0,.7)}

.confs{margin-top:18px;padding:12px;text-align:center;color:var(--text-2);font-size:13px;font-family:var(--mono);background:rgba(0,0,0,.2);border:1px dashed var(--border-2);border-radius:10px}
.confs b{color:var(--text);font-weight:700}

.steps-v{list-style:none;display:flex;flex-direction:column;gap:0;margin-bottom:22px;border-left:2px solid var(--border-2);padding-left:0;position:relative}
.steps-v li{position:relative;padding:14px 0 14px 28px;color:var(--text-3);font-size:14px;font-weight:500;line-height:1.4}
.steps-v li .dot-s{position:absolute;left:-7px;top:18px;width:12px;height:12px;border-radius:50%;background:var(--bg);border:2px solid var(--border-3)}
.steps-v li.done{color:var(--text)}
.steps-v li.done .dot-s{background:var(--pos);border-color:var(--pos);box-shadow:0 0 0 3px rgba(34,197,94,.2)}
.steps-v li.active{color:var(--text);font-weight:600}
.steps-v li.active .dot-s{background:var(--brand);border-color:var(--brand);box-shadow:0 0 0 3px rgba(99,102,241,.3);animation:pulse 1.8s infinite}
.steps-v li.fail .dot-s{background:var(--neg);border-color:var(--neg)}

.kv{display:grid;grid-template-columns:140px 1fr;gap:10px 14px;font-size:13.5px;font-family:var(--mono)}
@media(max-width:520px){.kv{grid-template-columns:1fr;gap:3px 0}.kv dt{margin-top:10px}}
.kv dt{color:var(--text-3);font-weight:500}
.kv dd{color:var(--text);word-break:break-all;font-weight:500}
.kv dd.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.kv dd.truncate:hover{white-space:normal;word-break:break-all}

.emergency-card{border-color:rgba(245,158,11,.4);background:linear-gradient(180deg,rgba(245,158,11,.08),rgba(245,158,11,.01))}
.emergency-card h2{color:var(--text);margin-bottom:8px}
.emergency-actions{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:16px}
@media(max-width:700px){.emergency-actions{grid-template-columns:1fr}}

.err-card{max-width:560px;margin:60px auto;text-align:center}
.err-card h1{color:var(--text);margin-bottom:12px}
.err-card .lede{margin:16px 0 24px}

/* ============================================================================
   SEO-landing-page components (added 2026-04-21)
   Breadcrumbs, TL;DR boxes, comparison tables, pair/coin/guide grids, etc.
   ============================================================================ */

/* Breadcrumbs */
.crumbs{padding:16px 28px 0;max-width:1280px;margin:0 auto}
.crumbs ol{list-style:none;display:flex;flex-wrap:wrap;align-items:center;gap:8px;color:var(--text-3);font-size:13px;font-family:var(--mono);letter-spacing:.04em;text-transform:uppercase;font-weight:500}
.crumbs li{display:flex;align-items:center;gap:8px}
.crumbs a{color:var(--text-3);transition:color .15s var(--ease)}
.crumbs a:hover{color:var(--text)}
.crumbs span[aria-current]{color:var(--text);font-weight:600}
.crumbs .sep{color:var(--text-4);opacity:.6}

/* TL;DR / Quick-answer box */
.tldr-sec{padding-top:12px;padding-bottom:12px}
.tldr{background:var(--card);border:1px solid var(--border-2);border-radius:var(--radius-lg);padding:22px 26px;max-width:900px;margin:0 auto;position:relative;backdrop-filter:blur(10px)}
.tldr::before{content:"";position:absolute;left:0;top:18px;bottom:18px;width:3px;background:linear-gradient(180deg,#a855f7 0%,#06b6d4 100%);border-radius:3px}
.tldr-tag{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;background:linear-gradient(120deg,rgba(168,85,247,.18),rgba(99,102,241,.18));color:var(--text);font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;margin-bottom:10px;border:1px solid var(--border-2)}
.tldr p{color:var(--text-2);font-size:16px;line-height:1.7;letter-spacing:-.005em}
.tldr strong{color:var(--text);font-weight:700}

/* Compare table */
.compare-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--card);backdrop-filter:blur(10px)}
.compare{width:100%;border-collapse:collapse;font-size:14.5px}
.compare caption{padding:0}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.compare thead th{font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);padding:14px 18px;text-align:left;border-bottom:1px solid var(--border-2);background:var(--surface)}
.compare tbody th{font-weight:600;color:var(--text);padding:14px 18px;text-align:left;border-bottom:1px solid var(--border);background:var(--surface)}
.compare tbody td{padding:14px 18px;color:var(--text-2);border-bottom:1px solid var(--border);vertical-align:top}
.compare tbody tr:last-child th,.compare tbody tr:last-child td{border-bottom:none}
.compare tbody tr:hover th,.compare tbody tr:hover td{background:var(--surface-2)}
.compare td.ok{color:#86efac;font-weight:600}
.compare td.ok::before{content:"✓ ";color:#22c55e}

/* Pair-card grid */
.pair-hub{display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));margin-top:8px}
.pair-card{display:block;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;transition:transform .18s var(--ease),border-color .18s var(--ease),background .18s var(--ease);backdrop-filter:blur(10px)}
.pair-card:hover{transform:translateY(-2px);border-color:var(--border-3);background:var(--card-2)}
.pair-head{font-family:var(--mono);font-weight:700;font-size:15px;color:var(--text);letter-spacing:.02em}
.pair-head b{color:var(--text);font-weight:800}
.pair-sub{margin-top:4px;font-size:12.5px;color:var(--text-3);letter-spacing:-.005em}

/* Coin chips */
.coin-hub{display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));margin-top:8px}
.coin-chip{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:12px 14px;color:var(--text-3);transition:transform .18s var(--ease),border-color .18s var(--ease),background .18s var(--ease);min-width:0}
.coin-chip:hover{transform:translateY(-2px);border-color:var(--border-3);background:var(--surface-2)}
.coin-chip img{width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.04);flex-shrink:0;object-fit:contain;padding:2px}
.coin-chip-text{display:flex;flex-direction:column;gap:1px;min-width:0;flex:1}
.coin-chip b{color:var(--text);font-family:var(--mono);font-weight:700;font-size:14px;letter-spacing:.02em;line-height:1.2}
.coin-chip span{font-size:12.5px;color:var(--text-3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.3}

/* Guide cards */
.guide-hub{display:grid;gap:18px;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));margin-top:8px}
.guide-card{display:block;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:24px 24px 22px;transition:transform .18s var(--ease),border-color .18s var(--ease),background .18s var(--ease);backdrop-filter:blur(10px)}
.guide-card:hover{transform:translateY(-2px);border-color:var(--border-3);background:var(--card-2)}
.guide-card h3{font-size:18px;font-weight:700;letter-spacing:-.015em;line-height:1.3;margin-bottom:10px;color:var(--text)}
.guide-card p{color:var(--text-3);font-size:14px;line-height:1.55}
.guide-card .guide-cta{display:inline-block;margin-top:14px;font-size:13px;color:#c4b5fd;font-weight:600;letter-spacing:.01em}
.guide-card:hover .guide-cta{color:#e9d5ff}

/* Pair-page hero layout */
.pair-page{position:relative}
.pair-hero{display:grid;grid-template-columns:1fr 380px;gap:44px;align-items:start;margin-bottom:48px}
@media(max-width:960px){.pair-hero{grid-template-columns:1fr}}
.pair-rate-card{background:var(--card);border:1px solid var(--border-2);border-radius:var(--radius-lg);padding:24px;backdrop-filter:blur(12px);position:sticky;top:92px}
@media(max-width:960px){.pair-rate-card{position:static}}
.prc-head{display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:13px;color:var(--text-3);letter-spacing:.04em;text-transform:uppercase;font-weight:600;margin-bottom:16px}
.prc-head .live{display:inline-flex;align-items:center;gap:4px;color:#86efac;font-size:11px;font-weight:700}
.prc-head .live::before{content:"";width:6px;height:6px;border-radius:50%;background:#22c55e;box-shadow:0 0 8px #22c55e}
.prc-rate{font-size:28px;font-weight:700;letter-spacing:-.02em;color:var(--text);margin-bottom:12px;word-break:break-all}
.prc-rate b{color:var(--text);font-weight:800;font-family:var(--mono)}
.prc-example{color:var(--text-3);font-size:13px;line-height:1.55;margin-bottom:20px}
.prc-example b{color:var(--text-2);font-family:var(--mono);font-weight:600}
.prc-kv{display:grid;grid-template-columns:auto 1fr;gap:10px 18px;margin:20px 0 24px;padding:16px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.prc-kv dt{font-size:12px;color:var(--text-3);text-transform:uppercase;letter-spacing:.05em;font-weight:600}
.prc-kv dd{font-size:13px;color:var(--text-2);font-weight:500;text-align:right}
.btn-block{display:inline-flex;width:100%;justify-content:center}

/* Inline section spacing inside articles */
.sec-inline{margin-top:56px;padding-top:0}
.sec-inline h2{margin-bottom:20px}
.sec-inline h3{margin:22px 0 10px}
.sec-inline p{color:var(--text-2);line-height:1.7;font-size:15.5px;margin-bottom:14px}
.sec-inline p + p{margin-top:12px}

.two-col{display:grid;grid-template-columns:1fr 1fr;gap:28px;margin-top:16px}
@media(max-width:760px){.two-col{grid-template-columns:1fr}}
.two-col h3{margin-top:0}

/* Bullet lists for guides */
.bullets{list-style:none;display:grid;gap:10px;padding:0;margin:10px 0 22px}
.bullets li{position:relative;padding-left:26px;color:var(--text-2);line-height:1.65;font-size:15.5px}
.bullets li::before{content:"";position:absolute;left:4px;top:10px;width:8px;height:8px;border-radius:50%;background:linear-gradient(120deg,#a855f7,#06b6d4)}
.bullets li b{color:var(--text);font-weight:700}

/* Facts list (coin detail) */
.facts{display:grid;grid-template-columns:1fr 2fr;gap:8px 20px;margin-top:16px;padding:18px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);max-width:520px}
.facts dt{color:var(--text-3);font-size:13px;text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.facts dd{color:var(--text-2);font-size:14px;font-weight:500}

/* Guide body typography */
.guide-body{color:var(--text-2);line-height:1.75;font-size:16px}
.guide-body h2{font-size:28px;font-weight:700;letter-spacing:-.02em;line-height:1.15;margin:40px 0 14px;color:var(--text)}
.guide-body h3{font-size:20px;font-weight:700;letter-spacing:-.01em;margin:28px 0 10px;color:var(--text)}
.guide-body p{margin-bottom:14px}
.guide-body ul,.guide-body ol{margin:10px 0 22px}
.guide-body code{font-family:var(--mono);font-size:14px;padding:2px 6px;background:var(--surface-2);border-radius:5px;color:var(--text);border:1px solid var(--border)}
.guide-body a{color:#c4b5fd;text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}
.guide-body a:hover{color:#e9d5ff}
.guide-body .compare-wrap{margin:16px 0 24px}
.guide-body .steps{margin:16px 0 24px}

/* Track-order button in the widget footer */
.swap-track{margin-left:auto;font-size:12px;color:var(--text-3);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px;padding:4px 8px;border-radius:8px;transition:color .15s var(--ease)}
.swap-track:hover{color:var(--text)}

@media(max-width:760px){
  .prc-rate{font-size:22px}
  .guide-body h2{font-size:23px;margin:28px 0 10px}
  .guide-body h3{font-size:17px}
}

/* ============================================================================
   Harmonized page-level scale (2026-04-21 redesign)
   - page-h1 / page-h2 replace the huge display h1/h2 on landing pages
   - page-hero / page-hero-slim give a consistent top-of-page feel
   - Widget-embed pair/coin pages reuse .hero-grid
   ============================================================================ */

.page-h1{font-family:inherit;font-weight:800;letter-spacing:-.035em;line-height:1.02;font-size:clamp(34px,4.6vw,64px);color:var(--text)}
.page-h2{font-family:inherit;font-weight:800;letter-spacing:-.028em;line-height:1.08;font-size:clamp(26px,3.4vw,44px);color:var(--text)}

.hero{padding:64px 0 48px}
.hero .page-h1{margin-top:0}

.page{display:block}
.page-hero{padding:48px 0 56px;position:relative}
.page-hero-slim{padding:40px 0 28px;text-align:left}
.page-hero .page-h1,.page-hero-slim .page-h1{margin-top:14px}
.page-hero .lede,.page-hero-slim .lede{margin-top:18px;max-width:58ch}
.hero-copy{min-width:0}

/* Sections inside inner pages: tighter rhythm than the landing */
.page .sec{padding:72px 0}
@media(max-width:720px){.page .sec{padding:56px 0}.page-hero{padding:32px 0 40px}.page-hero-slim{padding:28px 0 20px}}

/* Page-level sec-head alignment — left-aligned on inner pages feels cleaner */
.page .sec-head{text-align:left;margin:0 0 32px;max-width:760px}
.page .sec-head .kicker{margin-bottom:14px}
.page .sec-head .page-h2{margin-bottom:12px}
.page .sec-head .lede{margin-top:4px;max-width:60ch}

/* Centered CTA under a section */
.sec-cta{display:flex;justify-content:center;margin-top:36px}

/* Live rate badge below hero lede on pair pages */
.rate-badge{display:inline-flex;align-items:center;gap:12px;margin-top:22px;padding:10px 16px;background:var(--card);border:1px solid var(--border-2);border-radius:100px;backdrop-filter:blur(10px);font-family:var(--mono);font-size:14px;letter-spacing:-.005em}
.rate-badge b{color:var(--text);font-weight:700}
.rate-badge-live{display:inline-flex;align-items:center;gap:6px;color:#86efac;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.rate-badge-live::before{content:"";width:6px;height:6px;border-radius:50%;background:#22c55e;box-shadow:0 0 8px #22c55e;animation:pulse 2s infinite}
.rate-badge-eq{color:var(--text-2)}

/* Facts strip — coin pages below the hero */
.coin-facts{padding:8px 0 0}
.facts-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;background:var(--border);border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);margin-top:24px}
.facts-strip > div{background:var(--card);padding:16px 20px;backdrop-filter:blur(10px)}
.facts-strip dt{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);font-weight:700;margin-bottom:4px}
.facts-strip dd{color:var(--text);font-weight:600;font-size:14.5px;letter-spacing:-.005em}
@media(max-width:860px){.facts-strip{grid-template-columns:repeat(2,1fr)}}
@media(max-width:420px){.facts-strip{grid-template-columns:1fr}}

/* Prose-wide: article body with readable measure */
.prose-wide{max-width:760px;color:var(--text-2);line-height:1.75;font-size:16.5px}
.prose-wide p{margin-bottom:14px}
.prose-wide p + p{margin-top:12px}
.prose-wide h2{font-family:inherit;font-size:26px;font-weight:700;letter-spacing:-.02em;line-height:1.15;margin:36px 0 12px;color:var(--text)}
.prose-wide h3{font-family:inherit;font-size:19px;font-weight:700;letter-spacing:-.01em;margin:26px 0 8px;color:var(--text)}
.prose-wide ul,.prose-wide ol{margin:10px 0 22px}
.prose-wide code{font-family:var(--mono);font-size:14px;padding:2px 6px;background:var(--surface-2);border-radius:5px;color:var(--text);border:1px solid var(--border)}
.prose-wide a{color:#c4b5fd;text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}
.prose-wide a:hover{color:#e9d5ff}
.prose-wide .compare-wrap{margin:16px 0 24px}

/* Ensure two-col rhythm stays clean */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin-top:12px}
.two-col h3{margin-top:0}
.two-col p{color:var(--text-2);line-height:1.7;font-size:15.5px}
@media(max-width:760px){.two-col{grid-template-columns:1fr;gap:24px}}

/* Tighten hero-grid on pair/coin pages — the text column shouldn't dwarf the widget */
.page-hero .hero-grid{align-items:start}
.page-hero .hero-copy .lede{margin-top:16px}
.page-hero .hero-copy .trust{margin-top:28px}

/* Finale refinements inside .page */
.page .finale{padding:72px 0}
.page .finale-cta{margin-top:28px}

/* ============================================================================
   Widget-below-hero layout (2026-04-21, second pass)
   Homepage + /swap/{pair}/ + /coins/{slug}/ all share this pattern now:
   the hero is text-only, the widget is a centered section directly below.
   ============================================================================ */

/* Homepage hero — centered copy, no widget inside */
.hero-center{text-align:center;padding:72px 0 28px}
.hero-center .hero-copy{max-width:880px;margin:0 auto}
.hero-center .page-h1{margin-top:18px}
.hero-center .lede{margin:20px auto 0;max-width:60ch}
.hero-center .trust{justify-content:center;margin-top:32px}

/* Inner-page hero (coin/pair) — left-aligned copy, no widget inside */
.page-hero .hero-copy{max-width:760px}
.page-hero .page-h1{margin-top:14px}
.page-hero .lede{margin-top:18px;max-width:62ch}
.page-hero .rate-badge{margin-top:22px}
.page-hero .trust{margin-top:26px}
.hero-alt-cta{margin-top:22px}

/* The shared widget section. Centered, capped width, a little extra bottom
   space so the next content section has air around it. */
.exchange-bar{padding:8px 0 56px;position:relative}
.exchange-bar .swap-outer{max-width:560px;margin:0 auto;width:100%}
@media(max-width:640px){
  .exchange-bar{padding:4px 0 40px}
  .hero-center{padding:48px 0 20px}
}

/* Ensure hero-grid behaves if any legacy template still uses it */
.hero-grid .swap-outer{max-width:100%}

/* ============================================================================
   Horizontal widget (2026-04-21, final)
   FixedFloat-style: [Send] [↔] [Receive] [Continue →] in a single row on
   desktop, stacked on mobile. Every rule here overrides the older vertical
   layout by virtue of appearing later in the cascade at equal specificity.
   ============================================================================ */

/* Wider container when widget is standalone */
.exchange-bar .swap-outer{max-width:1080px}

.swap{padding:24px 28px}
@media(max-width:720px){.swap{padding:18px 16px}}

/* Row containing both legs, the direction button and the continue button */
.swap-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) 52px minmax(0,1fr) minmax(170px,200px);
  gap:14px;
  align-items:stretch;
  margin-top:10px;
}

/* Legs: row-layout with comfortable vertical spacing */
.swap-row .leg{
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  padding:18px 20px;
  gap:12px;
  min-width:0;
  min-height:120px;
}
.swap-row .leg-lbl{margin-bottom:0}
.swap-row .leg-row{gap:10px}
.swap-row .leg-amt{font-size:28px}
.swap-row .leg-usd{margin-top:0}

/* Direction swap button, centered in its own column between legs */
.swap-dir{
  align-self:center;
  width:52px;
  height:52px;
  border-radius:14px;
  background:linear-gradient(135deg,rgba(30,30,55,.95) 0%,rgba(15,15,35,.95) 100%);
  border:1px solid var(--border-3);
  color:var(--text);
  display:flex;
  align-items:center;
  justify-content:center;
  transition:.25s;
  cursor:pointer;
  box-shadow:0 4px 12px rgba(0,0,0,.4);
  flex-shrink:0;
}
.swap-dir:hover{
  border-color:var(--brand);
  color:var(--brand-2);
  box-shadow:0 4px 16px rgba(99,102,241,.3),0 0 0 4px rgba(99,102,241,.08)
}
.swap-dir svg{width:18px;height:18px;transition:transform .3s}
.swap-dir:hover svg{transform:rotate(180deg)}

/* Continue button — full-height in its grid column, prominent */
.swap-row .exchange-btn{
  margin-top:0;
  width:100%;
  height:auto;
  padding:0 22px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  font-size:16px;
  font-weight:700;
  letter-spacing:-.01em;
  border-radius:14px;
  min-height:100%;
}
.exchange-btn-label{white-space:nowrap}

/* Rate line + live pill, inline below the row */
.swap-sub{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:14px 4px 0;
  font-family:var(--mono);
  font-size:12.5px;
  color:var(--text-2);
  margin-top:16px;
  border-top:1px dashed var(--border-2);
  gap:10px;
  flex-wrap:wrap;
}
.swap-sub .rate-inline{letter-spacing:-.005em}
.swap-sub .rate-v{color:var(--text);font-weight:600}
.swap-sub .live{display:inline-flex;align-items:center;gap:6px;color:var(--pos);font-weight:600}
.swap-sub .live::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--pos);box-shadow:0 0 8px var(--pos);animation:pulse 2s infinite}
.swap-sub .live.warn{color:var(--warn)}
.swap-sub .live.warn::before{background:var(--warn);box-shadow:0 0 8px var(--warn)}

/* Mobile stack */
@media(max-width:900px){
  .swap-row{grid-template-columns:1fr;gap:10px}
  .swap-dir{
    width:44px;height:44px;
    justify-self:center;
    margin:-6px auto;
  }
  .swap-dir svg{transform:rotate(90deg)}
  .swap-dir:hover svg{transform:rotate(270deg)}
  .swap-row .leg{min-height:auto}
  .swap-row .exchange-btn{min-height:58px;padding:14px 22px;margin-top:6px}
  .swap-row .leg-amt{font-size:26px}
}

/* ============================================================================
   Homepage refinements — the eyebrow pill, larger hero H1, tighter rhythm
   ============================================================================ */

/* Eyebrow pill above the hero H1 */
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:8px 18px;
  border-radius:100px;
  background:var(--card);
  border:1px solid var(--border-2);
  color:var(--text-2);
  font-size:12.5px;
  font-weight:500;
  letter-spacing:-.005em;
  margin-bottom:26px;
  backdrop-filter:blur(10px);
}
.eyebrow-dot{
  width:7px;height:7px;
  border-radius:50%;
  background:#22c55e;
  box-shadow:0 0 10px rgba(34,197,94,.8);
  animation:pulse 2s infinite;
  flex-shrink:0;
}
.eyebrow-sep{color:var(--text-4);opacity:.6}

/* Bigger, more impactful homepage hero H1 (inner pages stay calmer) */
.hero-center .page-h1{font-size:clamp(38px,5.4vw,74px);line-height:1.02;letter-spacing:-.04em}
.hero-center{padding:80px 0 36px}
.hero-center .lede{font-size:clamp(16px,1.5vw,20px);margin-top:22px}
@media(max-width:720px){
  .hero-center{padding:48px 0 24px}
  .hero-center .page-h1{font-size:clamp(34px,9vw,48px)}
}

/* Breathing room between the widget and the ticker below */
.exchange-bar + .ticker{margin-top:16px}

/* Tighter stats grid: 4 chips on one row */
.stats{padding:28px 0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
@media(max-width:720px){.stats-grid{grid-template-columns:repeat(2,1fr)}}
