/* ── Design tokens ─────────────────────────────────────────────────────────── */
:root {
  --bg:      #0a0a0a;
  --bg-1:    #0f0f0f;
  --bg-2:    #141414;
  --bg-3:    #1a1a1a;
  --bg-4:    #222222;
  --bg-5:    #2a2a2a;

  --bd:      rgba(255,255,255,.07);
  --bd-2:    rgba(255,255,255,.12);
  --bd-3:    rgba(255,255,255,.18);

  --blue:    #3b82f6;
  --blue-dk: #2563eb;
  --blue-lt: #60a5fa;
  --blue-xs: rgba(59,130,246,.06);

  --green:   #22c55e;
  --green-lt:#86efac;
  --red:     #ef4444;
  --red-lt:  #fca5a5;
  --amber:   #f59e0b;
  --amber-lt:#fcd34d;

  --t1: #f0f0f0;
  --t2: #888888;
  --t3: #505050;

  --sans: 'Play', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --r:   8px;
  --r-sm:5px;
  --ease:cubic-bezier(.4,0,.2,1);
  --sh:  0 4px 24px rgba(0,0,0,.55);
}

/* ── Reset ─────────────────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;-webkit-text-size-adjust:100%}
body{font-family:var(--sans);background:var(--bg);color:var(--t1);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased}
a{color:var(--blue-lt);text-decoration:none;transition:color .15s}
a:hover{color:var(--t1)}
button,input,select,textarea{font-family:inherit;font-size:inherit}
img,svg{display:block;max-width:100%}
ul{list-style:none}

/* ── Layout helpers ────────────────────────────────────────────────────────── */
.wrap{width:100%;max-width:1200px;margin:0 auto;padding:0 1.75rem}
.flex{display:flex}
.grid{display:grid}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}

/* ── Buttons ───────────────────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.65rem 1.375rem;border-radius:var(--r-sm);border:none;cursor:pointer;
  font-weight:600;font-size:.875rem;letter-spacing:.01em;
  transition:background .18s var(--ease),color .18s,opacity .18s,transform .12s;
  user-select:none;white-space:nowrap;position:relative;
}
.btn:active{transform:scale(.975)}
.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}

.btn-primary{background:var(--blue);color:#fff}
.btn-primary:hover{background:var(--blue-dk)}
.btn-ghost{background:transparent;color:var(--t2);border:1px solid var(--bd-2)}
.btn-ghost:hover{border-color:var(--bd-3);color:var(--t1)}
.btn-danger{background:rgba(239,68,68,.12);color:var(--red-lt);border:1px solid rgba(239,68,68,.2)}
.btn-danger:hover{background:rgba(239,68,68,.2)}
.btn-success{background:rgba(34,197,94,.12);color:var(--green-lt);border:1px solid rgba(34,197,94,.2)}
.btn-success:hover{background:rgba(34,197,94,.2)}
.btn-full{width:100%}
.btn-lg{padding:.8rem 1.75rem;font-size:.9375rem}
.btn-sm{padding:.4rem .875rem;font-size:.8125rem}

.btn-spin{
  width:16px;height:16px;border:2px solid rgba(255,255,255,.3);
  border-top-color:#fff;border-radius:50%;
  animation:spin .7s linear infinite;display:none;
}
.btn.loading .btn-lbl{opacity:.3}
.btn.loading .btn-spin{display:block}

/* ── Forms ─────────────────────────────────────────────────────────────────── */
.field{display:flex;flex-direction:column;gap:.35rem}
.field label{font-size:.8125rem;font-weight:500;color:var(--t2);letter-spacing:.03em}
.field input,.field textarea,.field select{
  background:var(--bg-3);border:1px solid var(--bd-2);border-radius:var(--r-sm);
  color:var(--t1);padding:.7rem .95rem;outline:none;
  transition:border-color .18s,box-shadow .18s;
  width:100%;
}
.field input::placeholder,.field textarea::placeholder{color:var(--t3)}
.field input:focus,.field textarea:focus,.field select:focus{
  border-color:rgba(59,130,246,.5);
  box-shadow:0 0 0 3px rgba(59,130,246,.09);
}
.field textarea{resize:vertical;min-height:96px}
.field-error{font-size:.78rem;color:var(--red-lt);margin-top:.2rem;display:none}
.field.has-error input,.field.has-error textarea{border-color:rgba(239,68,68,.5)}
.field.has-error .field-error{display:block}

