/* === NEW COMPONENT STYLES === */

/* Welcome Banner */
.welcome-banner{background:linear-gradient(135deg,#2563eb,#7c3aed);border-radius:16px;padding:24px 28px;margin-bottom:20px;display:flex;align-items:center;justify-content:space-between;color:#fff;position:relative;overflow:hidden}
.welcome-banner::after{content:'';position:absolute;top:-50%;right:-20%;width:300px;height:300px;background:rgba(255,255,255,.06);border-radius:50%}
.welcome-banner.wb-teacher{background:linear-gradient(135deg,#059669,#0d9488)}
.welcome-banner.wb-admin{background:linear-gradient(135deg,#dc2626,#9333ea)}
.welcome-banner.wb-mgmt{background:linear-gradient(135deg,#0f172a,#1e3a5f)}
.wb-text h2{font-size:1.15rem;font-weight:800;margin-bottom:4px}
.wb-text p{font-size:.78rem;opacity:.85}
.wb-streak{text-align:center;z-index:1}
.wb-streak .streak-num{display:block;font-size:1.8rem;font-weight:900}
.wb-streak .streak-label{font-size:.68rem;opacity:.8}

/* Service Grid */
.service-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px;margin-bottom:20px}
.service-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:18px 12px;text-align:center;cursor:pointer;transition:all .25s}
.service-card:hover{transform:translateY(-3px);box-shadow:0 8px 25px rgba(0,0,0,.08)}
.service-card i{font-size:1.4rem;margin-bottom:8px;display:block}
.service-card span{font-size:.72rem;font-weight:600;color:var(--gray-700)}
.sc-blue i{color:#2563eb}.sc-green i{color:#059669}.sc-orange i{color:#f59e0b}
.sc-red i{color:#ef4444}.sc-purple i{color:#8b5cf6}.sc-cyan i{color:#06b6d4}
.sc-pink i{color:#ec4899}.sc-teal i{color:#14b8a6}

/* Colored Stats */
.dash-stat.s-blue{border-left:3px solid #2563eb}
.dash-stat.s-green{border-left:3px solid #059669}
.dash-stat.s-orange{border-left:3px solid #f59e0b}
.dash-stat.s-purple{border-left:3px solid #8b5cf6}
.dash-stat.s-red{border-left:3px solid #ef4444}
.dash-stat.s-cyan{border-left:3px solid #06b6d4}
.dash-stat .stat-icon{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1rem;margin-bottom:10px}
.s-blue .stat-icon{background:#dbeafe;color:#2563eb}
.s-green .stat-icon{background:#d1fae5;color:#059669}
.s-orange .stat-icon{background:#fef3c7;color:#f59e0b}
.s-purple .stat-icon{background:#ede9fe;color:#8b5cf6}
.s-red .stat-icon{background:#fee2e2;color:#ef4444}
.s-cyan .stat-icon{background:#cffafe;color:#06b6d4}

/* Quick Icon Colors */
.qi-blue{background:#dbeafe}.qi-green{background:#d1fae5}.qi-yellow{background:#fef3c7}
.qi-red{background:#fee2e2}.qi-purple{background:#ede9fe}.qi-orange{background:#ffedd5}

/* Status Badges */
.status-live{background:#059669;color:#fff;padding:2px 8px;border-radius:100px;font-size:.62rem;font-weight:700;animation:pulse 2s infinite}
.status-done{color:#059669;font-weight:700;font-size:.7rem}
.badge-warn{background:#fef3c7;color:#92400e;padding:2px 8px;border-radius:100px;font-size:.65rem;font-weight:700}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.6}}

/* Attendance Bars (Student) */
.att-row{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.att-sub{font-size:.8rem;font-weight:600;min-width:160px}
.att-bar{flex:1;height:24px;background:var(--gray-100);border-radius:6px;overflow:hidden}
.att-fill{height:100%;background:linear-gradient(90deg,#2563eb,#7c3aed);border-radius:6px;display:flex;align-items:center;justify-content:flex-end;padding-right:8px;font-size:.65rem;font-weight:700;color:#fff;transition:width .8s ease}
.att-fill.af-warn{background:linear-gradient(90deg,#f59e0b,#ef4444)}

/* Grade Table */
.grade-table{width:100%;border-collapse:collapse;font-size:.82rem}
.grade-table th{text-align:left;padding:10px 12px;background:var(--gray-50);font-weight:700;font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-l);border-bottom:2px solid var(--border)}
.grade-table td{padding:10px 12px;border-bottom:1px solid var(--border)}
.grade-table tr:hover{background:var(--blue-xl)}
.grade-badge{padding:3px 10px;border-radius:100px;font-size:.68rem;font-weight:700}
.gb-a{background:#d1fae5;color:#059669}.gb-b{background:#dbeafe;color:#2563eb}.gb-na{background:var(--gray-100);color:var(--gray-500)}
.grade-input{width:60px;padding:4px 8px;border:1px solid var(--border);border-radius:4px;font-size:.8rem;text-align:center}
.text-red{color:#ef4444;font-weight:600}

/* Class Cards (Teacher) */
.class-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}
.class-card{background:var(--card);border:1px solid var(--border);border-radius:14px;overflow:hidden;transition:all .25s}
.class-card:hover{box-shadow:0 8px 25px rgba(0,0,0,.08);transform:translateY(-2px)}
.cc-header{padding:16px 18px 12px}
.cc-header h4{font-size:.92rem;font-weight:700}
.cc-sem{font-size:.7rem;color:var(--text-l)}
.cc-body{padding:0 18px 12px}
.cc-stat{font-size:.78rem;color:var(--gray-700);padding:3px 0;display:flex;align-items:center;gap:6px}
.cc-stat i{width:16px;color:var(--text-l)}
.cc-actions{padding:12px 18px;border-top:1px solid var(--border);display:flex;gap:8px}
.cc-blue .cc-header{border-top:3px solid #2563eb}
.cc-green .cc-header{border-top:3px solid #059669}
.cc-purple .cc-header{border-top:3px solid #8b5cf6}
.cc-orange .cc-header{border-top:3px solid #f59e0b}
.cc-red .cc-header{border-top:3px solid #ef4444}
.btn-sm{padding:5px 12px;border:1px solid var(--border);border-radius:6px;background:var(--card);font-size:.72rem;font-weight:600;cursor:pointer;transition:all .2s;font-family:var(--font)}
.btn-sm:hover{background:var(--blue-xl);color:var(--blue);border-color:var(--blue)}
.btn-danger{color:#ef4444;border-color:#fee2e2}
.btn-danger:hover{background:#fee2e2;color:#ef4444;border-color:#ef4444}
.btn-success{color:#059669;border-color:#d1fae5}
.btn-success:hover{background:#d1fae5;color:#059669;border-color:#059669}

/* Teacher Attendance */
.att-controls{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap}
.att-select{padding:8px 12px;border:1px solid var(--border);border-radius:8px;font-size:.82rem;font-family:var(--font);outline:none;background:var(--card);min-width:200px}
.att-date{padding:8px 12px;border:1px solid var(--border);border-radius:8px;font-size:.82rem;font-family:var(--font)}
.student-att-list{margin-top:8px}
.sa-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border)}
.sa-info{display:flex;align-items:center;gap:10px}
.sa-avatar{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,var(--blue),var(--purple));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.65rem}
.sa-info span{font-size:.85rem;font-weight:600}
.sa-btns{display:flex;gap:4px}
.sa-btn{width:32px;height:32px;border:1px solid var(--border);border-radius:6px;background:var(--card);cursor:pointer;font-weight:700;font-size:.72rem;transition:all .2s}
.sa-btn.sa-p.active{background:#d1fae5;color:#059669;border-color:#059669}
.sa-btn.sa-a.active{background:#fee2e2;color:#ef4444;border-color:#ef4444}
.sa-btn.sa-l.active{background:#fef3c7;color:#f59e0b;border-color:#f59e0b}
.sa-btn:hover{background:var(--gray-100)}

/* Schedule Table */
.schedule-table{width:100%;border-collapse:collapse;font-size:.78rem}
.schedule-table th,.schedule-table td{padding:12px;border:1px solid var(--border);text-align:center;min-width:80px}
.schedule-table th{background:var(--gray-50);font-weight:700;font-size:.7rem;text-transform:uppercase}
.sched-fill{border-radius:6px;font-weight:600;font-size:.72rem}
.sf-blue{background:#dbeafe;color:#1d4ed8}
.sf-green{background:#d1fae5;color:#059669}
.sf-purple{background:#ede9fe;color:#7c3aed}
.sf-orange{background:#fef3c7;color:#92400e}
.schedule-table small{display:block;font-weight:400;opacity:.8;font-size:.62rem}

/* Student Cards (Teacher view) */
.student-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;margin-top:12px}
.student-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:18px;text-align:center;transition:all .25s}
.student-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.sc-avatar{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,var(--blue),var(--purple));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.85rem;margin:0 auto 10px}
.student-card h4{font-size:.88rem;font-weight:700}
.student-card p{font-size:.72rem;color:var(--text-l);margin-bottom:8px}
.sc-stats{display:flex;justify-content:center;gap:12px}
.sc-stats span{font-size:.68rem;font-weight:600;color:var(--gray-700);display:flex;align-items:center;gap:3px}
.sc-stats i{font-size:.6rem;color:var(--text-l)}

/* Admin Quick Stats */
.admin-quick-stat{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border);font-size:.82rem}
.admin-quick-stat:last-child{border:none}
.aqs-val{font-weight:700;color:var(--blue)}
.aqs-green{color:#059669}

/* Role Badges */
.role-badge{padding:3px 10px;border-radius:100px;font-size:.65rem;font-weight:700}
.rb-student{background:#dbeafe;color:#2563eb}
.rb-teacher{background:#d1fae5;color:#059669}
.rb-admin{background:#ede9fe;color:#7c3aed}
.status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:4px}
.sd-active{background:#059669}.sd-inactive{background:#ef4444}

/* Export Buttons */
.export-list{display:flex;flex-direction:column;gap:8px}
.export-btn{display:flex;align-items:center;gap:8px;padding:10px 14px;border:1px solid var(--border);border-radius:8px;background:var(--card);cursor:pointer;font-size:.82rem;font-weight:600;transition:all .2s;font-family:var(--font);color:var(--gray-700)}
.export-btn:hover{background:var(--blue-xl);color:var(--blue);border-color:var(--blue)}
.export-btn i{width:18px;text-align:center}

/* Perf Bar Colors */
.bf-green{background:linear-gradient(90deg,#059669,#10b981)!important}
.bf-purple{background:linear-gradient(90deg,#7c3aed,#8b5cf6)!important}
.bf-orange{background:linear-gradient(90deg,#f59e0b,#fbbf24)!important}
.bf-cyan{background:linear-gradient(90deg,#06b6d4,#22d3ee)!important}

/* Club Cards */
.club-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:20px;transition:all .25s}
.club-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.club-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;margin-bottom:12px;color:#fff}
.ci-blue{background:linear-gradient(135deg,#2563eb,#3b82f6)}
.ci-green{background:linear-gradient(135deg,#059669,#10b981)}
.ci-purple{background:linear-gradient(135deg,#7c3aed,#8b5cf6)}
.ci-orange{background:linear-gradient(135deg,#f59e0b,#fbbf24)}
.ci-red{background:linear-gradient(135deg,#ef4444,#f87171)}
.ci-cyan{background:linear-gradient(135deg,#06b6d4,#22d3ee)}
.club-card h4{font-size:.9rem;font-weight:700;margin-bottom:4px}
.club-card p{font-size:.78rem;color:var(--text-l);margin-bottom:10px}
.club-meta{display:flex;justify-content:space-between;align-items:center}
.club-meta span{font-size:.72rem;color:var(--text-l);font-weight:600}
.btn-join{padding:5px 14px;border:1px solid var(--blue);border-radius:100px;background:transparent;color:var(--blue);font-size:.72rem;font-weight:700;cursor:pointer;transition:all .2s}
.btn-join:hover,.btn-join.joined{background:var(--blue);color:#fff}

/* Mentor Card */
.mentor-card{display:flex;align-items:center;gap:14px;padding:14px 0}
.mentor-avatar{width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,var(--blue),var(--purple));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:1rem;flex-shrink:0}
.mentor-info h4{font-size:.9rem;font-weight:700}
.mentor-info p{font-size:.78rem;color:var(--text-l)}
.mentor-email{color:var(--blue)!important;display:flex;align-items:center;gap:4px;margin-top:2px}
.mentor-card .btn-add{margin-left:auto}

/* Internship Cards */
.intern-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:18px;position:relative;transition:all .25s}
.intern-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.intern-badge{position:absolute;top:12px;right:12px;padding:2px 10px;border-radius:100px;font-size:.62rem;font-weight:700}
.ib-new{background:#d1fae5;color:#059669}
.ib-hot{background:#fee2e2;color:#ef4444}
.intern-card h4{font-size:.88rem;font-weight:700;margin-bottom:2px}
.intern-co{font-size:.75rem;font-weight:600;color:var(--blue);margin-bottom:6px}
.intern-card>p{font-size:.78rem;color:var(--text-l)}
.intern-meta{display:flex;justify-content:space-between;align-items:center;margin-top:12px}
.intern-meta span{font-size:.82rem;font-weight:700;color:var(--green)}

/* Feedback Items (Management) */
.feedback-item{padding:14px;border-radius:10px;margin-bottom:10px;border:1px solid var(--border)}
.fi-pos{background:#f0fdf4;border-color:#bbf7d0}
.fi-neg{background:#fef2f2;border-color:#fecaca}
.fi-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.fi-badge{padding:2px 8px;border-radius:100px;font-size:.62rem;font-weight:700}
.fb-pos{background:#d1fae5;color:#059669}.fb-neg{background:#fee2e2;color:#ef4444}
.fi-date{font-size:.68rem;color:var(--text-l)}
.feedback-item p{font-size:.82rem;font-style:italic;color:var(--gray-700)}

/* Notification Badge */
.topbar-actions button{position:relative}
.notif-badge{position:absolute;top:-2px;right:-2px;width:16px;height:16px;background:#ef4444;color:#fff;border-radius:50%;font-size:.55rem;font-weight:800;display:flex;align-items:center;justify-content:center}

/* Responsive additions */
@media(max-width:768px){
.welcome-banner{flex-direction:column;text-align:center;gap:12px}
.service-grid{grid-template-columns:repeat(4,1fr);gap:8px}
.service-card{padding:12px 8px}
.service-card i{font-size:1.1rem;margin-bottom:4px}
.class-grid{grid-template-columns:1fr}
.student-grid{grid-template-columns:repeat(2,1fr)}
.att-row{flex-direction:column;align-items:flex-start;gap:4px}
.att-sub{min-width:auto}
.att-bar{width:100%}
.schedule-table{font-size:.65rem;display:block;overflow-x:auto}
.mentor-card{flex-direction:column;text-align:center}
.mentor-card .btn-add{margin-left:0}
}
@media(max-width:380px){
.service-grid{grid-template-columns:repeat(3,1fr)}
.student-grid{grid-template-columns:1fr}
}
