:root{--background: #ffffff;--foreground: #0f172a;--card: #ffffff;--card-foreground: #0f172a;--primary: #10b981;--primary-foreground: #ffffff;--secondary: #f1f5f9;--secondary-foreground: #0f172a;--muted: #f1f5f9;--muted-foreground: #64748b;--accent: #f1f5f9;--accent-foreground: #0f172a;--destructive: #ef4444;--destructive-foreground: #ffffff;--border: #e2e8f0;--input: #e2e8f0;--ring: #10b981;--radius: .5rem}.dark{--background: #0a0f1e;--foreground: #f8fafc;--card: #1a1f35;--card-foreground: #f8fafc;--primary: #10b981;--primary-foreground: #022c22;--secondary: #1e293b;--secondary-foreground: #f8fafc;--muted: #1e293b;--muted-foreground: #94a3b8;--accent: #1e2538;--accent-foreground: #f8fafc;--destructive: #ef4444;--destructive-foreground: #f8fafc;--border: #2d3548;--input: #1e293b;--ring: #047857}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--background);color:var(--foreground);transition:background-color .3s ease,color .3s ease}button{font-family:inherit;cursor:pointer}input,textarea,select{font-family:inherit}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--background)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--muted-foreground)}::selection{background:#10b9814d;color:var(--foreground)}:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.btn{display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;border-radius:.375rem;font-size:.875rem;font-weight:500;transition:all .2s;border:none;outline:none}.btn:focus-visible{outline:2px solid var(--ring);outline-offset:2px}.btn:disabled{pointer-events:none;opacity:.5}.btn-default{background-color:var(--primary);color:var(--primary-foreground)}.btn-default:hover:not(:disabled){opacity:.9}.btn-destructive{background-color:var(--destructive);color:var(--destructive-foreground)}.btn-destructive:hover:not(:disabled){opacity:.9}.btn-outline{border:1px solid var(--input);background-color:var(--background)}.btn-outline:hover:not(:disabled){background-color:var(--accent);color:var(--accent-foreground)}.btn-secondary{background-color:var(--secondary);color:var(--secondary-foreground)}.btn-secondary:hover:not(:disabled){opacity:.8}.btn-ghost{background-color:transparent;color:var(--foreground)}.btn-ghost:hover:not(:disabled){background-color:var(--accent);color:var(--accent-foreground)}.btn-link{background-color:transparent;color:var(--primary);text-decoration:underline;text-underline-offset:4px}.btn-link:hover:not(:disabled){text-decoration:none}.btn-default{height:2.5rem;padding:.5rem 1rem}.btn-sm{height:2.25rem;padding:.5rem .75rem;border-radius:.375rem}.btn-lg{height:2.75rem;padding:.5rem 2rem;border-radius:.375rem}.btn-icon{height:2.5rem;width:2.5rem;padding:0}.admin-layout{min-height:100vh;background-color:var(--background)}.sidebar{position:fixed;left:0;top:0;z-index:40;height:100vh;transition:all .3s cubic-bezier(.4,0,.2,1);border-right:1px solid var(--border);background:var(--card);display:flex;flex-direction:column;box-shadow:2px 0 12px #0000000d}.sidebar.collapsed{width:4.5rem}.sidebar:not(.collapsed){width:16rem}.sidebar.mobile-hidden{transform:translate(-100%)}@media(min-width:1024px){.sidebar.mobile-hidden{transform:translate(0)}}.sidebar-logo{display:flex;height:4.5rem;align-items:center;border-bottom:1px solid var(--border);padding:0;background:linear-gradient(135deg,#10b9810d,#0596690d)}.sidebar-logo-content{display:flex;align-items:center;width:100%;height:100%}.sidebar-logo-icon{width:2.5rem;height:2.5rem;background:linear-gradient(135deg,#10b981,#059669);border-radius:.625rem;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:1.125rem;box-shadow:0 4px 12px #10b9814d;flex-shrink:0}.sidebar-logo-text{font-weight:700;font-size:1.25rem;background:linear-gradient(135deg,#10b981,#059669);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em}.sidebar-logo-img{width:100%;height:100%;object-fit:contain;display:block;border-radius:0;box-shadow:none;flex-shrink:0}.sidebar-nav{flex:1;overflow-y:auto;padding:1rem .75rem}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-track{background:transparent}.sidebar-nav::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:var(--muted-foreground)}.sidebar-nav-list{display:flex;flex-direction:column;gap:.375rem}.sidebar-nav-item{width:100%;display:flex;align-items:center;gap:.875rem;padding:.75rem 1rem;border-radius:.625rem;font-size:.9375rem;font-weight:500;transition:all .2s cubic-bezier(.4,0,.2,1);background:none;border:none;color:var(--muted-foreground);text-align:left;cursor:pointer;position:relative;overflow:hidden}.sidebar-nav-item:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--primary);transform:scaleY(0);transition:transform .2s}.sidebar-nav-item:hover{background:var(--accent);color:var(--foreground);transform:translate(2px)}.sidebar-nav-item.active{background:linear-gradient(135deg,#10b98126,#05966926);color:var(--primary);font-weight:600}.sidebar-nav-item.active:before{transform:scaleY(1)}.sidebar.collapsed .sidebar-nav-item{justify-content:center;padding:.75rem}.sidebar-nav-icon{width:1.375rem;height:1.375rem;flex-shrink:0}.sidebar-nav-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.main-content{transition:all .3s cubic-bezier(.4,0,.2,1);min-height:100vh;display:flex;flex-direction:column}.main-content.sidebar-collapsed{margin-left:4.5rem}.main-content.sidebar-expanded{margin-left:16rem}@media(max-width:1023px){.main-content.sidebar-collapsed,.main-content.sidebar-expanded{margin-left:0}}.header{position:sticky;top:0;z-index:30;display:flex;height:4.5rem;align-items:center;gap:1rem;border-bottom:1px solid var(--border);background:var(--card);padding:0 1.25rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 1px 3px #0000000d}@media(min-width:1024px){.header{padding:0 2rem}}.header-actions{display:flex;align-items:center;gap:.5rem;margin-left:auto}.header-actions button{position:relative;transition:all .2s;color:var(--foreground)}.header-actions button:hover{background:var(--accent);transform:translateY(-1px)}.header-actions button:active{transform:translateY(0)}.header-user{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;margin-left:.5rem;border-left:1px solid var(--border);border-radius:.5rem;transition:all .2s;cursor:pointer}.header-user:hover{background:var(--accent)}.header-user-avatar{width:2.25rem;height:2.25rem;background:linear-gradient(135deg,#10b981,#059669);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.875rem;box-shadow:0 2px 8px #10b9814d;flex-shrink:0}.header-user-name{font-size:.9375rem;font-weight:600;color:var(--foreground);display:none}@media(min-width:768px){.header-user-name{display:inline-block}}.page-content{flex:1;padding:1.5rem;background:var(--background)}@media(min-width:1024px){.page-content{padding:2rem}}.mobile-overlay{position:fixed;inset:0;z-index:30;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media(min-width:1024px){.mobile-overlay{display:none}}.hide-on-mobile{display:none}@media(min-width:1024px){.hide-on-mobile{display:flex}}.show-on-mobile{display:flex}@media(min-width:1024px){.show-on-mobile{display:none}}.dark .sidebar{background:var(--card);border-right-color:var(--border)}.dark .header{background:var(--card);border-bottom-color:var(--border)}.dark .sidebar-nav-item:hover{background:var(--accent);color:var(--foreground)}.dark .sidebar-nav-item.active{background:#10b98126;color:var(--primary)}.dark .mobile-overlay{background:#000c}*{transition-property:background-color,border-color,color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.card{border-radius:.5rem;border:1px solid var(--border);background-color:var(--card);color:var(--card-foreground);box-shadow:0 1px 2px #0000000d}.card-header{display:flex;flex-direction:column;gap:.375rem;padding:1.5rem}.card-title{font-size:1.5rem;font-weight:600;line-height:1;letter-spacing:-.025em}.card-description{font-size:.875rem;color:var(--muted-foreground)}.card-content{padding:1.5rem;padding-top:0}.card-footer{display:flex;align-items:center;padding:1.5rem;padding-top:0}.dashboard{display:flex;flex-direction:column;gap:2rem}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:1rem}.dashboard-header h1{font-size:1.875rem;font-weight:700;letter-spacing:-.025em;margin:0 0 .25rem;background:linear-gradient(135deg,var(--foreground) 0%,var(--muted-foreground) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.dashboard-header p{color:var(--muted-foreground);margin:0}.date-badge{background:var(--card);padding:.5rem 1rem;border-radius:.5rem;border:1px solid var(--border);font-size:.875rem;color:var(--foreground);font-weight:500;box-shadow:0 1px 2px #0000000d}.section-container{display:flex;flex-direction:column;gap:1rem}.section-title{display:flex;align-items:center;gap:.75rem;color:var(--foreground)}.section-title h2{font-size:1.25rem;font-weight:600;margin:0;letter-spacing:-.02em}.section-title svg{color:var(--primary);opacity:.8}.stats-grid{display:grid;gap:1.5rem}.main-stats{grid-template-columns:repeat(1,1fr)}@media(min-width:640px){.main-stats{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.main-stats{grid-template-columns:repeat(3,1fr)}}.resources-stats{grid-template-columns:repeat(1,1fr)}@media(min-width:640px){.resources-stats{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.resources-stats{grid-template-columns:repeat(3,1fr)}}@media(min-width:1280px){.resources-stats{grid-template-columns:repeat(5,1fr)}}.stat-card{background:var(--card);border:1px solid var(--border);transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;border-radius:1rem}.stat-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px -10px #0000001a}.stat-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;opacity:.5;transition:opacity .3s}.stat-card:hover:before{opacity:1}.border-blue:before{background-color:#3b82f6}.border-yellow:before{background-color:#f59e0b}.border-green:before{background-color:#10b981}.border-purple:before{background-color:#8b5cf6}.border-indigo:before{background-color:#6366f1}.border-pink:before{background-color:#ec4899}.border-orange:before{background-color:#f97316}.border-cyan:before{background-color:#06b6d4}.border-blue,.border-yellow,.border-green,.border-purple,.border-indigo,.border-pink,.border-orange,.border-cyan{border-left:1px solid var(--border)}.stat-card-header{display:flex;justify-content:space-between;align-items:flex-start;padding:1.5rem}.stat-title{font-size:.75rem;font-weight:600;color:var(--muted-foreground);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.stat-main-value{font-size:1.75rem;font-weight:800;line-height:1;margin-bottom:.5rem;color:var(--foreground)}.stat-change{display:flex;align-items:center;gap:.25rem;font-size:.875rem;font-weight:500}.stat-change.up{color:#10b981}.stat-change.down{color:#ef4444}.stat-period{color:var(--muted-foreground);font-size:.75rem;font-weight:400;margin-left:.25rem}.stat-icon-wrapper{width:3.5rem;height:3.5rem;border-radius:1rem;display:flex;align-items:center;justify-content:center;transition:transform .3s ease}.stat-card:hover .stat-icon-wrapper{transform:scale(1.1) rotate(5deg)}.stat-icon{width:1.5rem;height:1.5rem}.bg-blue{background:#3b82f61a}.text-blue{color:#3b82f6}.bg-yellow{background:#f59e0b1a}.text-yellow{color:#f59e0b}.bg-green{background:#10b9811a}.text-green{color:#10b981}.bg-purple{background:#8b5cf61a}.text-purple{color:#8b5cf6}.bg-indigo{background:#6366f11a}.text-indigo{color:#6366f1}.bg-pink{background:#ec48991a}.text-pink{color:#ec4899}.bg-orange{background:#f973161a}.text-orange{color:#f97316}.bg-cyan{background:#06b6d41a}.text-cyan{color:#06b6d4}.content-grid{display:grid;gap:1.5rem;grid-template-columns:1fr}@media(min-width:1024px){.content-grid{grid-template-columns:2fr 1fr}}.chart-container{display:flex;align-items:flex-end;justify-content:space-between;height:250px;padding-top:2rem}.chart-column{display:flex;flex-direction:column;align-items:center;gap:.75rem;flex:1}.chart-bar-container{width:100%;height:100%;display:flex;align-items:flex-end;justify-content:center;position:relative}.chart-bar{width:60%;background:linear-gradient(180deg,#10b981,#059669);border-radius:.375rem .375rem 0 0;transition:all .3s;position:relative;cursor:pointer}.chart-bar:hover{opacity:.8;width:70%}.chart-tooltip{position:absolute;top:-2rem;left:50%;transform:translate(-50%);background:var(--foreground);color:var(--background);padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:600;opacity:0;transition:opacity .2s;white-space:nowrap;pointer-events:none;z-index:10}.chart-bar:hover .chart-tooltip{opacity:1}.chart-label{font-size:.75rem;color:var(--muted-foreground);font-weight:500}.activity-list{display:flex;flex-direction:column;gap:1.25rem}.activity-item{display:flex;align-items:center;gap:1rem;padding-bottom:1.25rem;border-bottom:1px solid var(--border);transition:background-color .2s;border-radius:.5rem;padding:.5rem}.activity-item:hover{background-color:var(--accent)}.activity-item:last-child{border-bottom:none;padding-bottom:.5rem}.activity-icon{width:2.5rem;height:2.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.activity-icon svg{color:#fff}.activity-icon.bg-blue svg{color:#3b82f6}.activity-icon.bg-yellow svg{color:#f59e0b}.activity-icon.bg-purple svg{color:#8b5cf6}.activity-icon.bg-green svg{color:#10b981}.activity-icon.bg-orange svg{color:#f97316}.activity-icon.bg-cyan svg{color:#06b6d4}.activity-details{display:flex;flex-direction:column;gap:.25rem}.activity-text{font-size:.875rem;font-weight:500;color:var(--foreground);margin:0}.activity-time{font-size:.75rem;color:var(--muted-foreground)}.input{display:flex;height:2.5rem;width:100%;border-radius:.375rem;border:1px solid var(--input);background-color:var(--background);color:var(--foreground);padding:.5rem .75rem;font-size:.875rem;transition:all .2s}.input::placeholder{color:var(--muted-foreground)}.input:focus{outline:none;border-color:var(--ring);box-shadow:0 0 0 2px var(--ring)}.input:disabled{cursor:not-allowed;opacity:.5}.input[type=file]{border:1px dashed var(--input);cursor:pointer}.modal-overlay{position:fixed;inset:0;z-index:50;display:flex;align-items:center;justify-content:center;padding:1rem}.modal-backdrop{position:absolute;inset:0;background-color:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{position:relative;z-index:51;width:100%;max-width:28rem;background-color:var(--card);border:1px solid var(--border);border-radius:1rem;padding:1.5rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1rem}.modal-icon{width:3rem;height:3rem;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:1rem}.modal-icon.danger{background-color:#ef44441a;color:var(--destructive)}.modal-icon.warning{background-color:#f59e0b1a;color:#f59e0b}.modal-icon.info{background-color:#3b82f61a;color:#3b82f6}.modal-close-btn{background:transparent;border:none;color:var(--muted-foreground);cursor:pointer;padding:.5rem;border-radius:.375rem;transition:all .2s}.modal-close-btn:hover{background-color:var(--accent);color:var(--foreground)}.modal-title{font-size:1.25rem;font-weight:600;color:var(--foreground);margin:0 0 .5rem}.modal-description{font-size:.9375rem;color:var(--muted-foreground);line-height:1.5;margin:0}.modal-footer{margin-top:2rem;display:flex;justify-content:flex-end;gap:.75rem}.loading-spinner-sm{width:1rem;height:1rem;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite;margin-right:.5rem}.dark .modal-backdrop{background-color:#000000b3}.dark .modal-content{background-color:var(--card)}.listening-manager-page{max-width:1200px;margin:0 auto;padding:2rem}.tests-section{background:var(--card);border:1px solid var(--border);border-radius:.75rem;padding:1.5rem}.tests-list{display:flex;flex-direction:column;gap:.75rem}.test-card{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:var(--accent);border:1px solid var(--border);border-radius:.5rem;transition:all .2s}.test-card:hover{background:var(--muted)}.test-info{flex:1}.test-title{font-size:.9375rem;font-weight:600;margin:0 0 .25rem;color:var(--foreground)}.test-date{font-size:.8125rem;color:var(--muted-foreground);margin:0}.delete-button{flex-shrink:0}.form-textarea{background:var(--background);border:1px solid var(--border);border-radius:.5rem;padding:.75rem 1rem;font-size:.875rem;color:var(--foreground);resize:vertical;min-height:80px;transition:all .2s;width:100%}.form-select{background:var(--background);border:1px solid var(--border);border-radius:.5rem;padding:.75rem 1rem;font-size:.875rem;color:var(--foreground);cursor:pointer;transition:all .2s;width:100%}.error-message{display:flex;align-items:center;gap:.5rem;padding:.875rem 1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:.5rem;font-size:.875rem;color:var(--destructive);margin-bottom:.5rem}.difficulty-badge{display:inline-block;padding:.125rem .5rem;background:var(--primary);color:#fff;border-radius:.25rem;font-size:.75rem;font-weight:600}.status-active{color:var(--primary);font-weight:600}.status-inactive{color:var(--muted-foreground)}.animate-spin{animation:spin 1s linear infinite}.reading-manager-page{max-width:1200px;margin:0 auto;padding:2rem}.upload-section{background:var(--card);border:1px solid var(--border);border-radius:.75rem;padding:1.5rem;margin-bottom:2rem}.file-upload-row{display:grid;grid-template-columns:1fr;gap:1rem}@media(min-width:768px){.file-upload-row{grid-template-columns:1fr 1fr}}.file-upload-group,.file-upload-button-group{display:flex;flex-direction:column;gap:.5rem}.file-upload-label{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--secondary);border:1px solid var(--border);border-radius:.5rem;font-size:.875rem;font-weight:500;color:var(--foreground);cursor:pointer;transition:all .2s}.file-upload-label:hover{background:var(--accent)}.upload-icon{width:1rem;height:1rem}.file-name{font-size:.75rem;color:var(--muted-foreground);padding:0 .5rem}.submit-button{width:100%;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:.875rem;border-radius:.5rem;font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .2s;display:flex;align-items:center;justify-content:center}.submit-button:disabled{opacity:.7;cursor:not-allowed}.passages-list{display:flex;flex-direction:column;gap:1rem}.passage-card{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:var(--card);border:1px solid var(--border);border-radius:.75rem}.passage-info{display:flex;align-items:center;gap:1rem}.passage-icon-wrapper{padding:.75rem;border-radius:.5rem;display:flex;align-items:center;justify-content:center}.passage-details h3{font-size:1.125rem;font-weight:600;margin:0 0 .25rem;color:var(--foreground)}.passage-meta{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--muted-foreground)}.badge{padding:.125rem .5rem;border-radius:9999px;font-size:.75rem;font-weight:500;text-transform:uppercase}.badge-hard{background:#fee2e2;color:#b91c1c}.badge-medium{background:#fef3c7;color:#b45309}.badge-easy{background:#d1fae5;color:#047857}.status-active{color:#059669;font-weight:500}.status-inactive{color:#6b7280;font-weight:500}.icon-hard{background:#fee2e2;color:#b91c1c}.icon-medium{background:#fef3c7;color:#b45309}.icon-easy{background:#d1fae5;color:#047857}.delete-button{color:#ef4444;padding:.5rem;border-radius:.375rem;transition:all .2s}.delete-button:hover{background:#fef2f2;color:#b91c1c}.resources-page{max-width:1200px;margin:0 auto;padding:2rem}.page-title-section{margin-bottom:2rem}.page-title-content{display:flex;align-items:center;gap:1rem}.page-title-icon{width:2.5rem;height:2.5rem;color:var(--primary)}.page-title{font-size:1.875rem;font-weight:700;margin:0;color:var(--foreground)}.page-subtitle{font-size:.875rem;color:var(--muted-foreground);margin:.25rem 0 0}.tabs-container{display:flex;gap:.5rem;margin-bottom:2rem;padding:.5rem;background:var(--card);border:1px solid var(--border);border-radius:.75rem;overflow-x:auto}.tab-button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:transparent;border:none;border-radius:.5rem;font-size:.9375rem;font-weight:500;color:var(--muted-foreground);cursor:pointer;transition:all .2s;white-space:nowrap}.tab-button:hover{background:var(--accent);color:var(--foreground)}.tab-button.active{background:var(--primary);color:#fff}.tab-icon{width:1.125rem;height:1.125rem}.tab-content{display:flex;flex-direction:column;gap:2rem}.upload-section{background:var(--card);border:1px solid var(--border);border-radius:.75rem;padding:1.5rem}.collapse-button{width:100%;display:flex;align-items:center;gap:.75rem;padding:0;background:none;border:none;color:var(--foreground);font-size:1rem;font-weight:600;cursor:pointer;transition:color .2s}.collapse-button:hover{color:var(--primary)}.collapse-icon{width:1.25rem;height:1.25rem}.upload-form{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:1.25rem}.form-field{display:flex;flex-direction:column;gap:.5rem}.form-label{font-size:.875rem;font-weight:500;color:var(--foreground)}.form-input{background:var(--background);border:1px solid var(--border);border-radius:.5rem;padding:.75rem 1rem;font-size:.875rem;color:var(--foreground);transition:all .2s}.form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #10b9811a}.form-input::placeholder{color:var(--muted-foreground)}.form-textarea{background:var(--background);border:1px solid var(--border);border-radius:.5rem;padding:.75rem 1rem;font-size:.875rem;color:var(--foreground);resize:vertical;min-height:100px;transition:all .2s}.form-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #10b9811a}.form-textarea::placeholder{color:var(--muted-foreground)}.form-select{background:var(--background);border:1px solid var(--border);border-radius:.5rem;padding:.75rem 1rem;font-size:.875rem;color:var(--foreground);cursor:pointer;transition:all .2s}.form-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #10b9811a}.form-file-input{background:var(--background);border:1px solid var(--border);border-radius:.5rem;padding:.75rem 1rem;font-size:.875rem;color:var(--foreground);cursor:pointer;transition:all .2s}.form-file-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #10b9811a}.form-file-input::file-selector-button{background:var(--secondary);border:1px solid var(--border);border-radius:.375rem;padding:.5rem 1rem;margin-right:1rem;font-size:.875rem;font-weight:500;color:var(--foreground);cursor:pointer;transition:all .2s}.form-file-input::file-selector-button:hover{background:var(--accent)}.form-row{display:grid;grid-template-columns:1fr;gap:1rem}@media(min-width:768px){.form-row{grid-template-columns:1fr 1fr}}.task-section{padding:1.25rem;background:var(--accent);border:1px solid var(--border);border-radius:.5rem;display:flex;flex-direction:column;gap:1rem}.task-header{margin-bottom:.5rem}.task-badge{display:inline-block;padding:.375rem .875rem;background:var(--primary);color:#fff;border-radius:.375rem;font-size:.8125rem;font-weight:600}.submit-button{width:100%;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:.875rem;border-radius:.5rem;font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .2s}.submit-button:hover{opacity:.9}.items-section{background:var(--card);border:1px solid var(--border);border-radius:.75rem;padding:1.5rem}.section-title{font-size:1.125rem;font-weight:600;margin:0 0 1.5rem;color:var(--foreground)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}.empty-icon{width:4rem;height:4rem;color:var(--muted-foreground);opacity:.5;margin-bottom:1rem}.empty-text{font-size:.875rem;color:var(--muted-foreground);margin:0}.items-list{display:flex;flex-direction:column;gap:.75rem}.item-card{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:var(--accent);border:1px solid var(--border);border-radius:.5rem;transition:all .2s}.item-card:hover{background:var(--muted)}.item-info{flex:1}.item-title{font-size:.9375rem;font-weight:600;margin:0 0 .25rem;color:var(--foreground)}.item-subtitle{font-size:.8125rem;color:var(--muted-foreground);margin:0}.item-description{font-size:.8125rem;color:var(--foreground);margin:.5rem 0 0;line-height:1.5}@media(max-width:768px){.resources-page{padding:1rem}.page-title{font-size:1.5rem}.tabs-container{padding:.25rem}.tab-button{padding:.625rem 1rem;font-size:.875rem}.upload-section,.items-section{padding:1rem}}.label{font-size:.875rem;font-weight:500;line-height:1;display:block;margin-bottom:.5rem}.label:has(+:disabled){cursor:not-allowed;opacity:.7}.profile-page{display:flex;flex-direction:column;gap:1.5rem}.profile-grid{display:grid;gap:1.5rem;grid-template-columns:repeat(1,1fr)}@media(min-width:768px){.profile-grid{grid-template-columns:repeat(2,1fr)}}.profile-card{background:var(--card);border:1px solid var(--border)}.profile-form,.stats-list{display:flex;flex-direction:column;gap:1rem}.stat-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:var(--accent);border-radius:.5rem}.stat-label{font-size:.875rem;color:var(--muted-foreground)}.stat-value{font-size:1.25rem;font-weight:600;color:var(--primary)}.info-list{display:flex;flex-direction:column;gap:1rem}.info-item{display:flex;align-items:center;gap:1rem;padding:.75rem;background:var(--accent);border-radius:.5rem}.info-icon{width:2.5rem;height:2.5rem;padding:.5rem;background:var(--primary);color:var(--primary-foreground);border-radius:.5rem}.info-label{font-size:.75rem;color:var(--muted-foreground);margin-bottom:.25rem}.info-value{font-size:.875rem;font-weight:500}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:var(--background)}.login-background{position:absolute;inset:0;z-index:0;overflow:hidden}.login-gradient-orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.3;animation:float 20s ease-in-out infinite}.orb-1{width:500px;height:500px;background:linear-gradient(135deg,#10b981,#059669);top:-250px;left:-250px;animation-delay:0s}.orb-2{width:400px;height:400px;background:linear-gradient(135deg,#3b82f6,#2563eb);bottom:-200px;right:-200px;animation-delay:7s}.orb-3{width:350px;height:350px;background:linear-gradient(135deg,#8b5cf6,#7c3aed);top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:14s}@keyframes float{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-30px) scale(1.1)}66%{transform:translate(-20px,20px) scale(.9)}}.login-container{position:relative;z-index:1;display:grid;grid-template-columns:1fr;gap:2rem;width:100%;max-width:1200px;padding:2rem}@media(min-width:1024px){.login-container{grid-template-columns:1fr 1fr;gap:4rem}}.login-left{display:none;flex-direction:column;justify-content:center;gap:3rem}@media(min-width:1024px){.login-left{display:flex}}.login-brand{text-align:center}.login-brand-logo{width:5rem;height:5rem;margin:0 auto 1.5rem;border-radius:1.5rem;object-fit:contain;box-shadow:0 20px 60px #10b9814d;animation:pulse 3s ease-in-out infinite}.login-brand-icon{width:5rem;height:5rem;margin:0 auto 1.5rem;background:linear-gradient(135deg,#10b981,#059669);border-radius:1.5rem;display:flex;align-items:center;justify-content:center;box-shadow:0 20px 60px #10b9814d;animation:pulse 3s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);box-shadow:0 20px 60px #10b9814d}50%{transform:scale(1.05);box-shadow:0 25px 70px #10b98166}}.brand-icon{width:3rem;height:3rem;color:#fff}.login-brand-title{font-size:3rem;font-weight:800;background:linear-gradient(135deg,#10b981,#059669);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 .5rem;letter-spacing:-.02em}.login-brand-subtitle{font-size:1.25rem;color:var(--muted-foreground);font-weight:500;margin:0}.login-features{display:flex;flex-direction:column;gap:1.5rem}.login-feature{display:flex;gap:1rem;padding:1.5rem;background:var(--card);border:1px solid var(--border);border-radius:1rem;transition:all .3s}.login-feature:hover{transform:translateY(-4px);box-shadow:0 12px 24px #0000001a;border-color:var(--primary)}.feature-icon{width:3rem;height:3rem;background:linear-gradient(135deg,#10b981,#059669);border-radius:.75rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.feature-icon svg{width:1.5rem;height:1.5rem;color:#fff}.feature-content h3{font-size:1.125rem;font-weight:600;margin:0 0 .25rem;color:var(--foreground)}.feature-content p{font-size:.875rem;color:var(--muted-foreground);margin:0;line-height:1.5}.login-right{display:flex;align-items:center;justify-content:center}.login-card{width:100%;max-width:28rem;background:var(--card);border:1px solid var(--border);border-radius:1.5rem;padding:2.5rem;box-shadow:0 20px 60px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.login-card-header{text-align:center;margin-bottom:2rem}.login-icon-wrapper{width:4rem;height:4rem;margin:0 auto 1.5rem;background:linear-gradient(135deg,#10b981,#059669);border-radius:1rem;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px #10b9814d}.login-icon{width:2rem;height:2rem;color:#fff}.login-title{font-size:1.875rem;font-weight:700;margin:0 0 .5rem;color:var(--foreground)}.login-subtitle{font-size:.9375rem;color:var(--muted-foreground);margin:0;line-height:1.5}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.input-wrapper{position:relative}.input-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);width:1.125rem;height:1.125rem;color:var(--muted-foreground);pointer-events:none;z-index:1}.input-with-icon{padding-left:2.75rem}.login-error{display:flex;align-items:center;gap:.5rem;padding:.875rem 1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:.5rem;font-size:.875rem;color:var(--destructive);animation:shake .4s}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}.error-icon{font-size:1.125rem}.login-button{width:100%;padding:.875rem;font-size:1rem;font-weight:600;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:.5rem;color:#fff;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:.5rem}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #10b98166}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed}.button-icon{width:1.125rem;height:1.125rem}.loading-spinner{width:1.125rem;height:1.125rem;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.dark .login-card{background:#1e293bcc;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.dark .login-feature{background:#1e293b99;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.dark .login-gradient-orb{opacity:.2}@media(max-width:1023px){.login-container{padding:1rem;gap:2rem}.login-left{display:none}.login-card{max-width:100%;padding:2rem}}@media(max-width:640px){.login-page{padding:1rem;align-items:flex-start}.login-container{padding:0;margin-top:2rem}.login-card{padding:1.5rem;border:none;box-shadow:none;background:transparent}.login-background{opacity:.5}.login-brand-title{font-size:2rem}.login-title{font-size:1.5rem}.input-with-icon{height:3rem;font-size:1rem}.login-button{height:3rem}}.not-found-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background-color:var(--background);padding:2rem}.not-found-content{text-align:center;max-width:500px;width:100%;padding:3rem;background-color:var(--card);border-radius:var(--radius);border:1px solid var(--border);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.not-found-icon{margin-bottom:2rem;display:flex;justify-content:center;color:hsl(var(--destructive))}.not-found-title{font-size:6rem;font-weight:800;line-height:1;margin:0;background:linear-gradient(to right,hsl(var(--primary)),hsl(var(--primary-foreground)));-webkit-background-clip:text;background-clip:text;color:transparent;margin-bottom:1rem}.not-found-subtitle{font-size:2rem;font-weight:700;margin-bottom:1rem;color:var(--foreground)}.not-found-description{font-size:1.1rem;color:var(--muted-foreground);margin-bottom:2.5rem;line-height:1.6}.not-found-actions{display:flex;justify-content:center;gap:1rem}.not-found-button{min-width:200px}
