:root{
  --font-sans:"Inter","Sarabun","Segoe UI",Arial,sans-serif;
  --bg:#f6fbf8;
  --bg-soft:#eef5f1;
  --surface:#ffffff;
  --surface-2:#fbfdfc;
  --surface-3:#f3f8f5;
  --sidebar:#0f2d26;
  --sidebar-soft:#13352d;
  --text:#16332c;
  --text-soft:#64786f;
  --text-faint:#8ca097;
  --text-invert:#f7fcfa;
  --border:#d9e5df;
  --border-strong:#c5d6ce;
  --primary:#34d399;
  --primary-strong:#16b676;
  --primary-soft:#e8f9f0;
  --accent:#17493e;
  --danger:#ca5b55;
  --danger-soft:#fff1ef;
  --warning:#b88628;
  --warning-soft:#fff7e9;
  --success:#20885d;
  --success-soft:#ebf8f1;
  --info:#2f6e86;
  --info-soft:#eef7fb;
  --shadow-xs:0 10px 24px rgba(15,45,38,.04);
  --shadow-sm:0 20px 48px rgba(15,45,38,.08);
  --shadow-md:0 28px 72px rgba(15,45,38,.12);
  --radius-sm:14px;
  --radius-md:20px;
  --radius-lg:28px;
  --page-width:1440px;
  --transition:180ms ease;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;min-height:100%}
