/*
 * Nightlink — App/Login shared components
 * Requires: /static/brand/tokens.css
 * v1.0 · 2026-04-21
 */

/* ==================== APP SUB-NAV ====================
 * Заменяет public .nav для авторизованных страниц (/app/*, /login).
 * Крепкий sticky top с Eclipse-лого слева и вкладками + выход справа.
 */
.sub-nav{position:sticky;top:0;z-index:var(--z-nav);background:rgba(10,10,10,.82);backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);border-bottom:1px solid var(--border)}
.sub-nav-inner{display:flex;align-items:center;justify-content:space-between;gap:var(--s-5);padding:14px 0}
.nl-logo{display:inline-flex;align-items:center;min-height:32px;padding:5px 0;gap:8px;color:var(--light)}
.sub-nav-tabs{display:flex;gap:var(--s-2);align-items:center;flex-wrap:wrap}
.sub-nav-tabs a{font-size:var(--fs-sm);color:var(--dim-1);font-weight:500;letter-spacing:-.005em;padding:8px 14px;border-radius:var(--r-full);transition:all var(--dur-fast) var(--ease)}
.sub-nav-tabs a:hover{color:var(--light)}
.sub-nav-tabs a.active{background:var(--surface);color:var(--light);border:1px solid var(--border)}
.sub-nav-tabs .logout{color:var(--dim-2);padding-left:14px;border-left:1px solid var(--border);border-radius:0;margin-left:var(--s-2)}
.sub-nav-tabs .logout:hover{color:var(--light)}
@media(max-width:720px){.sub-nav-tabs{gap:2px}.sub-nav-tabs a{padding:6px 10px;font-size:13px}.sub-nav-tabs .logout{margin-left:0;padding-left:10px}}

/* ==================== PAGE HEAD ==================== */
.page-head{padding:var(--s-8) 0 var(--s-5)}
.page-head .eyebrow{margin-bottom:var(--s-4)}
.page-head h1{font-size:clamp(var(--fs-2xl),6vw,var(--fs-3xl));font-weight:500;letter-spacing:-.04em;margin-bottom:var(--s-4)}
.page-head h1 em{font-style:italic;font-weight:400}
.page-head .lede{font-size:var(--fs-md);color:var(--dim-1);max-width:56ch;line-height:1.5}

/* ==================== CARD ==================== */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--s-6);transition:border-color var(--dur) var(--ease)}
.card:hover{border-color:var(--border-strong)}
.card--flat{background:transparent}
.card--inverse{background:var(--light);color:var(--void)}
.card--inverse h1,.card--inverse h2,.card--inverse h3,.card--inverse p{color:var(--void)}
.card-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--s-5);gap:var(--s-4);flex-wrap:wrap}
.card-title{font-size:var(--fs-xs);letter-spacing:.25em;text-transform:uppercase;color:var(--dim-1);font-weight:500;margin-bottom:var(--s-3)}

/* ==================== GRID ==================== */
.grid{display:grid;gap:var(--s-4)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
@media(max-width:780px){.grid-2,.grid-3{grid-template-columns:1fr}}

/* ==================== STAT ==================== */
.stat .stat-num{font-family:var(--font-display);font-size:clamp(var(--fs-2xl),5vw,var(--fs-3xl));font-weight:500;letter-spacing:-.04em;line-height:1;font-variant-numeric:tabular-nums}
.stat .stat-unit{font-size:var(--fs-md);color:var(--dim-1);margin-left:var(--s-2);font-weight:400}
.stat .stat-hint{font-size:var(--fs-xs);color:var(--dim-2);margin-top:var(--s-4);line-height:1.5}

/* progress */
.progress{height:4px;background:var(--surface-2);border-radius:var(--r-full);overflow:hidden;margin-top:var(--s-4)}
.progress-fill{height:100%;background:var(--light);border-radius:var(--r-full);transition:width var(--dur-slow) var(--ease)}
.progress-row{display:flex;justify-content:space-between;font-size:var(--fs-xs);color:var(--dim-2);letter-spacing:.1em;text-transform:uppercase;margin-top:var(--s-2)}

/* ==================== STATUS PILL ==================== */
.status-pill{display:inline-flex;align-items:center;gap:var(--s-2);font-size:var(--fs-xs);letter-spacing:.2em;text-transform:uppercase;color:var(--light);font-weight:500;padding:6px 12px;border:1px solid var(--border-strong);border-radius:var(--r-full);background:var(--surface)}
.status-pill::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--light);box-shadow:0 0 10px rgba(255,255,255,.35);animation:pulseDot 2.4s ease-in-out infinite}
.status-pill.is-muted{color:var(--dim-1)}
.status-pill.is-muted::before{background:var(--dim-2);box-shadow:none;animation:none}
@keyframes pulseDot{0%,100%{opacity:1}50%{opacity:.35}}

