/* ══════════════════════════════════════════
   EĞİTİM PANELİ — ORTAK STYLE.CSS
   ══════════════════════════════════════════ */

/* ── RESET & TOKENS ── */
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#0d1117;--surface:#111827;--surface2:#1a2236;--border:#1e2235;--border2:#2a3450;
  --text:#e8eaf0;--muted:#8b95b0;--dim:#4a5568;
  --purple:#6C63FF;--cyan:#43D8C9;--pink:#FF6584;--orange:#FFB347;
  --green:#6BCB77;--grad:linear-gradient(135deg,#6C63FF,#43D8C9);
}
body{font-family:'Nunito',sans-serif;background:var(--bg);color:var(--text);min-height:100vh}
button{cursor:pointer;font-family:inherit}
input,select,textarea{font-family:inherit}
input[type=number]::-webkit-inner-spin-button{opacity:1}
.hidden{display:none!important}

/* ── TOP NAV ── */
.top-nav{
  display:flex;align-items:center;gap:6px;padding:0 20px;
  background:var(--surface);border-bottom:1px solid var(--border);
  height:56px;position:sticky;top:0;z-index:200;flex-wrap:wrap
}
.nav-logo{
  font-size:18px;font-weight:900;
  background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;
  margin-right:4px;white-space:nowrap;text-decoration:none
}
.nav-link{
  display:flex;align-items:center;gap:5px;padding:7px 12px;border-radius:9px;
  border:none;background:transparent;color:var(--muted);font-size:12px;font-weight:600;
  text-decoration:none;transition:all .2s;cursor:pointer;white-space:nowrap
}
.nav-link:hover{background:var(--surface2);color:var(--text)}
.nav-link.active{background:linear-gradient(90deg,#6C63FF22,#43D8C911);color:var(--purple);font-weight:700}
.nav-spacer{flex:1}
.user-badge{
  display:flex;align-items:center;gap:8px;padding:6px 12px;
  background:var(--surface2);border-radius:20px;font-size:12px;font-weight:700
}
.logout-btn{
  padding:7px 14px;background:transparent;border:1px solid var(--border2);
  border-radius:8px;color:var(--muted);font-size:12px;font-weight:600;cursor:pointer
}
.logout-btn:hover{border-color:var(--pink);color:var(--pink)}

/* ── LAYOUT ── */
.page-wrap{display:flex;min-height:calc(100vh - 56px)}
#sidebar{
  width:200px;background:var(--surface);border-right:1px solid var(--border);
  padding:16px 10px;display:flex;flex-direction:column;gap:4px;flex-shrink:0
}
.sidebar-section-title{
  font-size:10px;color:var(--dim);font-weight:700;
  text-transform:uppercase;letter-spacing:.5px;padding:8px 10px 4px
}
.sb-btn{
  display:flex;align-items:center;gap:8px;padding:9px 10px;border-radius:8px;
  border:none;background:transparent;color:var(--muted);font-size:12px;font-weight:600;
  text-align:left;width:100%;transition:all .2s;cursor:pointer;text-decoration:none
}
.sb-btn:hover{background:var(--surface2);color:var(--text)}
.sb-btn.active{background:#6C63FF22;color:var(--purple);font-weight:700}
.sb-icon{font-size:14px}
#main-content{flex:1;padding:24px 28px;overflow-y:auto;min-width:0}

/* ── SECTION ── */
.section-header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:20px;flex-wrap:wrap;gap:10px
}
.section-title{font-size:20px;font-weight:800;color:#fff}
.section-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.empty-state{text-align:center;padding:48px;color:var(--dim);font-size:15px}

/* ── BUTTONS ── */
.btn-primary{
  padding:9px 18px;background:var(--grad);border:none;border-radius:10px;
  color:#fff;font-weight:700;font-size:13px;white-space:nowrap;transition:opacity .2s;cursor:pointer
}
.btn-primary:hover{opacity:.85}
.btn-danger{
  padding:9px 18px;background:linear-gradient(135deg,#FF6584,#FF4060);
  border:none;border-radius:10px;color:#fff;font-weight:700;font-size:13px;cursor:pointer
}
.delete-btn{
  background:transparent;border:none;color:var(--pink);
  font-size:16px;line-height:1;padding:0 4px;font-weight:700;cursor:pointer
}

/* ── INPUTS ── */
.input-field{
  width:100%;padding:10px 12px;background:var(--surface2);border:1px solid var(--border2);
  border-radius:10px;color:var(--text);font-size:13px;margin-bottom:10px;
  outline:none;transition:border-color .2s
}
.input-field:focus{border-color:var(--purple)}
select.input-field option{background:var(--surface2);color:var(--text)}

/* ── MODAL ── */
.overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.75);
  display:flex;align-items:center;justify-content:center;
  z-index:1000;opacity:0;pointer-events:none;transition:opacity .2s
}
.overlay.open{opacity:1;pointer-events:all}
.modal-box{
  background:var(--surface);border:1px solid var(--border2);border-radius:16px;
  padding:24px;width:340px;max-width:92vw;max-height:90vh;overflow-y:auto;
  transform:translateY(16px);transition:transform .2s
}
.overlay.open .modal-box{transform:translateY(0)}
.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}
.modal-title{font-weight:800;font-size:15px;color:#fff}
.close-btn{background:transparent;border:none;color:var(--muted);font-size:17px;cursor:pointer}
.modal-label{font-size:11px;color:var(--muted);font-weight:700;display:block;margin-bottom:4px;margin-top:12px}

/* ── TABLE ── */
.table-wrap{overflow-x:auto}
.data-table{width:100%;border-collapse:collapse;background:var(--surface);border-radius:12px;overflow:hidden}
.data-table th{
  padding:11px 13px;background:var(--surface2);color:var(--muted);
  font-weight:600;font-size:11px;text-align:left;border-bottom:1px solid var(--border)
}
.data-table td{
  padding:9px 13px;border-bottom:1px solid var(--border);
  font-size:12px;color:#c0c8d8;vertical-align:middle
}
.data-table tr:last-child td{border-bottom:none}
.cell-select{
  background:transparent;border:none;outline:none;font-size:12px;
  cursor:pointer;width:100%;font-weight:600;color:var(--muted);font-family:inherit
}

/* ── CARDS ── */
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}
.act-card{background:var(--surface);border-radius:12px;padding:13px;border:1px solid var(--border)}
.act-card-head{display:flex;justify-content:space-between;align-items:center;gap:6px}
.tag{display:inline-block;padding:2px 10px;border-radius:20px;color:#fff;font-size:11px;font-weight:700}
.act-date{font-size:11px;color:var(--muted)}
.act-desc{margin-top:8px;font-size:12px;color:#c0c8d8;line-height:1.5}

/* ── ADMIN PANEL CARDS ── */
.container{max-width:1000px;margin:0 auto;padding:30px 20px}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;margin-bottom:40px}
.card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:20px;position:relative}
.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}
.role-tag{font-size:10px;font-weight:800;padding:4px 10px;border-radius:20px;text-transform:uppercase}
.role-student{background:#6C63FF22;color:#6C63FF;border:1px solid #6C63FF55}
.role-teacher{background:#FFB34722;color:#FFB347;border:1px solid #FFB34755}
.user-name{font-size:16px;font-weight:800;color:#fff;margin-bottom:4px}
.user-meta{font-size:12px;color:var(--muted);margin-bottom:2px}
.user-meta span{color:var(--cyan);font-weight:600}
.actions{display:flex;gap:8px;margin-top:16px;flex-wrap:wrap}
.badge{background:var(--pink);color:#fff;padding:2px 8px;border-radius:12px;font-size:12px;font-weight:700}
.btn-approve{flex:1;padding:8px;background:linear-gradient(135deg,#6BCB77,#4CAF50);border:none;border-radius:8px;color:#fff;font-weight:700;font-size:12px;cursor:pointer}
.btn-reject{flex:1;padding:8px;background:transparent;border:1px solid var(--pink);border-radius:8px;color:var(--pink);font-weight:700;font-size:12px;cursor:pointer}
.btn-delete{padding:6px 12px;background:transparent;border:1px solid var(--border2);border-radius:8px;color:var(--dim);font-weight:700;font-size:11px;cursor:pointer}
.btn-delete:hover{border-color:var(--pink);color:var(--pink)}
.btn-migrate{padding:6px 12px;background:transparent;border:1px solid var(--cyan);border-radius:8px;color:var(--cyan);font-weight:700;font-size:11px;transition:all 0.2s;cursor:pointer}
.btn-migrate:hover{background:var(--cyan);color:#0d1117}
.btn-edit{padding:6px 12px;background:transparent;border:1px solid var(--purple);border-radius:8px;color:var(--purple);font-weight:700;font-size:11px;transition:all 0.2s;cursor:pointer}
.btn-edit:hover{background:var(--purple);color:#fff}
.empty-state-card{text-align:center;padding:40px;background:var(--surface);border:1px dashed var(--border2);border-radius:16px;color:var(--dim);font-size:14px;margin-bottom:40px}

/* ── BOOK ── */
.book-card{background:var(--surface);border-radius:14px;padding:16px;border:1px solid var(--border)}
.book-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}
.book-title{font-weight:800;font-size:16px;color:#fff;margin-bottom:6px}
.book-subject-tag{display:inline-block;padding:3px 10px;border-radius:14px;font-size:11px;font-weight:700;color:#fff}
.book-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}
.book-stat-box{background:var(--surface2);border-radius:8px;padding:10px;text-align:center;border:1px solid var(--border)}
.book-stat-label{font-size:10px;color:var(--muted);margin-bottom:4px;text-transform:uppercase;font-weight:700}
.book-stat-value{font-size:18px;font-weight:800;color:var(--cyan)}
.progress-wrap{height:8px;background:var(--border);border-radius:6px;overflow:hidden;margin-top:8px}
.progress-bar{height:100%;border-radius:6px;transition:width .6s ease}
.session-list{display:flex;flex-direction:column;gap:8px;max-height:200px;overflow-y:auto;padding-right:4px;margin-top:10px}
.session-item{background:var(--surface2);border-radius:8px;padding:10px;border-left:3px solid var(--purple)}
.session-item.completed{border-left-color:var(--green)}
.session-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.session-date{font-size:11px;font-weight:700;color:var(--purple)}
.session-item.completed .session-date{color:var(--green)}
.session-pages{font-size:10px;color:var(--muted);font-weight:600}
.session-summary{font-size:11px;color:#c0c8d8;margin-top:5px;padding:8px;background:var(--bg);border-radius:6px;border:1px solid var(--border)}
.session-summary-placeholder{color:var(--dim);font-style:italic}
.session-actions{display:flex;gap:5px;margin-top:7px}
.btn-complete{padding:4px 12px;background:linear-gradient(135deg,#6BCB77,#4CAF50);border:none;border-radius:6px;color:#fff;font-size:10px;font-weight:700;cursor:pointer}
.btn-edit-summary{padding:4px 12px;background:linear-gradient(135deg,#6C63FF,#43D8C9);border:none;border-radius:6px;color:#fff;font-size:10px;font-weight:700;cursor:pointer}
.add-reading-btn{width:100%;padding:10px;background:var(--surface2);border:1px dashed var(--border2);border-radius:8px;color:var(--purple);font-weight:700;font-size:12px;margin-top:10px;transition:all .2s;cursor:pointer}
.summary-textarea{width:100%;min-height:100px;padding:10px;background:var(--surface2);border:1px solid var(--border2);border-radius:8px;color:var(--text);font-size:12px;resize:vertical;outline:none;line-height:1.6}
.summary-textarea:focus{border-color:var(--purple)}

/* ── JOURNAL ── */
.jnl-subject-list{display:flex;flex-direction:column;gap:14px}
.jnl-subject-block{background:var(--surface);border-radius:14px;border:1px solid var(--border);overflow:hidden}
.jnl-subject-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;cursor:pointer;user-select:none;transition:background .15s}
.jnl-subject-header:hover{background:var(--surface2)}
.jnl-subject-header-left{display:flex;align-items:center;gap:10px}
.jnl-color-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.jnl-subject-title{font-weight:800;font-size:15px;color:#fff}
.jnl-subject-summary{display:flex;align-items:center;gap:10px}
.jnl-summary-badge{font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px}
.jnl-chevron{font-size:11px;color:var(--muted);transition:transform .2s}
.jnl-chevron.open{transform:rotate(180deg)}
.jnl-subject-body{display:none;border-top:1px solid var(--border)}
.jnl-subject-body.open{display:block}
.jnl-topics-wrap{padding:14px 18px}
.jnl-topic-table{width:100%;border-collapse:collapse}
.jnl-topic-table th{padding:7px 8px;background:var(--surface2);color:var(--muted);font-size:10px;font-weight:700;text-align:center;border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:.5px}
.jnl-topic-table th:first-child{text-align:left}
.jnl-topic-table td{padding:7px 8px;border-bottom:1px solid var(--border);font-size:12px;vertical-align:middle;text-align:center}
.jnl-topic-table tr:last-child td{border-bottom:none}
.jnl-topic-name-cell{font-weight:600;text-align:left!important;min-width:120px}
.jnl-num-input{width:58px;padding:5px 6px;background:var(--surface2);border:1px solid var(--border2);border-radius:7px;color:#fff;font-size:12px;font-weight:700;text-align:center;outline:none}
.jnl-num-input:focus{border-color:var(--purple)}
.jnl-net-cell{font-weight:800;font-size:13px}
.jnl-eval-input{width:140px;padding:5px 7px;background:var(--surface2);border:1px solid var(--border2);border-radius:7px;color:#fff;font-size:11px;outline:none}
.jnl-eval-input:focus{border-color:var(--purple)}
.jnl-topic-del{background:transparent;border:none;color:var(--dim);font-size:15px;padding:0 4px;cursor:pointer}
.jnl-topic-del:hover{color:var(--pink)}
.jnl-add-row{padding:10px 18px;background:var(--surface2);display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.jnl-add-input{flex:1;min-width:140px;padding:7px 10px;background:var(--bg);border:1px solid var(--border2);border-radius:7px;color:var(--text);font-size:12px;outline:none}
.jnl-add-input:focus{border-color:var(--purple)}
.btn-add-topic{padding:7px 14px;border:none;border-radius:7px;color:#fff;font-size:11px;font-weight:700;background:var(--grad);cursor:pointer}
.jnl-del-subject{background:transparent;border:none;color:var(--dim);font-size:12px;padding:3px 7px;border-radius:5px;cursor:pointer;font-weight:700}
.jnl-del-subject:hover{color:var(--pink);background:#ff658420}
.jnl-empty{text-align:center;padding:28px;color:var(--dim);font-size:13px}

/* ── STUDY PLAN ── */
.plan-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:10px}
.plan-day{background:var(--surface);border-radius:11px;padding:12px;border:1px solid var(--border)}
.plan-day-title{font-weight:800;font-size:12px;color:#fff;margin-bottom:8px;padding-bottom:7px;border-bottom:1px solid var(--border)}
.plan-item{background:var(--surface2);border-radius:7px;padding:8px;margin-bottom:5px;transition:all .2s}
.plan-item.active-session{border:1px solid var(--green);background:#6BCB7711;animation:pulse-green 2s infinite}
@keyframes pulse-green{0%,100%{box-shadow:0 0 0 0 #6BCB7744}50%{box-shadow:0 0 0 5px #6BCB7700}}
.plan-item-head{display:flex;justify-content:space-between;align-items:center}
.plan-time{font-size:10px;color:var(--muted);margin-top:2px}
.plan-empty{color:var(--dim);font-size:11px;text-align:center;padding:10px 0}
.plan-timer-display{font-size:20px;font-weight:800;color:var(--green);text-align:center;letter-spacing:2px;margin:6px 0;font-variant-numeric:tabular-nums}
.plan-session-log{margin-top:6px;padding-top:6px;border-top:1px solid var(--border)}
.plan-session-log-title{font-size:9px;color:var(--muted);font-weight:700;text-transform:uppercase;margin-bottom:4px}
.plan-session-entry{display:flex;justify-content:space-between;font-size:10px;color:#c0c8d8;padding:3px 5px;background:var(--bg);border-radius:5px;margin-bottom:3px}
.plan-session-entry-time{color:var(--cyan);font-weight:700}
.plan-session-entry-dur{color:var(--green);font-weight:700}
.btn-start-session{width:100%;padding:6px;background:linear-gradient(135deg,#6BCB77,#4CAF50);border:none;border-radius:7px;color:#fff;font-weight:700;font-size:11px;margin-top:5px;cursor:pointer}
.btn-stop-session{width:100%;padding:6px;background:linear-gradient(135deg,#FF6584,#FF4060);border:none;border-radius:7px;color:#fff;font-weight:700;font-size:11px;margin-top:3px;cursor:pointer}
.plan-total-time{font-size:10px;color:var(--muted);text-align:center;margin-top:3px;font-weight:600}
.plan-add-modal-note{font-size:11px;color:var(--muted);margin-bottom:10px;padding:9px;background:var(--surface2);border-radius:7px;border-left:3px solid var(--cyan)}

/* ── TICKER ── */
#lesson-ticker{
  position:fixed;bottom:0;left:0;right:0;z-index:1500;
  background:linear-gradient(90deg,#c0392b,#e67e22);
  padding:9px 0;border-top:2px solid #FF6584;
  box-shadow:0 -3px 15px rgba(255,101,132,.4);
  transform:translateY(100%);transition:transform .4s ease;overflow:hidden
}
#lesson-ticker.show{transform:translateY(0)}
.ticker-track{display:flex;width:max-content;animation:ticker-scroll 30s linear infinite}
.ticker-track:hover{animation-play-state:paused}
@keyframes ticker-scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.tick-item{display:inline-block;white-space:nowrap;font-size:12px;font-weight:700;color:#fff;padding:0 40px}

/* ── MISSED BANNER ── */
.missed-banner{background:#FF658418;border:1px solid #FF658444;border-radius:10px;padding:12px 14px;margin-bottom:14px;display:flex;align-items:center;gap:10px;flex-wrap:wrap;cursor:pointer;transition:all .2s}
.missed-banner:hover{background:#FF658428}

/* ── ACTIVE SESSION BANNER ── */
#active-session-banner{
  background:linear-gradient(135deg,#6BCB7722,#4CAF5011);
  border:1px solid var(--green);border-radius:11px;padding:13px 18px;
  margin-bottom:16px;display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:8px
}

/* ── OZET / RAPOR ── */
.report-container{max-width:1150px;margin:30px auto;padding:0 20px}
.header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:12px}
.page-title{font-size:24px;font-weight:900;color:#fff}
.btn-pdf{
  padding:10px 20px;background:linear-gradient(135deg,#FF6584,#FF4060);border:none;
  border-radius:10px;color:#fff;font-weight:800;font-size:14px;
  display:flex;align-items:center;gap:8px;
  box-shadow:0 4px 15px rgba(255,101,132,.4);transition:all .2s;cursor:pointer
}
.btn-pdf:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(255,101,132,.6)}
.btn-sec-pdf{
  padding:6px 12px;background:var(--surface2);border:1px solid var(--border2);
  border-radius:8px;color:var(--cyan);font-weight:700;font-size:11px;
  display:flex;align-items:center;gap:6px;transition:all .2s;cursor:pointer
}
.btn-sec-pdf:hover{background:var(--cyan);color:#0d1117}
#pdf-content{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:30px;color:var(--text)}
.report-header{text-align:center;border-bottom:2px solid var(--border2);padding-bottom:20px;margin-bottom:30px}
.report-title{font-size:28px;font-weight:900;color:#fff;letter-spacing:1px}
.report-subtitle{font-size:14px;color:var(--cyan);font-weight:700;margin-top:8px}
.report-date{font-size:12px;color:var(--muted);margin-top:4px}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:30px}
.stat-box{background:var(--bg);border:1px solid var(--border2);border-radius:12px;padding:20px;text-align:center}
.stat-label{font-size:11px;color:var(--muted);font-weight:800;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}
.stat-value{font-size:28px;font-weight:900;color:#fff}
.stat-sub-detail{font-size:11px;color:var(--muted);margin-top:6px;font-weight:700}
.report-section{margin-bottom:40px;background:var(--surface);padding:20px;border-radius:12px;border:1px solid var(--border2)}
.section-head{display:flex;justify-content:space-between;align-items:center;font-size:18px;font-weight:800;color:var(--purple);border-bottom:1px solid var(--border2);padding-bottom:12px;margin-bottom:16px}
.report-table{width:100%;border-collapse:collapse;background:var(--bg);border-radius:8px;overflow:hidden}
.report-table th{background:var(--surface2);color:var(--muted);font-size:11px;font-weight:800;text-align:left;padding:10px;text-transform:uppercase}
.report-table td{padding:10px;font-size:13px;color:#d1d5db;border-bottom:1px solid var(--border2);vertical-align:middle}
.report-table tr:last-child td{border-bottom:none}
.text-center{text-align:center!important}
.text-right{text-align:right!important}
.report-list{display:flex;flex-direction:column;gap:8px}
.list-item{background:var(--bg);border:1px solid var(--border2);border-radius:8px;padding:12px 16px;display:flex;justify-content:space-between;align-items:center}
.list-item-title{font-weight:700;color:#fff;font-size:14px}
.list-item-sub{font-size:12px;color:var(--muted)}
.print-only-header{display:none;text-align:center;margin-bottom:16px;font-weight:800;color:var(--cyan);border-bottom:1px dashed var(--border2);padding-bottom:8px}
.print-value{display:none}

/* ── WEEKLY TABLE ── */
.classic-paper{background:#ffffff;padding:15px;border-radius:8px;overflow-x:auto;border:1px solid #ccc}
.weekly-table{width:100%;border-collapse:collapse;font-family:Arial,sans-serif;background:transparent}
.weekly-table th,.weekly-table td{border:1px solid #1565C0;padding:6px;color:#000}
.weekly-table th{background:#E3F2FD;font-size:11px;font-weight:bold;text-align:center}
.weekly-table .day-cell{background:#E3F2FD;font-weight:bold;text-align:center!important;vertical-align:middle!important;font-size:12px;padding:4px!important}
.screen-day{writing-mode:vertical-rl;transform:rotate(180deg);letter-spacing:1px;display:inline-block}
.pdf-day-text{display:none;line-height:1.1;font-size:10px;color:#000;text-transform:uppercase}
.cell-wrapper{display:flex;flex-direction:column;gap:4px}
.w-input{width:100%;background:transparent;border:1px solid #90CAF9;color:#000!important;font-size:11px;font-weight:bold;padding:6px 4px;border-radius:2px;outline:none;text-align:center;transition:all .2s}
.w-input:focus{background:#BBDEFB;border-color:#1565C0}
.w-input::placeholder{color:#78909C;font-weight:normal}
.w-row{display:flex;gap:4px}
.w-row input{flex:1;min-width:0}
.totals-row td{background:#FFF9C4!important;font-weight:bold}
.tot-box{display:flex;justify-content:space-between;gap:4px}
.tot-box div{text-align:center;flex:1;font-size:10px;color:#000}
.tot-box div span{font-size:13px;font-weight:900;display:block;margin-top:2px}

/* ── PDF EXPORT ── */
.pdf-export-active .w-input{display:none!important}
.pdf-export-active .print-value{display:block!important}
.pdf-export-active .screen-day{display:none!important}
.pdf-export-active .pdf-day-text{display:block!important}
.pv-konu{color:#000;font-size:11px;font-weight:bold;text-align:center;padding-bottom:4px;border-bottom:1px dashed #1565C0;margin-bottom:4px;word-wrap:break-word;white-space:normal}
.pv-stat{font-size:11px;font-weight:bold;text-align:center;flex:1;color:#000}
.pdf-export-active .w-row{justify-content:space-between}
.pdf-export-active{margin-top:0!important}
.pdf-export-active .classic-paper{overflow-x:visible!important}

/* ── GİRİŞ SAYFASI (banner) ── */
#banner{position:fixed;inset:0;z-index:0;overflow:hidden}
.banner-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.2s ease-in-out}
.banner-slide.active{opacity:1}
#banner::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(13,17,23,.82) 0%,rgba(13,17,23,.62) 50%,rgba(13,17,23,.78) 100%);z-index:1}
#banner-dots{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);display:flex;gap:8px;z-index:20}
.bdot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.3);border:none;padding:0;transition:all .3s;cursor:pointer}
.bdot.active{background:#fff;width:24px;border-radius:4px}
.banner-arrow{position:fixed;top:50%;transform:translateY(-50%);width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.12);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.2);color:#fff;font-size:20px;z-index:20;transition:all .2s;display:flex;align-items:center;justify-content:center;cursor:pointer}
.banner-arrow:hover{background:rgba(255,255,255,.25)}
#arrow-prev{left:18px}
#arrow-next{right:18px}
#school-brand{position:fixed;top:0;left:0;right:0;z-index:15;padding:14px 28px;display:flex;align-items:center;gap:12px;background:linear-gradient(180deg,rgba(13,17,23,.85) 0%,transparent 100%)}
#school-brand-name{font-size:18px;font-weight:900;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.6);letter-spacing:.3px}
#school-brand-sub{font-size:11px;color:rgba(255,255,255,.5);font-weight:600;margin-top:1px}
#login-page{position:relative;z-index:10;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:32px 16px}
.login-box{background:rgba(17,24,39,.88);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border:1px solid rgba(255,255,255,.1);border-radius:24px;padding:40px;width:390px;max-width:94vw;position:relative;box-shadow:0 24px 64px rgba(0,0,0,.55)}
.login-box::before{content:'';position:absolute;inset:0;border-radius:24px;background:radial-gradient(ellipse at 30% 0%,#6C63FF18 0%,transparent 60%);pointer-events:none}
.login-logo{font-size:44px;text-align:center;margin-bottom:6px}
.login-title{text-align:center;font-weight:900;font-size:24px;color:#fff;margin-bottom:5px}
.login-sub{text-align:center;color:var(--muted);font-size:13px;margin-bottom:28px}
.tab-row{display:flex;gap:4px;background:rgba(13,17,23,.6);border-radius:10px;padding:4px;margin-bottom:18px}
.tab-btn{flex:1;padding:8px;border:none;background:transparent;color:var(--muted);border-radius:8px;font-weight:600;font-size:13px;transition:all .2s;cursor:pointer}
.tab-btn.active{color:#fff}
.login-input{width:100%;padding:10px 12px;background:rgba(26,34,54,.8);border:1px solid var(--border2);border-radius:10px;color:var(--text);font-size:14px;margin-bottom:12px;outline:none;transition:border-color .2s;font-family:inherit}
.login-input:focus{border-color:var(--purple)}
select.login-input option{background:var(--surface2);color:var(--text)}
.err-msg{color:var(--pink);font-size:12px;margin-bottom:10px;text-align:center}
.login-submit{width:100%;padding:12px;border:none;border-radius:10px;color:#fff;font-weight:700;font-size:15px;margin-top:4px;cursor:pointer}
.pending-notice{background:#FFB34722;border:1px solid #FFB347;border-radius:10px;padding:12px;text-align:center;color:#FFB347;font-size:13px;margin-top:12px}
.back-link{display:inline-flex;align-items:center;gap:6px;color:var(--muted);font-size:13px;font-weight:600;text-decoration:none;margin-bottom:20px;transition:color .2s}
.back-link:hover{color:var(--purple)}
.role-badge{display:flex;align-items:center;gap:8px;padding:7px 16px;border-radius:20px;color:#fff;font-weight:700;font-size:13px;margin:0 auto 14px;width:fit-content}
