.auth-layout{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--surface-0);position:relative;overflow:hidden;padding:var(--space-4)}.auth-bg-orb{position:absolute;border-radius:50%;filter:blur(120px);opacity:.4;pointer-events:none}.auth-bg-orb-1{width:500px;height:500px;background:radial-gradient(circle,var(--color-primary-700) 0%,transparent 70%);top:-150px;right:-100px}.auth-bg-orb-2{width:400px;height:400px;background:radial-gradient(circle,#1e3a8a 0%,transparent 70%);bottom:-100px;left:-80px}.auth-bg-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(148,163,184,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(148,163,184,.03) 1px,transparent 1px);background-size:60px 60px;pointer-events:none}.auth-container{width:100%;max-width:420px;background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-xl);padding:var(--space-10);position:relative;z-index:1;box-shadow:var(--shadow-xl)}.auth-header{text-align:center;margin-bottom:var(--space-8)}.auth-logo{width:56px;height:56px;border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--color-primary-500),var(--color-primary-700));display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-4);color:#fff;box-shadow:0 4px 20px #10b9814d}.auth-title{font-size:var(--font-2xl);font-weight:var(--weight-bold);color:var(--text-primary);letter-spacing:-.02em}.auth-subtitle{font-size:var(--font-sm);color:var(--text-tertiary);margin-top:var(--space-1);letter-spacing:.02em;text-transform:uppercase}.auth-footer{position:absolute;bottom:var(--space-6);text-align:center;z-index:1}.auth-footer p{font-size:var(--font-xs);color:var(--text-muted)}.auth-form{display:flex;flex-direction:column;gap:var(--space-5)}.auth-form .input-icon-group{position:relative}.auth-form .input-icon{position:absolute;left:var(--space-4);top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none;transition:color var(--transition-fast)}.auth-form .input-field:focus~.input-icon,.auth-form .input-field:focus+.input-icon{color:var(--color-primary-400)}.auth-form .input-with-icon{padding-left:calc(var(--space-4) + 24px + var(--space-2))}.auth-error{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:#ef444414;border:1px solid rgba(239,68,68,.15);border-radius:var(--radius-md);font-size:var(--font-sm);color:var(--color-danger-400)}.auth-submit{width:100%;margin-top:var(--space-2)}.totp-step{text-align:center}.totp-step p{font-size:var(--font-sm);color:var(--text-secondary);margin-bottom:var(--space-5)}.totp-input{text-align:center;font-size:var(--font-2xl);letter-spacing:.3em;font-weight:var(--weight-semibold)}.totp-back{margin-top:var(--space-4);font-size:var(--font-sm);color:var(--text-tertiary);display:inline-flex;align-items:center;gap:var(--space-1);cursor:pointer;transition:color var(--transition-fast)}.totp-back:hover{color:var(--text-secondary)}@media(max-width:768px){.auth-layout{padding:var(--space-3);justify-content:flex-start;padding-top:10vh}.auth-container{padding:var(--space-5) var(--space-4);border-radius:var(--radius-lg)}.auth-header{margin-bottom:var(--space-5)}.auth-logo{width:48px;height:48px;margin-bottom:var(--space-3)}.auth-title{font-size:var(--font-xl)}.auth-form{gap:var(--space-4)}.totp-input{font-size:var(--font-xl);letter-spacing:.2em}.auth-footer{position:relative;bottom:auto;margin-top:var(--space-6)}}.nd-container{position:relative}.nd-trigger{position:relative;color:var(--text-secondary);transition:all .2s ease}.nd-trigger:hover{color:var(--text-primary);background:var(--surface-hover)}.nd-badge{position:absolute;top:2px;right:2px;background:var(--color-danger-500);color:#fff;font-size:.65rem;font-weight:var(--weight-bold);height:16px;min-width:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px;border:2px solid var(--surface-100)}.nd-popover{position:absolute;top:100%;right:-8px;margin-top:var(--space-2);width:320px;background:var(--surface-100);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);z-index:50;display:flex;flex-direction:column;overflow:hidden;transform-origin:top right}.nd-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-subtle);background:var(--surface-200)}.nd-title{font-size:var(--font-sm);font-weight:var(--weight-bold);color:var(--text-primary)}.nd-mark-all{font-size:var(--font-xs);padding:var(--space-1) var(--space-2);color:var(--color-primary-400)}.nd-mark-all:hover{color:var(--color-primary-300)}.nd-body{max-height:350px;overflow-y:auto}.nd-empty{padding:var(--space-6) var(--space-4);text-align:center;color:var(--text-tertiary);font-size:var(--font-sm)}.nd-item{display:flex;align-items:flex-start;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-subtle);cursor:pointer;transition:background .2s ease;position:relative}.nd-item:hover{background:var(--surface-hover)}.nd-item:last-child{border-bottom:none}.nd-item-unread{background:#ffffff05;border-left:2px solid var(--nd-accent, var(--color-primary-500));padding-left:calc(var(--space-4) - 2px)}.nd-item-icon{flex-shrink:0;width:28px;height:28px;border-radius:7px;display:flex;align-items:center;justify-content:center;margin-top:1px}.nd-shift-chips{display:flex;flex-wrap:wrap;gap:3px;margin:3px 0 2px}.nd-shift-chip{font-size:10px;font-weight:var(--weight-bold);padding:1px 6px;border-radius:4px;border:1px solid;letter-spacing:.03em}.nd-shift-more{font-size:10px;color:var(--text-muted);padding:1px 4px;align-self:center}.nd-item-content{flex:1}.nd-item-title{font-size:var(--font-sm);font-weight:var(--weight-bold);color:var(--text-primary);margin-bottom:2px}.nd-item-message{font-size:var(--font-xs);color:var(--text-secondary);line-height:1.4;margin-bottom:4px}.nd-item-time{font-size:.65rem;color:var(--text-tertiary)}.nd-unread-dot{width:8px;height:8px;border-radius:50%;background:var(--color-primary-500);margin-top:6px;margin-left:var(--space-2);flex-shrink:0}.nd-footer{padding:var(--space-2);border-top:1px solid var(--border-subtle);background:var(--surface-200);text-align:center}@media(max-width:768px){.nd-popover{position:fixed;top:var(--header-height, 52px);left:0;right:0;width:100%;max-width:100vw;border-radius:0 0 var(--radius-lg) var(--radius-lg);max-height:calc(100vh - var(--header-height, 52px) - var(--space-4))}.nd-body{max-height:60vh}}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--surface-100);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:50;transition:width var(--transition-base),transform var(--transition-base)}.sidebar-collapsed .sidebar{width:var(--sidebar-collapsed)}.sidebar-header{height:var(--header-height);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-4);border-bottom:1px solid var(--border-subtle)}.sidebar-brand{display:flex;align-items:center;gap:var(--space-3);overflow:hidden}.sidebar-logo{width:36px;height:36px;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--color-primary-500),var(--color-primary-700));display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.sidebar-brand-text{font-size:var(--font-lg);font-weight:var(--weight-bold);color:var(--text-primary);white-space:nowrap;letter-spacing:-.01em}.sidebar-collapse-btn{color:var(--text-tertiary);flex-shrink:0}.sidebar-collapse-btn:hover{color:var(--text-secondary);background:var(--surface-300)}.sidebar-nav{flex:1;padding:var(--space-3) var(--space-2);display:flex;flex-direction:column;gap:2px;overflow-y:auto}.sidebar-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--font-sm);font-weight:var(--weight-medium);text-decoration:none;transition:all var(--transition-fast);white-space:nowrap;overflow:hidden}.sidebar-link:hover{color:var(--text-primary);background:var(--surface-300)}.sidebar-link-active{color:var(--color-primary-400)!important;background:#10b98114!important}.sidebar-link-active .sidebar-link-icon{color:var(--color-primary-400)}.sidebar-link-icon{flex-shrink:0;display:flex;align-items:center}.sidebar-link-label{overflow:hidden;text-overflow:ellipsis}.sidebar-collapsed .sidebar-brand,.sidebar-collapsed .sidebar-link-label,.sidebar-collapsed .sidebar-user-info{display:none}.sidebar-collapsed .sidebar-collapse-btn{margin:0 auto}.sidebar-collapsed .sidebar-link{justify-content:center;padding:var(--space-3)}.sidebar-collapsed .sidebar-header{justify-content:center}.sidebar-collapsed .sidebar-footer{justify-content:center;flex-direction:column;gap:var(--space-2)}.sidebar-footer{padding:var(--space-3);border-top:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:space-between;gap:var(--space-2)}.sidebar-user{display:flex;align-items:center;gap:var(--space-3);overflow:hidden;flex:1;min-width:0}.sidebar-user-info{display:flex;flex-direction:column;overflow:hidden;min-width:0}.sidebar-user-name{font-size:var(--font-sm);font-weight:var(--weight-semibold);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:var(--font-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em}.sidebar-logout{color:var(--text-tertiary);flex-shrink:0}.sidebar-logout:hover{color:var(--color-danger-400);background:#ef444414}.sidebar-overlay{display:none}.app-main{flex:1;margin-left:var(--sidebar-width);display:flex;flex-direction:column;min-height:100vh;transition:margin-left var(--transition-base)}.sidebar-collapsed .app-main{margin-left:var(--sidebar-collapsed)}.app-header{height:var(--header-height);background:var(--surface-100);border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;padding:0 var(--space-6);position:sticky;top:0;z-index:30;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.mobile-menu-btn,.header-page-title{display:none}.header-spacer{flex:1}.header-actions{display:flex;align-items:center;gap:var(--space-3)}.header-notification-btn{position:relative;color:var(--text-secondary)}.header-notification-btn:hover{color:var(--text-primary);background:var(--surface-300)}.notification-badge{position:absolute;top:2px;right:2px;min-width:16px;height:16px;font-size:10px;font-weight:var(--weight-bold);color:#fff;background:var(--color-danger-500);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;padding:0 4px;line-height:1}.header-user-pill{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3) var(--space-1) var(--space-1);background:var(--surface-200);border:1px solid var(--border-subtle);border-radius:var(--radius-full)}.header-user-name{font-size:var(--font-sm);font-weight:var(--weight-medium);color:var(--text-primary);white-space:nowrap}.app-content{flex:1;padding:var(--space-4);padding-bottom:var(--space-3);max-width:var(--max-content);width:100%;margin:0 auto;display:flex;flex-direction:column}@media(max-width:1024px){.sidebar-collapse-btn{display:none}}@media(max-width:768px){.sidebar{transform:translate(-100%);width:280px;box-shadow:var(--shadow-xl)}.sidebar-open{transform:translate(0)}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:40;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.app-main{margin-left:0!important}.mobile-menu-btn{display:flex}.header-page-title{display:block;font-size:var(--font-sm);font-weight:var(--weight-semibold);color:var(--text-primary);margin-left:var(--space-2);letter-spacing:-.01em}.header-user-name{display:none}.app-content{padding:var(--space-2) var(--space-3)}.sidebar{width:260px}.app-header{padding:0 var(--space-3)}.header-actions{gap:var(--space-1)}.header-user-pill{padding:var(--space-1)}.app-content{padding-bottom:calc(var(--space-3) + 68px)}}.bottom-tab-bar{display:none}@media(max-width:768px){.bottom-tab-bar{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:40;height:64px;background:var(--surface-100);border-top:1px solid var(--border-subtle);padding:0 var(--space-1);padding-bottom:env(safe-area-inset-bottom,0px);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}.btb-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;text-decoration:none;color:var(--text-tertiary);font-size:10px;font-weight:var(--weight-semibold);letter-spacing:.03em;transition:color var(--transition-fast);position:relative;-webkit-tap-highlight-color:transparent}.btb-tab svg{transition:transform var(--transition-fast),color var(--transition-fast)}.btb-tab:active svg{transform:scale(.85)}.btb-tab-active{color:var(--color-primary-400)}.btb-tab-active:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:24px;height:2px;border-radius:0 0 2px 2px;background:var(--color-primary-400)}}.schedule-calendar{position:relative;animation:fadeIn var(--transition-base) ease-out}.calendar-loading{opacity:.6;pointer-events:none}.calendar-loader{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:20;display:flex;flex-direction:column;align-items:center;gap:var(--space-3);color:var(--text-secondary);font-size:var(--font-sm)}.fc{--fc-border-color: var(--border-subtle);--fc-bg-event-opacity: 1;--fc-event-border-color: transparent;--fc-today-bg-color: rgba(16, 185, 129, .04);--fc-neutral-bg-color: var(--surface-100);--fc-page-bg-color: transparent;--fc-highlight-color: rgba(16, 185, 129, .08);--fc-non-business-color: rgba(0, 0, 0, .1);font-family:var(--font-family)!important}.fc .fc-toolbar{margin-bottom:10px!important;gap:8px!important;flex-wrap:wrap;align-items:center;padding:10px 12px 0}.fc .fc-toolbar-title{font-size:var(--font-lg)!important;font-weight:var(--weight-semibold)!important;color:var(--text-primary)!important;text-transform:capitalize;letter-spacing:-.01em}.fc .fc-button{background:var(--surface-300)!important;border:1px solid var(--border-subtle)!important;color:var(--text-secondary)!important;font-family:var(--font-family)!important;font-size:var(--font-xs)!important;font-weight:var(--weight-medium)!important;padding:5px 12px!important;border-radius:7px!important;transition:all var(--transition-fast)!important;box-shadow:none!important;text-transform:none!important;line-height:1.4!important}.fc .fc-button:hover{background:var(--surface-400)!important;color:var(--text-primary)!important;border-color:var(--border-default)!important}.fc .fc-button-active,.fc .fc-button:active{background:var(--color-primary-600)!important;border-color:var(--color-primary-500)!important;color:#fff!important;box-shadow:inset 0 1px #0003!important}.fc .fc-button-group{border-radius:8px!important;overflow:hidden;box-shadow:0 0 0 1px var(--border-subtle)}.fc .fc-button-group>.fc-button{border-radius:0!important;border-left-color:transparent!important;border-right-color:transparent!important;border-top-color:transparent!important;border-bottom-color:transparent!important}.fc .fc-button-group>.fc-button+.fc-button{border-left:1px solid var(--border-subtle)!important}.fc .fc-prev-button,.fc .fc-next-button{padding:5px 9px!important;border-radius:0!important}.fc .fc-today-button{border-radius:7px!important}.fc .fc-today-button:disabled{opacity:.35!important}.fc .fc-col-header-cell{background:var(--surface-200)!important;border-color:var(--border-subtle)!important;padding:6px 0!important}.fc .fc-col-header-cell-cushion{color:var(--text-secondary)!important;font-size:var(--font-xs)!important;font-weight:var(--weight-semibold)!important;text-transform:uppercase!important;letter-spacing:.06em!important;text-decoration:none!important}.fc .fc-daygrid-day{background:var(--surface-100)!important;transition:background var(--transition-fast)}.fc .fc-daygrid-day:hover{background:var(--surface-200)!important}.fc .fc-daygrid-day.fc-day-today{background:var(--fc-today-bg-color)!important}.fc .fc-daygrid-day-number{color:var(--text-secondary)!important;font-size:11px!important;font-weight:var(--weight-medium)!important;padding:4px 6px!important;text-decoration:none!important}.fc .fc-day-today .fc-daygrid-day-number{color:var(--color-primary-400)!important;font-weight:var(--weight-bold)!important}.fc .fc-daygrid-day-frame{min-height:88px!important}.fc .fc-day-other .fc-daygrid-day-number{color:var(--text-muted)!important;opacity:.5}.fc .fc-day-other{background:var(--surface-50)!important}.fc .fc-day-sat,.fc .fc-day-sun{background:#ffffff05!important}.fc .fc-day-sat.fc-day-other,.fc .fc-day-sun.fc-day-other{background:#ffffff02!important}.fc .fc-event-mirror{opacity:.92!important;box-shadow:0 10px 32px #0009!important;transform:scale(1.03) translateY(-2px)!important;pointer-events:none!important;background-color:var(--fc-event-bg-color)!important}.fc .fc-event-mirror .fc-event-main{background-color:inherit!important}.fc .fc-highlight{background:#10b9811a!important;border-radius:4px!important}.fc .fc-event{border-radius:var(--radius-sm)!important;border-width:2px!important;cursor:pointer!important;margin:1px 2px!important;transition:transform var(--transition-fast),box-shadow var(--transition-fast)!important;overflow:hidden}.fc .fc-event:hover{transform:translateY(-1px)!important;box-shadow:0 4px 12px #0000004d!important;z-index:10!important}.fc-shift-draft{border-style:dashed!important;opacity:.85}.fc-shift-cancelled{opacity:.4;text-decoration:line-through}.fc-event-inner{padding:2px 6px;display:flex;flex-direction:column;gap:1px;min-height:22px;position:relative;overflow:hidden}.fc-event-row{display:flex;align-items:center;gap:4px}.fc-event-code{font-size:11px;font-weight:var(--weight-bold);letter-spacing:.02em;white-space:nowrap}.fc-event-time{font-size:10px;opacity:.85;white-space:nowrap}.fc-event-count{font-size:9px;font-weight:var(--weight-bold);background:#00000059;color:#ffffffe6;padding:0 4px;border-radius:4px;letter-spacing:.02em;white-space:nowrap;flex-shrink:0}.fc-event-user{font-size:10px;opacity:.8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fc-event-draft-badge{font-size:9px;background:#0000004d;padding:0 4px;border-radius:3px;align-self:flex-start;text-transform:uppercase;letter-spacing:.04em;font-weight:var(--weight-semibold)}.fc-event-notes-dot{position:absolute;top:3px;right:4px;font-size:8px;color:var(--color-accent-400);line-height:1}.fc .fc-timegrid-slot{height:48px!important;border-color:var(--border-subtle)!important}.fc .fc-timegrid-slot-label-cushion,.fc .fc-timegrid-axis-cushion{color:var(--text-muted)!important;font-size:var(--font-xs)!important}.fc .fc-timegrid-now-indicator-line{border-color:var(--color-primary-500)!important;border-width:2px!important}.fc .fc-timegrid-now-indicator-arrow{border-top-color:transparent!important;border-bottom-color:transparent!important;border-left-color:var(--color-primary-500)!important}.fc .fc-daygrid-more-link{color:var(--color-primary-400)!important;font-size:var(--font-xs)!important;font-weight:var(--weight-semibold)!important}.fc .fc-scroller{scrollbar-width:thin;scrollbar-color:var(--surface-500) transparent}.fc .fc-popover{background:var(--surface-200)!important;border:1px solid var(--border-default)!important;border-radius:var(--radius-lg)!important;box-shadow:var(--shadow-lg)!important}.fc .fc-popover-header{background:var(--surface-300)!important;color:var(--text-primary)!important;font-size:var(--font-sm)!important;padding:var(--space-2) var(--space-3)!important;border-radius:var(--radius-lg) var(--radius-lg) 0 0!important}@media(max-width:768px){.fc .fc-toolbar{flex-direction:column;gap:var(--space-2)!important;padding:6px 8px 0!important}.fc .fc-toolbar-title{font-size:var(--font-base)!important}.fc .fc-toolbar .fc-button{padding:4px 8px!important;font-size:12px!important}.fc .fc-daygrid-day-frame{min-height:54px!important;padding:1px!important}.fc .fc-daygrid-day-number{font-size:11px!important;padding:2px 4px!important}.fc .fc-col-header-cell-cushion{font-size:10px!important;padding:4px 2px!important}.fc .fc-event{margin:0 1px 1px!important;border-width:1px!important;border-radius:3px!important}.fc-event-inner{padding:1px 3px;min-height:16px;gap:0}.fc-event-code{font-size:9px}.fc-event-time{font-size:8px}.fc-event-user{display:none}.fc-event-count{font-size:8px;padding:0 3px}.fc-event-notes-dot,.fc-event-draft-badge{display:none}.fc .fc-daygrid-more-link{font-size:9px!important;padding:0 2px!important}}.swap-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:480px;max-width:calc(100vw - var(--space-8));max-height:90vh;background:var(--surface-100);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);z-index:200;display:flex;flex-direction:column;overflow:hidden}.swap-modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-subtle);flex-shrink:0}.swap-modal-title-row{display:flex;align-items:center;gap:var(--space-2);color:var(--text-primary)}.swap-modal-title{font-size:var(--font-lg);font-weight:var(--weight-semibold);margin:0}.swap-modal-body{flex:1;overflow-y:auto;padding:var(--space-5) var(--space-6);display:flex;flex-direction:column;gap:var(--space-4)}.swap-shift-preview{display:flex;flex-direction:column;gap:var(--space-2)}.swap-preview-label{font-size:var(--font-xs);font-weight:var(--weight-semibold);text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary)}.swap-shift-card{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--surface-200);border:1px solid var(--border-subtle);border-radius:var(--radius-lg)}.swap-shift-card.my-shift{border-color:var(--color-primary-500);background:color-mix(in srgb,var(--color-primary-500) 8%,var(--surface-200))}.swap-shift-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.swap-shift-code{font-size:var(--font-sm);font-weight:var(--weight-bold);color:var(--text-primary)}.swap-shift-date{font-size:var(--font-sm);color:var(--text-secondary)}.swap-shift-time{font-size:var(--font-xs);color:var(--text-tertiary);margin-left:auto}.swap-shift-user{font-size:var(--font-xs);color:var(--text-secondary);border-left:1px solid var(--border-subtle);padding-left:var(--space-2);margin-left:var(--space-1)}.swap-arrow-divider{display:flex;align-items:center;justify-content:center;color:var(--text-tertiary)}.swap-field{display:flex;flex-direction:column;gap:var(--space-2)}.swap-field-label{display:flex;align-items:center;gap:var(--space-1);font-size:var(--font-xs);font-weight:var(--weight-semibold);text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary)}.swap-shift-list{display:flex;flex-direction:column;gap:var(--space-1);max-height:220px;overflow-y:auto;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-1);background:var(--surface-200)}.swap-shift-list-empty{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-5);color:var(--text-tertiary);font-size:var(--font-sm)}.swap-shift-option{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);border:1px solid transparent;background:transparent;cursor:pointer;text-align:left;width:100%;color:var(--text-primary);transition:background var(--transition-fast),border-color var(--transition-fast)}.swap-shift-option:hover{background:var(--surface-300)}.swap-shift-option.selected{background:color-mix(in srgb,var(--color-primary-500) 12%,var(--surface-200));border-color:var(--color-primary-500)}.swap-option-code{font-size:var(--font-sm);font-weight:var(--weight-bold);min-width:40px}.swap-option-user{font-size:var(--font-sm);color:var(--text-secondary);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.swap-option-time{font-size:var(--font-xs);color:var(--text-tertiary);white-space:nowrap}.swap-reason{resize:vertical;min-height:72px}.swap-modal-footer{display:flex;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-subtle);flex-shrink:0}@media(max-width:768px){.swap-modal{position:fixed;top:auto;bottom:0;left:0;right:0;transform:none;width:100%;max-width:100%;max-height:92vh;border-radius:var(--radius-xl) var(--radius-xl) 0 0;animation:swapModalSlideUp .3s ease-out}@keyframes swapModalSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.swap-modal-header{padding:var(--space-3) var(--space-4)}.swap-modal-title{font-size:var(--font-base)}.swap-modal-body{padding:var(--space-3) var(--space-4);gap:var(--space-3);max-height:calc(92vh - 120px);overflow-y:auto;-webkit-overflow-scrolling:touch}.swap-shift-card{flex-wrap:wrap;gap:var(--space-2);padding:var(--space-2) var(--space-3)}.swap-shift-time{margin-left:0;font-size:11px}.swap-shift-user{border-left:none;padding-left:0;margin-left:0;width:100%;margin-top:2px}.swap-shift-list{max-height:200px}.swap-shift-option{padding:var(--space-2) var(--space-3);gap:var(--space-2);min-height:44px}.swap-reason{min-height:60px}.swap-modal-footer{padding:var(--space-3) var(--space-4);gap:var(--space-2);padding-bottom:calc(var(--space-3) + env(safe-area-inset-bottom,0px))}.swap-modal-footer .btn{flex:1;min-height:44px;justify-content:center}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100}.shift-detail-panel{position:fixed;top:0;right:0;bottom:0;width:420px;max-width:100vw;background:var(--surface-100);border-left:1px solid var(--border-subtle);z-index:101;display:flex;flex-direction:column;box-shadow:var(--shadow-xl)}.sdp-header{display:flex;align-items:flex-start;justify-content:space-between;padding:var(--space-6);gap:var(--space-4)}.sdp-header-info{display:flex;flex-direction:column;gap:var(--space-2)}.sdp-title{font-size:var(--font-xl);font-weight:var(--weight-bold);color:var(--text-primary);line-height:var(--leading-tight)}.sdp-color-bar{height:3px;width:100%;opacity:.8}.sdp-body{flex:1;overflow-y:auto;padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-5)}.sdp-field{display:flex;gap:var(--space-3)}.sdp-field-icon{flex-shrink:0;width:32px;height:32px;border-radius:var(--radius-md);background:var(--surface-300);display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);margin-top:2px}.sdp-field-content{display:flex;flex-direction:column;gap:2px;min-width:0}.sdp-field-label{font-size:var(--font-xs);font-weight:var(--weight-medium);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em}.sdp-field-value{font-size:var(--font-sm);color:var(--text-primary);font-weight:var(--weight-medium);display:flex;align-items:center;gap:var(--space-2)}.sdp-type-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.sdp-notes-field{background:var(--surface-200);padding:var(--space-4);border-radius:var(--radius-md);border:1px solid var(--border-subtle);margin-left:calc(-1 * var(--space-3));padding-left:calc(var(--space-3) + var(--space-4))}.sdp-notes-content{font-size:var(--font-sm);color:var(--text-secondary);line-height:var(--leading-relaxed);white-space:pre-wrap;word-break:break-word}.sdp-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-subtle);display:flex;justify-content:flex-end;gap:var(--space-3)}.sdp-btn-remove{color:var(--color-danger-500);display:inline-flex;align-items:center;gap:var(--space-1)}.sdp-btn-remove:hover{background:var(--color-danger-50)}.sdp-btn-remove-group{color:var(--color-danger-500);display:inline-flex;align-items:center;gap:var(--space-1);border:1px solid var(--color-danger-200)!important}.sdp-btn-remove-group:hover{background:var(--color-danger-500)!important;color:#fff!important}.sdp-group{margin:0 var(--space-6);border:1px solid var(--border-subtle);border-radius:var(--radius-md);overflow:hidden}.sdp-group-header{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--surface-200);font-size:var(--font-xs);font-weight:var(--weight-semibold);color:var(--text-secondary)}.sdp-group-list{display:flex;flex-direction:column}.sdp-group-member{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);font-size:var(--font-sm);border-top:1px solid var(--border-subtle)}.sdp-group-member--active{background:var(--surface-200)}.sdp-group-member-num{font-size:var(--font-xs);color:var(--text-muted);min-width:36px;font-variant-numeric:tabular-nums}.sdp-group-member-name{flex:1;color:var(--text-primary);font-weight:var(--weight-medium)}.sdp-group-member-you{font-size:10px;color:var(--text-muted);background:var(--surface-300);padding:1px 6px;border-radius:var(--radius-sm)}.sdp-delete-confirm{margin:0 var(--space-6) var(--space-2);padding:var(--space-3) var(--space-4);background:var(--color-danger-50);border:1px solid var(--color-danger-200);border-radius:var(--radius-md)}.sdp-delete-confirm-header{display:flex;align-items:center;gap:var(--space-2);color:var(--color-danger-700);font-size:var(--font-sm);margin-bottom:var(--space-2)}.sdp-delete-confirm-details{display:flex;flex-direction:column;gap:var(--space-1);font-size:var(--font-xs);color:var(--color-danger-600)}.sdp-delete-confirm-details span{display:inline-flex;align-items:center;gap:var(--space-1)}.sdp-delete-warning{margin:var(--space-2) 0 0;font-size:var(--font-xs);font-weight:600;color:var(--color-danger-700)}.btn-danger{background:var(--color-danger-500);color:#fff;border:none;display:inline-flex;align-items:center;gap:var(--space-1)}.btn-danger:hover{background:var(--color-danger-600)}@media(max-width:768px){.shift-detail-panel{width:100vw}.sdp-header{padding:var(--space-4);gap:var(--space-3)}.sdp-body{padding:var(--space-4);gap:var(--space-4)}.sdp-footer{padding:var(--space-3) var(--space-4)}.sdp-group{margin:0 var(--space-4)}.sdp-notes-field{margin-left:0;padding-left:var(--space-4)}.sdp-delete-confirm{margin:0 var(--space-4) var(--space-2);padding:var(--space-2) var(--space-3)}}.sdv{display:flex;flex-direction:column;gap:6px;animation:fadeIn var(--transition-base) ease-out}.station-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:var(--space-3);color:var(--text-secondary);font-size:var(--font-sm)}.sdv-day{background:var(--surface-100);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border-subtle);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.sdv-today{border-color:var(--color-primary-500);box-shadow:0 0 0 1px var(--color-primary-500),0 4px 16px #10b9811f}.sdv-empty{opacity:.4}.sdv-day-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:var(--surface-100);border:none;width:100%;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .15s}.sdv-day-header:active{background:var(--surface-200)}.sdv-day-left{display:flex;align-items:center;gap:10px}.sdv-day-num{font-size:20px;font-weight:800;color:var(--text-primary);min-width:28px;line-height:1}.sdv-today .sdv-day-num{color:var(--color-primary-400)}.sdv-day-name{font-size:13px;color:var(--text-tertiary);text-transform:capitalize;font-weight:var(--weight-medium)}.sdv-badge-today{font-size:9px;font-weight:700;color:var(--color-primary-400);background:#10b9811f;padding:2px 8px;border-radius:99px;text-transform:uppercase;letter-spacing:.06em}.sdv-day-right{display:flex;align-items:center;gap:6px;color:var(--text-muted)}.sdv-day-right svg{transition:transform var(--transition-fast)}.sdv-day-count{font-size:11px;font-weight:700;color:var(--text-muted);background:var(--surface-300);padding:2px 8px;border-radius:99px;min-width:22px;text-align:center}.sdv-groups{display:flex;flex-direction:column;border-top:1px solid var(--border-subtle);animation:sdvSlideDown var(--transition-fast) ease-out}@keyframes sdvSlideDown{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.sdv-type-group{border-bottom:1px solid var(--border-subtle)}.sdv-type-group:last-child{border-bottom:none}.sdv-type-header{display:flex;align-items:center;gap:10px;padding:9px 14px;background:var(--surface-150, var(--surface-200))}.sdv-type-bar{width:3px;height:20px;border-radius:2px;flex-shrink:0}.sdv-type-code{font-size:13px;font-weight:700;letter-spacing:.02em}.sdv-type-time{font-size:11px;color:var(--text-tertiary);margin-left:auto;font-variant-numeric:tabular-nums}.sdv-type-count{display:inline-flex;align-items:center;gap:3px;font-size:10px;color:var(--text-muted);background:var(--surface-300);padding:1px 7px;border-radius:99px;font-weight:600}.sdv-members{display:flex;flex-direction:column}.sdv-member{display:flex;align-items:center;gap:10px;padding:9px 14px 9px 28px;border:none;background:transparent;cursor:pointer;width:100%;text-align:left;-webkit-tap-highlight-color:transparent;transition:background .12s}.sdv-member:active{background:var(--surface-200)}.sdv-member+.sdv-member{border-top:1px solid var(--border-subtle)}.sdv-member-avatar{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;color:#fff;flex-shrink:0;letter-spacing:.03em}.sdv-member-name{font-size:13px;color:var(--text-primary);font-weight:500;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sdv-member-num{font-size:11px;color:var(--text-muted);font-variant-numeric:tabular-nums;flex-shrink:0}.sdv-no-shifts{padding:12px 14px;font-size:12px;color:var(--text-muted);font-style:italic;border-top:1px solid var(--border-subtle)}@media(max-width:768px){.sdv{gap:4px}.sdv-day{border-radius:var(--radius-md)}.sdv-day-header{padding:10px 12px}.sdv-day-num{font-size:17px}.sdv-day-name{font-size:12px}.sdv-type-header{padding:7px 12px}.sdv-member{padding:8px 12px 8px 24px;gap:8px}.sdv-member-avatar{width:26px;height:26px;font-size:8px}.sdv-member-name{font-size:13px}}.daily-view{display:flex;flex-direction:column;gap:var(--space-3)}.daily-view-nav{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) 0}.daily-view-date{display:flex;align-items:center;gap:var(--space-2);color:var(--text-primary);font-weight:var(--weight-semibold);font-size:var(--font-sm)}.daily-view-date-text{text-transform:capitalize}.daily-view-today-badge{font-size:10px;font-weight:var(--weight-bold);color:var(--color-primary-400);background:#3b82f61f;padding:1px 8px;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.05em}.daily-view-goto-today{font-size:11px!important;color:var(--color-primary-400)!important;margin-left:var(--space-1)}.daily-view-empty{display:flex;align-items:center;justify-content:center;padding:var(--space-8);color:var(--text-muted);font-size:var(--font-sm);border:1px dashed var(--border-subtle);border-radius:var(--radius-lg)}.daily-view-content{display:flex;flex-direction:column;gap:var(--space-4)}.daily-view-section{display:flex;flex-direction:column;gap:var(--space-2)}.daily-view-section-title{font-size:10px;font-weight:var(--weight-bold);text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);padding-left:var(--space-1)}.daily-view-table{border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden;background:var(--surface-100)}.daily-view-table-header{display:grid;grid-template-columns:100px 140px 1fr;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--surface-200);border-bottom:1px solid var(--border-subtle);font-size:10px;font-weight:var(--weight-bold);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.daily-view-slot{border-bottom:1px solid var(--border-subtle)}.daily-view-slot:last-child{border-bottom:none}.daily-view-slot-toggle{display:grid;grid-template-columns:1fr 140px auto;gap:var(--space-2);padding:var(--space-2) var(--space-3);align-items:center;background:var(--surface-150, var(--surface-100));border:none;cursor:pointer;width:100%;text-align:left;transition:background .1s}.daily-view-slot-toggle:hover{background:var(--surface-200)}.daily-view-slot-header-left{display:flex;align-items:center;gap:var(--space-2);min-width:0}.daily-view-slot-header-right{display:flex;align-items:center;gap:var(--space-2);color:var(--text-muted)}.daily-view-slot-code{font-size:var(--font-sm);font-weight:var(--weight-bold);letter-spacing:.02em;flex-shrink:0}.daily-view-slot-grat-tag,.daily-view-slot-detail-tag{font-size:10px;color:var(--text-muted);background:var(--surface-300);padding:1px 6px;border-radius:var(--radius-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.daily-view-slot-range{font-size:11px;color:var(--text-secondary);font-variant-numeric:tabular-nums}.daily-view-slot-count{font-size:11px;color:var(--text-muted);background:var(--surface-300);border-radius:var(--radius-full);padding:1px 8px;width:fit-content;font-weight:var(--weight-bold)}.daily-view-slot-members{display:flex;flex-direction:column}.daily-view-member{display:flex;align-items:center;gap:var(--space-2);padding:6px var(--space-3) 6px calc(var(--space-3) + 4px);border:none;background:transparent;cursor:pointer;text-align:left;width:100%;font-size:12px;color:var(--text-secondary);transition:background .1s;border-top:1px solid var(--border-subtle)}.daily-view-member:hover{background:var(--surface-200)}.daily-view-member-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.daily-view-member-num{font-size:11px;font-weight:var(--weight-bold);color:var(--text-muted);min-width:36px;font-variant-numeric:tabular-nums}.daily-view-member-name{flex:1;color:var(--text-primary);font-weight:var(--weight-medium)}.daily-view-member-loc,.daily-view-member-grat{font-size:10px;color:var(--text-muted);background:var(--surface-300);padding:1px 6px;border-radius:var(--radius-sm)}.daily-view-slot-location{display:flex;align-items:center;gap:var(--space-1);padding:0 var(--space-3);font-size:11px;color:var(--text-secondary)}.daily-view-slot-actions{display:flex;justify-content:flex-end;padding:var(--space-1) var(--space-3) var(--space-1)}.daily-view-btn-remove{color:var(--color-error-400)!important;font-size:11px;gap:4px}.daily-view-btn-remove:hover{background:var(--color-error-400)!important;color:#fff!important}.daily-view-absence-inline{display:flex;flex-direction:column;gap:var(--space-2);background:var(--surface-100);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-2) var(--space-3)}.daily-view-absence-row{display:flex;align-items:center;gap:var(--space-3);min-height:28px}.daily-view-absence-row+.daily-view-absence-row{border-top:1px solid var(--border-subtle);padding-top:var(--space-2)}.daily-view-absence-code-inline{font-size:11px;font-weight:var(--weight-bold);letter-spacing:.04em;min-width:40px;flex-shrink:0}.daily-view-absence-chips{display:flex;flex-wrap:wrap;gap:4px}.daily-view-absence-chip{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border:1px solid var(--border-subtle);border-radius:var(--radius-full);background:var(--surface-200);cursor:pointer;font-size:11px;color:var(--text-secondary);transition:background .1s;white-space:nowrap}.daily-view-absence-chip:hover{background:var(--surface-300)}.daily-view-chip-num{font-weight:var(--weight-bold);color:var(--text-muted);font-variant-numeric:tabular-nums}.daily-view-chip-name{color:var(--text-primary);font-weight:var(--weight-medium)}.daily-view-chip-loc,.daily-view-chip-grat{font-size:9px;color:var(--text-muted);background:var(--surface-300);padding:0 4px;border-radius:var(--radius-sm)}.daily-view-inline-tag{font-size:10px;color:var(--text-muted);background:var(--surface-300);padding:1px 6px;border-radius:var(--radius-sm);white-space:nowrap;flex-shrink:0}.daily-view-summary{display:flex;gap:var(--space-4);padding:var(--space-2) var(--space-3);background:var(--surface-200);border:1px solid var(--border-subtle);border-radius:var(--radius-lg)}.daily-view-summary-item{display:flex;align-items:center;gap:var(--space-2);font-size:11px;color:var(--text-muted)}.daily-view-summary-val{font-weight:var(--weight-bold);color:var(--text-primary);background:var(--surface-300);padding:1px 7px;border-radius:var(--radius-full);font-variant-numeric:tabular-nums}@media(max-width:768px){.daily-view{gap:var(--space-2)}.daily-view-table-header{display:none}.daily-view-table{border-radius:var(--radius-md)}.daily-view-slot-toggle{display:flex;flex-wrap:nowrap;align-items:center;gap:8px;padding:10px 12px}.daily-view-slot-header-left{flex:1;min-width:0}.daily-view-slot-code{font-size:14px}.daily-view-slot-range{font-size:11px;flex-shrink:0}.daily-view-slot-grat-tag,.daily-view-slot-detail-tag{max-width:100px;font-size:9px}.daily-view-slot-count{font-size:10px;padding:1px 6px}.daily-view-member{padding:8px 12px 8px 16px;font-size:13px;-webkit-tap-highlight-color:transparent}.daily-view-member:active{background:var(--surface-200)}.daily-view-member-dot{width:7px;height:7px}.daily-view-member-name{font-size:13px}.daily-view-member-num{font-size:10px;min-width:28px}.daily-view-absence-inline{padding:var(--space-2);border-radius:var(--radius-md)}.daily-view-absence-row{flex-direction:column;align-items:flex-start;gap:var(--space-1)}.daily-view-absence-chip{font-size:12px;padding:4px 10px}.daily-view-summary{flex-wrap:wrap;gap:var(--space-2);padding:var(--space-2);border-radius:var(--radius-md)}.daily-view-nav{gap:4px;padding:var(--space-1) 0}.daily-view-date{font-size:13px;gap:6px}.daily-view-section-title{font-size:9px;padding-left:2px}.daily-view-empty{padding:var(--space-6)}.daily-view-slot-location{padding:2px 12px;font-size:10px}}.month-nav{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-6);flex-wrap:wrap}.month-nav-left{flex:1;min-width:0}.month-nav-title{font-size:var(--font-2xl);font-weight:var(--weight-bold);color:var(--text-primary);letter-spacing:-.02em;white-space:nowrap}.month-nav-center{display:flex;align-items:center;gap:var(--space-2)}.month-nav-label{font-size:var(--font-lg);font-weight:var(--weight-semibold);color:var(--text-primary);min-width:180px;text-align:center;text-transform:capitalize}.month-nav-today{margin-left:var(--space-2)}.month-nav-right{display:flex;align-items:center;gap:var(--space-2)}@media(max-width:768px){.month-nav{flex-direction:column;align-items:stretch;gap:var(--space-3)}.month-nav-center,.month-nav-right{justify-content:center}.month-nav-label{font-size:var(--font-base);min-width:150px}}.sgdp-panel{position:fixed;top:0;right:0;bottom:0;width:420px;max-width:100vw;background:var(--surface-100);border-left:1px solid var(--border-subtle);z-index:101;display:flex;flex-direction:column;box-shadow:var(--shadow-xl)}.sgdp-header{display:flex;align-items:flex-start;justify-content:space-between;padding:var(--space-6);gap:var(--space-4)}.sgdp-header-left{display:flex;flex-direction:column;gap:var(--space-2)}.sgdp-title{font-size:var(--font-xl);font-weight:var(--weight-bold);color:var(--text-primary);line-height:var(--leading-tight)}.sgdp-member-pill{display:inline-flex;align-items:center;gap:var(--space-1);font-size:var(--font-xs);color:var(--text-secondary);background:var(--surface-300);border-radius:999px;padding:2px 8px;border:1px solid var(--border-subtle)}.sgdp-color-bar{height:3px;width:100%;flex-shrink:0}.sgdp-meta{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--border-subtle)}.sgdp-meta-item{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-sm);color:var(--text-secondary)}.sgdp-meta-item svg{color:var(--text-tertiary);flex-shrink:0}.sgdp-type-code{font-family:var(--font-mono, monospace);font-size:var(--font-xs);font-weight:var(--weight-semibold);color:var(--text-primary);background:var(--surface-300);padding:1px 6px;border-radius:4px}.sgdp-section-label{padding:var(--space-3) var(--space-6) var(--space-2);font-size:11px;font-weight:var(--weight-semibold);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em}.sgdp-members{flex:1;overflow-y:auto;padding:0 var(--space-4) var(--space-4);display:flex;flex-direction:column;gap:var(--space-2)}.sgdp-member-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-3);border-radius:var(--radius-md);background:var(--surface-200);border:1px solid var(--border-subtle);transition:border-color var(--transition-fast)}.sgdp-member-row:hover{border-color:var(--border-default)}.sgdp-member-me{border-color:var(--color-primary-500);background:color-mix(in srgb,var(--color-primary-500) 8%,var(--surface-200))}.sgdp-avatar{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:var(--weight-bold);color:#fff;flex-shrink:0;opacity:.9}.sgdp-member-info{flex:1;display:flex;align-items:center;gap:var(--space-2);min-width:0}.sgdp-member-name{font-size:var(--font-sm);font-weight:var(--weight-medium);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sgdp-me-badge{font-size:10px;font-weight:var(--weight-semibold);color:var(--color-primary-400);background:color-mix(in srgb,var(--color-primary-500) 15%,transparent);border-radius:999px;padding:1px 6px;white-space:nowrap}.sgdp-member-ordem{font-size:10px;font-weight:var(--weight-medium);color:var(--text-tertiary);font-variant-numeric:tabular-nums;white-space:nowrap}.sgdp-member-actions{display:flex;gap:var(--space-1);flex-shrink:0}.sgdp-swap-btn{font-size:11px;padding:3px 8px;color:var(--color-primary-400)!important;border:1px solid color-mix(in srgb,var(--color-primary-500) 30%,transparent);border-radius:6px}.sgdp-swap-btn:hover{background:color-mix(in srgb,var(--color-primary-500) 12%,transparent)}.sgdp-remove-btn{color:var(--color-danger-400)!important;padding:3px 6px;border-radius:6px}.sgdp-remove-btn:hover{background:color-mix(in srgb,var(--color-danger-500) 12%,transparent)}.sgdp-confirm-inline{display:flex;align-items:center;gap:var(--space-2);width:100%;margin-top:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-danger-50);border:1px solid var(--color-danger-200);border-radius:var(--radius-sm);font-size:var(--font-xs);color:var(--color-danger-600)}.sgdp-confirm-inline svg{flex-shrink:0;color:var(--color-danger-500)}.sgdp-confirm-inline span{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sgdp-member-row{flex-wrap:wrap}.sgdp-remove-all-btn{color:var(--color-danger-400)!important;display:inline-flex;align-items:center;gap:var(--space-1);font-size:var(--font-xs)}.sgdp-remove-all-btn:hover{background:color-mix(in srgb,var(--color-danger-500) 10%,transparent)}.sgdp-delete-all-confirm{margin:0 var(--space-4) var(--space-2);padding:var(--space-3) var(--space-4);background:var(--color-danger-50);border:1px solid var(--color-danger-200);border-radius:var(--radius-md)}.sgdp-delete-all-header{display:flex;align-items:center;gap:var(--space-2);color:var(--color-danger-700);font-size:var(--font-sm);margin-bottom:var(--space-2)}.sgdp-delete-all-text{font-size:var(--font-xs);color:var(--color-danger-600);margin:0 0 var(--space-3)}.sgdp-delete-all-actions{display:flex;gap:var(--space-2);justify-content:flex-end}.sgdp-footer{display:flex;align-items:center;padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-subtle);gap:var(--space-3)}.sgdp-my-shift-note{font-size:var(--font-xs);color:var(--text-tertiary);font-style:italic}@media(max-width:768px){.sgdp-panel{width:100vw}.sgdp-header{padding:var(--space-4);gap:var(--space-3)}.sgdp-body{padding:var(--space-4)}.sgdp-footer{padding:var(--space-3) var(--space-4)}}.modal-container{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:100%;max-width:500px;background:var(--surface-100);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);z-index:101;display:flex;flex-direction:column;box-shadow:var(--shadow-2xl);overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--border-subtle);background:var(--surface-200)}.modal-title{font-size:var(--font-lg);font-weight:var(--weight-bold);color:var(--text-primary)}.modal-body{padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-5);max-height:calc(100vh - 120px);overflow-y:auto}.sem-row{display:flex;gap:var(--space-4);align-items:flex-start}.sem-time-group{display:flex;gap:var(--space-2)}.sem-allday-badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:6px var(--space-3);background:#10b9811a;border:1px solid rgba(16,185,129,.25);border-radius:var(--radius-md);color:var(--color-primary-400);font-size:var(--font-sm);font-weight:var(--weight-semibold)}.sem-time-group .input-field{width:90px}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3);padding-top:var(--space-4);border-top:1px solid var(--border-subtle)}.sem-warning-box{display:flex;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:#fbbf241a;border:1px solid rgba(251,191,36,.2);border-radius:var(--radius-md);color:var(--color-warning-500);margin-bottom:var(--space-2)}.sem-warning-icon{flex-shrink:0;margin-top:2px}.sem-warning-text{font-size:var(--font-sm);line-height:var(--leading-snug)}@media(max-width:768px){.modal-container{width:100vw;max-width:100vw;height:100vh;max-height:100vh;top:0;left:0;transform:none;border-radius:0}.modal-header{padding:var(--space-3) var(--space-4)}.modal-title{font-size:var(--font-base)}.modal-body{padding:var(--space-4);gap:var(--space-4);max-height:calc(100vh - 60px);max-height:calc(100dvh - 60px)}.sem-row{flex-direction:column}.sem-time-group .input-field{width:100%}}.publish-toolbar{position:fixed;bottom:var(--space-4);left:50%;transform:translate(-50%);z-index:40;width:auto;max-width:560px;min-width:280px;width:calc(100% - 2rem)}.publish-toolbar-content{background:var(--surface-150, var(--surface-200));border:1px solid rgba(245,158,11,.45);border-radius:var(--radius-full);padding:var(--space-2) var(--space-3) var(--space-2) var(--space-4);display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);box-shadow:0 4px 20px -4px #0006,0 0 0 1px #f59e0b1a;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}.publish-toolbar-info{display:flex;align-items:center;gap:var(--space-2)}.publish-icon{width:8px;height:8px;border-radius:var(--radius-full);background:var(--color-warning-500);flex-shrink:0;box-shadow:0 0 6px #f59e0bb3}.publish-title{font-size:var(--font-xs);font-weight:var(--weight-semibold);color:var(--text-secondary);white-space:nowrap}.publish-desc{font-size:var(--font-xs);color:var(--text-tertiary);white-space:nowrap}@media(max-width:768px){.publish-toolbar{max-width:calc(100vw - 1rem);min-width:unset;bottom:calc(68px + var(--space-2))}.publish-toolbar-content{border-radius:var(--radius-lg);padding:var(--space-2);gap:var(--space-2);flex-wrap:wrap;justify-content:center}.publish-title,.publish-desc{white-space:normal;text-align:center}}.publish-desc strong{color:var(--color-warning-400);font-weight:var(--weight-semibold)}.publish-toolbar-actions .btn{border-radius:var(--radius-full);font-size:var(--font-xs);padding:var(--space-1) var(--space-3);height:28px}.shift-library{width:190px;min-width:190px;display:flex;flex-direction:column;background:var(--surface-100);border-right:1px solid var(--border-subtle);overflow:hidden;flex-shrink:0;transition:width .18s ease,min-width .18s ease}.lib-collapsed{width:34px;min-width:34px}.shift-lib-toggle-bar{display:flex;align-items:center;justify-content:space-between;padding:7px 8px 7px 10px;border-bottom:1px solid var(--border-subtle);background:var(--surface-200);flex-shrink:0;min-height:30px}.lib-collapsed .shift-lib-toggle-bar{justify-content:center;padding:5px 0}.shift-library-title{font-size:9px;font-weight:var(--weight-bold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em;white-space:nowrap;overflow:hidden}.shift-lib-toggle{width:20px;height:20px;border-radius:5px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .1s,color .1s}.shift-lib-toggle:hover{background:var(--surface-400);color:var(--text-secondary)}.shift-lib-dots{display:none;flex-direction:column;align-items:center;gap:6px;padding:10px 0;overflow:hidden}.lib-collapsed .shift-lib-dots{display:flex}.shift-lib-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;opacity:.7;cursor:default}.shift-lib-content{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.lib-collapsed .shift-lib-content{display:none}.shift-library-scroll{flex:1;overflow-y:auto;padding:8px;display:flex;flex-direction:column;gap:10px;scrollbar-width:thin;scrollbar-color:var(--surface-400) transparent}.shift-lib-loading{display:flex;justify-content:center;padding:var(--space-6)}.shift-lib-group{display:flex;flex-direction:column;gap:5px}.shift-lib-group-label{font-size:9px;font-weight:var(--weight-bold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em;padding-left:2px}.shift-lib-rows{display:flex;flex-direction:column;gap:2px}.shift-lib-row{display:flex;align-items:center;gap:6px;padding:5px 7px;border-radius:6px;border:1px solid transparent;cursor:grab;-webkit-user-select:none;user-select:none;background:var(--surface-200);transition:background .12s,transform .1s,box-shadow .1s}.shift-lib-row:hover{background:var(--surface-300);transform:translateY(-1px);box-shadow:0 3px 10px #00000059}.shift-lib-row:active{cursor:grabbing;transform:scale(.97)}.shift-lib-row-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.shift-lib-row-code{font-size:11px;font-weight:var(--weight-bold);letter-spacing:.03em;line-height:1;flex-shrink:0}.shift-lib-row-time{font-size:10px;color:var(--text-muted);font-variant-numeric:tabular-nums;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;text-align:right}.shift-lib-cards{display:flex;flex-direction:column;gap:4px}.shift-lib-card{display:flex;flex-direction:column;gap:2px;padding:8px 10px;border-radius:8px;border:1px solid transparent;cursor:grab;-webkit-user-select:none;user-select:none;transition:filter .12s,transform .1s,box-shadow .1s}.shift-lib-card:hover{filter:brightness(1.3);transform:translateY(-1px);box-shadow:0 4px 14px #0006}.shift-lib-card:active{cursor:grabbing;transform:scale(.97)}.shift-lib-card-top{display:flex;align-items:center;justify-content:space-between}.shift-lib-card-code{font-size:var(--font-sm);font-weight:var(--weight-bold);letter-spacing:.04em;line-height:1}.shift-lib-card-time{font-size:10px;color:var(--text-secondary);font-variant-numeric:tabular-nums;line-height:1.2}.shift-lib-card-name{font-size:9px;color:var(--text-tertiary);line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.shift-lib-chip-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}.shift-lib-chip{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:7px 4px;border-radius:8px;border:1px solid transparent;cursor:grab;-webkit-user-select:none;user-select:none;text-align:center;transition:filter .1s,transform .1s,box-shadow .1s}.shift-lib-chip:hover{filter:brightness(1.35);transform:translateY(-1px);box-shadow:0 3px 10px #00000059}.shift-lib-chip:active{cursor:grabbing;transform:scale(.93)}.shift-lib-chip-code{font-size:11px;font-weight:var(--weight-bold);letter-spacing:.02em;line-height:1.2}.shift-lib-chip-sub{font-size:8px;color:var(--text-muted);line-height:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.shift-lib-card-clickable,.shift-lib-chip-clickable,.shift-lib-card-clickable:active,.shift-lib-chip-clickable:active{cursor:pointer}.apop-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:999}.apop-container{position:fixed;z-index:1000;width:300px;max-width:calc(100vw - 32px);max-height:calc(100vh - 32px);background:var(--surface-100);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);overflow:hidden;display:flex;flex-direction:column;animation:apop-in .12s ease-out}@keyframes apop-in{0%{opacity:0;transform:scale(.95) translateY(-4px)}to{opacity:1;transform:scale(1) translateY(0)}}.apop-header{display:flex;align-items:flex-start;justify-content:space-between;padding:var(--space-3) var(--space-4);background:var(--surface-200);border-bottom:1px solid var(--border-default);border-left:4px solid transparent}.apop-header-info{display:flex;flex-direction:column;gap:2px}.apop-type-code{font-size:var(--font-base);font-weight:var(--weight-bold);line-height:1.2}.apop-type-name{font-size:var(--font-sm);color:var(--text-secondary);line-height:1.2}.apop-date{font-size:var(--font-xs);color:var(--text-tertiary);margin-top:2px}.apop-close{margin-top:-4px;margin-right:-4px}.apop-body{padding:var(--space-3) var(--space-4);display:flex;flex-direction:column;gap:var(--space-3);overflow-y:auto;flex:1;min-height:0}.apop-times{display:flex;align-items:center;gap:var(--space-2)}.apop-time-field{display:flex;align-items:center;gap:var(--space-1);font-size:var(--font-xs);color:var(--text-secondary);flex:1}.apop-time-field label{font-size:var(--font-xs);color:var(--text-tertiary);white-space:nowrap}.apop-time-input{padding:var(--space-1) var(--space-2)!important;font-size:var(--font-xs)!important;height:28px;flex:1}.apop-time-sep{color:var(--text-tertiary);font-size:var(--font-xs);flex-shrink:0}.apop-fixed-time{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-sm);color:var(--text-secondary);background:var(--surface-200);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md)}.apop-allday-badge{display:inline-flex;align-items:center;background:var(--surface-200);color:var(--text-secondary);font-size:var(--font-xs);font-weight:var(--weight-medium);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);width:fit-content}.apop-grat-fields{display:flex;flex-direction:column;gap:var(--space-2)}.apop-field{display:flex;align-items:flex-start;gap:var(--space-2);font-size:var(--font-xs);color:var(--text-secondary)}.apop-field svg{margin-top:6px;flex-shrink:0;opacity:.6}.apop-field label{font-weight:var(--weight-medium);min-width:60px;margin-top:5px;white-space:nowrap}.apop-field input,.apop-field textarea{flex:1;font-size:var(--font-xs);padding:var(--space-1) var(--space-2);border-radius:var(--radius-md)}.apop-field textarea{resize:vertical;min-height:40px}.apop-notes-field{margin-top:var(--space-1)}.apop-section-label{font-size:var(--font-xs);font-weight:var(--weight-semibold);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em}.apop-user-section{display:flex;flex-direction:column;gap:var(--space-2)}.apop-user-list{display:flex;flex-direction:column;gap:2px;max-height:180px;overflow-y:auto;border:1px solid var(--border-default);border-radius:var(--radius-md);padding:var(--space-1);background:var(--surface-50, var(--surface-100))}.apop-user-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-2);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast)}.apop-user-item:hover{background:var(--surface-300)}.apop-checkbox{accent-color:var(--color-primary, #2563EB);width:14px;height:14px;flex-shrink:0}.apop-user-info{display:flex;flex-direction:column;gap:1px;min-width:0}.apop-user-name{font-size:var(--font-sm);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.apop-user-nip{font-size:var(--font-xs);color:var(--text-tertiary)}.apop-fixed-badge{display:inline-block;font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-primary-700);background:var(--color-primary-50);border:1px solid var(--color-primary-200);border-radius:var(--radius-full);padding:0 5px;margin-left:6px;vertical-align:middle}.apop-empty{font-size:var(--font-sm);color:var(--text-tertiary);padding:var(--space-3);text-align:center}.apop-actions{display:flex;gap:var(--space-2);justify-content:flex-end;align-items:center;padding-top:var(--space-1);border-top:1px solid var(--border-default)}.apop-hint{font-size:10px;color:var(--color-warning-400, #f59e0b);margin-right:auto}@media(max-width:768px){.apop-container{position:fixed;top:auto!important;left:0!important;right:0;bottom:0;width:100%;max-width:100%;max-height:70vh;border-radius:var(--radius-xl) var(--radius-xl) 0 0;animation:apop-slide-up .2s ease-out}@keyframes apop-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.apop-overlay{background:#0006}.apop-user-item{min-height:44px;padding:var(--space-2) var(--space-3)}.apop-checkbox{width:18px;height:18px}.apop-user-list{max-height:200px}.apop-body,.apop-header{padding:var(--space-3)}.apop-actions{padding:var(--space-2) 0}}.station-schedule-page{display:flex;flex-direction:column;height:100%}.station-schedule-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;flex-wrap:wrap;gap:var(--space-2);flex-shrink:0}.station-schedule-body{display:flex;flex-direction:row;flex:1;min-height:0;border:1px solid var(--border-subtle);border-radius:12px;overflow:hidden;box-shadow:0 2px 16px #00000040;min-width:0}.view-seg{display:inline-flex;align-items:center;gap:2px;background:var(--surface-300);border-radius:8px;padding:2px;box-shadow:inset 0 1px 2px #00000040}.view-seg-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:24px;border-radius:6px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;transition:background .1s,color .1s,box-shadow .1s}.view-seg-btn:hover{color:var(--text-secondary);background:var(--surface-400)}.view-seg-active{background:var(--surface-500, var(--surface-600))!important;color:var(--text-primary)!important;box-shadow:0 1px 4px #0006,inset 0 1px #ffffff0f!important}.view-seg-add{margin-left:4px;border-radius:6px!important;height:24px;padding:0 8px!important}.station-schedule-calendar{flex:1;min-width:0;overflow:hidden}.station-schedule-calendar .schedule-calendar{border-radius:0;border:none}.quick-stats{width:155px;min-width:155px;flex-shrink:0;background:var(--surface-100);border-left:1px solid var(--border-subtle);display:flex;flex-direction:column}.quick-stats-header{padding:var(--space-2) var(--space-3);font-size:9px;font-weight:var(--weight-bold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em;border-bottom:1px solid var(--border-subtle);background:var(--surface-200)}.quick-stats-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--border-subtle);font-size:var(--font-xs);color:var(--text-secondary)}.quick-stats-item span:nth-child(2){flex:1}.quick-stats-icon{color:var(--text-tertiary);flex-shrink:0}.quick-stats-warn{color:var(--color-warning-400)!important}.quick-stats-pending{color:var(--color-accent-400)!important}.quick-stats-badge{font-size:var(--font-xs);font-weight:var(--weight-bold);color:var(--text-primary);background:var(--surface-300);border-radius:var(--radius-full);padding:2px 7px;min-width:22px;text-align:center;flex-shrink:0}.quick-stats-badge-pending{background:#fbbf2426;color:var(--color-accent-400)}@media(max-width:768px){.station-schedule-body{flex-direction:column;border-radius:var(--radius-md);box-shadow:none;border-color:transparent}.shift-library,.quick-stats{display:none}.station-schedule-header{padding:0;gap:var(--space-1)}.station-schedule-header h1{font-size:14px}.station-schedule-header p{display:none}.view-seg-btn{width:28px;height:24px}.station-schedule-calendar{min-height:0}.daily-view-wrapper{padding:var(--space-2) 0}}.station-schedule-fullscreen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:var(--surface-50, #0d1117);padding:0;border-radius:0;overflow:hidden;display:flex;flex-direction:column}.station-schedule-fullscreen .station-schedule-header{display:none}.station-schedule-fullscreen .station-schedule-body{border:none;border-radius:14px;box-shadow:0 4px 32px #00000080;margin:12px;flex:1;min-height:0}.fullscreen-toggle-btn{display:inline-flex;align-items:center;gap:4px}.daily-view-wrapper{padding:var(--space-3);overflow-y:auto}.fullscreen-exit-fab{position:fixed;top:14px;right:14px;z-index:210;display:none;align-items:center;justify-content:center;width:34px;height:34px;border-radius:10px;border:1px solid var(--border-subtle);background:var(--surface-300);color:var(--text-secondary);cursor:pointer;box-shadow:0 2px 12px #0006;transition:background .15s,color .15s}.fullscreen-exit-fab:hover{background:var(--surface-400);color:var(--text-primary)}.station-schedule-fullscreen .fullscreen-exit-fab{display:flex}.notifications-list{display:flex;flex-direction:column;gap:var(--space-3);margin-top:var(--space-6);max-width:800px}.notification-card{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--surface-100);border:1px solid var(--border-subtle);border-left:3px solid transparent;border-radius:var(--radius-lg);transition:background .2s ease}.notification-card:hover{background:var(--surface-200)}.notification-card.unread{background:#ffffff05;border-left-color:var(--nc-accent, var(--color-primary-500));border-color:var(--border-default)}.nc-type-icon{flex-shrink:0;width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;margin-top:1px}.nc-title-row{display:flex;align-items:center;gap:var(--space-2);margin-bottom:2px}.nc-type-badge{font-size:10px;font-weight:var(--weight-bold);padding:1px 7px;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.06em;flex-shrink:0}.nc-shifts{display:flex;flex-wrap:wrap;gap:4px;margin:5px 0 2px}.nc-shift-chip{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:var(--weight-bold);padding:2px 8px;border-radius:5px;border:1px solid;letter-spacing:.03em;cursor:default}.nc-shift-date{font-size:10px;font-weight:var(--weight-medium);opacity:.75}.nc-content{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.nc-title{font-size:var(--font-sm);font-weight:var(--weight-bold);color:var(--text-primary)}.nc-message{font-size:var(--font-sm);color:var(--text-secondary);line-height:1.5;max-width:600px}.nc-meta{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-2);color:var(--text-tertiary);font-size:var(--font-xs)}.nc-mark-btn{color:var(--color-primary-400)}.nc-mark-btn:hover{color:var(--color-primary-300)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12) 0;color:var(--text-secondary);text-align:center}.empty-icon{color:var(--text-tertiary);margin-bottom:var(--space-4);opacity:.5}.empty-state h3{font-size:var(--font-lg);font-weight:var(--weight-bold);margin-bottom:var(--space-2);color:var(--text-primary)}.empty-state p{font-size:var(--font-sm)}@media(max-width:768px){.notifications-list{gap:var(--space-2);margin-top:var(--space-3)}.notification-card{padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);gap:var(--space-2)}.nc-type-icon{width:32px;height:32px;border-radius:8px}.nc-title-row{flex-wrap:wrap;gap:var(--space-1)}.nc-title{font-size:13px}.nc-message{font-size:13px;max-width:100%}.nc-meta{margin-top:var(--space-1);font-size:11px}.nc-shift-chip{font-size:10px;padding:1px 6px}.empty-state{padding:var(--space-8) 0}}.swaps-page{display:flex;flex-direction:column;gap:var(--space-3);padding-bottom:calc(68px + var(--space-4));max-width:100vw;overflow-x:hidden;box-sizing:border-box}.swap-page-toolbar{padding:0 var(--space-3)}.swap-filter-bar{display:flex;gap:6px;padding:0 var(--space-3);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.swap-filter-bar::-webkit-scrollbar{display:none}.swap-filter-pill{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;border-radius:999px;border:1px solid var(--border-subtle);background:var(--surface-200);color:var(--text-secondary);font-size:12px;font-weight:var(--weight-medium);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast);white-space:nowrap;flex-shrink:0}.swap-filter-pill:hover{background:var(--surface-300);color:var(--text-primary)}.swap-filter-pill.active{background:var(--color-primary-500);border-color:var(--color-primary-500);color:#fff}.swap-filter-count{background:#0003;border-radius:999px;padding:1px 6px;font-size:10px;min-width:16px;text-align:center}.swap-filter-pill.active .swap-filter-count{background:#ffffff40}.swap-list-area{padding:0 var(--space-3)}.swap-card-list{display:flex;flex-direction:column;gap:var(--space-3);min-width:0;width:100%}.swap-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-12) var(--space-4);color:var(--text-tertiary);font-size:var(--font-sm);text-align:center}.swap-empty--error{color:var(--color-danger-400)}.swap-card{background:var(--surface-200);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column}.swap-card--cancelled{opacity:.55}.swap-card-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-3) 0}.swap-status-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:999px;background:color-mix(in srgb,var(--sc-color) 15%,transparent);color:var(--sc-color);font-size:11px;font-weight:var(--weight-semibold);white-space:nowrap}.swap-card-meta{font-size:10px;color:var(--text-tertiary);white-space:nowrap}.swap-card-shifts{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-3)}.swap-shift-side{display:flex;flex-direction:column;gap:4px}.swap-shift-label{font-size:10px;font-weight:var(--weight-semibold);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.swap-arrow-wrap{display:flex;align-items:center;justify-content:center;padding:2px 0}.swap-arrow-icon{color:var(--text-tertiary);opacity:.5}.swap-shift-unknown{font-size:var(--font-xs);color:var(--text-tertiary);font-style:italic;padding:6px 10px}.swap-shift-chip{display:flex;align-items:center;gap:var(--space-2);padding:8px 12px;border-radius:var(--radius-md);background:var(--surface-300);border:1px solid var(--border-subtle);min-width:0;overflow:hidden}.swap-chip-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.swap-chip-code{font-size:var(--font-sm);font-weight:var(--weight-bold);color:var(--text-primary);flex-shrink:0}.swap-chip-meta{font-size:12px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.swap-actions{display:flex;gap:var(--space-2);padding:0 var(--space-3) var(--space-3)}.swap-action-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 16px;border-radius:var(--radius-md);font-size:var(--font-sm);font-weight:var(--weight-semibold);border:1px solid transparent;cursor:pointer;transition:background var(--transition-fast),opacity var(--transition-fast);flex:1;min-height:44px}.swap-action-btn:disabled{opacity:.5;cursor:not-allowed}.swap-action-accept{background:var(--color-primary-500);color:#fff}.swap-action-accept:hover:not(:disabled){background:var(--color-primary-600)}.swap-action-reject{background:#ef44441f;color:#f87171;border-color:#ef444440}.swap-action-reject:hover:not(:disabled){background:#ef444433}.swap-action-cancel{background:var(--surface-300);color:var(--text-secondary);font-size:var(--font-xs)}.swap-action-cancel:hover:not(:disabled){background:var(--surface-400)}.swap-action-download{background:var(--surface-300);color:var(--color-primary-400);font-size:var(--font-xs)}.swap-action-download:hover:not(:disabled){background:var(--surface-400)}.swap-detail-toggle{display:flex;align-items:center;justify-content:center;gap:4px;padding:var(--space-2) var(--space-3);font-size:11px;color:var(--text-tertiary);background:none;border:none;border-top:1px solid var(--border-subtle);cursor:pointer;width:100%}.swap-detail-toggle:hover{color:var(--text-secondary)}.swap-expand-icon{transform:rotate(0);transition:transform var(--transition-fast)}.swap-expand-icon.rotated{transform:rotate(180deg)}.swap-card-detail{padding:0 var(--space-3) var(--space-3)}.swap-reason-text{display:flex;align-items:flex-start;gap:var(--space-2);font-size:var(--font-sm);color:var(--text-secondary);margin:0;font-style:italic}@media(min-width:769px){.swaps-page{padding-bottom:var(--space-6)}.swap-page-toolbar{padding:0 var(--space-6)}.swap-page-toolbar .swap-action-btn{flex:none;max-width:200px}.swap-filter-bar{padding:0 var(--space-6);flex-wrap:wrap}.swap-list-area{padding:0 var(--space-6)}.swap-card-header{padding:var(--space-4) var(--space-4) 0}.swap-card-shifts{flex-direction:row;align-items:stretch;padding:var(--space-4)}.swap-shift-side{flex:1;min-width:0}.swap-arrow-wrap{padding-top:16px}.swap-actions{padding:0 var(--space-4) var(--space-4)}.swap-action-btn{flex:none;min-width:120px}.swap-card-detail{padding:0 var(--space-4) var(--space-4)}}.admin-toolbar{margin:var(--space-4) 0;display:flex;justify-content:space-between;align-items:center;gap:var(--space-4);flex-wrap:wrap}.search-bar{display:flex;align-items:center;background:var(--surface-100);border:1px solid var(--border-default);padding:0 var(--space-3);border-radius:var(--radius-md);width:300px;max-width:100%}.search-bar svg{color:var(--text-tertiary);margin-right:var(--space-2)}.search-bar input{background:transparent;border:none;font-family:inherit;font-size:var(--font-sm);color:var(--text-primary);width:100%;padding:var(--space-2) 0;outline:none}.admin-filters{display:flex;gap:var(--space-2);align-items:center;flex-wrap:wrap}.admin-filters select,.admin-filters input[type=date]{background:var(--surface-100);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);color:var(--text-primary);font-family:inherit;font-size:var(--font-sm);outline:none;cursor:pointer}.admin-filters select:focus,.admin-filters input[type=date]:focus{border-color:var(--color-primary-500)}.admin-table-container{background:var(--surface-100);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow-x:auto}.admin-table{width:100%;border-collapse:collapse}.admin-table th{background:var(--surface-200);color:var(--text-secondary);font-size:var(--font-xs);font-weight:var(--weight-semibold);letter-spacing:.05em;text-transform:uppercase;padding:var(--space-3) var(--space-4);text-align:left;border-bottom:1px solid var(--border-subtle);white-space:nowrap}.admin-table td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-subtle);color:var(--text-secondary);font-size:var(--font-sm);vertical-align:middle}.admin-table tbody tr:hover{background:var(--surface-200)}.badge{padding:var(--space-1) var(--space-2);border-radius:var(--radius-full);font-size:.7rem;font-weight:var(--weight-bold);letter-spacing:.05em;display:inline-block}.badge-info{background:#3b82f61a;color:var(--color-primary-400)}.badge-primary{background:#3b82f626;color:var(--color-info-400)}.badge-warning{background:#f59e0b1a;color:var(--color-warning-500)}.badge-danger{background:#ef44441a;color:var(--color-danger-500)}.badge-success{background:#10b9811a;color:var(--color-primary-500)}.fw-bold{font-weight:var(--weight-bold);color:var(--text-primary)}.text-muted{color:var(--text-tertiary)}.text-danger{color:var(--color-danger-500)}.text-success{color:var(--color-success-500)}.state-badge{display:inline-flex;align-items:center;gap:4px;font-weight:var(--weight-medium)}.admin-pagination{display:flex;justify-content:center;align-items:center;gap:var(--space-4);padding:var(--space-4);border-top:1px solid var(--border-subtle)}.admin-pagination button{display:inline-flex;align-items:center;gap:var(--space-1);background:var(--surface-200);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);color:var(--text-primary);font-size:var(--font-sm);cursor:pointer;transition:background var(--transition-fast)}.admin-pagination button:hover:not(:disabled){background:var(--surface-300)}.admin-pagination button:disabled{opacity:.4;cursor:not-allowed}.admin-pagination span{font-size:var(--font-sm);color:var(--text-tertiary)}.admin-action-dropdown{position:absolute;right:0;top:100%;z-index:50;background:var(--surface-200);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:200px;padding:var(--space-1) 0;animation:fadeIn .15s ease}.admin-action-dropdown button{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-4);background:none;border:none;color:var(--text-primary);font-size:var(--font-sm);cursor:pointer;text-align:left;transition:background var(--transition-fast)}.admin-action-dropdown button:hover{background:var(--surface-300)}.admin-action-dropdown hr{margin:var(--space-1) 0;border:none;border-top:1px solid var(--border-subtle)}.admin-menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40}.admin-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}.admin-modal{background:var(--surface-100);border:1px solid var(--border-default);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:640px;max-height:90vh;overflow-y:auto;animation:slideUp .2s ease}.admin-modal-sm{max-width:440px}.admin-modal--wide{max-width:800px}.admin-modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-subtle)}.admin-modal-header h2{font-size:1.1rem;font-weight:var(--weight-bold);color:var(--text-primary);margin:0}.admin-modal-body{padding:var(--space-6)}.admin-modal-footer{display:flex;justify-content:flex-end;gap:var(--space-3);padding-top:var(--space-5);margin-top:var(--space-4);border-top:1px solid var(--border-subtle)}.admin-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}@media(max-width:768px){.admin-modal{max-width:calc(100vw - 1rem);max-height:85vh;margin:0 .5rem;border-radius:var(--radius-lg)}.admin-modal--wide{max-width:calc(100vw - 1rem)}.admin-modal-header{padding:var(--space-3) var(--space-4)}.admin-modal-header h2{font-size:1rem}.admin-modal-body{padding:var(--space-4)}.admin-modal-footer{padding:var(--space-3) var(--space-4)}.admin-toolbar{flex-direction:column;align-items:stretch;gap:var(--space-2);margin:var(--space-2) 0}.search-bar{width:100%}.admin-filters{gap:var(--space-1)}.admin-filters select,.admin-filters input[type=date]{font-size:13px;padding:var(--space-2)}.admin-table th{padding:var(--space-2) var(--space-3);font-size:10px}.admin-table td{padding:var(--space-2) var(--space-3);font-size:13px}.admin-pagination{gap:var(--space-2);padding:var(--space-3)}.admin-pagination button{padding:var(--space-2);font-size:13px}.admin-kpi-grid{grid-template-columns:1fr 1fr;gap:var(--space-2);margin-top:var(--space-3)}.admin-kpi-card{padding:var(--space-3);gap:var(--space-2);flex-direction:column;align-items:flex-start}.admin-kpi-icon{width:36px;height:36px}.admin-kpi-value{font-size:1.2rem}.admin-role-bar-label{min-width:90px;font-size:12px}.admin-action-dropdown{min-width:160px;right:0}.admin-sections-grid{gap:var(--space-3);margin-top:var(--space-3)}.admin-section-card,.audit-detail-content{padding:var(--space-3)}.audit-detail-json pre{font-size:10px;padding:var(--space-2)}}@media(max-width:600px){.admin-form-grid{grid-template-columns:1fr}}.admin-form-grid label{display:flex;flex-direction:column;gap:var(--space-1)}.admin-form-grid label span{font-size:var(--font-xs);font-weight:var(--weight-semibold);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.admin-form-grid input,.admin-form-grid select{background:var(--surface-200);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);color:var(--text-primary);font-family:inherit;font-size:var(--font-sm);outline:none;transition:border-color var(--transition-fast)}.admin-form-grid input:focus,.admin-form-grid select:focus{border-color:var(--color-primary-500)}.admin-modal-body>label{display:flex;flex-direction:column;gap:var(--space-1)}.admin-modal-body>label span{font-size:var(--font-xs);font-weight:var(--weight-semibold);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.admin-modal-body>label input{background:var(--surface-200);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);color:var(--text-primary);font-family:inherit;font-size:var(--font-sm);outline:none}.admin-modal-body>label input:focus{border-color:var(--color-primary-500)}.admin-kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--space-4);margin-top:var(--space-6)}.admin-kpi-card{background:var(--surface-100);border:1px solid var(--border-default);border-radius:var(--radius-xl);padding:var(--space-5);display:flex;align-items:center;gap:var(--space-4);cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.admin-kpi-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--border-strong)}.admin-kpi-icon{width:48px;height:48px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.admin-kpi-body{display:flex;flex-direction:column}.admin-kpi-value{font-size:1.5rem;font-weight:var(--weight-bold);color:var(--text-primary);line-height:1.1}.admin-kpi-label{font-size:var(--font-sm);color:var(--text-secondary);margin-top:2px}.admin-kpi-detail{font-size:.72rem;color:var(--text-tertiary);margin-top:2px}.admin-sections-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6);margin-top:var(--space-6)}@media(max-width:900px){.admin-sections-grid{grid-template-columns:1fr}}.admin-section-card{background:var(--surface-100);border:1px solid var(--border-default);border-radius:var(--radius-xl);padding:var(--space-5)}.admin-section-title{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-sm);font-weight:var(--weight-bold);color:var(--text-primary);margin:0 0 var(--space-4) 0;text-transform:uppercase;letter-spacing:.04em}.admin-role-bars{display:flex;flex-direction:column;gap:var(--space-3)}.admin-role-bar-row{display:flex;align-items:center;gap:var(--space-3)}.admin-role-bar-label{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-sm);color:var(--text-secondary);min-width:130px}.admin-role-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.admin-role-bar-track{flex:1;height:6px;background:var(--surface-300);border-radius:3px;overflow:hidden}.admin-role-bar-fill{height:100%;border-radius:3px;transition:width .5s ease}.admin-role-bar-count{font-size:var(--font-sm);font-weight:var(--weight-bold);color:var(--text-primary);min-width:24px;text-align:right}.admin-quick-actions{display:flex;flex-direction:column;gap:var(--space-2)}.admin-action-btn{display:flex;align-items:center;gap:var(--space-3);background:var(--surface-200);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);color:var(--text-primary);font-size:var(--font-sm);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast)}.admin-action-btn:hover{background:var(--surface-300);border-color:var(--border-default)}.audit-row-expanded{background:var(--surface-200)!important}.audit-detail-row td{padding:0!important;border-bottom:2px solid var(--border-default)!important}.audit-detail-content{padding:var(--space-4) var(--space-6);background:var(--surface-50);display:flex;flex-direction:column;gap:var(--space-3)}.audit-detail-field{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-sm);color:var(--text-secondary)}.audit-detail-field strong{color:var(--text-primary)}.audit-detail-json{font-size:var(--font-sm)}.audit-detail-json strong{display:block;color:var(--text-primary);margin-bottom:var(--space-1)}.audit-detail-json pre{background:var(--surface-200);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-3);font-size:.72rem;color:var(--text-secondary);overflow-x:auto;margin:0;max-height:200px}.admin-color-swatch{width:24px;height:24px;border-radius:var(--radius-md);border:2px solid var(--border-default)}.admin-toggle-label{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-sm);color:var(--text-secondary);cursor:pointer}.admin-toggle-label input[type=checkbox]{accent-color:var(--color-primary-500)}.btn-sm{padding:var(--space-1) var(--space-3)!important;font-size:.72rem!important}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.dashboard-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6);margin-top:var(--space-6)}@media(max-width:1024px){.dashboard-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.dashboard-grid{grid-template-columns:1fr}}.kpi-card{background:var(--surface-100);border:1px solid var(--border-default);border-radius:var(--radius-xl);padding:var(--space-5);display:flex;align-items:center;gap:var(--space-4);transition:transform .2s ease,box-shadow .2s ease}.kpi-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.kpi-icon{width:56px;height:56px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.bg-info{background:var(--color-primary-500)}.bg-success{background:var(--color-success-500)}.bg-warning{background:var(--color-warning-500)}.kpi-info{display:flex;flex-direction:column}.kpi-label{font-size:var(--font-sm);color:var(--text-secondary);font-weight:var(--weight-medium);margin-bottom:2px}.kpi-value{font-size:var(--font-3xl);font-weight:var(--weight-bold);color:var(--text-primary);line-height:1}.chart-card{background:var(--surface-100);border:1px solid var(--border-default);border-radius:var(--radius-xl);padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-4)}.span-2{grid-column:span 2}@media(max-width:1024px){.span-2{grid-column:span 1}}.chart-title{font-size:var(--font-base);font-weight:var(--weight-bold);color:var(--text-primary)}.chart-wrapper{position:relative;height:280px;width:100%}:root{--color-primary-50: #ecfdf5;--color-primary-100: #d1fae5;--color-primary-200: #a7f3d0;--color-primary-300: #6ee7b7;--color-primary-400: #34d399;--color-primary-500: #10b981;--color-primary-600: #059669;--color-primary-700: #047857;--color-primary-800: #065f46;--color-primary-900: #064e3b;--color-accent-400: #fbbf24;--color-accent-500: #f59e0b;--color-accent-600: #d97706;--color-danger-50: rgba(239, 68, 68, .06);--color-danger-200: rgba(239, 68, 68, .2);--color-danger-400: #f87171;--color-danger-500: #ef4444;--color-danger-600: #dc2626;--color-danger-700: #b91c1c;--color-warning-400: #fb923c;--color-warning-500: #f97316;--color-info-400: #60a5fa;--color-info-500: #3b82f6;--surface-0: #050810;--surface-50: #0a0f1e;--surface-100: #0f1629;--surface-200: #141c33;--surface-300: #1a2340;--surface-400: #232e4d;--surface-500: #2e3a5a;--surface-600: #3b4a6b;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-tertiary: #64748b;--text-muted: #475569;--text-inverse: #0f172a;--border-subtle: rgba(148, 163, 184, .08);--border-default: rgba(148, 163, 184, .12);--border-strong: rgba(148, 163, 184, .2);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow-md: 0 4px 12px rgba(0, 0, 0, .5);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .6);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .7);--shadow-glow: 0 0 20px rgba(16, 185, 129, .15);--glass-bg: rgba(15, 22, 41, .75);--glass-border: rgba(148, 163, 184, .06);--glass-blur: 16px;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-full: 9999px;--font-family: "Outfit", -apple-system, BlinkMacSystemFont, sans-serif;--font-xs: .75rem;--font-sm: .875rem;--font-base: 1rem;--font-lg: 1.125rem;--font-xl: 1.25rem;--font-2xl: 1.5rem;--font-3xl: 1.875rem;--font-4xl: 2.25rem;--weight-regular: 400;--weight-medium: 500;--weight-semibold: 600;--weight-bold: 700;--leading-tight: 1.25;--leading-normal: 1.5;--leading-relaxed: 1.625;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .35s cubic-bezier(.4, 0, .2, 1);--sidebar-width: 220px;--sidebar-collapsed: 56px;--header-height: 52px;--max-content: 1400px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box;font-family:var(--font-family)}html{font-size:19px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth;-webkit-tap-highlight-color:transparent}body{background-color:var(--surface-50);color:var(--text-primary);font-family:var(--font-family);font-size:var(--font-base);font-weight:var(--weight-regular);line-height:var(--leading-normal);min-height:100vh;overflow-x:hidden}#root{min-height:100vh;display:flex;flex-direction:column}a{color:var(--color-primary-400);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-300)}img{max-width:100%;display:block}button{cursor:pointer;border:none;background:none;font-family:var(--font-family);font-size:var(--font-sm);color:var(--text-primary)}input,select,textarea{font-family:var(--font-family);font-size:var(--font-base);color:var(--text-primary)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--surface-500);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--surface-600)}::selection{background:#10b9814d;color:var(--text-primary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);border-radius:var(--radius-md);font-weight:var(--weight-semibold);font-size:var(--font-sm);letter-spacing:.01em;transition:all var(--transition-fast);white-space:nowrap;-webkit-user-select:none;user-select:none;position:relative;overflow:hidden}.btn:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#fff;opacity:0;transition:opacity var(--transition-fast)}.btn:hover:after{opacity:.06}.btn:active:after{opacity:.12}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn-primary{background:linear-gradient(135deg,var(--color-primary-500),var(--color-primary-600));color:#fff;box-shadow:0 2px 8px #10b98140}.btn-primary:hover{box-shadow:0 4px 16px #10b98159;transform:translateY(-1px)}.btn-secondary{background:var(--surface-300);color:var(--text-primary);border:1px solid var(--border-default)}.btn-secondary:hover{background:var(--surface-400);border-color:var(--border-strong)}.btn-danger{background:linear-gradient(135deg,var(--color-danger-500),var(--color-danger-600));color:#fff;box-shadow:0 2px 8px #ef444440}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--surface-300);color:var(--text-primary)}.btn-sm{padding:var(--space-2) var(--space-3);font-size:var(--font-xs)}.btn-lg{padding:var(--space-4) var(--space-8);font-size:var(--font-base)}.btn-icon{padding:var(--space-2);border-radius:var(--radius-md);width:36px;height:36px}.card{background:var(--surface-100);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-6);transition:all var(--transition-base)}.card:hover{border-color:var(--border-default)}.card-glass{background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border)}.input-group{display:flex;flex-direction:column;gap:var(--space-2)}.input-label{font-size:var(--font-sm);font-weight:var(--weight-medium);color:var(--text-secondary);letter-spacing:.02em;text-transform:uppercase}.input-field{padding:var(--space-3) var(--space-4);background:var(--surface-200);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--font-base);transition:all var(--transition-fast);outline:none;width:100%}.input-field::placeholder{color:var(--text-muted)}.input-field:focus{border-color:var(--color-primary-500);box-shadow:0 0 0 3px #10b9811f}.input-field:disabled{opacity:.5;cursor:not-allowed}.input-error{border-color:var(--color-danger-500)!important;box-shadow:0 0 0 3px #ef44441a!important}.input-error-text{font-size:var(--font-xs);color:var(--color-danger-400);margin-top:var(--space-1)}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:2px var(--space-3);border-radius:var(--radius-full);font-size:var(--font-xs);font-weight:var(--weight-semibold);letter-spacing:.04em;text-transform:uppercase}.badge-green{background:#10b9811f;color:var(--color-primary-400)}.badge-amber{background:#f59e0b1f;color:var(--color-accent-400)}.badge-red{background:#ef44441f;color:var(--color-danger-400)}.badge-blue{background:#3b82f61f;color:var(--color-info-400)}.badge-gray{background:#94a3b81f;color:var(--text-secondary)}.avatar{width:36px;height:36px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-weight:var(--weight-bold);font-size:var(--font-sm);text-transform:uppercase;background:linear-gradient(135deg,var(--color-primary-600),var(--color-primary-800));color:#fff;flex-shrink:0}.avatar-lg{width:48px;height:48px;font-size:var(--font-base)}.spinner{width:20px;height:20px;border:2px solid var(--border-default);border-top-color:var(--color-primary-400);border-radius:50%;animation:spin .6s linear infinite}.spinner-lg{width:32px;height:32px;border-width:3px}@keyframes spin{to{transform:rotate(360deg)}}.page-loader{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--surface-50)}.page-container{display:flex;flex-direction:column;gap:var(--space-4);padding-top:var(--space-2)}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-3);padding:0 var(--space-6)}.page-header-left{display:flex;align-items:center;gap:var(--space-3);color:var(--text-primary)}.page-title{font-size:var(--font-xl);font-weight:var(--weight-bold);color:var(--text-primary);margin:0;line-height:var(--leading-tight)}.page-subtitle{font-size:var(--font-sm);color:var(--text-tertiary);margin:2px 0 0}@media(max-width:768px){.page-header{padding:0 var(--space-3)}.page-title{font-size:var(--font-lg)}.page-subtitle{font-size:var(--font-xs)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fadeIn var(--transition-base) ease-out}@keyframes slideInRight{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}.animate-slide-in{animation:slideInRight var(--transition-base) ease-out}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.animate-scale-in{animation:scaleIn var(--transition-fast) ease-out}@media(max-width:768px){html{font-size:16px}:root{--sidebar-width: 0px;--header-height: 52px}button,a,.btn,.sidebar-link,.btb-tab{-webkit-user-select:none;user-select:none}.app-content{animation:mobilePageIn .2s ease-out}@keyframes mobilePageIn{0%{opacity:.7;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.card:active,.swap-card:active{transform:scale(.985);transition:transform 80ms ease}}[data-sonner-toaster]{--width: 340px;font-family:var(--font-family)!important}[data-sonner-toaster] [data-sonner-toast]{border-radius:10px!important;font-size:13px!important;font-weight:500!important;box-shadow:0 8px 32px #0000008c!important;border-width:1px!important;gap:10px!important;padding:12px 14px!important;--normal-bg: var(--surface-300);--normal-border: var(--border-strong);--normal-text: var(--text-primary);--normal-description-text: var(--text-secondary)}[data-sonner-toaster] [data-title]{font-size:13px!important;font-weight:600!important;line-height:1.3!important}[data-sonner-toaster] [data-description]{font-size:11.5px!important;line-height:1.4!important;margin-top:1px!important}[data-sonner-toaster] [data-sonner-toast][data-type=success]{--success-bg: #0d2b1e;--success-border: #10B981;--success-text: #6ee7b7;--success-description-text:#34d399}[data-sonner-toaster] [data-sonner-toast][data-type=error]{--error-bg: #2b0d0d;--error-border: #ef4444;--error-text: #fca5a5;--error-description-text:#f87171}[data-sonner-toaster] [data-sonner-toast][data-type=warning]{--warning-bg: #2b1e07;--warning-border: #f59e0b;--warning-text: #fcd34d;--warning-description-text:#fbbf24}[data-sonner-toaster] [data-sonner-toast][data-type=info]{--info-bg: #0d1b2b;--info-border: #3b82f6;--info-text: #93c5fd;--info-description-text:#60a5fa}[data-sonner-toaster] [data-close-button]{background:var(--surface-400)!important;border-color:var(--border-default)!important;color:var(--text-muted)!important;top:8px!important;right:8px!important;width:20px!important;height:20px!important;border-radius:5px!important}[data-sonner-toaster] [data-close-button]:hover{background:var(--surface-500)!important;color:var(--text-primary)!important}
