/* ============================================================
   TapeX — auth / console / admin shared styles
   (loads on top of styles.css for tokens)
   ============================================================ */
/* the [hidden] attribute must beat any explicit display rule below
   (e.g. .auth-wrap{display:flex} would otherwise keep a hidden gate visible) */
[hidden]{display:none!important}
.auth-wrap{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px;position:relative;z-index:4}
.auth-card{width:100%;max-width:420px;padding:40px 34px;border:1px solid var(--line-2);border-radius:var(--r-xl);
  background:linear-gradient(180deg,rgba(245,242,254,.92),rgba(251,250,255,.85));backdrop-filter:blur(16px);box-shadow:0 30px 90px rgba(27,18,51,.16),var(--glow)}
.auth-brand{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:8px}
.auth-brand .nav__name{font-size:22px}
.auth-card h1{font-family:var(--f-display);font-size:24px;text-align:center;letter-spacing:-.03em;margin:14px 0 6px}
.auth-card .sub{text-align:center;color:var(--fg-1);font-size:14.5px;margin-bottom:26px}
.auth-google{display:flex;justify-content:center;min-height:44px;margin-bottom:6px}
.gbtn{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;padding:13px 18px;border-radius:var(--r-md);
  border:1px solid var(--line-2);background:#fff;color:#1f2328;font-family:var(--f-display);font-weight:600;font-size:15px;cursor:pointer;transition:transform .3s var(--ease),box-shadow .3s}
.gbtn:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(27,18,51,.12)}
.auth-divider{display:flex;align-items:center;gap:12px;margin:22px 0;color:var(--fg-2);font-size:12px;font-family:var(--f-mono)}
.auth-divider::before,.auth-divider::after{content:"";flex:1;height:1px;background:var(--line)}
.auth-field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.auth-field label{font-size:12.5px;color:var(--fg-1)}
.auth-field input{padding:12px 14px;border-radius:var(--r-md);border:1px solid var(--line-2);background:rgba(0,0,0,.05);color:var(--fg-0);font-size:15px;font-family:var(--f-body)}
.auth-field input:focus{outline:none;border-color:var(--emerald)}
.auth-note{margin-top:18px;font-size:12px;color:var(--fg-2);text-align:center;line-height:1.5}
.auth-msg{margin-top:14px;font-size:13px;text-align:center;min-height:18px}
.auth-msg.err{color:var(--rose)} .auth-msg.ok{color:var(--emerald)}
.auth-back{display:block;text-align:center;margin-top:18px;color:var(--fg-1);font-size:13px}
.auth-back:hover{color:var(--emerald)}

/* ---------- app shell (console + admin) ---------- */
.app-nav{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:14px clamp(16px,4vw,32px);border-bottom:1px solid var(--line);background:rgba(255,255,255,.82);backdrop-filter:blur(16px)}
.app-nav__r{display:flex;align-items:center;gap:14px}
.who{display:flex;align-items:center;gap:10px;font-size:14px}
.who img{width:32px;height:32px;border-radius:50%;border:1px solid var(--line-2);object-fit:cover}
.who .ph{width:32px;height:32px;border-radius:50%;display:grid;place-items:center;background:var(--grad);color:#fff;font-family:var(--f-display);font-weight:700;font-size:14px}
.app-main{max-width:1100px;margin:0 auto;padding:clamp(24px,4vw,44px) clamp(16px,4vw,32px)}
.app-h{font-family:var(--f-display);font-size:clamp(24px,3vw,34px);letter-spacing:-.03em;margin-bottom:6px}
.app-sub{color:var(--fg-1);margin-bottom:28px}

/* stat cards */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:28px}
.kpi{padding:20px;border:1px solid var(--line);border-radius:var(--r-lg);background:rgba(0,0,0,.045)}
.kpi__v{font-family:var(--f-display);font-weight:700;font-size:30px;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.kpi__l{font-size:12.5px;color:var(--fg-2);margin-top:4px}

/* table */
.panel{border:1px solid var(--line);border-radius:var(--r-lg);background:rgba(0,0,0,.045);overflow:hidden;margin-bottom:24px}
.panel__h{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--line)}
.panel__h h3{font-size:16px}
.tbl{width:100%;border-collapse:collapse;font-size:13.5px}
.tbl th{text-align:left;padding:11px 16px;color:var(--fg-2);font-family:var(--f-mono);font-size:11.5px;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--line)}
.tbl td{padding:12px 16px;border-bottom:1px solid var(--line);color:var(--fg-1);vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl tr:hover td{background:rgba(0,0,0,.045)}
.tbl .u{display:flex;align-items:center;gap:10px;color:var(--fg-0)}
.tbl .u img,.tbl .u .ph{width:28px;height:28px;border-radius:50%}
.tbl .u .ph{display:grid;place-items:center;background:var(--grad);color:#fff;font-weight:700;font-size:12px;font-family:var(--f-display)}
.tag{font-family:var(--f-mono);font-size:11px;padding:3px 8px;border-radius:6px}
.tag--google{background:rgba(0,0,0,.14);color:var(--cyan)}
.tag--demo{background:rgba(27,18,51,.10);color:var(--fg-1)}
.tag--admin{background:rgba(0,0,0,.14);color:var(--emerald)}
.tag--manual{background:rgba(0,0,0,.10);color:var(--fg-1)}
.tag--active{background:rgba(22,163,74,.16);color:#16A34A}
.tag--suspended{background:rgba(217,119,6,.18);color:#D97706}
.tag--banned{background:rgba(220,38,38,.18);color:#DC2626}
.adm-in{padding:10px 12px;border:1px solid var(--line-2);border-radius:10px;background:rgba(0,0,0,.04);color:var(--fg-0);font-family:inherit;font-size:14px;width:100%}
.adm-in:focus{outline:none;border-color:var(--fg-0)}
.mono{font-family:var(--f-mono);font-size:12.5px;color:var(--fg-2)}
.empty{padding:40px;text-align:center;color:var(--fg-2)}

/* console feature grid reuse */
.console-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:8px}
.cg{padding:22px;border:1px solid var(--line);border-radius:var(--r-lg);background:rgba(0,0,0,.045)}
.cg h4{font-size:16px;margin-bottom:6px}
.cg p{font-size:13.5px;color:var(--fg-1)}
.cg .ico{font-size:22px;margin-bottom:10px;display:block}

@media (max-width:760px){
  .kpis{grid-template-columns:repeat(2,1fr)}
  .console-grid{grid-template-columns:1fr}
  .tbl .hide-sm{display:none}
}
/* log in / sign up tabs */
.auth-tabs{display:flex;gap:6px;background:rgba(255,138,0,.06);border:1px solid var(--line);border-radius:12px;padding:4px;margin-bottom:16px}
.auth-tab{flex:1;padding:9px;border:none;background:transparent;color:var(--fg-2);font-family:var(--f-display);font-weight:600;font-size:14px;border-radius:9px;cursor:pointer;transition:background .2s,color .2s}
.auth-tab.is-active{background:var(--grad);color:#000}
.auth-hint{display:block;margin-top:6px;font-family:var(--f-mono);font-size:11px;color:var(--fg-2)}
.auth-switch{text-align:center;font-size:13.5px;color:var(--fg-2);margin-top:14px}
.auth-switch a{color:var(--orange);font-weight:600}