/* ==================== HERO DASH ==================== */
.dash-hero{display:grid;grid-template-columns:1fr auto;gap:var(--s-7);align-items:start;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:var(--s-7)}
.dash-hero h1{font-family:var(--font-display);font-size:clamp(var(--fs-2xl),5vw,var(--fs-3xl));font-weight:500;letter-spacing:-.035em;line-height:1.05;margin:var(--s-4) 0 var(--s-3)}
.dash-hero .sub{color:var(--dim-1);font-size:var(--fs-sm);display:flex;flex-wrap:wrap;gap:var(--s-3);align-items:center}
.dash-hero .sub .sep{color:var(--dim-3)}
.dash-hero .counter{text-align:center;padding:var(--s-4) var(--s-6);border-left:1px solid var(--border);min-width:180px}
.dash-hero .counter .num{font-family:var(--font-display);font-size:clamp(56px,9vw,120px);font-weight:400;letter-spacing:-.04em;line-height:.9;color:var(--light);font-variant-numeric:tabular-nums;display:block}
.dash-hero .counter .lbl{font-size:var(--fs-xs);letter-spacing:.25em;text-transform:uppercase;color:var(--dim-1);margin-top:var(--s-2)}
.dash-hero .actions{display:flex;gap:var(--s-3);margin-top:var(--s-5);flex-wrap:wrap}
@media(max-width:720px){.dash-hero{grid-template-columns:1fr;padding:var(--s-5)}.dash-hero .counter{border-left:none;border-top:1px solid var(--border);padding:var(--s-5) 0 0;text-align:left;min-width:0}}

/* ==================== KEY BLOCK ==================== */
.key-block{display:grid;grid-template-columns:1fr 260px;gap:var(--s-7);align-items:start}
.key-block .url{font-family:var(--font-mono);font-size:13px;padding:var(--s-3) var(--s-4);background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);word-break:break-all;color:var(--light)}
.key-block .qr-frame{padding:var(--s-4);background:var(--light);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center}
.key-block .qr-frame img{max-width:100%;filter:contrast(1.1)}
.key-block .qr-cap{font-family:var(--font-mono);font-size:11px;color:var(--dim-2);letter-spacing:.15em;text-align:center;margin-top:var(--s-3);text-transform:uppercase}
@media(max-width:780px){.key-block{grid-template-columns:1fr}.key-block .qr-frame{max-width:260px;margin:0 auto}}

/* ==================== FORM ==================== */
.stack{display:flex;flex-direction:column;gap:var(--s-4)}
.label{display:block;font-size:var(--fs-xs);letter-spacing:.2em;text-transform:uppercase;color:var(--dim-1);font-weight:500;margin-bottom:var(--s-2)}
.input{width:100%;padding:14px 16px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);color:var(--light);font-family:var(--font-body);font-size:var(--fs-base);transition:border-color var(--dur-fast) var(--ease),background var(--dur-fast) var(--ease)}
.input:focus{outline:none;border-color:var(--light);background:var(--surface)}
.input::placeholder{color:var(--dim-3)}
.helper{font-size:var(--fs-xs);color:var(--dim-2);line-height:1.6;margin-top:var(--s-3)}

.btn-block{width:100%;justify-content:center}

/* ==================== TABLE ==================== */
.data-table{width:100%;border-collapse:collapse;font-size:var(--fs-sm)}
.data-table th,.data-table td{padding:var(--s-4) var(--s-5);text-align:left;border-bottom:1px solid var(--border)}
.data-table thead th{font-size:var(--fs-xs);letter-spacing:.2em;text-transform:uppercase;color:var(--dim-1);font-weight:500;background:var(--surface-2)}
.data-table tbody tr{transition:background var(--dur-fast) var(--ease)}
.data-table tbody tr:hover{background:var(--surface-2)}
.data-table tbody tr:last-child td{border-bottom:none}
.data-table .mono{font-family:var(--font-mono);font-variant-numeric:tabular-nums}
.data-table .amount{font-family:var(--font-display);font-weight:500;font-variant-numeric:tabular-nums}
.data-table .dim{color:var(--dim-2)}
.data-table .right{text-align:right}

