*{box-sizing:border-box}.market-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media (max-width: 768px){.market-grid{grid-template-columns:1fr}}.market-card{padding:16px}.market-title{font-size:14px;font-weight:700;color:#1e293b;margin-bottom:12px;display:flex;align-items:center;gap:6px}.market-unit{font-size:11px;color:#9ca3af;font-weight:400}.market-search{width:100%;padding:7px 10px;border:1px solid #e5e7eb;border-radius:6px;font-size:13px;margin-bottom:8px;outline:none;transition:border-color .15s}.market-search:focus{border-color:#3b82f6}.market-scroll{max-height:260px;overflow-y:auto;margin:-4px;padding:4px}.market-scroll::-webkit-scrollbar{width:6px}.market-scroll::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.market-scroll::-webkit-scrollbar-thumb:hover{background:#9ca3af}.market-table{width:100%;font-size:13px;border-collapse:collapse}.market-table thead th{position:sticky;top:0;background:#fff;z-index:1}.market-table th{color:#6b7280;font-weight:500;padding:6px 4px;border-bottom:1px solid #e5e7eb;font-size:12px;text-align:left}.market-table td{padding:8px 4px;border-bottom:1px solid #f3f4f6}.market-table tr:last-child td{border-bottom:none}.market-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid #f3f4f6}.market-row:last-child{border-bottom:none}.market-label{color:#6b7280;font-size:13px}.market-value{font-weight:700;color:#1e293b;font-size:14px;display:flex;align-items:center;gap:8px}.market-change{font-size:11px;padding:2px 6px;border-radius:4px;font-weight:600}.market-change.up{color:#16a34a;background:#dcfce7}.market-change.down{color:#dc2626;background:#fee2e2}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f5f6fa;color:#1f2937}a{color:#2563eb;text-decoration:none}a:hover{text-decoration:underline}.container{max-width:960px;margin:0 auto;padding:24px 16px}.dash-greeting{border-radius:16px;padding:22px 28px;margin-bottom:28px;color:#fff;position:relative;overflow:hidden;display:flex;align-items:center;gap:20px;transition:background .5s}.dash-greeting.weather-sunny{background:linear-gradient(135deg,#f6d365,#fda085,#f5876e)}.dash-greeting.weather-cloudy{background:linear-gradient(135deg,#a1c4fd,#c2e9fb,#96b7d8);color:#1e3a5f}.dash-greeting.weather-rainy{background:linear-gradient(135deg,#4facfe,#667eea,#5a6abf)}.dash-greeting.weather-stormy{background:linear-gradient(135deg,#434a6d,#30365e,#1a1f3a)}.dash-greeting.weather-foggy{background:linear-gradient(135deg,#d7d2cc,#bdc3c7,#a8b5c0);color:#374151}.dash-greeting:before{content:"";position:absolute;top:-40%;right:-10%;width:200px;height:200px;background:#ffffff1a;border-radius:50%;pointer-events:none}.dash-greeting:after{content:"";position:absolute;bottom:-30%;right:15%;width:120px;height:120px;background:#ffffff0f;border-radius:50%;pointer-events:none}.dash-greeting-content{position:relative;z-index:1;flex:1;min-width:0}.dash-greeting-main{font-size:22px;font-weight:700;margin-bottom:8px}.dash-greeting-quote{font-size:14px;opacity:.85;font-weight:400;letter-spacing:.2px}.dash-weather{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:2px;background:#ffffff26;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:14px;padding:14px 20px;min-width:100px;text-align:center;flex-shrink:0}.dash-weather-icon{font-size:32px;line-height:1}.dash-weather-temp{font-size:22px;font-weight:800;letter-spacing:-.5px}.dash-weather-label{font-size:11px;opacity:.85;font-weight:500;white-space:nowrap}.dash-greeting.weather-cloudy .dash-weather,.dash-greeting.weather-foggy .dash-weather{background:#00000014}.dash-ticker{position:relative;z-index:1;display:flex;flex-direction:column;gap:4px;background:#ffffff26;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:10px;padding:8px 14px;margin-left:auto;flex-shrink:0}.dash-ticker-line{display:flex;align-items:center;gap:14px}.dash-ticker-item{display:flex;align-items:center;gap:5px;font-size:13px;white-space:nowrap}.dash-ticker-icon{font-size:15px}.dash-ticker-label{opacity:.8;font-weight:500}.dash-ticker-num{font-weight:700;font-size:14px}.dash-ticker-sep{opacity:.5;font-size:12px}.dash-ticker-change{font-size:11px;font-weight:600;margin-left:2px}.dash-ticker-change.up{color:#bbf7d0}.dash-ticker-change.down{color:#fecaca}.dash-greeting.weather-cloudy .dash-ticker,.dash-greeting.weather-foggy .dash-ticker{background:#00000014}.dash-greeting.weather-cloudy .dash-ticker-change.up{color:#16a34a}.dash-greeting.weather-cloudy .dash-ticker-change.down,.dash-greeting.weather-foggy .dash-ticker-change.down{color:#dc2626}.dash-greeting.weather-foggy .dash-ticker-change.up{color:#16a34a}@media (max-width: 600px){.dash-greeting{flex-direction:column;text-align:center;padding:18px 16px;gap:12px}.dash-greeting-main{font-size:18px}.dash-ticker{margin-left:0}.dash-ticker-line{justify-content:center}.dash-weather{flex-direction:row;gap:10px;padding:10px 16px}.dash-weather-icon{font-size:24px}.dash-weather-temp{font-size:18px}}.card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #00000014;padding:24px;margin-bottom:20px}h1{font-size:24px;margin:0 0 16px;display:flex;align-items:center;gap:8px}h2{font-size:18px;margin:0 0 12px;display:flex;align-items:center;gap:6px}.nav{background:#1e293b;color:#fff;padding:0 20px;display:flex;align-items:center;gap:2px;min-height:52px;overflow-x:auto;position:sticky;top:0;z-index:1000}.nav-brand{display:flex;align-items:center;font-size:16px;font-weight:700;margin-right:12px;white-space:nowrap}.nav-link{display:flex;align-items:center;gap:5px;color:#94a3b8;font-size:13px;padding:14px 10px;border-bottom:2px solid transparent;white-space:nowrap;transition:color .15s,border-color .15s;text-decoration:none!important}.nav-link:hover{color:#e2e8f0}.nav-link.active{color:#fff;font-weight:600;border-bottom-color:#3b82f6}.spacer{flex:1}.nav-user{display:flex;align-items:center;gap:5px;font-size:12px;color:#94a3b8;white-space:nowrap;margin-left:8px}.nav-logout{display:flex;align-items:center;gap:4px;background:transparent;border:1px solid #475569;color:#cbd5e1;padding:5px 10px;border-radius:6px;cursor:pointer;font-size:12px;white-space:nowrap;margin-left:8px;transition:background .15s}.nav-logout:hover{background:#334155;color:#fff}.btn{display:inline-flex;align-items:center;gap:6px;background:#2563eb;color:#fff;border:none;padding:10px 18px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:background .15s}.btn:hover{background:#1d4ed8}.btn:disabled{background:#94a3b8;cursor:not-allowed}.btn.danger{background:#dc2626}.btn.danger:hover{background:#b91c1c}.btn.danger-outline{background:#fff;color:#dc2626;border:1px solid #fca5a5}.btn.danger-outline:hover{background:#fef2f2;border-color:#dc2626}.btn.sm{padding:4px 10px;font-size:12px}.btn.success{background:#16a34a}.btn.success:hover{background:#15803d}.btn.ghost{background:#e5e7eb;color:#1f2937}.btn.ghost:hover{background:#d1d5db}.btn.sm{padding:6px 12px;font-size:12px}.form{display:flex;flex-direction:column;gap:14px;max-width:420px}.form label{font-size:13px;font-weight:500}.form input,.form select{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px}.leave-form{display:flex;flex-direction:column;gap:18px}.leave-form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media (max-width: 540px){.leave-form-row{grid-template-columns:1fr}}.leave-form-field{display:flex;flex-direction:column;gap:6px}.leave-form-field label{font-size:13px;font-weight:600;color:#374151}.leave-form-field .required{color:#dc2626}.leave-form-field input,.leave-form-field select,.leave-form-field textarea{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;font-family:inherit;transition:border-color .15s}.leave-form-field input:focus,.leave-form-field select:focus,.leave-form-field textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.leave-form-field textarea{resize:vertical;min-height:72px}.leave-form-field select:disabled{background:#f3f4f6;color:#9ca3af;cursor:not-allowed}.field-hint{font-size:11px;color:#9ca3af;margin-top:2px}.leave-form-footer{display:flex;align-items:center;gap:16px;padding-top:6px}.leave-summary{display:flex;align-items:baseline;gap:8px;flex:1}.leave-summary-days{font-size:32px;font-weight:800;color:#2563eb;line-height:1}.leave-summary-label{font-size:13px;color:#6b7280}.half-day-tag{display:inline-block;margin-left:4px;padding:1px 6px;background:#ede9fe;color:#6d28d9;border-radius:4px;font-size:10px;font-weight:600;vertical-align:middle}.reason-cell{max-width:180px;font-size:13px;color:#6b7280;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}table{width:100%;border-collapse:collapse;font-size:14px}th,td{padding:10px 12px;text-align:left;border-bottom:1px solid #e5e7eb}.sticky-left{position:sticky;left:0;z-index:2;background:#fff}.sticky-left:after{content:"";position:absolute;top:0;right:-6px;bottom:0;width:6px;background:linear-gradient(to right,rgba(0,0,0,.06),transparent)}thead .sticky-left{background:#f9fafb;z-index:3}tbody tr:hover .sticky-left{background:#f8fafc}.sticky-right{position:sticky;right:0;z-index:2;background:#fff}.sticky-right:before{content:"";position:absolute;top:0;left:-6px;bottom:0;width:6px;background:linear-gradient(to left,rgba(0,0,0,.06),transparent)}thead .sticky-right{background:#f9fafb;z-index:3}tbody tr:hover .sticky-right{background:#f8fafc}tfoot .sticky-left,tfoot .sticky-right{background:#fff}th{background:#f9fafb;font-weight:600;font-size:12px;text-transform:uppercase;color:#6b7280}.badge{display:inline-block;padding:2px 10px;border-radius:999px;font-size:11px;font-weight:600;text-transform:uppercase}.badge.pending{background:#fef3c7;color:#92400e}.badge.approved{background:#d1fae5;color:#065f46}.badge.rejected{background:#fee2e2;color:#991b1b}.badge.cancelled{background:#e5e7eb;color:#374151}.alert{display:flex;align-items:center;gap:8px;padding:12px 16px;border-radius:8px;font-size:14px;margin-bottom:16px}.alert.ok{background:#d1fae5;color:#065f46}.alert.err{background:#fee2e2;color:#991b1b}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}.stat{background:#fff;border-radius:12px;padding:20px;box-shadow:0 1px 3px #00000014;transition:transform .15s,box-shadow .15s}.stat.stat-link:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001f}.stat .label{font-size:12px;color:#6b7280;text-transform:uppercase;display:flex;align-items:center;gap:5px}.stat .value{font-size:28px;font-weight:700;margin-top:6px}.ts-missing{color:#f59e0b;font-size:12px;font-style:italic}.ts-icon-ok{color:#16a34a}.ts-icon-fail{color:#dc2626}.cal-header{display:flex;align-items:center;gap:8px;margin-bottom:16px;flex-wrap:wrap}.cal-nav{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:1px solid #d1d5db;border-radius:8px;background:#fff;font-size:18px;cursor:pointer;color:#374151;transition:background .12s}.cal-nav:hover:not(:disabled){background:#f3f4f6}.cal-nav:disabled{opacity:.3;cursor:not-allowed}.cal-month-select{padding:6px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:15px;font-weight:600;color:#1f2937;background:#fff}.cal-stats{display:flex;gap:16px;margin-left:auto}.cal-stat{display:flex;align-items:center;gap:4px;font-size:13px;color:#374151}.cal-stat-muted{color:#9ca3af}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:#e5e7eb;border:1px solid #e5e7eb;border-radius:10px;overflow:hidden}.cal-dow{padding:8px 4px;text-align:center;font-size:11px;font-weight:700;text-transform:uppercase;color:#6b7280;background:#f9fafb;letter-spacing:.5px}.cal-dow-we{color:#dc2626}.cal-cell{background:#fff;min-height:72px;padding:6px 8px;display:flex;flex-direction:column;align-items:flex-start;gap:2px;cursor:default;position:relative;transition:background .1s}.cal-cell:not(.cal-empty):not(.cal-future):hover{background:#f8fafc}.cal-empty{background:#fafafa}.cal-we{background:#fefce8}.cal-today{box-shadow:inset 0 0 0 2px #3b82f6}.cal-future{opacity:.4}.cal-selected{background:#eff6ff!important;box-shadow:inset 0 0 0 2px #2563eb}.cal-s-ok{border-left:3px solid #16a34a}.cal-s-half{border-left:3px solid #f59e0b}.cal-s-miss{border-left:3px solid #dc2626}.cal-s-nocheck{border-left:3px solid #e5e7eb}.cal-s-leave{border-left:3px solid #8b5cf6;background:#f5f3ff}.cal-s-leave-pending{border-left:3px solid #a78bfa;background:#faf5ff;border-style:dashed}.cal-day{font-size:13px;font-weight:600;color:#374151;line-height:1}.cal-we .cal-day{color:#dc2626}.cal-today .cal-day{background:#3b82f6;color:#fff;width:22px;height:22px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:12px}.cal-icon{position:absolute;top:6px;right:6px}.cal-icon-ok{color:#16a34a}.cal-icon-half{font-size:12px;font-weight:800;color:#f59e0b}.cal-icon-miss{color:#dc2626}.cal-icon-absent{font-size:14px;color:#d1d5db;font-weight:600}.cal-icon-leave{font-size:12px}.cal-leave-label{color:#7c3aed!important;font-weight:600;font-size:10px!important}.cal-time{font-size:10px;color:#6b7280;font-variant-numeric:tabular-nums;font-family:SF Mono,Menlo,monospace,sans-serif;margin-top:auto}.cal-legend{display:flex;gap:18px;margin-top:12px;font-size:12px;color:#6b7280;flex-wrap:wrap}.cal-leg-dot{display:inline-block;width:10px;height:10px;border-radius:2px;margin-right:4px;vertical-align:middle}.cal-leg-ok{background:#16a34a}.cal-leg-half{background:#f59e0b}.cal-leg-absent{background:#e5e7eb}.cal-leg-leave{background:#8b5cf6}.cal-leg-we{background:#fef3c7}.cal-detail-leave{background:#f5f3ff;border:1px solid #e9d5ff;border-radius:10px;padding:12px 14px;margin-bottom:12px}.cal-detail-leave-badge{font-weight:700;color:#6d28d9;font-size:14px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.cal-leave-status{font-size:11px;padding:2px 8px;border-radius:999px;font-weight:600}.cal-leave-approved{background:#d1fae5;color:#065f46}.cal-leave-pending{background:#fef3c7;color:#92400e}.cal-detail-leave-range{font-size:13px;color:#64748b;margin-top:4px}.cal-detail-leave-reason{font-size:13px;color:#475569;margin-top:4px;font-style:italic}.cal-detail{margin-top:16px;padding:16px;background:#f8fafc;border-radius:10px;border:1px solid #e2e8f0}.cal-detail-title{display:flex;align-items:center;gap:6px;font-weight:600;font-size:14px;margin-bottom:12px;color:#1e293b}.cal-detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.cal-detail-item{display:flex;flex-direction:column;gap:2px}.cal-detail-label{font-size:11px;color:#94a3b8;text-transform:uppercase;font-weight:600}.cal-detail-value{font-size:18px;font-weight:700;color:#1e293b;font-variant-numeric:tabular-nums;font-family:SF Mono,Menlo,monospace,sans-serif}.emp-picker{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#eef2ff;border:1px solid #c7d2fe;border-radius:10px;margin-bottom:16px}.emp-picker select{flex:1;padding:7px 12px;border:1px solid #c7d2fe;border-radius:8px;font-size:14px;font-weight:500;background:#fff}@media (max-width: 600px){.cal-cell{min-height:56px;padding:4px 5px}.cal-day{font-size:12px}.cal-time{font-size:9px}.cal-icon{top:4px;right:4px}.cal-stats{margin-left:0;width:100%;margin-top:8px}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#0f172a url(/login-bg.jpg) center/cover no-repeat fixed;padding:20px;position:relative}.login-page:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#0f172a73;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}.login-card{position:relative;z-index:1;width:100%;max-width:380px;background:#ffffffeb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:20px;box-shadow:0 0 0 1px #fff3,0 25px 60px #0006;padding:44px 36px 32px}.login-brand{display:flex;flex-direction:column;align-items:center;gap:0}.login-logo{width:80px;height:80px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#eff6ff,#ecfdf5);border-radius:20px;margin-bottom:16px}.login-title{font-size:24px;font-weight:800;color:#0f172a;margin:0;letter-spacing:-.3px}.login-subtitle{font-size:13px;color:#94a3b8;margin:6px 0 0;letter-spacing:.2px}.login-divider{height:1px;background:#f1f5f9;margin:24px 0}.login-form{display:flex;flex-direction:column;gap:16px}.login-field{display:flex;flex-direction:column;gap:6px}.login-field label{display:flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.4px}.login-field input{width:100%;padding:11px 14px;border:1.5px solid #e2e8f0;border-radius:10px;font-size:14px;color:#1e293b;background:#f8fafc;transition:border-color .15s,box-shadow .15s,background .15s}.login-field input:focus{outline:none;border-color:#3b82f6;background:#fff;box-shadow:0 0 0 3px #3b82f61f}.login-field input::placeholder{color:#cbd5e1}.pwd-wrap{position:relative}.pwd-wrap input{padding-right:40px}.pwd-toggle{position:absolute;right:6px;top:50%;transform:translateY(-50%);background:none;border:none;padding:6px;cursor:pointer;color:#94a3b8;display:flex;align-items:center;border-radius:6px}.pwd-toggle:hover{color:#475569;background:#f1f5f9}.login-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px;margin-top:6px;border:none;border-radius:10px;background:#1e293b;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s,transform .1s,box-shadow .15s}.login-btn:hover:not(:disabled){background:#334155;transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.login-btn:active:not(:disabled){transform:translateY(0)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.25);border-top-color:#fff;border-radius:50%;animation:login-spin .6s linear infinite}@keyframes login-spin{to{transform:rotate(360deg)}}.login-footer{text-align:center;margin-top:28px;padding-top:20px;border-top:1px solid #f1f5f9;font-size:11px;color:#c1c9d4;letter-spacing:.3px}.emp-form{margin-bottom:20px;border:1px solid #e0e7ff;background:#f8faff}.emp-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media (max-width: 600px){.emp-form-grid{grid-template-columns:1fr}}@media (max-width: 440px){.login-card{padding:36px 24px 24px;border-radius:16px}.login-logo{width:56px;height:56px}}.leave-hist-filters{display:flex;align-items:center;flex-wrap:wrap;gap:10px;margin-bottom:14px}.leave-hist-range{display:flex;align-items:center;gap:8px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:4px 12px;transition:border-color .2s,box-shadow .2s}.leave-hist-range:focus-within{border-color:#818cf8;box-shadow:0 0 0 3px #818cf826;background:#fff}.leave-hist-range svg{color:#94a3b8;flex-shrink:0}.leave-hist-range input[type=date]{border:none;background:none;outline:none;font-size:13px;font-weight:500;padding:5px 2px;color:#1e293b}.leave-hist-sep{color:#cbd5e1;font-size:14px;font-weight:600}.leave-hist-presets{display:flex;gap:4px;flex-wrap:wrap}.leave-hist-presets .btn.sm.ghost{font-size:12px;padding:5px 10px;border-radius:8px}.leave-hist-status{font-size:13px;padding:7px 10px;border:1px solid #e2e8f0;border-radius:10px;background:#f8fafc;color:#1e293b;outline:none;cursor:pointer}.leave-hist-status:focus{border-color:#818cf8;box-shadow:0 0 0 3px #818cf826}.leave-hist-summary{display:flex;gap:8px;align-items:center;font-size:13px;color:#64748b;margin-bottom:12px;padding:6px 0;border-bottom:1px solid #f1f5f9}.leave-hist-summary b{color:#1e293b}@media (max-width: 600px){.leave-hist-filters{flex-direction:column;align-items:stretch}.leave-hist-range{width:100%}.leave-hist-presets{overflow-x:auto;flex-wrap:nowrap}}.att-admin-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:16px}.att-admin-date{display:flex;align-items:center;gap:8px}.att-admin-date input[type=date]{font-weight:600;font-size:14px;padding:6px 10px;border-radius:8px;border:1px solid #e2e8f0}.att-admin-stats{display:flex;gap:14px;flex-wrap:wrap}.att-stat{display:flex;align-items:center;gap:4px;font-size:13px;color:#64748b}.att-stat b{font-size:15px}.att-stat-ok b{color:#16a34a}.att-stat-late b{color:#f59e0b}.att-stat-absent b{color:#dc2626}.att-stat-leave b{color:#7c3aed}.att-search-wrap{position:relative;display:flex;align-items:center;max-width:280px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:0 12px;transition:border-color .2s,box-shadow .2s}.att-search-wrap:focus-within{border-color:#818cf8;box-shadow:0 0 0 3px #818cf826;background:#fff}.att-search-wrap svg{color:#94a3b8;flex-shrink:0}.att-search-wrap input{border:none;background:none;outline:none;padding:9px 8px;font-size:13px;width:100%;color:#1e293b}.att-search-wrap input::placeholder{color:#b0b8c4}.att-search-clear{background:none;border:none;cursor:pointer;padding:4px;border-radius:50%;color:#94a3b8;display:flex;align-items:center;transition:background .15s,color .15s}.att-search-clear:hover{background:#e2e8f0;color:#475569}@media (max-width: 600px){.att-admin-header{flex-direction:column;align-items:stretch}.att-admin-stats{justify-content:space-around}.att-search-wrap{max-width:100%}}input[type=date]:not(:focus):invalid,input[type=date].is-empty{color:#9ca3af}input[type=date]:not(:focus):invalid::-webkit-datetime-edit,input[type=date].is-empty::-webkit-datetime-edit{color:#9ca3af}input[type=date]::-webkit-datetime-edit-text,input[type=date]::-webkit-datetime-edit-month-field,input[type=date]::-webkit-datetime-edit-day-field,input[type=date]::-webkit-datetime-edit-year-field{color:inherit}.confirm-modal{background:#fff;border-radius:16px;padding:32px 36px 28px;text-align:center;max-width:400px;width:calc(100% - 32px);box-shadow:0 20px 60px #00000040;animation:popBounce .3s cubic-bezier(.34,1.56,.64,1)}.confirm-icon{font-size:52px;margin-bottom:8px;animation:emojiPop .5s ease}.confirm-title{font-size:20px;font-weight:700;color:#111827;margin-bottom:8px}.confirm-time{color:#6b7280;font-size:14px;margin-bottom:20px}.confirm-time b{color:#111827;font-size:16px;font-variant-numeric:tabular-nums}.checkin-popup-info{background:#eff6ff;border:1px solid #dbeafe;color:#1e40af;border-radius:10px;padding:8px 12px;font-size:13px;margin:8px 0 12px}.confirm-warn{background:#fef3c7;border:1px solid #fde68a;color:#92400e;border-radius:10px;padding:12px 14px;font-size:13.5px;line-height:1.5;text-align:left;margin:4px 0 18px}.confirm-actions{display:flex;gap:10px;justify-content:center}.confirm-actions .btn{min-width:110px;justify-content:center}.checkin-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:9000;animation:fadeIn .25s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.checkin-popup{background:#fff;border-radius:20px;padding:40px 36px 32px;text-align:center;max-width:380px;width:90%;position:relative;overflow:hidden;animation:popBounce .5s cubic-bezier(.34,1.56,.64,1);box-shadow:0 20px 60px #0003}.checkin-popup.checkin{border-top:5px solid #10b981}.checkin-popup.checkout{border-top:5px solid #8b5cf6}.checkin-confetti{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none;z-index:2}.checkin-popup-emoji{font-size:56px;line-height:1;margin-bottom:16px;animation:emojiPop .6s .2s cubic-bezier(.34,1.56,.64,1) both}.checkin-popup-title{font-size:22px;font-weight:800;color:#1e293b;margin-bottom:6px;animation:slideUp .4s .15s ease both}.checkin-popup.checkin .checkin-popup-title{color:#059669}.checkin-popup.checkout .checkin-popup-title{color:#7c3aed}.checkin-popup-time{display:inline-block;background:#f1f5f9;color:#475569;font-size:15px;font-weight:700;font-family:SF Mono,Fira Code,monospace;padding:6px 16px;border-radius:20px;margin-bottom:14px;letter-spacing:.5px;animation:slideUp .4s .25s ease both}.checkin-popup-quote{font-size:15px;color:#64748b;line-height:1.6;margin-bottom:24px;animation:slideUp .4s .35s ease both}.checkin-popup-btn{animation:slideUp .4s .45s ease both;font-size:15px;padding:10px 28px;border-radius:10px}.checkin-popup.checkin .checkin-popup-btn{background:linear-gradient(135deg,#10b981,#059669)}.checkin-popup.checkout .checkin-popup-btn{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.checkin-popup-btn:hover{transform:scale(1.04)}@keyframes popBounce{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}@keyframes emojiPop{0%{transform:scale(0) rotate(-20deg);opacity:0}60%{transform:scale(1.3) rotate(5deg)}to{transform:scale(1) rotate(0);opacity:1}}@keyframes slideUp{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.chat-fab{position:fixed;bottom:24px;right:24px;z-index:900;width:56px;height:56px;border-radius:50%;border:none;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #2563eb66;transition:transform .2s,box-shadow .2s}.chat-fab:hover{transform:scale(1.1);box-shadow:0 6px 24px #2563eb80}.chat-window{position:fixed;bottom:24px;right:24px;z-index:1000;width:380px;max-height:520px;background:#fff;border-radius:16px;box-shadow:0 8px 40px #0000002e;display:flex;flex-direction:column;overflow:hidden;animation:chat-slide-up .25s ease-out}@keyframes chat-slide-up{0%{opacity:0;transform:translateY(16px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.chat-header{background:linear-gradient(135deg,#1e293b,#334155);color:#fff;padding:14px 18px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.chat-avatar{width:34px;height:34px;border-radius:50%;background:#ffffff26;display:flex;align-items:center;justify-content:center}.chat-close{background:#ffffff1a;border:none;color:#fff;width:30px;height:30px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.chat-close:hover{background:#fff3}.chat-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px;background:#f8fafc;min-height:280px;max-height:340px}.chat-msg{display:flex}.chat-msg.user{justify-content:flex-end}.chat-msg.bot{justify-content:flex-start}.chat-bubble{max-width:80%;padding:10px 14px;border-radius:14px;font-size:13px;line-height:1.5;word-break:break-word}.chat-bubble.bot{background:#fff;color:#1e293b;border:1px solid #e2e8f0;border-bottom-left-radius:4px}.chat-bubble.user{background:#2563eb;color:#fff;border-bottom-right-radius:4px}.chat-typing{display:flex;align-items:center;gap:4px;padding:12px 18px}.chat-typing span{width:7px;height:7px;border-radius:50%;background:#94a3b8;animation:chat-dot 1.2s infinite}.chat-typing span:nth-child(2){animation-delay:.2s}.chat-typing span:nth-child(3){animation-delay:.4s}@keyframes chat-dot{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-4px);opacity:1}}.chat-input{padding:12px;border-top:1px solid #e2e8f0;display:flex;gap:8px;background:#fff;flex-shrink:0}.chat-input input{flex:1;padding:10px 14px;border:1.5px solid #e2e8f0;border-radius:10px;font-size:13px;outline:none;transition:border-color .15s}.chat-input input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb14}.chat-send{width:40px;height:40px;border-radius:10px;border:none;background:#2563eb;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;flex-shrink:0}.chat-send:hover{background:#1d4ed8}.chat-send:disabled{background:#94a3b8;cursor:not-allowed}@media (max-width: 440px){.chat-window{width:calc(100vw - 16px);right:8px;bottom:8px;max-height:calc(100vh - 16px)}.chat-fab{bottom:16px;right:16px}}