.form-msg{
  padding:.7rem 1rem;border-radius:var(--r-sm);font-size:.875rem;
  display:none;margin-top:.75rem;
}
.form-msg.ok{background:rgba(34,197,94,.07);border:1px solid rgba(34,197,94,.22);color:var(--green-lt);display:block}
.form-msg.err{background:rgba(239,68,68,.07);border:1px solid rgba(239,68,68,.22);color:var(--red-lt);display:block}
.form-msg.info{background:rgba(59,130,246,.07);border:1px solid rgba(59,130,246,.22);color:var(--blue-lt);display:block}

.pw-wrap{position:relative}
.pw-toggle{
  position:absolute;right:.75rem;top:50%;transform:translateY(-50%);
  background:none;border:none;cursor:pointer;color:var(--t3);padding:.25rem;
  transition:color .15s;
}
.pw-toggle:hover{color:var(--t2)}

/* ── Auth layout ───────────────────────────────────────────────────────────── */
.auth-bg{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  padding:2rem 1rem;
  background:
    radial-gradient(ellipse 80% 55% at 50% -10%, rgba(59,130,246,.08) 0%, transparent 65%),
    var(--bg);
  position:relative;overflow:hidden;
}
.auth-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.022) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.022) 1px,transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(ellipse 90% 90% at 50% 50%,#000 30%,transparent 100%);
  pointer-events:none;
}

.auth-card{
  width:100%;max-width:480px;position:relative;z-index:1;
}
.auth-card-inner{
  background:var(--bg-2);border:1px solid var(--bd-2);border-radius:12px;
  padding:2.5rem;box-shadow:var(--sh);
}

.auth-logo{
  display:flex;align-items:center;gap:.625rem;margin-bottom:2rem;
  justify-content:center;
}
.auth-logo img{height:28px;filter:brightness(0) invert(1);opacity:.9}
.auth-logo-text{font-size:1rem;font-weight:700;letter-spacing:.08em;color:var(--t1);text-transform:uppercase}

.auth-title{font-size:1.5rem;font-weight:700;color:var(--t1);margin-bottom:.375rem;text-align:center}
.auth-sub{font-size:.875rem;color:var(--t2);text-align:center;margin-bottom:1.75rem}
.auth-link{color:var(--blue-lt);font-weight:500}
.auth-link:hover{color:var(--t1)}
.auth-footer{text-align:center;font-size:.8125rem;color:var(--t3);margin-top:1.25rem}

/* ── Multi-step registration ───────────────────────────────────────────────── */
.auth-card-wide{max-width:560px}

.step-indicator{
  display:flex;align-items:center;justify-content:center;margin-bottom:2rem;gap:0;
}
.step-node{
  display:flex;flex-direction:column;align-items:center;gap:.375rem;position:relative;z-index:1;
}
.step-circle{
  width:32px;height:32px;border-radius:50%;border:2px solid var(--bd-3);
  display:flex;align-items:center;justify-content:center;
  font-size:.75rem;font-weight:700;color:var(--t3);
  transition:all .35s var(--ease);background:var(--bg-2);
}
.step-node.active   .step-circle{border-color:var(--blue);color:var(--blue);background:rgba(59,130,246,.1)}
.step-node.done     .step-circle{border-color:var(--green);background:rgba(34,197,94,.1)}
.step-node.done     .step-circle::after{content:'✓';color:var(--green-lt);font-size:.8rem}
.step-node.done     .step-num{display:none}
.step-label{font-size:.7rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--t3);transition:color .25s}
.step-node.active   .step-label{color:var(--blue-lt)}
.step-node.done     .step-label{color:var(--green-lt)}
.step-line{flex:1;height:1px;background:var(--bd-2);margin:0 .25rem;transition:background .4s;min-width:24px;margin-bottom:1.3rem}
.step-line.done{background:rgba(34,197,94,.4)}

/* Step panels */
.steps-container{overflow:hidden;position:relative;min-height:200px}
.step-panel{display:none}
.step-panel.active{display:block}
.step-panel.panel-out{
  position:absolute;top:0;left:0;width:100%;
  pointer-events:none;
  animation:stepOut .3s var(--ease) both;
}
.step-panel.panel-out-back{
  position:absolute;top:0;left:0;width:100%;
  pointer-events:none;
  animation:stepOutBack .3s var(--ease) both;
}
.step-panel.panel-in{animation:stepIn .38s var(--ease) both}
.step-panel.panel-in-back{animation:stepBack .38s var(--ease) both}