html{background:var(--bg)}
body{font-family:var(--font-sans);background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{text-decoration:none;color:inherit}
button,input,select,textarea{font:inherit}
img{display:block;max-width:100%}
::selection{background:rgba(52,211,153,.18)}
.hidden{display:none!important}
.mt-0{margin-top:0}.mt-24{margin-top:24px}.mb-0{margin-bottom:0}.mb-16{margin-bottom:16px}
.text-muted,.muted,.text-soft,.field-help,.topbar-subtitle{color:var(--text-soft)}
.text-danger{color:var(--danger)}
.align-end{align-self:end}.items-center{align-items:center}.justify-between{justify-content:space-between}.wrap-gap{flex-wrap:wrap}.w-full{width:100%}
.flex{display:flex}.grid{display:grid}.gap-18{gap:18px}
.container{width:min(var(--page-width),calc(100% - 32px));margin:0 auto}

.app-body{overflow-x:hidden;background:var(--bg)}
.app-shell{display:grid;grid-template-columns:308px minmax(0,1fr);min-height:100vh}
.app-sidebar{position:sticky;top:0;height:100vh;overflow:auto;padding:22px 18px;background:var(--sidebar);color:var(--text-invert);border-right:1px solid rgba(255,255,255,.06)}
.sidebar-overlay{position:fixed;inset:0;background:rgba(8,20,17,.42);opacity:0;pointer-events:none;transition:opacity var(--transition);z-index:20}
body.sidebar-open .sidebar-overlay{opacity:1;pointer-events:auto}

.brand-block{display:grid;gap:18px;padding:22px;border-radius:26px;background:#17382f;border:1px solid rgba(255,255,255,.08);box-shadow:inset 0 1px 0 rgba(255,255,255,.04)}
.brand-mark{display:flex;align-items:center;gap:14px}
.brand-logo{width:58px;height:58px;border-radius:18px;display:grid;place-items:center;background:var(--primary);color:#08362d;font-weight:900;font-size:1.1rem;letter-spacing:.06em;box-shadow:0 16px 36px rgba(52,211,153,.18)}
.brand-kicker{display:block;font-size:.76rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:rgba(247,252,250,.58);margin-bottom:4px}
.brand-title{margin:0;font-size:1.42rem;line-height:1.08;font-weight:800;letter-spacing:-.03em;color:#fff}
.brand-subtitle{margin:0;color:rgba(247,252,250,.78);font-size:.94rem;line-height:1.72}
.brand-meta{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.brand-meta .badge{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.09);color:#eef8f4}
.sidebar-section{margin-top:26px}
.sidebar-label{margin:0 0 12px;padding-left:4px;font-size:.74rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:rgba(247,252,250,.52)}
.sidebar-nav{display:grid;gap:10px}
.sidebar-link{display:block;position:relative;border-radius:18px;transition:transform var(--transition)}
.sidebar-link:hover{transform:translateY(-1px)}
.sidebar-link-main{display:flex;gap:14px;align-items:flex-start;padding:14px 15px;border-radius:18px;border:1px solid rgba(255,255,255,.05);background:transparent;transition:background var(--transition),border-color var(--transition),box-shadow var(--transition)}
.sidebar-link:hover .sidebar-link-main{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.07)}
.sidebar-link.is-active .sidebar-link-main{background:rgba(52,211,153,.10);border-color:rgba(52,211,153,.28);box-shadow:inset 0 0 0 1px rgba(52,211,153,.12)}
.sidebar-link.is-active::before{content:"";position:absolute;left:0;top:14px;bottom:14px;width:4px;border-radius:999px;background:var(--primary)}
.sidebar-icon{width:42px;height:42px;border-radius:14px;display:grid;place-items:center;background:rgba(255,255,255,.08);color:#f8fcfa;font-size:.94rem;font-weight:800;flex:0 0 auto;border:1px solid rgba(255,255,255,.05)}
.sidebar-link.is-active .sidebar-icon{background:rgba(52,211,153,.18);color:#ecfff7;border-color:rgba(52,211,153,.12)}
.sidebar-link-title{display:block;font-size:1rem;font-weight:700;color:#fff;line-height:1.25}
.sidebar-link-desc{display:block;margin-top:4px;font-size:.845rem;line-height:1.55;color:rgba(247,252,250,.68)}
.sidebar-foot{margin-top:24px;padding:18px;border-radius:22px;background:#17382f;border:1px solid rgba(255,255,255,.08)}
.sidebar-foot p{margin:0 0 10px;font-size:.91rem;line-height:1.7;color:rgba(247,252,250,.74)}
.sidebar-foot p:last-child{margin-bottom:0}
.sidebar-foot strong{color:#fff}

.app-main{min-width:0}
.app-main-inner{width:min(var(--page-width),calc(100% - 44px));margin:0 auto;padding:22px 0 42px}
.app-topbar{position:sticky;top:14px;z-index:15;display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;padding:16px 18px;background:rgba(255,255,255,.9);backdrop-filter:blur(14px);border:1px solid rgba(217,229,223,.92);border-radius:24px;box-shadow:var(--shadow-xs)}
.topbar-group{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.sidebar-toggle{display:none;width:44px;height:44px;border-radius:14px;border:1px solid var(--border);background:var(--surface);cursor:pointer;color:var(--text);font-size:1.1rem}
.topbar-context{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.topbar-chip{display:flex;gap:12px;align-items:center;padding:10px 14px;background:var(--surface-3);border:1px solid var(--border);border-radius:18px}
.topbar-title{margin:0;font-size:1rem;font-weight:800;color:var(--text)}
.topbar-subtitle{margin:2px 0 0;font-size:.88rem}
.helper-chip-row{display:flex;gap:8px;flex-wrap:wrap}
.helper-chip{display:inline-flex;align-items:center;min-height:34px;padding:0 12px;border-radius:999px;background:var(--surface);border:1px solid var(--border);color:#48665d;font-size:.82rem;font-weight:700}
.account-chip{display:flex;align-items:center;gap:12px;padding:8px 12px;border:1px solid var(--border);background:var(--surface);border-radius:18px;box-shadow:var(--shadow-xs)}
.profile-avatar,.profile-avatar-large{display:grid;place-items:center;border-radius:50%;background:var(--primary);color:#0b3d33;font-weight:800}
.profile-avatar{width:40px;height:40px;font-size:.92rem}.profile-avatar-large{width:76px;height:76px;font-size:1.3rem}
.account-chip-text{display:flex;flex-direction:column;line-height:1.2}.account-chip-text strong{font-size:.96rem}.account-chip-text small{font-size:.83rem;color:var(--text-soft)}
.content-stack{display:grid;gap:22px;margin-top:22px}

.page-section-head{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;flex-wrap:wrap;margin-bottom:18px}
.page-title{margin:0;font-size:clamp(1.8rem,2.35vw,2.9rem);line-height:1.12;font-weight:800;letter-spacing:-.045em;color:var(--text)}
.page-subtitle{margin:10px 0 0;max-width:840px;line-height:1.8;font-size:1rem;color:var(--text-soft)}
.eyebrow{display:inline-flex;align-items:center;padding:8px 12px;border-radius:999px;background:var(--primary-soft);border:1px solid rgba(52,211,153,.20);color:#0f5b4e;font-size:.79rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase}
.hero-actions,.actions-inline,.form-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}

.card,.card-form,.list-card,.calendar-toolbar-card,.calendar-board-card,.agenda-card,.profile-summary,.auth-panel,.auth-showcase{background:var(--surface);border:1px solid var(--border);border-radius:26px;box-shadow:var(--shadow-xs);padding:26px}
.card-hero{padding:30px;background:var(--surface)}
.card-compact{padding:18px}
.card-stat{display:grid;gap:16px;min-height:174px;position:relative;overflow:hidden}
.card-stat::after{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:var(--primary);opacity:.9}
.card-stat-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}
.card-stat-label{color:var(--text-soft);font-weight:700;font-size:.95rem}
.card-stat-value{margin:0;font-size:clamp(2rem,4vw,3rem);line-height:1;font-weight:800;letter-spacing:-.04em}
.card-stat-icon{width:54px;height:54px;border-radius:18px;display:grid;place-items:center;background:var(--surface-3);border:1px solid var(--border);font-size:1rem;color:var(--accent)}
.card-stat-meta{display:flex;gap:10px;flex-wrap:wrap;align-items:center;color:var(--text-soft);font-size:.92rem}
.kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-master{display:grid;grid-template-columns:320px minmax(0,1fr);gap:20px}
.panel-split{display:grid;grid-template-columns:1.1fr .9fr;gap:18px}
.inline-stat{display:grid;gap:5px}.inline-stat-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-faint);font-weight:800}.inline-stat-value{font-size:1.14rem;font-weight:800}
.soft-divider{height:1px;background:var(--border);margin:6px 0}

.premium-hero-grid{display:grid;grid-template-columns:1.22fr .78fr;gap:18px;align-items:stretch}
.hero-academic-grid{display:grid;grid-template-columns:1.12fr .88fr;gap:18px;align-items:stretch}
.premium-status-card{display:grid;gap:16px;padding:24px;border-radius:24px;background:var(--surface-2);border:1px solid var(--border)}
.premium-status-card h3{margin:0;font-size:1.12rem;font-weight:800}
.premium-status-card p{margin:0;line-height:1.75;color:var(--text-soft)}
.metric-pills{display:flex;flex-wrap:wrap;gap:10px}.metric-pill{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:#fff;border:1px solid var(--border);font-size:.84rem;font-weight:700;color:#37584f}.metric-dot{width:8px;height:8px;border-radius:50%;background:var(--primary)}
.academic-summary-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.academic-summary-item{padding:16px 18px;border-radius:18px;border:1px solid var(--border);background:#fff}
.academic-summary-item span{display:block;font-size:.75rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--text-faint)}
.academic-summary-item strong{display:block;margin-top:8px;font-size:1.08rem;line-height:1.35;color:var(--text)}

.toolbar{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap;margin-bottom:18px}
.toolbar-title{margin:0;font-size:1.06rem;font-weight:800}
.toolbar-desc{margin:6px 0 0;color:var(--text-soft);line-height:1.7}
.list-card-meta{display:flex;gap:8px;flex-wrap:wrap;align-items:center}

.table-wrap{overflow:auto;border:1px solid var(--border);border-radius:22px;background:#fff;box-shadow:inset 0 1px 0 rgba(255,255,255,.9)}
table{width:100%;border-collapse:separate;border-spacing:0}
.table,.table-modern{min-width:100%}
.table-modern thead th,.table thead th{position:sticky;top:0;background:#f4f8f6;color:#3f5b53;font-size:.78rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;text-align:left;padding:16px 18px;border-bottom:1px solid var(--border);white-space:nowrap}
.table-modern tbody td,.table tbody td{padding:17px 18px;border-bottom:1px solid #edf2ef;vertical-align:top;background:#fff;color:var(--text)}
.table-modern tbody tr:nth-child(even) td,.table tbody tr:nth-child(even) td{background:#fcfefd}
.table-modern tbody tr:hover td,.table tbody tr:hover td{background:#f6fbf8}
.table-modern tbody tr:last-child td,.table tbody tr:last-child td{border-bottom:0}
.table-modern th[data-sortable="true"],.table-modern th:not([data-no-sort="1"]),.table th:not([data-no-sort="1"]){cursor:pointer}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:46px;padding:0 18px;border:1px solid var(--primary);background:var(--primary);color:#08362d;border-radius:14px;font-weight:800;cursor:pointer;transition:transform var(--transition),box-shadow var(--transition),background var(--transition),border-color var(--transition),color var(--transition)}
.btn:hover{transform:translateY(-1px);box-shadow:0 12px 24px rgba(52,211,153,.16)}
.btn-primary{background:var(--primary);border-color:var(--primary);color:#08362d}
.btn-secondary,.btn-link{background:#fff;border-color:var(--border);color:var(--text)}
.btn-secondary:hover,.btn-link:hover{border-color:var(--border-strong);box-shadow:var(--shadow-xs)}
.btn-danger{background:#fff;border-color:#efc7c4;color:var(--danger)}
.btn-danger:hover{background:var(--danger-soft);box-shadow:none}
.btn-accent{background:#fff;border-color:#cfe8e5;color:var(--accent)}
.btn-accent:hover{background:#f2faf9;box-shadow:none}
.btn-sm{min-height:38px;padding:0 14px;border-radius:12px;font-size:.89rem}
.btn-block{width:100%}

.badge{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;font-size:.78rem;font-weight:700;border:1px solid transparent}
.badge-light,.badge-muted{background:var(--surface-3);border-color:var(--border);color:#48675d}
.badge-success{background:var(--success-soft);border-color:#cdebdc;color:var(--success)}
.badge-danger{background:var(--danger-soft);border-color:#f0d1cf;color:var(--danger)}
.badge-warning{background:var(--warning-soft);border-color:#efdfb6;color:#93651f}
.badge-accent{background:#eef9f8;border-color:#cde8e5;color:var(--accent)}

.alert{padding:16px 18px;border-radius:18px;border:1px solid var(--border);background:#fff;box-shadow:var(--shadow-xs)}
.alert-success{background:var(--success-soft);border-color:#cceadb;color:#1d7a54}
.alert-error,.alert-danger{background:var(--danger-soft);border-color:#efd3d1;color:#9b3b35}
.alert-warning{background:var(--warning-soft);border-color:#efdfb6;color:#8a5d1a}

.filter-bar,.form-grid{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:16px}
.form-group,.field{display:grid;gap:8px}
.form-group label,.field label{font-size:.79rem;font-weight:800;color:#48665d;letter-spacing:.08em;text-transform:uppercase}
.form-group input,.form-group select,.form-group textarea,.field .input,.input,.select,select,input,textarea{width:100%;padding:13px 14px;border-radius:14px;border:1px solid var(--border);background:#fbfdfb;color:var(--text);outline:none;transition:border-color var(--transition),box-shadow var(--transition),background var(--transition)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus,.field .input:focus,.input:focus,.select:focus,select:focus,input:focus,textarea:focus{border-color:#95ddbc;box-shadow:0 0 0 4px rgba(52,211,153,.11);background:#fff}
.form-group textarea,.field textarea,textarea{min-height:140px;resize:vertical}
.checkbox-row{display:inline-flex;gap:10px;align-items:center;font-size:.96rem;color:var(--text);font-weight:600}
.checkbox-row input{width:18px;height:18px;margin:0}
.form-group-full{grid-column:1 / -1}
.cols-1{grid-template-columns:1fr}.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.span-2{grid-column:span 2}.span-3{grid-column:span 3}.span-4{grid-column:span 4}.span-5{grid-column:span 5}.span-6{grid-column:span 6}.span-8{grid-column:span 8}.span-12{grid-column:span 12}
.field-help{font-size:.88rem;line-height:1.6}

.empty-state{display:grid;place-items:center;min-height:240px;padding:26px;text-align:center;background:var(--surface-3);border:1px dashed var(--border-strong);border-radius:22px}
.empty-state.compact{min-height:0;padding:18px}
.empty-state-icon{width:64px;height:64px;margin:0 auto 16px;display:grid;place-items:center;background:#fff;border:1px solid var(--border);border-radius:18px;font-size:1.35rem;color:var(--accent)}

.feature-list,.quick-links,.master-menu{display:grid;gap:14px}
.feature-item,.quick-link,.master-menu-item{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:18px;border-radius:20px;border:1px solid var(--border);background:#fff;transition:background var(--transition),border-color var(--transition),transform var(--transition),box-shadow var(--transition)}
.quick-link:hover,.master-menu-item:hover,.feature-item:hover{background:var(--surface-3);border-color:var(--border-strong);transform:translateY(-1px);box-shadow:var(--shadow-xs)}
.master-menu-item.is-active{background:var(--primary-soft);border-color:#a9e6cc}
.feature-icon{width:44px;height:44px;display:grid;place-items:center;border-radius:14px;background:var(--surface-3);border:1px solid var(--border);font-weight:800;color:var(--accent)}
.feature-title,.quick-link-title{display:block;font-size:1.02rem;font-weight:800;color:var(--text)}
.feature-desc,.quick-link-desc{display:block;margin-top:4px;font-size:.94rem;line-height:1.68;color:var(--text-soft)}
.quick-link::after{content:"→";font-weight:800;color:var(--text-faint)}
.master-sidebar-head{display:grid;gap:12px;margin-bottom:16px}
.master-hero{display:grid;gap:18px;padding:24px;border-radius:26px;background:#fff;border:1px solid var(--border);box-shadow:var(--shadow-xs)}
.master-hero-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.master-hero-item{padding:18px;border-radius:18px;background:var(--surface-3);border:1px solid var(--border)}
.master-hero-label{font-size:.76rem;font-weight:800;color:var(--text-faint);text-transform:uppercase;letter-spacing:.08em}
.master-hero-value{margin:10px 0 0;font-size:1.12rem;font-weight:800}
.premium-solid-muted{background:var(--surface-3)}

.hero-calendar-note,.calendar-hero{display:grid;gap:18px}
.calendar-shell{display:grid;grid-template-columns:minmax(0,1fr) 380px;gap:20px;align-items:start}
.calendar-main,.calendar-side{display:grid;gap:18px}
.calendar-toolbar-card,.calendar-board-card,.agenda-card{padding:24px}
.calendar-toolbar{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap;margin-bottom:18px}
.calendar-nav{display:flex;gap:10px;flex-wrap:wrap}
.calendar-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-top:18px}
.calendar-stat{padding:16px 18px;border-radius:18px;background:var(--surface-3);border:1px solid var(--border);display:grid;gap:8px}
.calendar-stat span{font-size:.75rem;font-weight:800;color:var(--text-faint);letter-spacing:.08em;text-transform:uppercase}
.calendar-stat strong{font-size:1.2rem;color:var(--text)}
.calendar-legend{display:flex;gap:16px;flex-wrap:wrap;align-items:center;margin-top:18px}
.legend-item{display:inline-flex;gap:8px;align-items:center;color:var(--text-soft);font-weight:600}
.legend-dot{width:10px;height:10px;border-radius:50%}.legend-dot.published{background:var(--primary)}.legend-dot.draft{background:#f0c36a}.legend-dot.unassigned{background:#c8d7cf}
.calendar-weekdays{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:10px;margin-bottom:10px}
.calendar-weekdays>div{padding:12px 10px;border-radius:14px;background:var(--surface-3);border:1px solid var(--border);font-size:.82rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:#45655c;text-align:center}
.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:10px}
.calendar-cell{display:grid;gap:12px;min-height:176px;padding:14px;border-radius:20px;background:#fff;border:1px solid var(--border);box-shadow:var(--shadow-xs);transition:border-color var(--transition),box-shadow var(--transition),transform var(--transition)}
.calendar-cell:hover{transform:translateY(-1px);border-color:#b7d7c7;box-shadow:var(--shadow-sm)}
.calendar-cell.is-out-month{background:#f8fbf9;opacity:.7}
.calendar-cell.is-today{border-color:#9de2bf;box-shadow:0 0 0 3px rgba(52,211,153,.10)}
.calendar-cell.is-selected{border-color:#34d399;box-shadow:0 0 0 4px rgba(52,211,153,.12)}
.calendar-cell-head{display:flex;justify-content:space-between;align-items:center;gap:10px}
.calendar-day{font-weight:800;font-size:1rem;color:var(--text)}
.calendar-day-count{display:inline-flex;min-width:28px;height:28px;padding:0 9px;align-items:center;justify-content:center;border-radius:999px;background:var(--surface-3);border:1px solid var(--border);font-size:.78rem;font-weight:800;color:#3f6157}
.calendar-cell-body{display:grid;gap:8px;align-content:start}
.calendar-empty{color:var(--text-faint);font-size:.9rem}
.calendar-pill{display:grid;gap:2px;padding:10px 12px;border-radius:14px;border:1px solid var(--border);background:var(--surface-3);font-size:.82rem;line-height:1.4;color:#39564d}
.calendar-pill strong{font-size:.78rem;color:#1a4035}
.calendar-pill.published{border-color:#b8ead0;background:var(--primary-soft)}
.calendar-pill.draft{border-color:#ecd7ab;background:#fff8ea}
.calendar-pill.unassigned{border-color:#d9e4de;background:#f7faf8}
.calendar-more{font-size:.82rem;color:var(--text-soft);font-weight:700;padding:2px 2px 0}
.agenda-head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;margin-bottom:16px}
.agenda-title{margin:10px 0 0;font-size:1.5rem;line-height:1.15;font-weight:800;letter-spacing:-.03em}
.agenda-subtitle{margin:8px 0 0;color:var(--text-soft);line-height:1.7}
.agenda-list{display:grid;gap:12px}
.agenda-item{display:grid;grid-template-columns:94px minmax(0,1fr);gap:14px;padding:16px;border-radius:18px;background:var(--surface-3);border:1px solid var(--border)}
.agenda-time{display:grid;gap:4px;align-content:start;padding:10px 12px;border-radius:16px;background:#fff;border:1px solid var(--border);font-weight:800;font-size:.95rem;color:var(--accent)}
.agenda-time span{font-size:.84rem;color:var(--text-soft)}
.agenda-body{display:grid;gap:8px}
.agenda-main{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.agenda-meta{margin:0;color:var(--text-soft);line-height:1.65}
.agenda-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:4px}
.calendar-mini-link{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 20px;border-radius:20px;border:1px solid var(--border);background:var(--surface-3);font-weight:700;min-width:300px}
.calendar-mini-link small{line-height:1.6}

.profile-shell,.profile-grid{display:grid;gap:18px}
.profile-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.profile-summary{display:grid;grid-template-columns:auto minmax(0,1fr);gap:18px;align-items:center}
.profile-summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
.profile-summary-grid div{padding:14px 16px;border-radius:18px;background:var(--surface-3);border:1px solid var(--border)}
.profile-summary-grid span{display:block;font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--text-faint)}
.profile-summary-grid strong{display:block;margin-top:8px;font-size:1rem}
.profile-meta{display:grid;gap:8px}.profile-name{margin:0;font-size:1.42rem;font-weight:800}.profile-role{color:var(--text-soft)}

.auth-body{background:var(--bg)}
.auth-shell{min-height:100vh;display:grid;place-items:center;padding:28px}
.auth-layout{width:min(1280px,100%);display:grid;grid-template-columns:1.08fr .92fr;gap:22px}
.auth-showcase{background:#103229;color:#f5fbf8;border-color:#173d33}
.auth-kicker{display:inline-flex;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.09);font-size:.78rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:#eef8f4}
.auth-title{margin:18px 0 12px;font-size:clamp(2.2rem,3vw,3.4rem);line-height:1.08;font-weight:800;letter-spacing:-.05em;color:#fff}
.auth-lead{margin:0;color:rgba(245,251,248,.78);font-size:1.02rem;line-height:1.85}
.auth-metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:24px}
.auth-metric{padding:16px;border-radius:20px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.07)}
.auth-metric-value{margin:0;font-size:1.1rem;font-weight:800;color:#fff}
.auth-metric-label{margin-top:8px;color:rgba(245,251,248,.72);line-height:1.65}
.auth-points{display:grid;gap:14px;margin-top:22px}
.auth-point{display:flex;gap:14px;align-items:flex-start;padding:16px;border-radius:20px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07)}
.auth-point-icon{width:40px;height:40px;display:grid;place-items:center;border-radius:14px;background:rgba(52,211,153,.14);color:#e8fff6;font-weight:800}
.auth-panel-head{margin-bottom:20px}.auth-panel-title{margin:10px 0 6px;font-size:2rem;line-height:1.1;font-weight:800;letter-spacing:-.04em}.auth-panel-subtitle{margin:0;color:var(--text-soft);line-height:1.75}
.auth-note{margin-top:22px;padding:18px;border-radius:20px;background:var(--surface-3);border:1px solid var(--border)}
.auth-meta-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:12px}
.auth-meta-item{padding:14px 16px;border-radius:16px;background:#fff;border:1px solid var(--border)}
.auth-meta-item span{display:block;font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-faint);font-weight:800}
.auth-meta-item strong{display:block;margin-top:6px}

.cookie-consent{position:fixed;left:18px;right:18px;bottom:18px;z-index:60}
.cookie-consent__inner{display:flex;justify-content:space-between;gap:18px;align-items:center;flex-wrap:wrap;padding:16px 18px;border-radius:18px;background:rgba(15,45,38,.96);color:#f3fbf7;box-shadow:var(--shadow-md)}
.cookie-consent__text strong{display:block;margin-bottom:4px}.cookie-consent__text p{margin:0;color:rgba(243,251,247,.82)}
.cookie-consent .btn{background:var(--primary);border-color:var(--primary);color:#063229}

.error-shell{display:grid;place-items:center;min-height:70vh}.error-card{max-width:640px;text-align:center}.error-code{font-size:4rem;line-height:1;font-weight:900;letter-spacing:-.05em;margin:0 0 12px}
.error-title{margin:0 0 10px;font-size:2rem;font-weight:800}.error-text{margin:0;color:var(--text-soft)}

@media (max-width: 1260px){
  .kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .premium-hero-grid,.panel-split,.calendar-shell,.grid-master,.profile-grid,.auth-layout{grid-template-columns:1fr}
  .calendar-stats,.academic-summary-grid,.profile-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width: 980px){
  .app-shell{grid-template-columns:1fr}
  .app-sidebar{position:fixed;left:0;top:0;bottom:0;width:300px;transform:translateX(-100%);transition:transform var(--transition);z-index:40}
  body.sidebar-open .app-sidebar{transform:translateX(0)}
  .sidebar-toggle{display:grid;place-items:center}
  .app-main-inner{width:min(var(--page-width),calc(100% - 24px));padding-top:18px}
  .calendar-weekdays{display:none}
}
@media (max-width: 760px){
  .kpi-grid,.master-hero-grid,.calendar-stats,.profile-summary-grid,.academic-summary-grid,.auth-metrics,.auth-meta-grid{grid-template-columns:1fr}
  .filter-bar,.form-grid,.cols-2{grid-template-columns:1fr}
  .span-2,.span-3,.span-4,.span-5,.span-6,.span-8,.span-12{grid-column:auto}
  .page-title{font-size:1.78rem}
  .card,.card-form,.list-card,.card-hero,.calendar-toolbar-card,.calendar-board-card,.agenda-card,.profile-summary,.auth-panel,.auth-showcase{padding:20px}
  .topbar-group,.hero-actions,.actions-inline,.form-actions,.toolbar,.page-section-head{width:100%}
  .calendar-grid{grid-template-columns:1fr}
  .agenda-item{grid-template-columns:1fr}
  .cookie-consent{left:12px;right:12px;bottom:12px}
}
