/* ==========================================
   DRILLBIT GUIDE ANIMATIONS v3
   ========================================== */

/* === CONTAINER === */
.guide-anim{border:1px solid #e2e2e0;border-radius:16px;overflow:hidden;margin:28px 0 32px;background:#fff;box-shadow:0 2px 12px rgba(0,0,0,0.04)}
.ga-slides{position:relative}
.ga-slide{display:none}
.ga-slide.active{display:block}

.guide-anim{position:relative;z-index:0;overflow:hidden;border-radius:14px;margin-bottom:24px;border:1px solid #e5e5e0;background:#fff}

/* === VIEWPORT (animation stage) === */
.ga-viewport{position:relative;height:340px;overflow:hidden;background:#eceae6}

/* === INFO === */
.ga-info{padding:18px 22px 14px;font-family:var(--db-font,system-ui,sans-serif)}
.ga-step-badge{display:inline-block;font-size:10px;font-weight:700;color:#1967D2;background:#E8F0FE;padding:4px 12px;border-radius:20px;margin-bottom:8px;text-transform:uppercase;letter-spacing:.8px}
.ga-info h3{font-size:16px;font-weight:600;margin-bottom:4px;color:#1a1a1a}
.ga-info p{font-size:13px;color:#6b6b6b;line-height:1.55;margin:0}

/* === CONTROLS === */
.ga-controls{display:none}
.ga-viewport{cursor:pointer;position:relative}
.ga-overlay{position:absolute;inset:0;background:rgba(0,0,0,.45);z-index:200;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s ease}
.ga-overlay.on{opacity:1;pointer-events:auto}
.ga-overlay-btn{width:50px;height:50px;border-radius:50%;background:rgba(255,255,255,.9);display:flex;align-items:center;justify-content:center;cursor:pointer}
.ga-overlay-btn svg{width:22px;height:22px;color:#333;margin-left:3px}
.ga-overlay-btn .reset-ico{position:absolute;bottom:10px;right:10px}
.ga-reset-float{position:absolute;bottom:8px;right:8px;width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,.85);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:201;opacity:0;pointer-events:none;transition:opacity .25s ease}
.ga-reset-float.on{opacity:1;pointer-events:auto}
.ga-reset-float svg{width:13px;height:13px;color:#333}
.ga-progress{height:3px;background:#eee;border-radius:2px}
.ga-progress-bar{height:100%;background:#4285f4;transition:width .5s ease;border-radius:2px}

/* === CURSOR === */
.ga-cursor{position:absolute;width:20px;height:24px;z-index:100;pointer-events:none;opacity:0;filter:drop-shadow(1px 2px 2px rgba(0,0,0,.25))}
.ga-cursor.vis{opacity:1}

/* === SCENE: each phase lives in a .sc layer === */
.sc{position:absolute;inset:0;opacity:0;pointer-events:none;transition:opacity .5s ease;font-family:var(--db-font,system-ui,sans-serif)}
.sc.on{opacity:1;pointer-events:auto}

/* ---- SCENE 1: EMAIL ---- */
.sc-email{background:#eceae6;display:flex;align-items:center;justify-content:center}
.em-notif{position:absolute;top:30px;left:50%;transform:translateX(-50%) scale(0);width:220px;background:#fff;border-radius:12px;padding:12px 14px;box-shadow:0 8px 30px rgba(0,0,0,.12);display:flex;align-items:center;gap:10px;z-index:10;opacity:0}
.em-notif.pop{animation:npop .5s cubic-bezier(.34,1.56,.64,1) forwards}
@keyframes npop{0%{opacity:0;transform:translateX(-50%) scale(.5) translateY(-8px)}100%{opacity:1;transform:translateX(-50%) scale(1) translateY(0)}}
.em-notif.gone{animation:ngone .3s ease forwards}
@keyframes ngone{to{opacity:0;transform:translateX(-50%) scale(.9) translateY(-8px)}}
.em-notif-ico{width:34px;height:34px;border-radius:9px;background:#4285f4;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.em-notif-ico svg{width:17px;height:17px}
.em-notif-txt{font-size:11px;color:#333;line-height:1.4}
.em-notif-txt b{display:block;font-size:12px;margin-bottom:1px}

.em-card{width:390px;background:#fff;border-radius:14px;box-shadow:0 12px 40px rgba(0,0,0,.12);overflow:hidden;opacity:0;transform:scale(.88)}
.em-card.pop{animation:ecpop .55s cubic-bezier(.34,1.2,.64,1) forwards}
@keyframes ecpop{0%{opacity:0;transform:scale(.85)}100%{opacity:1;transform:scale(1)}}
.em-bar{height:36px;background:#fafaf8;border-bottom:1px solid #eee;display:flex;align-items:center;padding:0 12px;gap:5px}
.em-bar i{width:8px;height:8px;border-radius:50%;display:block}
.em-bar span{flex:1;text-align:center;font-size:10px;color:#bbb}
.em-body{padding:18px 20px}
.em-subj{font-size:13px;font-weight:600;color:#1a1a1a;margin-bottom:2px}
.em-from{font-size:10px;color:#aaa;margin-bottom:14px}
.em-txt{font-size:11px;color:#666;line-height:1.7;margin-bottom:14px}
.em-creds{background:#f4f8fe;border:1px solid #d6e4fb;border-radius:10px;padding:12px 14px;position:relative}
.em-cr{display:flex;justify-content:space-between;align-items:center;padding:3px 0}
.em-cr+.em-cr{border-top:1px dashed #d6e4fb;margin-top:7px;padding-top:8px}
.em-cr .l{font-size:9px;color:#999;text-transform:uppercase;letter-spacing:.4px}
.em-cr .v{font-size:12px;font-weight:600;color:#1a1a1a}
.em-glow{position:absolute;inset:-2px;border-radius:12px;border:2px solid #4285f4;opacity:0;pointer-events:none}
.em-glow.on{animation:egl 1.5s ease-in-out infinite}
@keyframes egl{0%,100%{opacity:.3;box-shadow:0 0 0 0 rgba(66,133,244,.2)}50%{opacity:1;box-shadow:0 0 0 6px rgba(66,133,244,0)}}
.em-link{display:inline-block;margin-top:12px;font-size:11px;color:#4285f4;text-decoration:underline;cursor:default}
.em-link.hl{background:rgba(66,133,244,.1);border-radius:3px;padding:0 2px}

/* ---- SCENE 2: HOMEPAGE ---- */
.sc-home{background:#fff}
.hp-top{height:44px;background:#fff;border-bottom:1px solid #eee;display:flex;align-items:center;padding:0 20px;justify-content:space-between}
.hp-logo{display:flex;align-items:center;gap:6px}
.hp-logo i{width:18px;height:18px;background:#4285f4;border-radius:5px;display:block}
.hp-logo span{font-size:13px;font-weight:600;color:#1a1a1a}
.hp-nav{display:flex;gap:16px;font-size:11px;color:#777}
.hp-gs-btn{background:#4285f4;color:#fff;font-size:11px;font-weight:600;padding:7px 16px;border-radius:6px;border:none;cursor:default;position:relative;transition:background .15s}
.hp-gs-btn.hl{background:#3367c7;box-shadow:0 0 0 3px rgba(66,133,244,.2)}
.hp-hero{padding:40px 30px;display:flex;gap:30px;align-items:center}
.hp-hero-txt h2{font-size:20px;font-weight:700;color:#1a1a1a;line-height:1.3;margin-bottom:8px}
.hp-hero-txt p{font-size:11px;color:#888;line-height:1.5;max-width:280px}
.hp-hero-art{flex:1;height:160px;background:#f0f2f8;border-radius:16px}

/* Dropdown */
.hp-dd{position:absolute;top:46px;right:16px;width:160px;background:#fff;border-radius:10px;box-shadow:0 6px 24px rgba(0,0,0,.12);overflow:hidden;z-index:20;opacity:0;transform:translateY(-6px);pointer-events:none}
.hp-dd.on{opacity:1;transform:translateY(0);pointer-events:auto;transition:all .25s ease}
.hp-dd-item{padding:10px 14px;font-size:12px;color:#444;display:flex;align-items:center;gap:8px;cursor:default;transition:background .1s}
.hp-dd-item:first-child{border-bottom:1px solid #f0f0f0}
.hp-dd-item.hl{background:#f0f4ff;color:#4285f4}
.hp-dd-item i{width:16px;height:16px;background:#ddd;border-radius:4px;display:block}

/* ---- SCENE 3: LOGIN ---- */
.sc-login{background:#f0f2f8;display:flex}
.lg-art{flex:1;display:flex;align-items:center;justify-content:center}
.lg-art-box{width:220px;height:180px;background:#e0e4ee;border-radius:18px;position:relative;overflow:hidden}
.lg-art-box::before{content:'';position:absolute;bottom:16px;left:20px;width:100px;height:7px;background:#c0c8d8;border-radius:3px}
.lg-art-box::after{content:'';position:absolute;bottom:28px;left:35px;width:45px;height:36px;background:#b0bcd0;border-radius:4px;border:2px solid #a0aec0}
.lg-art-p1{position:absolute;bottom:16px;left:28px;width:36px;height:60px;background:#4285f4;border-radius:10px 10px 5px 5px}
.lg-art-p1::before{content:'';position:absolute;top:-15px;left:7px;width:22px;height:22px;background:#f5c6a0;border-radius:50%}
.lg-art-p2{position:absolute;bottom:16px;right:28px;width:32px;height:55px;background:#f5c6a0;border-radius:9px 9px 5px 5px}
.lg-art-p2::before{content:'';position:absolute;top:-14px;left:5px;width:20px;height:20px;background:#8d6e52;border-radius:50%}

.lg-form{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px}
.lg-logo{display:flex;align-items:center;gap:6px;margin-bottom:4px}
.lg-logo i{width:18px;height:18px;background:#4285f4;border-radius:5px;display:block}
.lg-logo span{font-size:13px;font-weight:600;color:#1a1a1a}
.lg-title{font-size:15px;font-weight:600;color:#1a1a1a;margin-bottom:18px}
.lg-grp{width:200px;margin-bottom:9px}
.lg-lbl{font-size:10px;font-weight:500;color:#777;margin-bottom:3px;display:block}
.lg-inp{width:100%;height:34px;border:1.5px solid #ddd;border-radius:7px;background:#fff;padding:0 10px;font-size:12px;color:#1a1a1a;display:flex;align-items:center;transition:border-color .2s,box-shadow .2s;overflow:hidden}
.lg-inp.fc{border-color:#4285f4;box-shadow:0 0 0 3px rgba(66,133,244,.1)}
.lg-forgot{font-size:10px;color:#4285f4;text-align:right;width:200px;margin:2px 0 12px;cursor:default;transition:color .15s}
.lg-forgot.hl{color:#1a56c7;text-decoration:underline;background:rgba(66,133,244,.08);border-radius:3px;padding:1px 4px}
.lg-btn{width:200px;height:36px;background:#4285f4;color:#fff;border:none;border-radius:7px;font-size:12px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:5px;transition:all .15s;cursor:default}
.lg-btn.press{transform:scale(.97);background:#3367c7}
.lg-btn .ldot{width:12px;height:12px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;display:none;animation:spin .5s linear infinite}
.lg-btn.ld .ldot{display:inline-block}
@keyframes spin{to{transform:rotate(360deg)}}

/* Typing cursor */
.tc{display:inline-block;width:2px;height:13px;background:#4285f4;vertical-align:middle;margin-left:1px;animation:tcb .5s step-end infinite}
@keyframes tcb{50%{opacity:0}}

/* ---- SCENE 4: DASHBOARD ---- */
.sc-dash{background:#fff;display:flex}
.ds-side{width:115px;background:#fafafc;border-right:1px solid #eee;padding:12px 0;display:flex;flex-direction:column;gap:1px}
.ds-side-logo{display:flex;align-items:center;gap:5px;padding:0 12px 14px}
.ds-side-logo i{width:18px;height:18px;background:#4285f4;border-radius:5px;display:block}
.ds-side-logo span{font-size:12px;font-weight:600;color:#1a1a1a}
.ds-nav{padding:8px 12px;font-size:10px;color:#999;display:flex;align-items:center;gap:7px;margin-right:6px;border-radius:0 7px 7px 0}
.ds-nav i{width:14px;height:14px;border-radius:4px;background:currentColor;opacity:.2;display:block}
.ds-nav.act{background:#4285f4;color:#fff;font-weight:600}
.ds-nav.act i{opacity:.5}
.ds-body{flex:1;padding:12px 16px;overflow:hidden}
.ds-top{display:flex;justify-content:flex-end;align-items:center;gap:7px;margin-bottom:12px}
.ds-uname{font-size:10px;color:#888}
.ds-uname b{color:#333}
.ds-av{width:28px;height:28px;border-radius:50%;background:#9c5fff;color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center}
.ds-cards{display:flex;gap:10px;margin-bottom:12px}
.ds-card{flex:1;border:1px solid #eee;border-radius:11px;padding:12px;position:relative;opacity:0;transform:translateY(10px);transition:opacity .4s ease,transform .4s ease}
.ds-card.pop{opacity:1;transform:translateY(0)}
.ds-card-lbl{font-size:10px;color:#aaa;margin-bottom:1px}
.ds-card-val{font-size:20px;font-weight:700;color:#1a1a1a}
.ds-card-ico{position:absolute;top:10px;right:10px;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.ds-card-ico svg{width:14px;height:14px}
.ds-chart{border:1px solid #eee;border-radius:11px;padding:12px 14px;opacity:0;transform:translateY(10px);transition:opacity .4s ease,transform .4s ease}
.ds-chart.pop{opacity:1;transform:translateY(0)}
.ds-chart-hd{font-size:11px;font-weight:600;color:#1a1a1a;margin-bottom:12px;display:flex;justify-content:space-between}
.ds-chart-hd span{font-size:9px;color:#aaa;background:#f5f5f3;padding:2px 7px;border-radius:4px}
.ds-bars{display:flex;align-items:stretch;gap:5px;height:65px}
.ds-bar-c{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end}
.ds-bar{width:100%;max-width:24px;background:#4285f4;border-radius:3px 3px 0 0;height:0;transition:height .7s cubic-bezier(.34,1.56,.64,1)}
.ds-bar-l{font-size:8px;color:#ccc;margin-top:4px}

/* ---- TIP CALLOUT (inline, not overlay) ---- */
.ga-tip{position:absolute;z-index:40;background:#fffde7;border:1px solid #f0e68c;border-radius:10px;padding:10px 14px;box-shadow:0 4px 16px rgba(0,0,0,.08);opacity:0;transform:translateY(6px);pointer-events:none;transition:opacity .35s ease,transform .35s ease;display:flex;align-items:flex-start;gap:8px;max-width:280px;font-family:var(--db-font,system-ui,sans-serif)}
.ga-tip.on{opacity:1;transform:translateY(0)}
.ga-tip-ico{width:20px;height:20px;flex-shrink:0;margin-top:1px}
.ga-tip-ico svg{width:20px;height:20px}
.ga-tip-txt{font-size:11px;color:#5d4e00;line-height:1.5}
.ga-tip-txt b{font-weight:600;color:#3e3300}

/* ---- ERROR POPUP (kept for other uses) ---- */
.err-overlay{position:absolute;inset:0;background:rgba(0,0,0,.3);z-index:60;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none}
.err-overlay.on{opacity:1;pointer-events:auto;transition:opacity .3s ease}
.err-box{background:#fff;border-radius:14px;padding:24px 28px;max-width:320px;box-shadow:0 12px 40px rgba(0,0,0,.18);text-align:center;transform:scale(.85);transition:transform .35s cubic-bezier(.34,1.3,.64,1);font-family:var(--db-font,system-ui,sans-serif)}
.err-overlay.on .err-box{transform:scale(1)}
.err-ico{width:44px;height:44px;border-radius:50%;background:#fce8e8;display:flex;align-items:center;justify-content:center;margin:0 auto 12px}
.err-ico svg{width:22px;height:22px}
.err-title{font-size:14px;font-weight:600;color:#c0392b;margin-bottom:6px}
.err-msg{font-size:12px;color:#666;line-height:1.55}

/* ---- LOGIN FIELD ERROR STATE ---- */
.lg-inp.err{border-color:#e74c3c;box-shadow:0 0 0 3px rgba(231,76,60,.1)}
.lg-inp.err-shake{animation:fshake .4s ease}
@keyframes fshake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-6px)}40%,80%{transform:translateX(6px)}}

/* ---- SUCCESS CHECKMARK ---- */
.lg-success{position:absolute;inset:0;background:rgba(255,255,255,.95);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:30;opacity:0;pointer-events:none;font-family:var(--db-font,system-ui,sans-serif)}
.lg-success.on{opacity:1;transition:opacity .4s ease}
.lg-success-check{width:50px;height:50px;border-radius:50%;background:#e8f5e9;display:flex;align-items:center;justify-content:center;margin-bottom:10px}
.lg-success-check svg{width:26px;height:26px}
.lg-success-txt{font-size:14px;font-weight:600;color:#2e7d32}

/* ---- TOAST NOTIFICATION ---- */
.ga-toast{position:absolute;top:10px;right:10px;background:#fff;border-radius:10px;padding:10px 14px;box-shadow:0 4px 20px rgba(0,0,0,.12);display:flex;align-items:center;gap:8px;z-index:50;opacity:0;transform:translateY(-10px);pointer-events:none;transition:opacity .3s ease,transform .3s ease;max-width:260px;font-family:var(--db-font,system-ui,sans-serif)}
.ga-toast.on{opacity:1;transform:translateY(0)}
.ga-toast-ico{width:22px;height:22px;flex-shrink:0}
.ga-toast-ico svg{width:22px;height:22px}
.ga-toast-txt{font-size:11px;color:#333;line-height:1.4}
.ga-toast-bar{position:absolute;bottom:0;left:10px;right:10px;height:3px;background:#eee;border-radius:2px;overflow:hidden}
.ga-toast-bar-fill{height:100%;background:#1D9E75;width:100%;border-radius:2px}
.ga-toast-bar-fill.run{animation:toastBar 2s linear forwards}
@keyframes toastBar{from{width:100%}to{width:0%}}

/* ---- FORGOT PASSWORD PAGE ---- */
.sc-forgot{background:#f0f2f8;display:flex}
.fp-form{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px}
.fp-title{font-size:16px;font-weight:700;color:#1a1a1a;margin-bottom:16px}
.fp-grp{width:210px;margin-bottom:12px}
.fp-lbl{font-size:10px;font-weight:500;color:#777;margin-bottom:3px;display:block}
.fp-inp{width:100%;height:34px;border:1.5px solid #ddd;border-radius:7px;background:#fff;padding:0 10px;font-size:12px;color:#1a1a1a;display:flex;align-items:center;transition:border-color .2s,box-shadow .2s;overflow:hidden}
.fp-inp.fc{border-color:#4285f4;box-shadow:0 0 0 3px rgba(66,133,244,.1)}
.fp-btn{width:210px;height:36px;background:#4285f4;color:#fff;border:none;border-radius:7px;font-size:12px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:5px;transition:all .15s;cursor:default}
.fp-btn.press{transform:scale(.97);background:#3367c7}
.fp-btn .ldot{width:12px;height:12px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;display:none;animation:spin .5s linear infinite}
.fp-btn.ld .ldot{display:inline-block}
.fp-back{font-size:10px;color:#4285f4;margin-top:10px;width:210px;text-align:center;transition:color .15s}
.fp-back.hl{color:#1a56c7;text-decoration:underline}

/* ---- RESET PASSWORD PAGE ---- */
.sc-reset{background:#f0f2f8;display:flex}
.rp-form{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px}
.rp-title{font-size:16px;font-weight:700;color:#1a1a1a;margin-bottom:16px}

/* ---- RESET EMAIL CARD (compact) ---- */
.sc-resetmail{background:#eceae6;display:flex;align-items:center;justify-content:center}
.rm-card{width:380px;background:#fff;border-radius:12px;box-shadow:0 10px 36px rgba(0,0,0,.1);overflow:hidden;opacity:0;transform:scale(.88)}
.rm-card.pop{animation:ecpop .55s cubic-bezier(.34,1.2,.64,1) forwards}
.rm-bar{height:34px;background:#fafaf8;border-bottom:1px solid #eee;display:flex;align-items:center;padding:0 12px;gap:5px}
.rm-bar i{width:8px;height:8px;border-radius:50%;display:block}
.rm-bar span{flex:1;text-align:center;font-size:10px;color:#bbb}
.rm-body{padding:16px 18px;font-family:var(--db-font,system-ui,sans-serif)}
.rm-subj{font-size:12px;font-weight:600;color:#1a1a1a;margin-bottom:2px}
.rm-from{font-size:10px;color:#aaa;margin-bottom:12px}
.rm-txt{font-size:11px;color:#666;line-height:1.6;margin-bottom:10px}
.rm-link{display:inline-block;font-size:10px;color:#4285f4;text-decoration:underline;word-break:break-all;cursor:default}
.rm-link.hl{background:rgba(66,133,244,.12);border-radius:3px;padding:2px 4px}

/* ---- PROFILE DROPDOWN ---- */
.ds-profile-dd{position:absolute;top:42px;right:14px;width:190px;background:#fff;border-radius:12px;box-shadow:0 6px 28px rgba(0,0,0,.14);z-index:30;overflow:hidden;opacity:0;transform:translateY(-6px);pointer-events:none;transition:opacity .25s ease,transform .25s ease;font-family:var(--db-font,system-ui,sans-serif)}
.ds-profile-dd.on{opacity:1;transform:translateY(0);pointer-events:auto}
.ds-dd-header{padding:12px 14px;border-bottom:1px solid #f0f0f0;display:flex;align-items:center;gap:8px}
.ds-dd-header .dd-av{width:30px;height:30px;border-radius:50%;background:#9c5fff;color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ds-dd-header .dd-info{font-size:10px;color:#888;line-height:1.3}
.ds-dd-header .dd-info b{display:block;font-size:11px;color:#333}
.ds-dd-item{padding:10px 14px;font-size:11px;color:#444;display:flex;align-items:center;gap:9px;cursor:default;transition:background .1s;border-bottom:1px solid #f8f8f8}
.ds-dd-item:last-child{border-bottom:none}
.ds-dd-item.hl{background:#f0f4ff;color:#4285f4}
.ds-dd-item .dd-ico{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ds-dd-item .dd-ico svg{width:14px;height:14px}
.ds-dd-item .dd-label{line-height:1.3}
.ds-dd-item .dd-label small{display:block;font-size:9px;color:#aaa}
.ds-dd-item.switch-item .dd-ico{background:#e8f5e9}
.ds-dd-item.acct-item .dd-ico{background:#e3f2fd}
.ds-dd-item.help-item .dd-ico{background:#e8f5e9}
.ds-dd-item.pw-item .dd-ico{background:#e3f2fd}
.ds-dd-logout{margin:6px 10px 10px;padding:8px;background:#4285f4;color:#fff;border-radius:8px;font-size:11px;font-weight:600;text-align:center;cursor:default}

/* ---- USER DASHBOARD (after switch) ---- */
.sc-userdash{background:#fff;display:flex}
.ud-side{width:115px;background:#fafafc;border-right:1px solid #eee;padding:12px 0;display:flex;flex-direction:column;gap:1px}
.ud-side-logo{display:flex;align-items:center;gap:5px;padding:0 12px 14px}
.ud-side-logo i{width:18px;height:18px;background:#4285f4;border-radius:5px;display:block}
.ud-side-logo span{font-size:12px;font-weight:600;color:#1a1a1a}
.ud-nav{padding:8px 12px;font-size:10px;color:#999;display:flex;align-items:center;gap:7px;margin-right:6px;border-radius:0 7px 7px 0}
.ud-nav i{width:14px;height:14px;border-radius:4px;background:currentColor;opacity:.2;display:block}
.ud-nav.act{background:#4285f4;color:#fff;font-weight:600}
.ud-nav.act i{opacity:.5}
.ud-body{flex:1;padding:12px 16px;overflow:hidden}
.ud-top{display:flex;justify-content:flex-end;align-items:center;gap:7px;margin-bottom:12px}
.ud-uname{font-size:10px;color:#888}
.ud-uname b{color:#333}
.ud-av{width:28px;height:28px;border-radius:50%;background:#9c5fff;color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center}
.ud-cards{display:flex;gap:10px;margin-bottom:12px}
.ud-card{flex:1;border:1px solid #eee;border-radius:11px;padding:12px;position:relative;opacity:0;transform:translateY(10px);transition:opacity .4s ease,transform .4s ease}
.ud-card.pop{opacity:1;transform:translateY(0)}
.ud-card-lbl{font-size:10px;color:#aaa;margin-bottom:1px}
.ud-card-val{font-size:20px;font-weight:700;color:#1a1a1a}
.ud-card-ico{position:absolute;top:10px;right:10px;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.ud-card-ico svg{width:14px;height:14px}
.ud-recent{border:1px solid #eee;border-radius:11px;padding:12px 14px;opacity:0;transform:translateY(10px);transition:opacity .4s ease,transform .4s ease}
.ud-recent.pop{opacity:1;transform:translateY(0)}
.ud-recent-hd{font-size:11px;font-weight:600;color:#1a1a1a;margin-bottom:10px}
.ud-recent-row{display:flex;align-items:center;gap:8px;padding:7px 0;border-bottom:1px solid #f5f5f5;font-size:10px;color:#666}
.ud-recent-row:last-child{border-bottom:none}
.ud-recent-row .ur-av{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:600;color:#fff;flex-shrink:0}
.ud-recent-row .ur-name{flex:1}
.ud-recent-row .ur-name b{display:block;font-size:11px;color:#333}
.ud-recent-row .ur-pct{padding:3px 8px;background:#e8f5e9;color:#2e7d32;border-radius:6px;font-size:10px;font-weight:600}
.ud-recent-row .ur-status{color:#2e7d32;font-size:9px;display:flex;align-items:center;gap:3px}
.ud-recent-row .ur-status i{width:5px;height:5px;border-radius:50%;background:#2e7d32;display:block}
.ud-recent-row .ur-btn{background:#7c6cf0;color:#fff;padding:4px 10px;border-radius:6px;font-size:9px;font-weight:600}

/* ---- ACCOUNT INFO PAGE ---- */
.sc-acctinfo{background:#fff;display:flex}
.ai-side{width:115px;background:#fafafc;border-right:1px solid #eee;padding:12px 0;display:flex;flex-direction:column;gap:1px}
.ai-side-logo{display:flex;align-items:center;gap:5px;padding:0 12px 14px}
.ai-side-logo i{width:18px;height:18px;background:#4285f4;border-radius:5px;display:block}
.ai-side-logo span{font-size:12px;font-weight:600;color:#1a1a1a}
.ai-nav{padding:8px 12px;font-size:10px;color:#999;display:flex;align-items:center;gap:7px;margin-right:6px;border-radius:0 7px 7px 0}
.ai-nav i{width:14px;height:14px;border-radius:4px;background:currentColor;opacity:.2;display:block}
.ai-body{flex:1;padding:12px 16px;overflow-y:auto;-ms-overflow-style:none;scrollbar-width:none}
.ai-body::-webkit-scrollbar{display:none}
.ai-top{display:flex;justify-content:flex-end;align-items:center;gap:7px;margin-bottom:10px}
.ai-uname{font-size:10px;color:#888}
.ai-uname b{color:#333}
.ai-av{width:28px;height:28px;border-radius:50%;background:#9c5fff;color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center}
.ai-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}
.ai-title{font-size:15px;font-weight:700;color:#1a1a1a}
.ai-logo-btn{background:#4285f4;color:#fff;font-size:9px;font-weight:600;padding:6px 14px;border-radius:6px;display:flex;align-items:center;gap:4px;cursor:default}
.ai-logo-btn svg{width:12px;height:12px}
.ai-profile-pic{width:50px;height:50px;border-radius:50%;background:#f0a030;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:#fff;flex-shrink:0}
.ai-format-note{font-size:8px;color:#aaa;margin-bottom:10px}
.ai-table{width:100%;border-collapse:collapse}
.ai-table tr{border-bottom:1px solid #f0f0f0}
.ai-table td{padding:7px 0;font-size:10px;vertical-align:top}
.ai-table td:first-child{color:#888;width:42%}
.ai-table td:last-child{color:#1a1a1a;font-weight:500}
.ai-row{opacity:0;transform:translateX(-8px);transition:opacity .3s ease,transform .3s ease}
.ai-row.pop{opacity:1;transform:translateX(0)}

/* ---- CHANGE PASSWORD PAGE ---- */
.sc-changepw{background:#f0f0ee;display:flex}
.cp-side{width:115px;background:#fafafc;border-right:1px solid #eee;padding:12px 0;display:flex;flex-direction:column;gap:1px}
.cp-side-logo{display:flex;align-items:center;gap:5px;padding:0 12px 14px}
.cp-side-logo i{width:18px;height:18px;background:#4285f4;border-radius:5px;display:block}
.cp-side-logo span{font-size:12px;font-weight:600;color:#1a1a1a}
.cp-nav{padding:8px 12px;font-size:10px;color:#999;display:flex;align-items:center;gap:7px;margin-right:6px;border-radius:0 7px 7px 0}
.cp-nav i{width:14px;height:14px;border-radius:4px;background:currentColor;opacity:.2;display:block}
.cp-body{flex:1;padding:14px 20px;overflow:hidden}
.cp-top{display:flex;justify-content:flex-end;align-items:center;gap:7px;margin-bottom:12px}
.cp-uname{font-size:10px;color:#888}
.cp-uname b{color:#333}
.cp-av{width:28px;height:28px;border-radius:50%;background:#9c5fff;color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center}
.cp-title{font-size:15px;font-weight:700;color:#1a1a1a;margin-bottom:14px}
.cp-form-area{background:#f8f8f6;border-radius:12px;padding:18px 20px;max-width:340px}
.cp-grp{margin-bottom:12px}
.cp-lbl{font-size:10px;font-weight:500;color:#777;margin-bottom:3px;display:block}
.cp-inp{width:100%;height:34px;border:1.5px solid #ddd;border-radius:7px;background:#fff;padding:0 10px;font-size:12px;color:#1a1a1a;display:flex;align-items:center;transition:border-color .2s,box-shadow .2s;overflow:hidden}
.cp-inp.fc{border-color:#4285f4;box-shadow:0 0 0 3px rgba(66,133,244,.1)}
.cp-btn{width:100%;height:36px;background:#4285f4;color:#fff;border:none;border-radius:7px;font-size:12px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:5px;transition:all .15s;cursor:default;margin-top:14px}
.cp-btn.press{transform:scale(.97);background:#3367c7}
.cp-btn .ldot{width:12px;height:12px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;display:none;animation:spin .5s linear infinite}
.cp-btn.ld .ldot{display:inline-block}

/* ---- ANNOUNCEMENTS PAGE ---- */
.sc-announce{background:#f0f0ee;display:flex}
.an-side{width:115px;background:#fafafc;border-right:1px solid #eee;padding:12px 0;display:flex;flex-direction:column;gap:1px}
.an-side-logo{display:flex;align-items:center;gap:5px;padding:0 12px 14px}
.an-side-logo i{width:18px;height:18px;background:#4285f4;border-radius:5px;display:block}
.an-side-logo span{font-size:12px;font-weight:600;color:#1a1a1a}
.an-nav{padding:8px 12px;font-size:10px;color:#999;display:flex;align-items:center;gap:7px;margin-right:6px;border-radius:0 7px 7px 0}
.an-nav i{width:14px;height:14px;border-radius:4px;background:currentColor;opacity:.2;display:block}
.an-body{flex:1;padding:14px 16px;overflow:hidden;position:relative}
.an-top{display:flex;justify-content:flex-end;align-items:center;gap:7px;margin-bottom:8px}
.an-uname{font-size:10px;color:#888}
.an-uname b{color:#333}
.an-av{width:28px;height:28px;border-radius:50%;background:#9c5fff;color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center}
.an-breadcrumb{font-size:10px;color:#888;margin-bottom:12px}
.an-breadcrumb b{color:#1a1a1a;font-weight:600}
.an-tabs{display:flex;gap:0;margin-bottom:14px}
.an-tab{padding:7px 14px;font-size:10px;font-weight:600;border:none;background:#eee;color:#888;cursor:default;border-radius:6px 6px 0 0;transition:all .15s}
.an-tab.act{background:#4285f4;color:#fff}
.an-search{float:right;font-size:9px;color:#aaa;border:1px solid #ddd;border-radius:5px;padding:5px 10px;background:#fff;margin-top:-30px}
.an-empty{border:1px solid #ddd;border-radius:8px;padding:20px;text-align:center;color:#aaa;font-size:11px;background:#fff}
.an-empty-ico{font-size:16px;margin-bottom:4px;opacity:.4}
.an-fab{position:absolute;bottom:14px;right:14px;width:36px;height:36px;border-radius:50%;background:#4285f4;color:#fff;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:300;cursor:default;box-shadow:0 3px 12px rgba(66,133,244,.3);transition:transform .15s}
.an-fab.hl{transform:scale(1.1)}

/* Slide panel */
.an-panel{position:absolute;top:0;right:0;bottom:0;width:55%;background:#fff;box-shadow:-4px 0 24px rgba(0,0,0,.1);z-index:20;transform:translateX(100%);transition:transform .4s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;padding:16px 18px;overflow-y:auto}
.an-panel.on{transform:translateX(0)}
.an-panel-close{position:absolute;top:10px;right:14px;font-size:16px;color:#aaa;cursor:default}
.an-panel-art{height:80px;background:#f0f2f8;border-radius:10px;margin-bottom:14px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.an-panel-art-person{width:40px;height:50px;background:#4285f4;border-radius:10px;position:relative}
.an-panel-art-person::before{content:'';position:absolute;top:-12px;left:10px;width:20px;height:20px;background:#f5c6a0;border-radius:50%}
.an-panel-art-dots{position:absolute;top:10px;right:20px;display:flex;gap:5px;flex-wrap:wrap;width:40px}
.an-panel-art-dots i{width:8px;height:8px;border-radius:50%;display:block}
.an-panel-grp{margin-bottom:10px}
.an-panel-lbl{font-size:10px;font-weight:500;color:#777;margin-bottom:3px;display:block}
.an-panel-inp{width:100%;height:32px;border:1.5px solid #ddd;border-radius:6px;background:#fff;padding:0 10px;font-size:11px;color:#1a1a1a;display:flex;align-items:center;transition:border-color .2s,box-shadow .2s;overflow:hidden}
.an-panel-inp.fc{border-color:#4285f4;box-shadow:0 0 0 3px rgba(66,133,244,.1)}
.an-panel-textarea{width:100%;height:70px;border:1.5px solid #ddd;border-radius:6px;background:#fff;padding:8px 10px;font-size:11px;color:#1a1a1a;transition:border-color .2s,box-shadow .2s;overflow:hidden;line-height:1.5;display:block}
.an-panel-textarea.fc{border-color:#4285f4;box-shadow:0 0 0 3px rgba(66,133,244,.1)}
.an-panel-btn{width:100%;height:34px;background:#4285f4;color:#fff;border:none;border-radius:7px;font-size:12px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:5px;transition:all .15s;cursor:default;margin-top:10px}
.an-panel-btn.press{transform:scale(.97);background:#3367c7}
.an-panel-btn .ldot{width:12px;height:12px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;display:none;animation:spin .5s linear infinite}
.an-panel-btn.ld .ldot{display:inline-block}

/* Announcement item (after creation) */
.an-item{border:1px solid #ddd;border-radius:8px;padding:12px 14px;background:#fff;opacity:0;transform:translateY(8px);transition:opacity .3s ease,transform .3s ease}
.an-item.pop{opacity:1;transform:translateY(0)}
.an-item-title{font-size:11px;font-weight:600;color:#1a1a1a;margin-bottom:3px}
.an-item-txt{font-size:10px;color:#888;line-height:1.5}
.an-item-date{font-size:9px;color:#bbb;margin-top:6px}
.an-item.found{border-color:#4285f4;box-shadow:0 0 0 3px rgba(66,133,244,.12)}
.an-search-box.fc{border-color:#4285f4 !important;box-shadow:0 0 0 2px rgba(66,133,244,.1)}

/* ---- FULL DASHBOARD (for dashboard article) ---- */
.sc-dashfull{background:#fff;display:flex}
.df-side{width:115px;background:#fafafc;border-right:1px solid #eee;padding:12px 0;display:flex;flex-direction:column;gap:1px}
.df-side-logo{display:flex;align-items:center;gap:5px;padding:0 12px 14px}
.df-side-logo i{width:18px;height:18px;background:#4285f4;border-radius:5px;display:block}
.df-side-logo span{font-size:12px;font-weight:600;color:#1a1a1a}
.df-nav{padding:8px 12px;font-size:10px;color:#999;display:flex;align-items:center;gap:7px;margin-right:6px;border-radius:0 7px 7px 0}
.df-nav i{width:14px;height:14px;border-radius:4px;background:currentColor;opacity:.2;display:block}
.df-nav.act{background:#4285f4;color:#fff;font-weight:600}
.df-nav.act i{opacity:.5}
.df-body{flex:1;padding:10px 14px;overflow-y:auto;-ms-overflow-style:none;scrollbar-width:none}
.df-body::-webkit-scrollbar{display:none}
.df-top{display:flex;justify-content:flex-end;align-items:center;gap:7px;margin-bottom:8px}
.df-uname{font-size:10px;color:#888}
.df-uname b{color:#333}
.df-av{width:28px;height:28px;border-radius:50%;background:#9c5fff;color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center}
.df-stats{display:flex;gap:8px;margin-bottom:10px}
.df-stat{flex:1;border:1px solid #eee;border-radius:10px;padding:10px;position:relative;opacity:0;transform:translateY(8px);transition:opacity .4s ease,transform .4s ease}
.df-stat.pop{opacity:1;transform:translateY(0)}
.df-stat-lbl{font-size:9px;color:#aaa;margin-bottom:1px}
.df-stat-val{font-size:18px;font-weight:700;color:#1a1a1a}
.df-stat-ico{position:absolute;top:8px;right:8px;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.df-stat-ico svg{width:12px;height:12px}
.df-row{display:flex;gap:8px;margin-bottom:8px}
.df-panel{flex:1;border:1px solid #eee;border-radius:10px;padding:10px;opacity:0;transform:translateY(8px);transition:opacity .4s ease,transform .4s ease;min-height:80px;position:relative;overflow:hidden}
.df-panel.pop{opacity:1;transform:translateY(0)}
.df-panel-hd{font-size:10px;font-weight:600;color:#1a1a1a;margin-bottom:2px;display:flex;justify-content:space-between;align-items:center}
.df-panel-hd small{font-size:8px;color:#bbb;font-weight:400}
.df-panel-hd .df-hm{width:14px;height:10px;display:flex;flex-direction:column;gap:2px;cursor:default}
.df-hm span{display:block;width:100%;height:2px;background:#ccc;border-radius:1px}
/* Mini bar chart */
.df-mini-bars{display:flex;align-items:stretch;gap:3px;height:65px;margin-top:6px}
.df-mini-bar{width:100%;background:#4285f4;border-radius:2px 2px 0 0;min-width:6px;height:0;transition:height .7s cubic-bezier(.34,1.56,.64,1)}
.df-mini-bar-lbl{font-size:7px;color:#ccc;text-align:center;margin-top:2px}
.df-mini-bar-c{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end}
/* SVG donut/pie */
.df-donut{width:70px;height:70px;margin:4px auto}
.df-donut circle{fill:none;stroke-width:8;transition:stroke-dasharray 1.2s ease}
.df-donut text{font-size:8px;font-weight:600;fill:#1a1a1a;font-family:var(--db-font,system-ui,sans-serif)}
.df-donut .donut-track{stroke:#eee}
.df-donut .donut-fill{stroke:#4285f4;stroke-linecap:round;stroke-dasharray:0 999;transition:stroke-dasharray 1.2s ease}
.df-donut .donut-fill2{stroke:#1a3a8a;stroke-linecap:round;stroke-dasharray:0 999;transition:stroke-dasharray 1.2s ease}
.df-pie{width:60px;height:60px;border-radius:50%;margin:4px auto;position:relative;overflow:hidden;background:conic-gradient(#4285f4 0% 0%,#eee 0% 100%);transition:background 1s ease}
.df-legend{display:flex;gap:6px;flex-wrap:wrap;margin-top:4px;justify-content:center}
.df-legend-item{display:flex;align-items:center;gap:3px;font-size:7px;color:#888}
.df-legend-item i{width:6px;height:6px;border-radius:50%;display:block}
.df-renew{font-size:8px;color:#4285f4;text-decoration:underline;margin-top:4px;display:block}
/* Similarity ranges line */
.df-line-chart{height:50px;margin-top:6px;position:relative}
.df-line-chart svg{width:100%;height:100%}
.df-line-chart polyline{fill:none;stroke:#4285f4;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:999;stroke-dashoffset:999;transition:stroke-dashoffset 1.5s ease}
.df-line-chart polyline.drawn{stroke-dashoffset:0}
.df-line-labels{display:flex;justify-content:space-between;font-size:7px;color:#ccc;margin-top:2px}

/* Dashboard highlight for individual sections */
.df-stat.hl,.df-panel.hl{border-color:#4285f4;box-shadow:0 0 0 3px rgba(66,133,244,.12);transform:scale(1.04);z-index:15;position:relative;transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;background:#fff}
.df-blur-overlay{position:absolute;inset:0;background:rgba(255,255,255,.55);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);z-index:10;opacity:0;pointer-events:none;transition:opacity .3s ease}
.df-blur-overlay.on{opacity:1}
/* User management highlights above blur */
.um-tab.hl{z-index:15;position:relative;box-shadow:0 0 0 3px rgba(66,133,244,.15);border-radius:6px}
.um-table tbody tr.hl{z-index:15;position:relative;background:#fff;box-shadow:0 2px 12px rgba(66,133,244,.12);border-radius:4px}
.um-fab.hl{z-index:15;box-shadow:0 0 0 4px rgba(66,133,244,.2);transform:scale(1.1)}
.um-stats-ico.hl{z-index:15;position:relative;background:rgba(66,133,244,.1);border-radius:4px;padding:2px}
.um-actions-hl.hl{z-index:15;position:relative;background:#fff;box-shadow:0 2px 12px rgba(66,133,244,.12);border-radius:4px}
/* Individual action card highlight */
.um-act-card{position:absolute;z-index:16;background:#fff;border:1.5px solid #4285f4;border-radius:10px;padding:10px 14px;box-shadow:0 6px 24px rgba(66,133,244,.15);display:flex;align-items:center;gap:10px;opacity:0;transform:scale(.9);pointer-events:none;transition:opacity .3s ease,transform .3s ease;font-family:var(--db-font,system-ui,sans-serif)}
.um-act-card.on{opacity:1;transform:scale(1)}
.um-act-card-ico{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.um-act-card-ico svg{width:16px;height:16px}
.um-act-card-info{font-size:9px;color:#555;line-height:1.4}
.um-act-card-info b{display:block;font-size:10px;color:#1a1a1a;margin-bottom:1px}
.df-tooltip{position:absolute;background:#fffef5;color:#333;font-size:9px;padding:8px 12px;border-radius:8px;z-index:30;opacity:0;pointer-events:none;transition:opacity .3s ease;white-space:normal;font-family:var(--db-font,system-ui,sans-serif);line-height:1.5;max-width:220px;letter-spacing:.2px;box-shadow:0 4px 20px rgba(0,0,0,.12);border:1px solid #f0e8c8}
.df-tooltip.on{opacity:1}
.df-tooltip::after{content:'';position:absolute;top:-5px;left:20px;width:10px;height:10px;background:#fffef5;transform:rotate(45deg);border-radius:2px;border-left:1px solid #f0e8c8;border-top:1px solid #f0e8c8}

/* ---- USER MANAGEMENT PAGE ---- */
.sc-usermgmt{background:#f0f0ee;display:flex}
.um-side{width:115px;background:#fafafc;border-right:1px solid #eee;padding:12px 0;display:flex;flex-direction:column;gap:1px}
.um-side-logo{display:flex;align-items:center;gap:5px;padding:0 12px 14px}
.um-side-logo i{width:18px;height:18px;background:#4285f4;border-radius:5px;display:block}
.um-side-logo span{font-size:12px;font-weight:600;color:#1a1a1a}
.um-nav{padding:8px 12px;font-size:10px;color:#999;display:flex;align-items:center;gap:7px;margin-right:6px;border-radius:0 7px 7px 0}
.um-nav i{width:14px;height:14px;border-radius:4px;background:currentColor;opacity:.2;display:block}
.um-nav.act{background:#4285f4;color:#fff;font-weight:600}
.um-nav.act i{opacity:.5}
.um-body{flex:1;padding:12px 14px;overflow:hidden;position:relative}
.um-top{display:flex;justify-content:flex-end;align-items:center;gap:7px;margin-bottom:6px}
.um-uname{font-size:10px;color:#888}
.um-uname b{color:#333}
.um-av{width:28px;height:28px;border-radius:50%;background:#9c5fff;color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center}
.um-breadcrumb{font-size:10px;color:#888;margin-bottom:10px}
.um-breadcrumb b{color:#1a1a1a;font-weight:600}
.um-tabs{display:flex;gap:0;margin-bottom:10px}
.um-tab{padding:6px 12px;font-size:9px;font-weight:600;background:#eee;color:#888;cursor:default;border-radius:6px 6px 0 0;transition:all .15s}
.um-tab.act{background:#4285f4;color:#fff}
.um-search-row{display:flex;justify-content:flex-end;align-items:center;gap:6px;margin-bottom:8px}
.um-csv-ico{width:24px;height:24px;border:1px solid #ddd;border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:8px;color:#888;cursor:default}
.um-search-inp{border:1px solid #ddd;border-radius:5px;padding:4px 8px;font-size:8px;color:#aaa;background:#fff;width:120px}
.um-table{width:100%;border-collapse:collapse;font-size:8px;font-family:var(--db-font,system-ui,sans-serif)}
.um-table thead th{padding:5px 4px;text-align:left;color:#666;font-weight:600;border-bottom:1.5px solid #ddd;font-size:8px}
.um-table tbody tr{border-bottom:1px solid #f0f0f0;opacity:0;transform:translateY(6px);transition:opacity .3s ease,transform .3s ease}
.um-table tbody tr.pop{opacity:1;transform:translateY(0)}
.um-table td{padding:5px 4px;color:#444;vertical-align:middle;white-space:nowrap}
.um-status{display:flex;align-items:center;gap:3px;font-size:8px}
.um-status i{width:5px;height:5px;border-radius:50%;display:block}
.um-status.active i{background:#4caf50}
.um-status.active{color:#4caf50}
.um-status.inactive i{background:#e74c3c}
.um-status.inactive{color:#e74c3c}
.um-actions{display:flex;gap:3px;align-items:center}
.um-act-btn{width:18px;height:18px;border:1px solid #ddd;border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:default;font-size:8px;color:#888}
.um-act-btn svg{width:10px;height:10px}
.um-toggle{width:24px;height:13px;border-radius:8px;background:#4285f4;position:relative;cursor:default}
.um-toggle::after{content:'';position:absolute;top:2px;right:2px;width:9px;height:9px;border-radius:50%;background:#fff;transition:all .2s}
.um-toggle.off{background:#ccc}
.um-toggle.off::after{right:auto;left:2px}
.um-stats-ico{font-size:10px;color:#888;cursor:default}
.um-fab{position:absolute;bottom:12px;right:12px;width:32px;height:32px;border-radius:50%;background:#4285f4;color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:300;cursor:default;box-shadow:0 3px 12px rgba(66,133,244,.3)}
/* Highlight row */
.um-table tbody tr.hl{background:rgba(66,133,244,.06);border-color:#4285f4}
.um-tab.hl,.um-fab.hl,.um-act-btn.hl,.um-stats-ico.hl{box-shadow:0 0 0 3px rgba(66,133,244,.15);border-radius:6px}

/* Confirmation dialog overlay */
.um-dialog{position:absolute;inset:0;background:rgba(0,0,0,.25);z-index:20;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s ease}
.um-dialog.on{opacity:1;pointer-events:auto}
.um-dialog-box{background:#fff;border-radius:14px;padding:20px 24px;max-width:240px;text-align:center;box-shadow:0 12px 40px rgba(0,0,0,.15);transform:scale(.85);transition:transform .35s cubic-bezier(.34,1.3,.64,1);font-family:var(--db-font,system-ui,sans-serif)}
.um-dialog.on .um-dialog-box{transform:scale(1)}
.um-dialog-ico{width:32px;height:32px;margin:0 auto 8px;display:flex;align-items:center;justify-content:center}
.um-dialog-ico svg{width:24px;height:24px}
.um-dialog-msg{font-size:10px;color:#444;margin-bottom:12px;line-height:1.5}
.um-dialog-btns{display:flex;gap:8px;justify-content:center}
.um-dialog-btn{padding:6px 16px;border-radius:6px;font-size:10px;font-weight:600;cursor:default;transition:all .15s}
.um-dialog-btn.no{background:#f5f5f5;color:#666;border:1px solid #ddd}
.um-dialog-btn.yes{background:#4285f4;color:#fff;border:1px solid #4285f4}
.um-dialog-btn.press{transform:scale(.94)}

/* Edit/Add User slide panel */
.um-edit-panel{position:absolute;top:0;right:0;bottom:0;width:55%;background:#fff;box-shadow:-4px 0 24px rgba(0,0,0,.1);z-index:20;transform:translateX(100%);transition:transform .4s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;padding:12px 14px;overflow-y:auto;font-family:var(--db-font,system-ui,sans-serif);-ms-overflow-style:none;scrollbar-width:none}
.um-edit-panel::-webkit-scrollbar{display:none}
.um-edit-panel.on{transform:translateX(0)}
.um-edit-panel-art{height:50px;background:#f0f2f8;border-radius:8px;margin-bottom:8px;display:flex;align-items:center;justify-content:center}
.um-edit-grp{margin-bottom:6px}
.um-edit-lbl{font-size:8px;font-weight:500;color:#777;margin-bottom:2px;display:block}
.um-edit-inp{width:100%;height:26px;border:1.5px solid #ddd;border-radius:5px;background:#fff;padding:0 8px;font-size:9px;color:#1a1a1a;display:flex;align-items:center;transition:border-color .2s,box-shadow .2s;overflow:hidden}
.um-edit-inp.fc{border-color:#4285f4;box-shadow:0 0 0 2px rgba(66,133,244,.1)}
.um-edit-btn{width:100%;height:28px;background:#4285f4;color:#fff;border:none;border-radius:6px;font-size:10px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:4px;cursor:default;margin-top:6px;transition:all .15s}
.um-edit-btn.press{transform:scale(.97);background:#3367c7}
.um-edit-btn .ldot{width:10px;height:10px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;display:none;animation:spin .5s linear infinite}
.um-edit-btn.ld .ldot{display:inline-block}
.um-edit-note{font-size:7px;color:#aaa;margin-top:2px}

/* Stats popup overlay */
.um-stats-popup{position:absolute;inset:4px;background:#fff;border-radius:10px;box-shadow:0 8px 40px rgba(0,0,0,.12);z-index:20;opacity:0;transform:scale(.92);pointer-events:none;transition:opacity .3s ease,transform .3s ease;display:flex;flex-direction:column;padding:10px 14px;overflow:hidden;font-family:var(--db-font,system-ui,sans-serif)}
.um-stats-popup.on{opacity:1;transform:scale(1);pointer-events:auto}
.um-stats-popup-close{position:absolute;top:6px;right:10px;font-size:14px;color:#aaa;cursor:default}
.um-stats-hd{font-size:12px;font-weight:700;color:#1a1a1a;margin-bottom:1px}
.um-stats-user{font-size:8px;color:#888;margin-bottom:6px}
.um-stats-row{display:flex;gap:8px;flex:1}
.um-stats-chart{flex:1.2;border:1px solid #eee;border-radius:8px;padding:6px;position:relative}
.um-stats-chart-hd{font-size:9px;font-weight:600;color:#1a1a1a;display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}
.um-stats-chart-hd small{font-size:7px;color:#aaa}
.um-stats-chart-hd .df-hm{cursor:default}
.um-stats-donut-area{flex:0.8;border:1px solid #eee;border-radius:8px;padding:6px;display:flex;flex-direction:column;align-items:center}
.um-stats-donut-hd{font-size:9px;font-weight:600;color:#1a1a1a;margin-bottom:2px;text-align:center}
.um-stats-mini-bars{display:flex;align-items:flex-end;gap:2px;height:50px;margin-top:4px}
.um-stats-mini-bar{flex:1;background:#1a3a8a;border-radius:2px 2px 0 0;height:0;transition:height .7s cubic-bezier(.34,1.56,.64,1)}
.um-stats-mini-bar-c{flex:1;display:flex;flex-direction:column;align-items:center}
.um-stats-mini-bar-lbl{font-size:5px;color:#ccc;text-align:center;margin-top:1px}
.um-stats-donut{width:65px;height:65px;margin:4px auto}
.um-stats-donut circle{fill:none;stroke-width:8;transition:stroke-dasharray 1.2s ease}
.um-stats-donut .donut-track{stroke:#eee}
.um-stats-donut .donut-fill-own{stroke:#7cb5ec;stroke-linecap:round;stroke-dasharray:0 188;transition:stroke-dasharray 1.2s ease}
.um-stats-donut .donut-fill-sim{stroke:#1a3a8a;stroke-linecap:round;stroke-dasharray:0 188;transition:stroke-dasharray 1.2s ease}
.um-dl-menu{position:absolute;background:#fff;border:1px solid #ddd;border-radius:5px;padding:3px 0;box-shadow:0 4px 16px rgba(0,0,0,.1);z-index:25;opacity:0;pointer-events:none;transition:opacity .2s ease;font-family:var(--db-font,system-ui,sans-serif)}
.um-dl-menu.on{opacity:1;pointer-events:auto}
.um-dl-menu-item{padding:3px 10px;font-size:8px;color:#444;cursor:default;white-space:nowrap}

/* ---- FAB POPUP MENU ---- */
.um-fab-menu{position:absolute;bottom:48px;right:12px;background:#fff;border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.15);z-index:22;opacity:0;transform:translateY(8px) scale(.92);pointer-events:none;transition:opacity .25s ease,transform .25s ease;padding:6px 0;min-width:140px;font-family:var(--db-font,system-ui,sans-serif)}
.um-fab-menu.on{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
.um-fab-menu-item{display:flex;align-items:center;gap:8px;padding:8px 14px;font-size:9px;color:#444;cursor:default;transition:background .1s;white-space:nowrap}
.um-fab-menu-item:first-child{border-bottom:1px solid #f0f0f0}
.um-fab-menu-item.hl{background:#f0f4ff;color:#4285f4}
.um-fab-menu-ico{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.um-fab-menu-ico.single{background:#4285f4}
.um-fab-menu-ico.multi{background:#34a853}
.um-fab-menu-ico svg{width:12px;height:12px}

/* ---- ADD USER PANEL (slide-over right) ---- */
.au-panel{position:absolute;top:0;right:0;bottom:0;width:55%;background:#fff;box-shadow:-4px 0 24px rgba(0,0,0,.1);z-index:20;transform:translateX(100%);transition:transform .4s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;padding:10px 14px;overflow-y:auto;font-family:var(--db-font,system-ui,sans-serif);-ms-overflow-style:none;scrollbar-width:none}
.au-panel::-webkit-scrollbar{display:none}
.au-panel.on{transform:translateX(0)}
.au-panel-art{height:44px;background:linear-gradient(135deg,#f0f4ff,#e8f0fe);border-radius:8px;margin-bottom:8px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.au-panel-art-person{width:28px;height:48px;position:relative}
.au-panel-art-person::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:14px;height:14px;background:#f5c6a0;border-radius:50%}
.au-panel-art-person::after{content:'';position:absolute;top:12px;left:50%;transform:translateX(-50%);width:20px;height:22px;background:#4285f4;border-radius:8px 8px 4px 4px}
.au-panel-art-plus{position:absolute;top:4px;left:50%;transform:translateX(8px);width:16px;height:16px;background:#34a853;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:11px;font-weight:700;border:2px solid #fff}
.au-grp{margin-bottom:5px}
.au-lbl{font-size:8px;font-weight:500;color:#777;margin-bottom:2px;display:block}
.au-lbl .req{color:#e74c3c}
.au-inp{width:100%;height:24px;border:1.5px solid #ddd;border-radius:5px;background:#fff;padding:0 8px;font-size:9px;color:#1a1a1a;display:flex;align-items:center;transition:border-color .2s,box-shadow .2s;overflow:hidden}
.au-inp.fc{border-color:#4285f4;box-shadow:0 0 0 2px rgba(66,133,244,.1)}
.au-inp.filled{background:#f8f9ff;border-color:#c5d4f7}
.au-note{font-size:7px;color:#aaa;margin-top:1px}
.au-btn{width:100%;height:26px;background:#4285f4;color:#fff;border:none;border-radius:6px;font-size:10px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:4px;cursor:default;margin-top:6px;transition:all .15s}
.au-btn.press{transform:scale(.97);background:#3367c7}
.au-btn .ldot{width:10px;height:10px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;display:none;animation:spin .5s linear infinite}
.au-btn.ld .ldot{display:inline-block}

/* ---- ADD MULTIPLE USERS: upload page scene ---- */
.mu-page{position:absolute;inset:0;display:flex;background:#f0f0ee;font-family:var(--db-font,system-ui,sans-serif)}
.mu-body{flex:1;padding:12px 16px;overflow:hidden}
.mu-breadcrumb{font-size:9px;color:#888;margin-bottom:10px}
.mu-breadcrumb b{color:#1a1a1a;font-weight:600}
.mu-back{font-size:14px;color:#555;cursor:default;margin-bottom:4px;display:inline-block}
.mu-hd-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.mu-title{font-size:13px;font-weight:700;color:#1a1a1a}
.mu-dl-btn{display:flex;align-items:center;gap:4px;background:#4285f4;color:#fff;font-size:9px;font-weight:600;padding:6px 12px;border-radius:6px;cursor:default;transition:all .15s}
.mu-dl-btn.press{transform:scale(.96);background:#3367c7}
.mu-dl-btn svg{width:12px;height:12px}
.mu-upload-zone{border:2px dashed #d0d0d0;border-radius:12px;padding:24px 20px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;background:#fafafa;transition:border-color .2s,background .2s}
.mu-upload-zone.drag{border-color:#4285f4;background:#f0f4ff}
.mu-upload-ico{width:48px;height:48px;margin-bottom:6px;display:flex;align-items:center;justify-content:center;position:relative}
.mu-upload-ico-doc{width:30px;height:36px;background:#e8eef8;border-radius:4px;border:1.5px solid #c5d0e8;position:relative}
.mu-upload-ico-doc::before{content:'';position:absolute;top:6px;left:5px;right:5px;height:2px;background:#a0b4d8;border-radius:1px}
.mu-upload-ico-doc::after{content:'';position:absolute;top:12px;left:5px;width:10px;height:2px;background:#4285f4;border-radius:1px}
.mu-upload-ico-plus{position:absolute;bottom:0;right:0;width:14px;height:14px;background:#34a853;border-radius:50%;color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;border:1.5px solid #fff}
.mu-upload-fmt{font-size:10px;font-weight:600;color:#444;margin-bottom:2px}
.mu-upload-req{font-size:8px;color:#888;margin-bottom:2px}
.mu-upload-max{font-size:8px;color:#888;margin-bottom:4px}
.mu-upload-browse{font-size:9px;color:#4285f4;font-weight:500;cursor:default}
.mu-upload-browse.hl{text-decoration:underline;background:rgba(66,133,244,.08);border-radius:3px;padding:1px 4px}
.mu-upload-file{display:flex;align-items:center;gap:4px;background:#f5f5f5;border:1px solid #ddd;border-radius:5px;padding:3px 8px;font-size:8px;color:#555;margin-top:6px;opacity:0;transition:opacity .3s ease}
.mu-upload-file.on{opacity:1}

/* ---- CSV preview modal ---- */
.mu-modal{position:absolute;inset:0;background:rgba(0,0,0,.3);z-index:25;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s ease;font-family:var(--db-font,system-ui,sans-serif)}
.mu-modal.on{opacity:1;pointer-events:auto}
.mu-modal-box{background:#fff;border-radius:10px;box-shadow:0 12px 40px rgba(0,0,0,.18);width:92%;max-height:85%;display:flex;flex-direction:column;overflow:hidden;transform:scale(.88);transition:transform .35s cubic-bezier(.34,1.3,.64,1)}
.mu-modal.on .mu-modal-box{transform:scale(1)}
.mu-modal-hd{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;border-bottom:1px solid #eee}
.mu-modal-title{font-size:10px;font-weight:600;color:#1a1a1a}
.mu-modal-close{font-size:16px;color:#aaa;cursor:default}
.mu-modal-body{overflow-y:auto;padding:6px 10px;flex:1;-ms-overflow-style:none;scrollbar-width:none}
.mu-modal-body::-webkit-scrollbar{display:none}
.mu-csv-table{width:100%;border-collapse:collapse;font-size:7px;font-family:var(--db-font,system-ui,sans-serif)}
.mu-csv-table th{padding:4px 3px;text-align:left;color:#666;font-weight:600;border-bottom:1.5px solid #ddd;font-size:7px;white-space:nowrap}
.mu-csv-table td{padding:3px 2px;color:#444;vertical-align:middle;white-space:nowrap}
.mu-csv-table tbody tr{border-bottom:1px solid #f0f0f0;opacity:0;transform:translateY(4px);transition:opacity .3s ease,transform .3s ease}
.mu-csv-table tbody tr.pop{opacity:1;transform:translateY(0)}
.mu-csv-cell{border:1px solid #ddd;border-radius:3px;padding:2px 4px;font-size:7px;color:#333;background:#fff;display:inline-block;min-width:40px}
.mu-csv-cell.email-hl{border-color:#e74c3c;background:#fff5f5;color:#c0392b}
.mu-csv-del{width:16px;height:16px;border:1px solid #ddd;border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:8px;color:#aaa;cursor:default}
.mu-modal-footer{padding:8px 14px;border-top:1px solid #eee;display:flex;justify-content:space-between;align-items:center}
.mu-modal-warn{font-size:7px;color:#e74c3c;display:flex;align-items:center;gap:3px;opacity:0;transition:opacity .3s ease}
.mu-modal-warn.on{opacity:1}
.mu-modal-warn::before{content:'*';font-weight:700}
.mu-submit-btn{background:#4285f4;color:#fff;font-size:9px;font-weight:600;padding:5px 14px;border-radius:5px;cursor:default;transition:all .15s;margin-left:auto}
.mu-submit-btn.press{transform:scale(.96);background:#3367c7}
.mu-submit-btn.disabled{background:#ccc;color:#999;cursor:not-allowed}

/* ---- ADMIN REPORTS PAGE SCENE ---- */
.rp-scene{position:absolute;inset:0;display:flex;background:#f0f0ee;font-family:var(--db-font,system-ui,sans-serif)}
.rp-body{flex:1;padding:12px 16px;overflow:hidden}
.rp-breadcrumb{font-size:9px;color:#888;margin-bottom:10px}
.rp-breadcrumb b{color:#1a1a1a;font-weight:600}
.rp-users-card{background:#fff;border-radius:8px;border:1px solid #eee;padding:10px 14px;display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;opacity:0;transform:translateY(6px);transition:opacity .4s ease,transform .4s ease}
.rp-users-card.pop{opacity:1;transform:translateY(0)}
.rp-users-card-txt{font-size:11px;font-weight:700;color:#1a1a1a}
.rp-csv-btn{width:28px;height:28px;border-radius:6px;background:#34a853;display:flex;align-items:center;justify-content:center;cursor:default;position:relative;transition:all .15s}
.rp-csv-btn.hl{box-shadow:0 0 0 3px rgba(52,168,83,.25);transform:scale(1.08)}
.rp-csv-btn svg{width:14px;height:14px}
.rp-csv-tip{position:absolute;top:100%;left:50%;transform:translateX(-50%);margin-top:4px;background:#333;color:#fff;font-size:7px;padding:3px 8px;border-radius:4px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:10}
.rp-csv-tip::before{content:'';position:absolute;bottom:100%;left:50%;transform:translateX(-50%);border:4px solid transparent;border-bottom-color:#333}
.rp-csv-tip.on{opacity:1}
.rp-section{background:#fff;border-radius:8px;border:1px solid #eee;padding:12px 14px;opacity:0;transform:translateY(6px);transition:opacity .4s ease,transform .4s ease}
.rp-section.pop{opacity:1;transform:translateY(0)}
.rp-section-title{font-size:12px;font-weight:700;color:#1a1a1a;margin-bottom:10px}
.rp-form-row{display:flex;gap:10px;margin-bottom:8px}
.rp-form-grp{flex:1}
.rp-form-lbl{font-size:8px;font-weight:500;color:#777;margin-bottom:3px;display:block}
.rp-form-lbl .req{color:#e74c3c}
.rp-select{width:100%;height:26px;border:1.5px solid #ddd;border-radius:5px;background:#fff;padding:0 8px;font-size:9px;color:#aaa;display:flex;align-items:center;justify-content:space-between;transition:border-color .2s}
.rp-select.fc{border-color:#4285f4;box-shadow:0 0 0 2px rgba(66,133,244,.1)}
.rp-select-arrow{font-size:8px;color:#aaa}
.rp-date-inp{width:100%;height:26px;border:1.5px solid #ddd;border-radius:5px;background:#fff;padding:0 8px;font-size:9px;color:#aaa;display:flex;align-items:center;justify-content:space-between}
.rp-vd-btn{width:100%;max-width:320px;height:28px;background:#4285f4;color:#fff;border:none;border-radius:6px;font-size:10px;font-weight:600;display:flex;align-items:center;justify-content:center;cursor:default;transition:all .15s;margin-top:4px}
.rp-vd-btn.press{transform:scale(.97);background:#3367c7}
/* Download notification popup (browser-like) */
.rp-dl-popup{position:absolute;top:6px;right:6px;width:180px;background:#2d2d2d;border-radius:10px;box-shadow:0 8px 30px rgba(0,0,0,.25);z-index:30;opacity:0;transform:translateY(-8px);pointer-events:none;transition:opacity .3s ease,transform .3s ease;font-family:var(--db-font,system-ui,sans-serif);overflow:hidden}
.rp-dl-popup.on{opacity:1;transform:translateY(0)}
.rp-dl-popup-hd{padding:8px 10px 4px;font-size:10px;font-weight:600;color:#fff;display:flex;align-items:center;justify-content:space-between}
.rp-dl-popup-hd-icons{display:flex;gap:4px}
.rp-dl-popup-hd-icons span{width:14px;height:14px;border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:8px;color:#999}
.rp-dl-item{display:flex;align-items:center;gap:6px;padding:6px 10px;border-top:1px solid rgba(255,255,255,.08)}
.rp-dl-item-ico{width:22px;height:22px;background:#1a6b3c;border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.rp-dl-item-ico svg{width:12px;height:12px}
.rp-dl-item-info{flex:1}
.rp-dl-item-name{font-size:8px;font-weight:600;color:#fff}
.rp-dl-item-sub{font-size:7px;color:#888}

/* ---- REPORTS RESULTS POPUP ---- */
.rp-results{position:absolute;inset:4px;background:#fff;border-radius:10px;box-shadow:0 8px 40px rgba(0,0,0,.15);z-index:25;opacity:0;transform:scale(.92);pointer-events:none;transition:opacity .3s ease,transform .3s ease;display:flex;flex-direction:column;overflow:hidden;font-family:var(--db-font,system-ui,sans-serif)}
.rp-results.on{opacity:1;transform:scale(1);pointer-events:auto}
.rp-results-hd{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;border-bottom:1px solid #eee}
.rp-results-title{font-size:11px;font-weight:700;color:#1a1a1a}
.rp-results-actions{display:flex;align-items:center;gap:6px}
.rp-results-csv{width:24px;height:24px;background:#34a853;border-radius:5px;display:flex;align-items:center;justify-content:center;cursor:default;position:relative}
.rp-results-csv.hl{box-shadow:0 0 0 3px rgba(52,168,83,.25);transform:scale(1.08)}
.rp-results-csv svg{width:12px;height:12px}
.rp-results-csv-tip{position:absolute;top:100%;right:0;margin-top:3px;background:#333;color:#fff;font-size:7px;padding:2px 6px;border-radius:3px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s}
.rp-results-csv-tip.on{opacity:1}
.rp-results-close{font-size:16px;color:#aaa;cursor:default}
.rp-results-body{flex:1;overflow-y:auto;padding:4px 8px;-ms-overflow-style:none;scrollbar-width:none}
.rp-results-body::-webkit-scrollbar{display:none}
.rp-res-table{width:100%;border-collapse:collapse;font-size:7px;font-family:var(--db-font,system-ui,sans-serif)}
.rp-res-table th{padding:4px 3px;text-align:left;color:#666;font-weight:600;border-bottom:1.5px solid #ddd;font-size:7px;white-space:nowrap}
.rp-res-table td{padding:3px 2px;color:#444;vertical-align:middle;white-space:nowrap;font-size:7px}
.rp-res-table tbody tr{border-bottom:1px solid #f0f0f0;opacity:0;transform:translateY(4px);transition:opacity .3s ease,transform .3s ease}
.rp-res-table tbody tr.pop{opacity:1;transform:translateY(0)}
/* Score badges */
.rp-score{display:inline-block;padding:1px 5px;border-radius:3px;font-size:7px;font-weight:600;min-width:24px;text-align:center}
.rp-score.high{background:#fce8e8;color:#c0392b}
.rp-score.mid{background:#fff3e0;color:#e67e22}
.rp-score.low{background:#e8f5e9;color:#2e7d32}
.rp-score.na{background:#f5f5f5;color:#999}
.rp-dl-small{width:14px;height:14px;border:1px solid #ddd;border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:7px;color:#888;cursor:default}
/* Form filled state */
.rp-select.filled{border-color:#4285f4;background:#f8f9ff;color:#1a1a1a}
.rp-select.filled span:first-child{color:#1a1a1a}
.rp-date-inp.filled{border-color:#4285f4;background:#f8f9ff}
.rp-date-inp.filled span:first-child{color:#1a1a1a}

/* ---- MAIL DIALOG (submissions report) ---- */
.rp-mail-dlg{position:absolute;inset:0;background:rgba(0,0,0,.3);z-index:30;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s ease;font-family:var(--db-font,system-ui,sans-serif)}
.rp-mail-dlg.on{opacity:1;pointer-events:auto}
.rp-mail-box{background:#fff;border-radius:12px;padding:16px 20px;width:220px;box-shadow:0 12px 40px rgba(0,0,0,.18);transform:scale(.85);transition:transform .35s cubic-bezier(.34,1.3,.64,1)}
.rp-mail-dlg.on .rp-mail-box{transform:scale(1)}
.rp-mail-hd{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.rp-mail-title{font-size:12px;font-weight:700;color:#1a1a1a}
.rp-mail-close{font-size:14px;color:#aaa;cursor:default}
.rp-mail-lbl{font-size:8px;font-weight:500;color:#777;margin-bottom:3px;display:block}
.rp-mail-lbl .req{color:#e74c3c}
.rp-mail-inp{width:100%;height:26px;border:1.5px solid #ddd;border-radius:5px;background:#fff;padding:0 8px;font-size:9px;color:#1a1a1a;display:flex;align-items:center;transition:border-color .2s,box-shadow .2s;overflow:hidden;margin-bottom:10px}
.rp-mail-inp.fc{border-color:#4285f4;box-shadow:0 0 0 2px rgba(66,133,244,.1)}
.rp-mail-btn{width:100%;height:28px;background:#4285f4;color:#fff;border:none;border-radius:6px;font-size:10px;font-weight:600;display:flex;align-items:center;justify-content:center;cursor:default;transition:all .15s}
.rp-mail-btn.press{transform:scale(.97);background:#3367c7}
/* Confirm dialogs inside reports need to be above results popup (z-index:25) */
.rf-confirm-dlg,.rp-confirm-dlg{z-index:30}

/* ---- EMAIL PREVIEW (submissions report) ---- */
.rp-email-preview{position:absolute;inset:4px;background:#fff;border-radius:10px;box-shadow:0 8px 40px rgba(0,0,0,.15);z-index:28;opacity:0;transform:scale(.92);pointer-events:none;transition:opacity .3s ease,transform .3s ease;display:flex;flex-direction:column;padding:14px 16px;overflow:hidden;font-family:var(--db-font,system-ui,sans-serif)}
.rp-email-preview.on{opacity:1;transform:scale(1);pointer-events:auto}
.rp-email-subj{font-size:11px;font-weight:600;color:#1a1a1a;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid #eee}
.rp-email-meta{display:flex;align-items:center;gap:8px;margin-bottom:14px}
.rp-email-avatar{width:28px;height:28px;border-radius:50%;background:#999;color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.rp-email-from-info{flex:1}
.rp-email-from-name{font-size:9px;font-weight:600;color:#444}
.rp-email-from-addr{font-size:7px;color:#999}
.rp-email-to{font-size:7px;color:#999}
.rp-email-time{font-size:7px;color:#aaa}
.rp-email-body-title{font-size:14px;font-weight:700;color:#2a7a6a;margin-bottom:10px;line-height:1.3}
.rp-email-link{font-size:8px;color:#2a7a6a;text-decoration:underline;word-break:break-all;line-height:1.4;cursor:default;display:inline-block;padding:2px;border-radius:3px;transition:background .15s}
.rp-email-link.hl{background:rgba(42,122,106,.1)}

/* ---- REPOSITORY SCENES ---- */
.repo-scene{position:absolute;inset:0;display:flex;background:#f0f0ee;font-family:var(--db-font,system-ui,sans-serif)}
.repo-body{flex:1;padding:12px 16px;overflow:hidden;position:relative}
.repo-breadcrumb{font-size:9px;color:#888;margin-bottom:6px}
.repo-breadcrumb b{color:#1a1a1a;font-weight:600}
.repo-title{font-size:12px;font-weight:700;color:#1a1a1a;margin-bottom:6px}
.repo-search{border:1px solid #ddd;border-radius:5px;padding:4px 8px;font-size:8px;color:#aaa;background:#fff;width:120px;float:right;margin-top:-20px}
.repo-note-box{background:#fafaf8;border:1px solid #eee;border-radius:8px;padding:8px 12px;margin-bottom:8px;font-size:8px;color:#666;line-height:1.5;opacity:0;transform:translateY(6px);transition:opacity .4s ease,transform .4s ease}
.repo-note-box.pop{opacity:1;transform:translateY(0)}
.repo-table{width:100%;border-collapse:collapse;font-size:7px;font-family:var(--db-font,system-ui,sans-serif)}
.repo-table th{padding:5px 4px;text-align:left;color:#666;font-weight:600;border-bottom:1.5px solid #ddd;font-size:7px;background:#f5f7fa}
.repo-table td{padding:4px 3px;color:#444;vertical-align:middle;white-space:nowrap;font-size:7px}
.repo-table tbody tr{border-bottom:1px solid #f0f0f0;opacity:0;transform:translateY(4px);transition:opacity .3s ease,transform .3s ease}
.repo-table tbody tr.pop{opacity:1;transform:translateY(0)}
/* Upload page scene */
.repo-upload-scene{position:absolute;inset:0;display:flex;background:#f0f0ee;font-family:var(--db-font,system-ui,sans-serif)}
.repo-upload-body{flex:1;padding:10px 14px;overflow:hidden}
.repo-tabs{display:flex;gap:0;margin-bottom:8px}
.repo-tab{padding:5px 12px;font-size:9px;font-weight:600;background:#eee;color:#888;cursor:default;border-radius:6px 6px 0 0}
.repo-tab.act{background:#4285f4;color:#fff}
.repo-back-row{display:flex;align-items:center;gap:6px;margin-bottom:6px}
.repo-back-arrow{font-size:12px;color:#555;cursor:default}
.repo-upload-title{font-size:11px;font-weight:600;color:#1a1a1a}
.repo-upload-zone{border:2px dashed #d0d0d0;border-radius:10px;padding:16px 14px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;background:#fafafa;transition:border-color .2s,background .2s;margin-bottom:6px}
.repo-upload-zone.drag{border-color:#4285f4;background:#f0f4ff}
.repo-upload-ico{width:36px;height:36px;margin-bottom:4px;display:flex;align-items:center;justify-content:center;position:relative}
.repo-upload-ico-doc{width:22px;height:28px;background:#e8eef8;border-radius:3px;border:1px solid #c5d0e8;position:relative}
.repo-upload-ico-doc::before{content:'';position:absolute;top:5px;left:4px;right:4px;height:2px;background:#a0b4d8;border-radius:1px}
.repo-upload-ico-doc::after{content:'';position:absolute;top:10px;left:4px;width:8px;height:2px;background:#4285f4;border-radius:1px}
.repo-upload-ico-plus{position:absolute;bottom:0;right:0;width:12px;height:12px;background:#34a853;border-radius:50%;color:#fff;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;border:1px solid #fff}
.repo-upload-fmt{font-size:8px;font-weight:600;color:#444;margin-bottom:1px}
.repo-upload-info{font-size:7px;color:#888;margin-bottom:0;line-height:1.4}
.repo-upload-browse{font-size:8px;color:#4285f4;font-weight:500;cursor:default;margin-top:2px}
.repo-upload-browse.hl{text-decoration:underline;background:rgba(66,133,244,.08);border-radius:3px;padding:1px 4px}
.repo-file-chip{display:inline-flex;align-items:center;gap:4px;background:#e8f0fe;border:1px solid #c5d4f7;border-radius:12px;padding:2px 8px;font-size:7px;color:#333;margin-top:4px;opacity:0;transition:opacity .3s ease}
.repo-file-chip.on{opacity:1}
.repo-file-chip-x{font-size:9px;color:#999;cursor:default}
/* Metadata form below upload */
.repo-meta{display:flex;align-items:flex-end;gap:6px;margin-top:4px;flex-wrap:wrap;opacity:0;transition:opacity .3s ease}
.repo-meta.on{opacity:1}
.repo-meta-fname{font-size:7px;color:#666;width:80px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
.repo-meta-grp{display:flex;flex-direction:column;gap:1px}
.repo-meta-lbl{font-size:6px;font-weight:600;color:#777}
.repo-meta-lbl .req{color:#e74c3c}
.repo-meta-inp{width:70px;height:20px;border:1.5px solid #ddd;border-radius:4px;background:#fff;padding:0 5px;font-size:7px;color:#1a1a1a;display:flex;align-items:center;transition:border-color .2s,box-shadow .2s;overflow:hidden}
.repo-meta-inp.fc{border-color:#4285f4;box-shadow:0 0 0 2px rgba(66,133,244,.1)}
.repo-meta-inp.filled{background:#f8f9ff;border-color:#c5d4f7}
.repo-meta-select{width:75px;height:20px;border:1.5px solid #ddd;border-radius:4px;background:#fff;padding:0 4px;font-size:7px;color:#aaa;display:flex;align-items:center;justify-content:space-between}
.repo-meta-select.filled{border-color:#4285f4;background:#f8f9ff;color:#1a1a1a}
.repo-meta-chk{display:flex;align-items:center;gap:3px;font-size:6px;color:#666}
.repo-meta-chk i{width:10px;height:10px;border:1px solid #ccc;border-radius:2px;display:block}
.repo-submit-btn{height:20px;background:#4285f4;color:#fff;border:none;border-radius:4px;font-size:8px;font-weight:600;padding:0 14px;cursor:default;transition:all .15s;margin-left:4px}
.repo-submit-btn.press{transform:scale(.96);background:#3367c7}
/* Repo select dropdown */
.repo-meta-dd{position:absolute;background:#fff;border:1px solid #ddd;border-radius:4px;padding:2px 0;box-shadow:0 4px 12px rgba(0,0,0,.1);z-index:10;opacity:0;pointer-events:none;transition:opacity .2s;font-family:var(--db-font,system-ui,sans-serif);min-width:65px}
.repo-meta-dd.on{opacity:1;pointer-events:auto}
.repo-meta-dd-item{padding:3px 8px;font-size:7px;color:#444;cursor:default}
.repo-meta-dd-item.hl{background:#f0f4ff;color:#4285f4}
/* Repo delete button */
.repo-del-btn{width:18px;height:18px;border:1px solid #ddd;border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:default;font-size:10px;color:#e74c3c;position:relative;transition:all .15s}
.repo-del-btn.hl{box-shadow:0 0 0 3px rgba(231,76,60,.15);background:#fff5f5;border-color:#e74c3c}
.repo-del-tip{position:absolute;top:100%;left:50%;transform:translateX(-50%);margin-top:3px;background:#333;color:#fff;font-size:6px;padding:2px 6px;border-radius:3px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s;z-index:5}
.repo-del-tip.on{opacity:1}

/* ---- INTEGRATIONS PAGE SCENE ---- */
.intg-scene{position:absolute;inset:0;display:flex;background:#f0f0ee;font-family:var(--db-font,system-ui,sans-serif)}
.intg-body{flex:1;padding:12px 16px;overflow:hidden}
.intg-breadcrumb{font-size:9px;color:#888;margin-bottom:6px}
.intg-breadcrumb b{color:#1a1a1a;font-weight:600}
.intg-title{font-size:12px;font-weight:700;color:#1a1a1a;margin-bottom:10px}
.intg-grid{display:flex;flex-wrap:wrap;gap:8px}
.intg-card{width:calc(25% - 6px);min-width:90px;background:#fff;border-radius:10px;border:1px solid #eee;padding:10px 10px 8px;display:flex;flex-direction:column;align-items:flex-start;position:relative;opacity:0;transform:translateY(8px);transition:opacity .4s ease,transform .4s ease}
.intg-card.pop{opacity:1;transform:translateY(0)}
.intg-card.hl{border-color:#4285f4;box-shadow:0 0 0 2px rgba(66,133,244,.12);z-index:15;position:relative}
.intg-card-logo{height:28px;display:flex;align-items:center;margin-bottom:4px}
.intg-card-logo-moodle{font-size:11px;font-weight:800;color:#f98012;font-family:Arial,sans-serif;letter-spacing:-.3px}
.intg-card-logo-moodle::before{content:'m';display:inline-block;background:#f98012;color:#fff;width:16px;height:16px;border-radius:50%;text-align:center;line-height:16px;font-size:10px;margin-right:2px}
.intg-card-logo-canvas{font-size:10px;font-weight:600;color:#e13f29;display:flex;align-items:center;gap:3px}
.intg-card-logo-canvas::before{content:'';display:inline-block;width:14px;height:14px;border-radius:50%;border:2px solid #e13f29}
.intg-card-logo-bb{display:flex;align-items:center;gap:3px}
.intg-card-logo-bb-icon{width:18px;height:18px;background:#d4a017;border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:8px;font-weight:800;color:#fff;font-family:serif}
.intg-card-logo-bb-txt{font-size:9px;font-weight:700;color:#333}
.intg-card-logo-bs{display:flex;align-items:center;gap:3px}
.intg-card-logo-bs-icon{width:16px;height:16px;background:#f36b21;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:800;color:#fff;font-family:serif}
.intg-card-logo-bs-txt{font-size:9px;font-weight:600;color:#666}
.intg-card-name{font-size:8px;font-weight:600;color:#1a1a1a;margin-bottom:6px;line-height:1.3}
.intg-card-toggle{width:28px;height:14px;border-radius:8px;background:#ccc;position:relative;cursor:default;align-self:flex-end;margin-top:auto}
.intg-card-toggle::after{content:'';position:absolute;top:2px;left:2px;width:10px;height:10px;border-radius:50%;background:#fff;transition:all .2s}
.intg-card-toggle.active{background:#4285f4}
.intg-card-toggle.active::after{left:auto;right:2px}
/* Tooltip cards for overview */
.intg-tip{position:absolute;z-index:16;background:#fff;border:1.5px solid #4285f4;border-radius:10px;padding:12px 14px;box-shadow:0 6px 24px rgba(66,133,244,.15);opacity:0;transform:scale(.9);pointer-events:none;transition:opacity .3s ease,transform .3s ease;font-family:var(--db-font,system-ui,sans-serif);width:200px;overflow:hidden}
.intg-tip.on{opacity:1;transform:scale(1)}
.intg-tip-title{font-size:12px;font-weight:700;color:#1a1a1a;margin-bottom:4px}
.intg-tip-desc{font-size:10px;color:#555;line-height:1.5}

/* ---- INTEGRATION SETUP PANEL (slide-over) ---- */
.intg-panel{position:absolute;top:0;right:0;bottom:0;width:55%;background:#fff;box-shadow:-4px 0 24px rgba(0,0,0,.1);z-index:20;transform:translateX(100%);transition:transform .4s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;padding:10px 14px;overflow-y:auto;font-family:var(--db-font,system-ui,sans-serif);-ms-overflow-style:none;scrollbar-width:none}
.intg-panel::-webkit-scrollbar{display:none}
.intg-panel.on{transform:translateX(0)}
.intg-panel-close{position:absolute;top:8px;right:10px;font-size:14px;color:#aaa;cursor:default}
.intg-panel-art{height:44px;background:linear-gradient(135deg,#f0f4ff,#e8f0fe);border-radius:8px;margin-bottom:8px;display:flex;align-items:center;justify-content:center}
.intg-panel-grp{margin-bottom:5px}
.intg-panel-lbl{font-size:8px;font-weight:500;color:#777;margin-bottom:2px;display:block}
.intg-panel-lbl .req{color:#e74c3c}
.intg-panel-inp{width:100%;height:24px;border:1.5px solid #ddd;border-radius:5px;background:#fff;padding:0 8px;font-size:9px;color:#1a1a1a;display:flex;align-items:center;transition:border-color .2s,box-shadow .2s;overflow:hidden}
.intg-panel-inp.fc{border-color:#4285f4;box-shadow:0 0 0 2px rgba(66,133,244,.1)}
.intg-panel-inp.filled{background:#f8f9ff;border-color:#c5d4f7}
.intg-panel-btn{width:100%;height:26px;background:#4285f4;color:#fff;border:none;border-radius:6px;font-size:10px;font-weight:600;display:flex;align-items:center;justify-content:center;cursor:default;margin-top:8px;transition:all .15s}
.intg-panel-btn.press{transform:scale(.97);background:#3367c7}
/* Know More link on card */
.intg-card-know{font-size:7px;color:#4285f4;font-weight:600;cursor:default;opacity:0;transition:opacity .3s ease;margin-top:auto;margin-bottom:2px}
.intg-card-know.on{opacity:1}
.intg-card-del{width:14px;height:14px;border:1px solid #ddd;border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:8px;color:#999;cursor:default;opacity:0;transition:opacity .3s ease}
.intg-card-del.on{opacity:1}
/* Moodle details page */
.intg-details{position:absolute;inset:0;display:flex;background:#f0f0ee;font-family:var(--db-font,system-ui,sans-serif);z-index:18;opacity:0;pointer-events:none;transition:opacity .4s ease}
.intg-details.on{opacity:1;pointer-events:auto}
.intg-details-body{flex:1;padding:12px 16px;overflow:hidden}
.intg-details-breadcrumb{font-size:9px;color:#888;margin-bottom:6px}
.intg-details-breadcrumb b{color:#1a1a1a;font-weight:600}
.intg-details-title{font-size:12px;font-weight:700;color:#1a1a1a;margin-bottom:8px}
.intg-details-card{background:#fff;border-radius:8px;border:1px solid #eee;padding:12px 14px}
.intg-details-status{font-size:9px;font-weight:600;color:#1a1a1a;margin-bottom:8px}
.intg-details-change{display:inline-flex;align-items:center;gap:4px;background:#4285f4;color:#fff;font-size:8px;font-weight:600;padding:5px 12px;border-radius:5px;cursor:default;margin-bottom:10px}
.intg-details-row{display:flex;justify-content:space-between;padding:4px 0;border-bottom:1px solid #f0f0f0;font-size:8px}
.intg-details-row:last-child{border-bottom:none}
.intg-details-key{color:#888;font-weight:500}
.intg-details-val{color:#1a1a1a;font-weight:500;text-align:right;max-width:55%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.intg-details-section{font-size:9px;font-weight:700;color:#1a1a1a;margin-top:8px}

/* ---- SECURITY SETTINGS SCENE ---- */
.sec-scene{position:absolute;inset:0;display:flex;background:#f0f0ee;font-family:var(--db-font,system-ui,sans-serif)}
.sec-body{flex:1;padding:12px 16px;overflow:hidden}
.sec-card{background:#fff;border-radius:8px;border:1px solid #eee;padding:12px 16px;opacity:0;transform:translateY(6px);transition:opacity .4s ease,transform .4s ease}
.sec-card.pop{opacity:1;transform:translateY(0)}
.sec-card-title{font-size:12px;font-weight:700;color:#1a1a1a;margin-bottom:6px}
.sec-card-desc{font-size:8px;color:#666;line-height:1.5;margin-bottom:10px}
.sec-mfa-row{display:flex;align-items:center;gap:12px;margin-bottom:4px}
.sec-mfa-label{font-size:9px;font-weight:500;color:#444}
.sec-mfa-toggle{width:32px;height:16px;border-radius:10px;background:#ccc;position:relative;cursor:default;transition:background .2s}
.sec-mfa-toggle::after{content:'';position:absolute;top:2px;left:2px;width:12px;height:12px;border-radius:50%;background:#fff;transition:all .2s}
.sec-mfa-toggle.active{background:#4285f4}
.sec-mfa-toggle.active::after{left:auto;right:2px}
.sec-mfa-status{font-size:9px;font-weight:600;color:#888}
.sec-mfa-status.on-txt{color:#4285f4}
.sec-mfa-note{font-size:7px;color:#888;font-style:italic}
/* OTP login page */
.sec-otp-scene{position:absolute;inset:0;background:#f0f2f8;display:flex;font-family:var(--db-font,system-ui,sans-serif);z-index:18;opacity:0;pointer-events:none;transition:opacity .4s ease}
.sec-otp-scene.on{opacity:1;pointer-events:auto}
.sec-otp-art{flex:1;display:flex;align-items:center;justify-content:center;background:#f0f2f8}
.sec-otp-art-box{width:180px;height:130px;background:#e0e4ee;border-radius:14px;position:relative;overflow:hidden}
.sec-otp-form{flex:1;display:flex;flex-direction:column;justify-content:center;padding:20px 24px}
.sec-otp-logo{display:flex;align-items:center;gap:5px;margin-bottom:12px}
.sec-otp-logo i{width:16px;height:16px;background:#4285f4;border-radius:4px;display:block}
.sec-otp-logo span{font-size:11px;font-weight:600;color:#1a1a1a}
.sec-otp-title{font-size:14px;font-weight:700;color:#1a1a1a;margin-bottom:6px}
.sec-otp-desc{font-size:8px;color:#888;line-height:1.5;margin-bottom:12px}
.sec-otp-lbl{font-size:8px;font-weight:500;color:#777;margin-bottom:3px}
.sec-otp-inp{width:160px;height:30px;border:1.5px solid #ddd;border-radius:6px;background:#fff;padding:0 10px;font-size:11px;color:#1a1a1a;display:flex;align-items:center;margin-bottom:10px;transition:border-color .2s}
.sec-otp-inp.fc{border-color:#4285f4;box-shadow:0 0 0 2px rgba(66,133,244,.1)}
.sec-otp-btn{width:160px;height:32px;background:#4285f4;color:#fff;border:none;border-radius:6px;font-size:11px;font-weight:600;display:flex;align-items:center;justify-content:center;cursor:default;margin-bottom:6px}
.sec-otp-back{font-size:8px;color:#888}

/* ---- SUPPORT CENTRE SCENE ---- */
.sup-scene{position:absolute;inset:0;display:flex;background:#f0f0ee;font-family:var(--db-font,system-ui,sans-serif)}
.sup-body{flex:1;padding:12px 16px;overflow:hidden;position:relative}
.sup-title{font-size:12px;font-weight:700;color:#1a1a1a;margin-bottom:8px}
.sup-search{border:1px solid #ddd;border-radius:5px;padding:4px 8px;font-size:8px;color:#aaa;background:#fff;width:130px;float:right;margin-top:-20px}
.sup-empty{border:1px solid #ddd;border-radius:8px;padding:20px;text-align:center;font-size:9px;color:#999;margin-bottom:8px}
.sup-empty-ico{font-size:16px;color:#ccc;margin-bottom:4px}
.sup-table{width:100%;border-collapse:collapse;font-size:7px;font-family:var(--db-font,system-ui,sans-serif)}
.sup-table th{padding:5px 3px;text-align:left;color:#666;font-weight:600;border-bottom:1.5px solid #ddd;font-size:7px}
.sup-table td{padding:4px 3px;color:#444;vertical-align:middle;white-space:nowrap;font-size:7px}
.sup-table tbody tr{border-bottom:1px solid #f0f0f0;opacity:0;transform:translateY(4px);transition:opacity .3s ease,transform .3s ease}
.sup-table tbody tr.pop{opacity:1;transform:translateY(0)}
.sup-status{display:flex;align-items:center;gap:3px;font-size:7px;font-weight:600}
.sup-status i{width:5px;height:5px;border-radius:50%;display:block}
.sup-status.open i{background:#4caf50}
.sup-status.open{color:#4caf50}
.sup-status.closed i{background:#e74c3c}
.sup-status.closed{color:#e74c3c}
.sup-action-btn{width:16px;height:16px;border:1px solid #ddd;border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:8px;color:#888;cursor:default}
.sup-action-btn.hl{border-color:#4285f4;background:#f0f4ff;color:#4285f4}
/* Create ticket panel */
.sup-panel{position:absolute;top:0;right:0;bottom:0;width:55%;background:#fff;box-shadow:-4px 0 24px rgba(0,0,0,.1);z-index:20;transform:translateX(100%);transition:transform .4s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;padding:10px 14px;overflow-y:auto;font-family:var(--db-font,system-ui,sans-serif);-ms-overflow-style:none;scrollbar-width:none}
.sup-panel::-webkit-scrollbar{display:none}
.sup-panel.on{transform:translateX(0)}
.sup-panel-art{height:40px;background:linear-gradient(135deg,#f0f4ff,#e8f0fe);border-radius:8px;margin-bottom:6px;display:flex;align-items:center;justify-content:center;font-size:9px;color:#aaa}
.sup-panel-grp{margin-bottom:4px}
.sup-panel-lbl{font-size:8px;font-weight:500;color:#777;margin-bottom:2px}
.sup-panel-inp{width:100%;height:22px;border:1.5px solid #ddd;border-radius:5px;background:#fff;padding:0 8px;font-size:8px;color:#1a1a1a;display:flex;align-items:center;transition:border-color .2s;overflow:hidden}
.sup-panel-inp.fc{border-color:#4285f4;box-shadow:0 0 0 2px rgba(66,133,244,.1)}
.sup-panel-inp.filled{background:#f8f9ff;border-color:#c5d4f7}
.sup-panel-select{width:100%;height:22px;border:1.5px solid #ddd;border-radius:5px;background:#fff;padding:0 8px;font-size:8px;color:#aaa;display:flex;align-items:center;justify-content:space-between}
.sup-panel-select.filled{border-color:#c5d4f7;background:#f8f9ff;color:#1a1a1a}
.sup-panel-textarea{width:100%;height:40px;border:1.5px solid #ddd;border-radius:5px;background:#fff;padding:4px 8px;font-size:7px;color:#1a1a1a;display:flex;align-items:flex-start;overflow:hidden;transition:border-color .2s}
.sup-panel-textarea.fc{border-color:#4285f4}
.sup-panel-textarea.filled{background:#f8f9ff;border-color:#c5d4f7}
.sup-panel-file{font-size:7px;color:#888;margin-bottom:4px}
.sup-panel-btn{width:100%;height:24px;background:#4285f4;color:#fff;border:none;border-radius:6px;font-size:9px;font-weight:600;display:flex;align-items:center;justify-content:center;cursor:default;margin-top:4px;transition:all .15s}
.sup-panel-btn.press{transform:scale(.97);background:#3367c7}
/* Ticket details page */
.sup-details{position:absolute;inset:0;display:flex;background:#f0f0ee;font-family:var(--db-font,system-ui,sans-serif);z-index:18;opacity:0;pointer-events:none;transition:opacity .4s ease}
.sup-details.on{opacity:1;pointer-events:auto}
.sup-details-body{flex:1;padding:10px 14px;overflow:hidden;display:flex;flex-direction:column}
.sup-details-title{font-size:11px;font-weight:700;color:#1a1a1a;margin-bottom:4px}
.sup-details-desc{font-size:8px;color:#666;background:#fff;border-radius:6px;padding:6px 8px;margin-bottom:6px;border:1px solid #eee}
.sup-details-desc b{color:#333}
.sup-details-chat{flex:1;background:#fff;border-radius:6px;border:1px solid #eee;padding:6px 8px;margin-bottom:6px;position:relative;overflow:hidden}
.sup-details-msg{background:#4285f4;color:#fff;border-radius:8px;padding:6px 8px;font-size:7px;line-height:1.4;max-width:70%;margin-left:auto;margin-bottom:4px;position:relative}
.sup-details-msg-time{font-size:6px;color:rgba(255,255,255,.7);margin-top:2px}
.sup-details-msg-sender{font-size:6px;color:#aaa;text-align:right;margin-bottom:2px}
.sup-details-input{display:flex;align-items:center;gap:6px;background:#fff;border-radius:6px;border:1px solid #eee;padding:6px 8px}
.sup-details-input-txt{flex:1;font-size:8px;color:#aaa}
.sup-details-input-icons{display:flex;gap:4px;font-size:10px;color:#4285f4}
.sup-details-sidebar{width:130px;background:#fff;border-left:1px solid #eee;padding:8px 10px;font-size:7px;overflow:hidden}
.sup-details-sidebar-row{margin-bottom:4px}
.sup-details-sidebar-key{font-weight:600;color:#333;margin-bottom:1px}
.sup-details-sidebar-val{color:#666}

/* ---- USER MY FOLDERS SCENE ---- */
.uf-scene{position:absolute;inset:0;display:flex;background:#f0f0ee;font-family:var(--db-font,system-ui,sans-serif)}
.uf-side{width:100px;background:#fff;border-right:1px solid #eee;padding:12px 0;display:flex;flex-direction:column;gap:2px;font-family:var(--db-font,system-ui,sans-serif)}
.uf-side-logo{display:flex;align-items:center;gap:5px;padding:0 10px 10px;font-size:11px;font-weight:700;color:#1a73e8}
.uf-side-logo i{width:16px;height:16px;background:#4285f4;border-radius:4px;display:block}
.uf-nav{font-size:9px;padding:7px 10px;color:#666;display:flex;align-items:center;gap:6px;cursor:default;border-left:3px solid transparent}
.uf-nav i{width:12px;height:12px;background:#ccc;border-radius:3px;display:block}
.uf-nav.act{background:#e8f0fe;color:#1a73e8;font-weight:600;border-left-color:#4285f4}
.uf-nav.act i{background:#4285f4}
.uf-body{flex:1;padding:12px 16px;overflow:hidden}
.uf-title{font-size:12px;font-weight:700;color:#1a1a1a;margin-bottom:8px}
.uf-view-icons{display:flex;gap:4px;float:right;margin-top:-20px}
.uf-view-icon{width:20px;height:20px;border:1px solid #ddd;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:8px;color:#888}
.uf-view-icon.act{background:#4285f4;color:#fff;border-color:#4285f4}
.uf-search{border:1px solid #ddd;border-radius:5px;padding:4px 8px;font-size:8px;color:#aaa;background:#fff;width:140px;float:right;margin-top:-20px;margin-right:70px}
.uf-table{width:100%;border-collapse:collapse;font-size:8px;margin-top:8px}
.uf-table th{padding:5px 4px;text-align:left;color:#666;font-weight:600;border-bottom:1.5px solid #ddd}
.uf-table td{padding:5px 4px;color:#444;border-bottom:1px solid #f0f0f0}
.uf-table .folder-ico{display:inline-block;width:12px;height:10px;background:#90CAF9;border-radius:1px 1px 2px 2px;position:relative;margin-right:4px;vertical-align:middle}
.uf-table .folder-ico::before{content:'';position:absolute;top:-3px;left:0;width:5px;height:3px;background:#90CAF9;border-radius:1px 2px 0 0}
.uf-table tbody tr{opacity:0;transform:translateY(4px);transition:opacity .3s ease,transform .3s ease}
.uf-table tbody tr.pop{opacity:1;transform:translateY(0)}
.uf-action{display:flex;gap:3px}
.uf-action-btn{width:16px;height:16px;border:1px solid #ddd;border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:8px;color:#888}
/* User profile dropdown */
.uf-profile-dd{position:absolute;top:28px;right:10px;width:160px;background:#fff;border-radius:10px;box-shadow:0 8px 30px rgba(0,0,0,.12);padding:10px 0;z-index:25;opacity:0;transform:translateY(-6px) scale(.97);pointer-events:none;transition:opacity .25s ease,transform .25s ease;font-family:var(--db-font,system-ui,sans-serif)}
.uf-profile-dd.on{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
.uf-profile-dd-head{display:flex;align-items:center;gap:8px;padding:6px 14px 10px;border-bottom:1px solid #f0f0f0}
.uf-profile-dd-av{width:28px;height:28px;border-radius:50%;background:#4285f4;display:flex;align-items:center;justify-content:center;color:#fff;font-size:11px;font-weight:600}
.uf-profile-dd-name{font-size:9px;font-weight:600;color:#1a1a1a}
.uf-profile-dd-email{font-size:7px;color:#888}
.uf-profile-dd-item{display:flex;align-items:center;gap:8px;padding:8px 14px;font-size:9px;color:#444;cursor:default;transition:background .15s}
.uf-profile-dd-item.hl{background:#f0f4ff;color:#4285f4}
.uf-profile-dd-item i{width:20px;height:20px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:10px}
.uf-profile-dd-item .ai-ico{background:#e8f0fe;color:#4285f4}
.uf-profile-dd-item .help-ico{background:#fce8f0;color:#e91e63}
.uf-profile-dd-item .cp-ico{background:#e8eaf6;color:#5c6bc0}
.uf-profile-dd-logout{margin:6px 14px 0;padding:6px 0;background:#f5f5f5;border-radius:6px;text-align:center;font-size:9px;color:#e74c3c;font-weight:600}
/* User account info page */
.uai-scene{position:absolute;inset:0;display:flex;background:#f0f0ee;font-family:var(--db-font,system-ui,sans-serif);z-index:18;opacity:0;pointer-events:none;transition:opacity .4s ease}
.uai-scene.on{opacity:1;pointer-events:auto}
.uai-body{flex:1;padding:10px 14px;overflow:hidden}
.uai-title{font-size:13px;font-weight:700;color:#1a1a1a;margin-bottom:8px}
.uai-avatar{width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,#f9a825,#ff8f00);float:right;margin-top:-10px;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:#fff}
.uai-table{width:100%;border-collapse:collapse;font-size:8px;background:#fff;border-radius:8px;border:1px solid #eee;overflow:hidden}
.uai-table td{padding:5px 10px;border-bottom:1px solid #f0f0f0;vertical-align:top}
.uai-table td:first-child{color:#888;font-weight:500;width:38%}
.uai-table td:last-child{color:#1a1a1a;font-weight:500}
.uai-table tr{opacity:0;transform:translateY(3px);transition:opacity .25s ease,transform .25s ease}
.uai-table tr.pop{opacity:1;transform:translateY(0)}

/* === RESPONSIVE === */
@media(max-width:640px){
  .ga-viewport{height:280px}
  .em-card{width:300px}
  .lg-art{display:none}
  .lg-grp,.lg-forgot,.lg-btn{width:170px}
  .ds-side,.ud-side,.ai-side,.cp-side,.an-side,.df-side,.um-side{width:80px}
  .au-panel{width:65%}
  .hp-hero{padding:20px 16px;flex-direction:column}
  .rm-card{width:290px}
  .fp-grp,.fp-btn{width:170px}
  .ds-profile-dd{width:160px}
  .an-panel{width:70%}
}

/* ======================================================================
   USER SECTION ANIMATIONS — NEW SCENES
   ====================================================================== */

/* --- Shared user top bar & breadcrumb bar --- */
.uf-top-bar{display:flex;justify-content:flex-end;align-items:center;gap:7px;margin-bottom:4px}
.uf-uname{font-size:10px;color:#888}
.uf-uname b{color:#333}
.uf-breadcrumb-bar{font-size:8px;color:#999;margin-bottom:6px}

/* --- USER CHANGE PASSWORD (uChangePw) --- */
.ucp-scene{position:absolute;inset:0}
.ucp-pwpage{position:absolute;inset:0;opacity:0;pointer-events:none;transition:opacity .4s ease}
.ucp-pwpage.on{opacity:1;pointer-events:auto}
.ucp-dd{z-index:20}
.ucp-tip,.ucp-toast{z-index:22}

/* --- USER DASHBOARD (uDashOverview, uDashCharts, uDashDocTypes) --- */
.ud-scene{position:absolute;inset:0}
.ud-body{overflow-y:auto}
.ud-cards{display:flex;gap:10px;margin-bottom:10px}
.ud-card{flex:1;border:1px solid #eee;border-radius:10px;padding:10px;position:relative;opacity:0;transform:translateY(8px);transition:opacity .4s,transform .4s}
.ud-card.pop{opacity:1;transform:translateY(0)}
.ud-card-ico{position:absolute;top:8px;right:8px;width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.ud-card-ico svg{width:13px;height:13px}
.ud-card-lbl{font-size:9px;color:#aaa;margin-bottom:1px}
.ud-card-val{font-size:17px;font-weight:700;color:#1a1a1a}
.ud-recent{border:1px solid #eee;border-radius:10px;padding:8px 10px;opacity:0;transform:translateY(8px);transition:opacity .4s,transform .4s}
.ud-recent.pop{opacity:1;transform:translateY(0)}
.ud-recent-title{font-size:10px;font-weight:600;color:#1a1a1a;margin-bottom:6px}
.ud-recent-table{width:100%;border-collapse:collapse;font-size:7.5px}
.ud-recent-table td{padding:4px 3px;border-bottom:1px solid #f5f5f5;vertical-align:middle}
.ud-rav{width:20px;height:20px;border-radius:50%;color:#fff;font-size:8px;font-weight:700;display:flex;align-items:center;justify-content:center}
.ud-pct{padding:1px 5px;border-radius:3px;font-weight:600;font-size:7px;color:#fff}
.ud-pct.red{background:#ef5350}
.ud-pct.orange{background:#ffa726}
.ud-pct.yellow{background:#ffee58;color:#333}
.ud-pct.green{background:#66bb6a}
.ud-status{color:#4caf50;font-size:7px}
.ud-review-btn{background:#4285f4;color:#fff;font-size:7px;padding:2px 8px;border-radius:3px;display:inline-block}
.ud-rrow{opacity:0;transform:translateX(-6px);transition:opacity .3s,transform .3s}
.ud-rrow.pop{opacity:1;transform:translateX(0)}

/* Charts */
.ud-charts-row{display:flex;gap:10px}
.ud-chart-box{flex:1;border:1px solid #eee;border-radius:10px;padding:10px;opacity:0;transform:translateY(8px);transition:opacity .4s,transform .4s}
.ud-chart-box.pop{opacity:1;transform:translateY(0)}
.ud-chart-hd{font-size:10px;font-weight:600;color:#1a1a1a;margin-bottom:8px;display:flex;justify-content:space-between;align-items:center}
.ud-chart-hd small{font-weight:400;color:#aaa;font-size:8px}
.ud-year-dd{font-size:8px;color:#888;background:#f5f5f3;padding:2px 6px;border-radius:4px}
.ud-bars{display:flex;align-items:stretch;gap:4px;height:60px}
.ud-bar-c{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end}
.ud-bar{width:100%;max-width:20px;background:#4285f4;border-radius:3px 3px 0 0;height:0;transition:height .7s cubic-bezier(.34,1.56,.64,1)}
.ud-bar-l{font-size:6px;color:#ccc;margin-top:3px}
.ud-donut{display:flex;flex-direction:column;align-items:center;gap:6px}
.ud-donut-svg{width:70px;height:70px}
.ud-donut-legend{display:flex;gap:8px;font-size:7px;color:#666}
.ud-leg-sim{color:#4285f4}
.ud-leg-own{color:#34a853}

/* Doc types */
.ud-doctypes{max-width:100%}
.ud-hamburger{cursor:default;font-size:12px;color:#999}
.ud-pie-area{display:flex;align-items:center;gap:14px;justify-content:center}
.ud-pie-svg{width:80px;height:80px}
.ud-pie-labels{display:flex;flex-wrap:wrap;gap:4px 10px;font-size:7px;color:#555}
.ud-pie-lbl span{display:inline-block;width:8px;height:8px;border-radius:2px;margin-right:3px;vertical-align:middle}
.ud-export-dd{position:absolute;top:30px;right:10px;background:#fff;border:1px solid #eee;border-radius:6px;box-shadow:0 4px 16px rgba(0,0,0,.1);padding:4px 0;font-size:8px;z-index:10;opacity:0;pointer-events:none;transition:opacity .2s}
.ud-export-dd.on{opacity:1;pointer-events:auto}
.ud-exp-item{padding:5px 12px;cursor:default}
.ud-exp-item:hover{background:#f5f5f5}

/* --- FOLDER MANAGEMENT (uFolderTable, uFolderView) --- */
.ufm-scene{position:absolute;inset:0}
.ufm-row{opacity:0;transform:translateY(4px);transition:opacity .3s,transform .3s}
.ufm-row.pop{opacity:1;transform:translateY(0)}
.ufm-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:8px}
.ufm-folder-card{background:#fff;border:1px solid #eee;border-radius:8px;padding:10px;text-align:center;position:relative;opacity:0;transform:scale(.95);transition:opacity .3s,transform .3s}
.ufm-folder-card.pop{opacity:1;transform:scale(1)}
.ufm-fc-dots{position:absolute;top:6px;right:8px;font-size:10px;color:#bbb;cursor:default}
.ufm-fc-ico{font-size:26px;margin-bottom:4px}
.ufm-fc-name{font-size:8px;font-weight:600;color:#333}
.ufm-fc-meta{font-size:7px;color:#999}
.ufm-fc-menu{position:absolute;top:18px;right:4px;background:#fff;border:1px solid #eee;border-radius:5px;box-shadow:0 3px 10px rgba(0,0,0,.1);padding:2px 0;font-size:8px;z-index:5;opacity:0;pointer-events:none;transition:opacity .2s}
.ufm-fc-menu.on{opacity:1;pointer-events:auto}
.ufm-fc-mi{padding:4px 10px;cursor:default}
.ufm-fc-mi:hover{background:#f0f4ff}

/* --- NEW FOLDER (uNewFolder) --- */
.unf-scene{position:absolute;inset:0}
.unf-panel{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.95);width:260px;max-height:90%;overflow-y:auto;background:#fff;border-radius:12px;box-shadow:0 8px 40px rgba(0,0,0,.18);padding:14px 18px;z-index:20;opacity:0;pointer-events:none;transition:opacity .3s,transform .3s;font-family:var(--db-font,system-ui,sans-serif)}
.unf-panel.on{opacity:1;pointer-events:auto;transform:translate(-50%,-50%) scale(1)}
.unf-art{font-size:22px;text-align:center;margin-bottom:8px}
.unf-close{position:absolute;top:8px;right:12px;font-size:14px;color:#999;cursor:default}
.unf-grp{margin-bottom:6px}
.unf-lbl{font-size:8px;font-weight:600;color:#d32f2f;margin-bottom:2px}
.unf-inp{border:1px solid #ddd;border-radius:5px;padding:5px 8px;font-size:8px;min-height:14px;background:#fff}
.unf-inp.fc{border-color:#4285f4;box-shadow:0 0 0 2px rgba(66,133,244,.15)}
.unf-toggles{margin-bottom:6px}
.unf-trow{display:flex;justify-content:space-between;align-items:center;padding:3px 0;font-size:8px;color:#444;border-bottom:1px solid #f5f5f5}
.unf-toggle{display:flex;border-radius:4px;overflow:hidden;border:1px solid #ddd}
.unf-t-yes,.unf-t-no{padding:2px 8px;font-size:7px;font-weight:600;cursor:default;transition:background .2s,color .2s}
.unf-t-yes{color:#999;background:#fff}
.unf-t-no{color:#999;background:#fff}
.unf-t-yes.sel{background:#4285f4;color:#fff}
.unf-t-no.sel{background:#4285f4;color:#fff}
.unf-toggle.toggled .unf-t-yes{background:#4285f4;color:#fff}
.unf-toggle.toggled .unf-t-no{background:#fff;color:#999}
.unf-db-title{font-size:9px;font-weight:700;color:#333;margin:8px 0 4px}
.unf-submit{background:#4285f4;color:#fff;text-align:center;padding:7px;border-radius:6px;font-size:9px;font-weight:600;margin-top:8px;cursor:default}

/* --- FILE UPLOAD (uUploadEnglish, uUploadRegional) --- */
.ufu-scene{position:absolute;inset:0}
.ufu-empty{border:1px solid #eee;border-radius:8px;padding:12px;margin-top:8px}
.ufu-empty-txt{font-size:8px;color:#666;background:#f8f9fa;padding:8px;border-radius:4px}
.ufu-lang-popup{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.95);width:180px;background:#fff;border-radius:12px;box-shadow:0 8px 40px rgba(0,0,0,.18);padding:16px;z-index:20;opacity:0;pointer-events:none;transition:opacity .3s,transform .3s}
.ufu-lang-popup.on{opacity:1;pointer-events:auto;transform:translate(-50%,-50%) scale(1)}
.ufu-lang-opt{display:flex;align-items:center;gap:10px;padding:10px;border-bottom:1px solid #f0f0f0;font-size:10px;font-weight:500;cursor:default;border-radius:6px;transition:background .15s}
.ufu-lang-opt:last-child{border-bottom:none}
.ufu-lang-opt.hl{background:#e8f0fe;color:#1a73e8}
.ufu-lang-ico{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;color:#4285f4}
.ufu-methods{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:200px;background:#fff;border-radius:12px;box-shadow:0 8px 40px rgba(0,0,0,.18);padding:10px;z-index:22;opacity:0;pointer-events:none;transition:opacity .3s}
.ufu-methods.on{opacity:1;pointer-events:auto}
.ufu-meth-opt{padding:8px 12px;font-size:9px;border-radius:5px;cursor:default;transition:background .15s}
.ufu-meth-opt.hl{background:#e8f0fe;color:#1a73e8}
.ufu-form{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:280px;background:#fff;border-radius:12px;box-shadow:0 8px 40px rgba(0,0,0,.18);padding:14px 18px;z-index:24;opacity:0;pointer-events:none;transition:opacity .3s}
.ufu-form.on{opacity:1;pointer-events:auto}
.ufu-form-title{font-size:10px;font-weight:700;color:#333;margin-bottom:8px}
.ufu-form-browse{background:#f8f9fa;border:1px dashed #ccc;border-radius:6px;padding:10px;text-align:center;font-size:8px;color:#4285f4;font-weight:600;margin-bottom:8px}
.ufu-form-browse small{display:block;color:#666;font-weight:400;margin-top:2px}
.ufu-form-checks{display:flex;gap:10px;margin-bottom:8px;font-size:8px;color:#333}
.ufu-form-row{display:flex;gap:8px;margin-bottom:6px}
.ufu-form-grp{flex:1}
.ufu-form-grp span{display:block;font-size:7px;font-weight:600;color:#555;margin-bottom:2px}
.ufu-form-inp{border:1px solid #ddd;border-radius:4px;padding:4px 6px;font-size:8px;min-height:14px}
.ufu-form-inp.fc{border-color:#4285f4}
.ufu-form-sel{border:1px solid #ddd;border-radius:4px;padding:4px 6px;font-size:8px;display:flex;justify-content:space-between;color:#aaa}
.ufu-form-sel.filled{color:#333}
.ufu-form-submit{background:#4285f4;color:#fff;text-align:center;padding:7px;border-radius:6px;font-size:9px;font-weight:600;margin-top:6px}

/* --- SUBMISSIONS (uSubOverview, uSubAnalysis) --- */
.usb-scene{position:absolute;inset:0}
.usb-table{font-size:7px}
.usb-table th{font-size:7px;white-space:nowrap}
.usb-row{opacity:0;transform:translateY(4px);transition:opacity .3s,transform .3s}
.usb-row.pop{opacity:1;transform:translateY(0)}
.usb-na{color:#bbb;font-size:7px}
.usb-gram{background:#e8f5e9;color:#2e7d32;padding:1px 4px;border-radius:3px;font-size:7px}
.usb-ai{color:#666;font-size:7px}
.usb-ai-high{background:#fce4ec;color:#c62828;padding:1px 4px;border-radius:3px;font-size:7px}
.usb-sim-warn{color:#e53935;font-size:7px}
.usb-sim-ok{color:#4caf50;font-size:7px}
.usb-sim-high{color:#e53935;font-weight:700;font-size:7px;cursor:default;text-decoration:underline}
.usb-sim-red{background:#ef5350;color:#fff;padding:1px 5px;border-radius:3px;font-size:7px}
.usb-dl-ico{font-size:9px;color:#888}
.usb-search{border:1px solid #ddd;border-radius:4px;padding:3px 6px;font-size:7px;color:#aaa;background:#fff}
.usb-ico-ref,.usb-ico-dl{font-size:10px;color:#888;cursor:default}

/* Analysis page */
.usb-analysis{position:absolute;inset:0;background:#fff;display:flex;flex-direction:column;font-family:var(--db-font,system-ui,sans-serif);opacity:0;transition:opacity .4s}
.usb-analysis.on{opacity:1}
.usb-an-top{display:flex;align-items:center;justify-content:space-between;padding:4px 10px;border-bottom:1px solid #eee;font-size:9px}
.usb-an-logo{font-weight:700;color:#4285f4}
.usb-an-toggle{font-size:7px;color:#888}
.usb-an-icons{display:flex;gap:6px;font-size:10px;color:#666}
.usb-an-icons span{opacity:0;transition:opacity .3s}
.usb-an-icons span.pop{opacity:1}
.usb-an-meta{font-size:7px;color:#888;padding:3px 10px;border-bottom:1px solid #f5f5f5}
.usb-an-body{display:flex;flex:1;overflow:hidden}
.usb-an-doc{flex:1;padding:8px;overflow:hidden;position:relative}
.usb-an-title-bar{font-size:8px;color:#555;margin-bottom:4px}
.usb-an-pages{position:absolute;left:2px;top:30px;font-size:7px;color:#999}
.usb-an-page-num{background:#f0f0f0;padding:2px 4px;border-radius:2px;font-size:7px}
.usb-an-content{margin-left:14px;font-size:7px;color:#333;line-height:1.4}
.usb-an-paper-title{font-size:8px;font-weight:600;color:#444;margin-bottom:4px}
.usb-an-hl{background:rgba(255,235,59,.3);padding:1px 2px}
.usb-an-text{color:#666;font-size:6.5px;margin-top:4px}
.usb-an-footer{font-size:7px;color:#999;border-top:1px solid #eee;padding-top:3px;margin-top:6px}
.usb-an-sidebar{width:130px;border-left:1px solid #eee;padding:8px;overflow-y:auto}
.usb-an-scores{display:flex;flex-direction:column;gap:2px;font-size:7px;color:#555;margin-bottom:6px}
.usb-an-scores b{color:#333}
.usb-an-sim-circle{text-align:center;margin-bottom:6px}
.usb-an-sim-pct{font-size:20px;font-weight:700;color:#e53935;display:block;line-height:1;border:3px solid #ef5350;width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 2px}
.usb-an-sim-circle div:last-child{font-size:7px;color:#888}
.usb-an-ranges{display:flex;flex-direction:column;gap:1px;font-size:6.5px;margin-bottom:6px}
.usb-rng-green{color:#4caf50}
.usb-rng-yellow{color:#ffa726}
.usb-rng-orange{color:#ef6c00}
.usb-rng-red{color:#e53935}
.usb-an-tabs{display:flex;border-bottom:2px solid #eee;margin-bottom:4px}
.usb-an-tab{flex:1;text-align:center;font-size:7px;padding:3px 0;cursor:default;color:#999}
.usb-an-tab.act{color:#4285f4;border-bottom:2px solid #4285f4;margin-bottom:-2px;font-weight:600}
.usb-an-sources{display:flex;flex-direction:column;gap:3px}
.usb-an-src{display:flex;align-items:center;gap:4px;font-size:7px;color:#444;padding:3px;border-radius:4px;opacity:0;transform:translateX(6px);transition:opacity .3s,transform .3s}
.usb-an-src.pop{opacity:1;transform:translateX(0)}
.usb-an-src span:first-child{width:14px;height:14px;background:#f5f5f5;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:7px;flex-shrink:0}
.usb-an-src div:nth-child(2){flex:1;line-height:1.2}
.usb-an-src small{color:#999;font-size:6px}
.usb-src-pct{padding:2px 6px;border-radius:3px;color:#fff;font-size:7px;font-weight:600;flex-shrink:0}

/* --- DOC ERRORS (uDocError) --- */
.ude-scene{position:absolute;inset:0}
.ude-err-badge{background:#ef5350;color:#fff;padding:1px 5px;border-radius:3px;font-size:7px}
.ude-err-row{background:#fff5f5}
.ude-tooltip{position:absolute;top:50%;right:10px;transform:translateY(-50%);width:160px;background:#fff;border:1px solid #eee;border-radius:8px;box-shadow:0 6px 24px rgba(0,0,0,.12);padding:8px 10px;z-index:15;opacity:0;transition:opacity .3s}
.ude-tooltip.on{opacity:1}
.ude-tooltip-title{font-size:9px;font-weight:700;color:#333;margin-bottom:4px}
.ude-tooltip-item{font-size:7px;color:#555;padding:2px 0;opacity:0;transform:translateX(4px);transition:opacity .3s,transform .3s}
.ude-tooltip-item.pop{opacity:1;transform:translateX(0)}

/* --- REPOSITORY (uRepoUpload, uRepoManage) --- */
.urp-scene{position:absolute;inset:0}
.urp-upload-area{border:1px dashed #ccc;border-radius:8px;padding:12px;text-align:center;margin-bottom:8px;opacity:0;transition:opacity .4s}
.urp-upload-area.pop{opacity:1}
.urp-upload-art{font-size:24px;margin-bottom:4px}
.urp-upload-info{font-size:7px;color:#666;margin-bottom:6px;line-height:1.5}
.urp-browse{background:#4285f4;color:#fff;display:inline-block;padding:4px 12px;border-radius:4px;font-size:8px;font-weight:600}
.urp-form-row{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:6px}
.urp-form-grp{flex:1;min-width:70px}
.urp-form-grp span,.urp-form-grp label{display:block;font-size:7px;font-weight:600;color:#555;margin-bottom:2px}
.urp-form-inp{border:1px solid #ddd;border-radius:4px;padding:4px 6px;font-size:8px;min-height:12px}
.urp-form-inp.fc{border-color:#4285f4}
.urp-form-sel{border:1px solid #ddd;border-radius:4px;padding:4px 6px;font-size:8px;color:#333}
.urp-exempt{font-size:7px;color:#555}
.urp-submit{background:#4285f4;color:#fff;text-align:center;padding:6px;border-radius:5px;font-size:8px;font-weight:600;width:60px}
.urp-tabs{display:flex;border-bottom:2px solid #eee;margin-bottom:6px}
.urp-tab{flex:1;text-align:center;font-size:8px;padding:5px 0;cursor:default;color:#999;font-weight:500}
.urp-tab.act{color:#4285f4;border-bottom:2px solid #4285f4;margin-bottom:-2px;font-weight:600}
.urp-row{opacity:0;transform:translateY(4px);transition:opacity .3s,transform .3s}
.urp-row.pop{opacity:1;transform:translateY(0)}
.urp-del-ico{color:#e53935;cursor:default;font-size:10px}
.urp-confirm{z-index:30}

/* --- MFA (uMfa) --- */
.umfa-scene{position:absolute;inset:0}
.umfa-card{border:1px solid #eee;border-radius:10px;padding:14px}
.umfa-confirm{z-index:30}
.umfa-toast{z-index:31}
.umfa-otp{z-index:32}

/* --- SUPPORT CENTRE (uSupCreate, uSupView) --- */
.usc-sc1,.usc-sc2{position:absolute;inset:0}
.usc-panel{z-index:20}
.usc-details{position:absolute;inset:0;z-index:15}
.usc-vrow{opacity:0;transform:translateY(4px);transition:opacity .3s,transform .3s}
.usc-vrow.pop{opacity:1;transform:translateY(0)}

/* --- FOLDER TABLE ROWS --- */
.uft-row{opacity:0;transform:translateY(6px);transition:opacity .3s ease,transform .3s ease}

/* --- FOLDER TABLE ICON (matches screenshot blue folder) --- */
.uft-fico{display:inline-block;width:14px;height:11px;background:#42a5f5;border-radius:1px 1px 2px 2px;position:relative;margin-right:5px;vertical-align:middle}
.uft-fico::before{content:'';position:absolute;top:-3px;left:0;width:6px;height:3px;background:#42a5f5;border-radius:2px 2px 0 0}

/* --- SUBMISSIONS TABLE ROWS --- */
.ust-row{opacity:0;transform:translateY(6px);transition:opacity .3s ease,transform .3s ease}
.ust-cb{cursor:default;font-size:10px}


/* ==========================================================================
   AI Content Detection — walkthrough animations
   Animations: aiPdfOverview, aiInfo, aiResult, aiHighlight
   ========================================================================== */

/* Per-section viewport heights */
.guide-anim.ai-det .ga-viewport { height: 320px; background: #f4f5f8; }
.guide-anim.ai-det .ga-slide[data-anim="aiPdfOverview"] .ga-viewport { height: 420px; background: #2d2d2d; }
.guide-anim.ai-det .ga-slide[data-anim="aiInfo"]        .ga-viewport { height: 280px; }
.guide-anim.ai-det .ga-slide[data-anim="aiResult"]      .ga-viewport { height: 360px; }
.guide-anim.ai-det .ga-slide[data-anim="aiHighlight"]   .ga-viewport { height: 360px; }

/* Common page frame for AI animations */
.ai-page {
  position: absolute;
  inset: 12px;
  background: #fff;
  border-radius: 6px;
  box-shadow: 0 1px 3px rgba(0,0,0,.08), 0 6px 18px rgba(0,0,0,.06);
  padding: 14px 20px;
  overflow: hidden;
  font-family: var(--db-font, system-ui, sans-serif);
  color: #2a2f45;
}
.ai-page-logo {
  display: flex; align-items: center; gap: 6px;
  font-size: 11px; font-weight: 700; color: #0B1E5C;
  margin-bottom: 6px; justify-content: center;
  padding-bottom: 6px; border-bottom: 1px solid #1447E6;
}
.ai-page-logo i {
  width: 12px; height: 12px; border-radius: 3px;
  background: linear-gradient(135deg, #1447E6, #1DE8FF);
}
.ai-section-title {
  font-size: 11px; font-weight: 600; font-style: italic;
  color: #1447E6; margin: 6px 0 4px;
}

/* ============= aiInfo: Submission Information ============= */
.ai-info-row {
  display: flex; font-size: 10px; line-height: 1.6; padding: 1.5px 0;
  opacity: 0; transform: translateX(-6px);
  transition: opacity .35s ease, transform .35s ease;
}
.ai-info-row.on { opacity: 1; transform: translateX(0); }
.ai-info-row .lbl { width: 38%; color: #d04141; }
.ai-info-row .val { flex: 1; color: #2a2f45; }

/* ============= aiResult: AI Text % + pie chart ============= */
.ai-result-row {
  display: flex; align-items: baseline; gap: 8px;
  font-size: 14px; margin: 4px 0 12px;
  opacity: 0; transition: opacity .4s ease;
}
.ai-result-row.on { opacity: 1; }
.ai-result-row .ai-result-lbl { color: #d04141; font-weight: 600; }
.ai-result-row .ai-result-val { color: #d04141; font-weight: 700; font-size: 18px; }

.ai-pie-title {
  text-align: center;
  font-size: 11px; font-style: italic; font-weight: 600;
  color: #1447E6;
  margin-bottom: 6px;
}
.ai-pie-wrap {
  position: relative;
  width: 200px; height: 130px;
  margin: 0 auto;
}
.ai-pie {
  width: 110px; height: 110px;
  border-radius: 50%;
  margin: 0 auto;
  background: conic-gradient(#e0e3ec 0% 100%);
  position: relative;
  transition: background 1.2s cubic-bezier(.22,1,.36,1);
  box-shadow: 0 2px 5px rgba(0,0,0,.08);
}
/* When .on, the chart fills with AI/Human split */
.ai-pie-wrap.on .ai-pie {
  background: conic-gradient(#1B8FE6 0% 32%, #f3f5f8 32% 100%);
}
.ai-pie-leg {
  position: absolute;
  font-size: 10px; line-height: 1.3;
  background: #fff; border: 1px solid #d0d5e0;
  padding: 4px 7px; border-radius: 3px;
  opacity: 0;
  transition: opacity .4s ease .6s, transform .4s ease .6s;
}
.ai-pie-leg b { font-weight: 700; }
.ai-pie-leg.ai {
  right: 0; top: 12px;
  color: #1B8FE6;
  transform: translateX(8px);
}
.ai-pie-leg.human {
  left: 0; top: 50px;
  color: #555;
  transform: translateX(-8px);
}
.ai-pie-wrap.on .ai-pie-leg { opacity: 1; transform: translateX(0); }

/* Connector lines from chart to legend boxes */
.ai-pie-leg::before {
  content: ""; position: absolute;
  top: 50%; width: 14px; height: 1px;
  background: #c0c5d0;
  opacity: 0;
  transition: opacity .3s ease .9s;
}
.ai-pie-leg.ai::before { left: -14px; }
.ai-pie-leg.human::before { right: -14px; }
.ai-pie-wrap.on .ai-pie-leg::before { opacity: 1; }

/* ============= aiHighlight: yellow AI-text highlights ============= */
.ai-doc-title {
  font-size: 12px; font-weight: 700; color: #2a2f45;
  margin: 6px 0 10px;
}
.ai-doc-line {
  font-size: 10.5px; line-height: 1.7; color: #2a2f45;
  margin-bottom: 6px;
}
.ai-hl {
  background: transparent;
  padding: 1px 3px; border-radius: 2px;
  transition: background .5s ease;
  position: relative;
}
.ai-hl.on {
  background: #fff3a8;
  box-shadow: inset 0 0 0 1px rgba(218, 165, 32, .25);
}

/* ============= Tooltip + typing caret (shared with similarity) =============
   These styles mirror the tooltip from the similarity-detection animations so
   the two pages have identical tooltip behaviour. They are scoped to
   .guide-anim.ai-det so they don't interfere with other pages. */
.guide-anim.ai-det .sd-tip {
  position: absolute;
  background: #2a2f45; color: #fff;
  font-size: 10px; padding: 7px 11px; border-radius: 6px;
  max-width: 240px; line-height: 1.4;
  white-space: normal; word-wrap: break-word;
  pointer-events: none;
  box-shadow: 0 6px 18px rgba(0,0,0,.22);
  opacity: 0; transform: translateY(-4px);
  transition: opacity .25s ease, transform .25s ease;
  z-index: 50;
}
.guide-anim.ai-det .sd-tip.on { opacity: 1; transform: translateY(0); }
.guide-anim.ai-det .sd-tip::after {
  content: ""; position: absolute;
  left: var(--tip-arrow-x, 18px); top: 100%;
  border: 6px solid transparent; border-top-color: #2a2f45;
}
.guide-anim.ai-det .sd-tip.tip-below::after {
  top: auto; bottom: 100%;
  border-top-color: transparent;
  border-bottom-color: #2a2f45;
}
.guide-anim.ai-det .sd-tip-caret {
  display: inline-block; width: 1px; height: 11px;
  background: #fff; margin-left: 2px; vertical-align: -2px;
  animation: ai-tip-caret-blink 0.7s steps(2) infinite;
}
.guide-anim.ai-det .sd-tip.done .sd-tip-caret { display: none; }
@keyframes ai-tip-caret-blink {
  0%, 50%   { opacity: 1; }
  50.01%, 100% { opacity: 0; }
}

/* ============= aiPdfOverview: Acrobat-style PDF viewer =============
   The .pdf-* base classes are duplicated here so this stylesheet is
   self-contained — the AI page does not import similarity-detection.css. */

.guide-anim.ai-det .sc-pdf {
  position: absolute; inset: 0;
  display: flex; flex-direction: column;
  background: #525252;
  font-family: var(--db-font, system-ui, sans-serif);
}
.guide-anim.ai-det .pdf-titlebar {
  height: 28px; background: linear-gradient(180deg, #f8f9fa 0%, #e8eaed 100%);
  border-bottom: 1px solid #c0c0c0;
  display: flex; align-items: center; padding: 0 8px;
  font-size: 10px; color: #444;
}
.guide-anim.ai-det .pdf-titlebar i {
  display: inline-block; width: 13px; height: 13px;
  background: linear-gradient(135deg, #db2929 0%, #aa1818 100%);
  border-radius: 2px; margin-right: 6px;
}
.guide-anim.ai-det .pdf-titlebar-name { flex: 1; font-weight: 600; color: #2a2f45; }
.guide-anim.ai-det .pdf-titlebar-controls { display: flex; gap: 6px; }
.guide-anim.ai-det .pdf-titlebar-controls span {
  display: inline-block; width: 11px; height: 11px;
  border: 1px solid #888; border-radius: 2px;
}
.guide-anim.ai-det .pdf-titlebar-controls span.x {
  background: #d04141; border-color: #a01010; color: #fff;
  font-size: 8px; line-height: 9px; text-align: center;
}
.guide-anim.ai-det .pdf-toolbar {
  height: 32px; background: #5c5c5c;
  display: flex; align-items: center; padding: 0 12px; gap: 14px;
  border-bottom: 1px solid #444;
}
.guide-anim.ai-det .pdf-tool-btn {
  width: 22px; height: 22px; border-radius: 3px;
  background: rgba(255,255,255,.08);
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; color: #ddd;
}
.guide-anim.ai-det .pdf-page-ind {
  font-size: 11px; color: #ddd;
  background: rgba(0,0,0,.25); padding: 3px 9px; border-radius: 3px;
  margin-left: auto;
}
.guide-anim.ai-det .pdf-page-ind b { color: #fff; transition: opacity .12s ease; }
.guide-anim.ai-det .pdf-zoom { font-size: 11px; color: #ddd; }

.guide-anim.ai-det .pdf-stage {
  flex: 1; position: relative;
  background: #525252;
  overflow: hidden;
}
.guide-anim.ai-det .pdf-scroll {
  position: absolute; inset: 0;
  display: flex; flex-direction: column; align-items: center;
  padding: 16px 0;
  transition: transform 0.6s cubic-bezier(.5,.05,.35,1);
  will-change: transform;
}
.guide-anim.ai-det .pdf-mini-page {
  width: 240px; min-height: 312px;
  background: #fff; border-radius: 2px;
  box-shadow: 0 2px 8px rgba(0,0,0,.4);
  margin-bottom: 14px;
  padding: 14px 16px 12px;
  font-size: 7.5px; line-height: 1.4; color: #333;
  position: relative;
  overflow: hidden;
}
.guide-anim.ai-det .pdf-mini-logo {
  text-align: center;
  font-size: 9px; font-weight: 700; color: #0B1E5C;
  margin-bottom: 6px;
  display: flex; align-items: center; justify-content: center; gap: 4px;
}
.guide-anim.ai-det .pdf-mini-logo i {
  width: 8px; height: 8px; border-radius: 2px;
  background: linear-gradient(135deg, #1447E6, #1DE8FF);
  display: inline-block;
}
.guide-anim.ai-det .pdf-mini-tag {
  text-align: center; font-size: 6px; color: #888;
  border-bottom: 1px solid #1447E6;
  padding-bottom: 3px; margin-bottom: 7px;
}
.guide-anim.ai-det .pdf-mini-h {
  font-size: 7px; font-weight: 600; color: #1447E6;
  font-style: italic; margin: 5px 0 3px;
}
.guide-anim.ai-det .pdf-mini-row { display: flex; padding: 1px 0; font-size: 6.5px; }
.guide-anim.ai-det .pdf-mini-row .k { width: 42%; color: #d04141; }
.guide-anim.ai-det .pdf-mini-row .v { flex: 1; color: #333; }
.guide-anim.ai-det .pdf-mini-doc-title {
  font-size: 8px; font-weight: 700; color: #2a2f45;
  margin: 4px 0 6px;
}
.guide-anim.ai-det .pdf-mini-line {
  font-size: 6.5px; line-height: 1.6; color: #2a2f45;
  margin-bottom: 4px;
}

.guide-anim.ai-det .pdf-ai-headline {
  font-size: 9px; color: #d04141; font-weight: 600;
  margin: 5px 0 4px;
}
.guide-anim.ai-det .pdf-ai-headline b {
  font-size: 11px; font-weight: 700; color: #d04141;
}
.guide-anim.ai-det .pdf-mini-pie-wrap {
  position: relative;
  width: 100%; height: 70px;
  margin: 4px 0 8px;
}
.guide-anim.ai-det .pdf-mini-aipie {
  width: 56px; height: 56px;
  border-radius: 50%;
  margin: 4px auto 0;
  background: conic-gradient(#1B8FE6 0% 32%, #f3f5f8 32% 100%);
  position: relative;
  box-shadow: 0 1px 3px rgba(0,0,0,.1);
}
.guide-anim.ai-det .pdf-mini-pie-leg {
  position: absolute;
  font-size: 6px;
  border: 1px solid #d0d5e0;
  background: #fff;
  padding: 2px 4px;
  border-radius: 2px;
  line-height: 1.2;
}
.guide-anim.ai-det .pdf-mini-pie-leg.ai { color: #1B8FE6; right: 18px; top: 10px; }
.guide-anim.ai-det .pdf-mini-pie-leg.human { color: #555; left: 18px; top: 35px; }

.guide-anim.ai-det .pdf-mini-disc {
  margin-top: 6px;
  padding-top: 5px;
  border-top: 1px solid #f0f1f5;
  font-size: 5.5px;
  line-height: 1.45;
  color: #555;
}
.guide-anim.ai-det .pdf-mini-disc-h {
  font-size: 6px; font-style: italic; font-weight: 600;
  color: #1447E6;
  margin-bottom: 2px;
}
.guide-anim.ai-det .pdf-mini-aihl {
  background: #fff3a8;
  padding: 0 1px;
  border-radius: 1px;
  box-shadow: inset 0 0 0 .5px rgba(218,165,32,.3);
}
