/* ============================================================
   SYLLABUS TRACKING SYSTEM — CSS
   Theme: Cyan / Dark Blue / White
   ============================================================ */

:root {
    --cyan-50:#e0f7fa;--cyan-100:#b2ebf2;--cyan-200:#80deea;--cyan-300:#4dd0e1;
    --cyan-400:#26c6da;--cyan-500:#00bcd4;--cyan-600:#00acc1;--cyan-700:#0097a7;
    --cyan-800:#00838f;--cyan-900:#006064;
    --blue-50:#e8eaf6;--blue-100:#c5cae9;--blue-200:#9fa8da;--blue-300:#7986cb;
    --blue-400:#5c6bc0;--blue-500:#3f51b5;--blue-600:#3949ab;--blue-700:#303f9f;
    --blue-800:#283593;--blue-900:#1a237e;--blue-950:#0d1247;
    --primary:#00bcd4;--primary-light:#4dd0e1;--primary-dark:#0097a7;
    --secondary:#1a237e;--secondary-light:#303f9f;--secondary-dark:#0d1247;
    --accent:#00e5ff;
    --white:#ffffff;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;
    --gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-600:#475569;
    --gray-700:#334155;--gray-800:#1e293b;--gray-900:#0f172a;
    --success:#10b981;--warning:#f59e0b;--danger:#ef4444;--info:#00bcd4;
    --gradient-primary:linear-gradient(135deg,var(--cyan-500) 0%,var(--blue-900) 100%);
    --gradient-hero:linear-gradient(135deg,var(--blue-950) 0%,var(--blue-900) 40%,var(--cyan-800) 100%);
    --shadow-sm:0 1px 3px rgba(0,0,0,.08);--shadow-md:0 4px 12px rgba(0,0,0,.1);
    --shadow-lg:0 8px 30px rgba(0,0,0,.12);--shadow-xl:0 20px 60px rgba(0,0,0,.15);
    --shadow-cyan:0 8px 30px rgba(0,188,212,.25);
    --font-primary:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
    --font-heading:'Playfair Display',Georgia,serif;
    --radius-sm:8px;--radius-md:12px;--radius-lg:20px;--radius-full:9999px;
    --transition-fast:.2s ease;--transition-base:.3s ease;
    --sidebar-width:260px;--topbar-height:64px;
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font-primary);font-size:15px;line-height:1.6;color:var(--gray-700);background:var(--gray-50);overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit;transition:color var(--transition-fast)}
img{max-width:100%;height:auto;display:block}
ul,ol{list-style:none}
h1,h2,h3,h4,h5,h6{font-family:var(--font-primary);color:var(--secondary);line-height:1.3;font-weight:700}
.text-center{text-align:center}
.text-muted{color:var(--gray-400);font-size:.8rem}
.mb-20{margin-bottom:20px}
.mt-20{margin-top:20px}
.required{color:var(--danger)}

/* ==================== LOGIN PAGE ==================== */
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--gradient-hero);position:relative;overflow:hidden}
.login-bg{position:fixed;inset:0;z-index:0}
.login-bg-pattern{position:absolute;inset:0;overflow:hidden;opacity:.07}
.bg-circle{position:absolute;border-radius:50%;border:2px solid var(--white)}
.bg-circle-1{width:600px;height:600px;top:-200px;right:-100px;animation:loginFloat 20s ease-in-out infinite}
.bg-circle-2{width:400px;height:400px;bottom:-100px;left:-150px;animation:loginFloat 15s ease-in-out infinite reverse}
.bg-circle-3{width:200px;height:200px;top:40%;left:30%;animation:loginFloat 12s ease-in-out infinite}
@keyframes loginFloat{0%,100%{transform:translateY(0) rotate(0)}33%{transform:translateY(-20px) rotate(2deg)}66%{transform:translateY(15px) rotate(-1deg)}}
.login-particles{position:absolute;inset:0;overflow:hidden}
.l-particle{position:absolute;width:4px;height:4px;background:var(--accent);border-radius:50%;opacity:0;animation:lpFloat 8s ease-in-out infinite}
.l-particle:nth-child(1){left:10%;animation-delay:0s}.l-particle:nth-child(2){left:25%;animation-delay:1.2s}
.l-particle:nth-child(3){left:45%;animation-delay:2.4s}.l-particle:nth-child(4){left:65%;animation-delay:.6s}
.l-particle:nth-child(5){left:80%;animation-delay:3s}.l-particle:nth-child(6){left:92%;animation-delay:1.8s}
@keyframes lpFloat{0%{transform:translateY(100vh) scale(0);opacity:0}10%{opacity:.6}90%{opacity:.6}100%{transform:translateY(-10vh) scale(1);opacity:0}}

