@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";
:root{--gold:#d4af37;--gold-light:#e8cc6e;--gold-dark:#b8941f;--gold-50:#fdf8e8;--gold-100:#f9edc4;--gold-200:#f3db8a;--gold-500:#d4af37;--gold-600:#b8941f;--gold-700:#9a7a14;--white:#fff;--gray-25:#fcfcfd;--gray-50:#f9fafb;--gray-100:#f2f4f7;--gray-200:#e4e7ec;--gray-300:#d0d5dd;--gray-400:#98a2b3;--gray-500:#667085;--gray-600:#475467;--gray-700:#344054;--gray-800:#1d2939;--gray-900:#101828;--success:#12b76a;--success-light:#ecfdf3;--warning:#f79009;--warning-light:#fffaeb;--danger:#f04438;--danger-light:#fef3f2;--info:#2e90fa;--info-light:#eff8ff;--bg-primary:var(--gray-50);--bg-card:var(--white);--bg-card-hover:var(--gray-25);--bg-input:var(--white);--bg-glass:#ffffffb8;--text-primary:var(--gray-900);--text-secondary:var(--gray-600);--text-tertiary:var(--gray-400);--text-on-gold:var(--gray-900);--border-light:var(--gray-200);--border-medium:var(--gray-300);--border-focus:var(--gold);--shadow-xs:0 1px 2px #1018280d;--shadow-sm:0 1px 3px #1018281a, 0 1px 2px #1018280f;--shadow-md:0 4px 8px -2px #1018281a, 0 2px 4px -2px #1018280f;--shadow-lg:0 12px 16px -4px #10182814, 0 4px 6px -2px #10182808;--shadow-xl:0 20px 24px -4px #10182814, 0 8px 8px -4px #10182808;--shadow-gold:0 4px 14px #d4af3740;--shadow-gold-lg:0 8px 24px #d4af3759;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--radius-full:9999px;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--space-16:64px;--font-family:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs:.75rem;--font-size-sm:.8125rem;--font-size-base:.875rem;--font-size-md:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:1.875rem;--font-size-4xl:2.25rem;--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-spring:cubic-bezier(.34, 1.56, .64, 1);--duration-fast:.15s;--duration-normal:.25s;--duration-slow:.4s}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-family);font-size:var(--font-size-base);color:var(--text-primary);background:var(--bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100dvh;line-height:1.6}img,video{max-width:100%;height:auto;display:block}a{color:inherit;text-decoration:none}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,select,textarea{font-family:inherit;font-size:inherit}.container{width:100%;max-width:480px;padding:0 var(--space-5);margin:0 auto}.page{min-height:100dvh;padding-bottom:var(--space-8)}.card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--duration-normal) var(--ease-out), transform var(--duration-normal) var(--ease-out)}.card:hover{box-shadow:var(--shadow-md)}.card-glass{background:var(--bg-glass);-webkit-backdrop-filter:blur(20px);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid #d4af3726}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);font-size:var(--font-size-base);border-radius:var(--radius-md);transition:all var(--duration-normal) var(--ease-out);white-space:nowrap;-webkit-user-select:none;user-select:none;font-weight:600;line-height:1.4;display:inline-flex}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{background:linear-gradient(135deg, var(--gold) 0%, var(--gold-dark) 100%);color:var(--white);box-shadow:var(--shadow-gold)}.btn-primary:hover:not(:disabled){box-shadow:var(--shadow-gold-lg);transform:translateY(-1px)}.btn-secondary{background:var(--white);color:var(--gray-700);border:1px solid var(--border-medium);box-shadow:var(--shadow-xs)}.btn-secondary:hover:not(:disabled){background:var(--gray-50);border-color:var(--gold-200)}.btn-danger{background:var(--danger);color:var(--white)}.btn-danger:hover:not(:disabled){background:#d92d20}.btn-ghost{color:var(--gray-600);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--gray-100)}.btn-lg{padding:var(--space-4) var(--space-8);font-size:var(--font-size-md);border-radius:var(--radius-lg)}.btn-full{width:100%}.btn-icon{border-radius:var(--radius-md);width:40px;height:40px;font-size:var(--font-size-lg);padding:0}.form-group{gap:var(--space-2);flex-direction:column;display:flex}.form-label{font-size:var(--font-size-sm);color:var(--gray-700);font-weight:500}.form-input{width:100%;padding:var(--space-3) var(--space-4);font-size:var(--font-size-base);color:var(--text-primary);background:var(--bg-input);border:1px solid var(--border-medium);border-radius:var(--radius-md);transition:border-color var(--duration-fast) var(--ease-out), box-shadow var(--duration-fast) var(--ease-out);outline:none}.form-input:focus{border-color:var(--gold);box-shadow:0 0 0 3px #d4af3726}.form-input::placeholder{color:var(--gray-400)}.form-select{width:100%;padding:var(--space-3) var(--space-4);padding-right:var(--space-10);font-size:var(--font-size-base);color:var(--text-primary);background:var(--bg-input) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%23667085' viewBox='0 0 16 16'%3E%3Cpath d='M4.47 5.97a.75.75 0 0 1 1.06 0L8 8.44l2.47-2.47a.75.75 0 1 1 1.06 1.06l-3 3a.75.75 0 0 1-1.06 0l-3-3a.75.75 0 0 1 0-1.06z'/%3E%3C/svg%3E") no-repeat right 12px center;border:1px solid var(--border-medium);border-radius:var(--radius-md);appearance:none;cursor:pointer;transition:border-color var(--duration-fast) var(--ease-out), box-shadow var(--duration-fast) var(--ease-out);outline:none}.form-select:focus{border-color:var(--gold);box-shadow:0 0 0 3px #d4af3726}.form-textarea{width:100%;min-height:80px;padding:var(--space-3) var(--space-4);font-size:var(--font-size-base);color:var(--text-primary);background:var(--bg-input);border:1px solid var(--border-medium);border-radius:var(--radius-md);resize:vertical;transition:border-color var(--duration-fast) var(--ease-out), box-shadow var(--duration-fast) var(--ease-out);outline:none;font-family:inherit}.form-textarea:focus{border-color:var(--gold);box-shadow:0 0 0 3px #d4af3726}.badge{font-size:var(--font-size-xs);border-radius:var(--radius-full);text-transform:capitalize;align-items:center;gap:4px;padding:2px 10px;font-weight:600;display:inline-flex}.badge-present{background:var(--success-light);color:#027a48}.badge-absent{background:var(--danger-light);color:#b42318}.badge-half-day{background:var(--warning-light);color:#b54708}.badge-pending{background:var(--info-light);color:#175cd3}.header{z-index:100;-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-light);padding:var(--space-3) 0;background:#ffffffd9;position:sticky;top:0}.header-inner{max-width:480px;padding:0 var(--space-5);justify-content:space-between;align-items:center;margin:0 auto;display:flex}.header-brand{align-items:center;gap:var(--space-2);font-size:var(--font-size-lg);color:var(--gray-900);font-weight:700;display:flex}.header-brand .brand-accent{color:var(--gold)}.stats-grid{gap:var(--space-3);grid-template-columns:1fr 1fr;display:grid}.stat-card{padding:var(--space-4);border-radius:var(--radius-lg);background:var(--bg-card);border:1px solid var(--border-light);box-shadow:var(--shadow-xs)}.stat-value{font-size:var(--font-size-3xl);color:var(--gray-900);font-weight:800;line-height:1.1}.stat-label{font-size:var(--font-size-xs);color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em;margin-top:var(--space-1);font-weight:500}.stat-card.stat-gold{background:linear-gradient(135deg, var(--gold-50) 0%, var(--gold-100) 100%);border-color:var(--gold-200)}.stat-card.stat-gold .stat-value{color:var(--gold-700)}.actions-grid{gap:var(--space-3);flex-direction:column;display:flex}.action-card{align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5);background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);cursor:pointer;transition:all var(--duration-normal) var(--ease-out);text-align:left;width:100%;display:flex}.action-card:hover{border-color:var(--gold-200);box-shadow:var(--shadow-gold);transform:translateY(-1px)}.action-icon{background:linear-gradient(135deg, var(--gold-50) 0%, var(--gold-100) 100%);border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:20px;display:flex}.action-text h3{font-size:var(--font-size-base);color:var(--gray-900);font-weight:600}.action-text p{font-size:var(--font-size-xs);color:var(--gray-500);margin-top:2px}.attendance-item{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-md);transition:border-color var(--duration-fast) var(--ease-out);display:flex}.attendance-item:hover{border-color:var(--gold-200)}.attendance-photo{border-radius:var(--radius-md);object-fit:cover;background:var(--gray-100);flex-shrink:0;width:40px;height:40px}.attendance-info{flex:1;min-width:0}.attendance-info .name{font-size:var(--font-size-base);color:var(--gray-900);white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.attendance-info .time{font-size:var(--font-size-xs);color:var(--gray-500)}.login-page{background:radial-gradient(ellipse at 20% 50%, #d4af3714 0%, transparent 50%), radial-gradient(ellipse at 80% 20%, #d4af370f 0%, transparent 50%), var(--bg-primary);min-height:100dvh;padding:var(--space-5);justify-content:center;align-items:center;display:flex}.login-card{width:100%;max-width:400px;padding:var(--space-8) var(--space-6)}.login-logo{text-align:center;margin-bottom:var(--space-8)}.login-logo .logo-icon{width:56px;height:56px;margin:0 auto var(--space-4);background:linear-gradient(135deg, var(--gold) 0%, var(--gold-dark) 100%);border-radius:var(--radius-lg);box-shadow:var(--shadow-gold);justify-content:center;align-items:center;font-size:24px;display:flex}.login-logo h1{font-size:var(--font-size-2xl);color:var(--gray-900);font-weight:800}.login-logo h1 .accent{color:var(--gold)}.login-logo p{font-size:var(--font-size-sm);color:var(--gray-500);margin-top:var(--space-1)}.login-form{gap:var(--space-5);flex-direction:column;display:flex}.camera-section{aspect-ratio:3/4;background:var(--gray-100);border-radius:var(--radius-lg);border:2px dashed var(--border-medium);justify-content:center;align-items:center;gap:var(--space-3);cursor:pointer;width:100%;transition:border-color var(--duration-normal) var(--ease-out);flex-direction:column;display:flex;position:relative;overflow:hidden}.camera-section:hover{border-color:var(--gold)}.camera-section.has-photo{border-style:solid;border-color:var(--success)}.camera-section img,.camera-section video{object-fit:cover;width:100%;height:100%;position:absolute;inset:0}.camera-placeholder-icon{color:var(--gray-400);font-size:40px}.camera-placeholder-text{font-size:var(--font-size-sm);color:var(--gray-500);text-align:center}.camera-overlay{padding:var(--space-4);background:linear-gradient(#0000,#00000080);justify-content:center;display:flex;position:absolute;bottom:0;left:0;right:0}.camera-capture-btn{background:var(--white);border:3px solid var(--gold);width:60px;height:60px;transition:transform var(--duration-fast) var(--ease-spring);border-radius:50%;box-shadow:0 2px 8px #0003}.camera-capture-btn:active{transform:scale(.9)}.location-badge{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--success-light);border-radius:var(--radius-full);font-size:var(--font-size-xs);color:#027a48;font-weight:500;display:inline-flex}.location-badge.error{background:var(--danger-light);color:#b42318}.location-badge.loading{background:var(--info-light);color:#175cd3}.toast-container{top:var(--space-5);z-index:10000;width:calc(100% - 40px);max-width:400px;position:fixed;left:50%;transform:translate(-50%)}.toast{padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--font-size-sm);box-shadow:var(--shadow-lg);animation:slideDown var(--duration-normal) var(--ease-spring);align-items:center;gap:var(--space-2);font-weight:500;display:flex}.toast-success{color:var(--white);background:#027a48}.toast-error{color:var(--white);background:#b42318}.toast-info{background:var(--gray-800);color:var(--white)}@keyframes slideDown{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}.section-header{margin-bottom:var(--space-3);justify-content:space-between;align-items:center;display:flex}.section-title{font-size:var(--font-size-md);color:var(--gray-900);font-weight:700}.section-subtitle{font-size:var(--font-size-xs);color:var(--gray-500)}.skeleton{background:linear-gradient(90deg, var(--gray-100) 25%, var(--gray-200) 50%, var(--gray-100) 75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.5s ease-in-out infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.empty-state{text-align:center;padding:var(--space-12) var(--space-6);color:var(--gray-400)}.empty-state-icon{margin-bottom:var(--space-3);font-size:48px}.empty-state-text{font-size:var(--font-size-sm);color:var(--gray-500)}.divider{background:var(--border-light);height:1px;margin:var(--space-5) 0}.mt-1{margin-top:var(--space-1)}.mt-2{margin-top:var(--space-2)}.mt-3{margin-top:var(--space-3)}.mt-4{margin-top:var(--space-4)}.mt-5{margin-top:var(--space-5)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.mb-3{margin-bottom:var(--space-3)}.mb-4{margin-bottom:var(--space-4)}.mb-5{margin-bottom:var(--space-5)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.text-center{text-align:center}.text-right{text-align:right}.page-enter{animation:fadeUp var(--duration-slow) var(--ease-out)}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.spinner{border:2.5px solid var(--gray-200);border-top-color:var(--gold);border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin}.spinner-lg{border-width:3px;width:32px;height:32px}@keyframes spin{to{transform:rotate(360deg)}}.date-picker-row{align-items:center;gap:var(--space-3);display:flex}.date-input{flex:1}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9999;padding:var(--space-5);animation:fadeIn var(--duration-fast) ease;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:var(--white);border-radius:var(--radius-xl);width:100%;max-width:400px;max-height:90vh;box-shadow:var(--shadow-xl);animation:scaleUp var(--duration-normal) var(--ease-spring);overflow-y:auto}.modal-header{padding:var(--space-5) var(--space-5) var(--space-3);justify-content:space-between;align-items:center;display:flex}.modal-body{padding:0 var(--space-5) var(--space-5)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleUp{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.back-btn{align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);color:var(--gray-600);padding:var(--space-2) 0;transition:color var(--duration-fast) var(--ease-out);font-weight:500;display:inline-flex}.back-btn:hover{color:var(--gold)}.review-grid{gap:var(--space-3);display:grid}.review-row{font-size:var(--font-size-sm);justify-content:space-between;align-items:flex-start;display:flex}.review-label{color:var(--gray-500);font-weight:500}.review-value{color:var(--gray-900);text-align:right;font-weight:600}@media (max-width:360px){:root{--font-size-3xl:1.5rem;--font-size-2xl:1.25rem}.stats-grid{gap:var(--space-2)}.stat-card{padding:var(--space-3)}}
