:root{--color-bg: #fcfcfc;--color-bg-subtle: #ffffff;--color-surface: #ffffff;--color-surface-hover: #f3f5fb;--color-border: #e2e5f0;--color-border-light: #eef1f7;--color-text: #1a1a2e;--color-text-secondary: #5a5d72;--color-text-muted: #9194a7;--color-primary: #1a1a2e;--color-primary-hover: #2d2d44;--color-accent: #4285f4;--color-accent-light: #e8f0fe;--color-accent-hover: #3367d6;--color-success: #34a853;--color-success-light: #e6f4ea;--color-warning: #f9ab00;--color-warning-light: #fef7e0;--color-danger: #ea4335;--color-danger-light: #fce8e6;--color-osce: #5b878f;--color-wpa: #a4744f;--color-students: #748850;--color-seniors: #8b5a8f;--font-family: "Google Sans", "Google Sans Text", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--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: 2rem;--font-size-4xl: 2.5rem;--font-size-hero: 3.5rem;--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;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .06);--shadow-md: 0 4px 16px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .1);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .12);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--navbar-height: 64px;--sidebar-width: 280px;--max-width: 1200px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%;touch-action:pan-x pan-y;overscroll-behavior:none}body{font-family:var(--font-family);background:var(--color-bg);color:var(--color-text);line-height:1.6;min-height:100vh;min-height:100dvh;overflow-x:hidden;overscroll-behavior:none;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;user-select:none;-webkit-user-select:none}input,textarea,[contenteditable]{user-select:text;-webkit-user-select:text;touch-action:manipulation}#root{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}.page{padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}.page[style*=paddingBottom]{padding-bottom:calc(80px + env(safe-area-inset-bottom))!important}a{color:var(--color-accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-accent-hover)}img{max-width:100%;display:block}h1,h2,h3,h4,h5,h6{font-weight:500;line-height:1.3;color:var(--color-text)}.text-hero{font-size:var(--font-size-hero);font-weight:400;letter-spacing:-.02em;line-height:1.1}.text-heading{font-size:var(--font-size-3xl);font-weight:500;letter-spacing:-.01em}.text-subheading{font-size:var(--font-size-xl);font-weight:500}.text-body{font-size:var(--font-size-base);color:var(--color-text-secondary)}.text-caption{font-size:var(--font-size-sm);color:var(--color-text-muted)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:500;border-radius:var(--radius-full);border:none;cursor:pointer;transition:all var(--transition-base);white-space:nowrap;text-decoration:none;line-height:1.5}.btn:active{transform:scale(.97)}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-hover);box-shadow:var(--shadow-md)}.btn-secondary{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-surface-hover);border-color:var(--color-text-muted)}.btn-accent{background:var(--color-accent);color:#fff}.btn-accent:hover{background:var(--color-accent-hover);box-shadow:var(--shadow-md)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover{background:#d33426}.btn-ghost{background:transparent;color:var(--color-text-secondary)}.btn-ghost:hover{background:var(--color-surface-hover);color:var(--color-text)}.btn-lg{padding:var(--space-4) var(--space-8);font-size:var(--font-size-base);font-weight:500}.btn-sm{padding:var(--space-2) var(--space-4);font-size:var(--font-size-xs)}.btn-icon{width:40px;height:40px;padding:0;border-radius:var(--radius-full);display:inline-flex;align-items:center;justify-content:center}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.card{background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border-light);transition:all var(--transition-base)}.card-elevated{box-shadow:var(--shadow-sm)}.card-interactive:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:var(--color-border)}.card-glass{background:#ffffffd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.4)}.input{width:100%;padding:var(--space-3) var(--space-4);font-family:var(--font-family);font-size:var(--font-size-base);color:var(--color-text);background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-md);outline:none;transition:all var(--transition-fast)}.input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-light)}.input::placeholder{color:var(--color-text-muted)}select.input{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239194a7' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.input-error{border-color:var(--color-danger)}.input-error:focus{box-shadow:0 0 0 3px var(--color-danger-light)}.input-label{display:block;font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary);margin-bottom:var(--space-2)}.input-helper{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:var(--space-1)}.input-error-text{font-size:var(--font-size-xs);color:var(--color-danger);margin-top:var(--space-1)}.table-wrapper{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--color-border-light)}.table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.table th{background:var(--color-bg-subtle);font-weight:500;font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);padding:var(--space-3) var(--space-4);text-align:left;border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:5}.table td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border-light);vertical-align:middle}.table tr:last-child td{border-bottom:none}.table tr:hover td{background:var(--color-surface-hover)}.table th.center,.table td.center{text-align:center}.tabs{display:flex;gap:var(--space-2);padding:var(--space-1);background:var(--color-bg-subtle);border-radius:var(--radius-full);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab{padding:var(--space-2) var(--space-5);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary);background:transparent;border:none;border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;flex-shrink:0}.tab:hover{color:var(--color-text);background:#fff9}.tab.active{background:var(--color-surface);color:#4285f4;box-shadow:var(--shadow-xs)}.chip{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-size:var(--font-size-xs);font-weight:500;border-radius:var(--radius-full);background:var(--color-bg-subtle);color:var(--color-text-secondary)}.chip-success{background:var(--color-success-light);color:var(--color-success)}.chip-warning{background:var(--color-warning-light);color:#b87a00}.chip-danger{background:var(--color-danger-light);color:var(--color-danger)}.navbar{position:sticky;top:0;z-index:100;height:var(--navbar-height);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-6);background:#ffffffe6;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--color-border-light)}.navbar-brand{display:flex;align-items:center;gap:var(--space-3);font-size:var(--font-size-lg);font-weight:500;color:var(--color-text);text-decoration:none}.navbar-brand svg{width:28px;height:28px}.navbar-nav{display:flex;align-items:center;gap:var(--space-2);list-style:none}.navbar-link{padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary);border-radius:var(--radius-full);transition:all var(--transition-fast);text-decoration:none}.navbar-link:hover,.navbar-link.active{color:var(--color-text);background:var(--color-surface-hover)}.page{flex:1;padding:var(--space-8) var(--space-6);max-width:var(--max-width);margin:0 auto;width:100%}.page-header{margin-bottom:var(--space-8)}.page-title{font-size:var(--font-size-3xl);font-weight:500;letter-spacing:-.01em;margin-bottom:var(--space-2)}.page-subtitle{font-size:var(--font-size-base);color:var(--color-text-secondary)}.sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;opacity:0;visibility:hidden;transition:all var(--transition-base)}.sidebar-overlay.open{opacity:1;visibility:visible}.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-width);background:var(--color-surface);z-index:201;transform:translate(-100%);transition:transform var(--transition-slow);display:flex;flex-direction:column;box-shadow:var(--shadow-xl)}.sidebar.open{transform:translate(0)}.sidebar-header{padding:var(--space-6);border-bottom:1px solid var(--color-border-light)}.sidebar-nav{flex:1;padding:var(--space-4);overflow-y:auto}.sidebar-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border:none;background:none;width:100%;text-align:left}.sidebar-item:hover{background:var(--color-surface-hover);color:var(--color-text)}.sidebar-item.active{background:var(--color-primary);color:#fff}.sidebar-item-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:.8}.sidebar-item.active .sidebar-item-icon{opacity:1}.sidebar-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border-light)}.dialog-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:300;padding:var(--space-4)}.dialog{background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-width:480px;width:100%;max-height:80vh;overflow-y:auto}.dialog-header{padding:var(--space-6) var(--space-6) var(--space-4)}.dialog-title{font-size:var(--font-size-xl);font-weight:500}.dialog-body{padding:0 var(--space-6) var(--space-6)}.dialog-footer{padding:var(--space-4) var(--space-6);display:flex;justify-content:flex-end;gap:var(--space-3);border-top:1px solid var(--color-border-light)}.snackbar{position:fixed;bottom:var(--space-6);left:50%;transform:translate(-50%) translateY(100px);padding:var(--space-3) var(--space-6);background:var(--color-primary);color:#fff;border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:500;box-shadow:var(--shadow-lg);z-index:400;opacity:0;transition:all var(--transition-base)}.snackbar.show{transform:translate(-50%) translateY(0);opacity:1}.snackbar-error{background:var(--color-danger)}.snackbar-success{background:var(--color-success)}.spinner{width:20px;height:20px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.spinner-lg{width:40px;height:40px;border-width:3px}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;gap:var(--space-4);flex-direction:column}.blueprint-cell{width:48px;height:48px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast);font-size:var(--font-size-lg);-webkit-user-select:none;user-select:none}.blueprint-cell:hover{background:var(--color-bg-subtle)}.blueprint-cell.selected{color:#5b878f}.blueprint-cell .check{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;background:var(--color-accent);color:#fff;border-radius:var(--radius-full);font-size:14px;animation:popIn .2s ease-out}@keyframes popIn{0%{transform:scale(0)}70%{transform:scale(1.2)}to{transform:scale(1)}}.blueprint-total{background:var(--color-warning-light);color:#b87a00;font-weight:600;padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);text-align:center;min-width:40px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fadeIn .4s ease-out both}.animate-slide-up{animation:slideUp .5s ease-out both}.animate-slide-down{animation:slideDown .5s ease-out both}@media(max-width:768px){:root{--navbar-height: 56px;--font-size-hero: 2rem;--font-size-3xl: 1.5rem}.page{padding:var(--space-4) var(--space-4)}.navbar{padding:0 var(--space-4)}.navbar-nav.desktop-only{display:none}.table{font-size:var(--font-size-xs)}.table th,.table td{padding:var(--space-2) var(--space-2)}.blueprint-cell{width:36px;height:36px}.dialog{max-width:100%;margin:var(--space-4);border-radius:var(--radius-lg)}}@media(max-width:480px){.page{padding:var(--space-3) var(--space-3)}.tabs{gap:var(--space-1)}.tab{padding:var(--space-2) var(--space-3);font-size:var(--font-size-xs)}}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.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-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.w-full{width:100%}.text-center{text-align:center}.text-right{text-align:right}.font-medium{font-weight:500}.font-semibold{font-weight:600}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.p-4{padding:var(--space-4)}.p-6{padding:var(--space-6)}.p-8{padding:var(--space-8)}.px-4{padding-left:var(--space-4);padding-right:var(--space-4)}.px-6{padding-left:var(--space-6);padding-right:var(--space-6)}.py-4{padding-top:var(--space-4);padding-bottom:var(--space-4)}.py-6{padding-top:var(--space-6);padding-bottom:var(--space-6)}.hidden{display:none}@media(min-width:769px){.md\:flex{display:flex}.md\:hidden{display:none}}[contenteditable]:empty:before{content:attr(data-placeholder);color:var(--color-text-muted);pointer-events:none}[contenteditable] img{max-width:100%;height:auto;border-radius:var(--radius-sm);margin:var(--space-2) 0}[contenteditable]:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-light)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:100;display:flex;align-items:stretch;justify-content:space-around;height:64px;background:#fffffff2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--color-border-light);padding-bottom:env(safe-area-inset-bottom,0px)}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;border:none;background:none;cursor:pointer;font-family:var(--font-family);font-size:11px;font-weight:500;color:var(--color-text-muted);transition:color var(--transition-fast);padding:0;-webkit-tap-highlight-color:transparent}.bottom-nav-item.active{color:var(--color-accent)}.bottom-nav-item:hover{color:var(--color-text-secondary)}.bottom-nav-item.active:hover{color:var(--color-accent)}.has-bottom-nav{padding-bottom:80px}.rtl{direction:rtl;text-align:right}.rtl .flex{direction:rtl}.rtl .text-left{text-align:right}.rtl .text-right{text-align:left}[style*="position: fixed"][style*="bottom: 0"]{padding-bottom:env(safe-area-inset-bottom,0px)!important}@media(display-mode:standalone){body{padding-top:env(safe-area-inset-top,0px)}}
