*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{overscroll-behavior:none;overflow-x:hidden}html,body,.app-shell,.app-content,.page{touch-action:pan-y;-ms-touch-action:pan-y}:root{--primary:#1e3a5f;--primary-light:#2a5080;--primary-50:#eef4fb;--accent:#f59e0b;--accent-light:#fef3c7;--danger:#ef4444;--success:#22c55e;--success-light:#dcfce7;--bg:#f0f4f8;--card:#fff;--text:#1a1a2e;--muted:#6b7280;--border:#e2e8f0;--radius:14px;--radius-sm:10px;--nav-height:68px;--header-height:56px}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;overscroll-behavior:none;width:100%;height:100dvh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow-x:hidden}.loading-screen{color:#fff;background:linear-gradient(135deg,#0a4da2 0%,#06a0c4 100%);flex-direction:column;justify-content:center;align-items:center;gap:16px;height:100dvh;display:flex}.loading-icon{opacity:.8}.spinner{border:3px solid #fff3;border-top-color:#fff;border-radius:50%;width:36px;height:36px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.app-shell{background:var(--bg);flex-direction:column;max-width:480px;height:100dvh;margin:0 auto;display:flex;overflow-x:hidden}.app-content{padding-bottom:var(--nav-height);padding-top:calc(var(--header-height) + env(safe-area-inset-top,0px));-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;flex:1;overflow-y:auto}.app-header{width:100%;max-width:480px;height:calc(var(--header-height) + env(safe-area-inset-top,0px));color:#fff;padding:env(safe-area-inset-top,0px) 16px 0 16px;z-index:100;background:linear-gradient(135deg,#0a4da2 0%,#06a0c4 100%);justify-content:space-between;align-items:center;display:flex;position:fixed;top:0;left:50%;transform:translate(-50%)}.app-header-brand{align-items:center;gap:8px;display:flex}.app-header-title{letter-spacing:-.3px;font-size:18px;font-weight:700}.app-header-meta{align-items:center;gap:8px;display:flex}.app-header-station{background:#ffffff26;border-radius:20px;padding:4px 12px;font-size:13px;font-weight:600}.bottom-nav{width:100%;max-width:480px;height:var(--nav-height);background:var(--card);border-top:1px solid var(--border);padding-bottom:env(safe-area-inset-bottom,0);z-index:100;justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%);box-shadow:0 -2px 10px #0000000a}.nav-item{color:var(--muted);cursor:pointer;background:0 0;border:none;flex-direction:column;flex:1;align-items:center;gap:2px;min-width:0;padding:8px 4px;font-size:10px;font-weight:500;transition:color .2s;display:flex}.nav-item.active{color:var(--primary)}.nav-spacer{flex:1;min-width:0}.nav-fab{color:#fff;border:4px solid var(--bg);cursor:pointer;z-index:10;background:linear-gradient(135deg,#0a4da2 0%,#06a0c4 100%);border-radius:50%;justify-content:center;align-items:center;width:54px;height:54px;transition:transform .2s,background .2s;display:flex;position:absolute;top:-24px;left:50%;transform:translate(-50%);box-shadow:0 4px 16px #1e3a5f66}.nav-fab.active{background:var(--accent);transform:translate(-50%)scale(1.05)}.nav-fab-right{background:var(--primary);color:#fff;border:3px solid var(--bg);cursor:pointer;z-index:10;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;transition:transform .2s,background .2s;display:flex;position:absolute;top:-20px;right:16px;box-shadow:0 2px 10px #1e3a5f4d}.nav-fab-right.active{background:var(--accent);transform:scale(1.05)}.notif-bell{color:#fff;cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:6px;transition:background .15s;display:flex;position:relative}.notif-bell:hover{background:#ffffff26}.notif-badge{background:var(--danger);color:#fff;border-radius:8px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 4px;font-size:10px;font-weight:700;display:flex;position:absolute;top:0;right:0}.notif-overlay{z-index:200;background:#0006;justify-content:center;display:flex;position:fixed;inset:0}.notif-panel{top:var(--header-height);background:var(--card);border-radius:0 0 var(--radius) var(--radius);flex-direction:column;width:100%;max-width:440px;max-height:70vh;display:flex;position:absolute;overflow:hidden;box-shadow:0 8px 32px #00000026}.notif-panel-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.notif-panel-header h3{font-size:16px;font-weight:700}.notif-panel-actions{align-items:center;gap:8px;display:flex}.notif-mark-all{color:var(--primary);cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;gap:4px;padding:4px 8px;font-size:12px;font-weight:600;display:inline-flex}.notif-mark-all:hover{background:var(--primary-50)}.notif-clear-all{color:var(--danger);cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;gap:4px;padding:4px 8px;font-size:12px;font-weight:600;display:inline-flex}.notif-clear-all:hover{background:#ef44441a}.notif-close{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px;display:flex}.notif-close:hover{background:var(--bg)}.notif-list{flex:1;overflow-y:auto}.notif-empty{color:var(--muted);flex-direction:column;align-items:center;gap:8px;padding:40px 20px;display:flex}.notif-empty-icon{opacity:.3}.notif-item{border-bottom:1px solid var(--border);cursor:pointer;align-items:flex-start;gap:12px;padding:14px 16px;transition:background .15s;display:flex}.notif-item.unread{background:var(--primary-50)}.notif-item:hover{background:var(--bg)}.notif-icon{background:var(--bg);width:34px;height:34px;color:var(--primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.notif-icon.shift_grabbed{color:#92400e;background:#fef3c7}.notif-icon.grab_confirmed{background:var(--success-light);color:#166534}.notif-content{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.notif-title{color:var(--text);font-size:13px;font-weight:700}.notif-message{color:var(--muted);font-size:12px;line-height:1.4}.notif-time{color:#b0bec5;margin-top:2px;font-size:11px}.notif-unread-dot{background:linear-gradient(135deg,#0a4da2 0%,#06a0c4 100%);border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:4px}.app-footer{color:#b0bec5;flex-direction:column;align-items:center;gap:2px;padding:24px 16px 32px;font-size:12px;font-weight:500;display:flex}.page{padding:16px}.page-header{color:var(--primary);align-items:center;gap:10px;margin-bottom:20px;display:flex}.page-header h2{flex:1;font-size:20px}.dashboard{padding:0}.dash-hero{color:#fff;background:linear-gradient(135deg,#0a4da2 0%,#065a80 100%);padding:24px 20px 28px}.dash-greeting{opacity:.8;font-size:14px}.dash-name{margin:2px 0 10px;font-size:26px;font-weight:700}.dash-team{opacity:.7;align-items:center;gap:6px;font-size:13px;display:flex}.dash-stats{z-index:1;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:-20px;padding:0 16px;display:grid;position:relative}.dash-stat-card{background:var(--card);border-radius:var(--radius);text-align:center;cursor:pointer;border:1px solid var(--border);padding:16px 12px;transition:transform .2s;box-shadow:0 2px 12px #0000000f}.dash-stat-card:active{transform:scale(.97)}.dash-stat-icon{border-radius:12px;justify-content:center;align-items:center;width:40px;height:40px;margin:0 auto 8px;display:flex}.dash-stat-icon.open{background:var(--primary-50);color:var(--primary)}.dash-stat-icon.urgent{color:var(--danger);background:#fef2f2}.dash-stat-icon.post{background:var(--success-light);color:var(--success)}.inbox-unread-badge{background:var(--danger);color:#fff;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 4px;font-size:10px;font-weight:700;line-height:1;display:flex;position:absolute;top:-6px;right:-6px;box-shadow:0 1px 3px #0003}.dash-stat-num{color:var(--text);font-size:22px;font-weight:800;display:block}.dash-stat-label{color:var(--muted);font-size:12px;font-weight:500}.dash-section{padding:20px 16px}.dash-section-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.dash-section-header h3{font-size:17px;font-weight:700}.dash-see-all{color:var(--primary);cursor:pointer;background:0 0;border:none;align-items:center;gap:4px;font-size:13px;font-weight:600;display:flex}.dash-empty{text-align:center;background:var(--card);border-radius:var(--radius);border:1px solid var(--border);padding:32px 20px}.dash-empty p{color:var(--muted);margin-bottom:16px}.btn-sm{width:auto;padding:10px 20px;font-size:14px;display:inline-flex}.dash-shift-list{flex-direction:column;gap:8px;display:flex}.dash-shift-item{background:var(--card);border-radius:var(--radius-sm);border:1px solid var(--border);cursor:pointer;align-items:center;gap:14px;padding:12px 14px;transition:border-color .2s;display:flex}.dash-shift-item:active{border-color:var(--primary)}.dash-shift-item.urgent{border-left:3px solid var(--danger)}.dash-shift-date-col{flex-direction:column;align-items:center;min-width:40px;display:flex}.dash-shift-day{color:var(--primary);font-size:20px;font-weight:800;line-height:1}.dash-shift-month{color:var(--muted);text-transform:uppercase;font-size:11px;font-weight:600}.dash-shift-info{flex:1;min-width:0}.dash-shift-title{color:var(--text);font-size:14px;font-weight:600;display:block}.dash-shift-by{color:var(--muted);margin-top:2px;font-size:12px;display:block}.dash-shift-type{color:#fff;border-radius:6px;flex-shrink:0;padding:3px 8px;font-size:11px;font-weight:700}.board-tabs{background:var(--card);border-radius:var(--radius-sm);border:1px solid var(--border);gap:4px;margin-bottom:16px;padding:4px;display:flex}.board-tab{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:6px;padding:10px;font-size:14px;font-weight:600;transition:all .2s;display:flex}.board-tab.active{color:#fff;background:linear-gradient(135deg,#0a4da2 0%,#06a0c4 100%)}.board-tab-count{background:#0000001a;border-radius:10px;padding:1px 7px;font-size:12px;font-weight:700}.board-tab.active .board-tab-count{background:#fff3}.board-filter-btn{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;padding:8px 10px;display:flex}.board-filter-btn.active{background:var(--accent-light);color:#92400e}.grabbed-toggle{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);gap:4px;margin-bottom:12px;padding:3px;display:flex}.grabbed-toggle-btn{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:6px;flex:1;justify-content:center;align-items:center;gap:5px;padding:8px 12px;font-size:13px;font-weight:600;transition:all .2s;display:flex}.grabbed-toggle-btn.active{background:var(--primary);color:#fff}.board-filters{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:12px;padding:12px;animation:.15s fadeSlideDown}.board-filter-row{gap:8px;margin-bottom:8px;display:flex}.board-filter-row:last-child{margin-bottom:0}.board-filter-row select,.board-filter-row input{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:8px;flex:1;padding:8px 10px;font-size:13px}.board-clear-btn{border:1px solid var(--border);background:var(--bg);color:var(--muted);cursor:pointer;white-space:nowrap;border-radius:8px;align-items:center;gap:4px;padding:8px 12px;font-size:12px;font-weight:600;display:inline-flex}.clear-past-grabbed-btn{border:1px solid var(--danger);color:var(--danger);cursor:pointer;background:#ef444414;border-radius:8px;justify-content:center;align-items:center;gap:6px;width:100%;margin-bottom:12px;padding:8px 14px;font-size:13px;font-weight:600;display:inline-flex}.clear-past-grabbed-btn:active{background:#ef444426}.board-filter-tag{color:var(--primary);background:var(--primary-50);text-align:center;border-radius:8px;margin-bottom:10px;padding:6px 12px;font-size:12px;font-weight:600}.profile-quick-actions{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px;overflow:hidden}.profile-action-btn{border:none;border-bottom:1px solid var(--border);width:100%;color:var(--text);cursor:pointer;text-align:left;background:0 0;align-items:center;gap:12px;padding:14px 16px;font-size:14px;font-weight:500;display:flex}.profile-action-btn:last-child{border-bottom:none}.profile-action-btn span{flex:1}.profile-action-btn:hover{background:var(--bg)}.auth-container{background:linear-gradient(135deg,#0a4da2 0%,#06a0c4 100%);justify-content:center;align-items:flex-start;min-height:100dvh;padding:60px 20px 20px;display:flex;overflow-y:auto}.auth-card{background:var(--card);border-radius:var(--radius);width:100%;max-width:400px;padding:32px 24px;box-shadow:0 20px 60px #0000004d}.auth-logo{text-align:center;color:var(--primary);flex-direction:column;align-items:center;margin-bottom:24px;display:flex}.auth-logo h1{margin-top:8px;font-size:24px}.auth-subtitle{color:var(--muted);margin-top:4px;font-size:13px}.forgot-password{text-align:center;margin-top:12px}.forgot-password button{color:var(--muted);cursor:pointer;background:0 0;border:none;font-size:13px;text-decoration:underline}.forgot-password button:hover{color:var(--primary)}.auth-toggle{text-align:center;color:var(--muted);margin-top:16px;font-size:14px}.auth-toggle button{color:var(--primary);cursor:pointer;background:0 0;border:none;font-weight:600;text-decoration:underline}.form-group{margin-bottom:16px}.form-group label{color:var(--text);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.form-group input,.form-group select,.form-group textarea{border:1.5px solid var(--border);background:var(--bg);width:100%;color:var(--text);border-radius:8px;padding:10px 12px;font-size:15px;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);outline:none}.form-group input:disabled{opacity:.5}.form-group textarea{resize:vertical;font-family:inherit}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.password-wrap{position:relative}.password-wrap input{padding-right:42px}.eye-btn{color:var(--muted);cursor:pointer;background:0 0;border:none;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.divider{color:var(--muted);align-items:center;gap:12px;margin:20px 0;font-size:12px;display:flex}.divider:before,.divider:after{content:"";background:var(--border);flex:1;height:1px}.btn{cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;width:100%;padding:12px;font-size:15px;font-weight:600;transition:opacity .2s,transform .1s;display:flex}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{color:#fff;background:linear-gradient(135deg,#0a4da2 0%,#06a0c4 100%)}.btn-secondary{background:var(--bg);color:var(--primary);border:1.5px solid var(--border)}.btn-outline{color:var(--primary);border:1.5px solid var(--primary);background:0 0}.btn-danger{background:var(--danger);color:#fff}.btn-grab{background:var(--success);color:#fff;margin-top:12px}.badge{color:#fff;background:linear-gradient(135deg,#0a4da2 0%,#06a0c4 100%);border-radius:12px;padding:2px 10px;font-size:12px;font-weight:600}.badge.red{background:var(--danger)}.status-tag{text-transform:capitalize;border-radius:6px;padding:2px 8px;font-size:12px;font-weight:600}.status-tag.active{color:#166534;background:#dcfce7}.status-tag.pending{color:#92400e;background:#fef3c7}.role-tag{border-radius:6px;padding:2px 8px;font-size:11px;font-weight:600}.role-tag.station_admin{color:#1e40af;background:#dbeafe}.role-tag.member{color:#4b5563;background:#f3f4f6}.own-tag{color:var(--muted);align-items:center;gap:4px;margin-top:10px;font-size:12px;font-style:italic;display:inline-flex}.grabbed-tag{color:var(--success);font-style:normal;font-weight:600}.filtered-tag{color:#fff;background:linear-gradient(135deg,#0a4da2 0%,#06a0c4 100%);border-radius:8px;padding:2px 8px;font-size:11px}.pool-tag{background:var(--bg);color:var(--muted);border-radius:6px;padding:2px 8px;font-size:11px}.shift-list{flex-direction:column;gap:12px;display:flex}.shift-card{background:var(--card);border-radius:var(--radius);border:1px solid var(--border);transition:border-color .2s;overflow:hidden;box-shadow:0 2px 8px #0000000a}.shift-card.urgent{border-color:var(--danger);box-shadow:0 2px 12px #ef44441f}.shift-card.grabbed{opacity:.75}.urgent-banner{background:var(--danger);color:#fff;letter-spacing:.5px;align-items:center;gap:6px;padding:6px 14px;font-size:12px;font-weight:700;animation:2s ease-in-out infinite urgentPulse;display:flex}@keyframes urgentPulse{0%,to{opacity:1}50%{opacity:.8}}.shift-card-body{padding:14px}.shift-top-row{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.shift-date{font-size:15px;font-weight:600}.shift-type-tag{color:#fff;border-radius:6px;padding:3px 10px;font-size:12px;font-weight:700}.shift-detail-row{color:var(--muted);align-items:center;gap:8px;margin-bottom:4px;font-size:13px;display:flex}.shift-detail-row.grabbed-info{color:var(--success);font-weight:600}.shift-notes{color:var(--text);background:var(--bg);border-radius:6px;margin-top:10px;padding:8px 10px;font-size:13px}.shift-type-selector{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.shift-type-btn{border:1.5px solid var(--border);background:var(--bg);cursor:pointer;border-radius:8px;padding:10px;font-size:14px;font-weight:600;transition:all .2s}.shift-type-btn.active{color:#fff;border-color:var(--primary);background:linear-gradient(135deg,#0a4da2 0%,#06a0c4 100%)}.post-type-selector{grid-template-columns:1fr 1fr;gap:10px;display:grid}.post-type-btn{border:2px solid var(--border);border-radius:var(--radius);background:var(--card);cursor:pointer;color:var(--muted);flex-direction:column;align-items:center;gap:6px;padding:16px 10px;transition:all .2s;display:flex}.post-type-btn.active{border-color:var(--primary);background:var(--primary-50);color:var(--primary)}.post-type-btn.request.active{color:#8b5cf6;background:#f3f0ff;border-color:#8b5cf6}.post-type-label{font-size:.9rem;font-weight:700}.post-type-desc{text-align:center;font-size:.72rem;line-height:1.3}.post-type-badge{text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:5px;padding:5px 12px;font-size:.7rem;font-weight:700;display:flex}.post-type-badge.giveaway{color:#b45309;background:#fef3c7}.post-type-badge.request{color:#6d28d9;background:#ede9fe}.btn-offer{border-radius:var(--radius-sm);color:#fff;cursor:pointer;background:linear-gradient(135deg,#8b5cf6,#6d28d9);border:none;width:100%;margin-top:10px;padding:10px;font-size:.85rem;font-weight:700;transition:opacity .2s}.btn-offer:active{opacity:.85}.shift-card.request-card{border-left:3px solid #8b5cf6}.shift-top-right{align-items:center;gap:8px;display:flex}.btn-more{color:var(--muted);cursor:pointer;letter-spacing:1px;background:0 0;border:none;border-radius:6px;padding:2px 6px;font-size:16px;font-weight:700;line-height:1;transition:background .15s}.btn-more:hover,.btn-more:active{background:var(--bg)}.shift-actions-dropdown{gap:6px;margin-bottom:8px;animation:.15s fadeSlideDown;display:flex}@keyframes fadeSlideDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.shift-action-btn{border:1px solid var(--border);background:var(--bg);color:var(--text);cursor:pointer;border-radius:8px;align-items:center;gap:5px;padding:6px 14px;font-size:13px;font-weight:500;transition:background .15s;display:inline-flex}.shift-action-btn:hover{background:var(--border)}.shift-action-btn.danger{color:var(--danger);background:#fef2f2;border-color:#fecaca}.shift-action-btn.danger:hover{background:#fecaca}.shift-delete-confirm{border-radius:var(--radius-sm);background:#fef2f2;border:1px solid #fecaca;margin-top:10px;padding:12px}.shift-delete-confirm p{color:var(--danger);margin-bottom:10px;font-size:13px;font-weight:600}.shift-delete-actions{gap:8px;display:flex}.btn-sm{padding:6px 16px!important;font-size:13px!important}.shift-card.editing{background:var(--card);border-radius:var(--radius);border:2px solid var(--primary);overflow:hidden;box-shadow:0 2px 12px #00000014}.edit-header{background:var(--primary-50);color:var(--primary);justify-content:space-between;align-items:center;padding:14px 16px;font-size:14px;font-weight:700;display:flex}.btn-icon-close{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;padding:4px;display:flex}.btn-icon-close:hover{background:var(--border)}.edit-form{padding:14px 16px}.edit-form .form-group.compact{margin-bottom:12px}.edit-form .form-group.compact label{color:var(--muted);margin-bottom:4px;font-size:12px;font-weight:600;display:block}.edit-form .shift-type-selector.compact{gap:6px}.edit-actions{gap:8px;margin-top:14px;display:flex}.edit-actions .btn{flex:1;padding:10px;font-size:13px}.post-disclaimer{border-left:4px solid var(--accent);border-radius:var(--radius-sm);background:#fef9e7;margin-top:8px;padding:16px 18px}.post-disclaimer-header{color:var(--primary);align-items:center;gap:8px;margin-bottom:10px;font-size:1rem;display:flex}.post-disclaimer p{color:var(--text);margin-bottom:2px;font-size:.85rem;line-height:1.5}.post-disclaimer-footer{color:var(--muted);margin-top:10px;font-size:.78rem;font-style:italic;display:block}.post-acknowledge{cursor:pointer;-webkit-tap-highlight-color:transparent;align-items:flex-start;gap:12px;padding:14px 0;display:flex}.post-acknowledge input[type=checkbox]{width:22px;min-width:22px;height:22px;accent-color:var(--primary);cursor:pointer;margin-top:2px}.post-acknowledge span{color:var(--text);font-size:.85rem;line-height:1.45}.header-actions{align-items:center;gap:8px;display:flex}.btn-icon-add{color:#fff;cursor:pointer;background:linear-gradient(135deg,#0a4da2 0%,#06a0c4 100%);border:none;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;transition:opacity .2s;display:flex}.btn-icon-add:active{opacity:.8}.radar-active-banner{color:#fff;border-radius:var(--radius-sm);background:linear-gradient(135deg,#065f46,#047857);align-items:center;gap:10px;margin-bottom:14px;padding:12px 14px;font-size:.82rem;font-weight:600;display:flex}.radar-active-banner span{flex:1}.radar-pulse{background:#34d399;border-radius:50%;width:10px;height:10px;animation:1.5s ease-in-out infinite radarPulse}@keyframes radarPulse{0%,to{opacity:1;box-shadow:0 0 #34d39999}50%{opacity:.7;box-shadow:0 0 0 8px #34d39900}}.alert-off-btn{color:#fff;cursor:pointer;opacity:.7;background:0 0;border:none;padding:2px}.alert-off-btn:hover{opacity:1}.new-shift-toast{background:var(--success);color:#fff;border-radius:8px;align-items:center;gap:8px;margin-bottom:14px;padding:12px 14px;font-size:14px;font-weight:600;animation:.3s ease-out slideInToast;display:flex}@keyframes slideInToast{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.radar-list{margin-bottom:16px}.radar-list-title{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;font-size:.85rem;font-weight:700}.radar-item{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);align-items:center;margin-bottom:8px;padding:12px 14px;transition:border-color .2s;display:flex}.radar-item.active{background:#ecfdf5;border-color:#047857}.radar-item-info{cursor:pointer;flex:1;align-items:center;gap:10px;min-width:0;display:flex}.radar-status-dot{background:#d1d5db;border-radius:50%;flex-shrink:0;width:10px;height:10px}.radar-status-dot.on{background:#34d399;animation:1.5s ease-in-out infinite radarPulse}.radar-item-details{flex-direction:column;min-width:0;display:flex}.radar-item-label{color:var(--text);font-size:.8rem;font-weight:700}.radar-item.active .radar-item-label{color:#047857}.radar-item-summary{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;font-size:.72rem;overflow:hidden}.radar-item-actions{flex-shrink:0;align-items:center;gap:6px;display:flex}.radar-toggle-btn{border:1px solid var(--border);cursor:pointer;color:var(--muted);background:0 0;border-radius:6px;justify-content:center;align-items:center;padding:6px;display:flex}.radar-toggle-btn.on{color:#047857;background:#ecfdf5;border-color:#047857}.radar-delete-btn{border:1px solid var(--border);cursor:pointer;color:var(--muted);background:0 0;border-radius:6px;justify-content:center;align-items:center;padding:6px;display:flex}.radar-delete-btn:active{color:var(--danger);border-color:var(--danger)}.radar-modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:flex-end;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.radar-modal{background:var(--card);border-radius:20px 20px 0 0;width:100%;max-width:480px;padding:20px 24px 34px;animation:.3s ease-out slideUp}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.radar-modal-handle{background:var(--border);border-radius:2px;width:40px;height:4px;margin:0 auto 16px}.radar-modal-title{color:var(--primary);margin-bottom:18px;font-size:1.1rem;font-weight:800}.radar-form-group{margin-bottom:14px}.radar-form-group label{color:var(--muted);margin-bottom:6px;font-size:.8rem;font-weight:600;display:block}.radar-form-group input,.radar-form-group select{border:1.5px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--primary);background:#f8fafc;padding:12px 14px;font-size:.9rem;font-weight:600}.radar-form-group input:disabled{opacity:.6}.radar-form-row{grid-template-columns:1fr 1fr;gap:10px;display:grid}.radar-activate-btn{justify-content:center;align-items:center;gap:8px;width:100%;margin-top:8px;display:flex}.radar-cancel-btn{width:100%;margin-top:8px}.radar-results{margin-top:4px}.radar-stats{color:var(--muted);align-items:center;gap:8px;margin-bottom:14px;font-size:13px;display:flex}.filtered-tag{background:var(--primary-50);color:var(--primary);border-radius:10px;padding:2px 8px;font-size:11px;font-weight:600}.empty-radar-icon{color:var(--border);margin-bottom:8px}.profile-card{text-align:center;background:var(--card);border-radius:var(--radius);border:1px solid var(--border);margin-bottom:16px;padding:24px}.profile-avatar{color:#fff;background:linear-gradient(135deg,#0a4da2 0%,#06a0c4 100%);border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 12px;font-size:22px;font-weight:700;display:flex}.profile-card h3{font-size:18px}.profile-name-row{justify-content:center;align-items:center;gap:8px;display:flex}.btn-edit-name{background:var(--bg);border:1px solid var(--border);color:var(--muted);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;transition:background .15s,color .15s;display:flex}.btn-edit-name:hover{background:var(--primary-50);color:var(--primary)}.profile-name-edit{flex-direction:column;align-items:center;gap:10px;width:100%;max-width:250px;margin:0 auto;display:flex}.profile-name-input{border:2px solid var(--primary);border-radius:var(--radius-sm);text-align:center;outline:none;width:100%;padding:8px 12px;font-size:16px;font-weight:600}.profile-name-actions{gap:8px;display:flex}.profile-badge{color:#1e40af;background:#dbeafe;border-radius:12px;margin-top:8px;padding:3px 12px;font-size:12px;font-weight:600;display:inline-block}.info-card{background:var(--card);border-radius:var(--radius);border:1px solid var(--border);margin-bottom:16px;overflow:hidden}.info-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 16px;font-size:14px;display:flex}.info-row:last-child{border-bottom:none}.info-label{color:var(--muted);font-weight:600}.notif-prefs-card{background:var(--card);border-radius:var(--radius);border:1px solid var(--border);margin-bottom:16px;padding:20px}.notif-prefs-header{color:var(--primary);align-items:center;gap:10px;margin-bottom:16px;display:flex}.notif-prefs-header h3{flex:1;font-size:1rem;font-weight:700}.notif-saved-badge{color:var(--success);background:var(--success-light);border-radius:20px;align-items:center;gap:4px;padding:4px 10px;font-size:.75rem;font-weight:600;animation:.2s fadeIn;display:flex}.notif-toggle-row{border-bottom:1px solid var(--border);cursor:pointer;-webkit-tap-highlight-color:transparent;justify-content:space-between;align-items:center;padding:14px 0;display:flex}.notif-toggle-row:last-child,.notif-toggle-row:last-of-type{border-bottom:none}.notif-toggle-info{flex:1;align-items:flex-start;gap:12px;min-width:0;display:flex}.notif-toggle-icon{color:var(--primary);flex-shrink:0;margin-top:2px}.notif-toggle-label{color:var(--text);font-size:.9rem;font-weight:600;display:block}.notif-toggle-desc{color:var(--muted);margin-top:2px;font-size:.75rem;display:block}.notif-switch{background:#d1d5db;border-radius:13px;flex-shrink:0;width:46px;height:26px;margin-left:12px;transition:background .2s;position:relative}.notif-switch.on{background:var(--success)}.notif-switch-thumb{background:#fff;border-radius:50%;width:22px;height:22px;transition:transform .2s;position:absolute;top:2px;left:2px;box-shadow:0 1px 3px #0003}.notif-switch.on .notif-switch-thumb{transform:translate(20px)}.notif-blocked-warning{border-radius:var(--radius-sm);color:#92400e;background:#fef3c7;border:1px solid #f59e0b;margin-top:12px;padding:10px 14px;font-size:.8rem;line-height:1.4}.legal-support-card{background:var(--card);border-radius:var(--radius);border:1px solid var(--border);margin-bottom:16px;padding:20px 0;overflow:hidden}.legal-support-title{margin-bottom:8px;padding:0 16px;font-size:16px;font-weight:700}.legal-row{width:100%;color:var(--text);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:12px;padding:14px 16px;font-size:15px;transition:background .15s;display:flex}.legal-row:active{background:var(--bg)}.legal-row-icon{color:var(--primary);flex-shrink:0}.legal-row span{flex:1}.legal-row-chevron{color:var(--muted);flex-shrink:0}.legal-row.delete,.legal-row.delete .legal-row-icon,.legal-row.delete .legal-row-chevron{color:var(--danger)}.legal-divider{background:var(--border);height:1px;margin:4px 16px}.legal-footer-text{color:var(--muted);text-align:center;margin-bottom:8px;padding:8px 16px 0;font-size:12px;line-height:1.4}.delete-confirm{border-radius:var(--radius);background:#fef2f2;border:1px solid #fecaca;margin-bottom:16px;padding:16px}.delete-confirm p{color:#991b1b;margin-bottom:12px;font-size:14px}.delete-confirm-actions{gap:8px;display:flex}.delete-confirm-actions .btn{flex:1}.legal-page{padding:16px}.legal-header{align-items:center;gap:12px;margin-bottom:20px;display:flex}.legal-header h2{color:var(--primary);font-size:20px}.legal-content{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px 16px}.legal-content h2.legal-title{color:var(--primary);margin-bottom:4px;font-size:20px}.legal-content h3.legal-heading{color:var(--text);margin-top:20px;margin-bottom:8px;font-size:16px;font-weight:700}.legal-content p.legal-text{color:var(--text);margin-bottom:4px;font-size:14px;line-height:1.6}.legal-content li{color:var(--text);margin-bottom:2px;margin-left:20px;font-size:14px;line-height:1.6}.legal-content br{content:"";margin-top:4px;display:block}.legal-footer{color:var(--muted);text-align:center;padding:16px;font-size:12px;line-height:1.4}.admin-section{margin-bottom:24px}.admin-section h3{align-items:center;gap:8px;margin-bottom:12px;font-size:16px;display:flex}.announcement-form{flex-direction:column;gap:10px;display:flex}.announcement-form select,.announcement-form input,.announcement-form textarea{border:1.5px solid var(--border);background:var(--bg);width:100%;color:var(--text);border-radius:8px;padding:10px 12px;font-family:inherit;font-size:14px}.announcement-form textarea{resize:vertical}.announcement-form .btn{justify-content:center;align-items:center;gap:6px;display:inline-flex}.announcement-result{color:var(--success);text-align:center;font-size:13px;font-weight:600}.back-btn{color:var(--primary);cursor:pointer;background:0 0;border:none;padding:4px}.request-list{flex-direction:column;gap:8px;display:flex}.request-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.request-card strong{font-size:14px}.request-actions{gap:8px;display:flex}.approve-btn,.deny-btn{cursor:pointer;background:0 0;border:none;padding:4px}.approve-btn{color:var(--success)}.deny-btn{color:var(--danger)}.delete-btn{cursor:pointer;color:var(--danger);background:0 0;border:none;border-radius:6px;align-items:center;padding:6px;transition:background .2s;display:flex}.delete-btn:hover{background:#dc26261a}.delete-btn:disabled{opacity:.4;cursor:not-allowed}.role-toggle-btn{border:1px solid var(--primary);color:var(--primary);cursor:pointer;white-space:nowrap;background:0 0;border-radius:6px;align-items:center;gap:4px;padding:4px 8px;font-size:11px;font-weight:600;display:inline-flex}.role-toggle-btn:active{background:var(--primary-50)}.pool-list{flex-direction:column;gap:8px;display:flex}.pool-card{background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius);cursor:pointer;justify-content:space-between;align-items:center;padding:12px 16px;transition:border-color .2s;display:flex}.pool-card.selected{border-color:var(--primary);background:#f0f7ff}.pool-info strong{font-size:14px}.pool-detail{color:var(--muted);margin-top:2px;font-size:12px;display:block}.pool-stats{color:var(--muted);align-items:center;gap:8px;font-size:13px;display:flex}.pool-detail-section{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.pool-detail-section h4{color:var(--muted);margin:12px 0 8px;font-size:14px}.pool-detail-section h4:first-child{margin-top:0}.member-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:8px 0;font-size:14px;display:flex}.stats-row{grid-template-columns:1fr 1fr;gap:12px;margin-top:8px;display:grid}.stat{text-align:center;background:var(--bg);border-radius:8px;padding:12px}.stat-num{color:var(--primary);font-size:24px;font-weight:700;display:block}.stat-label{color:var(--muted);font-size:12px}.all-users-list{flex-direction:column;gap:8px;display:flex}.user-row{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.user-row strong{font-size:14px}.user-meta{flex-direction:column;align-items:flex-end;gap:4px;display:flex}.invite-display{background:var(--bg);border:1.5px dashed var(--primary);border-radius:8px;align-items:center;gap:8px;margin:12px 0;padding:12px 16px;display:flex}.invite-display code{letter-spacing:3px;color:var(--primary);text-align:center;flex:1;font-size:20px;font-weight:700}.copy-btn{color:var(--primary);cursor:pointer;background:0 0;border:none;padding:4px}.invite-share-row{gap:8px;margin-bottom:16px;display:flex}.share-btn{cursor:pointer;border:none;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:6px;padding:10px;font-size:13px;font-weight:600;transition:opacity .2s,transform .1s;display:flex}.share-btn:active{transform:scale(.97)}.share-btn.sms{color:#166534;background:#dcfce7}.share-btn.email{color:#1e40af;background:#dbeafe}.share-btn.native{background:var(--primary-50);color:var(--primary)}.error-banner{color:#991b1b;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;margin-bottom:16px;padding:10px 14px;font-size:13px}.success-banner{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;align-items:center;gap:8px;margin-bottom:16px;padding:10px 14px;font-size:13px;display:flex}.pending-banner{color:#92400e;text-align:center;background:#fffbeb;border:1px solid #fde68a;border-radius:8px;margin-bottom:16px;padding:12px 14px;font-size:13px}.pending-full{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:60px 24px;display:flex}.pending-full .pending-icon{color:#f59e0b;background:#fffbeb;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;margin-bottom:8px;display:flex}.pending-full h2{color:var(--text);font-size:20px;font-weight:700}.pending-full p{color:var(--muted);max-width:280px;font-size:14px;line-height:1.5}.empty-state{text-align:center;color:var(--muted);padding:40px 20px}.empty-state p{margin-bottom:4px}.muted{color:var(--muted);font-size:13px}.logout-btn{margin-top:24px}.shift-views{color:var(--muted);border-top:1px solid var(--border);align-items:center;gap:4px;margin-top:8px;padding-top:8px;font-size:12px;display:flex}.btn-back{color:var(--primary);cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;padding:4px;display:flex}.btn-back:hover{background:var(--primary-50)}.members-count-badge{color:#fff;background:linear-gradient(135deg,#0a4da2 0%,#06a0c4 100%);border-radius:12px;margin-left:auto;padding:2px 10px;font-size:12px;font-weight:700}.members-pool-info{color:var(--muted);background:var(--primary-50);border-radius:var(--radius-sm);align-items:center;gap:6px;margin-bottom:16px;padding:10px 14px;font-size:13px;display:flex}.members-dot{color:var(--border)}.members-list{flex-direction:column;gap:8px;display:flex}.member-card{background:var(--card);border-radius:var(--radius-sm);border:1px solid var(--border);align-items:center;gap:12px;padding:14px 16px;display:flex}.member-card.pending{opacity:.85}.member-approve-actions{align-items:center;gap:8px;display:flex}.member-approve-actions .approve-btn{color:var(--success);cursor:pointer;background:0 0;border:none;border-radius:50%;align-items:center;padding:4px;display:flex}.member-approve-actions .deny-btn{color:var(--danger);cursor:pointer;background:0 0;border:none;border-radius:50%;align-items:center;padding:4px;display:flex}.member-approve-actions .approve-btn:active{background:var(--success-light)}.member-approve-actions .deny-btn:active{background:#fef2f2}.member-avatar{background:linear-gradient(135deg, var(--primary), var(--primary-light));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:16px;font-weight:700;display:flex}.member-avatar.pending{background:linear-gradient(135deg, var(--muted), #9ca3af)}.member-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.member-name{color:var(--text);font-size:14px;font-weight:600}.member-email{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;font-size:12px;overflow:hidden}.member-joined{color:var(--muted);align-items:center;gap:4px;font-size:11px;display:inline-flex}.member-role{flex-shrink:0}.role-badge{border-radius:8px;align-items:center;gap:4px;padding:4px 10px;font-size:11px;font-weight:600;display:inline-flex}.role-badge.admin{color:#92400e;background:#fef3c7}.role-badge.member{background:var(--success-light);color:#166534}.role-badge.pending{color:var(--danger);background:#fef2f2}.members-section-title{color:var(--muted);margin:20px 0 10px;font-size:14px;font-weight:700}.dash-stat-icon.members{color:#7c3aed;background:#ede9fe}.history-page .page-header{color:var(--primary);align-items:center;gap:10px;margin-bottom:20px;display:flex}.history-tabs{gap:8px;margin-bottom:16px;display:flex}.history-tab{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--card);color:var(--muted);cursor:pointer;flex:1;justify-content:center;align-items:center;gap:6px;padding:10px 12px;font-size:14px;font-weight:600;transition:all .2s;display:flex}.history-tab.active{color:#fff;border-color:var(--primary);background:linear-gradient(135deg,#0a4da2 0%,#06a0c4 100%)}.history-tab-count{background:#00000026;border-radius:10px;padding:1px 6px;font-size:11px;font-weight:700}.history-tab.active .history-tab-count{background:#ffffff40}.history-loading{color:var(--muted);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:60px 20px;display:flex}.history-empty{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:60px 20px;display:flex}.history-empty-icon{color:var(--border);margin-bottom:16px}.history-empty h3{color:var(--text);margin-bottom:6px;font-size:16px}.history-empty p{color:var(--muted);max-width:260px;font-size:13px}.history-list{flex-direction:column;gap:10px;display:flex}.history-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px}.history-card-top{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.history-card-type{align-items:center;gap:6px;display:flex}.history-type-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.history-type-label{color:var(--text);font-size:14px;font-weight:700}.history-request-tag{color:#7c3aed;background:#ede9fe;border-radius:6px;padding:1px 6px;font-size:11px;font-weight:600}.history-badge{border-radius:6px;align-items:center;gap:4px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.history-badge.grabbed{background:var(--success-light);color:#166534}.history-badge.expired{color:#991b1b;background:#fee2e2}.history-badge.open{background:var(--accent-light);color:#92400e}.history-card-date{color:var(--text);align-items:center;gap:6px;margin-bottom:6px;font-size:13px;display:flex}.history-card-detail{color:var(--muted);align-items:center;gap:6px;margin-bottom:4px;font-size:13px;display:flex}.history-card-detail:last-child{margin-bottom:0}.history-card-notes{color:var(--muted);border-top:1px solid var(--border);margin-top:8px;padding-top:8px;font-size:12px;font-style:italic}.post-form{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px 16px}.calendar-picker{position:relative}.calendar-input{border:1.5px solid var(--border);background:var(--bg);width:100%;color:var(--text);cursor:pointer;-webkit-tap-highlight-color:transparent;border-radius:8px;justify-content:space-between;align-items:center;padding:10px 12px;font-size:15px;display:flex}.calendar-input-placeholder{color:#999}.calendar-input-value{color:var(--text)}.calendar-input-icon{color:var(--text-light);flex-shrink:0}.calendar-dropdown{background:var(--card);border:1.5px solid var(--border);z-index:100;box-sizing:border-box;border-radius:12px;width:100%;margin-top:6px;padding:12px;overflow:hidden;box-shadow:0 4px 20px #0000001f}.calendar-month-label{color:var(--text);font-size:15px;font-weight:600}.calendar-nav{color:var(--primary);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:6px;align-items:center;padding:4px;display:flex}.calendar-nav:active{background:var(--primary-50)}.calendar-weekdays{text-align:center;grid-template-columns:repeat(7,1fr);margin-bottom:4px;display:grid}.calendar-weekday{color:var(--text-light);padding:4px 0;font-size:11px;font-weight:600}.calendar-days{grid-template-columns:repeat(7,1fr);gap:1px;display:grid}.calendar-day{aspect-ratio:1;color:var(--text);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;min-width:0;padding:0;font-size:13px;display:flex}.calendar-day:active:not(.disabled):not(.empty){background:var(--primary-50)}.calendar-day.empty{cursor:default}.calendar-day.disabled{color:#ccc;cursor:default}.calendar-day.today{color:var(--primary);font-weight:700}.calendar-day.selected{background:var(--primary);color:#fff;font-weight:600}[data-theme=dark]{--primary:#2a5080;--primary-light:#3b6ba5;--primary-50:#1a2a3e;--accent:#f59e0b;--accent-light:#3d2e0a;--danger:#ef4444;--success:#22c55e;--success-light:#0d2a18;--bg:#0f1419;--card:#1a2332;--text:#e8edf2;--muted:#89a;--border:#2a3a4a}[data-theme=dark] body{background:var(--bg);color:var(--text)}[data-theme=dark] .app-header{background:linear-gradient(135deg,#062a5c 0%,#044a6a 100%)}[data-theme=dark] .loading-screen{background:linear-gradient(135deg,#0f1e2e 0%,#060d14 100%)}[data-theme=dark] .dash-hero{background:linear-gradient(135deg,#0f1e2e 0%,#1a3050 100%)}[data-theme=dark] .bottom-nav{border-top-color:var(--border);background:#1a2332}[data-theme=dark] .nav-fab{border-color:var(--bg)}[data-theme=dark] .shift-card{background:var(--card);border-color:var(--border)}[data-theme=dark] .post-disclaimer{border-left-color:var(--accent);background:#2a2510}[data-theme=dark] .post-disclaimer p,[data-theme=dark] .post-disclaimer-footer{color:var(--text)}[data-theme=dark] input,[data-theme=dark] select,[data-theme=dark] textarea{background:var(--bg);color:var(--text);border-color:var(--border)}[data-theme=dark] .auth-card{background:var(--card);border-color:var(--border)}[data-theme=dark] .notif-panel{background:var(--card)}[data-theme=dark] .notif-item.unread{background:var(--primary-50)}[data-theme=dark] .radar-modal{background:var(--card)}[data-theme=dark] .radar-modal-overlay{background:#0009}[data-theme=dark] .shift-action-btn{background:var(--bg);border-color:var(--border);color:var(--text)}[data-theme=dark] .shift-action-btn.danger,[data-theme=dark] .shift-delete-confirm{background:#2a1515;border-color:#4a2020}[data-theme=dark] .profile-name-input{background:var(--bg);color:var(--text);border-color:var(--primary)}[data-theme=dark] .app-footer{color:#4a5a6a}.pull-to-refresh-wrapper{width:100%;min-height:100%;position:relative}.pull-indicator{color:var(--muted);-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;gap:8px;font-size:13px;transition:height .25s,opacity .25s;display:flex;overflow:hidden}.pull-indicator.past-threshold,.pull-indicator.refreshing{color:var(--primary)}.pull-indicator-icon{justify-content:center;align-items:center;transition:transform .2s;display:flex}.pull-indicator-icon .spin{animation:.8s linear infinite pull-refresh-spin}.pull-indicator-text{font-weight:500}@keyframes pull-refresh-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}[data-theme=dark] .pull-indicator{color:#6b7a8a}[data-theme=dark] .pull-indicator.past-threshold,[data-theme=dark] .pull-indicator.refreshing{color:var(--primary-light)}.onboarding-overlay{z-index:9999;-webkit-backdrop-filter:blur(6px);background:#0000008c;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.onboarding-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);text-align:center;width:100%;max-width:380px;padding:40px 28px 32px;animation:.35s onboarding-fade-in;box-shadow:0 20px 60px #00000040}@keyframes onboarding-fade-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.onboarding-skip{color:var(--muted);cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:14px;font-weight:500;position:absolute;top:16px;right:16px}.onboarding-step-label{color:var(--muted);letter-spacing:.5px;text-transform:uppercase;margin-bottom:16px;font-size:12px;font-weight:500}.onboarding-icon-wrap{background:linear-gradient(135deg,#0a4da21a 0%,#06a0c41a 100%);border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 20px;display:flex}.onboarding-icon{color:var(--primary)}.onboarding-tips{text-align:left;flex-direction:column;gap:10px;margin-bottom:24px;display:flex}.onboarding-tip{color:var(--text);background:var(--bg);border-radius:var(--radius-sm);border:1px solid var(--border);align-items:center;gap:10px;padding:10px 14px;font-size:13px;display:flex}.onboarding-tip-icon{color:var(--primary);flex-shrink:0}.onboarding-title{color:var(--text);margin-bottom:12px;font-size:22px;font-weight:700}.onboarding-description{color:var(--muted);margin-bottom:28px;font-size:15px;line-height:1.55}.onboarding-btn{color:#fff;border-radius:var(--radius-sm);cursor:pointer;background:linear-gradient(135deg,#0a4da2 0%,#06a0c4 100%);border:none;justify-content:center;align-items:center;width:100%;padding:14px 24px;font-size:16px;font-weight:600;transition:background .2s,transform .1s;display:inline-flex}.onboarding-btn:hover{background:var(--primary-light)}.onboarding-btn:active{transform:scale(.97)}.onboarding-dots{justify-content:center;align-items:center;gap:10px;margin-top:24px;display:flex}.onboarding-dot{background:var(--border);cursor:pointer;border-radius:50%;width:10px;height:10px;transition:background .25s,transform .2s}.onboarding-dot.active{background:linear-gradient(135deg,#0a4da2 0%,#06a0c4 100%);transform:scale(1.25)}.onboarding-dot.done{background:#0a4da266}[data-theme=dark] .onboarding-overlay{background:#000000b3}[data-theme=dark] .onboarding-card{box-shadow:0 20px 60px #00000080}.profile-avatar{cursor:pointer;position:relative;overflow:visible}.profile-avatar img{object-fit:cover;border-radius:50%;width:100%;height:100%}.avatar-upload-overlay{color:#fff;border:2px solid var(--card);background:#0000008c;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;transition:background .2s;display:flex;position:absolute;bottom:-2px;right:-2px}.avatar-upload-overlay:hover{background:#000000bf}.avatar-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:12px;height:12px;animation:.8s linear infinite spin}.avatar-file-input{display:none}.member-avatar{position:relative;overflow:hidden}.member-avatar img{object-fit:cover;border-radius:50%;width:100%;height:100%}[data-theme=dark] .avatar-upload-overlay{border-color:var(--card);background:#fff3}[data-theme=dark] .avatar-upload-overlay:hover{background:#ffffff59}.view-toggle{justify-content:flex-start;gap:4px;padding:8px 16px 0;display:flex}.view-toggle-btn.has-filters{position:relative}.view-toggle-btn.has-filters:after{content:"";background:#f59e0b;border-radius:50%;width:8px;height:8px;position:absolute;top:4px;right:4px}.view-toggle-btn{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--card);width:36px;height:36px;color:var(--muted);cursor:pointer;justify-content:center;align-items:center;transition:all .2s;display:flex}.view-toggle-btn.active{color:#fff;border-color:var(--primary);background:linear-gradient(135deg,#0a4da2 0%,#06a0c4 100%)}.view-toggle-btn:hover:not(.active){background:var(--primary-50);color:var(--primary)}.calendar-container{padding:12px 16px 24px}.calendar-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.calendar-title{color:var(--text);align-items:center;gap:8px;font-size:1.05rem;font-weight:600;display:flex}.calendar-nav-btn{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--card);width:34px;height:34px;color:var(--text);cursor:pointer;justify-content:center;align-items:center;transition:background .2s;display:flex}.calendar-nav-btn:hover{background:var(--primary-50)}.calendar-grid{background:var(--card);border-radius:var(--radius);border:1px solid var(--border);grid-template-columns:repeat(7,1fr);gap:2px;display:grid;overflow:hidden}.calendar-weekday{text-align:center;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;background:var(--primary-50);padding:8px 0;font-size:.7rem;font-weight:600}.calendar-day{cursor:default;background:var(--card);flex-direction:column;align-items:center;gap:2px;min-height:52px;padding:4px;transition:background .15s;display:flex;position:relative}.calendar-day.has-shifts{cursor:pointer}.calendar-day.has-shifts:hover{background:var(--primary-50)}.calendar-day.other-month{opacity:.35}.calendar-day.today .calendar-day-number{color:#fff;background:linear-gradient(135deg,#0a4da2 0%,#06a0c4 100%);border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;display:flex}.calendar-day.selected{background:var(--primary-50);box-shadow:inset 0 0 0 2px var(--primary)}.calendar-day-number{color:var(--text);justify-content:center;align-items:center;width:26px;height:26px;font-size:.8rem;font-weight:500;display:flex}.calendar-dots{flex-wrap:wrap;justify-content:center;gap:3px;display:flex}.calendar-dot{border-radius:50%;flex-shrink:0;width:5px;height:5px}.calendar-day-shifts{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);margin-top:12px;padding:14px;animation:.2s fadeIn}.calendar-day-shifts-title{color:var(--text);margin-bottom:10px;font-size:.9rem;font-weight:600}.calendar-shift-item{border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:8px 0;font-size:.85rem;display:flex}.calendar-shift-item:last-child{border-bottom:none;padding-bottom:0}.calendar-shift-badge{color:#fff;text-transform:uppercase;letter-spacing:.3px;border-radius:6px;flex-shrink:0;padding:2px 8px;font-size:.72rem;font-weight:600;display:inline-block}.calendar-shift-info{color:var(--text);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.calendar-shift-poster{color:var(--muted);flex-shrink:0;font-size:.78rem}[data-theme=dark] .calendar-nav-btn{background:var(--card);border-color:var(--border);color:var(--text)}[data-theme=dark] .calendar-nav-btn:hover{background:var(--primary-50)}[data-theme=dark] .calendar-grid{background:var(--card);border-color:var(--border)}[data-theme=dark] .calendar-weekday{background:var(--primary-50);color:var(--muted)}[data-theme=dark] .calendar-day{background:var(--card)}[data-theme=dark] .calendar-day.has-shifts:hover{background:var(--primary-50)}[data-theme=dark] .calendar-day.selected{background:var(--primary-50);box-shadow:inset 0 0 0 2px var(--primary-light)}[data-theme=dark] .calendar-day-shifts{background:var(--card);border-color:var(--border)}[data-theme=dark] .calendar-shift-item{border-bottom-color:var(--border)}[data-theme=dark] .view-toggle-btn{background:var(--card);border-color:var(--border);color:var(--muted)}[data-theme=dark] .view-toggle-btn.active{color:#fff;border-color:var(--primary);background:linear-gradient(135deg,#0a4da2 0%,#06a0c4 100%)}[data-theme=dark] .view-toggle-btn:hover:not(.active){background:var(--primary-50);color:var(--text)}.install-app-btn{background:linear-gradient(135deg, var(--primary), var(--primary-light));border:none;animation:2s ease-in-out infinite installPulse;color:#fff!important}.install-app-btn span{color:#fff;font-weight:600}.install-app-btn .legal-row-chevron{color:#ffffffb3}@keyframes installPulse{0%,to{box-shadow:0 0 #1e3a5f4d}50%{box-shadow:0 0 0 6px #1e3a5f00}}[data-theme=dark] .install-app-btn{background:linear-gradient(135deg, var(--primary-light), var(--primary))}.shift-chat-btn{color:var(--primary);background:var(--primary-50);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;align-items:center;gap:6px;margin-top:10px;padding:7px 14px;font-size:.82rem;font-weight:600;transition:background .2s,color .2s;display:inline-flex;position:relative}.shift-chat-btn:hover{color:#fff;background:linear-gradient(135deg,#0a4da2 0%,#06a0c4 100%)}.chat-unread-badge{color:#fff;background:var(--danger);border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 5px;font-size:.7rem;font-weight:700;display:inline-flex}.shift-chat-panel{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);margin-top:10px;overflow:hidden}.chat-messages{flex-direction:column;gap:8px;max-height:250px;padding:12px;display:flex;overflow-y:auto}.chat-empty{text-align:center;color:var(--muted);padding:20px 0;font-size:.82rem}.chat-bubble{word-break:break-word;border-radius:12px;max-width:80%;padding:8px 12px;font-size:.85rem;line-height:1.4}.chat-bubble.own{color:#fff;background:linear-gradient(135deg,#0a4da2 0%,#06a0c4 100%);border-bottom-right-radius:4px;align-self:flex-end}.chat-bubble.other{background:var(--card);color:var(--text);border:1px solid var(--border);border-bottom-left-radius:4px;align-self:flex-start}.chat-bubble-name{color:var(--primary);margin-bottom:2px;font-size:.72rem;font-weight:700;display:block}.chat-bubble-time{opacity:.65;margin-top:4px;font-size:.68rem;display:block}.chat-bubble.own .chat-bubble-time{text-align:right}.chat-seen{text-align:right;color:var(--primary);opacity:.8;margin-top:2px;font-size:.65rem;font-weight:600;display:block}.chat-input-row{border-top:1px solid var(--border);display:flex}.chat-input-row input{background:var(--card);color:var(--text);border:none;outline:none;flex:1;padding:10px 12px;font-size:.85rem}.chat-input-row button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#0a4da2 0%,#06a0c4 100%);border:none;justify-content:center;align-items:center;width:42px;transition:opacity .2s;display:flex}.chat-input-row button:disabled{opacity:.4;cursor:not-allowed}.chat-input-row button:not(:disabled):hover{opacity:.85}[data-theme=dark] .shift-chat-btn{color:#93c5fd;background:#ffffff14;border-color:#ffffff1f}[data-theme=dark] .shift-chat-btn:hover{color:#fff;background:linear-gradient(135deg,#0a4da2 0%,#06a0c4 100%)}[data-theme=dark] .shift-chat-panel{background:#0003;border-color:#ffffff1a}[data-theme=dark] .chat-bubble.other{color:var(--text);background:#ffffff14;border-color:#ffffff1a}[data-theme=dark] .chat-bubble.own{background:#2563eb}[data-theme=dark] .chat-bubble-name{color:#93c5fd}[data-theme=dark] .chat-input-row{border-color:#ffffff1a}[data-theme=dark] .chat-input-row input{color:var(--text);background:#ffffff0f}[data-theme=dark] .chat-input-row button{background:#2563eb}.skeleton{background:#e2e8f0;border-radius:4px;position:relative;overflow:hidden}.skeleton:after{content:"";background:linear-gradient(90deg,#0000 0%,#fff6 50%,#0000 100%);animation:1.5s infinite skeleton-shimmer;position:absolute;inset:0}.skeleton-circle{border-radius:50%}@keyframes skeleton-shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.skeleton-card{background:var(--card);border-radius:var(--radius);border:1px solid var(--border);margin-bottom:10px;padding:16px}.skeleton-row{align-items:center;gap:12px;display:flex}.page-loading{justify-content:center;align-items:center;min-height:60vh;display:flex}[data-theme=dark] .skeleton{background:#2d3748}[data-theme=dark] .skeleton:after{background:linear-gradient(90deg,#0000 0%,#ffffff14 50%,#0000 100%)}.analytics-grid{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:8px;display:grid}.analytics-stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);text-align:center;flex-direction:column;align-items:center;gap:4px;padding:14px 12px;display:flex}.analytics-stat-card .analytics-icon{color:var(--primary);margin-bottom:2px}.analytics-stat-num{color:var(--text);font-size:1.5rem;font-weight:700;line-height:1.1}.analytics-stat-label{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;font-size:.75rem;font-weight:600}.analytics-type-bars{flex-direction:column;gap:8px;display:flex}.analytics-type-row{align-items:center;gap:10px;display:flex}.analytics-type-label{width:36px;color:var(--text);flex-shrink:0;font-size:.82rem;font-weight:600}.analytics-type-track{background:var(--bg);border-radius:6px;flex:1;height:22px;overflow:hidden}.analytics-type-fill{background:linear-gradient(135deg,#0a4da2 0%,#06a0c4 100%);border-radius:6px;min-width:4px;height:100%;transition:width .4s}.analytics-type-count{text-align:right;width:28px;color:var(--text);flex-shrink:0;font-size:.82rem;font-weight:700}.analytics-leaderboard{flex-direction:column;gap:4px;display:flex}.analytics-leaderboard-item{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);align-items:center;gap:10px;padding:8px 12px;display:flex}.analytics-rank{color:var(--primary);flex-shrink:0;width:28px;font-size:.82rem;font-weight:700}.analytics-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:.88rem;font-weight:500;overflow:hidden}.analytics-count{color:var(--muted);background:var(--bg);border-radius:10px;flex-shrink:0;padding:2px 8px;font-size:.82rem;font-weight:700}.analytics-bar-chart{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);align-items:flex-end;gap:3px;height:120px;padding:12px 8px 24px;display:flex;overflow-x:auto}.analytics-bar-col{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;min-width:8px;height:100%;display:flex;position:relative}.analytics-bar{background:linear-gradient(135deg,#0a4da2 0%,#06a0c4 100%);border-radius:3px 3px 0 0;width:100%;min-height:2px;transition:height .4s}.analytics-bar-label{color:var(--muted);white-space:nowrap;font-size:.6rem;position:absolute;bottom:-18px}[data-theme=dark] .analytics-stat-card{background:var(--card);border-color:var(--border)}[data-theme=dark] .analytics-stat-card .analytics-icon{color:var(--accent)}[data-theme=dark] .analytics-type-track{background:var(--bg)}[data-theme=dark] .analytics-type-fill{background:var(--accent)}[data-theme=dark] .analytics-leaderboard-item{background:var(--card);border-color:var(--border)}[data-theme=dark] .analytics-rank{color:var(--accent)}[data-theme=dark] .analytics-count{background:var(--bg)}[data-theme=dark] .analytics-bar-chart{background:var(--card);border-color:var(--border)}[data-theme=dark] .analytics-bar{background:var(--accent)}.inbox-page{padding:16px}.inbox-title{color:var(--text);margin-bottom:16px;font-size:22px;font-weight:700}.inbox-empty{text-align:center;color:var(--muted);flex-direction:column;justify-content:center;align-items:center;padding:60px 20px;display:flex}.inbox-empty h3{color:var(--text);margin-top:12px;font-size:18px}.inbox-empty p{margin-top:6px;font-size:14px}.inbox-conversation{background:var(--card);border-radius:var(--radius);cursor:pointer;border:1px solid var(--border);align-items:center;gap:12px;margin-bottom:10px;padding:14px;transition:transform .15s,box-shadow .15s;display:flex}.inbox-conversation:active{transform:scale(.98)}.inbox-conv-avatar{color:#fff;background:linear-gradient(135deg,#0a4da2 0%,#06a0c4 100%);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:18px;font-weight:700;display:flex;position:relative}.inbox-unread-dot{background:var(--danger);border:2px solid var(--card);border-radius:50%;width:12px;height:12px;position:absolute;top:0;right:0}.inbox-conversation.unread{border-left:3px solid var(--primary);background:#eef4fb}.inbox-conversation.unread .inbox-conv-name{font-weight:700}.inbox-conv-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.inbox-conv-top{justify-content:space-between;align-items:center;display:flex}.inbox-conv-name{color:var(--text);font-size:15px;font-weight:600}.inbox-conv-date{color:var(--muted);font-size:12px}.inbox-conv-shift{color:var(--muted);font-size:13px}.inbox-conv-status{color:var(--muted);align-items:center;gap:4px;font-size:12px;display:flex}.inbox-conv-icon{color:var(--muted);flex-shrink:0}.inbox-chat-header{border-bottom:1px solid var(--border);align-items:center;gap:12px;margin-bottom:12px;padding-bottom:14px;display:flex}.inbox-back-btn{color:var(--text);cursor:pointer;background:0 0;border:none;border-radius:50%;align-items:center;padding:6px;display:flex}.inbox-back-btn:active{background:var(--border)}.inbox-chat-header-info{flex-direction:column;display:flex}.inbox-chat-header-name{color:var(--text);font-size:16px;font-weight:700}.inbox-chat-header-shift{color:var(--muted);font-size:13px}.inbox-messages{min-height:200px;max-height:calc(100dvh - var(--header-height) - var(--nav-height) - env(safe-area-inset-top,0px) - 160px);flex:1;padding:8px 0;overflow-y:auto}.inbox-input-row{border-top:1px solid var(--border);background:var(--bg);gap:8px;padding:12px 0 4px;display:flex;position:sticky;bottom:0}.inbox-input-row input{border:1px solid var(--border);background:var(--card);color:var(--text);border-radius:24px;flex:1;padding:10px 14px;font-size:14px}.inbox-input-row button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#0a4da2 0%,#06a0c4 100%);border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.inbox-input-row button:disabled{opacity:.4}.dash-quick-links{gap:10px;display:flex}.dash-quick-link{background:var(--card);border-radius:var(--radius);border:1px solid var(--border);cursor:pointer;color:var(--text);flex:1;align-items:center;gap:10px;padding:14px;font-size:14px;font-weight:600;display:flex}.dash-quick-link:active{transform:scale(.97)}.grab-confirm-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.grab-confirm-modal{text-align:center;background:#fff;border-radius:16px;width:100%;max-width:340px;padding:24px;animation:.2s ease-out grabModalIn;box-shadow:0 20px 60px #0000004d}@keyframes grabModalIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.grab-confirm-modal h3{color:#1a1a1a;margin-bottom:8px;font-size:1.1rem}.grab-confirm-modal p{color:#555;margin-bottom:16px;font-size:.9rem}.grab-confirm-details{color:#333;background:#f0f4f8;border-radius:10px;justify-content:center;align-items:center;gap:8px;margin-bottom:20px;padding:10px 14px;font-size:.85rem;font-weight:500;display:flex}.grab-confirm-actions{gap:10px;display:flex}.grab-confirm-actions .btn{border-radius:10px;flex:1;padding:12px;font-size:.95rem}.grab-success-toast{color:#fff;background:#10b981;border-radius:10px;align-items:center;gap:8px;margin-top:8px;padding:10px 16px;font-size:.85rem;font-weight:500;animation:.3s ease-out toastSlideIn,.5s ease-in 2.5s forwards toastFadeOut;display:flex}@keyframes toastSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes toastFadeOut{0%{opacity:1}to{opacity:0}}.admin-log-list{flex-direction:column;gap:8px;max-height:400px;display:flex;overflow-y:auto}.admin-log-entry{border-left:3px solid var(--primary);background:#f8f9fa;border-radius:8px;padding:10px 12px}.admin-log-header{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.admin-log-header strong{color:var(--primary);font-size:.85rem}.admin-log-time{color:#888;font-size:.7rem}.admin-log-action{color:#333;font-size:.85rem}.admin-log-details{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.admin-log-detail{color:#666;background:#e9ecef;border-radius:4px;padding:2px 6px;font-size:.7rem}.highlight-pulse{animation:2s ease-out highlightPulse}@keyframes highlightPulse{0%{box-shadow:0 0 #3b82f680}20%{box-shadow:0 0 0 8px #3b82f64d}50%{box-shadow:0 0 0 12px #3b82f626}to{box-shadow:0 0 #3b82f600}}