.login-container{position:relative;z-index:1;width:100%;max-width:440px;padding:20px}
.login-card{background:rgba(255,255,255,.08);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-lg);padding:40px 36px;animation:cardIn .6s ease-out}
@keyframes cardIn{from{opacity:0;transform:translateY(30px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}
.login-card-header{text-align:center;margin-bottom:32px}
.login-logo-icon{width:72px;height:72px;margin:0 auto 16px;background:rgba(0,229,255,.15);border:2px solid rgba(0,229,255,.3);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;color:var(--accent);animation:logoPulse 3s ease-in-out infinite}
@keyframes logoPulse{0%,100%{box-shadow:0 0 0 0 rgba(0,229,255,.3)}50%{box-shadow:0 0 0 12px rgba(0,229,255,0)}}
.login-title{font-family:var(--font-heading);font-size:1.75rem;color:var(--white);font-weight:800}
.login-subtitle{font-size:.9rem;color:rgba(255,255,255,.6);margin-top:4px}

.login-alert{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:var(--radius-sm);margin-bottom:20px;font-size:.85rem;animation:shakeIn .4s ease}
.login-alert-error{background:rgba(239,68,68,.15);border:1px solid rgba(239,68,68,.3);color:#fca5a5}
@keyframes shakeIn{0%,100%{transform:translateX(0)}20%{transform:translateX(-6px)}40%{transform:translateX(6px)}60%{transform:translateX(-4px)}80%{transform:translateX(4px)}}

.login-form{display:flex;flex-direction:column;gap:20px}
.form-label{display:flex;align-items:center;gap:8px;font-size:.8rem;font-weight:600;color:rgba(255,255,255,.7);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}
.form-input,.form-select,.form-textarea{width:100%;padding:14px 16px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-sm);color:var(--white);font-family:var(--font-primary);font-size:.95rem;transition:all var(--transition-fast);outline:0}
.form-input::placeholder,.form-textarea::placeholder{color:rgba(255,255,255,.35)}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(0,229,255,.15);background:rgba(255,255,255,.1)}
.form-textarea{resize:vertical;min-height:80px}
.password-wrapper{position:relative}
.password-toggle{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:0;border:0;color:rgba(255,255,255,.4);cursor:pointer;font-size:1rem;padding:4px}
.password-toggle:hover{color:var(--accent)}

.login-btn{width:100%;padding:16px;background:var(--gradient-primary);color:var(--white);border:0;border-radius:var(--radius-full);font-family:var(--font-primary);font-size:1rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:all var(--transition-base);box-shadow:var(--shadow-cyan)}
.login-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 35px rgba(0,188,212,.4)}
.login-btn:disabled{opacity:.7;cursor:not-allowed}
.login-footer{text-align:center;margin-top:24px}
.back-link{color:rgba(255,255,255,.5);font-size:.85rem;display:inline-flex;align-items:center;gap:6px;transition:color var(--transition-fast)}
.back-link:hover{color:var(--white)}

/* ==================== APP LAYOUT ==================== */
.syllabus-app{background:var(--gray-50)}

/* Top Bar */
.syl-topbar{position:fixed;top:0;left:0;right:0;height:var(--topbar-height);background:var(--white);border-bottom:1px solid var(--gray-200);display:flex;align-items:center;justify-content:space-between;padding:0 24px;z-index:100;box-shadow:var(--shadow-sm)}
.topbar-left{display:flex;align-items:center;gap:16px}
.sidebar-toggle{background:0;border:0;font-size:1.2rem;color:var(--gray-600);cursor:pointer;padding:8px;border-radius:var(--radius-sm);transition:all var(--transition-fast)}
.sidebar-toggle:hover{background:var(--cyan-50);color:var(--primary)}
.topbar-brand{display:flex;align-items:center;gap:10px}
.brand-icon{width:38px;height:38px;background:var(--gradient-primary);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--white);font-size:1.1rem}
.brand-name{font-family:var(--font-heading);font-size:1.1rem;font-weight:800;color:var(--secondary);line-height:1.1}
.brand-sub{font-size:.65rem;color:var(--primary-dark);font-weight:500;letter-spacing:.3px}
.brand-text{display:flex;flex-direction:column}
.topbar-right{display:flex;align-items:center;gap:12px}
.topbar-icon-btn{position:relative;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;color:var(--gray-500);transition:all var(--transition-fast);font-size:1.1rem}
.topbar-icon-btn:hover{background:var(--cyan-50);color:var(--primary)}
.notif-badge{position:absolute;top:2px;right:2px;min-width:18px;height:18px;background:var(--danger);color:var(--white);font-size:.65rem;font-weight:700;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;padding:0 4px;border:2px solid var(--white);animation:badgeBounce .5s ease}
@keyframes badgeBounce{0%{transform:scale(0)}50%{transform:scale(1.3)}100%{transform:scale(1)}}
.topbar-user{display:flex;align-items:center;gap:10px;padding:6px 12px;border-radius:var(--radius-full);cursor:pointer;transition:background var(--transition-fast);position:relative}
.topbar-user:hover{background:var(--gray-100)}
.user-avatar{width:36px;height:36px;border-radius:50%;background:var(--gradient-primary);color:var(--white);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;flex-shrink:0}
.user-info{display:flex;flex-direction:column}
.user-name{font-size:.85rem;font-weight:600;color:var(--gray-800)}
.user-role{font-size:.7rem;color:var(--gray-400);text-transform:capitalize}
.user-dropdown{position:absolute;top:100%;right:0;background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);padding:6px;min-width:160px;opacity:0;visibility:hidden;transform:translateY(8px);transition:all var(--transition-fast);z-index:101}
.topbar-user:hover .user-dropdown{opacity:1;visibility:visible;transform:translateY(4px)}
.user-dropdown a{display:flex;align-items:center;gap:8px;padding:10px 14px;font-size:.85rem;color:var(--gray-600);border-radius:6px;transition:all var(--transition-fast)}
.user-dropdown a:hover{background:var(--cyan-50);color:var(--primary)}

