*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-primary: #0d9488;--color-primary-dark: #0f766e;--color-primary-light: #14b8a6;--color-on-primary: #ffffff;--color-success: #16a34a;--color-error: #dc2626;--color-warning: #d97706;--color-info: #0284c7;--color-background: #f8fafc;--color-surface: #ffffff;--color-text: #1e293b;--color-text-secondary: #64748b;--color-text-muted: #94a3b8;--color-border: #e2e8f0;--color-border-focus: #0d9488;--font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--leading-tight: 1.25;--leading-normal: 1.5;--leading-relaxed: 1.75;--space-0: 0;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease;--z-dropdown: 100;--z-sticky: 200;--z-modal: 300;--z-toast: 400;--max-width: 480px;--header-height: 56px;--container-padding: var(--space-4);--breakpoint-xs: 375px;--breakpoint-sm: 640px;--breakpoint-md: 768px;--breakpoint-lg: 1024px}@media(prefers-color-scheme:dark){:root{--color-background: #0f172a;--color-surface: #1e293b;--color-text: #f1f5f9;--color-text-secondary: #94a3b8;--color-text-muted: #64748b;--color-border: #334155}}html{font-family:var(--font-family);font-size:16px;line-height:var(--leading-normal);color:var(--color-text);background-color:var(--color-background);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;touch-action:manipulation}body{min-height:100vh;min-height:100dvh}:focus-visible{outline:2px solid var(--color-border-focus);outline-offset:2px}button,a,input,select,textarea{min-height:44px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}::selection{background-color:var(--color-primary);color:var(--color-on-primary)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-background)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.container{width:100%;max-width:var(--max-width);margin:0 auto;padding:clamp(var(--space-3),4vw,var(--space-6));padding-bottom:calc(var(--space-4) + env(safe-area-inset-bottom))}@media(min-width:640px){.container{padding:clamp(var(--space-4),4vw,var(--space-8))}}@media(max-width:374px){:root{--text-xs: .6875rem;--text-sm: .8125rem;--text-base: .9375rem;--text-lg: 1.0625rem}}@media(min-width:375px)and (max-width:768px){:root{--text-sm: clamp(.8125rem, .75rem + .3vw, .875rem);--text-base: clamp(.9375rem, .875rem + .3vw, 1rem);--text-lg: clamp(1.0625rem, 1rem + .4vw, 1.125rem);--text-xl: clamp(1.125rem, 1.0625rem + .4vw, 1.25rem)}}@media(max-width:639px){.hidden-sm{display:none!important}}@media(min-width:640px)and (max-width:767px){.hidden-md{display:none!important}}@media(min-width:768px){.hidden-lg{display:none!important}}.visible-sm{display:none!important}@media(max-width:639px){.visible-sm{display:block!important}}.grid-responsive{display:grid;gap:var(--space-4);grid-template-columns:1fr}@media(min-width:640px){.grid-responsive{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-6)}}@media(min-width:768px){.grid-responsive{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}}.stack-sm{display:flex;flex-direction:column;gap:var(--space-3)}@media(min-width:640px){.stack-sm{flex-direction:row}}@supports (padding: max(0px)){.safe-top{padding-top:max(var(--space-4),env(safe-area-inset-top))}.safe-bottom{padding-bottom:max(var(--space-4),env(safe-area-inset-bottom))}.safe-left{padding-left:max(var(--space-4),env(safe-area-inset-left))}.safe-right{padding-right:max(var(--space-4),env(safe-area-inset-right))}}.flex-column{display:flex;flex-direction:column}.flex-row{display:flex;flex-direction:row}@media(max-width:639px){.flex-column-mobile{flex-direction:column}}@media(min-width:640px){.flex-row-tablet{flex-direction:row}}.gap-responsive{gap:var(--space-3)}@media(min-width:640px){.gap-responsive{gap:var(--space-5)}}@media(min-width:768px){.gap-responsive{gap:var(--space-6)}}.tap-target{min-width:44px;min-height:44px;display:inline-flex;align-items:center;justify-content:center}.w-full{width:100%}.w-auto{width:auto}@media(max-width:639px){.w-full-mobile{width:100%}}@media(min-width:640px){.w-auto-tablet{width:auto}}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}@media(max-width:639px){.text-center-mobile{text-align:center}}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.break-words{overflow-wrap:break-word;word-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.mx-auto{margin-left:auto;margin-right:auto}.mt-responsive{margin-top:var(--space-4)}@media(min-width:640px){.mt-responsive{margin-top:var(--space-6)}}@media(max-height:500px)and (orientation:landscape){:root{--header-height: 48px}.container{padding:var(--space-2) var(--space-4)}.attendance-form{gap:var(--space-2)!important}}@media(-webkit-min-device-pixel-ratio:2),(min-resolution:192dpi){html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}}@media print{body{background:#fff;color:#000}.header,.help-button,button[type=button]{display:none}.container{max-width:100%;padding:0}}
