/* —— Design tokens —— */
:root{
  --bg:#070b14;
  --bg-elevated:#0c1224;
  --surface:rgba(18,26,49,.72);
  --surface-solid:#121a31;
  --border:rgba(255,255,255,.08);
  --border-strong:rgba(255,255,255,.14);
  --text:#eef2ff;
  --text-secondary:#a8b7e8;
  --muted:#8b9dc9;
  --primary:#7c8cff;
  --primary-dim:rgba(124,140,255,.15);
  --accent:#4fd1c5;
  --danger:#f87171;
  --success:#34d399;
  --warning:#fbbf24;
  --icon:#a8b9ff;
  --radius-sm:10px;
  --radius-md:14px;
  --radius-lg:20px;
  --radius-xl:24px;
  --shadow-sm:0 2px 8px rgba(0,0,0,.25);
  --shadow-md:0 8px 32px rgba(0,0,0,.35);
  --shadow-lg:0 20px 50px rgba(0,0,0,.45);
  --font:system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",sans-serif;
  --step--1:.8125rem;
  --step-0:.9375rem;
  --step-1:1.0625rem;
  --step-2:1.25rem;
  --step-3:1.5rem;
  --step-4:1.875rem;
  --step-5:2.25rem;
  --space-1:.25rem;
  --space-2:.5rem;
  --space-3:.75rem;
  --space-4:1rem;
  --space-5:1.5rem;
  --space-6:2rem;
  --space-8:2.5rem;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font);
  font-size:var(--step-0);
  line-height:1.65;
  color:var(--text);
  -webkit-font-smoothing:antialiased;
  background-color:var(--bg);
  background-image:
    radial-gradient(ellipse 120% 80% at 100% -20%,rgba(88,101,242,.25),transparent 50%),
    radial-gradient(ellipse 80% 50% at 0% 100%,rgba(79,209,197,.12),transparent 45%),
    linear-gradient(180deg,#0a0f1c 0%,var(--bg) 40%);
  min-height:100vh;
}

/* —— Layout shell —— */
.shell{
  width:100%;
  max-width:1140px;
  margin:0 auto;
  padding:0 var(--space-4);
}
@media (min-width:768px){
  .shell{padding:0 var(--space-6)}
}

.container.shell{padding-top:var(--space-4);padding-bottom:var(--space-8)}

/* —— Top navigation —— */
.topbar{
  position:sticky;
  top:0;
  z-index:100;
  border-bottom:1px solid var(--border);
}
.glass{
  backdrop-filter:saturate(140%) blur(14px);
  background:rgba(8,12,24,.78);
}
.topbar-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:var(--space-4);
  min-height:3.5rem;
  flex-wrap:wrap;
}
.brand{
  color:var(--text);
  text-decoration:none;
  font-weight:700;
  font-size:var(--step-1);
  letter-spacing:-.02em;
}
.brand:hover{color:var(--text-secondary)}
.nav{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:var(--space-1) var(--space-3);
}
.nav a,.link-btn{
  color:var(--text-secondary);
  text-decoration:none;
  background:none;
  border:none;
  cursor:pointer;
  font-size:var(--step--1);
  padding:var(--space-2) var(--space-3);
  border-radius:var(--radius-sm);
  transition:color .2s,background .2s;
}
.nav a{display:inline-flex;align-items:center;gap:.4rem}
.nav a:hover,.link-btn:hover{
  color:var(--text);
  background:var(--primary-dim);
}
.link-btn{font-family:inherit}

/* —— Icons —— */
.ico-svg{
  display:inline-block;
  width:1.25em;
  height:1.25em;
  vertical-align:-0.25em;
  color:var(--icon);
  flex-shrink:0;
}
.brand .ico-svg{color:#c7d2fe}
@media (max-width:639px){
  .brand .brand-word-code{display:none}
}
.nav a .ico-svg{color:var(--muted)}
.nav a:hover .ico-svg,.link-btn:hover .ico-svg{color:var(--text-secondary)}
.inline-ico{display:inline-flex;align-items:center;gap:.45rem}
h2.inline-ico,h3.inline-ico,strong.inline-ico{display:inline-flex;align-items:center;gap:.45rem}
.wallet-side .muted.inline-ico{display:flex;align-items:center;gap:.35rem}
.wallet-side .muted.inline-ico{white-space:nowrap}
.btn-with-ico{display:inline-flex;align-items:center;gap:.45rem}
.btn .ico-svg,.btn-with-ico .ico-svg{color:var(--icon)}
.btn.primary .ico-svg,.btn.ghost-primary .ico-svg{color:rgba(255,255,255,.95)}
.card h2 .ico-svg,.card h3 .ico-svg,.modal-head h2 .ico-svg{margin-right:0;vertical-align:-0.15em}
.metric-card h3{display:flex;align-items:center;gap:.45rem}

/* —— Typography —— */
h1,h2,h3{margin:0 0 var(--space-3);font-weight:700;letter-spacing:-.02em;line-height:1.25}
h1{font-size:clamp(var(--step-3),4vw,var(--step-5))}
h2{font-size:var(--step-3)}
h3{font-size:var(--step-2)}
p{margin:0 0 var(--space-3)}
.muted{color:var(--muted)}
.eyebrow{
  font-size:var(--step--1);
  font-weight:600;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--primary);
  margin:0 0 var(--space-2);
}
.hero-lead,.lead{
  font-size:var(--step-1);
  color:var(--text-secondary);
  max-width:42rem;
  line-height:1.6;
  margin:0;
}

