@import "https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap";:root{--font-family:"Plus Jakarta Sans", system-ui, -apple-system, sans-serif;--bg-canvas:#e5e3de;--surface-primary:#fafaf8;--surface-white:#fff;--surface-subtle:#f5f4f1;--surface-muted:#f9f8f6;--border-default:#e8e7e4;--border-light:#f1f0ed;--text-primary:#0f172a;--text-secondary:#374151;--text-muted:#64748b;--text-placeholder:#94a3b8;--text-disabled:#cbd5e1;--accent-blue:#2563eb;--accent-blue-light:#1d4ed8;--blue-bg-tint:#eff6ff;--blue-border-tint:#bfdbfe;--applied-purple:#6d28d9;--applied-purple-bg:#f5f3ff;--applied-purple-border:#ddd6fe;--phone-amber:#b45309;--phone-amber-bg:#fffbeb;--phone-amber-border:#fde68a;--technical-orange:#c2410c;--technical-bg:#fff7ed;--onsite-rose:#9f1239;--onsite-bg:#fff1f2;--offer-green:#065f46;--offer-bg:#ecfdf5;--danger-red:#ef4444;--danger-bg:#fef2f2;--danger-border:#fca5a5;--fresh-green:#16a34a;--fresh-green-bg:#f0fdf4;--fresh-green-border:#bbf7d0;--aging-amber:#d97706;--note-yellow-bg:#fefdf0;--note-yellow-border:#fde68a;--shadow-app-frame:0 8px 48px #00000029, 0 1px 4px #00000012;--shadow-cta:0 1px 4px #2563eb73;--shadow-kanban-card:0 1px 3px #0000000d;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-normal:.25s cubic-bezier(.4, 0, .2, 1)}:root.theme-dark{--bg-canvas:#0f0e0c;--surface-primary:#171715;--surface-white:#20201e;--surface-subtle:#1c1c1a;--surface-muted:#1a1a18;--border-default:#2a2a27;--border-light:#2d2d2a;--text-primary:#f5f4f0;--text-secondary:#d7d6d0;--text-muted:#9e9d97;--text-placeholder:#5c5b56;--text-disabled:#474642;--accent-blue:#3b82f6;--accent-blue-light:#60a5fa;--blue-bg-tint:#1e3a8a;--blue-border-tint:#1d4ed8;--applied-purple:#c084fc;--applied-purple-bg:#4c1d95;--applied-purple-border:#5b21b6;--phone-amber:#fbbf24;--phone-amber-bg:#78350f;--phone-amber-border:#92400e;--technical-orange:#fb923c;--technical-bg:#7c2d12;--onsite-rose:#fb7185;--onsite-bg:#881337;--offer-green:#34d399;--offer-bg:#064e3b;--danger-red:#f87171;--danger-bg:#7f1d1d;--danger-border:#991b1b;--fresh-green:#4ade80;--fresh-green-bg:#14532d;--fresh-green-border:#166534;--aging-amber:#f59e0b;--note-yellow-bg:#222212;--note-yellow-border:#444020;--shadow-app-frame:0 8px 48px #0006, 0 1px 4px #0003;--shadow-cta:0 1px 4px #3b82f673;--shadow-kanban-card:0 1px 3px #0003}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-canvas);color:var(--text-secondary);font-family:var(--font-family);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;font-size:14px;line-height:1.5;overflow-x:hidden}button,select,input,textarea{color:inherit;font-family:inherit}.loading-fallback{height:100vh;color:var(--accent-blue);background-color:var(--surface-primary);letter-spacing:-.03em;justify-content:center;align-items:center;font-size:1.5rem;font-weight:700;animation:1.5s ease-in-out infinite pulse;display:flex}@keyframes pulse{0%,to{opacity:.6}50%{opacity:1}}.roster-app{background-color:var(--surface-primary);min-height:100vh;color:var(--text-secondary);justify-content:center;align-items:center;padding:0;display:flex}@media (width<=1023px){.roster-app{background-color:#18181b}}.roster-app__desktop-frame{background-color:var(--surface-primary);width:100vw;height:100vh;box-shadow:none;border:none;border-radius:0;flex-direction:column;display:flex;position:relative;overflow:hidden}.roster-app__header{background-color:var(--surface-white);border-bottom:1px solid var(--border-default);z-index:10;flex-shrink:0;align-items:center;gap:14px;height:56px;padding:0 20px;display:flex}.roster-app__logo{cursor:pointer;flex-shrink:0;align-items:center;gap:9px;display:flex}.roster-app__logo-box{background-color:var(--accent-blue);border-radius:7px;justify-content:center;align-items:center;width:30px;height:30px;display:flex;box-shadow:0 2px 8px #2563eb40}.roster-app__logo-text{color:var(--text-primary);letter-spacing:-.03em;font-size:16px;font-weight:800;line-height:1}.roster-app__search-wrapper{flex:1;max-width:520px;position:relative}.roster-app__search-icon{pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.roster-app__search-input{background-color:var(--surface-subtle);border:1.5px solid var(--border-default);border-radius:var(--radius-medium);width:100%;height:36px;color:var(--text-primary);transition:all var(--transition-fast);outline:none;padding:0 12px 0 34px;font-size:14px}.roster-app__search-input::placeholder{color:var(--text-placeholder)}.roster-app__search-input:focus{background-color:var(--surface-white);border-color:var(--accent-blue);box-shadow:0 0 0 3px var(--blue-bg-tint)}.roster-app__stats-badge{color:var(--text-muted);white-space:nowrap;font-size:14px}.roster-app__stats-badge strong{color:var(--text-primary);font-weight:700}.roster-app__stats-badge .new-count{color:var(--accent-blue);font-weight:700}.roster-app__view-toggle{border:1.5px solid var(--border-default);background-color:var(--surface-subtle);border-radius:9px;padding:2px;display:flex;overflow:hidden}.roster-app__toggle-btn{cursor:pointer;color:var(--text-placeholder);transition:all var(--transition-fast);background:0 0;border:none;border-radius:7px;align-items:center;gap:7px;padding:6px 15px;font-size:13px;font-weight:600;display:flex}.roster-app__toggle-btn svg{fill:var(--text-placeholder)}.roster-app__toggle-btn:hover{color:var(--text-muted)}.roster-app__toggle-btn:hover svg{fill:var(--text-muted)}.roster-app__toggle-btn--active{background-color:var(--surface-white);color:var(--text-primary);cursor:default;box-shadow:0 1px 3px #0000000f}.roster-app__toggle-btn--active svg{fill:var(--text-primary)}.roster-app__sort-select{border:1.5px solid var(--border-default);border-radius:var(--radius-medium);background-color:var(--surface-white);height:36px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);outline:none;align-items:center;gap:6px;padding:0 12px;font-size:13px;font-weight:600;display:flex}.roster-app__sort-select:hover{background-color:var(--surface-subtle);border-color:var(--text-placeholder)}.roster-app__util-controls{align-items:center;gap:8px;margin-left:auto;display:flex}.roster-app__theme-btn{background-color:var(--surface-white);border:1.5px solid var(--border-default);border-radius:var(--radius-medium);cursor:pointer;width:32px;height:32px;transition:all var(--transition-fast);justify-content:center;align-items:center;font-size:14px;display:flex}.roster-app__theme-btn:hover{background-color:var(--surface-subtle);border-color:var(--text-placeholder)}.roster-app__lang-btn{background-color:var(--surface-white);border:1.5px solid var(--border-default);border-radius:var(--radius-medium);cursor:pointer;text-transform:uppercase;height:32px;color:var(--text-secondary);transition:all var(--transition-fast);justify-content:center;align-items:center;padding:0 10px;font-size:11px;font-weight:700;display:flex}.roster-app__lang-btn:hover{background-color:var(--surface-subtle)}.roster-app__scraper-panel{background-color:var(--surface-muted);border-bottom:1px solid var(--border-default);color:var(--text-muted);flex-shrink:0;justify-content:space-between;align-items:center;padding:10px 20px;font-size:12px;display:flex}.roster-app__scraper-panel .scraper-status-group{align-items:center;gap:8px;display:flex}.roster-app__scraper-panel .status-dot{background-color:#94a3b8;border-radius:50%;width:8px;height:8px}.roster-app__scraper-panel .status-dot--idle{background-color:var(--text-placeholder)}.roster-app__scraper-panel .status-dot--running{background-color:var(--accent-blue);animation:1.5s infinite pulse-glow}.roster-app__scraper-panel .status-dot--success{background-color:var(--fresh-green)}.roster-app__scraper-panel .status-dot--failed{background-color:var(--danger-red)}.roster-app__scraper-panel .scraper-btn{color:var(--accent-blue);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-weight:600}.roster-app__scraper-panel .scraper-btn:hover:not(:disabled){background-color:var(--blue-bg-tint)}.roster-app__scraper-panel .scraper-btn:disabled{opacity:.5;cursor:not-allowed}.roster-app__split-pane{flex:1;height:calc(100% - 56px);display:flex;overflow:hidden}.roster-app__sidebar{background-color:var(--surface-subtle);border-right:1px solid var(--border-default);flex-direction:column;flex-shrink:0;gap:22px;width:210px;padding:20px 16px;display:flex;overflow-y:auto}.roster-app__sidebar-title{letter-spacing:.1em;text-transform:uppercase;color:var(--text-placeholder);margin-bottom:2px;font-size:10px;font-weight:700}.roster-app__filter-group{flex-direction:column;gap:11px;display:flex}.roster-app__filter-group .filter-header{color:var(--text-secondary);font-size:12px;font-weight:600}.roster-app__filter-list{flex-direction:column;gap:9px;display:flex}.roster-app__checkbox-label{cursor:pointer;-webkit-user-select:none;user-select:none;color:var(--text-secondary);align-items:center;gap:9px;font-size:13px;display:flex}.roster-app__checkbox-label input[type=checkbox]{appearance:none;cursor:pointer;width:16px;height:16px;transition:all var(--transition-fast);background-color:var(--surface-white);border:1.5px solid #d1d0cd;border-radius:4px;outline:none;justify-content:center;align-items:center;display:flex}.roster-app__checkbox-label input[type=checkbox]:checked{background-color:var(--accent-blue);border-color:var(--accent-blue)}.roster-app__checkbox-label input[type=checkbox]:checked:after{content:"";border:2px solid #fff;border-width:0 2px 2px 0;width:4px;height:8px;margin-bottom:2px;transform:rotate(45deg)}.roster-app__checkbox-label--unchecked-label{color:var(--text-placeholder)}.roster-app__company-filter-box{position:relative}.roster-app__company-filter-box input{background-color:var(--surface-white);border:1.5px solid var(--border-default);width:100%;height:34px;color:var(--text-primary);transition:border-color var(--transition-fast);border-radius:7px;outline:none;padding:0 10px 0 30px;font-size:13px}.roster-app__company-filter-box input::placeholder{color:var(--text-disabled)}.roster-app__company-filter-box input:focus{border-color:var(--accent-blue)}.roster-app__company-filter-box .box-search-icon{pointer-events:none;position:absolute;top:50%;left:9px;transform:translateY(-50%)}.roster-app__job-list-panel{background-color:var(--surface-white);border-right:1px solid var(--border-default);flex-direction:column;flex-shrink:0;width:310px;display:flex;overflow:hidden}.roster-app__list-header{border-bottom:1px solid var(--border-light);flex-shrink:0;justify-content:space-between;align-items:center;height:44px;padding:0 14px;display:flex}.roster-app__list-header .results-count{color:var(--text-muted);font-size:13px;font-weight:600}.roster-app__list-header .new-toggle-wrap{color:var(--text-placeholder);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;font-size:13px;display:flex}.roster-app__list-header .new-switch{background-color:var(--border-default);width:36px;height:20px;transition:background-color var(--transition-fast);border-radius:10px;position:relative}.roster-app__list-header .new-switch:after{content:"";width:16px;height:16px;transition:transform var(--transition-fast);background-color:#fff;border-radius:50%;position:absolute;top:2px;left:2px;box-shadow:0 1px 2px #0003}.roster-app__list-header .new-switch--on{background-color:var(--accent-blue);box-shadow:0 0 0 3px var(--blue-bg-tint)}.roster-app__list-header .new-switch--on:after{transform:translate(16px)}.roster-app__list-scrollable{flex:1;overflow-y:auto}.roster-app__job-card{border-bottom:1px solid var(--border-light);cursor:pointer;background-color:var(--surface-white);transition:all var(--transition-fast);border-left:3px solid #0000;padding:14px;position:relative}.roster-app__job-card:hover{background-color:var(--surface-muted)}.roster-app__job-card--active{border-left-color:var(--accent-blue);background-color:var(--blue-bg-tint)!important}.roster-app__job-card--dead{opacity:.5}.roster-app__job-card--dead .card-title{text-decoration:line-through}.roster-app__job-card .card-row-top{justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:5px;display:flex}.roster-app__job-card .card-title{color:var(--text-primary);flex:1;font-size:14px;font-weight:700;line-height:1.25}.roster-app__job-card .card-meta{color:var(--text-muted);margin-bottom:8px;font-size:13px}.roster-app__job-card .card-row-bottom{color:var(--text-muted);align-items:center;gap:6px;font-size:12px;display:flex}.roster-app__job-card .fresh-dot{border-radius:50%;width:6px;height:6px;display:inline-block}.roster-app__job-card .fresh-dot--green{background-color:var(--fresh-green)}.roster-app__job-card .fresh-dot--amber{background-color:var(--aging-amber)}.roster-app__job-card .fresh-dot--red{background-color:var(--danger-red)}.roster-app__job-card .age-text{font-weight:500}.roster-app__job-card .card-divider{background-color:#e2e1de;width:1px;height:10px}.roster-app__job-card .status-badge{border-radius:var(--radius-pill);white-space:nowrap;flex-shrink:0;padding:3px 9px;font-size:11px;font-weight:600}.roster-app__job-card .status-badge--new{color:var(--accent-blue-light);background-color:var(--blue-bg-tint);border:1px solid var(--blue-border-tint)}.roster-app__job-card .status-badge--needs-verification{color:var(--technical-orange);background-color:var(--technical-bg);border:1px solid var(--phone-amber-border)}.roster-app__job-card .status-badge--applied{color:var(--applied-purple);background-color:var(--applied-purple-bg);border:1px solid var(--applied-purple-border)}.roster-app__job-card .status-badge--interviewing{color:var(--phone-amber);background-color:var(--phone-amber-bg);border:1px solid var(--phone-amber-border)}.roster-app__job-card .status-badge--dead{color:var(--text-placeholder);background-color:var(--border-default);border:1px solid var(--border-default)}.roster-app__detail-panel{background-color:var(--surface-white);flex:1;padding:28px 32px;overflow-y:auto}@media (width<=1023px){.roster-app__detail-panel{padding:20px}}.roster-app__detail-content{flex-direction:column;gap:22px;max-width:800px;margin:0 auto;display:flex}.roster-app__detail-header-block{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:20px;display:flex}.roster-app__detail-titles{flex:1}.roster-app__detail-titles .title-row{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:6px;display:flex}.roster-app__detail-titles h1{color:var(--text-primary);letter-spacing:-.03em;font-size:22px;font-weight:800;line-height:1.2}.roster-app__detail-titles .detail-subtitle{color:var(--text-secondary);font-size:14px}.roster-app__detail-titles .detail-subtitle strong{color:var(--text-primary);font-weight:700}.roster-app__detail-actions{align-items:center;gap:10px;display:flex}@media (width<=575px){.roster-app__detail-actions{width:100%}}.roster-app .dead-notice-banner{color:var(--danger-red);margin-top:-10px;font-size:13px;font-weight:600}.roster-app__pills-row{flex-wrap:wrap;gap:6px;display:flex}.roster-app__detail-divider{background-color:var(--border-light);height:1px}.roster-app__pipeline-card{background-color:var(--surface-muted);border:1.5px solid var(--border-default);border-radius:var(--radius-large);flex-direction:column;gap:20px;padding:20px 22px;display:flex}.roster-app__pipeline-header{justify-content:space-between;align-items:center;display:flex}.roster-app__pipeline-header .pipeline-label{color:var(--text-primary);letter-spacing:.05em;text-transform:uppercase;font-size:13px;font-weight:700}.roster-app__pipeline-header .stage-badge{border-radius:var(--radius-pill);padding:4px 10px;font-size:12px;font-weight:600}.roster-app__pipeline-header .stage-badge--new{color:var(--accent-blue-light);background-color:var(--blue-bg-tint);border:1.5px solid var(--blue-border-tint)}.roster-app__pipeline-header .stage-badge--needs-verification{color:var(--technical-orange);background-color:var(--technical-bg);border:1.5px solid var(--phone-amber-border)}.roster-app__pipeline-header .stage-badge--applied{color:var(--applied-purple);background-color:var(--applied-purple-bg);border:1.5px solid var(--applied-purple-border)}.roster-app__pipeline-header .stage-badge--phone_screen{color:var(--phone-amber);background-color:var(--phone-amber-bg);border:1.5px solid var(--phone-amber-border)}.roster-app__pipeline-header .stage-badge--technical{color:var(--technical-orange);background-color:var(--technical-bg);border:1.5px solid var(--border-default)}.roster-app__pipeline-header .stage-badge--onsite{color:var(--onsite-rose);background-color:var(--onsite-bg);border:1.5px solid var(--border-default)}.roster-app__pipeline-header .stage-badge--offer{color:var(--offer-green);background-color:var(--offer-bg);border:1.5px solid var(--border-default)}.roster-app__pipeline-header .stage-badge--dead{color:var(--text-placeholder);background-color:var(--border-default);border:1.5px solid var(--border-default)}.roster-app__stepper{justify-content:space-between;align-items:center;padding:0 10px;display:flex;position:relative}.roster-app__step-node{z-index:2;cursor:pointer;flex-direction:column;align-items:center;gap:8px;width:60px;display:flex}.roster-app__step-node .node-circle{background-color:var(--surface-white);width:28px;height:28px;transition:all var(--transition-normal);border:2px solid #d1d0cd;border-radius:50%;justify-content:center;align-items:center;display:flex}.roster-app__step-node .node-label{color:var(--text-placeholder);text-align:center;white-space:nowrap;transition:all var(--transition-normal);font-size:10px;font-weight:600}.roster-app__step-node--completed .node-circle{background-color:var(--accent-blue);border-color:var(--accent-blue)}.roster-app__step-node--completed .node-circle svg{stroke:#fff}.roster-app__step-node--completed .node-label{color:var(--accent-blue);font-weight:700}.roster-app__step-node--active .node-circle{background-color:var(--accent-blue);border-color:var(--accent-blue);box-shadow:0 0 0 3px var(--accent-blue)}.roster-app__step-node--active .node-circle .inner-dot{background-color:#fff;border-radius:50%;width:8px;height:8px}.roster-app__step-node--active .node-label{color:var(--accent-blue);font-weight:700}.roster-app__step-connector{background-color:var(--border-default);z-index:1;height:2px;position:absolute;top:14px;left:40px;right:40px}.roster-app__step-connector .connector-fill{background-color:var(--accent-blue);height:100%;transition:width var(--transition-normal) ease}.roster-app__pipeline-actions{gap:8px;display:flex}@media (width<=575px){.roster-app__pipeline-actions{flex-direction:column}}.roster-app__desc-section{flex-direction:column;gap:10px;display:flex}.roster-app__desc-section h3{color:var(--text-primary);font-size:14px;font-weight:700}.roster-app__desc-section .desc-text{color:var(--text-secondary);font-size:14px;line-height:1.6}.roster-app__desc-section .desc-placeholder{border:1.5px dashed var(--border-default);background-image:repeating-linear-gradient(45deg, var(--surface-subtle), var(--surface-subtle) 10px, var(--surface-white) 10px, var(--surface-white) 20px);border-radius:var(--radius-large);height:135px;color:var(--text-placeholder);justify-content:center;align-items:center;font-size:14px;font-weight:600;display:flex}.roster-app__notes-section{flex-direction:column;gap:10px;display:flex}.roster-app__notes-section .notes-header{justify-content:space-between;align-items:center;display:flex}.roster-app__notes-section .notes-header h3{color:var(--text-primary);font-size:14px;font-weight:700}.roster-app__notes-section .notes-header .autosave-tag{color:var(--text-placeholder);align-items:center;gap:4px;font-size:11px;font-weight:500;display:flex}.roster-app__notes-section textarea{background-color:var(--note-yellow-bg);border:1.5px solid var(--note-yellow-border);border-radius:var(--radius-medium);color:#78350f;resize:vertical;width:100%;min-height:104px;transition:box-shadow var(--transition-fast);outline:none;padding:14px;font-size:14px;line-height:1.5}.roster-app__notes-section textarea::placeholder{color:#c9bb5a}.roster-app__notes-section textarea:focus{box-shadow:0 0 0 3px #fde68a80}.roster-app__detail-empty{height:100%;color:var(--text-placeholder);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:14px;display:flex}.roster-app__detail-empty svg{stroke:var(--text-disabled)}.roster-app__detail-empty p{max-width:320px;font-size:14px}.roster-app__kanban-board{flex:1;gap:10px;height:calc(100% - 56px);padding:14px 16px;display:flex;overflow-x:auto}.roster-app__kanban-column{background-color:var(--surface-subtle);border-radius:var(--radius-large);min-width:186px;height:100%;transition:all var(--transition-fast);border:1.5px solid #0000;flex-direction:column;flex:1;gap:8px;padding:8px;display:flex}.roster-app__kanban-column.drag-over{background-color:var(--blue-bg-tint);border-color:var(--accent-blue)}.roster-app__kanban-column--new{background-color:var(--blue-bg-tint);border-color:var(--blue-border-tint)}.roster-app__kanban-column--applied{background-color:var(--applied-purple-bg);border-color:var(--applied-purple-border)}.roster-app__kanban-column--phone_screen{background-color:var(--phone-amber-bg);border-color:var(--phone-amber-border)}.roster-app__kanban-column--technical{background-color:var(--technical-bg);border-color:var(--border-default)}.roster-app__kanban-column--onsite{background-color:var(--onsite-bg);border-color:var(--border-default)}.roster-app__kanban-column--offer{background-color:var(--offer-bg);border-color:var(--border-default)}.roster-app__kanban-column--dead{background-color:var(--surface-subtle);border-color:var(--border-default)}.roster-app__kanban-column .column-header{color:var(--text-primary);text-transform:uppercase;letter-spacing:.05em;justify-content:space-between;align-items:center;padding:8px 12px;font-size:13px;font-weight:700;display:flex}.roster-app__kanban-column .column-header .col-title--new{color:var(--accent-blue-light)}.roster-app__kanban-column .column-header .col-title--applied{color:var(--applied-purple)}.roster-app__kanban-column .column-header .col-title--phone_screen{color:var(--phone-amber)}.roster-app__kanban-column .column-header .col-title--technical{color:var(--technical-orange)}.roster-app__kanban-column .column-header .col-title--onsite{color:var(--onsite-rose)}.roster-app__kanban-column .column-header .col-title--offer{color:var(--offer-green)}.roster-app__kanban-column .column-header .col-title--dead{color:var(--text-placeholder)}.roster-app__kanban-column .column-header .count-badge{background-color:var(--surface-white);color:var(--text-primary);border-radius:var(--radius-pill);padding:2px 7px;font-size:11px;font-weight:600;box-shadow:0 1px 2px #0000000d}.roster-app__kanban-scrollable{scrollbar-width:thin;flex-direction:column;flex:1;gap:8px;padding-bottom:20px;display:flex;overflow-y:auto}.roster-app__kanban-scrollable::-webkit-scrollbar{width:4px}.roster-app__kanban-scrollable::-webkit-scrollbar-thumb{background-color:var(--border-default);border-radius:2px}.roster-app__kanban-card{background-color:var(--surface-white);border:1px solid var(--border-default);border-radius:var(--radius-medium);cursor:grab;-webkit-user-select:none;user-select:none;transition:all var(--transition-fast);box-shadow:var(--shadow-kanban-card);padding:12px}.roster-app__kanban-card:hover{border-color:var(--text-placeholder);box-shadow:0 4px 12px #0000000d}.roster-app__kanban-card:active{cursor:grabbing}.roster-app__kanban-card--dead{opacity:.6;border-style:dashed}.roster-app__kanban-card .card-title{color:var(--text-primary);margin-bottom:4px;font-size:13px;font-weight:700;line-height:1.3}.roster-app__kanban-card .card-subtitle{color:var(--text-muted);margin-bottom:8px;font-size:12px}.roster-app__kanban-card .card-footer{color:var(--text-muted);justify-content:space-between;align-items:center;font-size:11px;display:flex}.roster-app__kanban-card .footer-left{align-items:center;gap:4px;display:flex}.roster-app__kanban-card .fresh-dot{border-radius:50%;width:5px;height:5px}.roster-app__kanban-card .fresh-dot--green{background-color:var(--fresh-green)}.roster-app__kanban-card .fresh-dot--amber{background-color:var(--aging-amber)}.roster-app__kanban-card .fresh-dot--red{background-color:var(--danger-red)}.roster-app__kanban-card .flag-btn{color:var(--text-placeholder);cursor:pointer;background:0 0;border:none;padding:2px;font-size:12px;line-height:1}.roster-app__kanban-card .flag-btn:hover,.roster-app__kanban-card .flag-btn--flagged{color:var(--danger-red)}.roster-app__kanban-column-placeholder{border:1.5px dashed var(--border-default);border-radius:var(--radius-medium);color:var(--text-placeholder);text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:8px;margin:8px;padding:16px;font-size:12px;display:flex}.roster-app__kanban-column-placeholder .placeholder-plus{border:1.5px solid var(--text-placeholder);border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:14px;font-weight:700;display:flex}.roster-app .btn-primary{background-color:var(--accent-blue);color:#fff;border-radius:var(--radius-medium);cursor:pointer;box-shadow:var(--shadow-cta);transition:all var(--transition-fast);border:none;justify-content:center;align-items:center;gap:6px;padding:10px 20px;font-size:13px;font-weight:600;display:inline-flex}.roster-app .btn-primary:hover:not(:disabled){background-color:var(--accent-blue-light);box-shadow:0 4px 12px #2563eb59}.roster-app .btn-primary:disabled{opacity:.6;cursor:not-allowed}.roster-app .btn-ghost{background-color:var(--surface-white);color:var(--text-secondary);border:1.5px solid var(--border-default);border-radius:var(--radius-medium);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:600;display:inline-flex}.roster-app .btn-ghost:hover{background-color:var(--surface-subtle);color:var(--text-primary)}.roster-app .btn-danger-ghost{background-color:var(--surface-white);color:var(--danger-red);border:1.5px solid var(--danger-border);border-radius:var(--radius-medium);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:600;display:inline-flex}.roster-app .btn-danger-ghost:hover{background-color:var(--danger-bg);border-color:var(--danger-red)}.roster-app .chip-pill{color:var(--text-secondary);background-color:var(--surface-subtle);border:1px solid var(--border-default);white-space:nowrap;border-radius:7px;padding:5px 12px;font-size:12px;font-weight:500}.roster-app__mobile-shell{background-color:var(--surface-white);border:9px solid #18181b;border-radius:42px;flex-direction:column;width:390px;height:844px;display:flex;position:relative;overflow:hidden;box-shadow:0 24px 64px #0006}@media (width<=1023px){.roster-app__mobile-shell{border:none;border-radius:0;width:100vw;height:100vh}}.roster-app__mobile-status-bar{background-color:var(--surface-white);flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 22px 7px;display:flex}.roster-app__mobile-status-bar .status-time{color:var(--text-primary);font-size:15px;font-weight:700}.roster-app__mobile-status-bar .status-icons{align-items:center;gap:6px;display:flex}.roster-app__mobile-header{border-bottom:1px solid var(--border-light);flex-shrink:0;align-items:center;gap:10px;padding:16px 16px 12px;display:flex}.roster-app__mobile-header .mobile-logo{flex-shrink:0;align-items:center;gap:7px;display:flex}.roster-app__mobile-header .mobile-logo-box{background-color:var(--accent-blue);border-radius:6px;justify-content:center;align-items:center;width:26px;height:26px;display:flex}.roster-app__mobile-header .mobile-logo-text{color:var(--text-primary);letter-spacing:-.03em;font-size:16px;font-weight:800}.roster-app__mobile-header .mobile-search-input{background-color:var(--surface-subtle);border:1px solid var(--border-default);border-radius:var(--radius-medium);outline:none;flex:1;height:34px;padding:0 10px 0 28px;font-size:13px}.roster-app__mobile-header .mobile-search-input::placeholder{color:var(--text-placeholder)}.roster-app__mobile-chips-row{border-bottom:1px solid var(--border-light);scrollbar-width:none;flex-shrink:0;gap:8px;padding:10px 16px;display:flex;overflow-x:auto}.roster-app__mobile-chips-row::-webkit-scrollbar{display:none}.roster-app__mobile-chips-row .mobile-chip{border-radius:var(--radius-pill);white-space:nowrap;cursor:pointer;background-color:var(--surface-subtle);border:1px solid var(--border-default);color:var(--text-secondary);transition:all var(--transition-fast);padding:6px 14px;font-size:12px;font-weight:600}.roster-app__mobile-chips-row .mobile-chip--active{background-color:var(--accent-blue);border-color:var(--accent-blue);color:#fff}.roster-app__mobile-results-bar{color:var(--text-muted);border-bottom:1px solid var(--border-light);flex-shrink:0;justify-content:space-between;align-items:center;padding:10px 16px;font-size:12px;display:flex}.roster-app__mobile-results-bar strong{color:var(--text-primary)}.roster-app__mobile-list-content{flex:1;overflow-y:auto}.roster-app__mobile-nav-bar{border-bottom:1px solid var(--border-light);background-color:var(--surface-white);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 16px 12px;display:flex}.roster-app__mobile-nav-bar .back-btn{cursor:pointer;color:var(--accent-blue);background:0 0;border:none;align-items:center;gap:5px;padding:0;font-size:14px;font-weight:600;display:flex}.roster-app__mobile-nav-bar .flag-btn{border:1.5px solid var(--danger-border);border-radius:var(--radius-medium);background-color:var(--surface-white);color:var(--danger-red);cursor:pointer;padding:6px 12px;font-size:12px;font-weight:600}.roster-app__mobile-nav-bar .flag-btn--flagged{background-color:var(--danger-bg)}.roster-app__mobile-detail-scrollable{background-color:var(--surface-white);flex:1;overflow-y:auto}.roster-app__mobile-bottom-nav{border-top:1px solid var(--border-default);background-color:var(--surface-white);flex-shrink:0;justify-content:space-around;align-items:center;height:64px;padding-bottom:8px;display:flex}.roster-app__mobile-bottom-nav .nav-tab{cursor:pointer;width:70px;height:100%;color:var(--text-placeholder);transition:color var(--transition-fast);background:0 0;border:none;border-top:2.5px solid #0000;flex-direction:column;justify-content:center;align-items:center;gap:4px;font-size:10px;font-weight:600;display:flex}.roster-app__mobile-bottom-nav .nav-tab svg{fill:var(--text-placeholder)}.roster-app__mobile-bottom-nav .nav-tab:hover{color:var(--text-muted)}.roster-app__mobile-bottom-nav .nav-tab:hover svg{fill:var(--text-muted)}.roster-app__mobile-bottom-nav .nav-tab--active{color:var(--accent-blue);border-top-color:var(--accent-blue)}.roster-app__mobile-bottom-nav .nav-tab--active svg{fill:var(--accent-blue)}.roster-app__mobile-filters{background-color:var(--surface-subtle);flex:1;padding:20px;overflow-y:auto}@keyframes pulse-glow{0%,to{opacity:.6;box-shadow:0 0 4px var(--accent-blue)}50%{opacity:1;box-shadow:0 0 12px var(--accent-blue)}}