/* Sidebar */
.syl-sidebar{position:fixed;top:var(--topbar-height);left:0;bottom:0;width:var(--sidebar-width);background:var(--white);border-right:1px solid var(--gray-200);overflow-y:auto;z-index:90;transition:transform var(--transition-base)}
.syl-sidebar.collapsed{transform:translateX(-100%)}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:89}
.sidebar-menu{padding:20px 12px}
.menu-section{margin-bottom:24px}
.menu-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--gray-400);padding:0 14px;margin-bottom:8px}
.menu-item{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:var(--radius-sm);color:var(--gray-600);font-size:.88rem;font-weight:500;transition:all var(--transition-fast);margin-bottom:2px}
.menu-item i{width:20px;text-align:center;font-size:.95rem}
.menu-item:hover{background:var(--cyan-50);color:var(--primary)}
.menu-item.active{background:linear-gradient(135deg,rgba(0,188,212,.1),rgba(26,35,126,.06));color:var(--primary);font-weight:600;border-left:3px solid var(--primary)}

/* Main Content */
.syl-main{margin-left:var(--sidebar-width);margin-top:var(--topbar-height);min-height:calc(100vh - var(--topbar-height));transition:margin-left var(--transition-base)}
.syl-sidebar.collapsed ~ .syl-main{margin-left:0}
.page-content{padding:28px 32px;max-width:1400px}

/* ==================== PAGE HEADER ==================== */
.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:28px;flex-wrap:wrap}
.page-header h1{font-size:1.6rem;font-weight:800;color:var(--secondary);display:flex;align-items:center;gap:10px}
.page-header h1 i{color:var(--primary);font-size:1.3rem}
.page-header p{color:var(--gray-500);font-size:.9rem;margin-top:4px}
.page-header-actions{display:flex;gap:8px;flex-wrap:wrap}