/* —— Page sections —— */
.page-section{margin-bottom:var(--space-6)}
.section-kicker{
  font-size:var(--step--1);
  font-weight:600;
  color:var(--muted);
  letter-spacing:.04em;
  text-transform:uppercase;
  margin:0 0 var(--space-3);
}
.section-head{margin-bottom:var(--space-3)}

/* —— Hero —— */
.hero{padding:var(--space-4) 0 var(--space-2)}
.hero--auth{text-align:center;padding-top:var(--space-6)}
.hero--auth .hero-lead{margin-left:auto;margin-right:auto}
.hero-row{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:var(--space-5);
  flex-wrap:wrap;
}
.hero-copy{min-width:min(100%,280px);flex:1}

/* —— Cards —— */
.card{
  background:linear-gradient(165deg,rgba(22,32,58,.88),var(--surface));
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:var(--space-5);
  margin:0;
  box-shadow:var(--shadow-sm);
  transition:border-color .25s,box-shadow .25s,transform .25s;
}
.card + .card{margin-top:var(--space-4)}
.card--soft{background:var(--surface-solid);box-shadow:none}
.card--elevated{box-shadow:var(--shadow-md)}
.card:hover{
  border-color:var(--border-strong);
  box-shadow:var(--shadow-md);
}
.card h2,.card .section-title{
  font-size:var(--step-2);
  margin-bottom:var(--space-4);
  padding-bottom:var(--space-3);
  border-bottom:1px solid var(--border);
}
.card.legal h2{
  margin-top:var(--space-6);
  margin-bottom:var(--space-3);
  padding-bottom:0;
  border-bottom:none;
  font-size:var(--step-2);
  color:var(--text-secondary);
}
.card.legal h2:first-of-type{margin-top:var(--space-2)}
.card.legal > p:first-of-type{font-size:var(--step-1);color:var(--text-secondary)}
.auth-card{max-width:420px;margin-left:auto;margin-right:auto}
.login-lockout-notice{
  margin:0 0 var(--space-3);
  padding:var(--space-3);
  font-size:var(--step--1);
  text-align:center;
  color:var(--warning);
  background:rgba(251,191,36,.1);
  border:1px solid rgba(251,191,36,.25);
  border-radius:var(--radius-sm);
}
.login-lockout-notice[hidden]{display:none!important}

/* —— Grid —— */
.grid{display:grid;gap:var(--space-4)}
.metrics{grid-template-columns:1fr}
.two{grid-template-columns:1fr}
@media (min-width:768px){
  .metrics{grid-template-columns:repeat(3,1fr)}
  .metrics .wallet-card{grid-column:span 3}
  .two{grid-template-columns:1fr 1fr}
}

/* —— Buttons —— */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid var(--border-strong);
  background:rgba(26,36,69,.9);
  color:var(--text);
  padding:.65rem 1.1rem;
  border-radius:var(--radius-md);
  cursor:pointer;
  font-size:var(--step--1);
  font-weight:600;
  font-family:inherit;
  transition:transform .2s,background .2s,border-color .2s,box-shadow .2s;
}
.btn:hover{
  transform:translateY(-1px);
  background:rgba(38,51,95,.95);
  border-color:rgba(255,255,255,.2);
}
.btn:focus-visible{
  outline:2px solid var(--primary);
  outline-offset:2px;
}
.btn:disabled{opacity:.55;cursor:not-allowed;transform:none}
.btn.primary{
  background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%);
  border:none;
  color:#fff;
  box-shadow:0 4px 20px rgba(99,102,241,.35);
}
.btn.primary:hover{
  filter:brightness(1.06);
  box-shadow:0 6px 28px rgba(99,102,241,.45);
}
.btn.danger{background:rgba(248,113,113,.15);border-color:rgba(248,113,113,.35);color:#fecaca}
.btn.danger:hover{background:rgba(248,113,113,.25)}
.btn.ghost-primary{
  background:var(--primary-dim);
  border-color:rgba(124,140,255,.35);
  color:#c7d2fe;
}
.btn.ghost-primary:hover{background:rgba(124,140,255,.22)}

/* Verified account label (no frame, green text) */
.btn.verified-status{
  border:none;
  background:transparent;
  color:var(--success);
  box-shadow:none;
}
.btn.verified-status:hover{
  transform:none;
  background:transparent;
  border:none;
  color:var(--success);
  filter:none;
}
.btn.verified-status:disabled{
  opacity:1;
  cursor:default;
}
.verification-indicator{
  display:inline-flex;
  align-items:center;
  margin-right:.4rem;
  vertical-align:middle;
  position:relative;
  cursor:help;
}
.verification-indicator .ico-svg{
  width:1.1em;
  height:1.1em;
}
.verification-indicator::after{
  content:attr(data-tooltip);
  position:absolute;
  left:50%;
  bottom:calc(100% + .35rem);
  transform:translateX(-50%);
  padding:.28rem .48rem;
  border-radius:var(--radius-sm);
  border:1px solid var(--border-strong);
  background:rgba(10,15,28,.96);
  color:var(--text);
  white-space:nowrap;
  font-size:var(--step--1);
  line-height:1.2;
  opacity:0;
  pointer-events:none;
  transition:opacity .15s ease;
  z-index:20;
}
.verification-indicator:hover::after,
.verification-indicator:focus::after{
  opacity:1;
}
.verification-indicator-ok .ico-svg{color:var(--success);}
.verification-indicator-pending .ico-svg{color:var(--warning);}
.verification-indicator-none .ico-svg{color:var(--muted);}
.scope-count-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:1.35rem;
  height:1.2rem;
  padding:0 .35rem;
  border-radius:999px;
  margin-left:.35rem;
  background:rgba(124,140,255,.2);
  border:1px solid rgba(124,140,255,.35);
  color:#dbe4ff;
  font-size:var(--step--1);
  font-weight:700;
  line-height:1;
}
.status-text-success{color:var(--success);font-weight:600}

