:root{--color-primary: #4b3b8b;--color-primary-strong: #3e3175;--color-primary-soft: #f1eefb;--color-primary-tint: rgba(75, 59, 139, .12);--color-text: #505050;--color-text-strong: #2f2f2f;--color-text-muted: #6f6f6f;--color-text-soft: #8b8b8b;--color-bg: #f5f5f5;--color-surface: #ffffff;--color-surface-subtle: #fafafa;--color-border: #d9d9d9;--color-border-strong: #cacaca;--color-success-bg: #eaf7ef;--color-success-text: #17623b;--color-warning-bg: #fff5de;--color-warning-text: #9a6700;--color-danger-bg: #fff1f2;--color-danger-text: #b42318;--color-info-bg: #eef4ff;--color-info-text: #3d4f91;--font-family-base: "Plus Jakarta Sans", "Segoe UI", "Helvetica Neue", Arial, sans-serif;--font-family-display: "Plus Jakarta Sans", "Segoe UI", "Helvetica Neue", Arial, sans-serif;--font-size-caption: .75rem;--font-size-label: .8125rem;--font-size-body: .9375rem;--font-size-section: 1.125rem;--font-size-title: clamp(1.85rem, 2vw, 2.55rem);--space-2xs: .25rem;--space-xs: .5rem;--space-sm: .75rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 2.5rem;--space-3xl: 3rem;--radius-sm: 10px;--radius-md: 14px;--radius-lg: 20px;--radius-xl: 28px;--radius-pill: 999px;--shadow-xs: 0 1px 3px rgba(17, 24, 39, .06);--shadow-sm: 0 12px 28px rgba(17, 24, 39, .05);--shadow-md: 0 18px 40px rgba(17, 24, 39, .08);--shadow-lg: 0 30px 70px rgba(17, 24, 39, .12);--transition-fast: .16s ease;--transition-normal: .24s ease;--input-height: 48px;--button-height: 46px;--focus-ring: 0 0 0 4px rgba(75, 59, 139, .12);--content-max: 1240px}*{margin:0;padding:0;box-sizing:border-box}html{height:100%;scroll-behavior:smooth;font-family:var(--font-family-base)}body{min-height:100%;font-family:inherit;font-optical-sizing:auto;font-size:var(--font-size-body);line-height:1.5;background:radial-gradient(circle at top left,rgba(75,59,139,.08),transparent 24%),linear-gradient(180deg,#fafafa 0%,var(--color-bg) 100%);color:var(--color-text);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}body,button,input,select,textarea{font:inherit}app-root{display:block;min-height:100%;font-family:inherit;color:inherit}img{display:block;max-width:100%}lucide-angular,lucide-icon,i-lucide,span-lucide{display:inline-flex;align-items:center;justify-content:center;line-height:0;flex-shrink:0}a{color:inherit;text-decoration:none;transition:color var(--transition-fast),opacity var(--transition-fast)}button{background:none}::selection{background:#4b3b8b29}:focus-visible{outline:none;box-shadow:var(--focus-ring)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:#efefef}::-webkit-scrollbar-thumb{background:#50505059;border-radius:999px}::-webkit-scrollbar-thumb:hover{background:#5050508c}.app-frame{min-height:100vh;display:grid;grid-template-columns:280px minmax(0,1fr)}.app-frame.app-frame-auth{grid-template-columns:minmax(0,1fr)}.app-sidebar{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;gap:var(--space-xl);padding:var(--space-xl) var(--space-lg);background:#fffffff5;border-right:1px solid rgba(217,217,217,.9);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:18px 0 38px #1118270a}.sidebar-brand{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);border:1px solid rgba(75,59,139,.12);border-radius:var(--radius-lg);background:linear-gradient(180deg,#4b3b8b14,#fffffff5)}.sidebar-brand-mark{width:clamp(40px,4vw,46px);height:clamp(40px,4vw,46px);display:grid;place-items:center;padding:8px;flex-shrink:0;border-radius:12px;background:#fffffff5;border:1px solid rgba(75,59,139,.12);box-shadow:0 14px 24px #4b3b8b33}.sidebar-brand-logo{width:100%;height:100%;display:block;object-fit:contain}.sidebar-brand-copy{min-width:0;display:flex;flex-direction:column;gap:2px}.sidebar-overline,.sidebar-section-title,.page-eyebrow,.page-meta-label,.auth-kicker,.table-caption,.detail-label{font-size:var(--font-size-caption);letter-spacing:.12em;text-transform:uppercase}.sidebar-overline,.sidebar-section-title,.page-eyebrow,.page-meta-label,.auth-kicker,.table-caption,.detail-label{color:var(--color-text-soft)}.sidebar-brand strong{display:block;font-family:var(--font-family-display);font-size:1.05rem;color:var(--color-text-strong);line-height:1.2}.sidebar-nav-group{display:flex;flex-direction:column;gap:var(--space-sm)}.sidebar-nav{display:flex;flex-direction:column;gap:6px}.sidebar-link{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:var(--radius-md);color:var(--color-text-muted);font-weight:600;transition:background var(--transition-fast),color var(--transition-fast),transform var(--transition-fast)}.sidebar-link:hover{background:#5050500d;color:var(--color-text-strong);transform:translate(2px)}.sidebar-link.active{background:#4b3b8b1a;color:var(--color-primary)}.sidebar-link-icon{width:34px;height:34px;display:grid;place-items:center;border-radius:12px;background:#5050500f;font-size:0;color:currentColor;flex-shrink:0}.sidebar-link.active .sidebar-link-icon{background:#4b3b8b24}.sidebar-footer{margin-top:auto;display:flex;flex-direction:column;gap:var(--space-md);padding:clamp(14px,2.2vw,18px);border:1px solid var(--color-border);border-radius:var(--radius-lg);background:linear-gradient(180deg,#fffffffa,#f5f5f5eb);box-shadow:var(--shadow-xs)}.sidebar-session-card{display:flex;align-items:center;gap:var(--space-sm);padding:12px;border-radius:var(--radius-md);border:1px solid rgba(75,59,139,.08);background:#4b3b8b0a}.sidebar-session-avatar{width:42px;height:42px;min-width:42px;display:grid;place-items:center;flex-shrink:0;border-radius:14px;background:linear-gradient(180deg,#4b3b8b1f,#4b3b8b2e);color:var(--color-primary)}.page-meta.sidebar-session-meta{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1;margin:0;padding:0;background:transparent}.sidebar-session-kicker{font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-soft)}.sidebar-footer strong{display:block;margin-top:0;color:var(--color-text-strong);line-height:1.25;overflow-wrap:anywhere}.sidebar-session-meta .page-meta-caption{word-break:break-word;line-height:1.35}.sidebar-footer .btn{width:100%}.btn.btn-sidebar-logout{justify-content:flex-start;border-color:#d9d9d9f0;background:#5050500a;color:var(--color-text-strong)}.btn.btn-sidebar-logout:hover:not(:disabled){border-color:#4b3b8b2e;background:#4b3b8b0f;color:var(--color-primary)}.app-main{min-width:0;padding:var(--space-lg)}.app-main.app-main-auth{padding:0}.content-shell{width:min(100%,var(--content-max));margin:0 auto;display:flex;flex-direction:column;gap:var(--space-lg)}.page-topbar,.section-card,.table-card,.student-summary-card,.detail-card,.metric-card,.action-card{background:#fffffff0;border:1px solid rgba(217,217,217,.92);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.page-topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-lg);padding:clamp(22px,3vw,30px)}.page-heading{display:flex;flex-direction:column;gap:var(--space-xs)}.page-heading h1,.auth-title,.student-summary-main h2{font-family:var(--font-family-display);color:var(--color-text-strong)}.page-heading h1{font-size:var(--font-size-title);line-height:1.08}.page-heading p,.section-card-heading p,.form-block-header p,.auth-copy,.page-meta-caption,.empty-state p,.loading-state p{color:var(--color-text-muted)}.page-actions{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap;justify-content:flex-end}.page-meta{min-width:220px;display:flex;flex-direction:column;gap:4px;padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);border:1px solid rgba(75,59,139,.12);background:#4b3b8b0d}.page-meta strong{color:var(--color-text-strong);font-size:1rem}.btn{min-height:var(--button-height);padding:0 18px;display:inline-flex;align-items:center;justify-content:center;gap:10px;border:1px solid transparent;border-radius:var(--radius-md);cursor:pointer;font-weight:700;transition:transform var(--transition-fast),border-color var(--transition-fast),background var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast)}.btn:hover:not(:disabled){transform:translateY(-1px)}.btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.btn-primary{background:var(--color-primary);color:#fff;box-shadow:0 14px 28px #4b3b8b2e}.btn-primary:hover:not(:disabled){background:var(--color-primary-strong)}.btn-secondary{background:#4b3b8b14;border-color:#4b3b8b24;color:var(--color-primary)}.btn-secondary:hover:not(:disabled){background:#4b3b8b24}.btn-neutral{background:var(--color-surface);border-color:var(--color-border);color:var(--color-text-strong)}.btn-neutral:hover:not(:disabled){border-color:var(--color-border-strong);background:var(--color-surface-subtle)}.btn-danger{background:var(--color-danger-bg);border-color:#b423181f;color:var(--color-danger-text)}.btn-danger:hover:not(:disabled){background:#ffe7ea}.btn-ghost{background:transparent;border-color:transparent;color:var(--color-text-muted)}.btn-ghost:hover:not(:disabled){background:#5050500f;color:var(--color-text-strong)}.btn-small{min-height:38px;padding:0 14px;font-size:.85rem}.btn-block{width:100%}.btn-icon{min-height:36px;padding:0 12px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--color-border);border-radius:var(--radius-pill);background:transparent;color:var(--color-text);cursor:pointer;font-size:.85rem;font-weight:700;white-space:nowrap;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast),transform var(--transition-fast)}.btn-icon:hover{background:#4b3b8b12;border-color:#4b3b8b33;color:var(--color-primary);transform:translateY(-1px)}.section-card,.table-card,.student-summary-card{padding:clamp(22px,2vw,28px)}.section-card-header,.table-toolbar{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-md);flex-wrap:wrap}.section-card-header{margin-bottom:var(--space-lg)}.section-card-heading{display:flex;flex-direction:column;gap:6px}.section-card-heading h2,.form-block-header h3,.auth-form-header h2,.present-section-title,.history-section-title{font-family:var(--font-family-display);font-size:var(--font-size-section);color:var(--color-text-strong)}.inline-badge,.status-badge{display:inline-flex;align-items:center;justify-content:center;min-height:32px;padding:0 12px;border-radius:var(--radius-pill);font-size:.77rem;font-weight:700;letter-spacing:.04em}.inline-badge{background:#4b3b8b14;color:var(--color-primary)}.status-badge{border:1px solid transparent}.status-active,.status-paid{background:var(--color-success-bg);color:var(--color-success-text)}.status-inactive,.status-overdue,.status-cancelled{background:var(--color-danger-bg);color:var(--color-danger-text)}.status-suspended,.status-pending{background:var(--color-warning-bg);color:var(--color-warning-text)}.status-preview{min-height:var(--input-height);justify-content:flex-start;border-radius:var(--radius-md)}.error-banner{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding:16px 18px;border-radius:var(--radius-md);border:1px solid rgba(180,35,24,.18);background:var(--color-danger-bg);color:var(--color-danger-text);font-weight:600}.success-banner{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding:16px 18px;border-radius:var(--radius-md);border:1px solid rgba(23,98,59,.18);background:var(--color-success-bg);color:var(--color-success-text);font-weight:600}.loading-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-xs);min-height:170px;text-align:center}.metric-grid{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:var(--space-md)}.metric-card{min-height:170px;grid-column:span 4;padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-sm);transition:transform var(--transition-normal),box-shadow var(--transition-normal),border-color var(--transition-normal)}.metric-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:#4b3b8b24}.metric-card--accent{background:linear-gradient(180deg,#4b3b8bf0,#4b3b8bd6);color:#fff;border-color:transparent}.metric-card--accent .metric-label,.metric-card--accent .metric-detail,.metric-card--accent .metric-chip{color:#ffffffd6}.metric-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm)}.metric-label,.metric-detail{color:var(--color-text-muted)}.metric-label{font-size:var(--font-size-caption);text-transform:uppercase;letter-spacing:.1em}.metric-chip{display:inline-flex;align-items:center;gap:8px;padding:8px 10px;border-radius:12px;background:#5050500f;font-size:.72rem;font-weight:700;color:var(--color-text-soft)}.metric-card--accent .metric-chip{background:#ffffff1f}.metric-value{font-family:var(--font-family-display);font-size:clamp(1.85rem,3vw,2.55rem);line-height:1.05;color:inherit}.quick-actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--space-md)}.action-card{padding:var(--space-lg);display:flex;align-items:flex-start;gap:var(--space-md);cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast),border-color var(--transition-fast)}.action-card:hover{transform:translateY(-2px);border-color:#4b3b8b2e;box-shadow:var(--shadow-md)}.action-card-tag{min-width:42px;height:42px;display:grid;place-items:center;border-radius:14px;background:#4b3b8b14;color:var(--color-primary);font-size:0;font-weight:700}.action-card h3{color:var(--color-text-strong);font-family:var(--font-family-display);font-size:1rem}.action-card p{margin-top:4px;color:var(--color-text-muted)}.form-section-stack{display:flex;flex-direction:column;gap:var(--space-lg)}.form-block{padding:var(--space-lg);border:1px solid rgba(217,217,217,.92);border-radius:var(--radius-md);background:linear-gradient(180deg,#fffffffa,#fafafaeb)}.form-block-header{display:flex;flex-direction:column;gap:4px;margin-bottom:var(--space-md)}.form-grid{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:var(--space-md)}.form-grid--two .form-group{grid-column:span 6}.form-grid--three .form-group{grid-column:span 4}.form-grid--four .form-group{grid-column:span 3}.form-group{display:flex;flex-direction:column;gap:8px}.form-group--span-2{grid-column:span 8}.form-group--span-full{grid-column:1/-1}.form-group label,.checkbox-label{color:var(--color-text-strong);font-size:var(--font-size-label);font-weight:700}.form-hint{color:var(--color-text-soft);font-size:var(--font-size-caption)}.form-control{width:100%;min-height:var(--input-height);padding:0 14px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text-strong);transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast)}.form-control:hover{border-color:var(--color-border-strong)}.form-control:focus{border-color:var(--color-primary);box-shadow:var(--focus-ring)}.form-control::placeholder{color:#a5a5a5}.form-control[readonly]{background:#f8f8f8;color:var(--color-text-muted)}textarea.form-control{min-height:120px;padding:12px 14px;resize:vertical}input[type=checkbox]{accent-color:var(--color-primary)}.form-control.is-invalid,.form-control.ng-invalid.ng-touched{border-color:#b4231899;box-shadow:0 0 0 4px #b4231814}.error-message{color:var(--color-danger-text);font-size:var(--font-size-caption)}.checkbox-label{display:inline-flex;align-items:center;gap:10px;min-height:var(--input-height)}.form-actions,.pagination-bar,.actions{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap}.form-actions{justify-content:flex-end}.table-card{padding:0;overflow:hidden}.table-toolbar{padding:var(--space-lg);border-bottom:1px solid rgba(217,217,217,.9)}.data-table-wrapper{overflow:auto}.data-table{width:100%;border-collapse:separate;border-spacing:0}.data-table thead th{position:relative;padding:16px 20px;background:#f5f5f5eb;color:var(--color-text-soft);text-align:left;font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;white-space:nowrap}.data-table tbody td{padding:18px 20px;border-top:1px solid rgba(217,217,217,.75);color:var(--color-text);vertical-align:middle}.data-table tbody tr{transition:background var(--transition-fast)}.data-table tbody tr:hover{background:#4b3b8b09}.data-table a{color:var(--color-primary);font-weight:700}.data-table a:hover{color:var(--color-primary-strong)}.contact-stack{display:flex;flex-direction:column;gap:4px}.pagination-bar{justify-content:center;padding:var(--space-lg);background:#fffffff0;border:1px solid rgba(217,217,217,.92);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.auth-shell{min-height:100vh;padding:clamp(20px,4vw,38px);display:grid;place-items:center;background:radial-gradient(circle at top left,rgba(75,59,139,.16),transparent 28%),radial-gradient(circle at bottom right,rgba(75,59,139,.1),transparent 26%),linear-gradient(180deg,#f8f7fb,#efedf6 42%,#f5f5f5)}.auth-card{width:min(100%,1120px);display:grid;grid-template-columns:minmax(280px,.95fr) minmax(360px,1fr);border-radius:var(--radius-xl);overflow:hidden;border:1px solid rgba(217,217,217,.84);background:#fffffff0;box-shadow:var(--shadow-lg)}.auth-panel{padding:clamp(28px,4vw,42px)}.auth-panel--brand{display:flex;flex-direction:column;justify-content:space-between;gap:var(--space-2xl);background:linear-gradient(180deg,#4b3b8bf5,#4b3b8bd1);color:#fff}.auth-panel--brand .auth-kicker,.auth-panel--brand .auth-copy,.auth-panel--brand li{color:#ffffffd1}.auth-title{font-size:clamp(2rem,4vw,3rem);line-height:1.04}.auth-copy{margin-top:var(--space-md);max-width:40ch}.auth-support-card{padding:var(--space-lg);border-radius:var(--radius-lg);background:#ffffff1f;border:1px solid rgba(255,255,255,.16)}.auth-support-card strong{display:block;margin-bottom:var(--space-md)}.auth-feature-list{padding:0;list-style:none;display:flex;flex-direction:column;gap:var(--space-sm)}.auth-feature-list li{display:flex;align-items:flex-start;gap:12px}.auth-feature-list li lucide-angular{margin-top:2px}.auth-panel--form{display:flex;flex-direction:column;gap:var(--space-lg);justify-content:center}.auth-form-header{display:flex;flex-direction:column;gap:6px}.auth-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-md)}.auth-footer{color:var(--color-text-muted)}.auth-footer a{color:var(--color-primary);font-weight:700}.auth-footer a:hover{color:var(--color-primary-strong)}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--space-md)}.detail-card{padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-sm)}.detail-label{display:block}.detail-card-header{display:flex;align-items:center;gap:10px}.detail-card-icon{width:36px;height:36px;display:grid;place-items:center;border-radius:12px;background:#4b3b8b14;color:var(--color-primary)}.detail-value{color:var(--color-text-strong);font-size:1rem;font-weight:700}@media (max-width: 1180px){.metric-card{grid-column:span 6}}@media (max-width: 980px){.app-frame{grid-template-columns:minmax(0,1fr)}.app-sidebar{position:static;height:auto;border-right:none;border-bottom:1px solid rgba(217,217,217,.92)}.sidebar-footer{flex-direction:row;align-items:center;justify-content:space-between}.sidebar-session-card{flex:1;min-width:0}.sidebar-footer .btn{width:auto;min-width:118px;align-self:stretch}.auth-card{grid-template-columns:minmax(0,1fr)}}@media (max-width: 840px){.page-topbar,.section-card-header,.table-toolbar,.page-actions,.form-actions,.pagination-bar{align-items:stretch}.page-topbar,.section-card-header{flex-direction:column}.page-actions{justify-content:stretch}.page-meta{width:100%}.metric-card{grid-column:span 12}.form-grid--two .form-group,.form-grid--three .form-group,.form-grid--four .form-group,.form-group--span-2{grid-column:1/-1}.auth-form-grid{grid-template-columns:minmax(0,1fr)}}@media (max-width: 640px){.app-main{padding:var(--space-md)}.sidebar-brand{padding:12px}.sidebar-brand-mark{width:38px;height:38px;padding:7px}.sidebar-footer{flex-direction:column;align-items:stretch}.sidebar-footer .btn{width:100%;min-width:0}.auth-shell{padding:16px}.action-card{flex-direction:column}.error-banner{flex-direction:column;align-items:flex-start}.data-table thead th,.data-table tbody td{padding:14px 16px}}@media print{body{background:#fff}.app-sidebar,.btn,.btn-icon{display:none!important}}