.plan-meta-info{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.meta-chip{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;background:var(--cyan-50);color:var(--cyan-800);border-radius:var(--radius-full);font-size:.78rem;font-weight:600;border:1px solid var(--cyan-200)}
.meta-chip i{font-size:.7rem}
.meta-chip-locked{background:rgba(239,68,68,.08);color:var(--danger);border-color:rgba(239,68,68,.2)}
.meta-chip-draft{background:rgba(245,158,11,.08);color:var(--warning);border-color:rgba(245,158,11,.2)}

/* ==================== BUTTONS ==================== */
.btn-action{display:inline-flex;align-items:center;gap:8px;padding:10px 22px;font-family:var(--font-primary);font-size:.88rem;font-weight:600;border:none;border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-base);white-space:nowrap}
.btn-action-primary{background:var(--gradient-primary);color:var(--white);box-shadow:var(--shadow-cyan)}
.btn-action-primary:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(0,188,212,.35)}
.btn-action-secondary{background:var(--blue-900);color:var(--white)}
.btn-action-secondary:hover{background:var(--blue-800);transform:translateY(-1px)}
.btn-action-outline{background:transparent;color:var(--gray-600);border:1.5px solid var(--gray-300)}
.btn-action-outline:hover{border-color:var(--primary);color:var(--primary);background:var(--cyan-50)}
.btn-action-whatsapp{background:#25D366;color:var(--white)}
.btn-action-whatsapp:hover{background:#1ebe5d;transform:translateY(-1px)}
.btn-action-sm{padding:7px 16px;font-size:.8rem}
.btn-action-danger{background:var(--danger);color:var(--white)}

/* ==================== WELCOME BANNER ==================== */
.welcome-banner{background:var(--gradient-primary);border-radius:var(--radius-lg);padding:28px 32px;color:var(--white);display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;position:relative;overflow:hidden}
.welcome-banner::before{content:'';position:absolute;top:-50%;right:-10%;width:300px;height:300px;background:rgba(255,255,255,.05);border-radius:50%}
.welcome-banner h1{font-size:1.4rem;font-weight:700;color:var(--white);font-family:var(--font-primary)}
.welcome-banner p{color:rgba(255,255,255,.75);font-size:.9rem;margin-top:4px}
.welcome-date{display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.12);padding:8px 16px;border-radius:var(--radius-full);font-size:.85rem}
.admin-banner{background:linear-gradient(135deg,var(--blue-950),var(--blue-800))}

/* ==================== APPRECIATION BANNER ==================== */
.appreciation-banner{background:linear-gradient(135deg,#059669,#10b981);border-radius:var(--radius-lg);padding:24px 28px;margin-bottom:24px;position:relative;overflow:hidden}
.appreciation-content{display:flex;align-items:center;gap:16px;position:relative;z-index:1}
.appreciation-icon{width:56px;height:56px;background:rgba(255,255,255,.2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:var(--white);animation:trophyBounce 2s ease-in-out infinite}
@keyframes trophyBounce{0%,100%{transform:scale(1) rotate(0)}25%{transform:scale(1.1) rotate(-5deg)}75%{transform:scale(1.1) rotate(5deg)}}
.appreciation-text h3{color:var(--white);font-size:1.15rem;font-family:var(--font-primary)}
.appreciation-text p{color:rgba(255,255,255,.85);font-size:.9rem}
.appreciation-close{position:absolute;top:12px;right:12px;background:rgba(255,255,255,.15);border:0;color:var(--white);width:28px;height:28px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:2}
.confetti-container{position:absolute;inset:0;pointer-events:none;overflow:hidden}

/* ==================== ALERT BANNERS ==================== */
.alert-banner{display:flex;align-items:center;gap:12px;padding:14px 20px;border-radius:var(--radius-sm);margin-bottom:20px;font-size:.88rem;font-weight:500}
.alert-danger{background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.2);color:var(--danger)}
.alert-warning{background:rgba(245,158,11,.08);border:1px solid rgba(245,158,11,.2);color:#b45309}
.alert-success{background:rgba(16,185,129,.08);border:1px solid rgba(16,185,129,.2);color:#059669}
.alert-info{background:rgba(0,188,212,.08);border:1px solid rgba(0,188,212,.2);color:var(--primary-dark)}
.alert-banner a{color:inherit;font-weight:700;text-decoration:underline}

/* ==================== STAT CARDS ==================== */
.stats-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}
.stats-cards-6{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}
.stat-card{background:var(--white);border-radius:var(--radius-md);padding:22px 20px;display:flex;align-items:center;gap:16px;border:1px solid var(--gray-200);transition:all var(--transition-base)}
.stat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.stat-card-icon{width:48px;height:48px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}
.stat-card-primary .stat-card-icon{background:rgba(0,188,212,.1);color:var(--primary)}
.stat-card-success .stat-card-icon{background:rgba(16,185,129,.1);color:var(--success)}
.stat-card-warning .stat-card-icon{background:rgba(245,158,11,.1);color:var(--warning)}
.stat-card-danger .stat-card-icon{background:rgba(239,68,68,.1);color:var(--danger)}
.stat-card-info .stat-card-icon{background:rgba(0,188,212,.1);color:var(--info)}
.stat-card-accent .stat-card-icon{background:rgba(0,229,255,.1);color:var(--accent)}
.stat-card-number{font-size:1.6rem;font-weight:800;color:var(--secondary);line-height:1}
.stat-card-label{font-size:.78rem;color:var(--gray-500);margin-top:2px}

/* ==================== PROGRESS BAR ==================== */
.progress-overview-card{background:var(--white);border-radius:var(--radius-md);padding:22px 24px;border:1px solid var(--gray-200);margin-bottom:24px}
.progress-overview-card h3{font-size:1rem;margin-bottom:12px;font-family:var(--font-primary)}
.progress-bar-wrapper{display:flex;align-items:center;gap:14px}
.progress-bar-track{flex:1;height:12px;background:var(--gray-200);border-radius:var(--radius-full);overflow:hidden}
.progress-bar-fill{height:100%;background:var(--gradient-primary);border-radius:var(--radius-full);transition:width .8s ease;min-width:2px}
.progress-percent{font-size:1.1rem;font-weight:800;color:var(--primary);min-width:50px}
.progress-detail{font-size:.82rem;color:var(--gray-500);margin-top:6px}

/* ==================== DASHBOARD GRID ==================== */
.dashboard-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:20px;margin-bottom:24px}

/* Dash Card */
.dash-card{background:var(--white);border-radius:var(--radius-md);border:1px solid var(--gray-200);margin-bottom:20px;overflow:hidden}
.dash-card-header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--gray-100)}
.dash-card-header h3{font-size:.95rem;font-weight:700;font-family:var(--font-primary);display:flex;align-items:center;gap:8px;color:var(--secondary)}
.dash-card-header h3 i{color:var(--primary);font-size:.9rem}
.dash-card-body{padding:18px 22px}
.view-all-link{font-size:.8rem;font-weight:600;color:var(--primary);transition:color var(--transition-fast)}
.view-all-link:hover{color:var(--primary-dark)}

/* Badge */
.badge{display:inline-flex;padding:3px 10px;border-radius:var(--radius-full);font-size:.7rem;font-weight:700}
.badge-info{background:var(--cyan-50);color:var(--primary-dark)}

/* Deadline List */
.deadline-list{display:flex;flex-direction:column;gap:10px}
.deadline-item{display:flex;align-items:center;gap:14px;padding:10px 12px;border-radius:var(--radius-sm);background:var(--gray-50);transition:all var(--transition-fast)}
.deadline-item:hover{background:var(--cyan-50)}
.deadline-urgent{border-left:3px solid var(--danger)}
.deadline-warning{border-left:3px solid var(--warning)}
.deadline-normal{border-left:3px solid var(--primary)}
.deadline-date{text-align:center;min-width:44px}
.dl-day{display:block;font-size:1.2rem;font-weight:800;color:var(--secondary);line-height:1}
.dl-month{font-size:.65rem;color:var(--gray-500);text-transform:uppercase;font-weight:600}
.deadline-info{flex:1;min-width:0}
.dl-topic{display:block;font-size:.85rem;font-weight:600;color:var(--gray-800);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dl-meta{font-size:.75rem;color:var(--gray-400)}
.dl-badge{padding:3px 10px;border-radius:var(--radius-full);font-size:.7rem;font-weight:700;white-space:nowrap}
.dl-badge-danger{background:rgba(239,68,68,.1);color:var(--danger)}
.dl-badge-warning{background:rgba(245,158,11,.1);color:#b45309}
.dl-badge-info{background:var(--cyan-50);color:var(--primary-dark)}

/* Quick Actions */
.quick-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.quick-action-btn{display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px 12px;background:var(--gray-50);border-radius:var(--radius-sm);font-size:.8rem;font-weight:600;color:var(--gray-600);transition:all var(--transition-base);border:1px solid transparent}
.quick-action-btn i{font-size:1.3rem;color:var(--primary)}
.quick-action-btn:hover{background:var(--cyan-50);border-color:var(--cyan-200);transform:translateY(-2px);color:var(--primary-dark)}

/* Mini Plans */
.mini-plans-list{display:flex;flex-direction:column;gap:6px;margin-top:12px}
.mini-plan-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-radius:var(--radius-sm);background:var(--gray-50);transition:all var(--transition-fast)}
.mini-plan-item:hover{background:var(--cyan-50)}
.mp-class{font-weight:600;font-size:.85rem;color:var(--gray-800)}
.mp-subject{font-size:.75rem;color:var(--gray-500)}
.mp-status{font-size:.7rem;font-weight:700;padding:3px 10px;border-radius:var(--radius-full);display:inline-flex;align-items:center;gap:4px}
.mp-locked{background:rgba(239,68,68,.08);color:var(--danger)}.mp-draft{background:rgba(245,158,11,.08);color:#b45309}

/* Empty State */
.empty-state,.empty-state-large{text-align:center;padding:40px 20px;color:var(--gray-400)}
.empty-state i,.empty-state-large .empty-icon i{font-size:2.5rem;color:var(--gray-300);margin-bottom:12px}
.empty-state-large .empty-icon{width:80px;height:80px;margin:0 auto 16px;background:var(--gray-100);border-radius:50%;display:flex;align-items:center;justify-content:center}
.empty-state-large h3{font-size:1.15rem;color:var(--gray-600);margin-bottom:8px;font-family:var(--font-primary)}
.empty-state-large p{font-size:.9rem;margin-bottom:20px}

/* ==================== NOTIFICATIONS ==================== */
.notif-list,.notif-page-list{display:flex;flex-direction:column;gap:6px}
.notif-item{display:flex;gap:14px;padding:12px 14px;border-radius:var(--radius-sm);transition:background var(--transition-fast)}
.notif-item:hover{background:var(--gray-50)}
.notif-unread{background:rgba(0,188,212,.04);border-left:3px solid var(--primary)}
.notif-icon{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.85rem}
.notif-icon-info{background:rgba(0,188,212,.1);color:var(--primary)}
.notif-icon-warning{background:rgba(245,158,11,.1);color:var(--warning)}
.notif-icon-alert{background:rgba(239,68,68,.1);color:var(--danger)}
.notif-icon-appreciation{background:rgba(16,185,129,.1);color:var(--success)}
.notif-content{flex:1}
.notif-title{display:block;font-size:.85rem;font-weight:600;color:var(--gray-800)}
.notif-msg{display:block;font-size:.8rem;color:var(--gray-500);margin-top:2px}
.notif-time{display:block;font-size:.7rem;color:var(--gray-400);margin-top:4px}

/* ==================== FORM CARD ==================== */
.form-card{background:var(--white);border-radius:var(--radius-md);padding:28px;border:1px solid var(--gray-200)}
.syllabus-app .form-label{color:var(--gray-600);margin-bottom:6px;font-size:.8rem}
.syllabus-app .form-input,.syllabus-app .form-select,.syllabus-app .form-textarea{background:var(--white);color:var(--gray-800);border:1.5px solid var(--gray-200)}
.syllabus-app .form-input::placeholder,.syllabus-app .form-textarea::placeholder{color:var(--gray-400)}
.syllabus-app .form-input:focus,.syllabus-app .form-select:focus,.syllabus-app .form-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(0,188,212,.1)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:16px}
.form-row-4{grid-template-columns:repeat(4,1fr)}
.form-group{display:flex;flex-direction:column}
.filter-group select{min-width:200px}

/* ==================== PLAN BUILDER ==================== */
.plan-builder{margin-top:8px}
.term-block{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-md);margin-bottom:16px;overflow:hidden}
.term-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:linear-gradient(135deg,rgba(0,188,212,.06),rgba(26,35,126,.04));border-bottom:1px solid var(--gray-200)}
.term-title-wrapper{display:flex;align-items:center;gap:10px}
.term-title-wrapper i{color:var(--primary);font-size:1.1rem}
.term-title-input{background:transparent;border:none;border-bottom:2px solid var(--primary);font-size:1.05rem;font-weight:700;color:var(--secondary);padding:4px 8px;width:160px;outline:0;font-family:var(--font-primary)}
.term-actions{display:flex;gap:8px}
.btn-icon{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border:1px solid var(--gray-300);border-radius:var(--radius-full);background:var(--white);color:var(--gray-600);font-size:.78rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-primary)}
.btn-icon:hover{border-color:var(--primary);color:var(--primary);background:var(--cyan-50)}
.btn-danger-icon{color:var(--danger);border-color:rgba(239,68,68,.3)}
.btn-danger-icon:hover{background:rgba(239,68,68,.06);color:var(--danger);border-color:var(--danger)}
.months-container{padding:16px 20px}
.month-block{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius-sm);margin-bottom:12px;overflow:hidden}
.month-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:rgba(0,188,212,.04);border-bottom:1px solid var(--gray-200)}
.month-select{padding:6px 12px;border:1px solid var(--gray-300);border-radius:6px;font-size:.85rem;font-weight:600;color:var(--gray-700);background:var(--white);outline:0;cursor:pointer}
.month-actions{display:flex;gap:6px}
.weeks-container{padding:10px 14px}
.week-block{border:1px dashed var(--gray-300);border-radius:6px;padding:10px 12px;margin-bottom:8px;background:var(--white)}
.week-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.week-label{font-size:.82rem;font-weight:700;color:var(--primary-dark)}
.week-actions{display:flex;gap:6px}
.topics-container{display:flex;flex-direction:column;gap:6px}
.topic-row{display:flex;gap:8px;align-items:center}
.topic-input{flex:1;padding:8px 12px;border:1px solid var(--gray-200);border-radius:6px;font-size:.85rem;outline:0;font-family:var(--font-primary);color:var(--gray-700)}
.topic-input:focus{border-color:var(--primary)}
.topic-date{padding:8px 10px;border:1px solid var(--gray-200);border-radius:6px;font-size:.82rem;outline:0;color:var(--gray-600);font-family:var(--font-primary)}
.topic-date:focus{border-color:var(--primary)}
.btn-remove-topic{background:0;border:0;color:var(--gray-400);cursor:pointer;padding:4px;font-size:.9rem}
.btn-remove-topic:hover{color:var(--danger)}
.btn-add-term{width:100%;padding:14px;border:2px dashed var(--gray-300);border-radius:var(--radius-md);background:transparent;color:var(--gray-500);font-size:.9rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:20px;font-family:var(--font-primary)}
.btn-add-term:hover{border-color:var(--primary);color:var(--primary);background:rgba(0,188,212,.03)}
.plan-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:20px}