/* —— Site footer —— */
.site-footer{
  margin-top:var(--space-8);
  border-top:1px solid var(--border);
  padding:var(--space-5) 0 var(--space-6);
}
.footer-inner{
  display:grid;
  grid-template-columns:repeat(3,minmax(220px,1fr));
  gap:var(--space-5) var(--space-8);
}
.footer-col{
  display:grid;
  gap:var(--space-3);
  justify-items:center;
  text-align:center;
}
.footer-title{
  margin:0;
  color:var(--text);
  font-size:var(--step--1);
  font-weight:700;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.footer-nav{
  display:grid;
  gap:var(--space-2);
  justify-items:center;
}
.footer-nav a{
  color:var(--text-secondary);
  text-decoration:none;
  font-size:var(--step--1);
  display:inline-flex;
  align-items:center;
  gap:.35rem;
}
.footer-nav a:hover{color:var(--text)}
.footer-social{
  display:flex;
  flex-wrap:wrap;
  gap:var(--space-2);
  justify-content:center;
}
.footer-social a{
  color:var(--text-secondary);
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:3.1rem;
  height:3.1rem;
  padding:0;
  border:1px solid var(--border);
  border-radius:50%;
  background:rgba(255,255,255,.03);
}
.footer-social a .ico-svg{width:1.72rem;height:1.72rem}
.footer-social a:hover{
  color:var(--text);
  border-color:var(--border-strong);
  background:rgba(124,140,255,.15);
}
.footer-copy{
  margin:0;
  font-size:var(--step--1);
  color:var(--muted);
}
.footer-copy-bottom{
  grid-column:1 / -1;
  text-align:center;
  padding-top:var(--space-3);
  border-top:1px solid var(--border);
}
.footer-copy a{
  color:var(--text-secondary);
  text-decoration:none;
  font-weight:600;
}
.footer-copy a:hover{color:var(--text);text-decoration:underline}
.footer-contacts{
  margin:0;
  display:grid;
  gap:.55rem;
  font-style:normal;
  justify-items:center;
  text-align:center;
}
.footer-contacts a,
.footer-hours,
.footer-hours-inline{
  color:var(--text-secondary);
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  font-size:var(--step--1);
  line-height:1.4;
}
.footer-contacts a:hover{
  color:var(--text);
  text-decoration:underline;
}
.footer-hours{
  color:var(--muted);
}
.footer-hours-inline{
  color:var(--muted);
  font-size:var(--step--1);
}

@media (max-width: 760px){
  .footer-inner{grid-template-columns:1fr}
  .ref-url{font-size:16px}
  .ref-qr-wrap{width:96px;height:96px}
}

/* —— Forms —— */
.stack{display:grid;gap:var(--space-4)}
label{
  display:grid;
  gap:var(--space-2);
  font-size:var(--step--1);
  font-weight:600;
  color:var(--text-secondary);
}
input,textarea,select,.select-input{
  width:100%;
  background:var(--bg-elevated);
  color:var(--text);
  border:1px solid var(--border-strong);
  border-radius:var(--radius-sm);
  padding:.7rem .85rem;
  font-size:var(--step-0);
  font-family:inherit;
  transition:border-color .2s,box-shadow .2s;
}
input::placeholder,textarea::placeholder{color:var(--muted);opacity:.8}
input:hover,textarea:hover,select:hover,.select-input:hover{border-color:rgba(255,255,255,.2)}
input:focus,textarea:focus,select:focus,.select-input:focus{
  outline:none;
  border-color:var(--primary);
  box-shadow:0 0 0 3px rgba(124,140,255,.2);
}
.field-invalid{
  border-color:rgba(248,113,113,.75) !important;
  box-shadow:0 0 0 3px rgba(248,113,113,.2) !important;
}
.field-error{
  margin-top:.35rem;
  color:#fecaca;
  font-size:var(--step--1);
  line-height:1.4;
}
textarea{min-height:100px;resize:vertical}
select,.select-input{appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--muted) 50%),linear-gradient(135deg,var(--muted) 50%,transparent 50%);background-position:calc(100% - 16px) calc(50% - 2px),calc(100% - 10px) calc(50% - 2px);background-size:6px 6px,6px 6px;background-repeat:no-repeat;padding-right:2rem}

