/* ============================================================================
   style.css — Liquid Glass design untuk AUTH & DASHBOARD.
   Nama class/ID dipertahankan agar JS lama tetap jalan. Font: Urbanist.
   ========================================================================== */

:root {
    --ink:       #13203a;
    --ink-soft:  #5a6b85;
    --blue:      #2f7bf6;
    --teal:      #19b8c4;
    --orange:    #ff7a1a;
    --green:     #2bb673;
    --red:       #ff5557;
    --violet:    #7b7bff;
    --yellow:    #f4c020;

    --glass:     rgba(255,255,255,.55);
    --glass-2:   rgba(255,255,255,.40);
    --glass-strong: rgba(255,255,255,.72);
    --glass-brd: rgba(255,255,255,.75);
    --line:      rgba(19,32,58,.10);
    --glass-shadow: 0 12px 40px rgba(20,40,80,.14), inset 0 1px 0 rgba(255,255,255,.65);
    --glass-shadow-lg: 0 24px 70px rgba(20,40,80,.20), inset 0 1px 0 rgba(255,255,255,.7);

    --radius:    16px;
    --radius-lg: 26px;
    --blur:      blur(22px) saturate(1.7);
    --font: 'Urbanist', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; }
body {
    font-family: var(--font); color: var(--ink); line-height: 1.5; min-height: 100vh;
    -webkit-font-smoothing: antialiased; position: relative;
}
body::before {
    content: ""; position: fixed; inset: 0; z-index: -2;
    background:
        radial-gradient(42% 55% at 14% 18%, rgba(90,180,255,.55), transparent 70%),
        radial-gradient(46% 56% at 86% 12%, rgba(123,123,255,.40), transparent 70%),
        radial-gradient(52% 60% at 82% 86%, rgba(255,140,40,.48), transparent 72%),
        radial-gradient(48% 58% at 8% 92%, rgba(40,210,180,.40), transparent 72%),
        linear-gradient(160deg, #eef3f8, #e7edf4);
}
h1,h2,h3 { font-weight: 800; letter-spacing: -.02em; line-height: 1.05; }
a { color: inherit; text-decoration: none; }
.mono-label { font-size: .72rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-soft); }

.glass { background: var(--glass); backdrop-filter: var(--blur); -webkit-backdrop-filter: var(--blur);
    border: 1px solid var(--glass-brd); box-shadow: var(--glass-shadow); }

/* ---- buttons ---- */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; cursor: pointer;
    font-family: var(--font); font-weight: 700; font-size: .95rem; padding: 12px 22px; border-radius: 100px;
    border: 1px solid transparent; transition: transform .22s cubic-bezier(.2,.8,.2,1), box-shadow .22s, background .2s, opacity .2s; }
