:root{--background: 222 22% 8%;--foreground: 210 20% 92%;--card: 222 20% 11%;--card-foreground: 210 20% 92%;--popover: 222 20% 11%;--popover-foreground: 210 20% 92%;--primary: 217 76% 58%;--primary-foreground: 0 0% 100%;--secondary: 220 18% 16%;--secondary-foreground: 210 16% 80%;--muted: 220 16% 15%;--muted-foreground: 220 10% 52%;--accent: 217 76% 58%;--accent-foreground: 0 0% 100%;--destructive: 0 72% 51%;--destructive-foreground: 0 0% 98%;--border: 220 16% 16%;--input: 220 16% 16%;--ring: 217 76% 58%;--chart-1: 217 76% 58%;--chart-2: 160 60% 45%;--chart-3: 30 80% 55%;--chart-4: 280 65% 60%;--chart-5: 340 75% 55%;--radius: .75rem;--sidebar-background: 222 24% 6%;--sidebar-foreground: 220 10% 50%;--sidebar-primary: 217 76% 58%;--sidebar-primary-foreground: 0 0% 100%;--sidebar-accent: 222 20% 12%;--sidebar-accent-foreground: 210 16% 86%;--sidebar-border: 220 16% 12%;--sidebar-ring: 217 76% 58%}:root{--bg-primary: #050505;--bg-secondary: #0f1012;--bg-card: rgba(255, 255, 255, .03);--bg-glass: rgba(18, 18, 20, .9);--bg-glass-strong: rgba(14, 14, 16, .96);--gpa-green-light: #34d399;--gpa-green: #10b981;--gpa-green-dark: #059669;--text-primary: #f0f4f8;--text-secondary: #94a3b8;--text-tertiary: #64748b;--text-muted: #475569;--accent-primary: #3b82f6;--accent-primary-hover: #2563eb;--accent-purple: #8b5cf6;--accent-purple-hover: #7c3aed;--brand-gradient: linear-gradient(135deg, #3b82f6 0%, #8b5cf6 100%);--accent-success: #10b981;--accent-error: #ef4444;--accent-warning: #f59e0b;--border-color: rgba(255, 255, 255, .1);--border-glass: rgba(255, 255, 255, .06);--shadow-glass: 0 6px 18px rgba(0, 0, 0, .35);--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--glow-primary: 0 0 20px rgba(59, 130, 246, .5);--glow-purple: 0 0 20px rgba(139, 92, 246, .4);--font-xs: .75rem;--font-sm: .875rem;--font-base: 1rem;--font-lg: 1.125rem;--font-xl: 1.25rem;--font-2xl: 1.5rem;--font-3xl: 2rem;--font-4xl: 3rem;font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.6;color-scheme:dark}*{box-sizing:border-box}html{scroll-behavior:smooth}*{-webkit-tap-highlight-color:transparent}button,a,.v0-button-ghost{transition:transform .18s ease,background .18s ease,color .18s ease,border-color .18s ease,box-shadow .18s ease}button:active,a:active,.v0-button-ghost:active{transform:scale(.98)}.v0-container{width:100%;max-width:1200px;margin:0 auto;padding:2rem 1rem}.v0-grid{display:grid;gap:1.5rem;width:100%}.v0-grid-3{grid-template-columns:1fr}.degree-header-buttons{flex-wrap:wrap}@media(max-width:640px){.degree-header{flex-direction:column;align-items:flex-start;gap:.75rem}.degree-header-stats{font-size:.8rem;opacity:.8}.degree-header h1{font-size:1.25rem}.degree-header-buttons{width:100%;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.5rem}.degree-header-buttons .v0-button-ghost{width:100%;justify-content:center;font-size:.75rem;padding:.5rem .7rem}.degree-legend{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem 1rem;padding:0 .5rem 1.25rem;justify-items:start}.degree-legend span{font-size:.8rem}.exams-bottom-bar{padding:.5rem 0;justify-content:center}.exams-bottom-bar .v0-button-ghost{width:100%;justify-content:center}.exams-grid{grid-template-columns:1fr!important}}@media(min-width:1024px){.v0-grid-3{grid-template-columns:2fr 1fr}}.v0-card{background:var(--bg-glass);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid var(--border-glass);border-radius:1.25rem;padding:1.5rem;transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease,background .2s ease;box-shadow:var(--shadow-glass)}.v0-card:hover{border-color:#ffffff1f;transform:translateY(-1px);background:var(--bg-glass-strong)}@media(hover:none){.v0-card:hover{border-color:var(--border-glass);transform:none;background:var(--bg-glass)}.v0-button-ghost:hover:not(:disabled){background:transparent;color:var(--text-secondary);border-color:transparent}}.v0-badge{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.v0-badge-primary{background:#3b82f626;color:var(--accent-primary);border:1px solid rgba(59,130,246,.3)}.v0-badge-success{background:#10b98126;color:var(--accent-success);border:1px solid rgba(16,185,129,.3)}.v0-animate-in{animation:v0-fade-up .6s cubic-bezier(.4,0,.2,1) forwards;opacity:0}@keyframes v0-fade-up{0%{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}::-webkit-scrollbar{display:none}input::-webkit-outer-spin-button,input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]{appearance:textfield;-moz-appearance:textfield}body{margin:0;background:var(--bg-primary);background-color:var(--bg-primary);color:var(--text-primary);min-height:100vh;-webkit-font-smoothing:antialiased;overflow-x:hidden;width:100%}.app-container{display:flex;flex-direction:column;min-height:100vh;width:100%;max-width:1400px;margin:0 auto}.top-bar{background:var(--bg-secondary);padding:.5rem 1rem;font-size:var(--font-xs);color:var(--text-tertiary);text-align:center;border-bottom:1px solid var(--border-color)}.top-bar a{color:var(--accent-primary);text-decoration:none;font-weight:500;transition:opacity .2s}.top-bar a:hover{opacity:.8}.app-header{padding:1rem 1.5rem;display:flex;flex-direction:column;gap:1.5rem;border-bottom:1px solid var(--border-color);background:#050505cc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);position:relative;z-index:100}@media(min-width:768px){.app-header{flex-direction:row;align-items:center;justify-content:space-between;position:sticky;top:0}}.app-sidebar{transition:transform .3s cubic-bezier(.4,0,.2,1)}@media(max-width:768px){.app-sidebar{position:fixed;left:0;top:0;height:100%;z-index:1000;transform:translate(-100%);box-shadow:4px 0 24px #00000080}.app-sidebar.open{transform:translate(0)}}.auth-container{display:flex;flex-direction:column;min-height:100vh;padding:2rem;position:relative;overflow:hidden}.auth-content{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;max-width:1200px;margin:0 auto;flex:1;position:relative;z-index:10}.auth-hero{display:none;flex-direction:column;justify-content:center;color:var(--text-primary);padding-right:4rem}.auth-hero h1{font-size:4rem;font-weight:800;line-height:1.1;margin-bottom:1.5rem;background:linear-gradient(135deg,#fff 0%,var(--text-secondary) 100%);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.header-title{display:block}.mobile-search-toggle{display:none}.desktop-search-bar{display:block}@media(max-width:768px){.header-title{display:none}.mobile-search-toggle{display:block}.desktop-search-bar{display:none}}.dashboard-filters{padding:1.5rem 2rem;display:flex;gap:.75rem;overflow-x:auto;flex-shrink:0;max-width:100vw}.gpa-course-row{position:relative;display:flex;gap:1rem;align-items:flex-end;padding:.75rem 1rem;padding-right:45px;background:#ffffff08;border:1px solid var(--border-color);border-radius:12px}.gpa-input-group{display:flex;gap:1rem}.gpa-standing-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.gpa-layout{display:grid;grid-template-columns:2fr 1fr;gap:2rem;width:100%}.gpa-card{width:100%;padding:2rem;border-radius:24px;background:var(--bg-secondary);border:1px solid var(--border-color)}.gpa-container{padding:2rem;display:flex;flex-direction:column;align-items:center;width:100%}.dashboard-content{flex:1;padding:0 2rem 2rem}.profile-container{padding:2rem;width:100%}.profile-card{border-radius:24px;padding:3rem;display:flex;align-items:center;gap:2rem;position:relative;overflow:hidden;box-shadow:0 4px 20px -5px #0000001a}.profile-header-content{position:relative;z-index:1}.profile-details-row{display:flex;gap:1rem;flex-wrap:wrap}.profile-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-top:1.5rem}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.5rem}.exam-card{background:var(--bg-glass);border:1px solid var(--border-glass);border-radius:1rem;padding:1.25rem;display:flex;flex-direction:row;align-items:center;gap:1rem;cursor:pointer;transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease;position:relative;isolation:isolate}.exam-card:hover{transform:translateY(-1px)}.exam-card:before,.exam-card:after{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;opacity:0;transition:opacity .2s ease}.exam-card:before{padding:1px;background:linear-gradient(90deg,transparent 0%,var(--major-color, var(--accent-primary)) 50%,transparent 100%);background-size:200% 100%;-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude}.exam-card:after{box-shadow:0 0 0 1px var(--major-color, var(--accent-primary)),0 0 16px 2px color-mix(in srgb,var(--major-color, var(--accent-primary)) 65%,transparent);filter:blur(4px)}.exam-card:hover:before,.exam-card:hover:after{opacity:1}.exam-card:hover:before{animation:exam-card-sheen 1.4s ease-in-out infinite}@keyframes exam-card-sheen{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.exam-card-major{background:transparent;border:1px solid var(--text-secondary);border-radius:999px;padding:.25rem .75rem;color:var(--text-primary);font-size:.8rem;font-weight:700;transition:border-color .2s ease}@media(max-width:768px){.dashboard-filters{padding:1rem}.dashboard-content{padding:0 1rem 1rem}.dashboard-grid{grid-template-columns:1fr}.gpa-container{padding:1rem}.gpa-course-row{flex-direction:column;align-items:stretch!important;gap:1rem!important;padding:1.25rem!important;background:var(--bg-secondary)!important;border:1px solid var(--border-color)!important;border-radius:16px!important;margin-bottom:1rem;box-shadow:var(--shadow-sm)}.gpa-input-group{width:100%;display:grid;grid-template-columns:1fr 1fr;gap:1rem}.gpa-input-group.single{grid-template-columns:1fr}.gpa-standing-grid{grid-template-columns:1fr!important}.gpa-course-row input,.gpa-course-row select{width:100%!important;max-width:100%!important}.desktop-spacer{display:none}.gpa-layout{display:flex;flex-direction:column;gap:1rem}.gpa-card{padding:1rem!important}.gpa-container{padding:.5rem!important;width:100%;overflow-x:hidden}.profile-container{padding:1rem!important}.profile-card{flex-direction:column;padding:1.5rem!important;text-align:center;gap:1rem!important}.profile-details-row{justify-content:center}}.auth-hero p{font-size:1.25rem;color:var(--text-secondary);max-width:500px;line-height:1.6}.auth-form-wrapper{width:100%;max-width:420px;display:flex;justify-content:center}.login-parallax-page{background:radial-gradient(circle at 20% 20%,rgba(59,130,246,.12),transparent 45%),radial-gradient(circle at 80% 70%,rgba(139,92,246,.12),transparent 45%),var(--bg-primary);isolation:isolate}.login-parallax-bg{position:fixed;inset:0;overflow:hidden;pointer-events:none;z-index:0}.login-layer{position:absolute;transition:transform .12s linear}.login-layer-grid{inset:-20%;background-image:linear-gradient(to right,rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(to bottom,rgba(255,255,255,.025) 1px,transparent 1px);background-size:44px 44px}.login-layer-orb{width:26rem;height:26rem;border-radius:999px;filter:blur(100px);opacity:.26}.login-layer-orb.one{top:-7rem;left:-6rem;background:var(--accent-primary)}.login-layer-orb.two{top:24%;right:-8rem;background:var(--accent-purple)}.login-layer-orb.three{bottom:-10rem;left:35%;background:var(--accent-primary)}.login-topbar{width:100%;max-width:1200px;margin:0 auto 1rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;position:relative;z-index:2}.login-brand{display:flex;align-items:center;gap:.6rem}.login-brand-logo{height:64px;width:auto;object-fit:contain;mix-blend-mode:screen;filter:drop-shadow(0 4px 14px rgba(0,0,0,.45))}.login-brand-name{font-size:1.35rem;font-weight:800;line-height:1.1}.login-brand-sub{font-size:.72rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em}.login-register-btn{border:1px solid var(--border-color);background:#ffffff0a;color:var(--text-primary);padding:.65rem 1rem;border-radius:.8rem;font-weight:600;cursor:pointer}.login-register-btn:hover{background:#ffffff14}.login-auth-layout{position:relative;z-index:2}.login-project-panel{display:none}.login-tag{display:inline-flex;border:1px solid var(--border-color);border-radius:999px;padding:.35rem .75rem;font-size:.72rem;color:var(--text-secondary);margin-bottom:1rem;text-transform:uppercase;letter-spacing:.08em}.login-title{font-size:3.25rem;line-height:1.05;margin:0 0 1rem;letter-spacing:-.03em}.login-subtitle{margin:0;max-width:560px;color:var(--text-secondary);font-size:1.05rem}.login-feature-grid{margin-top:1.75rem;display:grid;grid-template-columns:1fr;gap:.75rem;max-width:560px}.login-feature-card{display:flex;gap:.75rem;align-items:flex-start;background:#ffffff09;border:1px solid var(--border-color);border-radius:.9rem;padding:.85rem;opacity:0;transform:translateY(16px) scale(.985);transition:opacity .55s ease,transform .55s cubic-bezier(.2,.8,.2,1)}.login-feature-card.is-visible{opacity:1;transform:translateY(0) scale(1)}.login-feature-card strong{font-size:.92rem}.login-feature-card p{margin:.2rem 0 0;color:var(--text-secondary);font-size:.84rem}.login-feature-card[data-feature-index="1"].is-visible{transition-delay:.12s}.login-feature-card[data-feature-index="2"].is-visible{transition-delay:.24s}.login-stats-row{margin-top:1.4rem;display:flex;gap:.8rem;max-width:560px}.login-stats-row>div{flex:1;border:1px solid var(--border-color);border-radius:.8rem;padding:.75rem;background:#ffffff08;display:flex;flex-direction:column;gap:.15rem}.login-stats-row span{font-size:1.1rem;font-weight:800}.login-stats-row small{font-size:.7rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em}.login-form-card{width:100%;max-width:430px;padding:2.1rem;border-radius:1.2rem;border:1px solid var(--border-color);background:#0f1012eb}.login-form-header{display:inline-flex;align-items:center;gap:.45rem;margin-bottom:1.2rem;color:var(--text-secondary);font-size:.9rem}.login-error-banner{margin-bottom:1rem;padding:.75rem;border-radius:.75rem;background:#ef44441c;border:1px solid rgba(239,68,68,.25);color:var(--accent-error);font-size:.88rem}.login-form-stack{display:flex;flex-direction:column;gap:.9rem}.login-input-label{display:flex;flex-direction:column;gap:.45rem;font-size:.85rem;color:var(--text-secondary)}.login-input-wrap{display:flex;align-items:center;gap:.5rem;border:1px solid var(--border-color);border-radius:.75rem;background:#0003;padding:.6rem .75rem}.login-input-wrap:focus-within{border-color:var(--accent-primary)}.login-input-wrap input{width:100%;border:none;outline:none;background:transparent;color:var(--text-primary);font-size:.95rem}.login-submit-btn{margin-top:.45rem;border:none;border-radius:.8rem;padding:.85rem 1rem;background:var(--accent-primary);color:#fff;font-weight:700;cursor:pointer}.login-submit-btn:disabled{opacity:.7;cursor:wait}.login-bottom-links{margin-top:.9rem}.login-bottom-links button{border:none;background:none;color:var(--text-tertiary);font-size:.82rem;cursor:pointer}.login-bottom-links button:hover{color:var(--text-secondary)}@media(min-width:1024px){.auth-content{flex-direction:row;align-items:center;justify-content:space-between;padding:0 2rem}.auth-hero{display:flex;width:50%}.auth-form-wrapper{width:50%;justify-content:flex-end}.login-project-panel{display:block;width:52%;padding-right:2rem}.login-auth-layout .auth-form-wrapper{width:48%}}@media(max-width:1023px){.login-brand-sub{display:none}.login-topbar{margin-bottom:.4rem}.login-form-card{padding:1.35rem}}.sidebar-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:998;opacity:0;visibility:hidden;transition:all .3s}.sidebar-overlay.open{opacity:1;visibility:visible}.menu-toggle{display:block;background:none;border:none;color:var(--text-primary);cursor:pointer;padding:.5rem}@media(min-width:768px){.menu-toggle,.sidebar-overlay{display:none}}.gpa-layout{display:grid;grid-template-columns:1fr;gap:2rem;width:100%;max-width:1200px;align-items:start}@media(min-width:1024px){.gpa-layout{grid-template-columns:1.5fr 1fr}}.header-brand{display:flex;align-items:center;gap:1rem;justify-content:space-between}.brand-icon{color:var(--accent-primary);filter:drop-shadow(0 0 5px rgba(59,130,246,.5))}.header-brand h1{margin:0;font-size:var(--font-xl);font-weight:700;letter-spacing:-.025em;background:var(--brand-gradient);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.theme-toggle-btn{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary);padding:.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.theme-toggle-btn:hover{color:var(--accent-warning);border-color:var(--accent-warning);transform:rotate(15deg)}.start-quiz-btn{background:var(--brand-gradient);color:#fff;border:none;padding:.6rem 1.2rem;border-radius:999px;font-weight:600;font-size:var(--font-sm);cursor:pointer;box-shadow:0 4px 6px -1px #3b82f64d;transition:transform .2s,box-shadow .2s;white-space:nowrap}.start-quiz-btn:hover{transform:translateY(-1px);box-shadow:0 6px 8px -1px #3b82f666}.header-user-section{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem;width:100%}@media(min-width:768px){.header-user-section{width:auto;align-items:center}}.user-controls{display:flex;align-items:center;gap:1rem;justify-content:space-between;width:100%}@media(min-width:768px){.user-controls{width:auto}}.logout-btn{display:flex;align-items:center;gap:.5rem;background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-secondary);padding:.5rem 1rem;border-radius:8px;cursor:pointer;transition:all .2s}.logout-btn:hover{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--text-tertiary)}.auth-form-container{display:flex;flex-direction:column;gap:.5rem;width:100%;max-width:400px}.auth-form{display:flex;gap:.5rem}.auth-input{flex:1;background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary);padding:.5rem .75rem;border-radius:6px;font-size:var(--font-sm);min-width:0}.auth-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px #3b82f633}.auth-submit-btn{background:var(--bg-card);border:1px solid var(--border-color);color:var(--accent-primary);padding:.5rem 1rem;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center}.auth-submit-btn:hover{background:var(--brand-gradient);color:#fff;border-color:transparent}.auth-toggle-container{font-size:var(--font-xs);color:var(--text-tertiary);text-align:right}.auth-toggle-btn{background:none;border:none;color:var(--accent-primary);cursor:pointer;font-size:inherit;padding:0;text-decoration:underline}.auth-error{color:var(--accent-error);font-size:var(--font-xs);text-align:right}.main-content{flex:1;padding:2rem 1rem;display:flex;flex-direction:column;align-items:center;gap:2rem}.score-board{display:flex;gap:1rem;width:100%;max-width:600px}.card-glass{background:var(--bg-glass);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid var(--border-glass);border-radius:16px;box-shadow:var(--shadow-glass);width:100%;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}.score-card{padding:1.5rem;display:flex;flex-direction:column;align-items:center;text-align:center;flex:1}.score-label{font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);margin-bottom:.5rem}.score-value{font-size:var(--font-2xl);font-weight:800;line-height:1}.score-value.highlight{color:var(--accent-success);text-shadow:0 0 20px rgba(16,185,129,.3)}.questions-container{width:100%;max-width:800px;display:flex;flex-direction:column;gap:1.5rem}.empty-state,.loading-state{text-align:center;padding:3rem;color:var(--text-secondary);border:1px dashed var(--border-color);border-radius:12px}.pagination-controls{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center;margin-top:auto}.pagination-btn{background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-secondary);width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:var(--font-sm);transition:all .2s}.pagination-btn:hover:not(:disabled){background:var(--bg-secondary);color:var(--text-primary);transform:translateY(-2px)}.pagination-btn.active{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary);box-shadow:var(--glow-primary)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.quiz-complete-card{padding:3rem;text-align:center;max-width:500px;margin:0 auto}.restart-btn{margin-top:1.5rem;background:var(--accent-primary);color:#fff;border:none;padding:.8rem 2rem;border-radius:8px;font-weight:600;cursor:pointer;transition:opacity .2s}.restart-btn:hover{opacity:.9}.app-footer{text-align:center;padding:3rem 1rem;border-top:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-tertiary);margin-top:auto}.footer-brand{color:var(--text-primary);font-weight:700;font-size:var(--font-lg);margin-bottom:.5rem}.footer-credits a{color:var(--text-secondary);text-decoration:none;border-bottom:1px dotted var(--text-tertiary)}.footer-credits a:hover{color:var(--accent-primary);border-color:var(--accent-primary)}.qc-header{position:relative;display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem}.qc-title{margin:0;font-size:var(--font-lg);line-height:1.4;padding-right:2.5rem}.qc-delete-btn{position:absolute;top:-5px;right:-5px;background:transparent;border:none;color:var(--text-tertiary);padding:.5rem;border-radius:50%;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.qc-delete-btn:hover{background:#ef44441a;color:var(--accent-error)}.qc-code-block{background:#0000004d;padding:1rem;border-radius:8px;border:1px solid var(--border-color);font-family:Fira Code,Consolas,monospace;font-size:var(--font-sm);overflow-x:auto;margin-bottom:1.5rem;color:#e2e8f0}.qc-options-list{display:flex;flex-direction:column;gap:.75rem}.qc-option{position:relative;padding:1rem;border-radius:12px;border:2px solid var(--border-color);background:var(--bg-secondary);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;overflow:hidden}.qc-option:hover:not(.disabled){border-color:var(--text-tertiary);background:var(--bg-card);transform:translate(4px)}.qc-option.disabled{cursor:default;opacity:.9}.qc-option.selected{border-color:var(--accent-primary);background:#3b82f61a}.qc-option.correct{border-color:var(--accent-success);background:#10b9811a}.qc-option.wrong{border-color:var(--accent-error);background:#ef44441a}.qc-option.missed{border-color:var(--accent-success);background:transparent;border-style:dashed;opacity:.7}.qc-option-content{display:flex;align-items:center;justify-content:space-between;width:100%;z-index:1}.qc-checkbox{width:24px;height:24px;border-radius:6px;border:2px solid var(--text-tertiary);margin-right:1rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s;background:transparent}.qc-radio .qc-checkbox{border-radius:50%}.qc-option.selected .qc-checkbox{border-color:var(--accent-primary);background:var(--accent-primary)}.qc-option.correct .qc-checkbox{border-color:var(--accent-success);background:var(--accent-success)}.qc-option.wrong .qc-checkbox{border-color:var(--accent-error);background:var(--accent-error)}.qc-option.missed .qc-checkbox{border-color:var(--accent-success)}.qc-checkbox-inner{width:10px;height:10px;background:#fff;border-radius:2px;opacity:0;transform:scale(0);transition:all .2s}.qc-radio .qc-checkbox-inner{border-radius:50%}.qc-option.selected .qc-checkbox-inner,.qc-option.correct .qc-checkbox-inner,.qc-option.wrong .qc-checkbox-inner{opacity:1;transform:scale(1)}.qc-label{font-size:var(--font-base);color:var(--text-primary);flex:1}.qc-explanation{margin-top:.75rem;padding:.75rem;background:#0003;border-radius:6px;font-size:var(--font-sm);color:var(--text-secondary);border-left:3px solid var(--text-tertiary);animation:fadeIn .3s ease}.qc-feedback-container{margin-top:1.5rem;padding:1rem 1.5rem;border-radius:12px;border:1px solid transparent;animation:fadeIn .3s ease}.qc-feedback-container.correct{background:#10b9811a;border-color:#10b9814d;color:var(--accent-success)}.qc-feedback-container.wrong{background:#ef44441a;border-color:#ef44444d;color:var(--accent-error)}.qc-feedback-title{margin:0;font-weight:700;font-size:var(--font-base)}.qc-submit-btn{margin-top:2rem;width:100%;padding:1rem;background:var(--accent-primary);color:#fff;border:none;border-radius:12px;font-weight:600;font-size:var(--font-base);cursor:pointer;transition:opacity .2s}.qc-submit-btn:disabled{opacity:.5;cursor:not-allowed}.qc-submit-btn:hover:not(:disabled){opacity:.9}.quiz-container{width:100%;max-width:900px;margin:0 auto;min-height:100vh;display:flex;flex-direction:column}.quiz-header-bar{position:sticky;top:0;z-index:100;background:#121212f2;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:1rem 1.5rem;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center;box-shadow:0 4px 6px -1px #0000001a}.quiz-quit-btn{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;font-size:var(--font-sm);display:flex;align-items:center;gap:.5rem;transition:color .2s}.quiz-quit-btn:hover{color:var(--accent-error)}.quiz-timer{font-family:monospace;font-weight:700;font-size:var(--font-lg);display:flex;align-items:center;gap:.5rem;color:var(--text-primary)}.quiz-timer.low{color:var(--accent-error);animation:pulse 1s infinite}.quiz-setup-card{max-width:600px;margin:3rem auto;padding:2.5rem}.setup-title{font-size:var(--font-2xl);font-weight:800;margin-bottom:.5rem;background:linear-gradient(135deg,#fff,#94a3b8);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.setup-subtitle{color:var(--text-secondary);margin-bottom:2rem}.chapter-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:1rem;margin-bottom:1rem}.chapter-label{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-radius:12px;background:var(--bg-secondary);border:1px solid var(--border-color);cursor:pointer;transition:all .2s;font-size:var(--font-sm);-webkit-user-select:none;user-select:none}.chapter-label:hover{background:var(--bg-card)}.chapter-label.active{background:#3b82f61a;border-color:var(--accent-primary);color:var(--accent-primary)}.chapter-input{accent-color:var(--accent-primary);width:16px;height:16px}.selection-actions{display:flex;gap:1rem;font-size:var(--font-xs);margin-bottom:2rem}.selection-link{background:none;border:none;color:var(--accent-primary);cursor:pointer;padding:0;text-decoration:underline}.quiz-select{width:100%;padding:1rem;background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary);border-radius:12px;font-size:var(--font-base);margin-bottom:2rem;appearance:none}.action-btn{width:100%;padding:1rem;border-radius:12px;border:none;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.75rem;font-size:var(--font-base);transition:opacity .2s}.action-btn.primary{background:var(--accent-primary);color:#fff}.action-btn.success{background:var(--accent-success);color:#fff}.action-btn:hover{opacity:.9}.quiz-results-hero{padding:4rem 2rem;text-align:center;background:linear-gradient(180deg,var(--bg-secondary) 0%,transparent 100%);margin-bottom:2rem}.results-score-large{font-size:4rem;font-weight:800;color:var(--accent-success);display:block;margin:1rem 0}body.light-mode{--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-card: rgba(0, 0, 0, .03);--bg-glass: rgba(255, 255, 255, .7);--text-primary: #0f172a;--text-secondary: #475569;--text-tertiary: #94a3b8;--border-color: #e2e8f0;--border-glass: #cbd5e1}body.light-mode .header-brand h1,body.light-mode .setup-title{background:linear-gradient(135deg,#0f172a,#475569);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.protect-cat{position:fixed;z-index:9999;width:64px;height:64px;pointer-events:none;filter:drop-shadow(2px 2px 0px rgba(0,0,0,.5));background-image:url(/assets/pixelated_cat_walk_strip-eqIlDi8z.png);background-size:256px 64px;background-repeat:no-repeat;image-rendering:pixelated}.protect-cat.walk{animation:catLegs .6s steps(4) infinite}.protect-cat.hit{background-position:0 0;animation:catHit .4s ease-in-out}@keyframes catLegs{0%{background-position:0 0}to{background-position:-256px 0}}@keyframes catHit{0%{transform:translate(-50%) scale(1)}50%{transform:translate(-50%,10px) scale(1.2)}to{transform:translate(-50%) scale(1)}}@keyframes pulse{0%{opacity:1}50%{opacity:.5}to{opacity:1}}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.landing-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;background:radial-gradient(circle at top center,#1e293b,var(--bg-primary))}.landing-header{text-align:center;margin-bottom:3rem}.brand-large{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:1rem}.brand-large h1{font-size:4rem;font-weight:800;margin:0;background:linear-gradient(135deg,#fff,#3b82f6);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.brand-icon-large{color:var(--accent-primary);filter:drop-shadow(0 0 15px rgba(59,130,246,.6))}.landing-subtitle{font-size:var(--font-lg);color:var(--text-secondary);max-width:600px;margin:0 auto}.landing-auth-card{width:100%;max-width:400px;padding:2.5rem;margin-bottom:3rem;text-align:center}.landing-auth-card h2{margin-top:0;margin-bottom:1.5rem}.landing-auth-form{display:flex;flex-direction:column;gap:1rem}.auth-input-large{width:100%;padding:1rem;background:#0000004d;border:1px solid var(--border-color);border-radius:8px;color:#fff;font-size:var(--font-base)}.input-group{width:100%}.auth-switcher{margin-top:1.5rem;font-size:var(--font-sm);color:var(--text-secondary)}.text-btn{background:none;border:none;color:var(--accent-primary);cursor:pointer;text-decoration:underline;font-size:inherit;padding:0}.landing-welcome{text-align:center;margin-bottom:3rem}.landing-welcome h2{font-size:var(--font-xl);margin-bottom:.5rem}.topic-grid{display:flex;gap:2rem;flex-wrap:wrap;justify-content:center;width:100%;max-width:900px}.topic-card{flex:1;min-width:300px;padding:2rem;display:flex;flex-direction:column;align-items:center;text-align:center;transition:transform .3s,box-shadow .3s}.topic-card:hover{transform:translateY(-5px);box-shadow:0 10px 40px -10px #00000080;border-color:var(--accent-primary)}.card-icon{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem}.java-icon{background:#f59e0b1a;color:#f59e0b}.algo-icon{background:#10b9811a;color:#10b981}.theory-icon{background:#8b5cf61a;color:#8b5cf6}.topic-card h3{font-size:var(--font-xl);margin:0 0 1rem}.topic-card p{color:var(--text-secondary);margin-bottom:2rem;flex-grow:1}.card-actions{display:flex;flex-direction:column;gap:1rem;width:100%}@media(max-width:768px){.topic-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;padding:0 .5rem}.topic-card{min-width:0;padding:1.25rem 1rem;gap:.75rem}.card-icon{width:48px;height:48px;margin-bottom:.75rem}.card-icon svg{width:24px;height:24px}.topic-card h3{font-size:var(--font-base);margin-bottom:.5rem}.topic-card p{font-size:var(--font-xs);margin-bottom:1rem;line-height:1.4;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.card-actions{gap:.5rem;width:100%}.action-btn{padding:.6rem;font-size:var(--font-xs);min-height:36px}}.action-btn{padding:.8rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;font-size:var(--font-base);transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%}.action-btn.primary{background:var(--accent-primary);color:#fff;border:none}.action-btn.primary:hover{background:var(--accent-primary-hover)}.action-btn.secondary{background:transparent;border:1px solid var(--border-color);color:var(--text-primary)}.action-btn.secondary:hover{background:var(--bg-secondary)}.full-width{width:100%}.highlight{color:var(--accent-primary)}.landing-footer{margin-top:4rem;color:var(--text-tertiary);font-size:var(--font-xs)}.qc-image-container{margin:1.5rem 0;display:flex;justify-content:center;width:100%}.qc-image{max-width:100%;max-height:400px;border-radius:8px;border:1px solid var(--border-color);box-shadow:0 4px 6px -1px #0000004d;object-fit:contain;background:#fff}.qc-option-image{max-height:50px;margin-left:1rem;border-radius:4px;border:1px solid var(--border-color);background:#fff;cursor:pointer;transition:transform .2s}.qc-option-image:hover{transform:scale(1.5);z-index:10;box-shadow:0 4px 12px #0003}.major-selection-overlay{position:fixed;inset:0;z-index:9999;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:2rem}.major-selection-modal-card{width:100%;max-width:800px;background:#0f1115;border:1px solid var(--border-color);border-radius:24px;padding:3rem;display:flex;flex-direction:column;align-items:center;box-shadow:0 25px 50px -12px #00000080;max-height:90vh;overflow-y:auto}.major-selection-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1.5rem;width:100%;margin-bottom:2.5rem}.major-card{position:relative;border-radius:16px;padding:1.5rem;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;cursor:pointer;transition:all .2s;min-height:140px;background:var(--bg-secondary);border:1px solid var(--border-color);width:100%}.major-card:hover{transform:translateY(-2px);background:var(--bg-card)}.major-card.selected{background:#10b9811a;border:2px solid var(--gpa-green);box-shadow:0 0 20px #10b98133}.major-card-icon{color:var(--text-secondary);transition:color .2s}.major-card.selected .major-card-icon{color:var(--gpa-green)}.major-card-label{color:var(--text-secondary);font-weight:700;font-size:1rem;letter-spacing:.5px;text-align:center}.major-card.selected .major-card-label{color:var(--text-primary)}@media(max-width:768px){.major-selection-overlay{padding:1rem}.major-selection-modal-card{padding:1.5rem 1rem;width:100%;border-radius:16px;max-height:95vh}.major-selection-grid{grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:1.5rem}.major-card{padding:1rem .5rem;min-height:110px;gap:.5rem}.major-card-icon svg{width:24px;height:24px}.major-card-label{font-size:.85rem;line-height:1.2}}.subject-hero{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:3rem}.subject-header-left{display:flex;flex-direction:column;align-items:center;text-align:center;gap:1.5rem;width:100%}.subject-actions-right{display:flex;justify-content:center;gap:1rem;width:100%}@media(min-width:768px){.subject-hero{flex-direction:row;justify-content:space-between;align-items:center}.subject-header-left{flex-direction:row;align-items:center;text-align:left;width:auto}.subject-actions-right{width:auto}.subject-meta-row{justify-content:flex-start}}.subject-meta-row{display:flex;align-items:center;gap:1rem;color:var(--text-secondary);margin-bottom:0;flex-wrap:wrap;justify-content:center}.subject-slides{margin-top:1.5rem;display:flex;flex-direction:column;gap:.75rem}.subject-slides-header{font-weight:700;color:var(--text-primary);letter-spacing:.2px}.subject-slides-grid{display:flex;flex-wrap:wrap;gap:.5rem}.subject-slide-button{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.5rem .9rem;border-radius:999px;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);font-weight:600;font-size:.9rem;text-decoration:none;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.subject-slide-button:hover{transform:translateY(-1px);border-color:var(--text-primary);box-shadow:0 8px 20px -16px #0009}.subject-slides-empty{color:var(--text-secondary);font-size:.9rem}.course-main-row{display:flex;align-items:center;gap:.75rem;width:100%}.gpa-hours-input{width:100%;height:42px;padding:0 .5rem;border-radius:12px;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);outline:none;text-align:center;font-weight:600}.course-retake-row{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.action-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:8px;cursor:pointer;transition:all .2s}.action-btn.delete{background:#ef44441a;color:var(--accent-error);border:none}.action-btn.delete:hover{background:#ef444433}.action-btn.active{background:var(--accent-primary);color:#fff;border:none;border-color:var(--accent-primary)}.mobile-show{display:flex!important}.desktop-show{display:none!important}.mobile-sticky-footer{position:fixed;bottom:0;left:0;width:100%;padding:1rem 1.5rem;background:#0f1012f2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--border-color);display:flex;align-items:center;gap:1rem;z-index:100;box-shadow:0 -10px 30px #00000080;padding-bottom:max(1rem,env(safe-area-inset-bottom))}.footer-btn{flex:1;height:48px;border-radius:12px;border:none;font-weight:600;font-size:1rem;display:flex;align-items:center;justify-content:center;gap:.5rem;cursor:pointer}.footer-btn.add{background:#ffffff1a;color:var(--text-primary)}.footer-btn.calc{background:var(--gpa-green);color:#fff;flex:2;box-shadow:0 4px 12px #10b9814d}.desktop-add-btn{display:none!important}@media(min-width:768px){.mobile-sticky-footer{display:none!important}.desktop-add-btn{display:flex!important}.course-retake-row{margin-left:2rem}.mobile-show{display:none!important}.desktop-show{display:flex!important}.gpa-results-column{display:flex;flex-direction:column}}.desktop-add-btn{display:none}@media(min-width:768px){.desktop-add-btn{display:flex!important}}.skill-tree-page{padding:2rem;background:radial-gradient(circle at top,#1e293b,#0f172a);min-height:100vh;color:#fff;font-family:Inter,sans-serif;overflow-y:auto}.skill-tree-header{display:flex;justify-content:space-between;align-items:center;max-width:1000px;margin:0 auto 3rem;padding-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.1)}.skill-tree-header h1{font-size:2rem;font-weight:700;margin:0;background:linear-gradient(90deg,#fff,#94a3b8);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.skill-tree-header .subtitle{color:#64748b;margin:0}.stats-pill{background:#ffffff0d;padding:.5rem 1rem;border-radius:20px;display:flex;align-items:center;gap:.5rem;border:1px solid rgba(255,255,255,.1);font-weight:600}.skill-tree-container{max-width:1400px;margin:0 auto;position:relative;padding-bottom:5rem;min-height:800px}.level-row{display:flex;justify-content:center;gap:1.5rem;margin-bottom:4rem;position:relative;z-index:2;flex-wrap:wrap}.skill-node{background:#1e293bb3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1rem;width:160px;min-height:80px;display:flex;flex-direction:column;align-items:center;text-align:center;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;box-shadow:0 4px 6px #0000004d}.skill-node:hover{transform:translateY(-5px);box-shadow:0 10px 20px #0006;border-color:#ffffff4d;z-index:10}.skill-node.status-completed{background:#10b9811a;border-color:#10b981;box-shadow:0 0 15px #10b98133}.skill-node.status-locked{opacity:.5;filter:grayscale(1);cursor:not-allowed;border-style:dashed}.skill-node.status-available{border-color:#fff}.node-icon{margin-bottom:.5rem;background:#ffffff1a;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--accent, #64748b)}.status-completed .node-icon{background:#10b981;color:#fff}.node-title{font-size:.85rem;font-weight:600;line-height:1.2;margin-bottom:.25rem}.node-code{font-size:.65rem;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px}.glow-effect{position:absolute;inset:-1px;border-radius:12px;background:linear-gradient(45deg,transparent 40%,rgba(255,255,255,.4) 50%,transparent 60%);background-size:200% 200%;animation:shimmer 3s infinite;z-index:-1;opacity:.5}@keyframes shimmer{0%{background-position:100% 50%}to{background-position:0% 50%}}.skill-tree-connections{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1}.connection-line{fill:none;stroke:#ffffff1a;stroke-width:2px;transition:stroke .5s ease}.connection-line.active{stroke:#10b981;stroke-dasharray:10;animation:flow 30s linear infinite}@keyframes flow{to{stroke-dashoffset:-1000}}.flowchart-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60vh;gap:1rem;color:var(--text-secondary)}.flowchart-header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.1)}.flowchart-header h1{margin:0;font-size:1.4rem;font-weight:700;letter-spacing:-.02em}.flowchart-stats{display:flex;align-items:center;gap:.75rem;font-size:.8rem;color:var(--text-secondary);background:#ffffff0d;padding:.5rem 1rem;border-radius:20px;border:1px solid rgba(255,255,255,.1)}.flowchart-saving{font-size:.7rem;color:var(--accent-primary);font-style:italic}.flowchart-canvas{position:relative;background:#00000040;border:1px solid rgba(255,255,255,.08);border-radius:12px;min-height:600px;box-shadow:inset 0 2px 20px #0000004d}.flowchart-svg{position:absolute;top:0;left:0;pointer-events:none;z-index:0}.flowchart-line{fill:none;stroke:#ffffff26;stroke-width:1.5;stroke-linecap:round}.flowchart-node{position:absolute;display:flex;align-items:stretch;background:#191923f2;border:1px solid rgba(255,255,255,.15);border-radius:8px;overflow:hidden;cursor:pointer;transition:all .2s ease;z-index:1;width:180px;height:50px;box-shadow:0 2px 8px #0006}.flowchart-node:hover{z-index:10}.flowchart-node:hover:not(.flowchart-node--locked){transform:translateY(-2px);box-shadow:0 6px 20px #00000080;border-color:var(--cat)}.flowchart-node__bar{width:5px;background:var(--cat);flex-shrink:0}.flowchart-node__body{display:flex;align-items:center;gap:6px;padding:6px 10px;flex:1;min-width:0}.flowchart-node__names{display:flex;flex-direction:column;gap:.15rem;min-width:0;flex:1}.flowchart-node__name-en{font-size:.85rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.01em}.flowchart-node__name-ar{font-size:.7rem;font-weight:400;color:#ffffff80;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;direction:rtl}.flowchart-node__lab{font-size:.55rem;font-weight:700;color:#f59e0b;background:#f59e0b26;padding:.15rem .4rem;border-radius:4px;border:1px solid rgba(245,158,11,.3);margin-left:auto;flex-shrink:0;text-transform:uppercase;letter-spacing:.02em}.flowchart-node--locked{opacity:.35;filter:grayscale(.7) brightness(.8);cursor:not-allowed}.flowchart-node--locked .flowchart-node__bar{background:#64646480;box-shadow:none}.flowchart-node--available{background:linear-gradient(135deg,color-mix(in srgb,var(--cat) 12%,rgba(30,30,40,.95)),color-mix(in srgb,var(--cat) 6%,rgba(20,20,30,.98)));border-color:color-mix(in srgb,var(--cat) 50%,transparent);box-shadow:0 2px 12px #00000059,0 0 20px color-mix(in srgb,var(--cat) 15%,transparent)}.flowchart-node--available .flowchart-node__bar{box-shadow:2px 0 12px var(--cat)}.flowchart-node--completed{background:linear-gradient(135deg,#10b9811f,#10b9810f);border-color:#10b98180}.flowchart-node--completed .flowchart-node__bar{background:#10b981;box-shadow:2px 0 8px #10b98180}.flowchart-node--completed .flowchart-node__name-en{text-decoration:line-through;opacity:.6}.flowchart-tip{display:flex;align-items:center;gap:.6rem;margin-top:1.25rem;padding:.75rem 1rem;background:#3b82f60f;border:1px solid rgba(59,130,246,.15);border-radius:10px;font-size:.75rem;color:var(--text-secondary)}.flowchart-tip svg{color:var(--accent-primary);flex-shrink:0}.spinner{width:24px;height:24px;border:3px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite}.spinner.small{width:14px;height:14px;border-width:2px}@keyframes spin{to{transform:rotate(360deg)}}.flowchart-controls{display:flex;align-items:center;gap:.5rem;background:#ffffff0d;padding:.25rem .5rem;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.control-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;color:var(--text-secondary);border-radius:4px;cursor:pointer;transition:all .2s}.control-btn:hover{background:#ffffff1a;color:#fff}.zoom-text{font-size:.75rem;color:var(--text-secondary);min-width:40px;text-align:center}.flowchart-viewport{border:1px solid rgba(255,255,255,.08);border-radius:12px;background:#0003;margin-bottom:1rem}.flowchart-scaler{transition:transform .3s cubic-bezier(.25,.8,.25,1)}.dhikr-modal-overlay{position:fixed;inset:0;background:#0006;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:9999;display:flex;align-items:flex-start;justify-content:center;padding:2rem 1rem;opacity:0;transition:opacity .3s ease-in-out}.dhikr-modal-overlay.visible{opacity:1}.dhikr-modal-card{position:relative;width:100%;max-width:600px;padding:3rem 2rem;display:flex;flex-direction:column;align-items:center;gap:2.5rem;border-radius:24px;animation:fadeInUp .4s ease-out}.dhikr-close-btn{position:absolute;top:1rem;right:1rem;background:#ffffff0d;border:1px solid var(--border-color);color:var(--text-secondary);width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.dhikr-close-btn:hover{background:#ffffff1a;color:var(--text-primary);transform:rotate(90deg)}.dhikr-content{width:100%;display:flex;align-items:center;justify-content:center;min-height:200px;padding:2rem;opacity:1;transform:scale(1);transition:opacity .2s ease-in-out,transform .2s ease-in-out}.dhikr-content.transitioning{opacity:0;transform:scale(.95)}.dhikr-text-arabic{font-size:2.5rem;font-weight:600;line-height:1.8;text-align:center;color:var(--text-primary);direction:rtl;font-family:Traditional Arabic,Amiri,Scheherazade,serif;text-shadow:0 0 20px rgba(59,130,246,.3)}.dhikr-random-btn{background:var(--brand-gradient);border:none;color:#fff;padding:.75rem 2rem;border-radius:50px;display:flex;align-items:center;justify-content:center;gap:.5rem;cursor:pointer;font-size:1rem;font-weight:600;transition:all .2s;box-shadow:0 4px 12px #3b82f64d}.dhikr-random-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #3b82f666}.dhikr-random-btn:active{transform:translateY(0)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.dhikr-modal-card{padding:2rem 1.5rem;gap:2rem}.dhikr-text-arabic{font-size:2rem}.dhikr-content{min-height:150px;padding:1.5rem}.dhikr-random-btn{padding:.65rem 1.5rem;font-size:.9rem}}.v0-modal-overlay{position:fixed;inset:0;background:#000000bf;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:2000;display:flex;align-items:center;justify-content:center;padding:1.5rem}.v0-modal-card{background:var(--bg-glass-strong);border:1px solid var(--border-glass);border-radius:1.5rem;width:100%;max-width:480px;position:relative;box-shadow:0 25px 50px -12px #00000080;overflow:hidden}.v0-modal-close{position:absolute;top:1rem;right:1rem;background:#ffffff0d;border:1px solid var(--border-glass);color:var(--text-secondary);width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;z-index:10}.v0-modal-close:hover{background:#ffffff1a;color:var(--text-primary);transform:rotate(90deg)}.v0-modal-header{padding:2rem 2rem 1rem;border-bottom:1px solid var(--border-glass)}.v0-modal-title{font-size:1.5rem;font-weight:700;margin:0;color:var(--text-primary);line-height:1.2}.v0-modal-subtitle{font-size:.8rem;font-weight:600;color:var(--accent-primary);text-transform:uppercase;letter-spacing:.05em;margin-top:.5rem}.v0-modal-body{padding:1.5rem 2rem 2rem}.v0-modal-description{color:var(--text-secondary);font-size:.95rem;line-height:1.6;margin-bottom:2rem}.v0-modal-stats{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:2rem}.v0-stat-item{background:#ffffff08;border:1px solid var(--border-glass);border-radius:1rem;padding:1rem;display:flex;align-items:center;gap:1rem}.v0-stat-icon{width:36px;height:36px;background:#3b82f61a;border-radius:.75rem;display:flex;align-items:center;justify-content:center;color:var(--accent-primary)}.v0-stat-content{display:flex;flex-direction:column}.v0-stat-value{font-size:1.125rem;font-weight:700;color:var(--text-primary)}.v0-stat-label{font-size:.75rem;color:var(--text-tertiary);font-weight:500}.v0-modal-actions{display:flex;flex-direction:column;gap:.75rem}.v0-modal-btn{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.875rem;border-radius:.75rem;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);border:1px solid transparent}.v0-modal-btn-primary{background:#3b82f61a;border-color:#3b82f633;color:var(--accent-primary)}.v0-modal-btn-primary.active{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.v0-modal-btn-success{background:#10b9811a;border-color:#10b98133;color:var(--accent-success)}.v0-modal-btn-success.active{background:var(--accent-success);color:#fff;border-color:var(--accent-success)}.v0-modal-btn-outline{background:transparent;border-color:var(--border-glass);color:var(--text-secondary)}.v0-modal-btn:hover{transform:translateY(-2px);filter:brightness(1.1)}.v0-modal-btn:active{transform:translateY(0)}@media(max-width:768px){.v0-modal-overlay{padding:0;align-items:flex-end}.v0-modal-card{border-radius:1.5rem 1.5rem 0 0;position:relative;bottom:0;max-width:none;max-height:85vh;overflow-y:auto}.v0-modal-header{padding:1.5rem 1.5rem .75rem}.v0-modal-body{padding:1rem 1.5rem 2rem}.v0-modal-stats{gap:.75rem}.v0-stat-item{padding:.75rem;gap:.75rem}.v0-modal-description{font-size:.9rem;margin-bottom:1.5rem}.v0-animate-in{animation:v0-slide-up .4s cubic-bezier(.16,1,.3,1) forwards}}@keyframes v0-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.v0-button-ghost{display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid transparent;color:var(--text-secondary);cursor:pointer;transition:all .2s}.v0-button-ghost:hover:not(:disabled){background:#ffffff0d;color:var(--text-primary);border-color:#ffffff1a}.v0-button-ghost:disabled{cursor:not-allowed;opacity:.3}.v0-badge{display:inline-flex;align-items:center;padding:.25rem .5rem;border-radius:9999px;font-size:.75rem;font-weight:600;line-height:1}.v0-badge-primary{background:#3b82f61a;color:var(--accent-primary);border:1px solid rgba(59,130,246,.2)}.v0-container{max-width:1200px;margin:0 auto;padding:1.5rem;width:100%}.v0-stack{display:flex;flex-direction:column;gap:1.5rem}.v0-grid{display:grid;gap:1.5rem}.v0-grid-3{grid-template-columns:2fr 1fr}.v0-animate-in{animation:v0-fade-in .5s ease-out forwards}@keyframes v0-fade-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1024px){.v0-grid-3{grid-template-columns:1fr}}