.toggle{
  display:flex;
  background:var(--bg-elevated);
  border-radius:var(--radius-md);
  padding:4px;
  margin-bottom:var(--space-5);
  border:1px solid var(--border);
}
.toggle a{
  flex:1;
  text-align:center;
  text-decoration:none;
  color:var(--muted);
  padding:.55rem .75rem;
  border-radius:var(--radius-sm);
  font-weight:600;
  font-size:var(--step--1);
  transition:background .2s,color .2s;
}
.toggle a.active{
  background:linear-gradient(135deg,rgba(99,102,241,.35),rgba(139,92,246,.25));
  color:#fff;
  box-shadow:var(--shadow-sm);
}

/* —— File upload —— */
.file-input{
  width:100%;
  padding:var(--space-4);
  border:1px dashed rgba(157,176,255,.35);
  border-radius:var(--radius-md);
  background:
    radial-gradient(circle at 90% 0%,rgba(124,140,255,.12),transparent 42%),
    linear-gradient(160deg,var(--bg-elevated),rgba(19,36,79,.6));
}
.file-input::file-selector-button{
  margin-right:.75rem;
  border:1px solid rgba(183,196,255,.45);
  background:linear-gradient(135deg,#6366f1,#8b5cf6);
  color:#fff;
  padding:.85rem 1.15rem;
  border-radius:var(--radius-sm);
  font-weight:700;
  font-size:var(--step--1);
  cursor:pointer;
  font-family:inherit;
  transition:filter .2s,transform .2s;
}
.file-input::file-selector-button:hover{
  filter:brightness(1.08);
  transform:translateY(-1px);
}
.upload-guide{
  display:grid;
  gap:var(--space-2);
  padding:var(--space-4);
  border:1px solid var(--border);
  border-radius:var(--radius-md);
  background:rgba(15,23,42,.5);
}
.account-line{position:relative;display:block}
.account-line > label:first-child{
  display:block;
  width:100%;
  padding-right:0;
}
.account-line input[name="account_number"]{
  width:100%;
  display:block;
}
.reg-type-switch{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:var(--space-2);
  padding:0;
  background:transparent;
  margin:auto;
  min-width:136px;
}
.reg-type-option{position:relative;display:block}
.reg-type-option input{
  position:absolute;
  inset:0;
  opacity:0;
  margin:0;
  cursor:pointer;
}
.reg-type-option > span{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:2.8rem;
  border-radius:999px;
  border:1px solid var(--border-strong);
  background:rgba(14,20,40,.65);
  transition:all .2s;
}
.reg-type-option > span .ico-svg{
  width:1.55rem;
  height:1.55rem;
}
.reg-type-option input:checked + span{
  background:linear-gradient(135deg,rgba(79,209,197,.22),rgba(99,102,241,.24));
  border-color:rgba(124,140,255,.45);
  box-shadow:0 0 0 2px rgba(124,140,255,.2), var(--shadow-sm);
}
.reg-type-option input:focus-visible + span{
  outline:2px solid var(--primary);
  outline-offset:2px;
}
.reg-type-option::after{
  content:attr(data-tooltip);
  position:absolute;
  left:50%;
  bottom:calc(100% + .4rem);
  transform:translateX(-50%);
  padding:.2rem .45rem;
  border-radius:var(--radius-sm);
  border:1px solid var(--border-strong);
  background:rgba(10,15,28,.96);
  color:var(--text);
  font-size:var(--step--1);
  line-height:1.2;
  white-space:nowrap;
  opacity:0;
  pointer-events:none;
  transition:opacity .15s ease;
}
.reg-type-option:hover::after,
.reg-type-option:focus-within::after{
  opacity:1;
}
.password-wrap{position:relative}
.password-wrap input{padding-right:2.6rem}
.password-eye{
  position:absolute;
  right:.4rem;
  top:50%;
  transform:translateY(-50%);
  width:2rem;
  height:2rem;
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  background:rgba(255,255,255,.06);
  color:var(--text-secondary);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
}
.password-eye:hover{background:rgba(255,255,255,.1);color:var(--text)}
.consent-check{
  display:flex;
  align-items:flex-start;
  flex-wrap:wrap;
  gap:.6rem;
  font-weight:500;
  line-height:1.45;
}
.consent-check > span{
  flex:1;
  min-width:0;
}
.consent-check input[type="checkbox"]{
  width:1rem;
  height:1rem;
  margin-top:.15rem;
  accent-color:var(--primary);
  flex-shrink:0;
}
.consent-check a{color:#c7d2fe;text-decoration:underline}
.consent-check a:hover{color:#fff}
.consent-check .field-error{
  flex-basis:100%;
  margin:.2rem 0 0 1.6rem;
}

/* —— Wallet & metrics —— */
.wallet-card{
  display:flex;
  gap:var(--space-5);
  justify-content:space-between;
  align-items:stretch;
  flex-wrap:wrap;
  padding:var(--space-6);
}
.wallet-main{flex:1;min-width:200px}
.wallet-main h3{
  margin:0 0 var(--space-2);
  font-size:var(--step--1);
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.06em;
  color:var(--muted);
}
.wallet-main p{
  font-size:clamp(1.75rem,4vw,2.35rem);
  font-weight:800;
  letter-spacing:-.03em;
  margin:0 0 var(--space-4);
  color:var(--text);
  font-variant-numeric:tabular-nums;
}
.wallet-main .btn{margin-top:0}
.wallet-side{display:flex;gap:var(--space-3);min-width:200px;align-content:center;flex-wrap:wrap;align-items:stretch}
.wallet-side{
  display:flex;
  gap:var(--space-3);
  min-width:200px;
  flex-wrap:wrap;
  align-items:stretch;
}
.wallet-side > div{
  padding:var(--space-4);
  border:1px solid var(--border);
  border-radius:var(--radius-md);
  background:rgba(12,18,36,.55);
  flex:1 1 240px;
  display:flex;
  flex-direction:column;
  gap:var(--space-3);
  justify-content:center;
}
.wallet-side > div .icon-btn{
  align-self:flex-end;
}
.wallet-side strong{
  display:block;
  font-size:var(--step-2);
  font-weight:700;
  margin-top:var(--space-2);
  font-variant-numeric:tabular-nums;
}
@media (min-width: 980px){
  .wallet-side{flex-wrap:nowrap}
  .wallet-side > div{flex:1 1 0}
}
.metric-card{padding:var(--space-5)}
.metric-card h3{
  margin:0 0 var(--space-2);
  font-size:var(--step--1);
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.05em;
  color:var(--muted);
}
.metric-card p{
  font-size:var(--step-4);
  font-weight:800;
  margin:0;
  font-variant-numeric:tabular-nums;
  color:var(--text);
}
.metric-updated{animation:pulseUp .45s ease}

.ref-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:var(--space-4);
}
.ref-main{
  display:flex;
  align-items:center;
  gap:var(--space-4);
  flex:1 1 auto;
  min-width:0;
}
.ref-row strong{font-size:var(--step-1)}
.ref-qr-wrap{
  position:relative;
  width:112px;
  height:112px;
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  overflow:hidden;
  flex:0 0 auto;
  background:#fff;
}
.ref-qr-image{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.ref-qr-download{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  border:none;
  background:rgba(5,9,18,.62);
  color:#fff;
  opacity:0;
  transition:opacity .18s ease;
  cursor:pointer;
}
.ref-qr-wrap:hover .ref-qr-download,
.ref-qr-wrap:focus-within .ref-qr-download{
  opacity:1;
}
.ref-qr-download .ico-svg{width:1.55rem;height:1.55rem;color:#fff}
.helper-text{font-size:var(--step--1);color:var(--muted);margin-top:var(--space-2);line-height:1.5}
.phone-block-notice{color:var(--warning);font-weight:600}
.ref-url{
  word-break:break-all;
  font-size:18px;
  flex:1 1 auto;
  min-width:0;
  padding:var(--space-3);
  background:var(--bg-elevated);
  border-radius:var(--radius-sm);
  border:1px solid var(--border);
  font-family:ui-monospace,SFMono-Regular,monospace;
  color:var(--success);
}
.ref-row > .btn{
  flex:0 0 auto;
  white-space:nowrap;
}

@media (max-width: 980px){
  .ref-row{
    flex-direction:column;
    align-items:flex-start;
  }
  .ref-main{
    width:100%;
    flex-direction:column;
    align-items:flex-start;
  }
}

/* —— Tables —— */
.table-wrap{
  overflow:auto;
  margin:0 calc(-1 * var(--space-1));
  border-radius:var(--radius-md);
  border:1px solid var(--border);
}
table{width:100%;border-collapse:collapse;font-size:var(--step--1)}
thead{background:rgba(12,18,36,.85)}
th{
  text-align:left;
  padding:.75rem 1rem;
  font-weight:600;
  font-size:var(--step--1);
  color:var(--text-secondary);
  border-bottom:1px solid var(--border);
  white-space:nowrap;
}
td{
  padding:.75rem 1rem;
  border-bottom:1px solid var(--border);
  vertical-align:middle;
}
tbody tr:hover{background:rgba(124,140,255,.04)}
tbody tr:last-child td{border-bottom:none}

.ok{color:var(--accent);font-weight:600}
.student-net-income{
  color:var(--success);
  font-weight:700;
  font-variant-numeric:tabular-nums;
}
.student-status{font-weight:700}
.student-status-1{color:#a78bfa} /* Նոր ուսման հայտ */
.student-status-2{color:var(--muted)} /* Որոշում չի կայացրել */
.student-status-3{color:var(--warning)} /* Հաստաել է մասնակցությունը */
.student-status-4{color:var(--success)} /* Ընթացիկ ուսանող */
.student-status-5{color:#15d7ed} /* Ուսումը ավարտել է */
.student-status-6{color:var(--danger)} /* Չեղարկվել է */
.student-status-0{color:var(--muted)}
.student-status-unknown{color:var(--muted)}
.inline-form{display:inline}
.inline-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:var(--space-3);
  border-bottom:1px solid var(--border);
  padding:var(--space-3) 0;
  flex-wrap:wrap;
}
.inline-row:last-child{border-bottom:none}

/* —— Legal —— */
.legal h2{font-size:var(--step-2);margin-top:var(--space-6);margin-bottom:var(--space-3);color:var(--text-secondary)}
.legal ul{padding-left:1.25rem}
.legal li{margin-bottom:var(--space-2)}

/* —— Toast & feedback —— */
.toast{
  position:fixed;
  right:var(--space-4);
  bottom:var(--space-4);
  max-width:min(360px,calc(100% - 2rem));
  background:var(--surface-solid);
  border:1px solid var(--border-strong);
  color:var(--text);
  padding:var(--space-4);
  border-radius:var(--radius-md);
  box-shadow:var(--shadow-lg);
  opacity:0;
  transform:translateY(8px);
  transition:opacity .3s,transform .3s;
  font-size:var(--step--1);
  z-index:2000;
}
.toast.show{opacity:1;transform:translateY(0)}
.form-feedback{
  margin-top:var(--space-3);
  padding:var(--space-3) var(--space-4);
  border-radius:var(--radius-sm);
  font-size:var(--step--1);
  display:none;
}
.form-feedback.show{display:block;animation:fadeSlide .3s ease}
.form-feedback.ok{
  background:rgba(52,211,153,.12);
  border:1px solid rgba(52,211,153,.35);
  color:#a7f3d0;
}
.form-feedback.err{
  background:rgba(248,113,113,.12);
  border:1px solid rgba(248,113,113,.35);
  color:#fecaca;
}
.status-pill{
  display:inline-block;
  padding:.2rem .65rem;
  border-radius:999px;
  border:1px solid var(--border);
  font-size:var(--step--1);
  font-weight:600;
}
.status-pill.pending{background:rgba(251,191,36,.12);color:#fde68a;border-color:rgba(251,191,36,.35)}
.status-pill.approved{background:rgba(52,211,153,.12);color:#a7f3d0;border-color:rgba(52,211,153,.35)}

/* —— Modals —— */
.modal-backdrop{
  position:fixed;
  inset:0;
  background:rgba(3,7,18,.72);
  backdrop-filter:blur(8px);
  display:none;
  align-items:center;
  justify-content:center;
  padding:var(--space-4);
  z-index:1000;
}
.modal-backdrop.open{display:flex;animation:fadeSlide .25s ease}
.modal-card{
  width:min(520px,100%);
  max-height:min(90vh,720px);
  overflow-y:auto;
  background:linear-gradient(180deg,rgba(22,32,58,.98),rgba(12,18,36,.98));
  border:1px solid var(--border-strong);
  border-radius:var(--radius-xl);
  padding:var(--space-6);
  box-shadow:var(--shadow-lg);
}
.modal-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:var(--space-4);
  margin-bottom:var(--space-5);
  padding-bottom:var(--space-4);
  border-bottom:1px solid var(--border);
}
.modal-head h2{margin:0;flex:1;font-size:var(--step-3)}
.modal-desc{font-size:var(--step--1);color:var(--muted);margin:var(--space-2) 0 0;line-height:1.5}
.icon-btn{
  flex-shrink:0;
  width:2.25rem;
  height:2.25rem;
  border-radius:var(--radius-sm);
  border:1px solid var(--border);
  background:rgba(255,255,255,.06);
  color:var(--text-secondary);
  font-size:1.25rem;
  line-height:1;
  cursor:pointer;
  transition:background .2s,color .2s;
}
.icon-btn:hover{background:rgba(255,255,255,.1);color:var(--text)}
.icon-btn .ico-svg{
  width:1.35em;
  height:1.35em;
  vertical-align:-0.25em;
}

/* —— Navbar user dropdown —— */
.user-dropdown{
  position:relative;
}
.user-dropdown-menu{
  position:absolute;
  right:0;
  top:calc(100% + .5rem);
  min-width:180px;
  background:rgba(10,15,28,.95);
  border:1px solid var(--border);
  border-radius:var(--radius-md);
  box-shadow:var(--shadow-md);
  padding:.35rem;
  z-index:200;
  display:none;
}
.user-dropdown.open .user-dropdown-menu{
  display:block;
}
.user-dropdown-item{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:.6rem;
  border:none;
  background:transparent;
  color:var(--text);
  padding:.65rem .75rem;
  border-radius:var(--radius-sm);
  cursor:pointer;
  font-weight:600;
  font-size:var(--step--1);
  font-family:inherit;
  text-decoration:none;
  white-space:nowrap;
}
.user-dropdown-item:hover{
  background:rgba(124,140,255,.18);
  color:var(--text);
}
.user-dropdown-form{margin:0}
.user-dropdown-btn{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:var(--space-2);
  width:100%;
  text-decoration:none;
}
.dropdown-caret{
  margin-left:auto;
  width:.55rem;
  height:.55rem;
  border-right:2px solid var(--muted);
  border-bottom:2px solid var(--muted);
  transform:rotate(45deg);
  flex-shrink:0;
}

/* —— Admin panel —— */
.admin-menu{
  display:flex;
  flex-wrap:wrap;
  gap:var(--space-2);
  align-items:center;
  margin:var(--space-4) 0;
}
.admin-menu a{
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  padding:.55rem .75rem;
  border-radius:var(--radius-sm);
  border:1px solid var(--border);
  background:rgba(12,18,36,.55);
  color:var(--text-secondary);
  font-weight:700;
  font-size:var(--step--1);
}
.admin-menu a:hover{
  color:var(--text);
  border-color:rgba(124,140,255,.5);
  background:rgba(124,140,255,.12);
}
.admin-menu a.active{
  color:var(--text);
  border-color:rgba(124,140,255,.65);
  background:rgba(124,140,255,.22);
  box-shadow:0 0 0 1px rgba(124,140,255,.22);
}
.admin-menu a.active .ico-svg{color:var(--primary);}
.admin-menu a.active:hover{
  border-color:rgba(124,140,255,.75);
  background:rgba(124,140,255,.28);
}
.admin-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:1.5rem;
  height:1.25rem;
  padding:0 .4rem;
  border-radius:999px;
  background:rgba(248,113,113,.18);
  border:1px solid rgba(248,113,113,.35);
  color:#fecaca;
  font-weight:800;
  font-size:.85em;
}
.admin-table-wrap{overflow:visible !important;margin:0 !important}
.admin-table-wrap table a:not(.btn){
  color:#fff;
  text-decoration:underline;
  text-underline-offset:2px;
}
.admin-table-wrap table a:not(.btn):hover{
  color:#fff;
  opacity:.88;
}
.admin-table-wrap .link-btn{
  color:#fff !important;
}
.admin-table-wrap .link-btn:hover{
  color:#fff !important;
  background:rgba(255,255,255,.12);
}
.admin-table-wrap .link-btn .ico-svg{color:var(--muted)}
.admin-table-wrap .link-btn:hover .ico-svg{color:#fff}
.admin-inline-actions{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-3)}
.admin-inline-form{margin:0;display:inline}
.status-text-warning{color:var(--warning);font-weight:700}
.status-text-danger{color:var(--danger);font-weight:700}
.admin-user-info{
  display:flex;
  flex-direction:column;
  gap:.15rem;
  color:var(--text-secondary);
}
.admin-user-info strong{color:var(--text)}
.admin-remove-icon .ico-svg{color:var(--danger)}

/* —— Referral + media row —— */
.ref-media-row{
  display:grid;
  grid-template-columns:3fr 1fr;
  gap:var(--space-5);
  align-items:stretch;
}
@media (max-width:900px){
  .ref-media-row{grid-template-columns:1fr;}
}
.ref-media-col{
  display:flex;
  flex-direction:column;
  min-width:0;
  align-self:stretch;
}
.ref-media-col > .card{
  flex:1;
  display:flex;
  flex-direction:column;
  min-height:0;
}
.media-folder-card{
  text-align:left;
  width:100%;
  cursor:default;
  transition:transform .15s ease, box-shadow .15s ease;
  position:relative;
  display:flex;
  flex-direction:column;
  align-items:stretch;
}
/* Match wallet «Ստացված եկամուտ» icon-btn: color + scale + stroke weight */
.media-folder-card .section-head strong.inline-ico{
  font-size:1.25rem;
  font-weight:700;
  color:var(--text);
}
.media-folder-card .section-head strong.inline-ico .ico-svg{
  width:1.5em;
  height:1.5em;
  color:var(--text-secondary);
}
.media-folder-card:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow-md);
}
.media-folder-preview{margin-top:var(--space-2);min-height:3.5rem;}
.media-folder-strip{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:flex-start;align-items:center;}
.media-folder-thumb{
  width:56px;height:56px;border-radius:var(--radius-sm);overflow:hidden;
  border:1px solid var(--border);background:#fff;position:relative;
}
button.media-folder-thumb{
  padding:0;margin:0;font:inherit;color:inherit;
  cursor:pointer;
  -webkit-appearance:none;appearance:none;
}
.media-folder-thumb--folder{
  display:flex;align-items:center;justify-content:center;
  padding:0;
  width:56px;min-width:56px;height:56px;min-height:56px;
  font-size:1.25rem;
  line-height:1;
  background:rgba(255,255,255,.06);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  color:var(--text-secondary);
  box-shadow:none;
  transition:background .2s,color .2s,border-color .2s;
}
.media-folder-thumb--folder:hover{
  background:rgba(255,255,255,.1);
  color:var(--text);
  border-color:var(--border-strong);
}
.media-folder-tile-icons{
  position:relative;z-index:1;
  display:inline-flex;align-items:center;justify-content:center;
}
.media-folder-thumb--folder .media-folder-tile-icons .ico-svg{
  width:2rem;
  height:2rem;
  vertical-align:-0.25em;
}
.media-folder-tile-overlay{
  position:absolute;inset:0;z-index:2;
  display:flex;align-items:center;justify-content:center;
  background:rgba(6,10,20,.82);
  opacity:0;
  transition:opacity .15s ease;
  pointer-events:none;
  border-radius:var(--radius-sm);
}
.media-folder-thumb--folder:hover .media-folder-tile-overlay,
.media-folder-thumb--folder:focus-visible .media-folder-tile-overlay{opacity:1;}
.media-folder-tile-overlay-arrow{display:flex;align-items:center;justify-content:center;}
.media-folder-tile-overlay-arrow .ico-svg{width:1.5rem;height:1.5rem;color:#fff;}
@media (max-width:900px){
  .media-folder-strip>button[data-media-thumb-id]:nth-child(5){display:none;}
}
.media-folder-thumb img,.media-folder-thumb video{width:100%;height:100%;object-fit:cover;display:block;}
.media-folder-thumb--video .media-folder-play{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.4);color:#fff;font-size:.75rem;
}
.modal-card.modal-card--wide{width:min(960px,100%);max-height:min(90vh,88vh);}
#mediaContentModalDialog.modal-card--media-narrow.modal-card--wide{
  width:min(550px,100%);
  max-width:550px;
}
#mediaContentModal:has(.media-content-modal-body--grid) .modal-card.modal-card--wide:not(.modal-card--media-narrow){
  width:min(1180px,100%);
  max-width:none;
}
.media-content-modal-body{display:grid;gap:var(--space-5);padding-top:var(--space-2);}
@media (min-width:768px){
  .media-content-modal-body--grid{
    grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
    align-items:start;
  }
}
.media-content-modal-body--grid .media-content-card{display:flex;flex-direction:column;min-width:0;}
.media-content-modal-body--grid .media-content-card-media{max-height:200px;}
.media-content-modal-body--grid .media-content-card-media img,
.media-content-modal-body--grid .media-content-card-media video{max-height:200px;}
.media-content-modal-body--grid .media-content-text{max-height:160px;font-size:var(--step--2);}
.media-content-card{
  border:1px solid var(--border);
  border-radius:var(--radius-md);
  overflow:hidden;
  background:rgba(12,18,36,.65);
}
.media-content-card-media{
  position:relative;
  max-height:320px;
  background:#0a0e18;
}
.media-content-card-media img,.media-content-card-media video{
  width:100%;max-height:320px;object-fit:contain;display:block;
}
a.media-content-card-download-btn.btn.primary{
  position:absolute;
  top:0;
  right:0;
  z-index:2;
  width:2.75rem;
  height:2.75rem;
  min-height:0;
  min-width:0;
  padding:0;
  margin:0;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:0 var(--radius-sm) 0 0;
  text-decoration:none;
  box-shadow:0 2px 8px rgba(0,0,0,.35);
}
.media-content-download-ico{display:flex;align-items:center;justify-content:center;}
.media-content-download-ico .ico-svg{width:1.25rem;height:1.25rem;}
.media-content-text{
  white-space:pre-wrap;
  word-break:break-word;
  margin:0;
  padding:var(--space-4);
  font-size:var(--step--1);
  line-height:1.55;
  max-height:220px;
  overflow:auto;
  font-family:inherit;
}
.media-content-card-copy{
  padding:0 var(--space-4) var(--space-4);
}
.media-content-btn-block{
  display:flex;
  width:100%;
  box-sizing:border-box;
  justify-content:center;
  text-align:center;
}
a.media-content-btn-block{text-decoration:none;}
.media-content-modal-body--grid .media-content-card-copy{
  padding-left:var(--space-3);
  padding-right:var(--space-3);
}
.admin-media-ref-hint{
  margin:var(--space-2) 0 var(--space-3);
  padding:var(--space-3);
  border-radius:var(--radius-md);
  border:1px solid var(--border);
  background:rgba(124,140,255,.08);
}
.admin-media-ref-hint-text{margin:0 0 var(--space-2);}
.admin-media-token{
  display:inline-block;padding:.12rem .4rem;margin:0 .15rem;
  font-size:.88em;border-radius:var(--radius-sm);
  border:1px solid var(--border-strong);
  background:rgba(12,18,36,.55);
  font-family:ui-monospace,SFMono-Regular,Consolas,monospace;
  color:var(--accent);
  white-space:nowrap;
}
button.admin-media-token--insert{
  margin:0 .15rem 0 0;
  cursor:pointer;
  font:inherit;line-height:inherit;
  -webkit-appearance:none;appearance:none;
}
button.admin-media-token--insert:hover{
  border-color:rgba(168,180,255,.75);
  background:rgba(124,140,255,.15);
}
button.admin-media-token--insert:focus-visible{
  outline:2px solid var(--accent);
  outline-offset:2px;
}
.admin-media-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(320px,1fr));
  gap:var(--space-5);
}
.admin-media-item-card{padding-bottom:var(--space-4);}
.admin-media-item-preview{
  max-height:220px;
  border-radius:var(--radius-md);
  overflow:hidden;
  margin-bottom:var(--space-4);
  background:#000;
}
.admin-media-item-preview img,.admin-media-item-preview video{width:100%;max-height:220px;object-fit:contain;}
.admin-media-textarea{width:100%;min-height:140px;font-family:inherit;font-size:var(--step--1);}
.admin-media-item-actions-row{
  display:flex;
  flex-wrap:wrap;
  gap:var(--space-3);
  align-items:center;
  margin-top:var(--space-4);
}
.admin-media-item-actions-row .admin-media-delete-form{margin:0;}
.admin-media-form-card{margin-bottom:var(--space-5);}

@keyframes fadeSlide{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulseUp{0%{transform:scale(1)}50%{transform:scale(1.02)}100%{transform:scale(1)}}

/* —— Reduced motion —— */
.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;
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
}