@keyframes stepIn    {from{opacity:0;transform:translateX(32px)} to{opacity:1;transform:none}}
@keyframes stepOut   {to  {opacity:0;transform:translateX(-32px)}}
@keyframes stepBack  {from{opacity:0;transform:translateX(-32px)}to{opacity:1;transform:none}}
@keyframes stepOutBack{to {opacity:0;transform:translateX(32px)}}

.step-nav{
  display:flex;gap:.75rem;margin-top:1.5rem;
  justify-content:space-between;align-items:center;
}
.step-nav .back-group{display:flex;align-items:center}

/* Survey cards */
.survey-grid{display:grid;grid-template-columns:1fr 1fr;gap:.625rem;margin-top:.25rem}
.survey-opt{
  position:relative;cursor:pointer;
}
.survey-opt input[type="radio"]{position:absolute;opacity:0;pointer-events:none}
.survey-card{
  padding:.875rem 1rem;border:1px solid var(--bd-2);border-radius:var(--r);
  background:var(--bg-3);transition:all .18s var(--ease);
  display:flex;flex-direction:column;gap:.25rem;
  height:100%;
}
.survey-card:hover{border-color:var(--bd-3);background:var(--bg-4)}
.survey-opt input:checked ~ .survey-card{
  border-color:rgba(59,130,246,.5);
  background:rgba(59,130,246,.06);
  box-shadow:0 0 0 1px rgba(59,130,246,.2);
}
.survey-icon{width:28px;height:28px;color:var(--t2);display:flex;align-items:center;justify-content:center;margin-bottom:.375rem;transition:color .18s}
.survey-opt input:checked ~ .survey-card .survey-icon{color:var(--blue-lt)}
.survey-title{font-size:.8125rem;font-weight:600;color:var(--t1)}
.survey-desc{font-size:.75rem;color:var(--t2);line-height:1.4}

/* Use-case checkboxes */
.usecase-list{display:flex;flex-direction:column;gap:.5rem;margin-top:.25rem}
.usecase-opt{position:relative;cursor:pointer;display:flex;align-items:center;gap:.75rem;padding:.65rem .875rem;border:1px solid var(--bd-2);border-radius:var(--r-sm);background:var(--bg-3);transition:all .18s}
.usecase-opt:hover{border-color:var(--bd-3)}
.usecase-opt input{position:absolute;opacity:0;pointer-events:none}
.usecase-check{
  width:18px;height:18px;border:1.5px solid var(--t3);border-radius:4px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;transition:all .18s;
}
.usecase-opt input:checked ~ .usecase-check{background:var(--blue);border-color:var(--blue)}
.usecase-opt input:checked ~ .usecase-check::after{content:'✓';color:#fff;font-size:.6875rem;font-weight:700}
.usecase-text{font-size:.875rem;color:var(--t2)}
.usecase-opt input:checked ~ .usecase-text{color:var(--t1)}

/* Success step */
.step-success{text-align:center;padding:1rem 0}
.success-icon{
  width:64px;height:64px;border-radius:50%;
  background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.25);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 1.5rem;
  animation:successPop .5s var(--ease) both;
}
.success-icon svg{width:28px;height:28px;color:var(--green-lt)}
@keyframes successPop{from{scale:.5;opacity:0}to{scale:1;opacity:1}}
.step-success h3{font-size:1.25rem;font-weight:700;margin-bottom:.5rem}
.step-success p{font-size:.875rem;color:var(--t2);line-height:1.7;max-width:360px;margin:0 auto}

/* Password strength */
.pw-strength{margin-top:.375rem;display:flex;flex-direction:column;gap:.375rem}
.pw-bars{display:flex;gap:3px}
.pw-bar{flex:1;height:3px;border-radius:2px;background:var(--bd-2);transition:background .3s}
.pw-bar.w{background:var(--red)}
.pw-bar.f{background:var(--amber)}
.pw-bar.g{background:var(--green)}
.pw-hint{font-size:.7375rem;color:var(--t3)}