/* ==================== PRICE CARDS (buy page) ==================== */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-4);margin-top:var(--s-5)}
.price-grid--4{grid-template-columns:repeat(4,1fr)}
@media(max-width:1080px){.price-grid--4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:900px){.price-grid{grid-template-columns:1fr;gap:var(--s-3)}.price-grid--4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.price-grid--4{grid-template-columns:1fr}}
.price-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--s-6);display:flex;flex-direction:column;gap:var(--s-4);transition:all var(--dur) var(--ease);position:relative}
.price-card:hover{border-color:var(--border-strong);transform:translateY(-4px)}
.price-card--featured{background:var(--light);color:var(--void);border-color:var(--light)}
.price-card--featured .pc-period,.price-card--featured .pc-monthly,.price-card--featured .pc-note{color:var(--void)}
.price-card__badge{position:absolute;top:-10px;left:var(--s-5);background:var(--void);color:var(--light);font-size:11px;letter-spacing:.2em;text-transform:uppercase;padding:4px 10px;border-radius:var(--r-full)}
.pc-period{font-size:var(--fs-xs);letter-spacing:.2em;text-transform:uppercase;color:var(--dim-1);font-weight:500}
.pc-total{font-family:var(--font-display);font-size:clamp(40px,5.5vw,64px);font-weight:500;letter-spacing:-.04em;line-height:.95;font-variant-numeric:tabular-nums}
.pc-total .unit{font-size:.4em;color:var(--dim-1);font-weight:400;margin-left:4px}
.price-card--featured .pc-total .unit{color:var(--dim-3)}
.pc-monthly{font-family:var(--font-mono);font-size:13px;color:var(--dim-1)}
.pc-note{font-size:var(--fs-xs);color:var(--dim-2);letter-spacing:.05em;line-height:1.5}
.price-card--featured .btn-primary{background:var(--void);color:var(--light)}
.price-card--featured .btn-primary::after{background:var(--light)}
.price-card--featured .btn-primary:hover span{color:var(--void)}

/* ==================== TABS ==================== */
.tabs{display:inline-flex;gap:4px;padding:4px;border:1px solid var(--border);border-radius:var(--r-full);background:var(--surface)}
.tabs a{font-size:var(--fs-sm);color:var(--dim-1);padding:8px 18px;border-radius:var(--r-full);font-weight:500;transition:all var(--dur-fast) var(--ease)}
.tabs a:hover{color:var(--light)}
.tabs a.active{background:var(--light);color:var(--void)}

/* ==================== SETTINGS ==================== */
.settings-grid{display:grid;grid-template-columns:200px 1fr;gap:var(--s-6);align-items:start}
@media(max-width:780px){.settings-grid{grid-template-columns:1fr}}
.settings-side{position:sticky;top:80px;display:flex;flex-direction:column;gap:4px}
.settings-side a{font-size:var(--fs-sm);color:var(--dim-1);padding:10px 14px;border-radius:var(--r-md);transition:all var(--dur-fast) var(--ease);font-family:var(--font-mono);letter-spacing:-.01em}
.settings-side a:hover{color:var(--light);background:var(--surface)}
.settings-side a.active{color:var(--light);background:var(--surface);border:1px solid var(--border)}
.settings-body{display:flex;flex-direction:column;gap:var(--s-4)}

/* ==================== LOGIN ==================== */
.auth-shell{min-height:calc(100vh - 140px);display:flex;align-items:center;justify-content:center;padding:var(--s-7) 0}
.auth-card{max-width:440px;width:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:var(--s-8) var(--s-7)}
.auth-card .icon{width:48px;height:48px;color:var(--light);margin-bottom:var(--s-5)}
.auth-card h1{font-family:var(--font-display);font-size:var(--fs-2xl);font-weight:500;letter-spacing:-.03em;line-height:1.1;margin-bottom:var(--s-4)}
.auth-card .lede{font-size:var(--fs-sm);color:var(--dim-1);line-height:1.6;margin-bottom:var(--s-6)}
.auth-card .helper{margin-top:var(--s-6);padding-top:var(--s-5);border-top:1px solid var(--border)}

/* ==================== UTILITIES ==================== */
.mt-3{margin-top:var(--s-3)} .mt-4{margin-top:var(--s-4)} .mt-5{margin-top:var(--s-5)}
.mb-3{margin-bottom:var(--s-3)} .mb-4{margin-bottom:var(--s-4)}
.row{display:flex;gap:var(--s-3);flex-wrap:wrap;align-items:center}
.between{display:flex;justify-content:space-between;align-items:center;gap:var(--s-4);flex-wrap:wrap}
.text-right{text-align:right}
.text-mono{font-family:var(--font-mono);font-variant-numeric:tabular-nums}
.mono-sm{font-family:var(--font-mono);font-size:12px;color:var(--dim-1);letter-spacing:.05em}
.text-accent{color:var(--light);font-weight:500}
.text-dim{color:var(--dim-1)}