/* ==================== PLANS GRID ==================== */
.plans-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}
.plan-card{background:var(--white);border-radius:var(--radius-md);border:1px solid var(--gray-200);overflow:hidden;transition:all var(--transition-base)}
.plan-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.plan-card-top{display:flex;justify-content:space-between;align-items:center;padding:16px 18px;background:linear-gradient(135deg,rgba(0,188,212,.06),rgba(26,35,126,.04));border-bottom:1px solid var(--gray-100)}
.plan-card-subject{font-size:1.05rem;font-weight:700;color:var(--secondary)}
.plan-card-status{font-size:.7rem;font-weight:700;padding:4px 10px;border-radius:var(--radius-full);display:inline-flex;align-items:center;gap:4px}
.pcs-locked{background:rgba(239,68,68,.08);color:var(--danger)}.pcs-draft{background:rgba(245,158,11,.08);color:#b45309}
.pcs-pending{background:rgba(245,158,11,.12);color:#b45309;border:1px solid rgba(245,158,11,.3);animation:pendingPulse 2s ease-in-out infinite}
.pcs-approved{background:rgba(16,185,129,.1);color:#059669;border:1px solid rgba(16,185,129,.2)}
.pcs-rejected{background:rgba(239,68,68,.1);color:var(--danger);border:1px solid rgba(239,68,68,.2)}
@keyframes pendingPulse{0%,100%{opacity:1}50%{opacity:.6}}
.row-pending-highlight{background:rgba(245,158,11,.04)!important;border-left:3px solid var(--warning)}

/* Approval Modal */
.approval-modal-overlay{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.5);backdrop-filter:blur(4px)}
.approval-modal{background:var(--white);border-radius:var(--radius-lg);width:100%;max-width:520px;box-shadow:var(--shadow-xl);animation:popIn .3s ease;overflow:hidden}
.approval-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--gray-200);background:var(--gray-50)}
.approval-modal-header h3{font-size:1.1rem;font-family:var(--font-primary);display:flex;align-items:center;gap:10px}
.approval-modal-close{background:0;border:0;font-size:1.4rem;color:var(--gray-400);cursor:pointer;padding:4px 8px;border-radius:6px;transition:all var(--transition-fast)}
.approval-modal-close:hover{background:var(--gray-200);color:var(--gray-600)}
.approval-modal-body{padding:24px}
.approval-modal-info{background:var(--gray-50);border-radius:var(--radius-sm);padding:14px 18px;margin-bottom:16px;font-size:.88rem}
.approval-modal-info p{margin-bottom:4px;color:var(--gray-600)}
.approval-modal-info strong{color:var(--gray-800)}
.approval-modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid var(--gray-200);background:var(--gray-50)}