/* ── Top navigation (dashboard) ────────────────────────────────────────────── */
.topnav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  height:60px;display:flex;align-items:center;
  background:rgba(10,10,10,.88);
  border-bottom:1px solid var(--bd);
  backdrop-filter:blur(18px) saturate(150%);
  -webkit-backdrop-filter:blur(18px) saturate(150%);
}
.topnav .wrap{display:flex;align-items:center;justify-content:space-between;gap:1rem;height:100%}
.topnav-logo{display:flex;align-items:center;gap:.5rem;text-decoration:none}
.topnav-logo img{height:24px;filter:brightness(0) invert(1);opacity:.9}
.topnav-logo-text{font-size:.875rem;font-weight:700;letter-spacing:.08em;color:var(--t1);text-transform:uppercase}
.topnav-right{display:flex;align-items:center;gap:.5rem}
.topnav-user{
  display:flex;align-items:center;gap:.5rem;
  font-size:.8125rem;color:var(--t2);
}
.topnav-avatar{
  width:30px;height:30px;border-radius:50%;background:var(--bg-4);
  border:1px solid var(--bd-2);display:flex;align-items:center;justify-content:center;
  font-size:.75rem;font-weight:700;color:var(--blue-lt);flex-shrink:0;
}
.topnav-user-meta{display:flex;flex-direction:column;gap:1px;line-height:1.2}
.topnav-name{font-weight:500;color:var(--t1);font-size:.8125rem}

/* BAC display */
.topnav-bac{display:flex;align-items:center;gap:4px;margin-top:1px}
.bac-code{
  font-family:ui-monospace,SFMono-Regular,'Cascadia Code',monospace;
  font-size:.675rem;color:var(--t3);letter-spacing:.04em;
  cursor:pointer;transition:color .15s;
}
.bac-code:hover{color:var(--t2);}
.bac-code.bac-copied{color:var(--green-lt);}
.bac-info{
  position:relative;display:inline-flex;align-items:center;justify-content:center;
  width:14px;height:14px;border-radius:50%;border:1px solid var(--bd-2);
  color:var(--t3);cursor:pointer;flex-shrink:0;
  transition:border-color .15s,color .15s;
}
.bac-info:hover,.bac-info:focus{border-color:var(--blue-lt);color:var(--blue-lt);outline:none}
.bac-tooltip{
  display:none;position:absolute;top:calc(100% + 8px);right:-4px;
  width:240px;padding:.55rem .7rem;
  background:var(--bg-3);border:1px solid var(--bd-2);border-radius:var(--r-sm);
  font-size:.72rem;color:var(--t2);line-height:1.55;
  box-shadow:0 8px 24px rgba(0,0,0,.5);z-index:200;white-space:normal;
  pointer-events:none;
}
.bac-tooltip::before{
  content:'';position:absolute;top:-5px;right:8px;
  width:8px;height:8px;background:var(--bg-3);
  border-left:1px solid var(--bd-2);border-top:1px solid var(--bd-2);
  transform:rotate(45deg);
}
.bac-info:hover .bac-tooltip,.bac-info:focus .bac-tooltip{display:block}

/* Admin badge in nav */
.role-badge{
  font-size:.65rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;
  padding:.15rem .45rem;border-radius:3px;
}
.role-badge.admin{background:rgba(59,130,246,.12);color:var(--blue-lt);border:1px solid rgba(59,130,246,.2)}
.role-badge.superuser{background:rgba(245,158,11,.12);color:var(--amber-lt);border:1px solid rgba(245,158,11,.2)}

/* ── Page shell ────────────────────────────────────────────────────────────── */
.page{padding-top:60px;min-height:100vh}
.page-inner{padding:3rem 0 5rem}

.page-header{margin-bottom:2.5rem}
.page-header .label{
  font-size:.685rem;font-weight:700;letter-spacing:.13em;text-transform:uppercase;
  color:var(--blue-lt);margin-bottom:.5rem;
}
.page-title{font-size:1.75rem;font-weight:700;color:var(--t1)}
.page-sub{font-size:.9375rem;color:var(--t2);margin-top:.375rem}

/* ── App cards ─────────────────────────────────────────────────────────────── */
.apps-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:1.25rem;
}
.app-card{
  background:var(--bg-2);border:1px solid var(--bd);border-radius:var(--r);
  display:flex;flex-direction:column;
  transition:border-color .22s var(--ease),transform .22s,box-shadow .22s;
  overflow:hidden;position:relative;
}
.app-card:hover{
  border-color:var(--bd-2);
  transform:translateY(-3px);
  box-shadow:0 8px 32px rgba(0,0,0,.45);
}
.app-card-atmo{
  position:absolute;top:-40px;right:-40px;width:140px;height:140px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(59,130,246,.12) 0%,transparent 70%);
  pointer-events:none;
  animation:atmoBreathe 7s ease-in-out infinite;
}
.app-card-head{
  padding:1.5rem 1.5rem 1rem;
  border-bottom:1px solid var(--bd);
  display:flex;align-items:center;gap:.875rem;
}
.app-icon{
  width:44px;height:44px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
}
.app-icon img,.app-icon svg{width:100%;height:100%;object-fit:contain;filter:brightness(0) invert(1);opacity:.9}
.app-name{font-size:1.0625rem;font-weight:700;color:var(--t1)}
.app-tag{
  font-size:.65rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  padding:.2rem .5rem;border-radius:3px;margin-top:.2rem;display:inline-block;
  background:rgba(59,130,246,.1);color:var(--blue-lt);border:1px solid rgba(59,130,246,.18);
}
.app-body{padding:1.125rem 1.5rem 1rem;flex:1}
.app-desc{font-size:.875rem;color:var(--t2);line-height:1.65}
.app-foot{
  padding:.875rem 1.5rem;border-top:1px solid var(--bd);
  display:flex;align-items:center;justify-content:space-between;
}
.app-status-dot{
  width:7px;height:7px;border-radius:50%;background:var(--green);
  box-shadow:0 0 6px var(--green);
  animation:bdot 2.5s ease-in-out infinite;
}
.app-status-text{font-size:.78rem;color:var(--t2)}
.app-status-wrap{display:flex;align-items:center;gap:.5rem}

