:root{--primary: #416e57;--primary-light: #5a8f72;--primary-dark: #2d4f3d;--primary-glow: rgba(65, 110, 87, .3);--accent: #b98b1a;--accent-light: #d4a832;--accent-dark: #8f6b10;--accent-glow: rgba(185, 139, 26, .25);--bg-deep: #0f1219;--bg-base: #1a1f2e;--bg-card: #232838;--bg-card-hover: #2a3048;--bg-elevated: #2d3350;--bg-input: #1e2336;--text-primary: #f0f0f0;--text-secondary: #a0a8b8;--text-muted: #6b7280;--text-accent: #b98b1a;--danger: #e74c3c;--danger-bg: rgba(231, 76, 60, .12);--success: #2ecc71;--success-bg: rgba(46, 204, 113, .12);--warning: #f39c12;--warning-bg: rgba(243, 156, 18, .12);--info: #3498db;--info-bg: rgba(52, 152, 219, .12);--border-subtle: rgba(255, 255, 255, .06);--border-light: rgba(255, 255, 255, .1);--border-accent: rgba(185, 139, 26, .3);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .2);--shadow-md: 0 4px 16px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .4);--shadow-glow: 0 0 20px var(--primary-glow);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--font-family: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-xs: .7rem;--font-sm: .8rem;--font-base: .9rem;--font-md: 1rem;--font-lg: 1.15rem;--font-xl: 1.4rem;--font-2xl: 1.8rem;--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s ease;--header-height: 56px;--bottom-nav-height: 64px;--safe-area-bottom: env(safe-area-inset-bottom, 0px)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-text-size-adjust:100%;text-size-adjust:100%;-webkit-tap-highlight-color:transparent}body{font-family:var(--font-family);background:var(--bg-deep);color:var(--text-primary);line-height:1.6;min-height:100vh;min-height:100dvh;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}a{color:var(--accent);text-decoration:none}img{max-width:100%;display:block}button{font-family:inherit;cursor:pointer;border:none;outline:none;background:none;font-size:inherit}input,select,textarea{font-family:inherit;font-size:inherit;border:none;outline:none;background:none}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--primary-dark);border-radius:var(--radius-full)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-4px)}20%,40%,60%,80%{transform:translate(4px)}}.animate-fade-in{animation:fadeIn var(--transition-base) ease forwards}.animate-fade-in-up{animation:fadeInUp .4s ease forwards}.animate-scale-in{animation:scaleIn var(--transition-base) ease forwards}.text-danger{color:var(--danger)!important}.text-success{color:var(--success)!important}.text-warning{color:var(--warning)!important}.text-accent{color:var(--accent)!important}.text-muted{color:var(--text-muted)!important}.text-secondary{color:var(--text-secondary)!important}.bg-danger{background:var(--danger-bg)!important}.bg-success{background:var(--success-bg)!important}.bg-warning{background:var(--warning-bg)!important}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}@media print{body{background:white;color:#000}.bottom-nav,.app-header,.page>*:not(.print-area),.modal-overlay,.btn{display:none!important}.print-area{display:block!important;width:100%;margin:0;padding:0}.card{background:white;border:1px solid #ddd}table{width:100%;border-collapse:collapse}th,td{border:1px solid #000;padding:4px;font-size:12px}}.app-layout{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh}.app-header{position:fixed;top:0;left:0;right:0;height:var(--header-height);background:linear-gradient(135deg,rgba(45,79,61,.8),rgba(65,110,87,.8));display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-md);z-index:100;border-bottom:1px solid rgba(255,255,255,.08);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:0 4px 30px #0000004d}.app-header h1{font-size:var(--font-lg);font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:var(--space-sm)}.app-header h1 span.accent{color:var(--accent);font-weight:800}.header-badge{display:flex;align-items:center;gap:6px;background:var(--bg-card);padding:6px 12px;border-radius:var(--radius-full);font-size:var(--font-xs);font-weight:600;border:1px solid var(--border-subtle);transition:var(--transition-fast)}.header-badge.danger{border-color:var(--danger);color:var(--danger);background:var(--danger-bg);animation:pulse 2s infinite}.header-badge.warning{border-color:var(--warning);color:var(--warning);background:var(--warning-bg)}.header-badge.ok{border-color:var(--success);color:var(--success);background:var(--success-bg)}.main-content{flex:1;padding:calc(var(--header-height) + var(--space-md)) var(--space-md) calc(var(--bottom-nav-height) + var(--safe-area-bottom) + var(--space-md));max-width:800px;width:100%;margin:0 auto}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:calc(var(--bottom-nav-height) + var(--safe-area-bottom));padding-bottom:var(--safe-area-bottom);background:rgba(26,31,46,.85);border-top:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:space-around;z-index:100;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 -4px 30px #0006}.nav-tab{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 12px;border-radius:var(--radius-md);color:var(--text-muted);transition:var(--transition-fast);position:relative;font-size:var(--font-xs);font-weight:500;min-width:64px;-webkit-tap-highlight-color:transparent}.nav-tab svg{width:22px;height:22px;transition:var(--transition-fast)}.nav-tab.active{color:var(--accent)}.nav-tab.active:before{content:"";position:absolute;top:-1px;left:50%;transform:translate(-50%);width:24px;height:3px;background:var(--accent);border-radius:0 0 var(--radius-sm) var(--radius-sm)}.nav-tab:active{transform:scale(.92)}.card{background:rgba(35,40,56,.6);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-lg);padding:var(--space-lg);transition:var(--transition-base);animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow-sm)}.card:hover{background:rgba(42,48,72,.7);border-color:#ffffff26;box-shadow:var(--shadow-md)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.card-title{font-size:var(--font-md);font-weight:600;color:var(--text-primary)}.card-subtitle{font-size:var(--font-sm);color:var(--text-secondary);margin-top:2px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:10px 20px;border-radius:var(--radius-md);font-weight:600;font-size:var(--font-sm);transition:var(--transition-fast);cursor:pointer;white-space:nowrap;border:none}.btn:active{transform:scale(.96)}.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;box-shadow:0 2px 8px var(--primary-glow)}.btn-primary:hover{box-shadow:0 4px 16px var(--primary-glow)}.btn-accent{background:linear-gradient(135deg,var(--accent-dark),var(--accent));color:#fff;box-shadow:0 2px 8px var(--accent-glow)}.btn-accent:hover{box-shadow:0 4px 16px var(--accent-glow)}.btn-outline{background:transparent;color:var(--text-secondary);border:1px solid var(--border-light)}.btn-outline:hover{border-color:var(--accent);color:var(--accent)}.btn-danger{background:var(--danger);color:#fff}.btn-sm{padding:6px 12px;font-size:var(--font-xs);border-radius:var(--radius-sm)}.btn-block{width:100%}.btn-icon{width:36px;height:36px;padding:0;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center}.btn:disabled{opacity:.5;cursor:not-allowed}.input-group{margin-bottom:var(--space-md)}.input-group label{display:block;font-size:var(--font-sm);font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-xs)}.input-field{width:100%;background:var(--bg-input);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:10px 14px;color:var(--text-primary);font-size:var(--font-base);transition:var(--transition-fast)}.input-field:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.input-field::placeholder{color:var(--text-muted)}select.input-field{-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='%23a0a8b8' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}select.input-field option,select option{background:#fff;color:#1a1a1a;padding:8px}.upload-zone{border:2px dashed var(--border-light);border-radius:var(--radius-lg);padding:var(--space-xl);text-align:center;cursor:pointer;transition:var(--transition-base);background:var(--bg-input)}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--accent);background:var(--accent-glow)}.upload-zone svg{width:40px;height:40px;color:var(--text-muted);margin:0 auto var(--space-sm)}.upload-zone p{color:var(--text-secondary);font-size:var(--font-sm)}.upload-zone .formats{font-size:var(--font-xs);color:var(--text-muted);margin-top:var(--space-xs)}.doc-list{display:flex;flex-direction:column;gap:var(--space-sm);margin-top:var(--space-md)}.doc-item{display:flex;align-items:center;gap:var(--space-md);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-md);transition:var(--transition-fast);animation:fadeIn .3s ease}.doc-item:hover{border-color:var(--border-light)}.doc-icon{width:40px;height:40px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:var(--font-xs);font-weight:700;flex-shrink:0}.doc-icon.pdf{background:#e74c3c22;color:#e74c3c}.doc-icon.docx{background:#3498db22;color:#3498db}.doc-icon.xlsx{background:#2ecc7122;color:#2ecc71}.doc-icon.pptx{background:#f39c1222;color:#f39c12}.doc-icon.img{background:#9b59b622;color:#9b59b6}.doc-info{flex:1;min-width:0}.doc-name{font-size:var(--font-sm);font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.doc-meta{font-size:var(--font-xs);color:var(--text-muted)}.doc-actions{display:flex;gap:var(--space-xs);flex-shrink:0}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.6);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;z-index:200;animation:fadeIn .2s ease;padding:0}@media (min-width: 600px){.modal-overlay{align-items:center;padding:var(--space-md)}}.modal{background:rgba(35,40,56,.85);border-radius:var(--radius-xl) var(--radius-xl) 0 0;width:100%;max-width:500px;max-height:85vh;overflow-y:auto;animation:slideUp .3s ease;border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);box-shadow:var(--shadow-lg)}@media (min-width: 600px){.modal{border-radius:var(--radius-xl);animation:scaleIn .3s ease}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);border-bottom:1px solid rgba(255,255,255,.08);position:sticky;top:0;background:rgba(35,40,56,.6);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:1}.modal-header h2{font-size:var(--font-lg);font-weight:700}.modal-body{padding:var(--space-lg)}.modal-footer{display:flex;gap:var(--space-sm);padding:var(--space-md) var(--space-lg) var(--space-lg);justify-content:flex-end}.guide-section{margin-bottom:var(--space-lg);border:1px solid var(--border-subtle);border-radius:var(--radius-md);overflow:hidden}.guide-section-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md);background:var(--bg-elevated);cursor:pointer;font-weight:600;font-size:var(--font-sm);color:var(--accent);-webkit-user-select:none;user-select:none}.guide-section-content{padding:var(--space-md);font-size:var(--font-sm);line-height:1.7;color:var(--text-secondary);white-space:pre-wrap}.calendar-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.calendar-nav h3{font-size:var(--font-md);font-weight:600}.week-grid{display:flex;flex-direction:column;gap:var(--space-sm)}.day-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-md);transition:var(--transition-fast)}.day-card:hover{border-color:var(--border-light)}.day-card.evaluation{border-left:3px solid var(--accent)}.day-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-sm)}.day-name{font-weight:600;font-size:var(--font-sm);color:var(--text-primary)}.day-date{font-size:var(--font-xs);color:var(--text-muted)}.day-tag{font-size:var(--font-xs);padding:2px 8px;border-radius:var(--radius-full);font-weight:600}.day-tag.eval{background:var(--accent-glow);color:var(--accent)}.day-tag.hrs8{background:var(--success-bg);color:var(--success)}.day-tag.hrs4{background:var(--info-bg);color:var(--info)}.system-slot{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--bg-input);border-radius:var(--radius-sm);margin-top:var(--space-sm);font-size:var(--font-sm)}.system-slot select{flex:1;color:var(--text-primary);background:transparent}.grade-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--space-sm);margin-top:var(--space-sm)}.grade-input{text-align:center;width:100%;background:var(--bg-input);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:6px;color:var(--text-primary);font-size:var(--font-sm);font-weight:600}.grade-input.fail{border-color:var(--danger);color:var(--danger);background:var(--danger-bg)}.grade-label{font-size:var(--font-xs);color:var(--text-muted);text-align:center;margin-bottom:2px}.search-bar{position:relative;margin-bottom:var(--space-md)}.search-bar input{width:100%;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-full);padding:10px 16px 10px 40px;color:var(--text-primary);font-size:var(--font-sm)}.search-bar input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.search-bar svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--text-muted)}.data-table{width:100%;border-collapse:collapse;font-size:var(--font-sm)}.data-table th{text-align:left;padding:var(--space-sm) var(--space-md);background:rgba(45,51,80,.97);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:var(--accent-light);font-weight:700;font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.5px;position:sticky;top:0;z-index:1;box-shadow:inset 0 -1px #ffffff1a}.data-table td{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--border-subtle);color:var(--text-primary)}.data-table tr:hover td{background:var(--bg-card-hover)}.table-wrapper{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden;overflow-y:auto;max-height:60vh}.pill-tabs{display:flex;gap:var(--space-xs);background:rgba(30,35,54,.5);padding:4px;border-radius:var(--radius-full);margin-bottom:var(--space-lg);border:1px solid rgba(255,255,255,.05)}.pill-tab{flex:1;padding:8px 12px;border-radius:var(--radius-full);font-size:var(--font-sm);font-weight:500;color:var(--text-muted);text-align:center;transition:var(--transition-fast)}.pill-tab.active{background:var(--primary);color:#fff;box-shadow:var(--shadow-sm)}.alert-banner{padding:var(--space-md);border-radius:var(--radius-md);display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md);font-size:var(--font-sm);font-weight:500;animation:fadeIn .3s ease}.alert-banner.danger{background:var(--danger-bg);border:1px solid rgba(231,76,60,.3);color:var(--danger)}.alert-banner.warning{background:var(--warning-bg);border:1px solid rgba(243,156,18,.3);color:var(--warning)}.alert-banner.success{background:var(--success-bg);border:1px solid rgba(46,204,113,.3);color:var(--success)}.loading-spinner{width:32px;height:32px;border:3px solid var(--border-subtle);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin:var(--space-xl) auto}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:var(--space-2xl) var(--space-lg);color:var(--text-muted)}.empty-state svg{width:48px;height:48px;margin:0 auto var(--space-md);opacity:.4}.empty-state h3{font-size:var(--font-md);color:var(--text-secondary);margin-bottom:var(--space-xs)}.empty-state p{font-size:var(--font-sm)}.section-title{font-size:var(--font-lg);font-weight:700;color:var(--text-primary);margin-bottom:var(--space-md);display:flex;align-items:center;gap:var(--space-sm)}.section-title svg{color:var(--accent);width:20px;height:20px}.chip{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-full);font-size:var(--font-xs);font-weight:600;background:var(--bg-elevated);color:var(--text-secondary)}.crop-container{position:relative;max-height:60vh;overflow:auto;background:var(--bg-deep);border-radius:var(--radius-md)}.page{animation:fadeIn .25s ease}.settings-btn{width:32px;height:32px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:var(--transition-fast)}.settings-btn:hover{background:var(--bg-elevated);color:var(--accent)}.drive-link{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--font-sm);transition:var(--transition-fast);text-decoration:none;margin-bottom:var(--space-md)}.drive-link:hover{border-color:var(--accent);color:var(--accent)}.drive-link svg{width:20px;height:20px;flex-shrink:0}.glossary-system-row:hover td{background:rgba(65,110,87,.12)!important}.glossary-system-row td:first-child{position:relative}