.plan-card-body{padding:14px 18px}
.plan-card-class,.plan-card-year{font-size:.82rem;color:var(--gray-500);margin-bottom:4px;display:flex;align-items:center;gap:6px}
.plan-card-class i,.plan-card-year i{color:var(--primary);font-size:.75rem}
.plan-card-progress{margin-top:10px}
.pcp-bar{height:6px;background:var(--gray-200);border-radius:var(--radius-full);overflow:hidden;margin-bottom:4px}
.pcp-fill{height:100%;background:var(--gradient-primary);border-radius:var(--radius-full);transition:width .5s ease}
.pcp-text{font-size:.72rem;color:var(--gray-500);font-weight:600}
.plan-card-footer{display:flex;border-top:1px solid var(--gray-100);padding:0}
.pcf-btn{flex:1;padding:10px;text-align:center;font-size:.8rem;font-weight:600;color:var(--gray-500);transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;gap:6px}
.pcf-btn:hover{background:var(--cyan-50);color:var(--primary)}
.pcf-btn+.pcf-btn{border-left:1px solid var(--gray-100)}
.pcf-btn-primary{color:var(--primary)}
.plan-select-card{display:flex;align-items:center;gap:14px;padding:16px 18px;background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-sm);transition:all var(--transition-fast)}
.plan-select-card:hover{border-color:var(--primary);box-shadow:var(--shadow-sm)}
.psc-icon{width:44px;height:44px;background:var(--cyan-50);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--primary);font-size:1.1rem;flex-shrink:0}
.psc-info{flex:1}
.psc-subject{display:block;font-weight:600;color:var(--gray-800);font-size:.9rem}
.psc-class{font-size:.78rem;color:var(--gray-500)}
.psc-arrow{color:var(--gray-300);font-size:.8rem}