/* ── Pending / status pages ────────────────────────────────────────────────── */
.status-page{
  min-height:calc(100vh - 60px);display:flex;align-items:center;justify-content:center;
  padding:2rem 1rem;
}
.status-card{
  max-width:480px;width:100%;text-align:center;
  background:var(--bg-2);border:1px solid var(--bd-2);border-radius:12px;
  padding:3rem 2.5rem;
}
.status-icon{
  width:72px;height:72px;border-radius:50%;margin:0 auto 1.75rem;
  display:flex;align-items:center;justify-content:center;
}
.status-icon.pending{background:rgba(59,130,246,.1);border:1px solid rgba(59,130,246,.25)}
.status-icon.denied {background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.25)}
.status-icon.email  {background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.25)}
.status-icon svg{width:32px;height:32px}
.status-title{font-size:1.375rem;font-weight:700;margin-bottom:.625rem}
.status-desc{font-size:.9375rem;color:var(--t2);line-height:1.7;margin-bottom:1.75rem}
.status-steps{
  display:flex;flex-direction:column;gap:.5rem;text-align:left;
  margin-bottom:1.75rem;
}
.status-step{
  display:flex;align-items:center;gap:.75rem;
  padding:.6rem .875rem;border-radius:var(--r-sm);
  background:var(--bg-3);border:1px solid var(--bd);
  font-size:.8125rem;color:var(--t2);
}
.status-step.done{color:var(--t1)}
.status-step .dot{
  width:8px;height:8px;border-radius:50%;background:var(--bd-3);flex-shrink:0;
}
.status-step.done .dot{background:var(--green);box-shadow:0 0 5px var(--green)}
.status-step.active .dot{background:var(--blue-lt);animation:bdot 2s ease-in-out infinite}

/* ── Admin panel ───────────────────────────────────────────────────────────── */
.admin-tabs{display:flex;gap:0;border-bottom:1px solid var(--bd);margin-bottom:2rem}
.admin-tab{
  padding:.625rem 1.125rem;font-size:.875rem;font-weight:500;color:var(--t3);
  border-bottom:2px solid transparent;cursor:pointer;transition:all .18s;
  border:none;background:none;margin-bottom:-1px;
}
.admin-tab:hover{color:var(--t2)}
.admin-tab.active{color:var(--blue-lt);border-bottom-color:var(--blue)}
.admin-count{
  display:inline-flex;align-items:center;justify-content:center;
  width:18px;height:18px;border-radius:50%;
  background:var(--blue);color:#fff;font-size:.6rem;font-weight:700;
  margin-left:.375rem;vertical-align:middle;
}

.admin-table-wrap{border:1px solid var(--bd);border-radius:var(--r);overflow:hidden}
.admin-table{width:100%;border-collapse:collapse}
.admin-table thead{background:var(--bg-3)}
.admin-table th{
  padding:.75rem 1rem;text-align:left;font-size:.75rem;font-weight:600;
  letter-spacing:.06em;text-transform:uppercase;color:var(--t3);
  border-bottom:1px solid var(--bd);
}
.admin-table td{
  padding:.875rem 1rem;font-size:.875rem;color:var(--t2);
  border-bottom:1px solid var(--bd);vertical-align:top;
}
.admin-table tr:last-child td{border-bottom:none}
.admin-table tr:hover td{background:rgba(255,255,255,.017)}
.user-name{font-weight:600;color:var(--t1);font-size:.9375rem}
.user-email{font-size:.8125rem;color:var(--t3)}
.user-bac{font-family:ui-monospace,SFMono-Regular,'Cascadia Code',monospace;font-size:.72rem;color:var(--bg-5);margin-top:.15rem;letter-spacing:.04em}

