:root{--bg-color:#0f172a;--card-bg:#ffffff08;--card-border:#ffffff14;--text-primary:#f8fafc;--text-secondary:#94a3b8;--accent-primary:#8b5cf6;--accent-secondary:#ec4899;--accent-hover:#7c3aed;--tab-inactive:#ffffff0d;--tab-active:#8b5cf633;--blob-1:#8b5cf6;--blob-2:#ec4899}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);color:var(--text-primary);justify-content:center;align-items:center;min-height:100vh;font-family:Outfit,sans-serif;display:flex;position:relative;overflow:hidden}.container{z-index:10;width:100%;max-width:500px;padding:20px}.glass-card{background:var(--card-bg);-webkit-backdrop-filter:blur(20px);border:1px solid var(--card-border);border-radius:24px;flex-direction:column;gap:32px;padding:40px;transition:transform .3s,box-shadow .3s;display:flex;box-shadow:0 25px 50px -12px #00000080}.glass-card:hover{transform:translateY(-5px);box-shadow:0 30px 60px -12px #0009}header{text-align:center}h1{background:linear-gradient(135deg,#fff,#cbd5e1);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:8px;font-size:2rem;font-weight:700}header p{color:var(--text-secondary);font-size:.95rem}.tabs{background:#0003;border-radius:12px;padding:6px;display:flex;position:relative}.tab-btn{color:var(--text-secondary);cursor:pointer;z-index:2;background:0 0;border:none;border-radius:8px;flex:1;padding:12px 0;font-family:inherit;font-size:.95rem;font-weight:500;transition:all .3s}.tab-btn:hover{color:var(--text-primary)}.tab-btn.active{color:var(--text-primary);background:var(--tab-active);border:1px solid #8b5cf64d;box-shadow:0 4px 15px #0000001a}.content{flex-direction:column;gap:24px;display:flex}.number-display{text-align:center;box-sizing:border-box;background:#0000004d;border:1px solid #ffffff0d;border-radius:16px;justify-content:center;align-items:center;height:172px;min-height:172px;max-height:172px;padding:24px 20px;display:flex;position:relative;overflow:hidden}.number-display>div{justify-content:center;align-items:center;width:100%;height:100%;min-height:0;display:flex;overflow:hidden}.number-display:before{content:"";background:linear-gradient(90deg, transparent, var(--accent-primary), transparent);opacity:0;pointer-events:none;height:2px;transition:opacity .3s;position:absolute;top:0;left:0;right:0}.number-display.highlight:before{opacity:1}.placeholder-text{color:var(--text-secondary);font-size:.95rem;font-style:italic;transition:opacity .3s}.phone-number{letter-spacing:1px;color:#fff;text-shadow:0 0 20px #8b5cf680;opacity:0;cursor:pointer;width:100%;font-size:1.8rem;font-weight:700;transition:color .3s;animation:.4s forwards fadeInUp;display:block;position:relative;transform:translateY(10px)}.phone-number:hover{color:#e2e8f0}.phone-digits{text-align:center;box-sizing:border-box;padding:0 2.25rem;display:block}.phone-number .copy-icon{opacity:0;color:var(--accent-primary);flex-shrink:0;transition:opacity .3s,transform .3s;position:absolute;top:50%;right:0;transform:translateY(-50%)}.phone-number:hover .copy-icon{opacity:1;transform:translateY(-50%)scale(1.1)}.phone-display-stack{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:10px;width:100%;max-height:100%;display:flex;overflow:hidden}.officer-name-below{color:var(--text-secondary);opacity:0;word-break:break-word;text-align:center;width:100%;max-width:100%;padding:0 8px;font-size:.95rem;font-weight:500;line-height:1.3;animation:.45s 60ms forwards fadeInUp;transform:translateY(8px)}@keyframes fadeInUp{to{opacity:1;transform:translateY(0)}}.action-btn{background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));color:#fff;cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:12px;padding:16px;font-family:inherit;font-size:1.1rem;font-weight:600;transition:all .3s;display:flex;position:relative;overflow:hidden;box-shadow:0 10px 20px -10px #8b5cf680}.action-btn:after{content:"";opacity:0;pointer-events:none;background:linear-gradient(135deg,#fff3,#0000);width:100%;height:100%;transition:opacity .3s;position:absolute;top:0;left:0}.action-btn:hover{transform:translateY(-2px);box-shadow:0 15px 25px -10px #8b5cf699}.action-btn:hover:after{opacity:1}.action-btn:active{transform:translateY(1px)}.btn-icon{transition:transform .3s}.action-btn:hover .btn-icon{transform:rotate(15deg)scale(1.1)}.fade-out{opacity:0;transition:all .2s;transform:translateY(-10px)}.loading{border:3px solid #ffffff1a;border-top-color:#fff;border-radius:50%;width:24px;height:24px;animation:1s ease-in-out infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width:480px){.glass-card{padding:30px 20px}.number-display{height:156px;min-height:156px;max-height:156px;padding:20px 16px}.phone-number{font-size:1.4rem}.phone-digits{padding:0 1.85rem}}@font-face{font-family:KhmerHeading;src:url(/heading-font.ttf)format("truetype");font-weight:400;font-style:normal}@font-face{font-family:KhmerBody;src:url(/body-font.ttf)format("truetype");font-weight:400;font-style:normal}body.lang-kh h1,body.lang-kh .action-btn,body.lang-kh .phone-number,body.lang-kh .phone-digits,body.lang-kh .officer-name-below{font-family:KhmerHeading,sans-serif!important;font-weight:400!important}body.lang-kh,body.lang-kh p,body.lang-kh .tab-btn,body.lang-kh .placeholder-text{font-family:KhmerBody,sans-serif!important;font-weight:400!important}.card-top-bar{z-index:5;justify-content:space-between;align-items:center;margin-bottom:-16px;display:flex;position:relative}.branding{align-items:center;display:flex}.branding .logo-text{letter-spacing:1.5px;background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-family:Outfit,sans-serif;font-size:1.2rem;font-weight:800}.lang-toggle{align-items:center;gap:8px;display:flex}.lang-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;font-family:inherit;font-size:.9rem;font-weight:600;transition:color .3s}.lang-btn.active{color:var(--accent-primary)}.lang-btn:hover{color:var(--text-primary)}.lang-toggle .divider{color:var(--card-border);font-size:.8rem}.glass-card.sunday-mode{--accent-primary:#f59e0b;--accent-secondary:#fb923c;--accent-hover:#d97706;border-color:#f59e0b40;box-shadow:0 25px 50px -12px #00000080,0 0 0 1px #f59e0b1a}.sunday-badge{color:#f59e0b;letter-spacing:.04em;text-transform:uppercase;background:#f59e0b1f;border:1px solid #f59e0b59;border-radius:20px;align-items:center;gap:5px;margin-top:10px;padding:4px 12px;font-size:.78rem;font-weight:700;display:inline-flex}.toast{color:#fff;opacity:0;pointer-events:none;white-space:nowrap;-webkit-backdrop-filter:blur(10px);background:#8b5cf6f2;border:1px solid #ffffff1a;border-radius:50px;padding:12px 28px;font-size:.95rem;font-weight:500;transition:all .4s cubic-bezier(.175,.885,.32,1.275);position:fixed;bottom:40px;left:50%;transform:translate(-50%)translateY(100px);box-shadow:0 10px 25px #8b5cf680}.toast.show{opacity:1;transform:translate(-50%)translateY(0)}.copy-hint{text-align:center;color:var(--text-secondary);opacity:0;visibility:hidden;margin-top:-16px;margin-bottom:-8px;font-size:.85rem;font-style:italic;transition:opacity .3s,visibility .3s}.copy-hint.visible{opacity:1;visibility:visible}.input-field{border:1px solid var(--card-border);width:100%;color:var(--text-primary);background:#0003;border-radius:8px;outline:none;padding:12px 16px;font-family:inherit;font-size:1rem;transition:border-color .3s}.input-field:focus{border-color:var(--accent-primary)}.qr-wrapper{-webkit-backdrop-filter:blur(10px);text-align:center;background:linear-gradient(135deg,#ffffff1a,#fff0);border:1px solid #ffffff2e;border-radius:24px;flex-direction:column;justify-content:center;align-items:center;padding:30px;display:flex;position:relative;overflow:hidden;box-shadow:0 8px 32px #0000005e}.qr-inner-canvas{z-index:2;background:#fff;border-radius:16px;margin-bottom:20px;padding:20px;position:relative;box-shadow:0 10px 25px #0003}.qr-inner-canvas img{width:220px;height:220px;display:block}.qr-text{z-index:2;background:#0f172ab3;border:1px solid #ffffff1a;border-radius:16px;margin-top:5px;padding:15px 30px;position:relative}.qr-text h2{color:#fff;margin-bottom:5px;font-size:1.6rem;font-weight:700}.qr-text p{color:#cbd5e1;max-width:250px;margin:0 auto;font-size:.95rem}.orb{filter:blur(40px);z-index:1;opacity:.6;border-radius:50%;position:absolute}.orb-1{background:var(--accent-primary);width:150px;height:150px;top:-50px;left:-50px}.orb-2{background:var(--accent-secondary);width:150px;height:150px;bottom:-50px;right:-50px}.download-btn{width:100%;margin-top:30px}body.admin-layout{align-items:unset;justify-content:unset;display:block;overflow:auto}body.admin-layout main.container{width:100%;max-width:100%;padding:0}.admin-auth-screen{box-sizing:border-box;justify-content:center;align-items:center;width:100%;min-height:100vh;padding:24px;display:flex}.admin-shell{z-index:10;min-height:100vh;display:flex;position:relative}.admin-sidebar{border-right:1px solid var(--card-border);-webkit-backdrop-filter:blur(20px);background:#ffffff08;flex-direction:column;flex-shrink:0;width:220px;height:100vh;padding:24px 0 16px;transition:width .22s;display:flex;position:sticky;top:0;overflow:hidden}.admin-shell.sidebar-collapsed .admin-sidebar{width:60px}.sidebar-brand{border-bottom:1px solid var(--card-border);flex-direction:column;align-items:flex-start;gap:2px;margin-bottom:12px;padding:0 20px 20px;display:flex;position:relative}.admin-shell.sidebar-collapsed .sidebar-brand{align-items:center;padding:0 0 20px}.sidebar-collapse-btn{border:1px solid var(--card-border);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:6px;justify-content:center;align-self:flex-end;align-items:center;margin-top:8px;padding:4px 6px;transition:background .15s;display:flex}.admin-shell.sidebar-collapsed .sidebar-collapse-btn{align-self:center;margin-top:0}.sidebar-collapse-btn:hover{color:var(--text-primary);background:#ffffff12}.sidebar-nav{flex-direction:column;flex:1;gap:4px;padding:0 8px;display:flex}.sidebar-item{color:var(--text-secondary);cursor:pointer;text-align:left;white-space:nowrap;background:0 0;border:none;border-radius:10px;align-items:center;gap:10px;width:100%;padding:10px 14px;font-family:inherit;font-size:.9rem;transition:all .2s;display:flex}.admin-shell.sidebar-collapsed .sidebar-item{justify-content:center;padding:10px}.sidebar-item:hover{color:var(--text-primary);background:#ffffff0d}.sidebar-item.active{color:#fff;background:#8b5cf62e;border:1px solid #8b5cf64d;font-weight:600}.sidebar-item.active svg{stroke:#fff}.sidebar-item.logout{color:#f87171}.sidebar-item.logout:hover{background:#f871711a}.sidebar-footer{border-top:1px solid var(--card-border);flex-direction:column;gap:4px;padding:12px 8px 0;display:flex}.sidebar-view-site{min-width:0}.sidebar-newtab-icon{opacity:.65;flex-shrink:0}.sidebar-view-site:hover{color:var(--text-primary)!important}.sidebar-view-site:hover .sidebar-newtab-icon{opacity:1}.admin-main{flex-direction:column;flex:1;display:flex;overflow:auto}.admin-topbar{border-bottom:1px solid var(--card-border);background:#ffffff03;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:24px 32px 20px;display:flex}.admin-page-title{background:linear-gradient(135deg,#fff,#cbd5e1);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:4px;font-size:1.4rem;font-weight:700}.admin-page-sub{color:var(--text-secondary);font-size:.85rem}.admin-add-btn{background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:10px;padding:10px 18px;font-family:inherit;font-size:.9rem;font-weight:600;transition:all .2s}.admin-add-btn:hover{opacity:.88;transform:translateY(-1px)}.admin-content-area{flex:1;padding:28px 32px}.tables-grid{grid-template-columns:1fr 1fr;gap:24px;display:grid}@media (max-width:860px){.tables-grid{grid-template-columns:1fr}}.table-block{border:1px solid var(--card-border);-webkit-overflow-scrolling:touch;background:#ffffff08;border-radius:16px;overflow-x:auto}.table-header-row{border-bottom:1px solid var(--card-border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.table-title{color:var(--text-primary);font-size:.95rem;font-weight:600}.team-badge{color:var(--accent-primary);background:#8b5cf626;border:1px solid #8b5cf640;border-radius:20px;padding:3px 10px;font-size:.75rem;font-weight:600}.officer-table{border-collapse:collapse;width:100%;min-width:max-content}.officer-table th{text-align:left;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;vertical-align:middle;background:#0000001a;padding:10px 20px;font-size:.75rem;font-weight:600}.officer-table td{border-top:1px solid var(--card-border);color:var(--text-primary);white-space:nowrap;vertical-align:middle;padding:12px 20px;font-size:.9rem}.officer-table tr:hover td{background:#ffffff05}.phone-chip{border:1px solid var(--card-border);letter-spacing:.5px;background:#00000040;border-radius:6px;padding:3px 10px;font-family:monospace;font-size:.85rem}.delete-btn{color:#f87171;cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;padding:6px;transition:background .2s;display:flex}.delete-btn:hover{background:#f871711f}.status-toggle{cursor:pointer;border:1px solid var(--card-border);color:var(--text-secondary);background:0 0;border-radius:20px;padding:4px 14px;font-family:inherit;font-size:.8rem;font-weight:600;transition:all .2s}.status-toggle.active{color:#10b981;background:#10b98126;border-color:#10b98166}.status-toggle:not(.active):hover{background:#ffffff0d}.table-empty{text-align:center;color:var(--text-secondary);padding:32px 20px;font-size:.9rem;font-style:italic}.admin-loading{min-height:100vh;color:var(--text-secondary);justify-content:center;align-items:center;gap:10px;font-size:1rem;display:flex}.admin-loading-inline{text-align:center;color:var(--text-secondary);padding:48px}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-box{border:1px solid var(--card-border);background:#1e293b;border-radius:18px;width:100%;max-width:400px;padding:28px;box-shadow:0 25px 60px #00000080}.sunday-assign-btn{color:#fbbf24;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #fbbf244d;border-radius:6px;padding:4px 10px;font-family:inherit;font-size:.78rem;font-weight:600;transition:background .2s}.sunday-assign-btn:hover{background:#fbbf241f}.officer-sunday-sched-cell{vertical-align:middle}.sunday-sched-view-btn{color:var(--accent-primary);cursor:pointer;white-space:nowrap;background:#8b5cf61a;border:1px solid #8b5cf659;border-radius:8px;flex-shrink:0;align-items:center;gap:6px;padding:5px 11px;font-family:inherit;font-size:.78rem;font-weight:600;transition:background .15s,border-color .15s;display:inline-flex}.sunday-sched-view-btn:hover{background:#8b5cf62e;border-color:#8b5cf680}.sunday-sched-view-badge{background:var(--accent-primary);color:#fff;text-align:center;border-radius:999px;min-width:18px;height:18px;padding:0 5px;font-size:.68rem;font-weight:700;line-height:18px}.sunday-sched-view-modal{max-width:400px}.sunday-sched-view-list{flex-direction:column;gap:6px;max-height:min(52vh,340px);margin-bottom:16px;display:flex;overflow-y:auto}.sunday-sched-view-row{border:1px solid var(--card-border);color:var(--text-primary);background:#ffffff08;border-radius:8px;justify-content:space-between;align-items:center;gap:12px;padding:10px 14px;font-size:.88rem;font-weight:500;display:flex}.sunday-sched-view-date{flex:1;min-width:0;line-height:1.35}.sunday-sched-unassign{color:#f87171;cursor:pointer;background:#f871711f;border:1px solid #f8717173;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;min-width:88px;padding:6px 12px;font-family:inherit;font-size:.75rem;font-weight:600;transition:background .15s;display:inline-flex}.sunday-sched-unassign:hover:not(:disabled){background:#f8717138}.sunday-sched-unassign:disabled{opacity:.55;cursor:not-allowed}.sunday-sched-unassign .btn-spinner{border-width:2px;width:14px;height:14px}.sunday-sched-view-empty{text-align:center;color:var(--text-secondary);border:1px dashed var(--card-border);border-radius:8px;padding:20px;font-size:.85rem}.sunday-sched-view-close{border:1px solid var(--card-border);width:100%;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:10px;padding:10px;font-family:inherit;font-size:.85rem;font-weight:600}.sunday-sched-view-close:hover{color:var(--text-primary);background:#ffffff0d}.th-tight{white-space:nowrap;color:var(--text-secondary);font-size:.78rem;font-weight:600}.modal-title{color:var(--text-primary);margin-bottom:8px;font-size:1.1rem;font-weight:700}.modal-sub{color:var(--text-secondary);margin-bottom:16px;font-size:.85rem}.sunday-assign-modal{width:100%;max-width:420px}.sunday-assign-actions{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-top:14px;display:flex}.sunday-assign-actions-trailing{align-items:center;gap:8px;margin-left:auto;display:flex}.sunday-assign-modal .sunday-btn{cursor:pointer;white-space:nowrap;border-radius:8px;padding:7px 12px;font-family:inherit;font-size:.78rem;font-weight:600;transition:background .15s,border-color .15s,opacity .15s}.sunday-assign-modal .sunday-btn:disabled{opacity:.45;cursor:not-allowed}.sunday-assign-modal .sunday-btn-clear{color:var(--text-secondary);background:0 0;border:1px dashed #fff3;padding:7px 10px;font-weight:500}.sunday-assign-modal .sunday-btn-clear:not(:disabled):hover{color:var(--text-primary);background:#ffffff0f;border-color:#ffffff47}.sunday-assign-modal .sunday-btn-cancel{border:1px solid var(--card-border);color:var(--text-secondary);background:0 0}.sunday-assign-modal .sunday-btn-cancel:not(:disabled):hover{color:var(--text-primary);background:#ffffff0d}.sunday-assign-modal .sunday-btn-assign{background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));color:#fff;border:none;justify-content:center;align-items:center;min-width:100px;display:inline-flex;box-shadow:0 4px 12px -4px #8b5cf68c}.sunday-assign-modal .sunday-btn-assign:not(:disabled):hover{filter:brightness(1.06)}.sunday-assign-modal .sunday-btn-assign .btn-spinner{border-width:2px;width:14px;height:14px}.sunday-date-list{flex-direction:column;gap:6px;max-height:340px;padding-right:4px;display:flex;overflow-y:auto}.sunday-date-row{border:1px solid var(--card-border);cursor:pointer;text-align:left;background:0 0;border-radius:8px;justify-content:space-between;align-items:center;padding:10px 14px;font-family:inherit;transition:background .15s,border-color .15s;display:flex}.sunday-date-row:hover{background:#8b5cf614}.sunday-date-row.selected{border-color:var(--accent-primary);background:#8b5cf626}.sunday-date-row.self-assigned{border-color:#fbbf2466}.sunday-date-row.occupied-by-other{opacity:.48;background:#6b72801f;border-color:#6b728040}.sunday-date-row.occupied-by-other .sunday-date-label{color:var(--text-secondary)}.sunday-date-row.occupied-by-other .sunday-date-assignee{color:#9ca3af;background:#6b728026}.sunday-date-row.occupied-by-other:hover{background:#6b72802e}.sunday-date-row.occupied-by-other.selected{opacity:1;border-color:var(--accent-primary);background:#8b5cf626}.sunday-date-row.occupied-by-other.selected .sunday-date-label{color:var(--text-primary)}.sunday-date-row.occupied-by-other.selected .sunday-date-assignee{color:var(--text-secondary);background:#ffffff0f}.sunday-date-check{flex-shrink:0;align-items:center;margin-right:10px;display:flex}.custom-checkbox{background:0 0;border:2px solid #8b5cf666;border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;transition:background .15s,border-color .15s;display:flex}.custom-checkbox.checked{background:var(--accent-primary);border-color:var(--accent-primary);box-shadow:0 0 0 3px #8b5cf633}.sunday-modal-sub{color:var(--text-secondary);justify-content:space-between;align-items:center;gap:10px;margin-bottom:16px;font-size:.85rem;display:flex}.sunday-selected-count{color:var(--accent-primary);white-space:nowrap;letter-spacing:.02em;background:#8b5cf62e;border:1px solid #8b5cf64d;border-radius:20px;padding:3px 10px;font-size:.78rem;font-weight:700}.sunday-date-label{color:var(--text-primary);flex:1;font-size:.9rem;font-weight:600}.sunday-date-assignee{color:var(--text-secondary);background:#ffffff0f;border-radius:5px;padding:2px 8px;font-size:.8rem}.sunday-date-assignee.self{color:#fbbf24;background:#fbbf241f}.sunday-date-free{color:#6b7280;font-size:.78rem}.sunday-date-badge{color:#fbbf24;background:#fbbf241a;border:1px solid #fbbf2440;border-radius:5px;padding:2px 8px;font-size:.8rem;font-weight:600}.btn-spinner{vertical-align:middle;border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.6s linear infinite btn-spin;display:inline-block}@keyframes btn-spin{to{transform:rotate(360deg)}}.row-menu-wrap{display:inline-block;position:relative}.row-menu-btn{cursor:pointer;background:0 0;border:none;border-radius:6px;flex-direction:column;justify-content:center;align-items:center;gap:3px;width:28px;height:28px;padding:0;transition:background .15s;display:flex}.row-menu-btn:hover{background:#ffffff14}.row-menu-btn span{background:var(--text-secondary);border-radius:50%;width:4px;height:4px;display:block}.row-menu-dropdown{border:1px solid var(--card-border);z-index:100;background:#1e1e2e;border-radius:8px;min-width:110px;position:absolute;top:calc(100% + 4px);right:0;overflow:hidden;box-shadow:0 8px 24px #0006}.row-menu-dropdown button{text-align:left;width:100%;color:var(--text-primary);cursor:pointer;background:0 0;border:none;padding:9px 14px;font-family:inherit;font-size:.85rem;transition:background .12s;display:block}.row-menu-dropdown button:hover{background:#ffffff0f}.row-menu-dropdown button.danger{color:#f87171}.row-menu-dropdown button.danger:hover{background:#f871711a}