/* ==================== TABLES ==================== */
.plan-table-wrapper{overflow-x:auto;border-radius:var(--radius-sm)}
.plan-table,.progress-table,.report-table{width:100%;border-collapse:collapse;font-size:.85rem}
.plan-table th,.progress-table th{background:linear-gradient(135deg,var(--blue-900),var(--blue-800));color:var(--white);padding:12px 14px;text-align:left;font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}
.plan-table td,.progress-table td{padding:11px 14px;border-bottom:1px solid var(--gray-100);color:var(--gray-700)}
.plan-table tbody tr:hover,.progress-table tbody tr:hover{background:rgba(0,188,212,.03)}
.plan-cell-month{font-weight:700;color:var(--primary-dark);background:rgba(0,188,212,.04);border-right:2px solid var(--cyan-200);vertical-align:top}
.plan-cell-week{font-weight:600;color:var(--gray-600);background:rgba(0,188,212,.02);border-right:1px solid var(--gray-200);vertical-align:top}
.plan-cell-topic{font-weight:500}
.plan-cell-date{font-size:.8rem;color:var(--gray-500);white-space:nowrap}

/* Status Badges */
.status-badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:var(--radius-full);font-size:.72rem;font-weight:700;white-space:nowrap}
.status-completed{background:rgba(16,185,129,.1);color:#059669}
.status-not_completed{background:rgba(239,68,68,.1);color:var(--danger)}
.status-pending{background:rgba(245,158,11,.1);color:#b45309}
.status-row-completed{background:rgba(16,185,129,.03)!important}
.status-row-not_completed{background:rgba(239,68,68,.03)!important}

/* Status Select */
.status-select{padding:6px 10px;border-radius:6px;font-size:.8rem;font-weight:600;border:1.5px solid var(--gray-200);outline:0;cursor:pointer;font-family:var(--font-primary)}
.status-select-pending{border-color:var(--warning);color:#b45309}
.status-select-completed{border-color:var(--success);color:#059669}
.status-select-not_completed{border-color:var(--danger);color:var(--danger)}

/* Progress Table Specifics */
.progress-row.row-overdue{background:rgba(239,68,68,.04)!important}
.overdue-tag{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:var(--radius-full);background:rgba(239,68,68,.1);color:var(--danger);font-size:.68rem;font-weight:700;margin-left:8px}
.reason-row td{padding:0!important;background:var(--gray-50)}
.reason-fields{padding:14px 20px;display:grid;grid-template-columns:1fr 1fr;gap:14px}
.reason-field label{font-size:.78rem;font-weight:600;color:var(--gray-600);margin-bottom:6px;display:flex;align-items:center;gap:6px}
.reason-field textarea{width:100%;min-height:70px;padding:10px;border:1.5px solid var(--gray-200);border-radius:6px;font-family:var(--font-primary);font-size:.85rem;resize:vertical;outline:0;color:var(--gray-700)}
.reason-field textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(0,188,212,.1)}
.reason-error{animation:shakeIn .4s ease}
.reason-error .reason-field textarea{border-color:var(--danger)!important}
.progress-actions{display:flex;gap:12px;margin-top:20px;justify-content:flex-end}
.topic-cell{position:relative}

/* Mini Progress Bars (admin) */
.mini-progress{width:80px;height:6px;background:var(--gray-200);border-radius:var(--radius-full);overflow:hidden;display:inline-block;vertical-align:middle}
.mini-progress-fill{height:100%;background:var(--gradient-primary);border-radius:var(--radius-full)}
.mini-pct{font-size:.75rem;font-weight:700;color:var(--primary);margin-left:6px}

/* Table Actions */
.table-actions{display:flex;gap:4px}
.table-action-btn{width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--gray-500);transition:all var(--transition-fast);font-size:.85rem}
.table-action-btn:hover{background:var(--cyan-50);color:var(--primary)}
.table-action-warning:hover{background:rgba(245,158,11,.1);color:var(--warning)}
.table-action-danger:hover{background:rgba(239,68,68,.1);color:var(--danger)}
.table-action-success:hover{background:rgba(16,185,129,.1);color:var(--success)}
.table-action-info:hover{background:rgba(0,188,212,.1);color:var(--info)}
.row-inactive{opacity:.5}

/* ==================== PLAN VIEW ==================== */
.plan-view-term{margin-bottom:20px}
.pv-term-header{padding:12px 18px;background:var(--gradient-primary);color:var(--white);border-radius:var(--radius-sm) var(--radius-sm) 0 0;font-weight:700;font-size:.9rem;display:flex;align-items:center;gap:8px}
.plan-stats-row{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap}
.plan-stat-mini{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-sm);padding:12px 18px;text-align:center;flex:1;min-width:90px}
.psm-number{display:block;font-size:1.4rem;font-weight:800;color:var(--secondary)}
.psm-label{font-size:.7rem;color:var(--gray-500);text-transform:uppercase;font-weight:600}
.plan-stat-success .psm-number{color:var(--success)}
.plan-stat-warning .psm-number{color:var(--warning)}
.plan-stat-danger .psm-number{color:var(--danger)}
.plan-stat-info .psm-number{color:var(--primary)}

/* Report Stats */
.report-stats-row{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap}
.report-stat{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-sm);padding:14px 20px;text-align:center;flex:1;min-width:80px}
.rs-num{display:block;font-size:1.5rem;font-weight:800;color:var(--secondary)}
.rs-label{font-size:.68rem;color:var(--gray-500);text-transform:uppercase;font-weight:600}
.report-stat-green .rs-num{color:var(--success)}
.report-stat-blue .rs-num{color:var(--info)}
.report-stat-orange .rs-num{color:#ea580c}
.report-stat-yellow .rs-num{color:var(--warning)}
.report-stat-red .rs-num{color:var(--danger)}
.reason-cell{font-size:.8rem;color:var(--gray-500);max-width:180px;word-wrap:break-word}

/* Activity */
.activity-list{display:flex;flex-direction:column;gap:8px}
.activity-item{display:flex;gap:12px;padding:10px 12px;border-radius:var(--radius-sm);transition:background var(--transition-fast)}
.activity-item:hover{background:var(--gray-50)}
.activity-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.75rem}
.activity-icon-completed{background:rgba(16,185,129,.1);color:var(--success)}
.activity-icon-not_completed{background:rgba(239,68,68,.1);color:var(--danger)}
.activity-content{font-size:.84rem;color:var(--gray-600);line-height:1.5}
.activity-content strong{color:var(--gray-800)}
.activity-meta{display:block;font-size:.72rem;color:var(--gray-400);margin-top:2px}

