/* JARVIS Homeschool — Admin/Parent Portal Styles: admin shell, forms, student mgmt, parent portal, media queries */
    /* ====================================================
       ADMIN PORTAL
    ==================================================== */
    #screen-admin-portal{flex-direction:row;background:var(--gray-100);min-height:100vh;}
    .ap-sb{width:256px;min-height:100vh;background:var(--navy);padding:26px 0;display:flex;flex-direction:column;flex-shrink:0;position:sticky;top:0;height:100vh;overflow-y:auto;}
    .ap-sb-logo{padding:0 22px 26px;border-bottom:1px solid rgba(255,255,255,0.08);margin-bottom:18px;display:flex;align-items:center;gap:11px;}
    .ap-jmark{width:40px;height:40px;background:var(--gold);border-radius:12px;display:flex;align-items:center;justify-content:center;font-family:var(--font-c);font-weight:900;font-size:20px;color:var(--navy);}
    .ap-wm{font-family:var(--font-c);font-weight:900;font-size:18px;color:var(--white);letter-spacing:3px;}
    .ap-ws{font-size:10px;color:rgba(255,255,255,0.38);margin-top:1px;}
    .ap-ng{padding:0 14px;margin-bottom:6px;}
    .ap-nl{font-size:9px;font-weight:700;letter-spacing:1.4px;color:rgba(255,255,255,0.28);text-transform:uppercase;padding:0 8px;margin-bottom:5px;}
    .ap-nb{display:flex;align-items:center;gap:9px;padding:9px 11px;border-radius:var(--r-sm);background:none;border:none;color:rgba(255,255,255,0.5);font-size:13px;font-weight:500;width:100%;text-align:left;transition:all 0.15s;margin-bottom:2px;}
    .ap-nb:hover{background:rgba(255,255,255,0.06);color:var(--white);}
    .ap-nb.active{background:rgba(245,166,35,0.16);color:var(--gold);}
    .ap-nb.disabled{opacity:0.38;cursor:not-allowed;pointer-events:none;}
    .n-ico{font-size:15px;}
    .p-tag{margin-left:auto;font-size:9px;font-weight:600;background:rgba(255,255,255,0.08);color:rgba(255,255,255,0.28);padding:2px 6px;border-radius:8px;}
    .ap-nb.active .p-tag{background:rgba(245,166,35,0.2);color:var(--gold);}
    .ap-so{margin-top:auto;padding:16px 22px;border-top:1px solid rgba(255,255,255,0.08);}
    .ap-so button{background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1);color:rgba(255,255,255,0.42);padding:9px 16px;border-radius:var(--r-sm);font-size:13px;width:100%;transition:all 0.2s;}
    .ap-so button:hover{background:rgba(255,80,80,0.1);border-color:rgba(255,100,100,0.3);color:#ff9999;}
    .ap-main{flex:1;padding:34px 32px;overflow-y:auto;}
    .ap-page{display:none;animation:pop 0.25s ease;}
    .ap-page.active{display:block;}
    .ap-pt{font-size:25px;font-weight:700;color:var(--navy);margin-bottom:4px;}
    .ap-ps{font-size:13px;color:var(--slate-lt);margin-bottom:28px;}
    .hero-card{background:linear-gradient(135deg,var(--navy),#243B60);border-radius:var(--r-lg);padding:30px;margin-bottom:26px;color:var(--white);display:flex;align-items:center;justify-content:space-between;gap:16px;}
    .hero-card h2{font-size:22px;font-weight:700;margin-bottom:5px;}
    .hero-card p{font-size:13px;opacity:0.68;}
    .hero-badge{background:var(--gold);color:var(--navy);padding:8px 20px;border-radius:20px;font-weight:700;font-size:13px;white-space:nowrap;flex-shrink:0;}
    .stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px;margin-bottom:26px;}
    .stat-card{background:var(--white);border-radius:var(--r-md);padding:22px;box-shadow:var(--shadow-sm);}
    .stat-card .si{font-size:26px;margin-bottom:10px;}
    .stat-card .sl{font-size:11px;font-weight:600;color:var(--slate-lt);text-transform:uppercase;letter-spacing:0.5px;margin-bottom:7px;}
    .stat-card .sv{font-size:30px;font-weight:700;color:var(--navy);line-height:1;margin-bottom:5px;}
    .stat-card .ss{font-size:11px;color:var(--slate-lt);}
    .sec-hd{font-size:15px;font-weight:700;color:var(--navy);margin-bottom:14px;}
    .phase-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(265px,1fr));gap:12px;margin-bottom:28px;}
    .pi{background:var(--white);border-radius:var(--r-md);padding:18px;box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:14px;}
    .pn{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:15px;flex-shrink:0;}
    .pn.done{background:var(--mint-lt);color:var(--mint);}
    .pn.now{background:var(--gold-lt);color:var(--gold-dk);}
    .pn.next{background:var(--gray-100);color:var(--gray-300);}
    .pi-info h4{font-size:13px;font-weight:600;color:var(--navy);margin-bottom:2px;}
    .pi-info p{font-size:11px;color:var(--slate-lt);}
    .setup-card{background:var(--white);border-radius:var(--r-md);padding:26px;box-shadow:var(--shadow-sm);margin-bottom:20px;}
    .setup-card h3{font-size:16px;font-weight:700;color:var(--navy);margin-bottom:5px;}
    .setup-desc{font-size:13px;color:var(--slate-lt);margin-bottom:20px;line-height:1.55;}
    .form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
    .s-input{width:100%;padding:11px 14px;border:2px solid var(--gray-200);border-radius:var(--r-sm);font-size:14px;color:var(--navy);background:var(--cream);outline:none;transition:border-color 0.2s;}
    .s-input:focus{border-color:var(--gold);}
    .s-label{font-size:12px;font-weight:600;color:var(--slate);display:block;margin-bottom:7px;text-transform:uppercase;letter-spacing:0.3px;}
    .setup-msg{border-radius:var(--r-sm);padding:12px 16px;font-size:13px;font-weight:600;margin-top:14px;display:none;}
    .setup-msg.ok{background:var(--mint-lt);color:var(--mint);}
    .setup-msg.err{background:var(--coral-lt);color:var(--coral);}
    .stu-row{display:flex;align-items:center;gap:14px;padding:13px 15px;background:var(--gray-100);border-radius:var(--r-sm);margin-bottom:9px;}
    .stu-av{width:40px;height:40px;background:var(--gold-lt);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;}
    .stu-meta{flex:1;}
    .stu-meta strong{font-size:14px;font-weight:600;color:var(--navy);}
    .stu-meta span{font-size:12px;color:var(--slate-lt);display:block;margin-top:1px;}
    .stu-pill{font-size:11px;font-weight:600;background:var(--mint-lt);color:var(--mint);padding:3px 10px;border-radius:20px;}
    .empty-st{font-size:13px;color:var(--slate-lt);padding:16px 0;}

    /* Student metrics expand panel */
    .stu-metrics-toggle{background:none;border:none;color:var(--sky);font-size:11px;font-weight:700;cursor:pointer;padding:2px 0;font-family:var(--font-c);text-decoration:underline;}
    .stu-metrics-toggle:hover{color:var(--navy);}
    .stu-metrics-panel{display:none;background:var(--cream);border-radius:var(--r-md);padding:14px 16px;margin-top:10px;border:1px solid var(--gray-200);}
    .stu-metrics-panel.open{display:block;animation:fadeIn 0.2s ease;}
    .metrics-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:10px;}
    .metric-chip{background:var(--white);border-radius:8px;padding:8px 10px;text-align:center;box-shadow:var(--shadow-sm);}
    .metric-chip .mv{font-family:var(--font-c);font-weight:900;font-size:18px;color:var(--navy);}
    .metric-chip .ml{font-size:9px;color:var(--slate-lt);font-weight:600;text-transform:uppercase;letter-spacing:0.5px;margin-top:2px;}
    .metrics-section-title{font-family:var(--font-c);font-weight:800;font-size:11px;color:var(--slate);text-transform:uppercase;letter-spacing:0.8px;margin:10px 0 6px;border-bottom:1px solid var(--gray-200);padding-bottom:4px;}
    .mastery-bar-row{display:flex;align-items:center;gap:8px;margin-bottom:5px;}
    .mastery-bar-label{font-size:11px;color:var(--navy);font-weight:600;width:80px;flex-shrink:0;text-transform:capitalize;}
    .mastery-bar-wrap{flex:1;background:var(--gray-200);border-radius:10px;height:7px;overflow:hidden;}
    .mastery-bar-fill{height:100%;border-radius:10px;transition:width 0.6s ease;}
    .mastery-bar-val{font-size:10px;font-weight:700;color:var(--slate-lt);width:28px;text-align:right;flex-shrink:0;}

    /* Student management — edit/delete/PIN reset */
    .stu-row{display:flex;align-items:center;gap:14px;padding:13px 15px;background:var(--gray-100);border-radius:var(--r-sm);margin-bottom:9px;transition:background 0.2s;}
    .stu-actions{display:flex;gap:6px;flex-shrink:0;margin-left:auto;}
    .stu-btn{border:none;border-radius:8px;padding:6px 11px;font-size:12px;font-weight:700;cursor:pointer;transition:all 0.18s;font-family:var(--font-a);}
    .stu-btn.edit{background:var(--sky-lt);color:var(--sky);}
    .stu-btn.edit:hover{background:var(--sky);color:var(--white);}
    .stu-btn.del{background:var(--coral-lt);color:var(--coral);}
    .stu-btn.del:hover{background:var(--coral);color:var(--white);}
    .stu-edit-form{background:var(--white);border:2px solid var(--gold);border-radius:var(--r-md);padding:18px;margin-bottom:12px;display:none;animation:pop 0.25s ease;}
    .stu-edit-form.open{display:block;}
    .stu-edit-form h4{font-size:14px;font-weight:700;color:var(--navy);margin-bottom:14px;}
    .stu-edit-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px;}
    .stu-edit-actions{display:flex;gap:10px;}
    .btn-save{background:var(--mint);color:var(--white);border:none;border-radius:var(--r-sm);padding:9px 20px;font-size:13px;font-weight:700;cursor:pointer;transition:all 0.18s;}
    .btn-save:hover{background:#3a9e76;transform:translateY(-1px);}
    .btn-cancel{background:none;border:2px solid var(--gray-200);color:var(--slate-lt);border-radius:var(--r-sm);padding:9px 18px;font-size:13px;font-weight:700;cursor:pointer;transition:all 0.18s;}
    .btn-cancel:hover{border-color:var(--slate-lt);color:var(--navy);}
    .del-confirm{background:var(--coral-lt);border:2px solid var(--coral);border-radius:var(--r-md);padding:16px 18px;margin-bottom:12px;display:none;animation:pop 0.2s ease;}
    .del-confirm.open{display:block;}
    .del-confirm p{font-size:13px;font-weight:600;color:var(--coral);margin-bottom:12px;}
    .del-confirm-actions{display:flex;gap:10px;}
    .btn-del-confirm{background:var(--coral);color:var(--white);border:none;border-radius:var(--r-sm);padding:9px 18px;font-size:13px;font-weight:700;cursor:pointer;}
    .btn-del-confirm:hover{background:#e05a4a;}

    /* ===== CHILD BOTTOM NAV ===== */
    .child-bottom-nav{position:fixed;bottom:0;left:0;right:0;background:var(--white);border-top:1.5px solid var(--gray-200);display:flex;z-index:300;padding:6px 0 max(6px,env(safe-area-inset-bottom));}
    .cbn-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:8px 4px;background:none;border:none;cursor:pointer;transition:all 0.15s;}
    .cbn-btn .cbn-ico{font-size:22px;transition:transform 0.2s;}
    .cbn-btn .cbn-lbl{font-family:var(--font-c);font-size:10px;font-weight:700;color:var(--slate-lt);transition:color 0.2s;}
    .cbn-btn.active .cbn-lbl{color:var(--gold-dk);}
    .cbn-btn.active .cbn-ico{transform:scale(1.15);}
    .cbn-btn:hover .cbn-ico{transform:scale(1.1);}
    /* Add bottom padding to child screens so nav doesn't cover content */
    .child-screen{padding-bottom:72px;}
    #cs-lesson{padding-bottom:0;}

    /* ===== CHILD DASHBOARD ===== */
    #cs-dashboard{padding:18px;overflow-y:auto;}
    .dash-hero{background:linear-gradient(135deg,var(--navy) 0%,#243B60 100%);border-radius:var(--r-lg);padding:22px;margin-bottom:16px;color:var(--white);}
    .dash-hero-top{display:flex;align-items:center;gap:14px;margin-bottom:16px;}
    .dash-avatar{width:56px;height:56px;background:var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;flex-shrink:0;}
    .dash-hero-name{font-family:var(--font-c);font-weight:900;font-size:20px;}
    .dash-hero-level{font-size:12px;color:rgba(255,255,255,0.6);margin-top:2px;}
    .xp-bar-wrap{background:rgba(255,255,255,0.15);border-radius:20px;height:10px;overflow:hidden;margin-bottom:6px;}
    .xp-bar-fill{height:100%;background:linear-gradient(90deg,var(--gold),#FFD060);border-radius:20px;transition:width 0.8s ease;}
    .xp-bar-label{font-family:var(--font-c);font-size:11px;color:rgba(255,255,255,0.6);}
    .dash-stats-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;}
    .dash-mini-stat{background:rgba(255,255,255,0.1);border-radius:10px;padding:10px;text-align:center;}
    .dash-mini-stat .dms-ico{font-size:18px;margin-bottom:2px;}
    .dash-mini-stat .dms-val{font-family:var(--font-c);font-weight:900;font-size:20px;color:var(--white);}
    .dash-mini-stat .dms-lbl{font-size:10px;color:rgba(255,255,255,0.55);font-weight:600;}

    .dash-section{margin-bottom:18px;}
    .dash-section-title{font-family:var(--font-c);font-weight:800;font-size:15px;color:var(--navy);margin-bottom:10px;display:flex;align-items:center;gap:6px;}

    /* Mastery meters */
    .mastery-grid{display:flex;flex-direction:column;gap:8px;}
    .mastery-row{background:var(--white);border-radius:var(--r-md);padding:12px 14px;box-shadow:var(--shadow-sm);}
    .mastery-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:7px;}
    .mastery-subj{font-family:var(--font-c);font-weight:700;font-size:13px;display:flex;align-items:center;gap:6px;}
    .mastery-pct{font-family:var(--font-c);font-weight:800;font-size:13px;}
    .mastery-pct.high{color:var(--mint);}
    .mastery-pct.mid{color:var(--gold-dk);}
    .mastery-pct.low{color:var(--coral);}
    .mastery-bar{background:var(--gray-200);border-radius:20px;height:7px;overflow:hidden;}
    .mastery-fill{height:100%;border-radius:20px;transition:width 0.7s ease;}
    .mastery-fill.high{background:var(--mint);}
    .mastery-fill.mid{background:var(--gold);}
    .mastery-fill.low{background:var(--coral);}
    .mastery-tag{font-size:10px;font-weight:700;padding:2px 8px;border-radius:10px;margin-top:4px;display:inline-block;}
    .mastery-tag.high{background:var(--mint-lt);color:var(--mint);}
    .mastery-tag.mid{background:var(--gold-lt);color:var(--gold-dk);}
    .mastery-tag.low{background:var(--coral-lt);color:var(--coral);}

    /* Countdown cards */
    .events-wrap{display:flex;flex-direction:column;gap:8px;}
    .event-card{background:var(--white);border-radius:var(--r-md);padding:14px 16px;box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:14px;border-left:4px solid var(--gold);}
    .event-card.trip{border-left-color:var(--sky);}
    .event-card.test{border-left-color:var(--coral);}
    .event-card.eval{border-left-color:#9B59B6;}
    .event-card.special{border-left-color:var(--mint);}
    .event-ico{font-size:28px;flex-shrink:0;}
    .event-info{flex:1;}
    .event-title{font-family:var(--font-c);font-weight:800;font-size:14px;color:var(--navy);margin-bottom:2px;}
    .event-date{font-size:11px;color:var(--slate-lt);font-weight:600;}
    .event-countdown{text-align:right;flex-shrink:0;}
    .event-days{font-family:var(--font-c);font-weight:900;font-size:24px;color:var(--navy);}
    .event-days-lbl{font-size:10px;color:var(--slate-lt);font-weight:600;}
    .no-events{font-family:var(--font-c);font-size:13px;color:var(--slate-lt);text-align:center;padding:16px;background:var(--white);border-radius:var(--r-md);}

    /* Badge grid */
    .badge-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;}
    .badge-cell{background:var(--white);border-radius:var(--r-md);padding:10px 6px;text-align:center;box-shadow:var(--shadow-sm);border:1.5px solid var(--gray-200);}
    .badge-cell.earned{border-color:var(--gold);background:var(--gold-lt);}
    .badge-cell .bc-ico{font-size:22px;margin-bottom:3px;}
    .badge-cell .bc-lbl{font-family:var(--font-c);font-size:9px;font-weight:700;color:var(--slate-lt);}
    .badge-cell.earned .bc-lbl{color:var(--gold-dk);}

    /* Grade report */
    .grade-grid{display:flex;flex-direction:column;gap:6px;}
    .grade-row{background:var(--white);border-radius:var(--r-md);padding:11px 14px;box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:12px;}
    .grade-ico{font-size:20px;width:28px;text-align:center;}
    .grade-subj{font-family:var(--font-c);font-weight:700;font-size:13px;flex:1;}
    .grade-letter{font-family:var(--font-c);font-weight:900;font-size:18px;min-width:24px;text-align:center;}
    .grade-letter.A{color:var(--mint);}
    .grade-letter.B{color:var(--sky);}
    .grade-letter.C{color:var(--gold-dk);}
    .grade-letter.D{color:var(--coral);}
    .grade-letter.F{color:#cc2200;}
    .grade-pct{font-size:11px;color:var(--slate-lt);font-weight:600;}

    /* Admin events page */
    .events-admin-list{display:flex;flex-direction:column;gap:10px;margin-top:16px;}
    .ea-row{background:var(--gray-100);border-radius:var(--r-sm);padding:12px 15px;display:flex;align-items:center;gap:12px;}
    .ea-ico{font-size:22px;}
    .ea-info{flex:1;}
    .ea-title{font-size:14px;font-weight:600;color:var(--navy);}
    .ea-date{font-size:12px;color:var(--slate-lt);}
    .ea-del{background:var(--coral-lt);color:var(--coral);border:none;border-radius:8px;padding:5px 12px;font-size:12px;font-weight:700;cursor:pointer;}
    .ea-del:hover{background:var(--coral);color:var(--white);}

    /* ===== LIBRARY ===== */
    #cs-library{padding:0;overflow-y:auto;background:var(--cream);}
    .lib-header{background:linear-gradient(135deg,#1a1a2e 0%,#16213e 50%,#0f3460 100%);padding:20px 18px 16px;color:var(--white);}
    .lib-header h2{font-family:var(--font-c);font-weight:900;font-size:20px;margin-bottom:8px;}
    .lib-search-wrap{display:flex;gap:8px;align-items:center;}
    .lib-search{flex:1;padding:10px 14px;border-radius:var(--r-md);border:none;font-size:14px;background:rgba(255,255,255,0.15);color:var(--white);font-family:var(--font-c);}
    .lib-search::placeholder{color:rgba(255,255,255,0.5);}
    .lib-search:focus{outline:none;background:rgba(255,255,255,0.25);}
    .lib-filter{padding:9px 14px;border-radius:var(--r-md);border:none;font-size:13px;background:rgba(255,255,255,0.15);color:var(--white);font-family:var(--font-c);cursor:pointer;}
    .lib-body{padding:16px 18px 80px;}
    .lib-section-title{font-family:var(--font-c);font-weight:800;font-size:14px;color:var(--navy);margin-bottom:12px;display:flex;align-items:center;gap:6px;}
    .book-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:14px;margin-bottom:24px;}
    .book-card{background:var(--white);border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-sm);cursor:pointer;transition:all 0.2s;border:2px solid var(--gray-200);}
    .book-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--gold);}
    .book-cover{width:100%;aspect-ratio:3/4;object-fit:cover;background:linear-gradient(135deg,var(--navy),#243B60);display:flex;align-items:center;justify-content:center;font-size:40px;}
    .book-cover-img{width:100%;aspect-ratio:3/4;object-fit:cover;}
    .book-cover-fb{width:100%;aspect-ratio:3/4;background:linear-gradient(135deg,var(--navy),#243B60);display:flex;align-items:center;justify-content:center;font-size:40px;}
    .book-info{padding:10px;}
    .book-title{font-family:var(--font-c);font-weight:800;font-size:12px;color:var(--navy);line-height:1.3;margin-bottom:3px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
    .book-author{font-size:10px;color:var(--slate-lt);margin-bottom:6px;}
    .book-badge{display:inline-flex;align-items:center;gap:3px;font-family:var(--font-c);font-size:10px;font-weight:700;padding:2px 7px;border-radius:10px;}
    .book-badge.unread{background:var(--gold-lt);color:var(--gold-dk);}
    .book-badge.read{background:var(--mint-lt);color:var(--mint);}
    .lib-empty{text-align:center;padding:40px 20px;color:var(--slate-lt);font-family:var(--font-c);}
    .lib-empty-ico{font-size:48px;margin-bottom:12px;}

    /* Book reader overlay */
    .book-reader{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--navy);z-index:500;display:none;flex-direction:column;}
    .book-reader.open{display:flex;}
    .reader-bar{background:var(--navy);padding:12px 16px;display:flex;align-items:center;gap:12px;flex-shrink:0;}
    .reader-close{background:none;border:none;color:var(--white);font-size:20px;cursor:pointer;padding:4px;}
    .reader-title{font-family:var(--font-c);font-weight:800;font-size:15px;color:var(--white);flex:1;}
    .reader-frame{flex:1;border:none;width:100%;background:var(--white);}

    /* Admin library page */
    .book-admin-row{background:var(--white);border-radius:var(--r-md);padding:14px 16px;box-shadow:var(--shadow-sm);display:flex;align-items:flex-start;gap:12px;margin-bottom:10px;}
    .book-admin-cover{width:50px;height:70px;border-radius:6px;object-fit:cover;background:linear-gradient(135deg,var(--navy),#243B60);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;}
    .book-admin-cover-img{width:50px;height:70px;border-radius:6px;object-fit:cover;flex-shrink:0;}
    .book-admin-info{flex:1;}
    .book-admin-title{font-family:var(--font-c);font-weight:800;font-size:14px;color:var(--navy);margin-bottom:2px;}
    .book-admin-meta{font-size:11px;color:var(--slate-lt);margin-bottom:6px;}
    .book-admin-stats{font-size:11px;color:var(--slate-lt);}
    .book-admin-actions{display:flex;gap:6px;flex-shrink:0;}

    /* ===== KID COUPON SHOP ===== */
    #cs-shop{padding:18px;overflow-y:auto;}
    .shop-header{background:linear-gradient(135deg,#2D1B69 0%,#11998e 100%);border-radius:var(--r-lg);padding:20px;margin-bottom:18px;color:var(--white);display:flex;align-items:center;justify-content:space-between;}
    .shop-header-left h2{font-family:var(--font-c);font-weight:900;font-size:20px;margin-bottom:4px;}
    .shop-header-left p{font-size:12px;opacity:0.7;}
    .shop-balance{background:rgba(255,255,255,0.15);border-radius:var(--r-md);padding:12px 18px;text-align:center;}
    .shop-balance-val{font-family:var(--font-c);font-weight:900;font-size:32px;color:#FFD060;}
    .shop-balance-lbl{font-size:11px;opacity:0.7;font-weight:600;}
    .shop-section-title{font-family:var(--font-c);font-weight:800;font-size:14px;color:var(--navy);margin-bottom:10px;display:flex;align-items:center;gap:6px;}
    .reward-grid{display:flex;flex-direction:column;gap:10px;margin-bottom:22px;}
    .reward-card{background:var(--white);border-radius:var(--r-lg);padding:16px;box-shadow:var(--shadow-sm);border:2px solid var(--gray-200);display:flex;align-items:center;gap:14px;transition:all 0.2s;position:relative;}
    .reward-card.affordable{border-color:var(--mint);background:linear-gradient(135deg,#F0FBF5,var(--white));}
    .reward-card.premium{border-color:#9B59B6;background:linear-gradient(135deg,#F9F0FF,var(--white));}
    .reward-card.claimed{border-color:var(--gray-200);opacity:0.6;}
    .reward-card.pending{border-color:var(--gold);background:var(--gold-lt);}
    .reward-ico{font-size:36px;flex-shrink:0;width:52px;text-align:center;}
    .reward-info{flex:1;min-width:0;}
    .reward-name{font-family:var(--font-c);font-weight:800;font-size:15px;color:var(--navy);margin-bottom:3px;}
    .reward-desc{font-size:12px;color:var(--slate-lt);margin-bottom:8px;line-height:1.4;}
    .reward-cost{display:inline-flex;align-items:center;gap:4px;background:var(--navy);color:var(--white);border-radius:20px;padding:3px 11px;font-family:var(--font-c);font-size:12px;font-weight:800;}
    .reward-cost.affordable{background:var(--mint);}
    .reward-cost.premium{background:#9B59B6;}
    .reward-action{flex-shrink:0;margin-left:8px;}
    .btn-redeem{border:none;border-radius:var(--r-sm);padding:9px 16px;font-family:var(--font-c);font-size:13px;font-weight:800;cursor:pointer;transition:all 0.2s;}
    .btn-redeem.can{background:var(--gold);color:var(--navy);}
    .btn-redeem.can:hover{background:var(--gold-dk);transform:translateY(-1px);}
    .btn-redeem.cant{background:var(--gray-100);color:var(--gray-300);cursor:not-allowed;}
    .btn-redeem.pending-btn{background:var(--gold-lt);color:var(--gold-dk);cursor:not-allowed;}
    .btn-redeem.claimed-btn{background:var(--mint-lt);color:var(--mint);cursor:not-allowed;}
    .reward-tier-badge{position:absolute;top:10px;right:10px;font-size:10px;font-weight:700;padding:2px 8px;border-radius:10px;}
    .tier-small{background:var(--mint-lt);color:var(--mint);}
    .tier-medium{background:var(--sky-lt);color:var(--sky);}
    .tier-large{background:#F0E8FF;color:#9B59B6;}
    .tier-premium{background:#2D1B69;color:#FFD060;}
    .redemption-row{background:var(--white);border-radius:var(--r-md);padding:14px 16px;box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:12px;margin-bottom:8px;border-left:4px solid var(--gold);}
    .redemption-row.approved{border-left-color:var(--mint);}
    .redemption-row.denied{border-left-color:var(--coral);}
    .red-ico{font-size:24px;flex-shrink:0;}
    .red-info{flex:1;}
    .red-title{font-family:var(--font-c);font-weight:700;font-size:14px;color:var(--navy);}
    .red-meta{font-size:11px;color:var(--slate-lt);margin-top:2px;}
    .red-actions{display:flex;gap:6px;flex-shrink:0;}
    .btn-approve{background:var(--mint);color:var(--white);border:none;border-radius:8px;padding:7px 14px;font-size:12px;font-weight:700;cursor:pointer;}
    .btn-approve:hover{background:#3a9e76;}
    .btn-deny{background:var(--coral-lt);color:var(--coral);border:none;border-radius:8px;padding:7px 14px;font-size:12px;font-weight:700;cursor:pointer;}
    .btn-deny:hover{background:var(--coral);color:var(--white);}
    .red-status{font-size:12px;font-weight:700;padding:4px 12px;border-radius:20px;}
    .red-status.approved{background:var(--mint-lt);color:var(--mint);}
    .red-status.denied{background:var(--coral-lt);color:var(--coral);}
    .red-status.pending{background:var(--gold-lt);color:var(--gold-dk);}
    .shop-empty{font-family:var(--font-c);font-size:13px;color:var(--slate-lt);text-align:center;padding:20px;background:var(--white);border-radius:var(--r-md);}

    /* ===== PHASE 3 ADDITIONS ===== */

    /* Streak bar under lesson progress */
    .streak-bar{display:flex;align-items:center;gap:8px;padding:7px 18px;background:var(--gold-lt);border-bottom:1.5px solid rgba(245,166,35,0.2);transition:all 0.3s;}
    .streak-bar.hidden{display:none;}
    .streak-label{font-family:var(--font-c);font-size:13px;font-weight:800;color:var(--gold-dk);}
    .streak-dots{display:flex;gap:4px;}
    .sdot{width:10px;height:10px;border-radius:50%;background:var(--gray-200);transition:all 0.25s;}
    .sdot.lit{background:var(--gold);box-shadow:0 0 6px rgba(245,166,35,0.7);}

    /* Combo burst label */
    .combo-burst{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(0);font-family:var(--font-c);font-weight:900;font-size:42px;color:var(--gold);text-shadow:0 4px 20px rgba(245,166,35,0.5),0 0 0 2px var(--navy);pointer-events:none;z-index:9999;transition:transform 0.25s cubic-bezier(0.34,1.56,0.64,1),opacity 0.25s;}
    .combo-burst.show{transform:translate(-50%,-60%) scale(1);}
    .combo-burst.hide{transform:translate(-50%,-70%) scale(0.8);opacity:0;}

    /* JARVIS speaking pulse */
    @keyframes jvPulse{0%,100%{box-shadow:0 0 0 0 rgba(74,173,232,0.5)}50%{box-shadow:0 0 0 8px rgba(74,173,232,0)}}
    .lp-jv-img.speaking{animation:jvPulse 1s ease infinite,jarvisFade 0.3s ease;}
    .lp-jv.speaking{border:1.5px solid rgba(74,173,232,0.4);}

    /* Hint button */
    .hint-row{display:flex;justify-content:flex-end;margin-top:-6px;}
    .hint-btn{background:none;border:1.5px solid var(--sky);color:var(--sky);border-radius:20px;padding:5px 14px;font-family:var(--font-c);font-size:12px;font-weight:700;transition:all 0.2s;display:flex;align-items:center;gap:5px;}
    .hint-btn:hover{background:var(--sky-lt);}
    .hint-btn:disabled{opacity:0.35;cursor:not-allowed;}
    .hint-text{background:var(--sky-lt);border:1.5px solid rgba(74,173,232,0.3);border-radius:var(--r-sm);padding:11px 15px;font-family:var(--font-c);font-size:13px;font-weight:600;color:var(--navy);line-height:1.5;display:none;animation:pop 0.25s ease;}
    .hint-text.show{display:block;}

    /* Sound toggle in header */
    .sound-toggle{background:none;border:none;font-size:18px;cursor:pointer;padding:4px 6px;border-radius:8px;transition:background 0.15s;opacity:0.65;}
    .sound-toggle:hover{background:var(--gray-100);opacity:1;}

    /* XP header shimmer */
    @keyframes xpShimmer{0%{color:var(--navy)}30%{color:var(--gold-dk)}70%{color:var(--gold-dk)}100%{color:var(--navy)}}
    .cp-stat-val.xpshine{animation:xpShimmer 0.8s ease;}

    /* Milestone toast */
    .milestone-toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%) translateY(80px);background:var(--navy);color:var(--white);border-radius:var(--r-lg);padding:14px 22px;font-family:var(--font-c);font-weight:700;font-size:15px;display:flex;align-items:center;gap:10px;box-shadow:var(--shadow-lg);z-index:9999;transition:transform 0.4s cubic-bezier(0.34,1.56,0.64,1),opacity 0.3s;opacity:0;white-space:nowrap;}
    .milestone-toast.show{transform:translateX(-50%) translateY(0);opacity:1;}
    .milestone-toast.hide{transform:translateX(-50%) translateY(80px);opacity:0;}

    @media(max-width:768px){
      #screen-admin-portal{flex-direction:column;}
      .ap-sb{width:100%;min-height:auto;height:auto;position:relative;padding:14px 0;}
      .ap-ng{display:flex;flex-wrap:wrap;gap:4px;padding:0 10px;}
      .ap-nl{display:none;}
      .ap-main{padding:18px 14px;}
      .form-row{grid-template-columns:1fr;}
      .hero-card{flex-direction:column;gap:12px;text-align:center;}
    }
    @media(max-width:480px){
      .land-title{font-size:30px;}
      .pin-pad{max-width:240px;}
      .lp-qtext{font-size:16px;}
      .ans-btn{font-size:14px;padding:13px 15px;}
      .sum-stats{grid-template-columns:1fr 1fr;}
    }
  
/* ============================================================
   CURRICULUM VAULT (Step 2D)
   ============================================================ */

.cv-filter-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  padding: 16px;
  background: var(--white);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-sm);
  margin-bottom: 16px;
  align-items: flex-end;
}
.cv-filter-group {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 120px;
}
.cv-filter-group label {
  font-size: 10px;
  font-weight: 800;
  color: var(--slate-lt);
  letter-spacing: 0.5px;
  text-transform: uppercase;
}
.cv-filter-group select,
.cv-filter-group input {
  padding: 8px 10px;
  border-radius: var(--r-sm);
  border: 1.5px solid var(--gray-200);
  font-size: 13px;
  font-weight: 600;
  color: var(--navy);
  background: var(--white);
  cursor: pointer;
  font-family: inherit;
}
.cv-filter-group input {
  cursor: text;
}
.cv-count-bar {
  font-size: 12px;
  color: var(--slate);
  padding: 8px 4px;
  margin-bottom: 12px;
}
.cv-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 16px;
}
.cv-card {
  background: var(--white);
  border-radius: var(--r-md);
  padding: 16px;
  box-shadow: var(--shadow-sm);
  cursor: pointer;
  border: 1.5px solid transparent;
  transition: all 0.15s ease;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.cv-card:hover {
  border-color: var(--navy);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md, 0 4px 12px rgba(0,0,0,0.1));
}
.cv-card-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 8px;
}
.cv-card-icon {
  font-size: 24px;
}
.cv-card-badge {
  font-size: 9px;
  font-weight: 800;
  padding: 3px 8px;
  border-radius: 8px;
  letter-spacing: 0.5px;
}
.cv-card-title {
  font-size: 14px;
  font-weight: 800;
  color: var(--navy);
  line-height: 1.3;
  min-height: 36px;
}
.cv-card-meta {
  font-size: 11px;
  color: var(--slate-lt);
  font-weight: 600;
}
.cv-card-asg {
  display: flex;
  gap: 4px;
  align-items: center;
  padding-top: 8px;
  border-top: 1px solid var(--gray-200);
  margin-top: 4px;
}
.cv-asg-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 22px;
  height: 22px;
  padding: 0 6px;
  border-radius: 11px;
  background: var(--navy);
  color: var(--white);
  font-size: 10px;
  font-weight: 800;
}
.cv-asg-more {
  background: var(--gray-200);
  color: var(--slate);
}

/* Modal */
.cv-modal {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(10, 20, 40, 0.7);
  z-index: 9999;
  align-items: flex-start;
  justify-content: center;
  padding: 40px 20px;
  overflow-y: auto;
}
.cv-modal-inner {
  background: var(--white);
  border-radius: var(--r-md);
  max-width: 900px;
  width: 100%;
  padding: 32px;
  position: relative;
  box-shadow: 0 20px 60px rgba(0,0,0,0.3);
}
.cv-modal-close {
  position: absolute;
  top: 16px;
  right: 16px;
  background: var(--gray-100);
  border: none;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  font-size: 16px;
  font-weight: 800;
  color: var(--slate);
  cursor: pointer;
  z-index: 2;
}
.cv-modal-close:hover {
  background: var(--coral-lt);
  color: var(--coral);
}

.cv-detail-header {
  padding-bottom: 20px;
  border-bottom: 2px solid var(--gray-200);
  margin-bottom: 20px;
}
.cv-detail-meta {
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
  padding: 16px;
  background: var(--gray-100);
  border-radius: var(--r-sm);
  margin-bottom: 20px;
  font-size: 12px;
  color: var(--slate);
}
.cv-detail-meta strong {
  color: var(--slate-lt);
  text-transform: uppercase;
  font-size: 10px;
  display: block;
  margin-bottom: 2px;
  letter-spacing: 0.5px;
}

.cv-status-actions {
  display: flex;
  gap: 12px;
  margin-bottom: 20px;
  flex-wrap: wrap;
}
.cv-status-btn {
  padding: 12px 24px;
  border-radius: var(--r-sm);
  border: none;
  font-size: 13px;
  font-weight: 800;
  cursor: pointer;
  letter-spacing: 0.3px;
}
.cv-status-approve {
  background: #E0E7FF;
  color: #3730A3;
}
.cv-status-approve:hover { background: #C7D2FE; }
.cv-status-publish {
  background: var(--mint);
  color: var(--white);
}
.cv-status-publish:hover { background: #0E8A6E; }
.cv-status-unpublish {
  background: var(--coral-lt);
  color: var(--coral);
}

.cv-detail-section {
  margin-bottom: 24px;
}
.cv-detail-section-title {
  font-size: 13px;
  font-weight: 800;
  color: var(--navy);
  margin-bottom: 12px;
  padding-bottom: 6px;
  border-bottom: 1.5px solid var(--gray-200);
}

/* Assignment panel */
.cv-asg-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 12px;
}
.cv-asg-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  background: var(--gray-100);
  border-radius: var(--r-sm);
}
.cv-asg-name {
  flex: 1;
  font-size: 13px;
  font-weight: 700;
  color: var(--navy);
}
.cv-asg-status {
  font-size: 9px;
  font-weight: 800;
  padding: 3px 8px;
  border-radius: 8px;
  letter-spacing: 0.5px;
}
.cv-asg-pending { background: var(--gold-lt); color: var(--gold-dk); }
.cv-asg-in_progress { background: #DBEAFE; color: #1E40AF; }
.cv-asg-completed { background: var(--mint-lt); color: var(--mint); }
.cv-asg-remove {
  background: var(--coral-lt);
  color: var(--coral);
  border: none;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  font-weight: 800;
  cursor: pointer;
  font-size: 11px;
}
.cv-asg-add-row {
  display: flex;
  gap: 8px;
  padding-top: 8px;
  align-items: center;
}
.cv-asg-select {
  flex: 1;
  padding: 8px 12px;
  border-radius: var(--r-sm);
  border: 1.5px solid var(--gray-200);
  font-size: 13px;
  font-weight: 600;
  color: var(--navy);
}
.cv-asg-add {
  padding: 8px 16px;
  background: var(--navy);
  color: var(--white);
  border: none;
  border-radius: var(--r-sm);
  font-size: 12px;
  font-weight: 800;
  cursor: pointer;
}

/* Teach slides */
.cv-slide {
  background: var(--gray-100);
  border-radius: var(--r-sm);
  padding: 16px;
  margin-bottom: 12px;
  border-left: 4px solid var(--navy);
}
.cv-slide-head {
  font-size: 12px;
  font-weight: 800;
  color: var(--navy);
  margin-bottom: 8px;
  text-transform: uppercase;
  letter-spacing: 0.3px;
}
.cv-slide-body {
  font-size: 14px;
  line-height: 1.6;
  color: var(--slate);
  margin-bottom: 10px;
}
.cv-slide-example {
  padding: 10px 14px;
  background: var(--gold-lt);
  border-radius: var(--r-sm);
  font-size: 13px;
  color: var(--gold-dk);
  margin-bottom: 10px;
}
.cv-slide-vocab {
  font-size: 12px;
  color: var(--slate);
}
.cv-slide-vocab ul {
  margin: 6px 0 0 20px;
  padding: 0;
}
.cv-slide-vocab li {
  margin-bottom: 4px;
}

/* Questions */
.cv-question {
  padding: 16px;
  background: var(--white);
  border: 1.5px solid var(--gray-200);
  border-radius: var(--r-sm);
  margin-bottom: 12px;
}
.cv-q-head {
  font-size: 11px;
  font-weight: 800;
  color: var(--slate-lt);
  letter-spacing: 0.5px;
  text-transform: uppercase;
  margin-bottom: 8px;
}
.cv-q-text {
  font-size: 14px;
  font-weight: 700;
  color: var(--navy);
  margin-bottom: 12px;
}
.cv-ans-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-bottom: 10px;
}
.cv-ans {
  padding: 10px 14px;
  background: var(--gray-100);
  border-radius: var(--r-sm);
  font-size: 13px;
  color: var(--slate);
  display: flex;
  align-items: center;
  gap: 8px;
  position: relative;
}
.cv-ans-correct {
  background: var(--mint-lt);
  color: var(--mint);
  font-weight: 700;
}
.cv-ans-letter {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--white);
  font-size: 11px;
  font-weight: 800;
  flex-shrink: 0;
}
.cv-ans-correct .cv-ans-letter {
  background: var(--mint);
  color: var(--white);
}
.cv-ans-check {
  margin-left: auto;
  color: var(--mint);
  font-weight: 800;
}
.cv-q-hint {
  padding: 8px 12px;
  background: var(--gold-lt);
  border-radius: var(--r-sm);
  font-size: 12px;
  color: var(--gold-dk);
}

/* Validator audit */
.cv-audit {
  padding: 16px;
  background: #F0F9FF;
  border: 1.5px solid #BAE6FD;
  border-radius: var(--r-sm);
  margin-bottom: 20px;
}
.cv-audit-title {
  font-size: 12px;
  font-weight: 800;
  color: #0C4A6E;
  margin-bottom: 8px;
  letter-spacing: 0.5px;
  text-transform: uppercase;
}
.cv-audit-row {
  font-size: 12px;
  color: #075985;
  font-family: monospace;
  padding: 2px 0;
}

/* Utility actions */
.cv-utility-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  padding-top: 16px;
  border-top: 2px solid var(--gray-200);
}
.cv-util-btn {
  padding: 10px 16px;
  background: var(--gray-100);
  color: var(--navy);
  border: 1.5px solid var(--gray-200);
  border-radius: var(--r-sm);
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
}
.cv-util-btn:hover {
  background: var(--white);
  border-color: var(--navy);
}
.cv-util-danger {
  background: var(--coral-lt);
  color: var(--coral);
  border-color: var(--coral-lt);
}
.cv-util-danger:hover {
  background: var(--coral);
  color: var(--white);
  border-color: var(--coral);
}
.cv-util-bootcamp {
  background: #FEF3C7;
  color: #92400E;
  border-color: #FDE68A;
}
.cv-util-bootcamp:hover {
  background: #F59E0B;
  color: var(--white);
  border-color: #F59E0B;
}
.cv-util-redo {
  background: #DBEAFE;
  color: #1E40AF;
  border-color: #93C5FD;
}
.cv-util-redo:hover {
  background: #3B82F6;
  color: var(--white);
  border-color: #3B82F6;
}

/* Math visual equation rendering in teach slides */
.cv-slide-body pre,
.cv-slide-example pre {
  background: #1E293B;
  color: #E2E8F0;
  padding: 16px 20px;
  border-radius: 8px;
  font-family: 'Courier New', Courier, monospace;
  font-size: 15px;
  line-height: 1.6;
  overflow-x: auto;
  margin: 12px 0;
  white-space: pre;
  border-left: 4px solid var(--gold);
}

/* ============================================================
   LESSON UPLOADER (Task 7)
   ============================================================ */

.lu-mode-tabs{display:flex;gap:0;margin-bottom:16px;border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-sm);}
.lu-mode-tab{flex:1;padding:14px 12px;text-align:center;background:var(--gray-100);color:var(--slate-lt);font-size:13px;font-weight:700;cursor:pointer;border:none;transition:background 0.15s;}
.lu-mode-tab:hover{background:var(--gray-200);}
.lu-mode-active{background:var(--navy);color:var(--white);}
.lu-mode-active:hover{background:var(--navy);}

.lu-textarea{width:100%;min-height:380px;padding:14px;font-family:Menlo,Consolas,'Courier New',monospace;font-size:12.5px;line-height:1.5;border:1px solid var(--gray-300);border-radius:var(--r-md);background:#fafafa;color:var(--navy);resize:vertical;box-sizing:border-box;}
.lu-textarea:focus{outline:none;border-color:var(--navy);background:var(--white);box-shadow:0 0 0 3px rgba(11,30,50,0.08);}

.lu-btn-row{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap;}
.lu-btn-primary{background:var(--navy);color:var(--white);border:none;border-radius:var(--r-sm);padding:10px 22px;font-size:13px;font-weight:700;cursor:pointer;}
.lu-btn-primary:hover{opacity:0.9;}
.lu-btn-primary:disabled{opacity:0.4;cursor:not-allowed;}
.lu-btn-secondary{background:var(--white);color:var(--navy);border:1px solid var(--gray-300);border-radius:var(--r-sm);padding:10px 22px;font-size:13px;font-weight:700;cursor:pointer;}
.lu-btn-secondary:hover{background:var(--gray-100);}

.lu-errors-box{margin-top:14px;padding:14px 16px;background:#fdecec;border:1px solid #e8b4b4;border-left:4px solid #c93131;border-radius:var(--r-sm);}
.lu-errors-title{font-weight:700;color:#7a1f1f;font-size:13px;margin-bottom:8px;}
.lu-errors-list{margin:0;padding-left:20px;color:#7a1f1f;font-size:12.5px;line-height:1.6;}
.lu-errors-list li{margin-bottom:3px;}

.lu-preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:14px;margin-top:18px;}
.lu-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--r-md);padding:14px 16px;box-shadow:var(--shadow-sm);}
.lu-card-head{display:flex;align-items:flex-start;gap:12px;margin-bottom:10px;}
.lu-card-icon{font-size:28px;line-height:1;flex-shrink:0;}
.lu-card-titles{flex:1;min-width:0;}
.lu-card-id{font-family:Menlo,Consolas,monospace;font-size:12px;color:var(--slate-lt);margin-bottom:2px;word-break:break-all;}
.lu-card-subj{font-weight:700;color:var(--navy);font-size:13px;}
.lu-card-badges{display:flex;flex-direction:column;gap:4px;align-items:flex-end;flex-shrink:0;}
.lu-card-meta{margin-bottom:10px;padding-bottom:10px;border-bottom:1px dashed var(--gray-200);}
.lu-card-topic{font-size:13px;color:var(--navy);margin-bottom:4px;line-height:1.4;}
.lu-card-counts{font-size:11.5px;color:var(--slate-lt);font-weight:600;letter-spacing:0.3px;}

.lu-tag{display:inline-block;padding:3px 8px;border-radius:10px;font-size:10px;font-weight:700;letter-spacing:0.4px;background:var(--gray-200);color:var(--slate-lt);}
.lu-tag-new{background:#d8efe1;color:#1d6b3a;}
.lu-tag-dup{background:#fde8c8;color:#8a4a09;}
.lu-tag-faith{background:#e7d9f2;color:#5a2d8c;}
.lu-tag-warn{background:#fdecec;color:#7a1f1f;}
.lu-tag-saved{background:#1d6b3a;color:var(--white);}
.lu-tag-fail{background:#c93131;color:var(--white);}

.lu-action-row{display:flex;gap:6px;margin-top:8px;}
.lu-action-row-3 button{flex:1;font-size:11px;padding:7px 4px;}
.lu-action-row button{flex:1;border:none;border-radius:var(--r-sm);padding:8px 10px;font-size:12px;font-weight:700;cursor:pointer;transition:opacity 0.15s;}
.lu-action-row button:hover{opacity:0.85;}

.lu-btn-skip{background:var(--gray-200);color:var(--slate-lt);}
.lu-btn-save{background:#1d6b3a;color:var(--white);}
.lu-btn-version{background:#8c5a17;color:var(--white);}
.lu-btn-overwrite{background:#c93131;color:var(--white);}

.lu-action-pill{display:inline-block;font-size:10.5px;font-weight:700;padding:3px 9px;border-radius:10px;margin-bottom:6px;letter-spacing:0.3px;}
.lu-action-pill-save{background:#d8efe1;color:#1d6b3a;}
.lu-action-pill-version{background:#f5e3c8;color:#8c5a17;}
.lu-action-pill-overwrite{background:#fdd8d8;color:#7a1f1f;}
.lu-action-pill-skip{background:var(--gray-200);color:var(--slate-lt);}

.lu-saved-id{font-family:Menlo,Consolas,monospace;font-size:11.5px;color:#1d6b3a;font-weight:700;}
.lu-fail-msg{font-size:11.5px;color:#7a1f1f;font-weight:600;}

.lu-save-bar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px;margin-top:22px;padding:14px 18px;background:var(--gray-100);border-radius:var(--r-md);border:1px solid var(--gray-200);}
.lu-save-bar-summary{font-size:13px;color:var(--navy);}

.lu-instructions{padding:14px 16px;background:var(--gray-100);border-left:4px solid var(--navy);border-radius:var(--r-sm);font-size:12.5px;color:var(--slate-lt);line-height:1.6;margin-bottom:18px;}
.lu-instructions strong{color:var(--navy);}

/* Uploader page header utilities (replaces inline styles in index.html) */
.lu-header-btn-group{display:flex;gap:10px;flex-wrap:wrap;}
.lu-header-nav-btn{background:var(--navy);color:var(--white);border:none;border-radius:var(--r-sm);padding:10px 20px;font-size:13px;font-weight:700;cursor:pointer;white-space:nowrap;}
.lu-header-nav-btn:hover{opacity:0.9;}
.lu-page-header{display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-bottom:20px;}
.lu-page-title{margin-bottom:6px;}
.lu-hidden{display:none !important;}
