@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--color-primary-50: #F0FDFA;--color-primary-100: #CCFBF1;--color-primary-200: #99F6E4;--color-primary-300: #5EEAD4;--color-primary-400: #2DD4BF;--color-primary-500: #14B8A6;--color-primary-600: #0D9488;--color-primary: #0D9488;--color-primary-700: #0F766E;--color-primary-800: #115E59;--color-primary-900: #134E4A;--color-accent-50: #ECFDF5;--color-accent-100: #D1FAE5;--color-accent-200: #A7F3D0;--color-accent-300: #6EE7B7;--color-accent-400: #34D399;--color-accent-500: #10B981;--color-accent: #10B981;--color-accent-600: #059669;--color-accent-700: #047857;--color-accent-800: #065F46;--color-accent-900: #064E3B;--color-success: #22C55E;--color-success-50: #ECFDF5;--color-success-light: #DCFCE7;--color-success-dark: #15803D;--color-warning: #F59E0B;--color-warning-50: #FFFBEB;--color-warning-light: #FEF3C7;--color-warning-dark: #B45309;--color-error: #EF4444;--color-error-light: #FEE2E2;--color-error-dark: #B91C1C;--color-info: #3B82F6;--color-info-50: #EFF6FF;--color-info-light: #DBEAFE;--color-info-dark: #1D4ED8;--color-gray-50: #F9FAFB;--color-gray-100: #F3F4F6;--color-gray-200: #E5E7EB;--color-gray-300: #D1D5DB;--color-gray-400: #9CA3AF;--color-gray-500: #6B7280;--color-gray-600: #4B5563;--color-gray-700: #374151;--color-gray-800: #1F2937;--color-gray-900: #111827;--color-background: #F9FAFB;--color-surface: #FFFFFF;--color-text-primary: #111827;--color-text-secondary: #6B7280;--color-text-muted: #9CA3AF;--color-border: #E5E7EB;--color-border-light: #F3F4F6;--gradient-primary: linear-gradient(135deg, var(--color-primary) 0%, var(--color-accent) 100%);--gradient-primary-subtle: linear-gradient(135deg, var(--color-primary-100) 0%, var(--color-accent-100) 100%);--font-family-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, sans-serif;--font-family-mono: "JetBrains Mono", "Fira Code", "Consolas", monospace;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--space-0: 0;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px -1px rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);--shadow-primary: 0 4px 14px 0 rgba(13, 148, 136, .25);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-modal-backdrop: 400;--z-modal: 500;--z-tooltip: 600;--sidebar-width: 260px;--sidebar-collapsed-width: 72px;--header-height: 64px;--container-max-width: 1400px}@media(prefers-color-scheme:dark){:root.auto-dark{--color-background: #111827;--color-surface: #1F2937;--color-text-primary: #F9FAFB;--color-text-secondary: #D1D5DB;--color-text-muted: #9CA3AF;--color-border: #374151;--color-border-light: #4B5563}}*,*:before,*:after{box-sizing:border-box}*{margin:0;padding:0}html{-moz-text-size-adjust:none;-webkit-text-size-adjust:none;text-size-adjust:none}body{min-height:100vh;line-height:1.5;-webkit-font-smoothing:antialiased}h1,h2,h3,h4,h5,h6,button,input,label{line-height:1.1}h1,h2,h3,h4,h5,h6{text-wrap:balance}ul,ol{list-style:none}a:not([class]){text-decoration-skip-ink:auto;color:currentColor}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit}textarea:not([rows]){min-height:10em}:target{scroll-margin-block:5ex}@media(prefers-reduced-motion:reduce){html:focus-within{scroll-behavior:auto}*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}button{background:none;border:none;cursor:pointer}table{border-collapse:collapse;border-spacing:0}fieldset{border:none}legend{padding:0}summary{cursor:pointer}blockquote{margin:0}hr{border:none;border-top:1px solid;color:inherit;height:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-family-sans);font-size:var(--font-size-base);font-weight:var(--font-weight-normal);line-height:var(--line-height-normal);color:var(--color-text-primary);background-color:var(--color-background)}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-2)}h1{font-size:var(--font-size-4xl);line-height:var(--line-height-tight)}h2{font-size:var(--font-size-3xl);line-height:var(--line-height-tight)}h3{font-size:var(--font-size-2xl)}h4{font-size:var(--font-size-xl)}h5{font-size:var(--font-size-lg)}h6{font-size:var(--font-size-base)}p{margin-bottom:var(--space-4);color:var(--color-text-secondary)}p:last-child{margin-bottom:0}small{font-size:var(--font-size-sm)}strong,b{font-weight:var(--font-weight-semibold)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-700)}a:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;border-radius:var(--radius-sm)}code,pre,kbd,samp{font-family:var(--font-family-mono);font-size:.9em}code{background-color:var(--color-gray-100);padding:.125em .375em;border-radius:var(--radius-sm);color:var(--color-primary-700)}pre{background-color:var(--color-gray-900);color:var(--color-gray-100);padding:var(--space-4);border-radius:var(--radius-md);overflow-x:auto}pre code{background-color:transparent;padding:0;color:inherit}::selection{background-color:var(--color-primary-200);color:var(--color-primary-900)}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-gray-100)}::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-gray-400)}*{scrollbar-width:thin;scrollbar-color:var(--color-gray-300) var(--color-gray-100)}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}.text-muted{color:var(--color-text-muted)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-error{color:var(--color-error)}.text-info{color:var(--color-info)}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-base{font-size:var(--font-size-base)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.text-2xl{font-size:var(--font-size-2xl)}.text-3xl{font-size:var(--font-size-3xl)}.text-4xl{font-size:var(--font-size-4xl)}.font-normal{font-weight:var(--font-weight-normal)}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hidden{display:none}.block{display:block}.inline{display:inline}.inline-block{display:inline-block}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.m-0{margin:0}.m-1{margin:var(--space-1)}.m-2{margin:var(--space-2)}.m-3{margin:var(--space-3)}.m-4{margin:var(--space-4)}.m-6{margin:var(--space-6)}.m-8{margin:var(--space-8)}.mt-0{margin-top:0}.mt-1{margin-top:var(--space-1)}.mt-2{margin-top:var(--space-2)}.mt-3{margin-top:var(--space-3)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.mb-0{margin-bottom:0}.mb-1{margin-bottom:var(--space-1)}.mb-2{margin-bottom:var(--space-2)}.mb-3{margin-bottom:var(--space-3)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.p-0{padding:0}.p-1{padding:var(--space-1)}.p-2{padding:var(--space-2)}.p-3{padding:var(--space-3)}.p-4{padding:var(--space-4)}.p-6{padding:var(--space-6)}.p-8{padding:var(--space-8)}.items-start{align-items:flex-start}.items-center{align-items:center}.items-end{align-items:flex-end}.justify-start{justify-content:flex-start}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-between{justify-content:space-between}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.flex-shrink-0{flex-shrink:0}.gap-8{gap:var(--space-8)}.icon-box{display:flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:var(--radius-lg)}.icon-box-sm{width:20px;height:20px}.icon-box-sm svg{width:14px;height:14px}.icon-box-md{width:40px;height:40px}.icon-box-md svg{width:20px;height:20px}.icon-box-lg{width:48px;height:48px}.icon-box-lg svg{width:24px;height:24px}.icon-box-xl{width:64px;height:64px}.icon-box-xl svg{width:32px;height:32px}.icon-box-round{border-radius:var(--radius-full)}.state-success{--state-bg: var(--color-success-light);--state-color: var(--color-success);--state-border: var(--color-success)}.state-warning{--state-bg: var(--color-warning-light);--state-color: var(--color-warning);--state-border: var(--color-warning)}.state-error{--state-bg: var(--color-error-light);--state-color: var(--color-error);--state-border: var(--color-error)}.state-info{--state-bg: var(--color-info-light);--state-color: var(--color-info);--state-border: var(--color-info)}.state-muted{--state-bg: var(--color-gray-100);--state-color: var(--color-gray-400);--state-border: var(--color-gray-300)}.icon-box[class*=state-]{background-color:var(--state-bg);color:var(--state-color)}.card-base{background-color:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-xl)}.card-base-lg{border-radius:var(--radius-lg)}.card-pad-sm{padding:var(--space-3)}.card-pad-md{padding:var(--space-4)}.card-pad-lg{padding:var(--space-5)}.card-pad-xl{padding:var(--space-6)}.list-none{list-style:none;padding:0;margin:0}.list-vertical{display:flex;flex-direction:column}.list-horizontal{display:flex;flex-direction:row;flex-wrap:wrap}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-5{gap:var(--space-5)}.gap-6{gap:var(--space-6)}.indicator-left{border-left:4px solid var(--indicator-color, var(--color-gray-300))}.indicator-left.state-success{--indicator-color: var(--color-success)}.indicator-left.state-warning{--indicator-color: var(--color-warning)}.indicator-left.state-error{--indicator-color: var(--color-error)}.indicator-left.state-info{--indicator-color: var(--color-info)}.divider-bottom{border-bottom:1px solid var(--color-border-light)}.divider-top{border-top:1px solid var(--color-border-light)}.empty-state{text-align:center;padding:var(--space-8) var(--space-4);color:var(--color-text-muted);font-size:var(--font-size-sm)}.app{display:flex;min-height:100vh}.app-content{flex:1;display:flex;flex-direction:column;min-width:0}.sidebar{width:var(--sidebar-width);background-color:var(--color-surface);border-right:1px solid var(--color-border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:var(--z-fixed);transition:width var(--transition-base),transform var(--transition-base)}.sidebar-header{padding:var(--space-6);border-bottom:1px solid var(--color-border-light)}.sidebar-logo{display:flex;align-items:center;gap:var(--space-3);text-decoration:none}.sidebar-logo-icon{width:40px;height:40px;background:var(--gradient-primary);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.sidebar-logo-text{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-nav{flex:1;padding:var(--space-4);overflow-y:auto}.nav-section{margin-bottom:var(--space-6)}.nav-section-title{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;padding:var(--space-2) var(--space-3);margin-bottom:var(--space-2)}.nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-3);border-radius:var(--radius-lg);color:var(--color-text-secondary);text-decoration:none;transition:all var(--transition-fast);margin-bottom:var(--space-1)}.nav-item:hover{background-color:var(--color-gray-100);color:var(--color-text-primary)}.nav-item.active{background-color:var(--color-primary-50);color:var(--color-primary)}.nav-item.active .nav-icon{color:var(--color-primary)}.nav-icon{width:20px;height:20px;flex-shrink:0}.nav-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.nav-badge{margin-left:auto;background-color:var(--color-primary);color:#fff;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);padding:.125rem .5rem;border-radius:var(--radius-full);min-width:20px;text-align:center}.sidebar-footer{padding:var(--space-4);border-top:1px solid var(--color-border-light)}.user-menu{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-lg);cursor:pointer;transition:background-color var(--transition-fast)}.user-menu:hover{background-color:var(--color-gray-100)}.user-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);flex-shrink:0}.user-info{flex:1;min-width:0}.user-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:var(--font-size-xs);color:var(--color-text-muted)}.sidebar-logout-form{margin-left:auto;flex-shrink:0}.sidebar-logout-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;border-radius:var(--radius-md);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast)}.sidebar-logout-btn:hover{background-color:var(--color-gray-100);color:var(--color-error)}.portal-logout-form{margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--color-border-light)}.btn-portal-logout{display:flex;align-items:center;justify-content:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-3);border:none;background:transparent;border-radius:var(--radius-md);color:var(--color-text-muted);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-fast)}.btn-portal-logout:hover{background-color:var(--color-gray-100);color:var(--color-error)}.main{flex:1;margin-left:var(--sidebar-width);display:flex;flex-direction:column;min-height:100vh}.header{height:var(--header-height);background-color:var(--color-surface);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-6);position:sticky;top:0;z-index:var(--z-sticky)}.header-left{display:flex;align-items:center;gap:var(--space-4)}.header-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.header-breadcrumb{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);color:var(--color-text-muted)}.header-breadcrumb a{color:var(--color-text-secondary)}.header-breadcrumb a:hover{color:var(--color-primary)}.header-breadcrumb span{color:var(--color-text-primary)}.header-right{display:flex;align-items:center;gap:var(--space-3)}.header-search{position:relative;width:280px}.header-search input{width:100%;height:40px;padding:0 var(--space-4) 0 var(--space-10);background-color:var(--color-gray-100);border:1px solid transparent;border-radius:var(--radius-lg);font-size:var(--font-size-sm);color:var(--color-text-primary);transition:all var(--transition-fast)}.header-search input::placeholder{color:var(--color-text-muted)}.header-search input:focus{background-color:var(--color-surface);border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px var(--color-primary-100)}.header-search-icon{position:absolute;left:var(--space-3);top:50%;transform:translateY(-50%);width:20px;height:20px;color:var(--color-text-muted);pointer-events:none}.header-icon-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-lg);color:var(--color-text-secondary);transition:all var(--transition-fast);position:relative}.header-icon-btn:hover{background-color:var(--color-gray-100);color:var(--color-text-primary)}.header-icon-btn .icon{width:20px;height:20px}.notification-dot{position:absolute;top:8px;right:8px;width:8px;height:8px;background-color:var(--color-error);border-radius:var(--radius-full);border:2px solid var(--color-surface)}.page-content{flex:1;padding:var(--space-6);max-width:var(--container-max-width);width:100%}.container{width:100%;max-width:var(--container-max-width);margin:0 auto;padding:0 var(--space-4)}.container-sm{max-width:640px}.container-md{max-width:768px}.container-lg{max-width:1024px}.container-xl{max-width:1280px}.grid{display:grid;gap:var(--space-6)}.grid-cols-1{grid-template-columns:repeat(1,1fr)}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-6)}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-6)}.two-column{display:grid;grid-template-columns:2fr 1fr;gap:var(--space-6)}.section{margin-bottom:var(--space-8)}.section:last-child{margin-bottom:0}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.section-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.section-link{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-primary);display:flex;align-items:center;gap:var(--space-1)}.section-link:hover{color:var(--color-primary-700)}@media(max-width:1024px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main{margin-left:0}.stats-grid{grid-template-columns:repeat(2,1fr)}.two-column{grid-template-columns:1fr}.header-search{width:200px}}@media(max-width:640px){.page-content{padding:var(--space-4)}.stats-grid{grid-template-columns:1fr}.header{padding:0 var(--space-4)}.header-search{display:none}.header-title{font-size:var(--font-size-lg)}.card-grid{grid-template-columns:1fr}}.mobile-menu-toggle{display:none;width:40px;height:40px;align-items:center;justify-content:center;border-radius:var(--radius-lg);color:var(--color-text-secondary)}@media(max-width:1024px){.mobile-menu-toggle{display:flex}}.sidebar-overlay{display:none;position:fixed;inset:0;background-color:#00000080;z-index:calc(var(--z-fixed) - 1)}@media(max-width:1024px){.sidebar-overlay.active{display:block}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);line-height:1.5;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;text-decoration:none;border:1px solid transparent}.btn:disabled{opacity:.5;cursor:not-allowed}.btn .icon{width:18px;height:18px;flex-shrink:0}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--font-size-xs)}.btn-sm .icon{width:16px;height:16px}.btn-lg{padding:var(--space-3) var(--space-6);font-size:var(--font-size-base)}.btn-lg .icon{width:20px;height:20px}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover{opacity:.9;box-shadow:var(--shadow-primary);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background-color:var(--color-gray-100);color:var(--color-text-primary)}.btn-secondary:hover{background-color:var(--color-gray-200)}.btn-outline{background-color:transparent;border-color:var(--color-border);color:var(--color-text-primary)}.btn-outline:hover{background-color:var(--color-gray-50);border-color:var(--color-gray-300)}.btn-outline-primary{background-color:transparent;border-color:var(--color-primary);color:var(--color-primary)}.btn-outline-primary:hover{background-color:var(--color-primary-50)}.btn-ghost{background-color:transparent;color:var(--color-text-secondary)}.btn-ghost:hover{background-color:var(--color-gray-100);color:var(--color-text-primary)}.btn-danger{background-color:var(--color-error);color:#fff}.btn-danger:hover{background-color:var(--color-error-dark)}.btn-success{background-color:var(--color-success);color:#fff}.btn-success:hover{background-color:var(--color-success-dark)}.btn-icon{padding:var(--space-2);width:36px;height:36px}.btn-icon.btn-sm{width:28px;height:28px;padding:var(--space-1)}.btn-icon.btn-lg{width:44px;height:44px;padding:var(--space-3)}.btn-group{display:inline-flex}.btn-group .btn{border-radius:0}.btn-group .btn:first-child{border-radius:var(--radius-lg) 0 0 var(--radius-lg)}.btn-group .btn:last-child{border-radius:0 var(--radius-lg) var(--radius-lg) 0}.btn-group .btn:not(:last-child){border-right:1px solid rgba(255,255,255,.2)}.btn-block{display:flex;width:100%}.card{background-color:var(--color-surface);border-radius:var(--radius-xl);border:1px solid var(--color-border-light);box-shadow:var(--shadow-sm);transition:all var(--transition-base)}.card-hover:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-body{padding:var(--space-6)}.card-header{padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border-light)}.card-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border-light);background-color:var(--color-gray-50);border-radius:0 0 var(--radius-xl) var(--radius-xl)}.stat-card{background-color:var(--color-surface);border-radius:var(--radius-xl);padding:var(--space-6);border:1px solid var(--color-border-light);box-shadow:var(--shadow-sm);transition:all var(--transition-base)}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-3)}.stat-card-icon{--icon-bg: var(--color-gray-100);--icon-color: var(--color-gray-500);width:48px;height:48px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0;background-color:var(--icon-bg);color:var(--icon-color)}.stat-card-icon .icon{width:24px;height:24px}.stat-card-icon.primary{--icon-bg: var(--color-primary-100);--icon-color: var(--color-primary)}.stat-card-icon.success{--icon-bg: var(--color-success-light);--icon-color: var(--color-success)}.stat-card-icon.warning{--icon-bg: var(--color-warning-light);--icon-color: var(--color-warning)}.stat-card-icon.info{--icon-bg: var(--color-info-light);--icon-color: var(--color-info)}.stat-card-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-1)}.stat-card-value{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);line-height:1;margin-bottom:var(--space-2)}.stat-card-trend{display:inline-flex;align-items:center;gap:var(--space-1);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.stat-card-trend.up{color:var(--color-success)}.stat-card-trend.down{color:var(--color-error)}.stat-card-trend .icon{width:16px;height:16px}.stat-card-tinted{position:relative;overflow:hidden;border:1px solid rgba(0,0,0,.04)}.stat-card-tinted .stat-bg-icon{position:absolute;right:-5px;bottom:-5px;width:90px;height:90px;opacity:.08;pointer-events:none}.stat-card-tinted .stat-bg-icon svg{width:100%;height:100%;stroke-width:1.5}.stat-card-info{background:linear-gradient(135deg,var(--color-info-50) 0%,var(--color-surface) 40%)}.stat-card-success{background:linear-gradient(135deg,var(--color-success-50) 0%,var(--color-surface) 40%)}.stat-card-warning{background:linear-gradient(135deg,var(--color-warning-50) 0%,var(--color-surface) 40%)}.stat-card-primary{background:linear-gradient(135deg,var(--color-primary-50) 0%,var(--color-surface) 40%)}@media(prefers-color-scheme:dark){.stat-card-info{background:linear-gradient(135deg,rgba(59,130,246,.1) 0%,var(--color-surface) 40%)}.stat-card-success{background:linear-gradient(135deg,rgba(16,185,129,.1) 0%,var(--color-surface) 40%)}.stat-card-warning{background:linear-gradient(135deg,rgba(245,158,11,.1) 0%,var(--color-surface) 40%)}.stat-card-primary{background:linear-gradient(135deg,rgba(13,148,136,.1) 0%,var(--color-surface) 40%)}}.stat-card-clickable{cursor:pointer;transition:all var(--transition-base)}.stat-card-clickable:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-card-clickable.active{ring:2px;box-shadow:0 0 0 2px var(--color-primary),var(--shadow-md)}.stat-card-clickable.primary.active{box-shadow:0 0 0 2px var(--color-primary),var(--shadow-md)}.stat-card-clickable.success.active{box-shadow:0 0 0 2px var(--color-success),var(--shadow-md)}.stat-card-clickable.info.active{box-shadow:0 0 0 2px var(--color-info),var(--shadow-md)}.stat-card-clickable.warning.active{box-shadow:0 0 0 2px var(--color-warning),var(--shadow-md)}.student-card{background-color:var(--color-surface);border-radius:var(--radius-xl);padding:var(--space-5);border:1px solid var(--color-border-light);box-shadow:var(--shadow-sm);transition:all var(--transition-base);cursor:pointer;text-decoration:none;display:block}.student-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:var(--color-primary-200)}.student-card-header{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-4)}.student-avatar{width:48px;height:48px;border-radius:var(--radius-full);background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:var(--font-weight-semibold);font-size:var(--font-size-lg);flex-shrink:0}.student-avatar.large{width:80px;height:80px;font-size:var(--font-size-2xl)}.student-info{flex:1;min-width:0}.student-name{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.student-email{font-size:var(--font-size-sm);color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.student-card-body{display:flex;flex-direction:column;gap:var(--space-3)}.student-card-stat{display:flex;align-items:center;justify-content:space-between}.student-card-stat-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.student-card-stat-value{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.payment-card{background-color:var(--color-surface);border-radius:var(--radius-xl);padding:var(--space-5);border:1px solid var(--color-border-light)}.payment-card-header{margin-bottom:var(--space-4)}.payment-card-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.payment-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4);margin-bottom:var(--space-4)}.payment-summary-item{text-align:center}.payment-summary-label{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-bottom:var(--space-1)}.payment-summary-value{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold)}.payment-summary-value.collected{color:var(--color-success)}.payment-summary-value.pending{color:var(--color-warning)}.payment-summary-value.total{color:var(--color-text-primary)}.skill-card{background-color:var(--color-gray-50);border-radius:var(--radius-lg);padding:var(--space-4);border:1px solid var(--color-border-light)}.skill-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-3)}.skill-card-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.skill-card-level{font-size:var(--font-size-xs);color:var(--color-text-muted)}.skill-dots{display:flex;gap:var(--space-1)}.skill-dot{width:8px;height:8px;border-radius:var(--radius-full);background-color:var(--color-gray-200)}.skill-dot.filled{background-color:var(--color-primary)}.goal-card{background-color:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-4);border:1px solid var(--color-border-light);display:flex;align-items:flex-start;gap:var(--space-3)}.goal-checkbox{width:20px;height:20px;border-radius:var(--radius-sm);border:2px solid var(--color-gray-300);flex-shrink:0;display:flex;align-items:center;justify-content:center;margin-top:2px}.goal-checkbox.checked{background-color:var(--color-success);border-color:var(--color-success);color:#fff}.goal-checkbox .icon{width:14px;height:14px}.goal-content{flex:1;min-width:0}.goal-text{font-size:var(--font-size-sm);color:var(--color-text-primary);margin-bottom:var(--space-1)}.goal-card.completed .goal-text{text-decoration:line-through;color:var(--color-text-muted)}.goal-deadline{font-size:var(--font-size-xs);color:var(--color-text-muted)}.empty-state{text-align:center;padding:var(--space-12) var(--space-6)}.empty-state-icon{width:64px;height:64px;margin:0 auto var(--space-4);color:var(--color-gray-300)}.empty-state-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-2)}.empty-state-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);max-width:320px;margin:0 auto var(--space-6)}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:.25rem .625rem;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);line-height:1.4;border-radius:var(--radius-full);white-space:nowrap}.badge .icon{width:12px;height:12px}.badge-sm{padding:.125rem .5rem;font-size:.625rem}.badge-lg{padding:.375rem .75rem;font-size:var(--font-size-sm)}.badge-active{background-color:#fff8e1;color:#ff8f00}.badge-success{background-color:var(--color-success-light);color:var(--color-success-dark)}.badge-completed{background-color:#e0f2f1;color:#00796b}.badge-warning{background-color:var(--color-warning-light);color:var(--color-warning-dark)}.badge-pending{background-color:#fff3e0;color:#e65100}.badge-error,.badge-overdue{background-color:var(--color-error-light);color:var(--color-error-dark)}.badge-info,.badge-in-progress{background-color:var(--color-info-light);color:var(--color-info-dark)}.badge-neutral,.badge-not-started{background-color:var(--color-gray-100);color:var(--color-gray-600)}.badge-primary{background-color:var(--color-primary-100);color:var(--color-primary-700)}.badge-past{background:linear-gradient(135deg,#99f6e4,#5eead4);color:#0d5c5c;font-weight:var(--font-weight-semibold);box-shadow:0 2px 8px #14b8a633;transition:all var(--transition-base)}.badge-past:hover{box-shadow:0 4px 12px #14b8a64d;transform:translateY(-1px)}.badge-upcoming{background:linear-gradient(135deg,#bfdbfe,#93c5fd);color:#1e3a8a;font-weight:var(--font-weight-semibold);box-shadow:0 2px 8px #3b82f640;transition:all var(--transition-base)}.badge-upcoming:hover{box-shadow:0 4px 12px #3b82f659;transform:translateY(-1px)}.badge-scheduled{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);color:#374151;font-weight:var(--font-weight-medium);box-shadow:0 1px 4px #00000014;transition:all var(--transition-base)}.badge-scheduled:hover{box-shadow:0 2px 8px #0000001f}.badge-meeting{padding:.25rem .75rem;font-size:.6875rem;letter-spacing:.015em}.badge-dot{display:inline-flex;align-items:center;gap:var(--space-2)}.badge-dot:before{content:"";width:6px;height:6px;border-radius:var(--radius-full);flex-shrink:0}.badge-dot.active:before,.badge-dot.success:before,.badge-dot.completed:before{background-color:var(--color-success)}.badge-dot.warning:before,.badge-dot.pending:before{background-color:var(--color-warning)}.badge-dot.error:before,.badge-dot.overdue:before{background-color:var(--color-error)}.badge-dot.info:before,.badge-dot.in-progress:before{background-color:var(--color-info)}.badge-dot.neutral:before,.badge-dot.not-started:before{background-color:var(--color-gray-400)}.badge-dot.pending:before{background-color:#e65100}.badge-outline{background-color:transparent;border:1px solid currentColor}.badge-outline.badge-success{background-color:transparent;color:var(--color-success)}.badge-outline.badge-warning{background-color:transparent;color:var(--color-warning)}.badge-outline.badge-error{background-color:transparent;color:var(--color-error)}.badge-outline.badge-info{background-color:transparent;color:var(--color-info)}.skill-tag{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);background-color:var(--color-primary-50);color:var(--color-primary-700);border-radius:var(--radius-md);white-space:nowrap}.skill-tag.secondary{background-color:var(--color-gray-100);color:var(--color-gray-700)}.count-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);background-color:var(--color-gray-200);color:var(--color-gray-700);border-radius:var(--radius-full)}.count-badge.primary{background-color:var(--color-primary);color:#fff}.count-badge.success{background-color:var(--color-success);color:#fff}.count-badge.warning{background-color:var(--color-warning);color:#fff}.count-badge.error{background-color:var(--color-error);color:#fff}.progress{width:100%;height:8px;background-color:var(--color-gray-200);border-radius:var(--radius-full);overflow:hidden}.progress-bar{height:100%;border-radius:var(--radius-full);transition:width var(--transition-slow)}.progress-sm{height:4px}.progress-lg{height:12px}.progress-xl{height:16px}.progress-bar.primary{background:var(--gradient-primary)}.progress-bar.success{background-color:var(--color-success)}.progress-bar.warning{background-color:var(--color-warning)}.progress-bar.error{background-color:var(--color-error)}.progress-bar.info{background-color:var(--color-info)}.progress-labeled{display:flex;flex-direction:column;gap:var(--space-2)}.progress-label{display:flex;align-items:center;justify-content:space-between;font-size:var(--font-size-sm)}.progress-label-text{color:var(--color-text-secondary)}.progress-label-value{font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.payment-progress{width:100%;height:24px;background-color:var(--color-gray-100);border-radius:var(--radius-lg);overflow:hidden;display:flex}.payment-progress-paid{height:100%;background-color:var(--color-success);display:flex;align-items:center;justify-content:center;color:#fff;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);transition:width var(--transition-slow)}.payment-progress-pending{height:100%;background-color:var(--color-warning-light);display:flex;align-items:center;justify-content:center;color:var(--color-warning-dark);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);transition:width var(--transition-slow)}.roadmap-progress{width:100%;height:8px;background-color:var(--color-gray-200);border-radius:var(--radius-full);overflow:hidden;display:flex}.roadmap-progress-segment{height:100%;transition:width var(--transition-slow)}.roadmap-progress-segment.completed{background-color:var(--color-success)}.roadmap-progress-segment.in-progress{background-color:var(--color-info)}.roadmap-progress-segment.not-started{background-color:var(--color-gray-300)}.progress-ring{position:relative;display:inline-flex;align-items:center;justify-content:center}.progress-ring svg{transform:rotate(-90deg)}.progress-ring-bg{fill:none;stroke:var(--color-gray-200)}.progress-ring-fill{fill:none;stroke:var(--color-primary);stroke-linecap:round;transition:stroke-dashoffset var(--transition-slow)}.progress-ring-fill.success{stroke:var(--color-success)}.progress-ring-fill.warning{stroke:var(--color-warning)}.progress-ring-fill.error{stroke:var(--color-error)}.progress-ring-value{position:absolute;font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.progress-ring-value.sm{font-size:var(--font-size-sm)}.mini-progress{width:80px;height:4px;background-color:var(--color-gray-200);border-radius:var(--radius-full);overflow:hidden}.mini-progress-bar{height:100%;background:var(--gradient-primary);border-radius:var(--radius-full)}.mini-progress-container{display:flex;align-items:center;gap:var(--space-2)}.mini-progress-value{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);min-width:32px}.progress-steps{display:flex;align-items:center;gap:var(--space-2)}.progress-step{width:32px;height:4px;background-color:var(--color-gray-200);border-radius:var(--radius-full);transition:background-color var(--transition-fast)}.progress-step.completed{background-color:var(--color-success)}.progress-step.current{background-color:var(--color-primary)}.progress-animated .progress-bar{animation:progressPulse 2s ease-in-out infinite}@keyframes progressPulse{0%,to{opacity:1}50%{opacity:.7}}.progress-striped .progress-bar{background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-size:1rem 1rem;animation:progressStripes 1s linear infinite}@keyframes progressStripes{0%{background-position:1rem 0}to{background-position:0 0}}.tabs{display:flex;flex-direction:column}.tabs-list{display:flex;border-bottom:1px solid var(--color-border);overflow-x:auto;scrollbar-width:none}.tabs-list::-webkit-scrollbar{display:none}.tab{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);white-space:nowrap;border-bottom:2px solid transparent;margin-bottom:-1px;cursor:pointer;transition:all var(--transition-fast);background:none;border-left:none;border-right:none;border-top:none}.tab:hover{color:var(--color-text-primary);background-color:var(--color-gray-50)}.tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.tab .icon{width:18px;height:18px}.tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);background-color:var(--color-gray-200);color:var(--color-gray-700);border-radius:var(--radius-full)}.tab.active .tab-badge{background-color:var(--color-primary-100);color:var(--color-primary)}.tabs-content{padding-top:var(--space-6)}.tab-panel{display:none}.tab-panel.active{display:block;animation:tabFadeIn var(--transition-base)}@keyframes tabFadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.tabs-pills .tabs-list{border-bottom:none;background-color:var(--color-gray-100);padding:var(--space-1);border-radius:var(--radius-lg);gap:var(--space-1);width:fit-content}.tabs-pills .tab{border-bottom:none;border-radius:var(--radius-md);margin-bottom:0;padding:var(--space-2) var(--space-4)}.tabs-pills .tab:hover{background-color:var(--color-gray-200)}.tabs-pills .tab.active{background-color:var(--color-surface);color:var(--color-text-primary);box-shadow:var(--shadow-sm)}.tabs-boxed .tabs-list{border-bottom:none;gap:var(--space-2)}.tabs-boxed .tab{border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:0}.tabs-boxed .tab:hover{border-color:var(--color-primary-200);background-color:var(--color-primary-50)}.tabs-boxed .tab.active{border-color:var(--color-primary);background-color:var(--color-primary-50);color:var(--color-primary)}.tabs-vertical{flex-direction:row;gap:var(--space-6)}.tabs-vertical .tabs-list{flex-direction:column;border-bottom:none;border-right:1px solid var(--color-border);padding-right:var(--space-4);min-width:200px}.tabs-vertical .tab{border-bottom:none;border-left:2px solid transparent;margin-right:-1px;margin-bottom:0;padding:var(--space-3) var(--space-4);justify-content:flex-start;text-align:left}.tabs-vertical .tab.active{border-left-color:var(--color-primary);background-color:var(--color-primary-50)}.tabs-vertical .tabs-content{padding-top:0;flex:1}@media(max-width:640px){.tabs-list{gap:0}.tab{padding:var(--space-3);flex:1;justify-content:center}.tab .icon{display:none}.tabs-vertical{flex-direction:column}.tabs-vertical .tabs-list{flex-direction:row;border-right:none;border-bottom:1px solid var(--color-border);padding-right:0;min-width:auto}.tabs-vertical .tab{border-left:none;border-bottom:2px solid transparent;margin-right:0;margin-bottom:-1px}.tabs-vertical .tab.active{border-left-color:transparent;border-bottom-color:var(--color-primary);background-color:transparent}.tabs-vertical .tabs-content{padding-top:var(--space-6)}}.profile-content-wrapper{display:flex;flex-direction:column}.profile-nav{margin-bottom:var(--space-6)}.profile-nav-list{display:flex;border-bottom:1px solid var(--color-border);overflow-x:auto;scrollbar-width:none}.profile-nav-list::-webkit-scrollbar{display:none}.profile-nav-link{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);white-space:nowrap;border-bottom:2px solid transparent;margin-bottom:-1px;text-decoration:none;transition:all var(--transition-fast)}.profile-nav-link:hover{color:var(--color-text-primary);background-color:var(--color-gray-50)}.profile-nav-link.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.profile-nav-link .icon{width:18px;height:18px}.profile-page-content{animation:tabFadeIn var(--transition-base)}@media(max-width:640px){.profile-nav-list{gap:0}.profile-nav-link{padding:var(--space-3);flex:1;justify-content:center}.profile-nav-link .icon{display:none}}.table-container{width:100%;overflow-x:auto;background-color:var(--color-surface);border-radius:var(--radius-xl);border:1px solid var(--color-border-light)}.table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.table th,.table td{padding:var(--space-4);text-align:left;vertical-align:middle}.table th{font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);background-color:var(--color-gray-50);border-bottom:1px solid var(--color-border);white-space:nowrap}.table th:first-child{border-radius:var(--radius-xl) 0 0 0}.table th:last-child{border-radius:0 var(--radius-xl) 0 0}.table td{border-bottom:1px solid var(--color-border-light);color:var(--color-text-primary)}.table tbody tr:last-child td{border-bottom:none}.table tbody tr{transition:background-color var(--transition-fast)}.table tbody tr:hover{background-color:var(--color-gray-50)}.table tbody tr.selected{background-color:var(--color-primary-50)}.table-clickable tbody tr{cursor:pointer}.table td.numeric{text-align:right;font-variant-numeric:tabular-nums}.table th.numeric{text-align:right}.table td.actions{text-align:right;white-space:nowrap}.table td.actions .btn{opacity:0;transition:opacity var(--transition-fast)}.table tbody tr:hover td.actions .btn{opacity:1}.table td.compact{padding:var(--space-2) var(--space-4)}.student-row{display:flex;align-items:center;gap:var(--space-3)}.student-row-avatar{width:40px;height:40px;border-radius:var(--radius-full);background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);flex-shrink:0}.student-row-info{min-width:0}.student-row-name{font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:2px}.student-row-email{font-size:var(--font-size-xs);color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.table-sm th,.table-sm td{padding:var(--space-2) var(--space-3);font-size:var(--font-size-xs)}.table-lg th,.table-lg td{padding:var(--space-5) var(--space-6)}.table-striped tbody tr:nth-child(odd){background-color:var(--color-gray-50)}.table-striped tbody tr:nth-child(odd):hover{background-color:var(--color-gray-100)}.table-bordered th,.table-bordered td{border:1px solid var(--color-border)}.table-bordered th:first-child,.table-bordered td:first-child{border-left:none}.table-bordered th:last-child,.table-bordered td:last-child{border-right:none}.table-bordered tbody tr:last-child td{border-bottom:none}.payment-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);border-bottom:1px solid var(--color-border-light)}.payment-item:last-child{border-bottom:none}.payment-item-info{display:flex;align-items:center;gap:var(--space-3)}.payment-item-icon{width:40px;height:40px;border-radius:var(--radius-lg);background-color:var(--color-gray-100);display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary)}.payment-item-icon .icon{width:20px;height:20px}.payment-item-icon.success{background-color:var(--color-success-light);color:var(--color-success)}.payment-item-icon.pending{background-color:var(--color-warning-light);color:var(--color-warning)}.payment-item-details{flex:1}.payment-item-date{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:2px}.payment-item-method{font-size:var(--font-size-xs);color:var(--color-text-muted)}.payment-item-amount{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.payment-item-amount.success{color:var(--color-success)}.upcoming-payment{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);background-color:var(--color-gray-50);border-radius:var(--radius-lg);margin-bottom:var(--space-2);text-decoration:none;transition:background-color var(--transition-fast);cursor:pointer}.upcoming-payment:hover{background-color:var(--color-gray-100)}.upcoming-payment:hover .upcoming-payment-name{color:var(--color-primary)}.upcoming-payment:last-child{margin-bottom:0}.upcoming-payment-overdue{background-color:var(--color-error-light)}.upcoming-payment-overdue:hover{background-color:#fecaca}.upcoming-payment-date-overdue,.upcoming-payment-amount-overdue{color:var(--color-error)}.upcoming-payment-left{display:flex;align-items:center;gap:var(--space-3)}.upcoming-payment-avatar{width:32px;height:32px;border-radius:var(--radius-full);background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:var(--font-weight-semibold);font-size:var(--font-size-xs)}.upcoming-payment-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.upcoming-payment-date{font-size:var(--font-size-xs);color:var(--color-text-muted)}.upcoming-payment-amount{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}@media(max-width:768px){.table-responsive thead{display:none}.table-responsive tbody tr{display:block;padding:var(--space-4);border-bottom:1px solid var(--color-border);margin-bottom:var(--space-2);background-color:var(--color-surface);border-radius:var(--radius-lg)}.table-responsive tbody tr:last-child{margin-bottom:0}.table-responsive td{display:flex;justify-content:space-between;align-items:center;padding:var(--space-2) 0;border-bottom:1px solid var(--color-border-light)}.table-responsive td:last-child{border-bottom:none}.table-responsive td:before{content:attr(data-label);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);margin-right:var(--space-4)}}.timeline{position:relative;padding-left:calc(var(--space-8) + var(--space-6))}.timeline:before{content:"";position:absolute;left:39px;top:0;bottom:0;width:3px;border-radius:2px;background:linear-gradient(to bottom,var(--color-success) 0%,var(--color-success) var(--completed-percentage, 0%),var(--color-info) var(--completed-percentage, 0%),var(--color-info) var(--current-percentage, 0%),var(--color-gray-200) var(--current-percentage, 0%),var(--color-gray-200) 100%)}.milestone-item{position:relative;padding-bottom:var(--space-6)}.milestone-item:last-child{padding-bottom:0}.milestone-number{position:absolute;left:calc(-1 * var(--space-8) - var(--space-6) + 4px);top:4px;width:24px;height:24px;border-radius:var(--radius-full);background:var(--color-gray-100);color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold)}.milestone-item.completed .milestone-number{background:var(--color-success-light);color:var(--color-success)}.milestone-item.in-progress .milestone-number{background:var(--color-info-light);color:var(--color-info)}.milestone-marker{position:absolute;left:calc(-1 * var(--space-8) + 2px);top:0;width:26px;height:26px;border-radius:var(--radius-full);background-color:var(--color-surface);border:3px solid var(--color-gray-300);display:flex;align-items:center;justify-content:center;z-index:1;transition:all var(--transition-fast)}.milestone-marker .icon{width:14px;height:14px}.milestone-item.completed .milestone-marker{background-color:var(--color-success);border-color:var(--color-success);color:#fff}.milestone-item.in-progress .milestone-marker{background-color:var(--color-info);border-color:var(--color-info);color:#fff;animation:pulse 2s infinite}.milestone-item.not-started .milestone-marker{background-color:var(--color-surface);border-color:var(--color-gray-300);color:var(--color-gray-400)}@keyframes pulse{0%,to{box-shadow:0 0 #3b82f666}50%{box-shadow:0 0 0 10px #3b82f600}}.milestone-item.completed .milestone-marker .icon{animation:checkDraw .3s ease-out}@keyframes checkDraw{0%{stroke-dasharray:20;stroke-dashoffset:20}to{stroke-dasharray:20;stroke-dashoffset:0}}.milestone-content{background-color:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);padding:var(--space-4);transition:all var(--transition-fast)}.milestone-content:hover{box-shadow:var(--shadow-md);border-color:var(--color-border);transform:translate(4px)}.milestone-item.in-progress .milestone-content{border:2px solid var(--color-info);box-shadow:0 0 20px #3b82f626,0 4px 12px #0000000d;background:linear-gradient(135deg,var(--color-surface) 0%,rgba(59,130,246,.03) 100%)}.milestone-item.in-progress .milestone-content:hover{box-shadow:0 0 25px #3b82f633,0 6px 16px #00000014}.milestone-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-3);margin-bottom:var(--space-2)}.milestone-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.milestone-item.completed .milestone-title{color:var(--color-text-secondary)}.milestone-meta{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.milestone-duration{font-size:var(--font-size-xs);color:var(--color-text-muted);background:var(--color-gray-100);padding:var(--space-1) var(--space-2);border-radius:var(--radius-md);white-space:nowrap}.milestone-item.in-progress .milestone-duration{background:var(--color-info-light);color:var(--color-info)}.milestone-date{font-size:var(--font-size-xs);color:var(--color-text-muted);white-space:nowrap}.milestone-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-3)}.milestone-skills{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-3)}.skill-tag{display:inline-block;padding:2px 10px;background:var(--color-primary-50);color:var(--color-primary-700);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);transition:all var(--transition-fast)}.skill-tag:hover{background:var(--color-primary-100);transform:translateY(-1px)}.milestone-item.completed .skill-tag{background:var(--color-success-light);color:var(--color-success-dark)}.milestone-item.in-progress .skill-tag{background:var(--color-info-light);color:var(--color-info)}.milestone-item.not-started .skill-tag{background:var(--color-gray-100);color:var(--color-text-muted)}.milestone-progress{display:flex;align-items:center;gap:var(--space-3)}.milestone-progress .progress{flex:1}.milestone-progress-value{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);min-width:40px;text-align:right}.activity-timeline{position:relative;padding-left:var(--space-6)}.activity-timeline:before{content:"";position:absolute;left:11px;top:8px;bottom:8px;width:2px;background-color:var(--color-border-light)}.activity-item{position:relative;padding-bottom:var(--space-4)}.activity-item:last-child{padding-bottom:0}.activity-marker{position:absolute;left:calc(-1 * var(--space-6) + 4px);top:4px;width:16px;height:16px;border-radius:var(--radius-full);background-color:var(--color-surface);border:2px solid var(--color-gray-300);z-index:1}.activity-item.completed .activity-marker{background-color:var(--color-success-light);border-color:var(--color-success)}.activity-item.session .activity-marker{background-color:var(--color-info-light);border-color:var(--color-info)}.activity-item.payment .activity-marker{background-color:var(--color-primary-100);border-color:var(--color-primary)}.activity-text{font-size:var(--font-size-sm);color:var(--color-text-primary);margin-bottom:var(--space-1)}.activity-time{font-size:var(--font-size-xs);color:var(--color-text-muted)}.timeline-horizontal{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-4) 0}.timeline-h-item{flex:1;text-align:center}.timeline-h-marker{width:32px;height:32px;margin:0 auto var(--space-2);border-radius:var(--radius-full);background-color:var(--color-gray-200);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-muted);position:relative}.timeline-h-item.completed .timeline-h-marker{background-color:var(--color-success);color:#fff}.timeline-h-item.in-progress .timeline-h-marker{background-color:var(--color-info);color:#fff}.timeline-h-connector{position:absolute;right:-50%;top:50%;width:100%;height:2px;background-color:var(--color-gray-200);z-index:-1}.timeline-h-item.completed .timeline-h-connector{background-color:var(--color-success)}.timeline-h-item:last-child .timeline-h-connector{display:none}.timeline-h-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);white-space:nowrap}.timeline-h-item.completed .timeline-h-label{color:var(--color-success)}.timeline-h-item.in-progress .timeline-h-label{color:var(--color-info);font-weight:var(--font-weight-medium)}.timeline-compact{display:flex;flex-direction:column;gap:var(--space-3)}.timeline-compact-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background-color:var(--color-gray-50);border-radius:var(--radius-lg);border:1px solid transparent;transition:all var(--transition-fast)}.timeline-compact-item:hover{background-color:var(--color-surface);border-color:var(--color-border);box-shadow:var(--shadow-sm)}.timeline-compact-icon{width:32px;height:32px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.timeline-compact-icon .icon{width:16px;height:16px}.timeline-compact-item.completed .timeline-compact-icon{background-color:var(--color-success-light);color:var(--color-success)}.timeline-compact-item.in-progress .timeline-compact-icon{background-color:var(--color-info-light);color:var(--color-info)}.timeline-compact-item.not-started .timeline-compact-icon{background-color:var(--color-gray-200);color:var(--color-gray-500)}.timeline-compact-content{flex:1;min-width:0}.timeline-compact-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.timeline-compact-item.completed .timeline-compact-title{color:var(--color-text-secondary)}.timeline-compact-meta{font-size:var(--font-size-xs);color:var(--color-text-muted)}@media(max-width:640px){.timeline-horizontal{flex-wrap:wrap;justify-content:center}.timeline-h-item{flex:0 0 auto;min-width:80px}.timeline-h-connector{display:none}.milestone-header{flex-direction:column;gap:var(--space-2)}.milestone-meta{flex-wrap:wrap}.milestone-skills{gap:var(--space-1)}.skill-tag{font-size:10px;padding:2px 6px}}.modal-backdrop{position:fixed;inset:0;display:none;align-items:center;justify-content:center;padding:var(--space-4);background-color:#11182780;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-modal-backdrop);opacity:0;visibility:hidden;transition:opacity var(--transition-base),visibility var(--transition-base)}.modal-backdrop.active{display:flex!important;opacity:1;visibility:visible}.modal{width:100%;max-width:500px;max-height:calc(100vh - var(--space-8));display:flex;flex-direction:column;background-color:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);z-index:var(--z-modal);transform:scale(.95) translateY(10px);transition:transform var(--transition-base)}.modal-backdrop.active .modal{transform:scale(1) translateY(0)}.modal.modal-sm{max-width:400px}.modal.modal-lg{max-width:640px}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border-light)}.modal-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;color:var(--color-text-muted);background:none;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.modal-close:hover{color:var(--color-text-primary);background-color:var(--color-gray-100)}.modal-close svg{width:20px;height:20px}.modal-body{flex:1;padding:var(--space-6);overflow-y:auto}.modal-body.delete-confirm{text-align:center;padding:var(--space-8) var(--space-6)}.delete-confirm-icon{display:flex;align-items:center;justify-content:center;width:64px;height:64px;margin:0 auto var(--space-4);background-color:var(--color-error-light);border-radius:var(--radius-full);color:var(--color-error)}.delete-confirm-icon svg{width:32px;height:32px}.delete-confirm-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--space-2)}.delete-confirm-message{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border-light)}@media(max-width:480px){.modal-backdrop{align-items:flex-end;padding:0}.modal{max-width:100%;max-height:90vh;border-radius:var(--radius-xl) var(--radius-xl) 0 0;transform:translateY(100%)}.modal-backdrop.active .modal{transform:translateY(0)}.modal-header{padding:var(--space-4) var(--space-5)}.modal-body{padding:var(--space-5)}.modal-footer{padding:var(--space-4) var(--space-5);padding-bottom:max(var(--space-4),env(safe-area-inset-bottom))}.modal-footer{flex-direction:column-reverse}.modal-footer .btn{width:100%}}.modal-body::-webkit-scrollbar{width:6px}.modal-body::-webkit-scrollbar-track{background:var(--color-gray-100);border-radius:var(--radius-full)}.modal-body::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:var(--radius-full)}.modal-body::-webkit-scrollbar-thumb:hover{background:var(--color-gray-400)}.slideover-backdrop{position:fixed;inset:0;background-color:#11182780;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-modal-backdrop);opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}.slideover-backdrop.active{opacity:1;visibility:visible}.slideover-panel{position:fixed;top:0;right:0;bottom:0;width:540px;max-width:100%;background:var(--color-surface);box-shadow:var(--shadow-xl);z-index:var(--z-modal);display:flex;flex-direction:column;transform:translate(100%);transition:transform .35s cubic-bezier(.4,0,.2,1)}.slideover-backdrop.active .slideover-panel{transform:translate(0)}.slideover-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border-light);flex-shrink:0}.slideover-header-info{flex:1;min-width:0}.slideover-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0;line-height:var(--line-height-tight);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.slideover-type-badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:2px var(--space-2);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em;margin-top:var(--space-1)}.slideover-type-badge.type-learning{background:var(--color-info-light);color:var(--color-info-dark)}.slideover-type-badge.type-project{background:var(--color-primary-100);color:var(--color-primary-700)}.slideover-type-badge.type-career{background:var(--color-warning-light);color:var(--color-warning-dark)}.slideover-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;color:var(--color-text-muted);background:none;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.slideover-close:hover{color:var(--color-text-primary);background-color:var(--color-gray-100)}.slideover-close svg{width:20px;height:20px}.slideover-body{flex:1;overflow-y:auto;padding:var(--space-6)}.slideover-body::-webkit-scrollbar{width:6px}.slideover-body::-webkit-scrollbar-track{background:var(--color-gray-100);border-radius:var(--radius-full)}.slideover-body::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:var(--radius-full)}.slideover-body::-webkit-scrollbar-thumb:hover{background:var(--color-gray-400)}.quiz-question-card{background:var(--color-gray-50);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);padding:var(--space-5);margin-bottom:var(--space-4)}.quiz-question-card:last-child{margin-bottom:0}.quiz-question-number{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--color-primary);margin-bottom:var(--space-2)}.quiz-question-text{font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-text-primary);line-height:var(--line-height-relaxed);margin-bottom:var(--space-4)}.quiz-options{display:flex;flex-direction:column;gap:var(--space-2)}.quiz-option{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);border:1px solid var(--color-border-light);border-radius:var(--radius-md);background:var(--color-surface);cursor:pointer;transition:all var(--transition-fast);position:relative}.quiz-option:hover{border-color:var(--color-primary-200);background:#0d94880a}.quiz-option.selected{border-color:var(--color-primary);background:#0d94880f}.quiz-option input[type=radio]{position:absolute;opacity:0;width:0;height:0}.quiz-option-radio{width:18px;height:18px;border:2px solid var(--color-gray-300);border-radius:var(--radius-full);flex-shrink:0;margin-top:1px;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.quiz-option.selected .quiz-option-radio{border-color:var(--color-primary)}.quiz-option.selected .quiz-option-radio:after{content:"";width:10px;height:10px;background:var(--color-primary);border-radius:var(--radius-full)}.quiz-option-text{font-size:var(--font-size-sm);color:var(--color-text-primary);line-height:var(--line-height-normal)}.quiz-option.correct{border-color:var(--color-success);background:#22c55e14}.quiz-option.correct .quiz-option-radio{border-color:var(--color-success)}.quiz-option.correct .quiz-option-radio:after{content:"";width:10px;height:10px;background:var(--color-success);border-radius:var(--radius-full)}.quiz-option.incorrect{border-color:var(--color-error);background:#ef444414}.quiz-option.incorrect .quiz-option-radio{border-color:var(--color-error)}.quiz-option.incorrect .quiz-option-radio:after{content:"";width:10px;height:10px;background:var(--color-error);border-radius:var(--radius-full)}.quiz-options.reviewed .quiz-option:not(.correct):not(.incorrect){opacity:.5}.slideover-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border-light);flex-shrink:0}.quiz-result{text-align:center;padding:var(--space-8) var(--space-4)}.quiz-result-icon{width:72px;height:72px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-4)}.quiz-result-icon svg{width:36px;height:36px}.quiz-result-icon.pass{background:#22c55e1f;color:var(--color-success)}.quiz-result-icon.fail{background:#ef44441f;color:var(--color-error)}.quiz-result-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin-bottom:var(--space-2)}.quiz-result-score{font-size:var(--font-size-base);color:var(--color-text-secondary);margin-bottom:var(--space-6)}.quiz-result-score strong{font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}@media(max-width:640px){.slideover-panel{width:100%}.slideover-header{padding:var(--space-4) var(--space-5)}.slideover-body{padding:var(--space-5)}.slideover-footer{padding:var(--space-4) var(--space-5);padding-bottom:max(var(--space-4),env(safe-area-inset-bottom))}.quiz-question-card{padding:var(--space-4)}.quiz-option{padding:var(--space-3)}}.slideover-type-badge.feedback-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.feedback-content{display:flex;flex-direction:column;gap:var(--space-6)}.feedback-section{background:var(--color-gray-50);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);padding:var(--space-5)}.feedback-section-title{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin:0 0 var(--space-4)}.feedback-section:nth-child(1) .feedback-section-title{color:var(--color-warning-dark)}.feedback-section:nth-child(2) .feedback-section-title{color:var(--color-success-dark)}.feedback-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-3)}.feedback-list li{padding-left:var(--space-4);position:relative;font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:var(--line-height-relaxed)}.feedback-list li:before{content:"";position:absolute;left:0;top:9px;width:6px;height:6px;border-radius:var(--radius-full)}.feedback-section:nth-child(1) .feedback-list li:before{background:var(--color-warning)}.feedback-section:nth-child(2) .feedback-list li:before{background:var(--color-success)}.feedback-section-requirements .feedback-section-title{color:var(--color-primary-700)}.feedback-section-requirements .feedback-list li:before{background:var(--color-primary)}.pr-url-section{border-top:1px solid var(--color-border-light);padding-top:var(--space-5);margin-top:var(--space-2)}.pr-url-title{color:var(--color-primary-700)!important}.pr-url-input-wrapper{display:flex;flex-direction:column;gap:var(--space-2)}.pr-url-input{width:100%;padding:var(--space-3) var(--space-4);border:1px solid var(--color-border-light);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-family:inherit;color:var(--color-text-primary);background:var(--color-surface);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);box-sizing:border-box}.pr-url-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #0d94881f}.pr-url-input.pr-url-input-error{border-color:var(--color-error);box-shadow:0 0 0 3px #ef44441f}.pr-url-input::placeholder{color:var(--color-text-muted)}.pr-url-hint{font-size:var(--font-size-xs);color:var(--color-text-muted);margin:0}.pr-url-display{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:#0d94880f;border:1px solid rgba(13,148,136,.2);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--color-primary-700);text-decoration:none;word-break:break-all;transition:all var(--transition-fast)}.pr-url-display:hover{background:#0d94881a;border-color:var(--color-primary)}.pr-url-display svg{flex-shrink:0;color:var(--color-primary)}.pr-url-submit-btn{background:var(--color-primary);color:#fff;border:none;padding:var(--space-2) var(--space-5);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-fast)}.pr-url-submit-btn:hover:not(:disabled){background:var(--color-primary-700)}.pr-url-submit-btn:disabled{opacity:.5;cursor:not-allowed}.roadmap-item-pr-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);background:#0d94881a;color:var(--color-primary-700);margin-left:auto;white-space:nowrap}.roadmap-item-pr-badge svg{width:14px;height:14px}.form-group{margin-bottom:var(--space-4)}.form-group:last-child{margin-bottom:0}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4)}@media(max-width:480px){.form-row{grid-template-columns:1fr}}.form-label{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--space-2)}.form-label.required:after{content:" *";color:var(--color-error)}.form-input{width:100%;padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm);font-family:inherit;color:var(--color-text-primary);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--transition-fast);outline:none}.form-input::placeholder{color:var(--color-text-muted)}.form-input:hover{border-color:var(--color-gray-300)}.form-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #0d94881a}.form-input:disabled{background-color:var(--color-gray-100);color:var(--color-text-muted);cursor:not-allowed}.form-input.error{border-color:var(--color-error)}.form-input.error:focus{box-shadow:0 0 0 3px #ef44441a}.form-textarea{width:100%;min-height:100px;padding:var(--space-3);font-size:var(--font-size-sm);font-family:inherit;color:var(--color-text-primary);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--transition-fast);outline:none;resize:vertical}.form-textarea::placeholder{color:var(--color-text-muted)}.form-textarea:hover{border-color:var(--color-gray-300)}.form-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #0d94881a}.form-textarea.error{border-color:var(--color-error)}.form-select{width:100%;padding:var(--space-2) var(--space-3);padding-right:var(--space-8);font-size:var(--font-size-sm);font-family:inherit;color:var(--color-text-primary);background-color:var(--color-surface);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3) center;background-size:16px;border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--transition-fast);outline:none;cursor:pointer;appearance:none}.form-select:hover{border-color:var(--color-gray-300)}.form-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #0d94881a}.form-select:disabled{background-color:var(--color-gray-100);color:var(--color-text-muted);cursor:not-allowed}.form-select.error{border-color:var(--color-error)}.form-tags{display:flex;flex-wrap:wrap;gap:var(--space-2);padding:var(--space-2);min-height:44px;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.form-tags:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px #0d94881a}.form-tags .tag{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-primary-700);background-color:var(--color-primary-100);border-radius:var(--radius-md)}.form-tags .tag-remove{display:flex;align-items:center;justify-content:center;width:14px;height:14px;padding:0;font-size:16px;line-height:1;color:var(--color-primary-600);background:none;border:none;border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast)}.form-tags .tag-remove:hover{color:var(--color-error);background-color:var(--color-error-light)}.form-tags .tag-input{flex:1;min-width:100px;padding:var(--space-1);font-size:var(--font-size-sm);font-family:inherit;color:var(--color-text-primary);background:none;border:none;outline:none}.form-tags .tag-input::placeholder{color:var(--color-text-muted)}.form-input-currency{position:relative}.form-input-currency .currency-prefix{position:absolute;left:var(--space-3);top:50%;transform:translateY(-50%);font-size:var(--font-size-sm);color:var(--color-text-secondary);pointer-events:none}.form-input-currency .form-input{padding-left:var(--space-12)}.form-helper{display:block;margin-top:var(--space-1);font-size:var(--font-size-xs);color:var(--color-text-muted)}.form-error{display:block;margin-top:var(--space-1);font-size:var(--font-size-xs);color:var(--color-error)}.form-input[type=date]{cursor:pointer}.form-input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.6;transition:opacity var(--transition-fast)}.form-input[type=date]::-webkit-calendar-picker-indicator:hover{opacity:1}.form-input[type=number]{-moz-appearance:textfield}.form-input[type=number]::-webkit-outer-spin-button,.form-input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.dashboard-filter{background-color:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-xl);margin-bottom:var(--space-6);padding:var(--space-4) var(--space-5)}.dashboard-filter-buttons{display:flex;gap:var(--space-2);flex-wrap:wrap;justify-content:center}.dashboard-filter-buttons .btn-filter{padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm);background:var(--color-gray-100);color:var(--color-text-secondary);border:none;border-radius:var(--radius-lg);cursor:pointer;transition:var(--transition-fast);font-weight:var(--font-weight-medium)}.dashboard-filter-buttons .btn-filter:hover{background:var(--color-gray-200)}.dashboard-filter-buttons .btn-filter.active{background:var(--color-primary);color:#fff}.dashboard-filter-custom{margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--color-border-light)}.dashboard-filter-custom .form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4);margin-bottom:var(--space-4)}.dashboard-filter-custom .form-group{margin:0}.dashboard-filter-custom .form-label{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);margin-bottom:var(--space-2)}.dashboard-filter-custom .form-input{width:100%;padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text-primary);transition:var(--transition-fast)}.dashboard-filter-custom .form-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #0d94881a}.dashboard-filter-actions{display:flex;gap:var(--space-3);justify-content:flex-end}.dashboard-filter-actions .btn{padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-fast)}.dashboard-filter-actions .btn-sm{padding:var(--space-2) var(--space-3)}.dashboard-filter-actions .btn-secondary{background:var(--color-gray-100);color:var(--color-text-secondary);border:1px solid var(--color-border)}.dashboard-filter-actions .btn-secondary:hover{background:var(--color-gray-200)}.dashboard-filter-actions .btn-primary{background:var(--color-primary);color:#fff;border:none}.dashboard-filter-actions .btn-primary:hover{background:var(--color-primary-700)}@media(max-width:768px){.dashboard-filter{padding:var(--space-3) var(--space-4)}.dashboard-filter-buttons{width:100%}.dashboard-filter-buttons .btn-filter{flex:1;min-width:0;text-align:center;padding:var(--space-2);font-size:var(--font-size-xs)}.dashboard-filter-custom .form-row{grid-template-columns:1fr;gap:var(--space-3)}.dashboard-filter-actions{flex-direction:column}.dashboard-filter-actions .btn{width:100%;justify-content:center}}@media(max-width:480px){.dashboard-filter-buttons{flex-wrap:wrap}.dashboard-filter-buttons .btn-filter{flex:0 0 calc(50% - var(--space-1))}.dashboard-filter-buttons .btn-filter:last-child{flex:1 1 100%}}.payment-empty-state,.student-empty-state{padding:var(--space-6) var(--space-4);text-align:center;color:var(--color-text-muted);font-size:var(--font-size-sm)}.welcome-banner{background:var(--gradient-primary);border-radius:var(--radius-xl);padding:var(--space-6);color:#fff;margin-bottom:var(--space-6)}.welcome-content{max-width:600px}.welcome-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);margin-bottom:var(--space-2);color:#fff}.welcome-subtitle{font-size:var(--font-size-base);opacity:.9;margin-bottom:0;color:#fff}.dashboard-stats{margin-bottom:var(--space-8)}.stats-grid-2{grid-template-columns:repeat(2,1fr)}.recent-students{margin-bottom:var(--space-8)}.recent-students-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-5)}.upcoming-meetings-card{background-color:var(--color-surface);border-radius:var(--radius-xl);border:1px solid var(--color-border-light);overflow:hidden;margin-bottom:var(--space-6)}.upcoming-meetings-header{padding:var(--space-5);border-bottom:1px solid var(--color-border-light);display:flex;align-items:center;justify-content:space-between}.upcoming-meetings-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.upcoming-meetings-icon{color:var(--color-text-muted)}.upcoming-meetings-list{padding:var(--space-4)}.upcoming-meeting{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);background-color:var(--color-gray-50);border-radius:var(--radius-lg);margin-bottom:var(--space-2);text-decoration:none;transition:background-color var(--transition-fast);cursor:pointer}.upcoming-meeting:hover{background-color:var(--color-gray-100)}.upcoming-meeting:hover .upcoming-meeting-name{color:var(--color-primary)}.upcoming-meeting:last-child{margin-bottom:0}.upcoming-meeting-left{display:flex;align-items:center;gap:var(--space-3);min-width:0}.upcoming-meeting-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);flex-shrink:0}.upcoming-meeting-info{min-width:0}.upcoming-meeting-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);transition:color var(--transition-fast)}.upcoming-meeting-detail{font-size:var(--font-size-xs);color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.upcoming-meeting-time{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-primary);white-space:nowrap;padding-left:var(--space-4)}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6)}@media(max-width:1024px){.dashboard-grid{grid-template-columns:1fr}}.payment-overview-card{background-color:var(--color-surface);border-radius:var(--radius-xl);border:1px solid var(--color-border-light);overflow:hidden}.payment-overview-header{padding:var(--space-5);border-bottom:1px solid var(--color-border-light);display:flex;align-items:center;justify-content:space-between}.payment-overview-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.payment-overview-stats{display:grid;grid-template-columns:repeat(3,1fr);padding:var(--space-5);gap:var(--space-4);background-color:var(--color-gray-50)}.payment-stat{text-align:center}.payment-stat-value{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin-bottom:var(--space-1)}.payment-stat-value.success{color:var(--color-success)}.payment-stat-value.warning{color:var(--color-warning)}.payment-stat-label{font-size:var(--font-size-xs);color:var(--color-text-muted)}.payment-overview-list{padding:var(--space-4)}.payment-overview-list-header{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);margin-bottom:var(--space-3)}.roadmap-overview-card{background-color:var(--color-surface);border-radius:var(--radius-xl);border:1px solid var(--color-border-light);padding:var(--space-5)}.roadmap-overview-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-5)}.roadmap-overview-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.roadmap-student{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) 0;border-bottom:1px solid var(--color-border-light)}.roadmap-student:last-child{border-bottom:none;padding-bottom:0}.roadmap-student.clickable{text-decoration:none;border-radius:var(--radius-lg);margin:0 calc(var(--space-2) * -1);padding:var(--space-3) var(--space-2);transition:background-color var(--transition-fast)}.roadmap-student.clickable:hover{background-color:var(--color-gray-50)}.roadmap-student.clickable:last-child{padding-bottom:var(--space-3)}.roadmap-student-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);flex-shrink:0}.roadmap-student-info{flex:1;min-width:0}.roadmap-student-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--space-2)}.roadmap-student-progress{display:flex;align-items:center;gap:var(--space-2)}.roadmap-student-progress .progress{flex:1}.roadmap-student-progress-value{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);min-width:36px;text-align:right}.quick-actions{display:flex;gap:var(--space-3);flex-wrap:wrap}.dashboard-empty{background-color:var(--color-surface);border-radius:var(--radius-xl);border:2px dashed var(--color-border);padding:var(--space-12);text-align:center}.dashboard-empty-icon{width:80px;height:80px;margin:0 auto var(--space-4);background-color:var(--color-primary-50);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:var(--color-primary)}.dashboard-empty-icon .icon{width:40px;height:40px}.dashboard-empty-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-2)}.dashboard-empty-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);max-width:400px;margin:0 auto var(--space-6)}@media(max-width:768px){.payment-overview-stats{grid-template-columns:1fr;text-align:left}.payment-stat{text-align:left;display:flex;justify-content:space-between;align-items:center;padding:var(--space-2) 0}.payment-stat-value{margin-bottom:0}.welcome-banner{padding:var(--space-5)}.welcome-title{font-size:var(--font-size-xl)}.upcoming-meeting{flex-direction:column;align-items:flex-start;gap:var(--space-2)}.upcoming-meeting-time{padding-left:calc(36px + var(--space-3))}}.profile-header{background-color:var(--color-surface);border-radius:var(--radius-xl);border:1px solid var(--color-border-light);padding:var(--space-6);margin-bottom:var(--space-6)}.profile-header-content{display:flex;align-items:flex-start;gap:var(--space-6)}.profile-avatar{width:100px;height:100px;border-radius:var(--radius-full);background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:var(--font-weight-bold);font-size:var(--font-size-3xl);flex-shrink:0}.profile-info{flex:1;min-width:0}.profile-name{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin-bottom:var(--space-1)}.profile-email{font-size:var(--font-size-base);color:var(--color-text-secondary);margin-bottom:var(--space-3)}.profile-meta{display:flex;align-items:center;gap:var(--space-4);flex-wrap:wrap}.profile-meta-item{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.profile-meta-item .icon{width:16px;height:16px;color:var(--color-text-muted)}.profile-quick-stats{display:flex;gap:var(--space-6);margin-top:var(--space-6);padding-top:var(--space-6);border-top:1px solid var(--color-border-light)}.profile-quick-stat{text-align:center}.profile-quick-stat-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin-bottom:var(--space-1)}.profile-quick-stat-value.success{color:var(--color-success)}.profile-quick-stat-label{font-size:var(--font-size-xs);color:var(--color-text-muted)}.profile-tabs{background-color:var(--color-surface);border-radius:var(--radius-xl);border:1px solid var(--color-border-light);overflow:hidden}.profile-tabs .tabs-list{padding:0 var(--space-4);background-color:var(--color-gray-50)}.profile-tabs .tabs-content{padding:var(--space-6)}.roadmap-section{max-width:100%}.roadmap-hero{display:flex;align-items:center;gap:var(--space-8);background:var(--color-surface);border-radius:var(--radius-xl);padding:var(--space-6);margin-bottom:var(--space-6);box-shadow:0 1px 3px #00000014,0 4px 12px #0000000a}.roadmap-hero-progress{position:relative;width:120px;height:120px;flex-shrink:0}.circular-progress-hero{width:100%;height:100%;transform:rotate(-90deg)}.circular-progress-hero .progress-bg{fill:none;stroke:var(--color-gray-100);stroke-width:10}.circular-progress-hero .progress-fill{fill:none;stroke:url(#progressGradient);stroke-width:10;stroke-linecap:round;transition:stroke-dashoffset .5s ease}.progress-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.progress-center .progress-value{display:block;font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-primary);line-height:1}.progress-center .progress-label{display:block;font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:var(--space-1)}.roadmap-hero-info{flex:1;min-width:0}.current-focus{margin-bottom:var(--space-5)}.current-label{display:block;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-2)}.current-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0 0 var(--space-2) 0}.current-meta{display:flex;align-items:center;gap:var(--space-3)}.current-meta .duration{font-size:var(--font-size-sm);color:var(--color-text-secondary);background:var(--color-gray-100);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full)}.current-meta .progress-text{font-size:var(--font-size-sm);color:var(--color-info);font-weight:var(--font-weight-medium)}.completion-bar{padding-top:var(--space-4);border-top:1px solid var(--color-border-light)}.completion-track{height:8px;background:var(--color-gray-100);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--space-2)}.completion-fill{height:100%;background:linear-gradient(90deg,var(--color-success) 0%,var(--color-success-light) 100%);border-radius:var(--radius-full);transition:width .5s ease}.completion-text{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.milestone-cards{display:flex;flex-direction:column;gap:var(--space-4)}.milestone-card{--card-border: var(--color-gray-300);--card-bg: var(--color-surface);--card-bg-hover: var(--color-surface);--card-shadow-hover: var(--shadow-sm);--card-opacity: .75;--icon-bg: var(--color-gray-100);--icon-color: var(--color-gray-400);--title-color: var(--color-text-primary);--desc-color: var(--color-text-secondary);--tag-bg: var(--color-gray-100);--tag-color: var(--color-text-muted);display:flex;gap:var(--space-4);background:var(--card-bg);border-radius:var(--radius-xl);padding:var(--space-5);border-left:4px solid var(--card-border);opacity:var(--card-opacity);transition:all var(--transition-fast)}.milestone-card:hover{transform:translate(4px);opacity:1;background:var(--card-bg-hover);box-shadow:var(--card-shadow-hover)}.milestone-card.completed{--card-border: var(--color-success);--card-bg: var(--color-gray-50);--card-opacity: 1;--icon-bg: var(--color-success-light);--icon-color: var(--color-success);--title-color: var(--color-text-secondary);--desc-color: var(--color-text-muted)}.milestone-card.in-progress{--card-border: var(--color-info);--card-bg: linear-gradient(135deg, rgba(59, 130, 246, .04) 0%, var(--color-surface) 100%);--card-shadow-hover: 0 6px 20px rgba(59, 130, 246, .16), 0 2px 6px rgba(0, 0, 0, .06);--card-opacity: 1;--icon-bg: var(--color-info-light);--icon-color: var(--color-info);--tag-bg: var(--color-info-light);--tag-color: var(--color-info);box-shadow:0 4px 16px #3b82f61f,0 1px 3px #0000000a}.milestone-card.in-progress:hover{transform:translate(4px) translateY(-2px)}.milestone-card-icon{width:40px;height:40px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--icon-bg);color:var(--icon-color)}.milestone-card-icon svg{width:20px;height:20px}.milestone-card.in-progress .milestone-card-icon{animation:iconPulse 2s ease-in-out infinite}@keyframes iconPulse{0%,to{box-shadow:0 0 #3b82f64d}50%{box-shadow:0 0 0 8px #3b82f600}}.milestone-card-content{flex:1;min-width:0}.milestone-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-3);margin-bottom:var(--space-2)}.milestone-card-header h4{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--title-color);margin:0}.milestone-card-header .milestone-date{font-size:var(--font-size-xs);color:var(--color-text-muted);white-space:nowrap}.milestone-card-header .milestone-status{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-info);background:var(--color-info-light);padding:var(--space-1) var(--space-2);border-radius:var(--radius-md);white-space:nowrap}.milestone-card-header .milestone-duration{font-size:var(--font-size-xs);color:var(--color-text-muted);white-space:nowrap}.milestone-desc{font-size:var(--font-size-sm);color:var(--desc-color);margin:0 0 var(--space-3) 0;line-height:1.5}.milestone-card .milestone-skills{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:0}.milestone-card .skill-tag{background:var(--tag-bg);color:var(--tag-color)}.card-actions{display:flex;align-items:center;gap:var(--space-1);opacity:0;transition:opacity var(--transition-fast)}.milestone-card:hover .card-actions,.payment-history-item:hover .card-actions{opacity:1}.milestone-card:focus-within .card-actions,.payment-history-item:focus-within .card-actions{opacity:1}.milestone-card-actions{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}.milestone-deadline{font-size:var(--font-size-xs);color:var(--color-text-muted);background:var(--color-gray-100);padding:var(--space-1) var(--space-2);border-radius:var(--radius-md);white-space:nowrap}.milestone-deadline.deadline-warning{color:var(--color-warning-dark);background:var(--color-warning-light)}.milestone-deadline.deadline-overdue{color:var(--color-error);background:var(--color-error-light)}.section-header h3{margin:0}.milestone-card-progress{display:flex;align-items:center;gap:var(--space-3);margin-top:var(--space-4);padding-top:var(--space-3);border-top:1px solid var(--color-border-light)}.milestone-card-progress .progress-track{flex:1;height:6px;background:var(--color-gray-100);border-radius:var(--radius-full);overflow:hidden}.milestone-card-progress .progress-fill{height:100%;background:var(--color-info);border-radius:var(--radius-full);transition:width .3s ease}.milestone-card-progress .progress-value{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-info);min-width:40px;text-align:right}.payments-summary{background:var(--gradient-primary-subtle);border-radius:var(--radius-xl);padding:var(--space-6);margin-bottom:var(--space-6)}.payments-summary-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6);margin-bottom:var(--space-5)}.payments-summary-item{text-align:center}.payments-summary-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin-bottom:var(--space-1)}.payments-summary-value.success{color:var(--color-success-dark)}.payments-summary-value.warning{color:var(--color-warning-dark)}.payments-summary-label{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.payments-progress{background-color:var(--color-surface);border-radius:var(--radius-lg);overflow:hidden}.payment-history{background-color:var(--color-surface);border-radius:var(--radius-xl);border:1px solid var(--color-border-light);overflow:hidden}.payment-history-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border-light);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.payment-history-list{padding:var(--space-2)}.payment-history-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);border-radius:var(--radius-lg);transition:background-color var(--transition-fast)}.payment-history-item:hover{background-color:var(--color-gray-50)}.payment-history-left{display:flex;align-items:center;gap:var(--space-3)}.payment-history-icon{width:40px;height:40px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center}.payment-history-icon .icon{width:20px;height:20px}.payment-history-icon.success{background-color:var(--color-success-light);color:var(--color-success)}.payment-history-icon.pending{background-color:var(--color-warning-light);color:var(--color-warning)}.payment-history-details{min-width:0}.payment-history-date{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.payment-history-method{font-size:var(--font-size-xs);color:var(--color-text-muted)}.payment-history-right{text-align:right}.payment-history-amount{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.payment-history-amount.success{color:var(--color-success)}.meetings-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4);margin-top:var(--space-6)}.meetings-section-header.meetings-section-divider{margin-top:var(--space-8);padding-top:var(--space-8);border-top:2px solid var(--color-border)}.meetings-section-header:first-child{margin-top:0}.meetings-section-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.meetings-section-count{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:28px;padding:0 var(--space-2);background:var(--color-primary-100);color:var(--color-primary);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold)}.meetings-grid{display:flex;flex-direction:column;gap:var(--space-4)}.meeting-card-full{display:flex;align-items:stretch;gap:var(--space-4);background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);padding:var(--space-4);transition:all var(--transition-fast);cursor:default}.meeting-card-full:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--color-border)}.meeting-card-upcoming{border-left:3px solid var(--color-primary)}.meeting-card-upcoming:hover{box-shadow:var(--shadow-lg),0 0 0 1px var(--color-primary-100)}.meeting-card-past{border-left:3px solid var(--color-gray-300)}.meeting-date-box{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:80px;padding:var(--space-3);background:var(--color-primary-50);border:1px solid var(--color-primary-100);border-radius:var(--radius-lg);text-align:center;flex-shrink:0}.meeting-date-box-past{background:var(--color-gray-100);border-color:var(--color-gray-200);opacity:.8}.meeting-date-day{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-primary);line-height:1;margin-bottom:var(--space-1)}.meeting-date-box-past .meeting-date-day{color:var(--color-gray-600)}.meeting-date-month{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-2)}.meeting-date-time{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-primary);padding:var(--space-1) var(--space-2);background:var(--color-surface);border-radius:var(--radius-md);white-space:nowrap}.meeting-date-box-past .meeting-date-time{color:var(--color-text-muted)}.meeting-card-content{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center}.meeting-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-3);margin-bottom:var(--space-2)}.meeting-card-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0;line-height:var(--line-height-tight)}.meeting-card-past .meeting-card-title{color:var(--color-text-secondary);text-decoration:line-through}.meeting-card-relative{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-muted);white-space:nowrap;flex-shrink:0}.meeting-card-upcoming .meeting-card-relative{color:var(--color-primary)}.meeting-card-summary{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:var(--line-height-normal);margin:0}.meeting-card-past .meeting-card-summary{color:var(--color-text-muted)}.portal-empty-enhanced{padding:var(--space-12) var(--space-4)}.portal-empty-icon-large{width:80px;height:80px;margin:0 auto var(--space-4);background:var(--color-primary-50);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:var(--color-primary)}.portal-empty-icon-large .icon{width:40px;height:40px}.portal-empty-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--space-2) 0}@media(max-width:768px){.meeting-card-full{flex-direction:column;gap:var(--space-3)}.meeting-date-box{flex-direction:row;min-width:auto;width:100%;justify-content:flex-start;gap:var(--space-3);padding:var(--space-3)}.meeting-date-day{font-size:var(--font-size-2xl)}.meeting-date-month,.meeting-date-time{margin-bottom:0}.meeting-card-header{flex-direction:column;align-items:flex-start;gap:var(--space-1)}.meeting-card-relative{white-space:normal}}@media(prefers-reduced-motion:reduce){.meeting-card-full,.meeting-card-full:hover{transform:none;transition:none}}.back-link{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-4);transition:color var(--transition-fast)}.back-link:hover{color:var(--color-primary)}.back-link .icon{width:16px;height:16px}@media(max-width:768px){.profile-header-content{flex-direction:column;align-items:center;text-align:center}.profile-meta,.profile-quick-stats{justify-content:center}.payments-summary-grid{grid-template-columns:1fr;text-align:left}.payments-summary-item{text-align:left;display:flex;justify-content:space-between;align-items:center;padding:var(--space-2) 0;border-bottom:1px solid var(--color-border-light)}.payments-summary-item:last-child{border-bottom:none}.payments-summary-value{margin-bottom:0}.roadmap-hero{flex-direction:column;text-align:center;gap:var(--space-5)}.roadmap-hero-progress{width:100px;height:100px}.progress-center .progress-value{font-size:var(--font-size-xl)}.current-meta{justify-content:center}.milestone-card-header{flex-direction:column;gap:var(--space-2)}}@media(max-width:480px){.roadmap-hero{padding:var(--space-4)}.roadmap-hero-progress{width:80px;height:80px}.progress-center .progress-value{font-size:var(--font-size-lg)}.progress-center .progress-label{font-size:10px}.current-title{font-size:var(--font-size-lg)}.milestone-card{flex-direction:column;gap:var(--space-3);padding:var(--space-4)}.milestone-card-icon{width:32px;height:32px}.milestone-card-icon svg{width:16px;height:16px}}.students-page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-6)}.students-page-header h1{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0}.filters-panel{background-color:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-xl);margin-bottom:var(--space-6);overflow:hidden}.filters-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color var(--transition-fast)}.filters-header:hover{background-color:var(--color-gray-50)}.filters-title{display:flex;align-items:center;gap:var(--space-2);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.filters-title svg{width:18px;height:18px;color:var(--color-text-muted)}.filters-toggle-icon{width:20px;height:20px;color:var(--color-text-muted);transition:transform var(--transition-fast)}.filters-panel.open .filters-toggle-icon{transform:rotate(180deg)}.filters-body{display:none;padding:var(--space-5);border-top:1px solid var(--color-border-light)}.filters-panel.open .filters-body{display:block}.filters-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-4)}.filters-actions{display:flex;gap:var(--space-3);margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--color-border-light)}.btn-link{background:none;border:none;color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;padding:var(--space-2) var(--space-3);transition:color var(--transition-fast)}.btn-link:hover{color:var(--color-text-primary)}.filters-body .search-input-wrapper{max-width:none}.filters-body .search-input-wrapper .form-input{width:100%}.students-toolbar{display:flex;gap:var(--space-4);margin-bottom:var(--space-6);flex-wrap:wrap}.search-input-wrapper{position:relative;flex:1;min-width:200px;max-width:400px}.search-input-wrapper .search-icon{position:absolute;left:var(--space-3);top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--color-text-muted);pointer-events:none}.search-input-wrapper .form-input{padding-left:var(--space-10);width:100%}.filter-buttons{display:flex;gap:var(--space-2)}.btn-filter{padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm);background:var(--color-gray-100);color:var(--color-text-secondary);border:none;border-radius:var(--radius-lg);cursor:pointer;transition:var(--transition-fast)}.btn-filter:hover{background:var(--color-gray-200)}.btn-filter.active{background:var(--color-primary);color:#fff}.students-table{min-width:800px}.students-table th{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em}.students-table .student-cell{min-width:200px}.student-row-link{text-decoration:none;color:inherit;transition:opacity var(--transition-fast)}.student-row-link:hover{opacity:.8}.student-row-link:hover .student-row-name{color:var(--color-primary)}.program-dates{display:flex;flex-direction:column;gap:2px}.program-date-range{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.form-helper-inline{font-size:var(--font-size-xs);font-weight:var(--font-weight-normal);color:var(--color-text-muted)}.students-table .status-cell{width:100px}.students-table .progress-cell{width:150px}.students-table .progress-cell .mini-progress-container{width:100%}.students-table .progress-cell .mini-progress{flex:1;max-width:100px}.students-table .payments-cell{width:140px}.payments-info{display:flex;flex-direction:column;gap:2px}.payments-paid{font-weight:var(--font-weight-semibold);color:var(--color-success)}.payments-total{font-size:var(--font-size-xs);color:var(--color-text-muted)}.students-table .enrolled-cell{width:120px;color:var(--color-text-secondary)}.students-table .actions-cell{width:80px;text-align:right}@media(max-width:768px){.students-page-header{flex-direction:column;align-items:stretch;gap:var(--space-3)}.students-page-header h1{font-size:var(--font-size-xl)}.students-page-header .btn{width:100%}.students-table-container{overflow:visible}.students-table{min-width:unset}.students-table thead{display:none}.students-table tbody{display:flex;flex-direction:column;gap:var(--space-3)}.students-table tbody tr{display:flex;flex-direction:column;background-color:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);padding:var(--space-4)}.students-table tbody tr:hover{background-color:var(--color-surface)}.students-table td{padding:var(--space-2) 0;border-bottom:none}.students-table td:not(:last-child){border-bottom:1px solid var(--color-border-light);padding-bottom:var(--space-3);margin-bottom:var(--space-2)}.students-table .student-cell{min-width:unset;padding-bottom:var(--space-3)}.students-table .student-row{gap:var(--space-4)}.students-table .student-row-avatar{width:48px;height:48px}.students-table .mobile-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}.students-table .status-cell,.students-table .progress-cell,.students-table .payments-cell,.students-table .enrolled-cell{width:auto}.students-table .mobile-label{display:block;font-size:var(--font-size-xs);color:var(--color-text-muted);margin-bottom:var(--space-1);text-transform:uppercase;letter-spacing:.05em}.students-table .actions-cell{width:auto;text-align:left;padding-top:var(--space-2);margin-top:var(--space-2);border-top:1px solid var(--color-border-light)}.students-table .actions-cell .btn{width:100%;justify-content:center}}@media(min-width:769px){.students-table .mobile-label{display:none}.students-table .mobile-grid{display:contents}}@media(max-width:768px){.students-toolbar{flex-direction:column}.search-input-wrapper{max-width:none}.filter-buttons{flex-wrap:wrap}}.students-empty-state{padding:var(--space-10) var(--space-4);text-align:center;color:var(--color-text-muted)}.students-empty-state p{margin:0;font-size:var(--font-size-sm)}.student-switcher{padding:var(--space-3) var(--space-4);border-top:1px solid var(--color-border)}.student-switcher-label{display:block;font-size:var(--font-size-xs);color:var(--color-text-muted);margin-bottom:var(--space-1);font-weight:var(--font-weight-medium)}.student-switcher-select{width:100%;padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface);color:var(--color-text);font-size:var(--font-size-sm);font-family:inherit;cursor:pointer;transition:border-color var(--transition-fast)}.student-switcher-select:hover{border-color:var(--color-primary)}.student-switcher-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #0d94881a}.portal-student-badge{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text)}.portal-student-badge .student-avatar-sm{width:28px;height:28px;border-radius:var(--radius-full);background:var(--gradient-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold)}.portal-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4);margin-bottom:var(--space-6)}.portal-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);margin-bottom:var(--space-5)}.portal-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.portal-section-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text)}.portal-section-link{font-size:var(--font-size-sm);color:var(--color-primary);text-decoration:none;font-weight:var(--font-weight-medium);transition:color var(--transition-fast)}.portal-section-link:hover{color:var(--color-primary-dark)}.current-milestone-card{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4);background:var(--color-surface-secondary);border-radius:var(--radius-md);border:1px solid var(--color-border)}.current-milestone-icon{width:48px;height:48px;border-radius:var(--radius-md);background:#0d94881a;color:var(--color-primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.current-milestone-icon svg{width:24px;height:24px}.current-milestone-info{flex:1;min-width:0}.current-milestone-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text);margin-bottom:var(--space-1)}.current-milestone-meta{font-size:var(--font-size-sm);color:var(--color-text-muted)}.current-milestone-progress{width:80px;text-align:right;flex-shrink:0}.current-milestone-pct{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-primary)}.current-milestone-pct-label{font-size:var(--font-size-xs);color:var(--color-text-muted)}.current-milestone-card{background:linear-gradient(135deg,var(--color-primary-50, #F0FDFA) 0%,var(--color-surface) 60%)}@media(prefers-color-scheme:dark){.current-milestone-card{background:linear-gradient(135deg,rgba(13,148,136,.15) 0%,var(--color-surface) 60%)}}.portal-dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-5)}.meeting-mini-card{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);border-bottom:1px solid var(--color-border-light)}.meeting-mini-card:last-child{border-bottom:none}.meeting-mini-date{text-align:center;min-width:48px;flex-shrink:0}.meeting-mini-date-day{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-primary);line-height:1}.meeting-mini-date-month{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase}.meeting-mini-info{flex:1;min-width:0}.meeting-mini-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text);display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.meeting-mini-summary{font-size:var(--font-size-xs);color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.meeting-mini-card-past .meeting-mini-title{color:var(--color-text-secondary);text-decoration:line-through}.meeting-mini-card-past .meeting-mini-date-day{color:var(--color-text-muted)}.meeting-mini-card{background:linear-gradient(135deg,var(--color-info-light, #DBEAFE) 0%,var(--color-surface) 60%);border-radius:var(--radius-md)}.meeting-mini-card-past{background:linear-gradient(135deg,rgba(148,163,184,.1) 0%,var(--color-surface) 60%)}@media(prefers-color-scheme:dark){.meeting-mini-card{background:linear-gradient(135deg,rgba(59,130,246,.12) 0%,var(--color-surface) 60%)}.meeting-mini-card-past{background:linear-gradient(135deg,rgba(148,163,184,.08) 0%,var(--color-surface) 60%)}}.payment-mini-summary{display:flex;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-4)}.payment-mini-item{text-align:center;flex:1}.payment-mini-value{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text)}.payment-mini-value.success{color:var(--color-success)}.payment-mini-value.warning{color:var(--color-warning)}.payment-mini-label{font-size:var(--font-size-xs);color:var(--color-text-muted)}.payment-mini-bar{height:8px;background:var(--color-border-light);border-radius:var(--radius-full);overflow:hidden}.payment-mini-bar-fill{height:100%;background:var(--gradient-primary);border-radius:var(--radius-full);transition:width var(--transition-slow)}.milestone-progress-control{display:flex;align-items:center;gap:var(--space-3);margin-top:var(--space-3);padding:var(--space-3);background:var(--color-surface-secondary);border-radius:var(--radius-md)}.progress-slider{flex:1;-webkit-appearance:none;appearance:none;height:6px;background:var(--color-border-light);border-radius:var(--radius-full);outline:none;cursor:pointer}.progress-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:var(--radius-full);background:var(--color-primary);cursor:pointer;border:2px solid white;box-shadow:var(--shadow-sm)}.progress-slider::-moz-range-thumb{width:18px;height:18px;border-radius:var(--radius-full);background:var(--color-primary);cursor:pointer;border:2px solid white;box-shadow:var(--shadow-sm)}.progress-slider-value{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-primary);min-width:40px;text-align:right}.milestone-mark-complete{margin-top:var(--space-3)}.portal-empty{text-align:center;padding:var(--space-8) var(--space-4);color:var(--color-text-muted)}.portal-empty-icon{width:48px;height:48px;margin:0 auto var(--space-3);color:var(--color-text-light)}.portal-empty-text{font-size:var(--font-size-sm)}.portal-confirm-modal{display:none;position:fixed;inset:0;z-index:var(--z-modal);background:#00000080;align-items:center;justify-content:center}.portal-confirm-modal.active{display:flex}.portal-confirm-content{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-6);max-width:400px;width:90%;box-shadow:var(--shadow-xl);text-align:center}.portal-confirm-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text);margin-bottom:var(--space-2)}.portal-confirm-message{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-bottom:var(--space-5)}.portal-confirm-actions{display:flex;gap:var(--space-3);justify-content:center}@media(max-width:1024px){.portal-dashboard-grid{grid-template-columns:1fr}.portal-stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.portal-stats-grid{grid-template-columns:1fr}.portal-nav-list{overflow-x:auto;-webkit-overflow-scrolling:touch}.portal-nav-link{white-space:nowrap;padding:var(--space-2) var(--space-3);font-size:var(--font-size-xs)}.current-milestone-card{flex-direction:column;text-align:center}.current-milestone-progress{width:auto;text-align:center}.payment-mini-summary{flex-direction:column;gap:var(--space-2)}}.roadmap-program-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.roadmap-program-subtitle{font-size:var(--font-size-base);color:var(--color-text-secondary);margin-top:var(--space-1)}.roadmap-month{margin-bottom:var(--space-8)}.roadmap-month-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding-bottom:var(--space-4);margin-bottom:var(--space-4);border-bottom:2px solid var(--color-border)}.roadmap-month-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.roadmap-month-title span{color:var(--color-text-secondary);font-weight:var(--font-weight-normal);font-size:var(--font-size-base);margin-left:var(--space-2)}.roadmap-month-progress{display:flex;align-items:center;gap:var(--space-3);min-width:200px}.roadmap-month-progress-bar{flex:1;height:6px;background:var(--color-gray-200);border-radius:var(--radius-full);overflow:hidden}.roadmap-month-progress-fill{height:100%;background:var(--gradient-primary);border-radius:var(--radius-full);transition:width var(--transition-slow)}.roadmap-month-progress-text{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-primary);white-space:nowrap}.roadmap-week-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:var(--space-3);overflow:hidden;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.roadmap-week-card:hover{box-shadow:var(--shadow-sm)}.roadmap-week-card.status-in-progress{border-left:3px solid var(--color-info)}.roadmap-week-card.status-completed{border-left:3px solid var(--color-success)}.roadmap-week-card.status-not-started{border-left:3px solid var(--color-gray-300)}.roadmap-week-card.locked{opacity:.6;pointer-events:auto}.roadmap-week-card.locked .roadmap-week-icon{background:linear-gradient(135deg,var(--color-gray-200) 0%,var(--color-gray-300) 100%);color:var(--color-gray-500)}.roadmap-week-card.locked .roadmap-week-title{color:var(--color-text-muted)}.portal-roadmap .roadmap-week-card.locked{border-color:var(--color-gray-300);background:var(--color-gray-50)}.portal-roadmap .roadmap-week-card.locked:hover{transform:none;box-shadow:var(--shadow-xs)}.week-lock-message{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-4);margin-bottom:var(--space-4);background:linear-gradient(135deg,#6b728014,#9ca3af14);border:1px dashed var(--color-gray-400);border-radius:var(--radius-lg);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-600)}.week-lock-message .lock-icon{width:18px;height:18px;color:var(--color-gray-500)}.week-lock-message .lock-icon svg{width:100%;height:100%}.roadmap-item.locked{opacity:.5;cursor:not-allowed;pointer-events:none}.roadmap-item.locked:hover{background-color:transparent;transform:none}.roadmap-item.locked .roadmap-item-checkmark{border-color:var(--color-gray-300);background:var(--color-gray-100)}.item-lock-icon{margin-left:auto;color:var(--color-gray-400)}.item-lock-icon svg{width:14px;height:14px}.roadmap-week-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color var(--transition-fast)}.roadmap-week-header:hover{background-color:var(--color-gray-50)}.roadmap-week-icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.roadmap-week-icon svg{width:22px;height:22px}.status-completed .roadmap-week-icon{background:var(--color-success-light);color:var(--color-success)}.status-in-progress .roadmap-week-icon{background:var(--color-info-light);color:var(--color-info)}.status-not-started .roadmap-week-icon{background:var(--color-gray-100);color:var(--color-gray-400)}.roadmap-week-info{flex:1;min-width:0}.roadmap-week-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-1)}.roadmap-week-meta{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.roadmap-week-skills .skill-tag{font-size:var(--font-size-xs);padding:1px var(--space-2)}.roadmap-week-count{font-size:var(--font-size-xs);color:var(--color-text-secondary);white-space:nowrap}.roadmap-week-mini-progress{width:60px;height:4px;background:var(--color-gray-200);border-radius:var(--radius-full);overflow:hidden;flex-shrink:0}.roadmap-week-mini-progress-fill{height:100%;background:var(--gradient-primary);border-radius:var(--radius-full);transition:width var(--transition-slow)}.roadmap-week-chevron{width:20px;height:20px;color:var(--color-text-muted);flex-shrink:0;transition:transform var(--transition-fast)}.roadmap-week-chevron svg{width:20px;height:20px}.roadmap-week-card.expanded .roadmap-week-chevron{transform:rotate(180deg)}.roadmap-week-body{max-height:0;overflow:hidden;transition:max-height .3s ease}.roadmap-week-card.expanded .roadmap-week-body{max-height:1000px}.roadmap-week-body-inner{padding:0 var(--space-5) var(--space-4) var(--space-5);border-top:1px solid var(--color-border-light)}.roadmap-category{padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);border-left:3px solid;margin-top:var(--space-3)}.roadmap-category.type-learning{background:#3b82f60d;border-left-color:var(--color-info)}.roadmap-category.type-project{background:#0d94880d;border-left-color:var(--color-primary)}.roadmap-category.type-career{background:#f59e0b0d;border-left-color:var(--color-warning)}.roadmap-category.type-next_steps{background:#8b5cf60d;border-left-color:#8b5cf6}.roadmap-category-label{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-2)}.roadmap-category-label svg{width:14px;height:14px}.roadmap-category-label.type-learning{background:var(--color-info-light);color:var(--color-info-dark)}.roadmap-category-label.type-project{background:var(--color-primary-100);color:var(--color-primary-700)}.roadmap-category-label.type-career{background:var(--color-warning-light);color:var(--color-warning-dark)}.roadmap-category-label.type-next_steps{background:#8b5cf61a;color:#6d28d9}.roadmap-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);transition:background-color var(--transition-fast);cursor:pointer}.roadmap-item:hover{background-color:#00000008}.roadmap-item-checkbox{position:relative;width:20px;height:20px;flex-shrink:0}.roadmap-item-checkbox input{position:absolute;opacity:0;width:100%;height:100%;cursor:pointer;z-index:1;margin:0}.roadmap-item-checkmark{position:absolute;top:0;left:0;width:20px;height:20px;border:2px solid var(--color-gray-300);border-radius:var(--radius-sm);background:var(--color-surface);transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.roadmap-item-checkmark svg{width:12px;height:12px;color:#fff;opacity:0;transition:opacity var(--transition-fast)}.roadmap-item-checkbox input:checked+.roadmap-item-checkmark{background:var(--color-primary);border-color:var(--color-primary)}.roadmap-item-checkbox input:checked+.roadmap-item-checkmark svg{opacity:1}.roadmap-item-checkbox input:focus-visible+.roadmap-item-checkmark{box-shadow:0 0 0 3px #0d948833}.roadmap-item-title{font-size:var(--font-size-base);color:var(--color-text-primary);transition:color var(--transition-fast);line-height:var(--line-height-normal)}.roadmap-item.checked .roadmap-item-title{color:var(--color-text-muted);text-decoration:line-through}.roadmap-item-readonly{display:flex;align-items:center;gap:var(--space-2);padding:2px 0;font-size:var(--font-size-sm);color:var(--color-text-primary)}.roadmap-item-readonly svg{flex-shrink:0}.roadmap-item-readonly.completed{color:var(--color-text-muted);text-decoration:line-through}.portal-roadmap .roadmap-hero{background:linear-gradient(135deg,var(--color-primary-800) 0%,var(--color-primary-600) 100%);border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl),0 8px 32px #0d948833;overflow:hidden;position:relative;padding:var(--space-8)}.portal-roadmap .roadmap-hero:before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.08) 1px,transparent 1px);background-size:20px 20px;pointer-events:none}.portal-roadmap .roadmap-hero:after{content:"";position:absolute;top:-40px;right:-40px;width:160px;height:160px;background:radial-gradient(circle,rgba(16,185,129,.3) 0%,transparent 70%);border-radius:50%;pointer-events:none}.portal-roadmap .roadmap-hero-progress{width:140px;height:140px;position:relative;z-index:1}.portal-roadmap .circular-progress-hero .progress-bg{stroke:#ffffff26;stroke-width:8}.portal-roadmap .circular-progress-hero .progress-fill{stroke-width:8;filter:drop-shadow(0 0 6px rgba(16,185,129,.5))}.portal-roadmap .progress-center .progress-value{font-size:var(--font-size-3xl);color:#fff}.portal-roadmap .progress-center .progress-label{color:#ffffffb3}.portal-roadmap .roadmap-hero-info{position:relative;z-index:1}.portal-roadmap .current-label{color:#fff9}.portal-roadmap .current-title{font-size:var(--font-size-2xl);color:#fff}.portal-roadmap .current-meta{color:#ffffffb3}.portal-roadmap .current-meta .duration{background:#ffffff1f;color:#ffffffe6}.portal-roadmap .current-meta .progress-text{color:var(--color-accent-300)}.portal-roadmap .completion-bar{border-top-color:#ffffff1a}.portal-roadmap .completion-track{background:#ffffff26}.portal-roadmap .completion-fill{background:linear-gradient(90deg,var(--color-accent-400) 0%,var(--color-accent-300) 100%);box-shadow:0 0 8px #10b98166}.portal-roadmap .completion-text{color:#fffc;display:inline-flex;align-items:center;gap:var(--space-2)}.portal-roadmap .completion-icon{flex-shrink:0;opacity:.8}.portal-roadmap .program-title-section{padding:var(--space-8) 0 var(--space-6)}.portal-roadmap .roadmap-program-title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);letter-spacing:-.02em;position:relative;padding-bottom:var(--space-3)}.portal-roadmap .roadmap-program-title:after{content:"";position:absolute;bottom:0;left:0;width:60px;height:4px;background:var(--gradient-primary);border-radius:var(--radius-full)}.portal-roadmap .roadmap-month-header{background:var(--gradient-primary-subtle);border-radius:var(--radius-xl);border-bottom:none;padding:var(--space-5) var(--space-6);margin-bottom:var(--space-5);box-shadow:var(--shadow-xs)}.portal-roadmap .roadmap-month-title{color:var(--color-primary-800);display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.portal-roadmap .month-number{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--gradient-primary);color:#fff;font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);border-radius:var(--radius-full);box-shadow:var(--shadow-primary);flex-shrink:0}.portal-roadmap .month-task-count{background:var(--color-primary-100);color:var(--color-primary-700);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);margin-left:auto}.portal-roadmap .roadmap-month-progress-bar{height:8px;background:var(--color-primary-100)}.portal-roadmap .roadmap-month-progress-fill{box-shadow:0 0 6px #0d94884d}.portal-roadmap .roadmap-month-progress-text{background:#0d948814;padding:2px var(--space-2);border-radius:var(--radius-full)}.portal-roadmap .roadmap-week-card{box-shadow:var(--shadow-xs);border-radius:var(--radius-xl);border-color:var(--color-border-light);transition:transform var(--transition-fast),box-shadow var(--transition-fast),border-color var(--transition-fast)}.portal-roadmap .roadmap-week-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--color-primary-200)}.portal-roadmap .roadmap-week-card.status-in-progress,.portal-roadmap .roadmap-week-card.status-completed,.portal-roadmap .roadmap-week-card.status-not-started{border-left-width:4px}.portal-roadmap .roadmap-week-card.expanded{border-color:var(--color-primary-200);box-shadow:var(--shadow-sm),0 0 0 1px #0d948814}.portal-roadmap .roadmap-week-icon{width:48px;height:48px;border-radius:var(--radius-lg)}.portal-roadmap .status-completed .roadmap-week-icon{background:linear-gradient(135deg,var(--color-success-light) 0%,#bbf7d0 100%);box-shadow:0 2px 8px #22c55e26}.portal-roadmap .status-in-progress .roadmap-week-icon{background:linear-gradient(135deg,var(--color-info-light) 0%,#bfdbfe 100%);box-shadow:0 2px 8px #3b82f626}.portal-roadmap .status-not-started .roadmap-week-icon{background:linear-gradient(135deg,var(--color-gray-100) 0%,var(--color-gray-200) 100%)}.portal-roadmap .roadmap-week-header{padding:var(--space-5) var(--space-6)}.portal-roadmap .roadmap-week-title{font-weight:var(--font-weight-bold);letter-spacing:-.01em}.portal-roadmap .roadmap-week-skills .skill-tag{border:1px solid var(--color-primary-100)}.portal-roadmap .roadmap-week-mini-progress{width:80px;height:6px}.portal-roadmap .roadmap-week-body-inner{padding:var(--space-5) var(--space-6) var(--space-5) var(--space-6);background:var(--color-gray-50);border-top:none;position:relative}.portal-roadmap .roadmap-week-body-inner:before{content:"";position:absolute;top:0;left:var(--space-6);right:var(--space-6);height:1px;background:linear-gradient(90deg,transparent,var(--color-primary-100),transparent)}.portal-roadmap .roadmap-category{padding:var(--space-4) var(--space-5);border-radius:var(--radius-lg);background:var(--color-surface);box-shadow:var(--shadow-xs);border:1px solid var(--color-border-light);border-left-width:4px;border-left-style:solid;margin-top:var(--space-4);overflow:hidden}.portal-roadmap .roadmap-category:first-child{margin-top:0}.portal-roadmap .roadmap-category-label{font-size:var(--font-size-xs);border-radius:var(--radius-md);display:flex;width:100%;align-items:center;padding:var(--space-3);margin-bottom:var(--space-3)}.portal-roadmap .roadmap-category-label svg{width:16px;height:16px;flex-shrink:0;display:block}.portal-roadmap .roadmap-category-label.type-learning{border-bottom:1px solid rgba(59,130,246,.15)}.portal-roadmap .roadmap-category-label.type-project{border-bottom:1px solid rgba(13,148,136,.15)}.portal-roadmap .roadmap-category-label.type-career{border-bottom:1px solid rgba(245,158,11,.15)}.portal-roadmap .roadmap-category-label.type-next_steps{border-bottom:1px solid rgba(139,92,246,.15)}.portal-roadmap .category-count{margin-left:auto;font-size:var(--font-size-xs);font-weight:var(--font-weight-normal);text-transform:none;letter-spacing:normal;color:var(--color-text-muted)}.portal-roadmap .roadmap-item{padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);border-bottom:1px solid var(--color-border-light);transition:background-color var(--transition-fast),transform var(--transition-fast)}.portal-roadmap .roadmap-item:last-child{border-bottom:none}.portal-roadmap .roadmap-item:hover{background-color:#0d94880f;transform:translate(2px)}.portal-roadmap .roadmap-item.checked{opacity:.6;cursor:default}.portal-roadmap .roadmap-item.checked:hover{background-color:transparent;transform:none}.portal-roadmap .roadmap-item.checked .roadmap-item-title{text-decoration-color:#0006}.portal-roadmap .roadmap-item-feedback-badge{display:inline-flex;align-items:center;gap:5px;margin-left:auto;flex-shrink:0;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-primary-700);background:#0d94881f;padding:3px 10px;border-radius:var(--radius-full);cursor:pointer;transition:background-color var(--transition-fast),transform var(--transition-fast);animation:feedbackBadgeAttention 2s ease-in-out .5s 2}.portal-roadmap .roadmap-item-feedback-badge:hover{background:#0d948833;transform:scale(1.05)}.portal-roadmap .roadmap-item-feedback-badge svg{width:14px;height:14px;flex-shrink:0}@keyframes feedbackBadgeAttention{0%,to{box-shadow:0 0 #0d948800}50%{box-shadow:0 0 0 4px #0d948826}}.portal-roadmap .roadmap-item-passed{font-size:var(--font-size-xs);color:var(--color-success);font-weight:var(--font-weight-medium);margin-left:auto;flex-shrink:0;opacity:.8}.portal-roadmap .roadmap-item-checkbox{width:22px;height:22px}.portal-roadmap .roadmap-item-checkmark{width:22px;height:22px;border-radius:var(--radius-md);transition:all .2s cubic-bezier(.4,0,.2,1)}.portal-roadmap .roadmap-item:hover .roadmap-item-checkmark{border-color:var(--color-primary-200)}.portal-roadmap .roadmap-item-checkbox input:checked+.roadmap-item-checkmark{background:var(--gradient-primary);border-color:var(--color-primary);box-shadow:0 2px 6px #0d948840;transform:scale(1.05)}.portal-roadmap .roadmap-item-checkmark svg{transition:opacity .2s cubic-bezier(.4,0,.2,1)}@media(max-width:768px){.portal-roadmap .roadmap-hero{flex-direction:column;padding:var(--space-6);text-align:center}.portal-roadmap .roadmap-hero-progress{width:120px;height:120px}.portal-roadmap .current-title{font-size:var(--font-size-xl)}.portal-roadmap .roadmap-program-title{font-size:var(--font-size-2xl)}.portal-roadmap .roadmap-month-header,.portal-roadmap .roadmap-week-header{padding:var(--space-4)}.portal-roadmap .roadmap-week-icon{width:40px;height:40px}.portal-roadmap .roadmap-week-body-inner{padding:var(--space-4) var(--space-4) var(--space-4) var(--space-4)}.portal-roadmap .roadmap-week-body-inner:before{left:var(--space-4);right:var(--space-4)}.portal-roadmap .roadmap-category{padding:var(--space-3) var(--space-4)}.portal-roadmap .roadmap-item{padding:var(--space-2) var(--space-3)}}@media(max-width:768px){.roadmap-month-header{flex-direction:column;align-items:flex-start;gap:var(--space-2)}.roadmap-month-progress{width:100%;min-width:unset}.roadmap-week-header{padding:var(--space-3)}.roadmap-week-skills{display:none}.roadmap-week-mini-progress{width:40px}.roadmap-week-body-inner{padding:0 var(--space-3) var(--space-3) var(--space-3)}.roadmap-category{padding:var(--space-2) var(--space-3)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.welcome-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;background:linear-gradient(135deg,#0f172a,#1e293b,#0d9488);font-family:var(--font-family-sans);position:relative;overflow:hidden}.welcome-page:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 600px 600px at 20% 80%,rgba(13,148,136,.25),transparent),radial-gradient(ellipse 500px 500px at 80% 20%,rgba(16,185,129,.15),transparent);pointer-events:none;z-index:0}.welcome-page>*{position:relative;z-index:1}.welcome-header{width:100%;padding:var(--space-5) var(--space-8)}.welcome-header-brand{display:flex;align-items:center;gap:var(--space-3)}.welcome-header-logo{width:40px;height:40px;background:var(--gradient-primary);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:#fff}.welcome-header-text{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:#fff}.welcome-hero{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-8) var(--space-6);max-width:700px;animation:fadeInUp .6s ease-out}.welcome-hero-logo{width:100px;height:100px;background:var(--gradient-primary);border-radius:var(--radius-2xl);display:flex;align-items:center;justify-content:center;color:#fff;margin-bottom:var(--space-6);box-shadow:0 0 40px #0d948866}.welcome-hero-brand{font-size:3rem;font-weight:var(--font-weight-bold);color:#fff;margin:0 0 var(--space-3);line-height:var(--line-height-tight)}.welcome-hero-tagline{font-size:1.5rem;color:#ffffffe6;margin:0 0 var(--space-4);font-weight:var(--font-weight-medium)}.welcome-hero-desc{font-size:1.125rem;color:#ffffffb3;margin:0 0 var(--space-10);line-height:var(--line-height-relaxed);max-width:520px}.welcome-hero-actions{display:flex;align-items:center;gap:var(--space-4);flex-wrap:wrap;justify-content:center}.welcome-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);border-radius:var(--radius-lg);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);text-decoration:none;cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.welcome-btn:hover{transform:translateY(-2px)}.welcome-btn-arrow{transition:transform var(--transition-fast)}.welcome-btn:hover .welcome-btn-arrow{transform:translate(4px)}.welcome-btn-primary{background:#fff;color:var(--color-primary);box-shadow:0 4px 14px #00000026}.welcome-btn-primary:hover{box-shadow:0 8px 24px #00000040}.welcome-btn-outline{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.5)}.welcome-btn-outline:hover{border-color:#fff;box-shadow:0 8px 24px #00000026}.welcome-features{width:100%;max-width:960px;padding:0 var(--space-6) var(--space-16);animation:fadeInUp .6s ease-out .2s both}.welcome-features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6)}.welcome-feature-card{background:#ffffff14;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-xl);padding:var(--space-8) var(--space-6);text-align:center;transition:transform var(--transition-fast),background var(--transition-fast)}.welcome-feature-card:hover{transform:translateY(-4px);background:#ffffff1f}.welcome-feature-icon{width:56px;height:56px;background:#ffffff1a;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:var(--color-accent-300);margin:0 auto var(--space-5)}.welcome-feature-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:#fff;margin:0 0 var(--space-3)}.welcome-feature-desc{font-size:var(--font-size-sm);color:#ffffffa6;margin:0;line-height:var(--line-height-relaxed)}.welcome-footer{width:100%;border-top:1px solid rgba(255,255,255,.1);padding:var(--space-8) var(--space-6);text-align:center}.welcome-footer-copy{font-size:var(--font-size-sm);color:#fff9;margin:0 0 var(--space-1)}.welcome-footer-sub{font-size:var(--font-size-xs);color:#fff6;margin:0}@media(max-width:768px){.welcome-header-text{display:none}.welcome-hero-brand{font-size:2.25rem}.welcome-hero-logo{width:80px;height:80px}.welcome-hero-logo svg{width:40px;height:40px}.welcome-hero-tagline{font-size:1.25rem}.welcome-hero-desc{font-size:1rem}.welcome-hero-actions{flex-direction:column;width:100%}.welcome-btn{width:100%;justify-content:center}.welcome-features-grid{grid-template-columns:1fr}}@keyframes authFadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.auth-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;background:linear-gradient(135deg,#0f172a,#1e293b,#0d9488);font-family:var(--font-family-sans);position:relative;overflow:hidden}.auth-page:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 600px 600px at 20% 80%,rgba(13,148,136,.25),transparent),radial-gradient(ellipse 500px 500px at 80% 20%,rgba(16,185,129,.15),transparent);pointer-events:none;z-index:0}.auth-page>*{position:relative;z-index:1}.auth-header{width:100%;padding:var(--space-5) var(--space-8)}.auth-header-brand{display:flex;align-items:center;gap:var(--space-3);text-decoration:none}.auth-header-logo{width:40px;height:40px;background:var(--gradient-primary);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:#fff}.auth-header-text{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:#fff}.auth-content{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--space-8) var(--space-6);width:100%}.auth-card{background:#ffffff14;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-xl);padding:var(--space-10) var(--space-8);width:100%;max-width:420px;animation:authFadeInUp .6s ease-out}.auth-card-icon{width:56px;height:56px;background:#ffffff1a;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:var(--color-accent-300);margin:0 auto var(--space-5)}.auth-card-title{font-size:1.5rem;font-weight:var(--font-weight-bold);color:#fff;text-align:center;margin:0 0 var(--space-2)}.auth-card-subtitle{font-size:var(--font-size-sm);color:#fff9;text-align:center;margin:0 0 var(--space-8)}.auth-form .form-group{margin-bottom:var(--space-5)}.auth-form .form-label{color:#ffffffd9}.auth-form .form-input{background:#ffffff0f;border-color:#ffffff26;color:#fff}.auth-form .form-input::placeholder{color:#ffffff59}.auth-form .form-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #0d948840;background:#ffffff14}.auth-form .btn{margin-top:var(--space-2)}.auth-card-footer{text-align:center;margin-top:var(--space-6);padding-top:var(--space-6);border-top:1px solid rgba(255,255,255,.1)}.auth-card-footer p{font-size:var(--font-size-sm);color:#ffffff80;margin:0}.auth-card-footer a{color:var(--color-accent-300);text-decoration:none;font-weight:var(--font-weight-medium);transition:color var(--transition-fast)}.auth-card-footer a:hover{color:#fff}.auth-footer{width:100%;border-top:1px solid rgba(255,255,255,.1);padding:var(--space-6) var(--space-6);text-align:center}.auth-footer p{font-size:var(--font-size-xs);color:#fff6;margin:0}.auth-alert{padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);font-size:var(--font-size-sm);margin-bottom:var(--space-6)}.auth-alert-error{background:#ef444426;border:1px solid rgba(239,68,68,.3);color:#fca5a5}.auth-form .form-input.input-error{border-color:#ef444480}.auth-form .form-input.input-error:focus{border-color:#ef4444b3;box-shadow:0 0 0 3px #ef444433}.auth-quickfill{margin-top:var(--space-4);text-align:center}.btn-quickfill{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:transparent;border:1px dashed rgba(255,255,255,.25);border-radius:var(--radius-lg);color:#ffffff80;font-size:var(--font-size-xs);cursor:pointer;transition:all var(--transition-fast)}.btn-quickfill:hover{border-color:var(--color-accent-300);color:var(--color-accent-300);background:#ffffff0d}@media(max-width:480px){.auth-header{padding:var(--space-4) var(--space-5)}.auth-header-text{display:none}.auth-content{padding:var(--space-4) var(--space-4)}.auth-card{padding:var(--space-8) var(--space-5)}}