/* Teacher Form */
.teacher-form .form-row{margin-bottom:16px}

/* ==================== PRINT HEADER ==================== */
.print-header{display:none}

/* ==================== TOAST ==================== */
.toast-container{position:fixed;top:80px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:8px}
.toast{padding:14px 20px;border-radius:var(--radius-sm);background:var(--white);border:1px solid var(--gray-200);box-shadow:var(--shadow-lg);font-size:.88rem;font-weight:500;display:flex;align-items:center;gap:10px;animation:toastIn .3s ease;min-width:280px;max-width:400px}
.toast-success{border-left:4px solid var(--success);color:#059669}
.toast-error{border-left:4px solid var(--danger);color:var(--danger)}
.toast-info{border-left:4px solid var(--info);color:var(--primary-dark)}
@keyframes toastIn{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:translateX(0)}}

/* Appreciation Popup */
.appreciation-popup{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.5)}
.appreciation-popup-card{background:var(--white);border-radius:var(--radius-lg);padding:40px;text-align:center;max-width:400px;animation:popIn .4s ease}
.appreciation-popup-card h2{font-size:1.5rem;color:var(--success);margin:12px 0 8px;font-family:var(--font-primary)}
.appreciation-popup-card p{color:var(--gray-500);margin-bottom:20px}
.appreciation-popup-card .trophy-big{font-size:3rem;animation:trophyBounce 2s ease-in-out infinite}
@keyframes popIn{from{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}

/* ==================== RESPONSIVE ==================== */
@media(max-width:1024px){
    .dashboard-grid{grid-template-columns:1fr}
    .form-row-4{grid-template-columns:1fr 1fr}
    .stats-cards-6{grid-template-columns:repeat(3,1fr)}
    .reason-fields{grid-template-columns:1fr}
}
@media(max-width:768px){
    .syl-sidebar{transform:translateX(-100%)}
    .syl-sidebar.open{transform:translateX(0)}
    .sidebar-overlay.active{display:block}
    .syl-main{margin-left:0!important}
    .page-content{padding:20px 16px}
    .form-row,.form-row-4{grid-template-columns:1fr}
    .stats-cards{grid-template-columns:1fr 1fr}
    .stats-cards-6{grid-template-columns:1fr 1fr}
    .page-header{flex-direction:column}
    .welcome-banner{flex-direction:column;gap:16px;text-align:center}
    .plan-stats-row,.report-stats-row{flex-wrap:wrap}
    .plan-stat-mini,.report-stat{min-width:calc(33% - 8px)}
    .plans-grid{grid-template-columns:1fr}
    .quick-actions{grid-template-columns:1fr}
    .topbar-user .user-info{display:none}
}
@media(max-width:480px){
    .stats-cards{grid-template-columns:1fr}
    .stats-cards-6{grid-template-columns:1fr}
    .plan-actions{flex-direction:column}
    .topic-row{flex-wrap:wrap}
    .topic-input{min-width:100%}
}