.status-pill{
  display:inline-flex;align-items:center;gap:.375rem;
  padding:.2rem .625rem;border-radius:99px;font-size:.72rem;font-weight:600;letter-spacing:.04em;
}
.status-pill::before{content:'';width:6px;height:6px;border-radius:50%}
.status-pill.pending-email{background:rgba(245,158,11,.1);color:var(--amber-lt);border:1px solid rgba(245,158,11,.2)}
.status-pill.pending-email::before{background:var(--amber)}
.status-pill.pending-approval{background:rgba(59,130,246,.1);color:var(--blue-lt);border:1px solid rgba(59,130,246,.2)}
.status-pill.pending-approval::before{background:var(--blue-lt)}
.status-pill.approved{background:rgba(34,197,94,.1);color:var(--green-lt);border:1px solid rgba(34,197,94,.2)}
.status-pill.approved::before{background:var(--green);box-shadow:0 0 4px var(--green)}
.status-pill.denied{background:rgba(239,68,68,.1);color:var(--red-lt);border:1px solid rgba(239,68,68,.2)}
.status-pill.denied::before{background:var(--red)}

.admin-actions{display:flex;gap:.5rem;flex-wrap:wrap}

.survey-answer{font-size:.8125rem;color:var(--t2);line-height:1.5;margin-top:.2rem}
.survey-label{font-size:.7rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--t3)}

/* Modal / Reason dialog */
.modal-backdrop{
  position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:200;
  display:none;align-items:center;justify-content:center;padding:1rem;
  backdrop-filter:blur(4px);
}
.modal-backdrop.open{display:flex;animation:fadeIn .22s var(--ease) both}
.modal{
  background:var(--bg-2);border:1px solid var(--bd-2);border-radius:10px;
  padding:2rem;max-width:440px;width:100%;
  animation:slideUp .3s var(--ease) both;
}
.modal h3{font-size:1.125rem;font-weight:700;margin-bottom:.5rem}
.modal p{font-size:.875rem;color:var(--t2);margin-bottom:1.25rem}
.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.25rem}

@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}

/* ── Stats row ─────────────────────────────────────────────────────────────── */
.stats-row{display:flex;gap:1px;background:var(--bd);border:1px solid var(--bd);border-radius:var(--r);overflow:hidden;margin-bottom:2rem}
.stat-cell{flex:1;padding:1.25rem 1.5rem;background:var(--bg-2)}
.stat-val{font-size:1.625rem;font-weight:700;color:var(--t1)}
.stat-key{font-size:.75rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--t3);margin-top:.2rem}

/* ── Admin toolbar ─────────────────────────────────────────────────────────── */
.admin-toolbar{display:flex;align-items:center;justify-content:flex-end;margin-bottom:1rem}
.admin-search{
  background:var(--bg-3);border:1px solid var(--bd-2);border-radius:var(--r-sm);
  color:var(--t1);padding:.55rem .9rem .55rem 2.25rem;font-family:var(--sans);font-size:.875rem;
  outline:none;width:260px;transition:border-color .18s,box-shadow .18s;
}
.admin-search::placeholder{color:var(--t3)}
.admin-search:focus{border-color:rgba(59,130,246,.5);box-shadow:0 0 0 3px rgba(59,130,246,.09)}
.admin-search-wrap{position:relative}
.admin-search-icon{
  position:absolute;left:.7rem;top:50%;transform:translateY(-50%);
  color:var(--t3);pointer-events:none;
}

/* ── Empty state ───────────────────────────────────────────────────────────── */
.empty-state{
  text-align:center;padding:4rem 2rem;color:var(--t3);
}
.empty-state svg{width:48px;height:48px;margin:0 auto 1rem;opacity:.3}
.empty-state p{font-size:.9375rem}