.btn--primary { background: linear-gradient(135deg, var(--blue), var(--teal)); color: #fff; box-shadow: 0 10px 26px rgba(47,123,246,.4); }
.btn--primary:hover { transform: translateY(-2px); box-shadow: 0 16px 34px rgba(47,123,246,.5); }
.btn--danger { background: linear-gradient(135deg, var(--red), #ff8a6a); color: #fff; box-shadow: 0 10px 24px rgba(255,85,87,.4); }
.btn--danger:hover { transform: translateY(-2px); }
.btn--ghost { background: var(--glass); backdrop-filter: var(--blur); -webkit-backdrop-filter: var(--blur); border: 1px solid var(--glass-brd); color: var(--ink); box-shadow: var(--glass-shadow); }
.btn--ghost:hover { transform: translateY(-2px); background: var(--glass-strong); }
.btn--block { width: 100%; }
.btn:active { transform: translateY(0); }
.btn:disabled { opacity: .45; cursor: not-allowed; transform: none; }
.btn:focus-visible { outline: 3px solid var(--blue); outline-offset: 2px; }

/* ---- forms ---- */
.field { margin-bottom: 16px; }
.field label { display: block; margin-bottom: 7px; }
input, select { font-family: var(--font); font-size: .95rem; width: 100%; color: var(--ink); padding: 12px 14px;
    border-radius: 13px; border: 1px solid var(--glass-brd); background: rgba(255,255,255,.5);
    backdrop-filter: blur(8px); transition: border-color .2s, background .2s, box-shadow .2s; }
input::placeholder { color: #8a93a6; }
input:focus, select:focus { outline: none; border-color: var(--blue); background: rgba(255,255,255,.85); box-shadow: 0 0 0 4px rgba(47,123,246,.16); }
select { cursor: pointer; appearance: none;
    background-image: linear-gradient(45deg, transparent 50%, var(--ink) 50%), linear-gradient(135deg, var(--ink) 50%, transparent 50%);
    background-position: calc(100% - 18px) 55%, calc(100% - 13px) 55%; background-size: 5px 5px, 5px 5px; background-repeat: no-repeat; padding-right: 34px; }
.hint { font-size: .74rem; margin-top: 6px; }
.hint.ok { color: var(--green); } .hint.bad { color: var(--red); }
.rules { list-style: none; font-size: .74rem; margin-top: 10px; display: grid; gap: 3px; }
.rules li { padding-left: 22px; position: relative; color: var(--ink-soft); opacity: .7; }
.rules li::before { content: "○"; position: absolute; left: 2px; }
.rules li.met { opacity: 1; color: var(--green); }
.rules li.met::before { content: "●"; }

.linkish { display: block; width: 100%; margin-top: 12px; background: none; border: none; cursor: pointer;
    font-family: var(--font); font-weight: 600; font-size: .82rem; color: var(--blue); text-align: center; padding: 4px; }
.linkish:hover { text-decoration: underline; }

/* ============================ AUTH ============================ */
.auth-wrap { position: relative; min-height: 100vh; display: grid; place-items: center; padding: 24px; }
.auth-card { width: 100%; max-width: 440px; border-radius: var(--radius-lg); padding: 34px;
    background: var(--glass); backdrop-filter: var(--blur); -webkit-backdrop-filter: var(--blur);
    border: 1px solid var(--glass-brd); box-shadow: var(--glass-shadow-lg); }
.brand { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; }
.brand .dot { width: 18px; height: 18px; border-radius: 6px; background: linear-gradient(135deg, var(--blue), var(--teal)); }
.auth-card h1 { font-size: 1.9rem; }
.auth-sub { font-size: .82rem; color: var(--ink-soft); margin-bottom: 24px; }
.tabs { display: flex; gap: 6px; padding: 5px; border-radius: 100px; margin-bottom: 24px; background: rgba(255,255,255,.4); border: 1px solid var(--glass-brd); }
.tabs button { flex: 1; font-family: var(--font); font-weight: 700; font-size: .82rem; color: var(--ink-soft); padding: 10px; border: none; background: transparent; cursor: pointer; border-radius: 100px; transition: all .2s; }
.tabs button.active { background: linear-gradient(135deg, var(--blue), var(--teal)); color: #fff; box-shadow: 0 6px 16px rgba(47,123,246,.4); }
.pane { display: none; } .pane.active { display: block; }
.otp-inputs { display: flex; gap: 8px; justify-content: space-between; }
.otp-inputs input { text-align: center; font-size: 1.3rem; font-weight: 800; padding: 14px 0; border-radius: 13px; }
.otp-timer { font-size: .8rem; margin: 16px 0; text-align: center; color: var(--ink-soft); }
.otp-timer b { color: var(--orange); }

/* ============================ DASHBOARD ============================ */
.topbar { position: sticky; top: 12px; z-index: 30; display: flex; align-items: center; justify-content: space-between;
    gap: 12px; padding: 12px 20px; flex-wrap: wrap; margin: 12px auto 0; width: min(1240px, calc(100% - 36px)); border-radius: 100px;
    background: var(--glass); backdrop-filter: var(--blur); -webkit-backdrop-filter: var(--blur); border: 1px solid var(--glass-brd); box-shadow: var(--glass-shadow); }
.topbar .brand { margin: 0; }
.topbar .brand h1 { font-size: 1.1rem; }
.topbar .brand .dot { background: linear-gradient(135deg, var(--blue), var(--teal)); }
.topbar .who { font-size: .8rem; color: var(--ink-soft); display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.blink { animation: blink 1.1s steps(1) infinite; color: var(--teal); }
@keyframes blink { 50% { opacity: 0; } }

.shell { position: relative; max-width: 1240px; margin: 0 auto; padding: 24px 18px 70px; }

/* bento */
.bento { display: grid; gap: 16px; margin-bottom: 24px; grid-template-columns: repeat(4, 1fr); }
.cell { border-radius: var(--radius-lg); padding: 22px; position: relative; overflow: hidden;
    background: var(--glass); backdrop-filter: var(--blur); -webkit-backdrop-filter: var(--blur); border: 1px solid var(--glass-brd); box-shadow: var(--glass-shadow); }
.cell--total    { grid-column: span 1; background: linear-gradient(150deg, rgba(47,123,246,.85), rgba(25,184,196,.8)); color: #fff; border-color: rgba(255,255,255,.4); }
.cell--calendar { grid-column: span 2; }
.cell--algo     { grid-column: span 1; }
.cell--ratio    { grid-column: span 2; }
.cell--chart    { grid-column: span 2; }
.cell h2 { font-size: .68rem; letter-spacing: .1em; text-transform: uppercase; opacity: .85; margin-bottom: 12px; }
.bignum { font-size: 3rem; font-weight: 800; letter-spacing: -.03em; line-height: 1; }
.bignum small { font-size: .78rem; font-weight: 600; display: block; margin-top: 8px; opacity: .9; }

.bar { height: 24px; border-radius: 100px; display: flex; overflow: hidden; margin: 12px 0 8px; background: rgba(19,32,58,.08); }
.bar span { display: block; height: 100%; }
.bar .seg-reg { background: linear-gradient(90deg, var(--blue), var(--teal)); }
.bar .seg-bea { background: linear-gradient(90deg, var(--green), #5fd6a0); }
.ratio-legend { display: flex; gap: 18px; font-size: .76rem; flex-wrap: wrap; color: var(--ink-soft); }
.ratio-legend b { color: var(--ink); }
.swatch { display: inline-block; width: 12px; height: 12px; border-radius: 4px; vertical-align: -1px; margin-right: 5px; }

.algo-list { list-style: none; font-size: .8rem; }
.algo-list li { display: flex; justify-content: space-between; padding: 5px 0; border-bottom: 1px solid var(--line); }
.algo-list li b { color: var(--ink); }

/* calendar widget */
.cal-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.cal-head h2 { font-size: 1rem; letter-spacing: -.01em; text-transform: none; opacity: 1; margin: 0; }
.cal-nav { width: 32px; height: 32px; border-radius: 50%; border: 1px solid var(--glass-brd); background: rgba(255,255,255,.5);
    cursor: pointer; font-size: 1.1rem; line-height: 1; color: var(--ink); display: grid; place-items: center; transition: all .18s; }
.cal-nav:hover { background: #fff; transform: translateY(-1px); }
.cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; user-select: none; touch-action: pan-y; }
.cal-dow { text-align: center; font-size: .64rem; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--ink-soft); padding-bottom: 4px; }
.cal-day { aspect-ratio: 1 / 1; display: grid; place-items: center; border-radius: 11px; font-size: .82rem; font-weight: 600; color: var(--ink); transition: background .15s; }
.cal-day:hover { background: rgba(255,255,255,.6); }
.cal-day.other { color: rgba(19,32,58,.28); }
.cal-day.today { background: linear-gradient(135deg, var(--blue), var(--teal)); color: #fff; font-weight: 800; box-shadow: 0 6px 16px rgba(47,123,246,.45); }

/* angkatan chart */
.chart-bars { display: flex; align-items: flex-end; gap: 14px; height: 130px; padding-top: 8px; }
.cbar { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 8px; height: 100%; justify-content: flex-end; }
.cbar-fill { width: 100%; max-width: 46px; border-radius: 10px 10px 4px 4px; background: linear-gradient(180deg, var(--blue), var(--teal)); min-height: 6px;
    transition: height .8s cubic-bezier(.2,.8,.2,1); position: relative; }
.cbar:nth-child(2) .cbar-fill { background: linear-gradient(180deg, var(--violet), #a6a6ff); }
.cbar:nth-child(3) .cbar-fill { background: linear-gradient(180deg, var(--orange), #ffb259); }
.cbar:nth-child(4) .cbar-fill { background: linear-gradient(180deg, var(--green), #5fd6a0); }
.cbar:nth-child(5) .cbar-fill { background: linear-gradient(180deg, var(--red), #ff8a8c); }
.cbar-val { font-size: .8rem; font-weight: 800; }
.cbar-label { font-size: .7rem; color: var(--ink-soft); font-weight: 600; }

/* control panel */
.panel { border-radius: var(--radius-lg); padding: 20px; margin-bottom: 24px;
    background: var(--glass); backdrop-filter: var(--blur); -webkit-backdrop-filter: var(--blur); border: 1px solid var(--glass-brd); box-shadow: var(--glass-shadow); }
.panel-row { display: flex; gap: 14px; flex-wrap: wrap; align-items: flex-end; }
.panel-group { display: flex; flex-direction: column; gap: 6px; }
.search-group { flex: 2 1 260px; }
.spacer { flex: 1 1 auto; }
.actions { display: flex; gap: 10px; flex-wrap: wrap; }

/* table */
.table-wrap { border-radius: var(--radius-lg); overflow-x: auto;
    background: var(--glass-strong); backdrop-filter: var(--blur); -webkit-backdrop-filter: var(--blur); border: 1px solid var(--glass-brd); box-shadow: var(--glass-shadow); }
table.data { width: 100%; border-collapse: collapse; min-width: 860px; }
.data thead th { background: rgba(255,255,255,.45); color: var(--ink-soft); font-size: .68rem; letter-spacing: .08em; text-transform: uppercase;
    text-align: left; padding: 14px 16px; white-space: nowrap; position: sticky; top: 0; backdrop-filter: blur(8px); }
.data tbody td { padding: 13px 16px; border-bottom: 1px solid var(--line); font-size: .86rem; vertical-align: middle; }
.data tbody tr { transition: background .15s; }
.data tbody tr:hover { background: rgba(47,123,246,.08); }
.data .col-no { width: 44px; text-align: center; font-weight: 700; color: var(--ink-soft); }
.data .col-aksi { white-space: nowrap; }
.tag { display: inline-block; padding: 4px 11px; border-radius: 100px; font-size: .7rem; font-weight: 700; }
.tag--reguler { background: rgba(19,32,58,.08); color: var(--ink-soft); }
.tag--beasiswa { background: linear-gradient(135deg, var(--green), #5fd6a0); color: #fff; }
.icon-btn { font-family: var(--font); font-weight: 700; font-size: .72rem; cursor: pointer; margin-right: 6px; border: 1px solid var(--glass-brd);
    background: rgba(255,255,255,.6); color: var(--ink); padding: 6px 12px; border-radius: 100px; transition: all .18s; }
.icon-btn:hover { background: #fff; transform: translateY(-1px); }
.icon-btn--del { background: linear-gradient(135deg, var(--red), #ff8a6a); color: #fff; border-color: transparent; }
.empty-row td { text-align: center; padding: 36px; color: var(--ink-soft); }
.result-meta { font-size: .74rem; margin: 14px 4px 0; color: var(--ink-soft); }

/* cheat sheet */
.cheat { margin-top: 36px; border-radius: var(--radius-lg); overflow: hidden;
    background: rgba(15,25,45,.55); backdrop-filter: var(--blur); -webkit-backdrop-filter: var(--blur); border: 1px solid rgba(255,255,255,.18); box-shadow: var(--glass-shadow); color: #fff; }
.cheat h2 { font-size: .9rem; padding: 16px 18px; border-bottom: 1px solid rgba(255,255,255,.16); color: #fff; }
.cheat-grid { display: grid; grid-template-columns: repeat(2, 1fr); }
.cheat table { width: 100%; border-collapse: collapse; }
.cheat caption { text-align: left; font-weight: 700; font-size: .72rem; letter-spacing: .1em; padding: 14px 18px 6px; text-transform: uppercase; color: #9fd0ff; }
.cheat td { padding: 8px 18px; font-size: .78rem; border-bottom: 1px solid rgba(255,255,255,.1); }
.cheat td:last-child { text-align: right; color: #7fe3b0; white-space: nowrap; }
.cheat .col-left { border-right: 1px solid rgba(255,255,255,.16); }
.footnote { text-align: center; font-size: .7rem; color: var(--ink-soft); margin-top: 28px; letter-spacing: .04em; }

/* modal */
.overlay { position: fixed; inset: 0; background: rgba(15,25,45,.45); backdrop-filter: blur(4px); display: none; place-items: center; padding: 20px; z-index: 50; }
.overlay.open { display: grid; }
.modal { width: 100%; max-width: 520px; border-radius: var(--radius-lg); max-height: 92vh; overflow-y: auto;
    background: var(--glass-strong); backdrop-filter: var(--blur); -webkit-backdrop-filter: var(--blur); border: 1px solid var(--glass-brd); box-shadow: var(--glass-shadow-lg); }
.modal-head { display: flex; align-items: center; justify-content: space-between; padding: 18px 20px; border-bottom: 1px solid var(--line); }
.modal-head h2 { font-size: 1.2rem; }
.modal-head .x { cursor: pointer; width: 34px; height: 34px; display: grid; place-items: center; border-radius: 50%; background: rgba(19,32,58,.06); font-size: 1.2rem; transition: background .2s; }
.modal-head .x:hover { background: rgba(19,32,58,.14); }
.modal-body { padding: 20px; }
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 0 14px; }

/* toasts */
#toasts { position: fixed; top: 16px; right: 16px; z-index: 100; display: flex; flex-direction: column; gap: 12px; max-width: min(360px, 90vw); }
.toast { border-radius: var(--radius); padding: 14px 16px; display: flex; gap: 12px; align-items: flex-start;
    background: var(--glass-strong); backdrop-filter: var(--blur); -webkit-backdrop-filter: var(--blur); border: 1px solid var(--glass-brd); box-shadow: var(--glass-shadow); }
.toast .icon { width: 26px; height: 26px; flex: none; display: grid; place-items: center; border-radius: 50%; font-weight: 800; color: #fff; }
.toast--success .icon { background: var(--green); }
.toast--error .icon { background: var(--red); }
.toast--info .icon { background: var(--orange); }
.toast .body { font-size: .84rem; }
.toast .body b { display: block; font-weight: 700; font-size: .76rem; margin-bottom: 2px; }

/* responsive */
@media (max-width: 980px) {
    .bento { grid-template-columns: repeat(2, 1fr); }
    .cell--total { grid-column: span 1; }
    .cell--algo { grid-column: span 1; }
    .cell--calendar, .cell--ratio, .cell--chart { grid-column: span 2; }
}
@media (max-width: 560px) {
    .bento { grid-template-columns: 1fr; }
    .cell--total, .cell--algo, .cell--calendar, .cell--ratio, .cell--chart { grid-column: span 1; }
    .bignum { font-size: 2.5rem; }
    .cheat-grid { grid-template-columns: 1fr; }
    .cheat .col-left { border-right: none; border-bottom: 1px solid rgba(255,255,255,.16); }
    .grid-2 { grid-template-columns: 1fr; }
    .panel-row { flex-direction: column; align-items: stretch; }
    .actions .btn { flex: 1 1 auto; }
}
@media (prefers-reduced-motion: reduce) { *, *::before, *::after { animation: none !important; transition: none !important; } }

/* =====================================================================
   v3 ADD-ONS: dark mode, sidebar mengambang, pagination, jam, poles glass
   ===================================================================== */

/* ---------- DARK MODE ---------- */
html[data-theme="dark"] {
    --ink: #eaf0fb; --ink-soft: #9db0cc;
    --glass: rgba(28,40,66,.55); --glass-2: rgba(28,40,66,.4); --glass-strong: rgba(28,40,66,.74);
    --glass-brd: rgba(255,255,255,.14); --line: rgba(255,255,255,.10);
    --glass-shadow: 0 12px 40px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.10);
    --glass-shadow-lg: 0 24px 70px rgba(0,0,0,.55), inset 0 1px 0 rgba(255,255,255,.12);
}
html[data-theme="dark"] body::before {
    background:
        radial-gradient(42% 55% at 14% 18%, rgba(60,120,210,.40), transparent 70%),
        radial-gradient(46% 56% at 86% 12%, rgba(110,110,220,.30), transparent 70%),
        radial-gradient(52% 60% at 82% 86%, rgba(220,110,40,.30), transparent 72%),
        radial-gradient(48% 58% at 8% 92%, rgba(30,170,150,.28), transparent 72%),
        linear-gradient(160deg, #0b1322, #0d1626);
}
html[data-theme="dark"] input, html[data-theme="dark"] select { background: rgba(255,255,255,.06); color: var(--ink); }
html[data-theme="dark"] .data thead th { background: rgba(255,255,255,.06); }
html[data-theme="dark"] .data tbody tr:hover { background: rgba(255,255,255,.06); }
html[data-theme="dark"] .tag--reguler { background: rgba(255,255,255,.12); color: var(--ink-soft); }
html[data-theme="dark"] .icon-btn { background: rgba(255,255,255,.08); }
html[data-theme="dark"] .cal-day:hover { background: rgba(255,255,255,.10); }
html[data-theme="dark"] .modal-head .x { background: rgba(255,255,255,.10); }
html[data-theme="dark"] .pager button { background: rgba(255,255,255,.08); }
html[data-theme="dark"] .pager button:hover:not(:disabled) { background: rgba(255,255,255,.16); }

/* ---------- SIDEBAR MENGAMBANG ---------- */
.sidebar { position: fixed; left: 18px; top: 50%; transform: translateY(-50%); z-index: 45;
    display: flex; flex-direction: column; align-items: center; gap: 8px; padding: 12px 9px; border-radius: 100px;
    background: var(--glass); backdrop-filter: var(--blur); -webkit-backdrop-filter: var(--blur);
    border: 1px solid var(--glass-brd); box-shadow: var(--glass-shadow); }
.side-btn, .theme-toggle { width: 44px; height: 44px; border-radius: 50%; border: 1px solid transparent;
    background: transparent; color: var(--ink-soft); display: grid; place-items: center; cursor: pointer; transition: all .18s; }
.side-btn svg, .theme-toggle svg { width: 22px; height: 22px; }
.side-btn:hover { background: rgba(255,255,255,.5); color: var(--ink); transform: translateY(-1px); }
html[data-theme="dark"] .side-btn:hover { background: rgba(255,255,255,.12); }
.side-sep { width: 22px; height: 1px; background: var(--line); margin: 3px 0; }
.theme-toggle { border: 1px solid var(--glass-brd); background: rgba(255,255,255,.4); color: var(--ink); margin-top: 2px; }
html[data-theme="dark"] .theme-toggle { background: rgba(255,255,255,.10); }
.tt-moon { display: none; }
html[data-theme="dark"] .tt-sun { display: none; }
html[data-theme="dark"] .tt-moon { display: grid; place-items: center; }
@media (min-width: 1000px) { body { padding-left: 92px; } }
@media (max-width: 999px) {
    .sidebar { left: 50%; top: auto; bottom: 14px; transform: translateX(-50%); flex-direction: row; padding: 9px 12px; }
    .side-sep { width: 1px; height: 22px; margin: 0 3px; }
    body { padding-bottom: 84px; }
}

/* ---------- JAM DIGITAL ---------- */
.cal-clock { text-align: center; font-weight: 800; font-size: 1.55rem; letter-spacing: .04em; margin: 0 0 12px;
    font-variant-numeric: tabular-nums; background: linear-gradient(135deg, var(--blue), var(--teal));
    -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.cal-clock small { display: block; font-size: .62rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
    -webkit-text-fill-color: var(--ink-soft); color: var(--ink-soft); margin-top: 2px; }

/* ---------- PAGINATION ---------- */
.table-tools { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin: 0 2px 12px; }
.table-tools .mono-label { margin: 0; }
.pagesize { width: auto; padding: 9px 30px 9px 12px; font-size: .85rem; }
.pager { display: flex; gap: 6px; justify-content: center; align-items: center; flex-wrap: wrap; margin: 18px 0 4px; }
.pager button { min-width: 38px; height: 38px; padding: 0 12px; border-radius: 100px; border: 1px solid var(--glass-brd);
    background: rgba(255,255,255,.5); backdrop-filter: var(--blur); -webkit-backdrop-filter: var(--blur);
    color: var(--ink); font-family: var(--font); font-weight: 700; font-size: .85rem; cursor: pointer; transition: all .18s; }
.pager button:hover:not(:disabled) { transform: translateY(-1px); background: #fff;
    box-shadow: 0 0 0 1px rgba(255,255,255,.6), 0 6px 18px rgba(120,140,255,.35), 0 8px 26px rgba(255,150,90,.22); }
html[data-theme="dark"] .pager button:hover:not(:disabled) { background: rgba(255,255,255,.16); }
.pager button.active { background: linear-gradient(135deg, var(--blue), var(--teal)); color: #fff; border-color: transparent;
    box-shadow: 0 6px 16px rgba(47,123,246,.45); }
.pager button:disabled { opacity: .4; cursor: not-allowed; }
.pager .ellipsis { padding: 0 2px; color: var(--ink-soft); font-weight: 700; }

/* ---------- POLES GLASS: specular + tepi prismatik ---------- */
.cell, .auth-card, .panel { position: relative; }
.cell::before, .auth-card::before {
    content: ""; position: absolute; top: 0; left: 8%; right: 8%; height: 1px; pointer-events: none;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,.92), transparent); }
.cell::after {
    content: ""; position: absolute; left: 12%; right: 12%; bottom: 0; height: 2px; pointer-events: none;
    background: linear-gradient(90deg, #6ea8ff, #b48cff, #ff9b6e, #5fe0c0); opacity: .35; filter: blur(.5px); }
.cell--total::before { background: linear-gradient(90deg, transparent, rgba(255,255,255,.7), transparent); }