/* ── Toasts ────────────────────────────────────────────────────────────────── */
.toast-wrap{position:fixed;bottom:1.5rem;right:1.5rem;z-index:300;display:flex;flex-direction:column;gap:.5rem}
.toast{
  padding:.75rem 1.125rem;border-radius:var(--r-sm);font-size:.875rem;font-weight:500;
  box-shadow:0 4px 16px rgba(0,0,0,.5);max-width:340px;
  animation:toastIn .3s var(--ease) both;
}
.toast.ok {background:#14532d;border:1px solid rgba(34,197,94,.3);color:var(--green-lt)}
.toast.err{background:#450a0a;border:1px solid rgba(239,68,68,.3);color:var(--red-lt)}
.toast.out{animation:toastOut .25s var(--ease) forwards}
@keyframes toastIn {from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
@keyframes toastOut{to{opacity:0;transform:translateY(12px)}}

/* ── Keyframes ─────────────────────────────────────────────────────────────── */
@keyframes spin       {to{transform:rotate(360deg)}}
@keyframes atmoBreathe{0%,100%{scale:1}50%{scale:1.15}}
@keyframes bdot       {0%,100%{opacity:1}50%{opacity:.3}}
@keyframes heroIn     {from{opacity:0;transform:translateY(20px)}}
@keyframes pulse      {0%,100%{box-shadow:0 0 0 0 rgba(59,130,246,.4)}50%{box-shadow:0 0 0 8px rgba(59,130,246,0)}}

/* ── Divider ───────────────────────────────────────────────────────────────── */
.divider{display:flex;align-items:center;gap:.75rem;margin:1.25rem 0;color:var(--t3);font-size:.8125rem}
.divider::before,.divider::after{content:'';flex:1;height:1px;background:var(--bd)}

/* ── Reveal ────────────────────────────────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .55s var(--ease),transform .55s var(--ease)}
.reveal.visible{opacity:1;transform:none}

/* ── Responsive ────────────────────────────────────────────────────────────── */
@media(max-width:900px){
  .stats-row{flex-wrap:wrap}
  .stat-cell{min-width:140px}
  .admin-table th:nth-child(4),.admin-table td:nth-child(4){display:none}
}
@media(max-width:700px){
  .auth-card-inner{padding:1.75rem 1.25rem}
  .survey-grid{grid-template-columns:1fr}
  .admin-table th:nth-child(3),.admin-table td:nth-child(3){display:none}
  .admin-table th:nth-child(5),.admin-table td:nth-child(5){display:none}
  .modal{padding:1.5rem}
  .topnav-user .topnav-user-meta{display:none}
}
@media(max-width:480px){
  .step-label{display:none}
  .stats-row{flex-direction:column}
  .page-inner{padding:2rem 0 3rem}
  .apps-grid{grid-template-columns:1fr}
}

/* ── Admin subnav ──────────────────────────────────────────────────────────── */
.admin-subnav{
  display:flex;gap:.125rem;margin-bottom:2rem;
  border-bottom:1px solid var(--bd-2);
}
.admin-subnav-link{
  padding:.6rem 1rem;font-size:.8125rem;font-weight:600;
  color:var(--t3);text-decoration:none;white-space:nowrap;
  border-bottom:2px solid transparent;margin-bottom:-1px;
  transition:color .18s var(--ease),border-color .18s var(--ease);
}
.admin-subnav-link:hover{color:var(--t1)}
.admin-subnav-link.active{color:var(--blue);border-bottom-color:var(--blue)}

/* ── Banned badge / pill ───────────────────────────────────────────────────── */
.banned-badge{
  display:inline-block;margin-left:.4rem;vertical-align:middle;
  background:rgba(239,68,68,.12);border:1px solid rgba(239,68,68,.25);
  color:var(--red-lt);font-size:.6rem;font-weight:700;letter-spacing:.05em;
  text-transform:uppercase;padding:.1rem .35rem;border-radius:3px;
}
.status-pill.banned{
  background:rgba(239,68,68,.12);color:var(--red-lt);
  border:1px solid rgba(239,68,68,.25);
}

/* ── Settings pages ────────────────────────────────────────────────────────── */
.settings-section{
  background:var(--bg-2);border:1px solid var(--bd-2);
  border-radius:var(--r);padding:1.5rem;margin-bottom:1.5rem;
}
.settings-section-title{
  font-size:.875rem;font-weight:700;color:var(--t1);
  margin-bottom:1.25rem;padding-bottom:.75rem;
  border-bottom:1px solid var(--bd-2);
}
.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.settings-note{font-size:.75rem;color:var(--t3);margin-top:.3rem}
.settings-vars{display:flex;gap:.375rem;flex-wrap:wrap;margin:.25rem 0 .875rem}
.settings-var{
  background:var(--bg-3);border:1px solid var(--bd-2);border-radius:4px;
  padding:.2rem .5rem;font-family:'Courier New',monospace;
  font-size:.7rem;color:#93c5fd;
}

/* ── Template textarea ─────────────────────────────────────────────────────── */
.tpl-textarea{
  width:100%;background:var(--bg-3);border:1px solid var(--bd-2);
  border-radius:var(--r-sm);color:var(--t1);padding:.7rem .95rem;
  font-family:'Courier New',monospace;font-size:.775rem;line-height:1.65;
  resize:vertical;outline:none;min-height:180px;
  transition:border-color .18s,box-shadow .18s;
}
.tpl-textarea:focus{
  border-color:rgba(59,130,246,.5);
  box-shadow:0 0 0 3px rgba(59,130,246,.09);
}

/* ── Modal role selector ───────────────────────────────────────────────────── */
.modal-select{
  width:100%;background:var(--bg-3);border:1px solid var(--bd-2);
  border-radius:var(--r-sm);color:var(--t1);padding:.65rem .9rem;
  font-family:inherit;font-size:.875rem;outline:none;
  appearance:none;-webkit-appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right .75rem center;
  padding-right:2.25rem;
  transition:border-color .18s,box-shadow .18s;
}
.modal-select:focus{
  border-color:rgba(59,130,246,.5);
  box-shadow:0 0 0 3px rgba(59,130,246,.09);
}

@media(max-width:700px){
  .settings-grid{grid-template-columns:1fr}
  .admin-subnav{overflow-x:auto}
}

/* ── Google sign-in button ─────────────────────────────────────────────────── */
.btn-google{
  display:flex;align-items:center;justify-content:center;gap:.625rem;
  width:100%;padding:.7rem 1.375rem;border-radius:var(--r-sm);
  background:#fff;color:#1f1f1f;border:1px solid rgba(0,0,0,.12);
  font-weight:600;font-size:.875rem;cursor:pointer;text-decoration:none;
  transition:background .18s,box-shadow .18s,transform .12s;
  user-select:none;letter-spacing:.01em;
}
.btn-google:hover{background:#f8f8f8;box-shadow:0 2px 8px rgba(0,0,0,.18);color:#1f1f1f}
.btn-google:active{transform:scale(.975)}
.btn-google svg{flex-shrink:0}

/* ── Auth divider ("or") ───────────────────────────────────────────────────── */
.auth-divider{
  display:flex;align-items:center;gap:.75rem;
  margin:1rem 0;color:var(--t3);font-size:.8125rem;
}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--bd)}

/* ── Premium role badge ────────────────────────────────────────────────────── */
.role-badge.premium{background:rgba(245,158,11,.12);color:var(--amber-lt);border:1px solid rgba(245,158,11,.2)}

/* ── Premium upgrade page ──────────────────────────────────────────────────── */
.premium-card{
  background:var(--bg-2);border:1px solid var(--bd-2);border-radius:var(--r);
  padding:1.25rem 1.5rem;display:flex;align-items:flex-start;gap:.875rem;
  transition:border-color .18s;
}
.premium-card:hover{border-color:rgba(245,158,11,.3)}
.premium-card-icon{
  width:36px;height:36px;border-radius:var(--r-sm);flex-shrink:0;
  background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.2);
  display:flex;align-items:center;justify-content:center;color:var(--amber-lt);
}
.premium-card-title{font-size:.9375rem;font-weight:600;color:var(--t1);margin-bottom:.2rem}
.premium-card-desc{font-size:.8125rem;color:var(--t2);line-height:1.55}
.premium-features-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem;margin-bottom:2rem}

.premium-price-tag{
  display:flex;align-items:baseline;gap:.5rem;
  margin:1.5rem 0 .75rem;
}
.premium-price-amount{
  font-size:3rem;font-weight:700;color:var(--amber-lt);letter-spacing:-.02em;
}
.premium-price-period{font-size:1rem;color:var(--t2);font-weight:500}
.premium-price-note{font-size:.8125rem;color:var(--t3);margin-bottom:1.5rem}

@media(max-width:600px){
  .premium-features-grid{grid-template-columns:1fr}
  .premium-price-amount{font-size:2.25rem}
}

/* ── Premium topnav button ─────────────────────────────────────────────────── */
.btn-premium {
  background: linear-gradient(135deg, #f59e0b 0%, #c97c1c 100%);
  color: #0a0a0a;
  font-weight: 700;
  border: 1px solid rgba(245,158,11,.45);
  position: relative;
  overflow: hidden;
}
.btn-premium:hover { color: #0a0a0a; opacity: .9; }
.btn-premium::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(105deg, transparent 30%, rgba(255,255,255,.22) 50%, transparent 70%);
  transform: translateX(-120%);
  transition: transform .55s ease;
}
.btn-premium:hover::after { transform: translateX(120%); }
