*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--navy:#1b3a56;--navy-dark:#0d1f33;--navy-light:#254e72;--gold:#c8973b;--gold-hover:#b5852d;--white:#fff;--off-white:#f5f4f1;--gray-100:#eeece7;--gray-200:#dbd8d0;--gray-300:#c3bfb5;--gray-400:#9e998f;--gray-500:#726d63;--gray-600:#524e46;--gray-700:#373229;--gray-800:#211d18;--text:#28231e;--text-light:#55504a;--error:#bf3b2e;--success:#1c7a42;--shadow-xs:0 1px 3px #0d1f3312;--shadow-sm:0 2px 8px #0d1f3314, 0 0 0 1px #0d1f330a;--shadow:0 4px 16px #0d1f3317, 0 1px 4px #0d1f330a;--shadow-md:0 8px 28px #0d1f331c, 0 2px 8px #0d1f330d;--shadow-lg:0 20px 52px #0d1f3321, 0 8px 20px #0d1f330f;--sans:"Plus Jakarta Sans", system-ui, -apple-system, "Segoe UI", sans-serif;font-family:var(--sans);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;line-height:1.55}body{background:var(--off-white);min-height:100vh;margin:0}#root{text-align:left;border:none;width:100%;min-height:100vh;display:block}h1,h2,h3,h4{font-family:var(--sans);color:var(--gray-800);letter-spacing:-.03em;font-weight:800;line-height:1.18}a{color:inherit}button{font-family:var(--sans)}.btn{cursor:pointer;white-space:nowrap;letter-spacing:-.01em;border:2px solid #0000;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:10px 22px;font-size:14px;font-weight:700;text-decoration:none;transition:background .18s,border-color .18s,color .18s,box-shadow .18s,transform .18s;display:inline-flex}.btn-primary{background:var(--gold);color:var(--navy-dark);border-color:var(--gold)}.btn-primary:hover{background:var(--gold-hover);border-color:var(--gold-hover);transform:translateY(-1px);box-shadow:0 4px 16px #c8973b66}.btn-navy{background:var(--navy);color:var(--white);border-color:var(--navy)}.btn-navy:hover{background:var(--navy-light);border-color:var(--navy-light);transform:translateY(-1px);box-shadow:0 4px 16px #1b3a5652}.btn-ghost{color:#ffffffe6;background:0 0;border-color:#ffffff47}.btn-ghost:hover{background:#ffffff1a;border-color:#ffffffb8}.btn-outline{color:#ffffffe6;background:0 0;border-color:#fff6}.btn-outline:hover{background:#ffffff24;border-color:#ffffffc7}.btn-lg{border-radius:12px;padding:14px 32px;font-size:15px}.navbar,.hero-bottom-bar{background-color:#0f1f3d;background-image:radial-gradient(circle,#ffffff16 1px,#0000 1px),radial-gradient(circle,#ffffff0b 1px,#0000 1px);background-position:0 0,2px 3px;background-size:4px 4px,9px 9px}.navbar{z-index:100;border-bottom:1px solid #ffffff12;padding:0 32px;position:sticky;top:0}.nav-container{justify-content:center;align-items:center;max-width:1200px;height:68px;margin:0 auto;display:flex}.nav-brand{align-items:center;gap:10px;text-decoration:none;display:flex}.nav-brand-text{color:var(--white);letter-spacing:-.5px;font-size:20px;font-weight:800}.nav-links{align-items:center;gap:10px;display:flex}.hero{text-align:center;width:100%;max-width:none;color:var(--white);background:#1a0a00;margin:0;padding:110px 0 120px;position:relative;overflow:hidden}.hero-video{object-fit:cover;object-position:center center;z-index:0;pointer-events:none;width:100%;height:100%;position:absolute;inset:0}.hero-overlay{z-index:1;pointer-events:none;background-color:#8c4b0038;background-image:radial-gradient(at 50% 52%,#00000085 0%,#00000042 36%,#00000012 64%,#0000 82%);position:absolute;inset:0}.hero-bottom-bar{z-index:2;pointer-events:none;border-top:1px solid #ffffff12;height:68px;position:absolute;bottom:0;left:0;right:0}.hero-container{z-index:3;max-width:800px;margin:0 auto;padding:0 32px;position:relative}.hero-text-wrap{-webkit-backdrop-filter:blur(14px)saturate(.8);background:#0604028a;border:1px solid #ffffff12;border-radius:22px;margin-bottom:32px;padding:46px 52px 40px}.hero-badge{color:#f0cc7a;letter-spacing:.9px;text-transform:uppercase;background:#c8973b33;border:1px solid #c8973b6b;border-radius:100px;align-items:center;gap:8px;margin-bottom:28px;padding:6px 20px;font-size:11px;font-weight:700;display:inline-flex}.hero h1{color:#fff;letter-spacing:-2.6px;-webkit-text-stroke:0;text-shadow:0 2px 4px #000000e6,0 4px 12px #000000b3,0 8px 28px #00000073;margin:0 0 18px;font-size:66px;font-weight:800;line-height:1.03}.hero-tagline{color:#fbbf24;letter-spacing:0;text-shadow:0 1px 4px #000c,0 2px 12px #00000080;margin:0 0 22px;font-size:21px;font-weight:700}.hero-subtitle{color:#ffffffed;text-shadow:0 1px 3px #000000d9,0 2px 10px #0000008c;max-width:520px;margin:0 auto;font-size:18px;font-weight:400;line-height:1.72}.hero-ctas{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}@media (width<=640px){.hero{padding:72px 0 80px}.hero-container{padding:0 16px}.hero-text-wrap{border-radius:16px;margin-bottom:24px;padding:32px 22px 28px}.hero h1{letter-spacing:-1.2px;font-size:36px}.hero-tagline{font-size:17px}.hero-subtitle{font-size:15px}}.section-container{max-width:1100px;margin:0 auto}.section-header{text-align:center;margin-bottom:56px}.section-header h2{color:var(--navy-dark);letter-spacing:-.8px;margin-bottom:14px;font-size:36px;font-weight:800}.section-header p{color:var(--text-light);max-width:480px;margin:0 auto;font-size:17px;line-height:1.68}.lp-features{background-color:#0f1f3d;background-image:radial-gradient(circle,#ffffff16 1px,#0000 1px),radial-gradient(circle,#ffffff0b 1px,#0000 1px);background-position:0 0,2px 3px;background-size:4px 4px,9px 9px;padding:96px 32px 104px}.lp-features-header{text-align:center;margin-bottom:60px}.lp-heading-pill{background:#fdf8f0f7;border:1px solid #c8aa734d;border-radius:22px;max-width:680px;padding:44px 64px 38px;display:inline-block;box-shadow:0 4px 32px #00000038}.lp-heading-pill h2{color:var(--navy-dark);letter-spacing:-1px;margin:0 0 14px;font-size:38px;font-weight:800;line-height:1.18}.lp-heading-pill p{color:var(--text-light);max-width:380px;margin:0 auto;font-size:16px;line-height:1.68}.lp-br{display:block}.lp-cards{grid-template-columns:repeat(3,1fr);gap:22px;display:grid}.lp-card{background:var(--white);border:1px solid #ffffff1a;border-radius:20px;padding:36px 30px 38px;transition:transform .22s,box-shadow .22s,border-color .22s;box-shadow:0 4px 20px #0000004d}.lp-card:hover{border-color:#c8973b80;transform:translateY(-4px);box-shadow:0 10px 38px #00000073}.lp-card-icon{color:#a07020;background:#c8973b21;border-radius:14px;justify-content:center;align-items:center;width:52px;height:52px;margin-bottom:22px;display:flex}.lp-card-icon svg{width:24px;height:24px}.lp-card h3{color:var(--navy-dark);letter-spacing:-.3px;margin:0 0 12px;font-size:18px;font-weight:800}.lp-card p{color:var(--text-light);margin:0;font-size:14px;line-height:1.74}@media (width<=780px){.lp-cards{grid-template-columns:1fr}.lp-br{display:none}.lp-features{padding:72px 20px 80px}.lp-heading-pill{border-radius:16px;max-width:100%;padding:32px 24px 28px}.lp-heading-pill h2{font-size:28px}}.footer{background:var(--navy-dark);padding:36px 32px 0}.footer-container{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;max-width:1200px;margin:0 auto;padding-bottom:28px;display:flex}.footer-brand{align-items:center;gap:10px;display:flex}.footer-brand-text{color:var(--white);font-size:16px;font-weight:800}.footer-links{gap:24px;display:flex}.footer-links a{color:#ffffff73;font-size:14px;font-weight:500;text-decoration:none;transition:color .15s}.footer-links a:hover{color:var(--white)}.footer-copy{color:#ffffff59;text-align:center;border-top:1px solid #ffffff12;max-width:1200px;margin:0 auto;padding:18px 0;font-size:13px}.auth-page{background:var(--off-white);flex-direction:column;min-height:100vh;display:flex}.auth-nav{background:var(--navy-dark);border-bottom:1px solid #ffffff0f;padding:0 32px}.auth-nav-inner{align-items:center;max-width:1200px;height:64px;margin:0 auto;display:flex}.auth-main{flex:1;justify-content:center;align-items:center;padding:52px 24px;display:flex}.auth-card{background:var(--white);border:1px solid var(--gray-100);width:100%;max-width:440px;box-shadow:var(--shadow-md);border-radius:22px;padding:48px}.onboarding-card{max-width:520px}.auth-card-header{text-align:center;margin-bottom:36px}.auth-card-icon{justify-content:center;margin-bottom:20px;display:flex}.auth-logo-wrap{background:var(--navy-dark);box-shadow:var(--shadow);border-radius:20px;justify-content:center;align-items:center;padding:12px 18px;display:inline-flex}.auth-card-header h1{color:var(--navy-dark);letter-spacing:-.5px;margin-bottom:8px;font-size:26px;font-weight:800}.auth-card-header p{color:var(--text-light);font-size:14px;line-height:1.55}.auth-form{flex-direction:column;gap:16px;display:flex}.form-section-label{color:var(--gray-500);letter-spacing:.8px;text-transform:uppercase;margin-top:4px;margin-bottom:-4px;font-size:11px;font-weight:700}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:var(--gray-700);letter-spacing:-.1px;font-size:13px;font-weight:600}.form-group input{border:1.5px solid var(--gray-200);width:100%;font-size:15px;font-family:var(--sans);color:var(--text);background:var(--white);border-radius:10px;outline:none;padding:11px 15px;transition:border-color .15s,box-shadow .15s}.form-group input:focus{border-color:var(--navy);box-shadow:0 0 0 3px #1b3a561f}.form-group input::placeholder{color:var(--gray-400)}.form-group textarea{border:1.5px solid var(--gray-200);width:100%;font-size:15px;font-family:var(--sans);color:var(--text);background:var(--white);box-sizing:border-box;border-radius:10px;outline:none;padding:11px 15px;transition:border-color .15s,box-shadow .15s}.form-group textarea:focus{border-color:var(--navy);box-shadow:0 0 0 3px #1b3a561f}.form-group textarea::placeholder{color:var(--gray-400)}.form-select{border:1.5px solid var(--gray-200);width:100%;font-size:15px;font-family:var(--sans);color:var(--text);background-color:var(--white);appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2364748b' stroke-width='2'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M19 9l-7 7-7-7'/%3E%3C/svg%3E");background-position:right 11px center;background-repeat:no-repeat;background-size:18px;border-radius:10px;outline:none;padding:11px 36px 11px 15px;transition:border-color .15s,box-shadow .15s}.form-select:focus{border-color:var(--navy);box-shadow:0 0 0 3px #1b3a561f}.form-select.select-placeholder{color:var(--gray-400)}.form-submit{background:var(--navy);width:100%;color:var(--white);font-size:15px;font-weight:700;font-family:var(--sans);cursor:pointer;letter-spacing:-.01em;border:none;border-radius:10px;margin-top:4px;padding:13px;transition:background .18s,box-shadow .18s,transform .18s}.form-submit:hover:not(:disabled){background:var(--navy-light);transform:translateY(-1px);box-shadow:0 4px 16px #1b3a5652}.form-submit:disabled{opacity:.55;cursor:not-allowed}.form-error{color:var(--error);background:#fdf3f2;border:1px solid #f5c8c3;border-radius:10px;padding:11px 15px;font-size:13px;line-height:1.55}.form-success{color:var(--success);background:#f0f9f4;border:1px solid #b7e4ca;border-radius:10px;padding:11px 15px;font-size:13px;line-height:1.55}.form-footer{text-align:center;color:var(--text-light);margin-top:24px;font-size:14px}.form-footer a{color:var(--navy);font-weight:700;text-decoration:none}.form-footer a:hover{text-decoration:underline}.dashboard{height:100vh;display:flex;overflow:hidden}.sidebar{width:252px;min-width:252px;color:var(--white);background:linear-gradient(#0c1e31 0%,#09192a 100%);border-right:1px solid #ffffff0d;flex-direction:column;display:flex}.sidebar-brand{border-bottom:1px solid #ffffff12;align-items:center;gap:10px;padding:22px 20px 20px;text-decoration:none;display:flex}.sidebar-brand-text{color:var(--white);letter-spacing:-.45px;font-size:18px;font-weight:800}.sidebar-section-label{color:#ffffff47;letter-spacing:1px;text-transform:uppercase;padding:18px 20px 6px;font-size:10px;font-weight:700}.sidebar-nav{flex:1;padding:8px 12px}.sidebar-nav-item{color:#ffffff8c;cursor:pointer;text-align:left;letter-spacing:-.1px;background:0 0;border:none;border-left:2px solid #0000;border-radius:10px;align-items:center;gap:10px;width:100%;padding:10px 12px;font-size:14px;font-weight:600;text-decoration:none;transition:background .15s,color .15s;display:flex}.sidebar-nav-item:hover{color:#ffffffe6;background:#ffffff12}.sidebar-nav-item.active{color:var(--white);border-left-color:var(--gold);background:#ffffff17}.sidebar-nav-item svg{opacity:.85;flex-shrink:0;width:17px;height:17px}.sidebar-footer{border-top:1px solid #ffffff12;padding:16px 20px 20px}.sidebar-user{align-items:center;gap:10px;margin-bottom:12px;display:flex}.sidebar-user-avatar{color:#ddb96a;background:#c8973b33;border:1px solid #c8973b52;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:13px;font-weight:700;display:flex}.sidebar-user-info{overflow:hidden}.sidebar-user-name{color:#ffffffe6;white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:700;overflow:hidden}.sidebar-user-email{color:#ffffff61;white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.sidebar-signout{color:#ffffff57;font-size:13px;font-family:var(--sans);cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;width:100%;padding:6px 0;transition:color .15s;display:flex}.sidebar-signout:hover{color:#ffffffc7}.sidebar-signout svg{width:15px;height:15px}.chat-area{background:var(--off-white);flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.chat-header{background:var(--white);border-bottom:1px solid var(--gray-100);box-shadow:0 1px 0 var(--gray-100);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 28px;display:flex}.chat-header-left{align-items:center;gap:14px;display:flex}.chat-header-right{align-items:center;display:flex}.chat-header-icon{background:var(--navy);border-radius:13px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex;box-shadow:0 2px 8px #1b3a5647}.chat-header-info h2{color:var(--navy-dark);letter-spacing:-.2px;margin:0;font-size:15px;font-weight:700}.chat-header-info p{color:var(--gray-500);margin:2px 0 0;font-size:12px}.chat-action-bar{border-bottom:1px solid var(--gray-100);background:var(--white);flex-shrink:0;align-items:center;gap:8px;padding:7px 20px;display:flex}.chat-action-label{color:var(--gray-400);letter-spacing:.2px;text-transform:uppercase;flex:1;margin-right:4px;font-size:11px;font-weight:600}.chat-action-btn{border:1px solid var(--gray-200);color:var(--gray-600);cursor:pointer;font-size:12px;font-weight:600;font-family:var(--sans);white-space:nowrap;background:0 0;border-radius:6px;align-items:center;gap:5px;padding:4px 12px;transition:background .14s,border-color .14s,color .14s;display:inline-flex}.chat-action-btn:hover:not(:disabled){border-color:var(--gray-400);color:var(--gray-800);background:var(--gray-100)}.chat-action-btn:disabled{opacity:.45;cursor:not-allowed}.chat-action-btn--save:hover:not(:disabled){border-color:var(--navy);color:var(--navy);background:#1b3a560d}.chat-messages{scroll-behavior:smooth;flex-direction:column;flex:1;gap:18px;padding:28px;display:flex;overflow-y:auto}.message{gap:10px;max-width:80%;display:flex}.message.user{flex-direction:row-reverse;align-self:flex-end}.message.assistant{align-self:flex-start}.message-avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;margin-top:2px;font-size:13px;font-weight:700;display:flex}.message.user .message-avatar{color:#fbbf24;background:#0f1f3d}.message.assistant .message-avatar{color:var(--white);letter-spacing:-.5px;background:#0f1f3d;font-size:11px}.message-bubble{white-space:pre-wrap;word-break:break-word;border-radius:18px;padding:13px 17px;font-size:14px;line-height:1.72}.message.user .message-bubble{background:var(--navy);color:var(--white);border-radius:18px 5px 18px 18px;animation:.3s forwards paraFadeIn;box-shadow:0 2px 10px #1b3a5647}.message.assistant .message-bubble{background:var(--white);color:var(--text);border:1px solid var(--gray-100);box-shadow:var(--shadow-xs);border-radius:5px 18px 18px;transition:opacity .18s}.message-bubble--pre{opacity:0;pointer-events:none}.typing-indicator{align-items:center;gap:5px;padding:4px 2px;display:flex}.typing-dot{background:var(--gray-400);border-radius:50%;width:7px;height:7px;animation:1.2s infinite bounce}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,80%,to{opacity:.5;transform:translateY(0)}40%{opacity:1;transform:translateY(-5px)}}@keyframes paraFadeIn{0%{opacity:0}to{opacity:1}}.para-fade{animation:.7s forwards paraFadeIn;display:block}.para-fade+.para-fade{margin-top:.85em}.chat-welcome{text-align:center;align-self:center;max-width:520px;margin:auto;padding:24px}.chat-welcome-icon{justify-content:center;margin-bottom:26px;display:flex}.welcome-logo-bg{background:var(--navy-dark);box-shadow:var(--shadow-md);border-radius:24px;justify-content:center;align-items:center;padding:15px 20px;display:inline-flex}.chat-welcome h3{color:var(--navy-dark);letter-spacing:-.45px;margin-bottom:10px;font-size:23px;font-weight:800}.chat-welcome p{color:var(--text-light);margin-bottom:28px;font-size:15px;line-height:1.68}.suggestions-grid{text-align:left;grid-template-columns:1fr 1fr;gap:8px;display:grid}.suggestion-chip{background:var(--white);border:1.5px solid var(--gray-200);font-size:13px;font-family:var(--sans);color:var(--navy);cursor:pointer;text-align:left;box-shadow:var(--shadow-xs);border-radius:13px;padding:12px 16px;font-weight:500;line-height:1.45;transition:all .18s}.suggestion-chip:hover{background:var(--navy);color:var(--white);border-color:var(--navy);transform:translateY(-1px);box-shadow:0 4px 14px #1b3a5647}.chat-input-area{background:var(--white);border-top:1px solid var(--gray-100);flex-shrink:0;padding:16px 28px 18px}.chat-input-form{align-items:flex-end;gap:10px;max-width:860px;margin:0 auto;display:flex}.chat-input{border:1.5px solid var(--gray-200);font-size:14px;font-family:var(--sans);color:var(--text);resize:none;background:var(--white);border-radius:13px;outline:none;flex:1;min-height:46px;max-height:120px;padding:12px 16px;line-height:1.55;transition:border-color .15s,box-shadow .15s}.chat-input:focus{border-color:var(--navy);box-shadow:0 0 0 3px #1b3a561a}.chat-input::placeholder{color:var(--gray-400)}.chat-send{background:var(--navy);width:46px;height:46px;color:var(--white);cursor:pointer;border:none;border-radius:13px;flex-shrink:0;justify-content:center;align-items:center;transition:background .18s,box-shadow .18s,transform .18s;display:flex;box-shadow:0 2px 8px #1b3a5638}.chat-send:hover:not(:disabled){background:var(--navy-light);transform:translateY(-1px);box-shadow:0 4px 14px #1b3a5652}.chat-send:disabled{opacity:.4;cursor:not-allowed;box-shadow:none;transform:none}.chat-send svg{width:18px;height:18px}.chat-input-hint{text-align:center;color:var(--gray-400);max-width:860px;margin-top:8px;margin-left:auto;margin-right:auto;font-size:11px}.profile-btn{background:var(--navy);width:36px;height:36px;color:var(--white);font-size:13px;font-weight:700;font-family:var(--sans);cursor:pointer;border:2px solid #0000;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,box-shadow .15s;display:flex}.profile-btn:hover{background:var(--navy-light);box-shadow:0 2px 10px #1b3a564d}.profile-btn.active{background:var(--gold);color:var(--navy-dark)}.home-view{flex:1;padding:40px 36px 100px;overflow-y:auto}.home-welcome{margin-bottom:44px}.home-greeting{color:var(--navy-dark);letter-spacing:-.6px;margin:0 0 5px;font-size:28px;font-weight:800}.home-pub{color:var(--gray-500);margin:0;font-size:14px;font-weight:500}.home-section{margin-bottom:42px}.home-section-label{color:var(--gray-500);letter-spacing:.8px;text-transform:uppercase;margin-bottom:14px;font-size:11px;font-weight:700}.stats-grid{grid-template-columns:repeat(3,1fr);gap:14px;display:grid}.stat-card{background:var(--white);border:1px solid var(--gray-100);text-align:center;box-shadow:var(--shadow-xs);border-radius:16px;padding:24px}.stat-value{color:var(--navy);letter-spacing:-1.5px;margin-bottom:6px;font-size:36px;font-weight:800;line-height:1}.stat-label{color:var(--gray-500);font-size:12px;font-weight:500}.topic-grid{flex-wrap:wrap;gap:10px;display:flex}.topic-btn{background:var(--white);border:1.5px solid var(--gray-200);font-size:14px;font-weight:600;font-family:var(--sans);color:var(--navy);cursor:pointer;white-space:nowrap;box-shadow:var(--shadow-xs);border-radius:100px;align-items:center;gap:8px;padding:10px 20px;transition:all .18s;display:inline-flex}.topic-btn:hover{background:var(--navy);border-color:var(--navy);color:var(--white);transform:translateY(-1px);box-shadow:0 4px 16px #1b3a564d}.topic-btn-icon{flex-shrink:0;align-items:center;display:flex}.topic-btn-label{font-size:14px}.recent-list{flex-direction:column;gap:6px;display:flex}.recent-item{background:var(--white);border:1px solid var(--gray-100);cursor:pointer;text-align:left;font-family:var(--sans);width:100%;box-shadow:var(--shadow-xs);border-radius:13px;align-items:center;gap:12px;padding:14px 18px;transition:all .18s;display:flex}.recent-item:hover{box-shadow:var(--shadow-sm);border-color:#1b3a5638;transform:translateY(-1px)}.recent-item-icon{width:16px;height:16px;color:var(--gray-400);flex-shrink:0;justify-content:center;align-items:center;display:flex}.recent-item-icon svg{width:15px;height:15px}.recent-item-text{color:var(--gray-700);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:14px;font-weight:500;overflow:hidden}.recent-item-time{color:var(--gray-400);flex-shrink:0;font-size:12px}.reminders-list{flex-direction:column;gap:8px;display:flex}.reminder-card{background:var(--white);border:1px solid var(--gray-100);box-shadow:var(--shadow-xs);border-radius:13px;justify-content:space-between;align-items:center;gap:12px;padding:15px 18px;display:flex}.reminder-card.reminder-due{background:#fdfbf3;border-color:#f0d087}.reminder-info{align-items:center;gap:12px;display:flex}.reminder-icon{flex-shrink:0;align-items:center;display:flex}.reminder-due .reminder-icon{color:#c87a1a}.reminder-card:not(.reminder-due) .reminder-icon{color:var(--success)}.reminder-title{color:var(--gray-800);letter-spacing:-.1px;font-size:14px;font-weight:600}.reminder-sub{color:var(--gray-500);margin-top:1px;font-size:12px}.reminder-done-btn{background:var(--navy);color:var(--white);font-size:12px;font-weight:700;font-family:var(--sans);cursor:pointer;border:none;border-radius:8px;flex-shrink:0;padding:7px 16px;transition:background .15s,box-shadow .15s}.reminder-done-btn:hover{background:var(--navy-light);box-shadow:0 2px 8px #1b3a5647}.quick-win-card{background:var(--white);border:1px solid var(--gray-100);border-left:3px solid var(--gold);box-shadow:var(--shadow-xs);border-radius:13px;align-items:flex-start;gap:14px;padding:18px 20px;display:flex}.quick-win-icon{color:var(--navy);opacity:.6;flex-shrink:0;align-items:flex-start;padding-top:1px;display:flex}.quick-win-card p{color:var(--gray-700);font-size:14px;font-weight:500;line-height:1.68}.kpi-header-btns{gap:8px;display:flex}.kpi-btn{font-size:12px;font-weight:700;font-family:var(--sans);cursor:pointer;white-space:nowrap;border-radius:7px;padding:5px 14px;transition:all .15s}.kpi-btn--ghost{border:1.5px solid var(--gray-200);color:var(--navy);background:0 0}.kpi-btn--ghost:hover{border-color:var(--navy)}.kpi-btn--primary{background:var(--navy);color:var(--white);border:none}.kpi-btn--primary:hover{background:var(--navy-light)}.kpi-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px;display:grid}.kpi-card{background:var(--white);border:1.5px solid var(--gray-200);box-shadow:var(--shadow-xs);border-radius:12px;flex-direction:column;gap:6px;padding:14px 16px;display:flex}.kpi-card--green{background:#f0fdf4;border-color:#bbf7d0}.kpi-card--amber{background:#fffbeb;border-color:#fde68a}.kpi-card--red{background:#fef2f2;border-color:#fecaca}.kpi-card--none{border-color:var(--gray-100)}.kpi-card-top{justify-content:space-between;align-items:center;display:flex}.kpi-label{color:var(--gray-600);text-transform:uppercase;letter-spacing:.4px;font-size:11px;font-weight:700}.kpi-actual{letter-spacing:-1px;color:var(--navy-dark);font-size:26px;font-weight:800;line-height:1}.kpi-target-row{justify-content:space-between;align-items:center;display:flex}.kpi-target-label{color:var(--gray-400);font-size:11px}.kpi-target-val{color:var(--gray-600);font-size:12px;font-weight:600}.kpi-status-dot{border-radius:100px;align-self:flex-start;align-items:center;margin-top:2px;padding:2px 9px;font-size:10px;font-weight:700;display:inline-flex}.kpi-card--green .kpi-status-dot{color:#059669;background:#0596691f}.kpi-card--amber .kpi-status-dot{color:#d97706;background:#d977061f}.kpi-card--red .kpi-status-dot{color:#dc2626;background:#dc26261f}.kpi-card--none .kpi-status-dot{background:var(--gray-100);color:var(--gray-400)}.compliance-panel{background:var(--white);border:1px solid var(--gray-100);box-shadow:var(--shadow-xs);border-radius:16px;margin-bottom:24px;padding:20px 24px}.compliance-panel-header{align-items:center;gap:12px;margin-bottom:16px;display:flex}.compliance-panel-title{color:var(--navy-dark);letter-spacing:-.2px;margin:0;font-size:16px;font-weight:700}.home-two-col{flex-wrap:wrap;gap:14px;display:flex}.home-two-col .home-section{min-width:0}.snapshot-card{background:linear-gradient(135deg, var(--navy-dark) 0%, var(--navy) 100%);box-shadow:var(--shadow-sm);border-radius:14px;align-items:center;gap:16px;margin-bottom:10px;padding:18px 24px;display:flex}.snapshot-date{color:var(--white)}.snapshot-day{letter-spacing:-.5px;font-size:22px;font-weight:800;line-height:1.1}.snapshot-fulldate{color:#fff9;margin-top:3px;font-size:13px}.forecast-strip{scrollbar-width:none;gap:8px;padding-bottom:4px;display:flex;overflow-x:auto}.forecast-strip::-webkit-scrollbar{display:none}.forecast-card{background:var(--white);border:1px solid var(--gray-100);min-width:74px;box-shadow:var(--shadow-xs);text-align:center;border-radius:12px;flex-direction:column;flex:none;align-items:center;gap:5px;padding:11px 10px;display:flex}.forecast-card--today{background:var(--navy-dark);border-color:var(--navy-dark)}.forecast-card--today .forecast-card-day{color:#ffffff8c}.forecast-card--today .forecast-card-temp{color:var(--white)}.forecast-card--today .forecast-card-desc{color:#ffffff8c}.forecast-card--today svg{color:var(--gold)}.forecast-card-day{color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;font-size:10px;font-weight:700}.forecast-card-temp{color:var(--navy-dark);letter-spacing:-.5px;font-size:17px;font-weight:800;line-height:1}.forecast-card-desc{color:var(--gray-400);font-size:10px;line-height:1.3}.forecast-strip-loading{color:var(--gray-400);padding:8px 0;font-size:13px}.on-today-list{flex-direction:column;gap:8px;display:flex}.on-today-item{background:var(--white);border:1px solid var(--gray-100);box-shadow:var(--shadow-xs);border-left:3px solid;border-radius:10px;align-items:center;gap:12px;padding:10px 14px;display:flex}.on-today-avatar{width:32px;height:32px;color:var(--white);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex}.on-today-name{color:var(--navy-dark);letter-spacing:-.1px;font-size:14px;font-weight:700}.on-today-shift{color:var(--gray-500);margin-top:1px;font-size:12px}.next-shift-card{border:1px solid;border-radius:14px;flex-direction:column;gap:4px;padding:18px 20px;display:flex}.next-shift-day{color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:700}.next-shift-type{letter-spacing:-.5px;font-size:22px;font-weight:800;line-height:1.1}.next-shift-time{color:var(--gray-600);margin-top:2px;font-size:14px;font-weight:600}.next-shift-notes{color:var(--text-light);border-top:1px solid #00000012;margin:8px 0 0;padding-top:8px;font-size:13px;line-height:1.55}.shift-notes-list{flex-direction:column;gap:8px;display:flex}.shift-note-card{background:var(--white);border:1px solid var(--gray-100);border-left:3px solid;border-radius:0 12px 12px 0;padding:12px 16px}.shift-note-label{text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px;font-size:11px;font-weight:700}.shift-note-text{color:var(--text);margin:0;font-size:14px;line-height:1.65}.staff-task-list{flex-direction:column;gap:8px;display:flex}.staff-task-item{background:var(--white);border:1px solid var(--gray-100);border-radius:12px;padding:14px 16px}.staff-task-title{color:var(--navy-dark);margin-bottom:2px;font-size:14px;font-weight:700}.staff-task-desc{color:var(--text-light);margin:4px 0 6px;font-size:13px;line-height:1.55}.staff-task-due{color:#92400e;background:#fef3c7;border-radius:6px;padding:2px 8px;font-size:11px;font-weight:700;display:inline-block}.on-today-empty{background:var(--white);border:1px solid var(--gray-100);color:var(--text-light);border-radius:12px;flex-direction:column;gap:8px;padding:16px;font-size:14px;display:flex}.on-today-rota-link{color:var(--navy);cursor:pointer;font-size:13px;font-weight:700;font-family:var(--sans);background:0 0;border:none;align-self:flex-start;padding:0;text-decoration:underline}@keyframes insight-beer-rise{0%,to{transform:translateY(100%)}40%,60%{transform:translateY(0%)}}@keyframes insight-foam-rise{0%,to{opacity:0;transform:translateY(100%)}35%,65%{opacity:1;transform:translateY(0%)}}@keyframes insight-text-reveal{0%{opacity:0}to{opacity:1}}.insight-loading-wrap{flex-direction:column;align-items:center;gap:12px;padding:18px 0;display:flex}.insight-loading-svg{overflow:hidden}.il-beer-rect{transform-box:fill-box;animation:2.4s ease-in-out infinite insight-beer-rise}.il-foam{transform-box:fill-box;animation:2.4s ease-in-out infinite insight-foam-rise}.insight-loading-text{color:var(--gray-400);letter-spacing:.1px;margin:0;font-size:12px;font-style:italic}.insight-card{background:var(--white);border:1px solid var(--gray-100);border-left:3px solid var(--navy);box-shadow:var(--shadow-xs);border-radius:12px;height:100%;padding:16px 18px;transition:border-left-color .2s}.insight-card--pinned{background:#fffbf4;border-left-color:#d97706}.insight-icon{color:var(--navy);opacity:.6}.insight-text{color:var(--text);margin:0;font-size:14px;font-weight:500;line-height:1.7;animation:.6s ease-in both insight-text-reveal}.insight-loading{color:var(--gray-500);font-style:italic}.message-avatar--brewing{background:#0f1f3d!important}.archive-count-pill{background:var(--gray-100);min-width:18px;height:18px;color:var(--gray-500);letter-spacing:0;border-radius:9px;justify-content:center;align-items:center;padding:0 5px;font-size:10px;font-weight:800;display:inline-flex}.archive-empty{color:var(--gray-400);margin:0;font-size:13px;font-style:italic;line-height:1.6}.archive-list{flex-direction:column;gap:6px;display:flex}.archive-item{border:1px solid var(--gray-100);background:var(--white);box-shadow:var(--shadow-xs);border-radius:12px;transition:border-color .15s;overflow:hidden}.archive-item--open{border-color:#1b3a5633}.archive-item-header{align-items:stretch;display:flex}.archive-item-header:hover{background:var(--off-white)}.archive-item-expand{cursor:pointer;font-family:var(--sans);text-align:left;background:0 0;border:none;flex:1;justify-content:space-between;align-items:center;gap:12px;min-width:0;padding:12px 16px;display:flex}.archive-item-meta{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.archive-item-topic{color:var(--navy-dark);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.archive-item-date{color:var(--gray-400);font-size:11px;font-weight:500}.archive-chevron{color:var(--gray-400);flex-shrink:0;transition:transform .2s}.archive-chevron--open{transform:rotate(180deg)}.archive-thread{border-top:1px solid var(--gray-100);flex-direction:column;gap:10px;max-height:500px;padding:14px 16px;display:flex;overflow-y:auto}.archive-msg{flex-direction:column;gap:3px;display:flex}.archive-msg-who{text-transform:uppercase;letter-spacing:.5px;color:var(--gray-400);font-size:10px;font-weight:700}.archive-msg--user .archive-msg-who{color:var(--navy)}.archive-msg-text{color:var(--text);white-space:pre-wrap;margin:0;font-size:13px;line-height:1.66}.archive-msg--user{background:#1b3a560a;border-left:2px solid #1b3a5626;border-radius:0 8px 8px 0;padding:8px 12px}.archive-msg--assistant{padding:0 4px}.archive-delete-btn{cursor:pointer;width:32px;color:var(--gray-300);opacity:0;background:0 0;border:none;border-left:1px solid #0000;flex-shrink:0;justify-content:center;align-items:center;transition:opacity .15s,color .15s,background .15s;display:flex}.archive-item:hover .archive-delete-btn{opacity:1}.archive-delete-btn:hover{color:var(--error);border-left-color:var(--gray-100);background:#bf3b2e12}.archive-delete-confirm{flex-shrink:0;align-items:center;gap:6px;padding:0 12px;display:flex}.archive-delete-question{color:var(--gray-700);white-space:nowrap;font-size:12px;font-weight:600}.archive-confirm-yes{color:var(--error);cursor:pointer;font-size:11px;font-weight:700;font-family:var(--sans);white-space:nowrap;background:#bf3b2e14;border:1px solid #bf3b2e66;border-radius:5px;padding:3px 10px}.archive-confirm-yes:hover{background:#bf3b2e29}.archive-confirm-cancel{border:1px solid var(--gray-200);color:var(--gray-500);cursor:pointer;font-size:11px;font-weight:600;font-family:var(--sans);background:0 0;border-radius:5px;padding:3px 8px}.archive-confirm-cancel:hover{color:var(--gray-700);background:var(--gray-100)}.insight-pin-btn{border:1px solid var(--gray-200);color:var(--gray-500);cursor:pointer;font-size:11px;font-weight:600;font-family:var(--sans);background:0 0;border-radius:6px;align-items:center;gap:4px;padding:2px 8px;transition:all .15s;display:inline-flex}.insight-pin-btn:hover{border-color:var(--gray-400);color:var(--gray-700)}.insight-pin-btn--active{color:#92400e;background:#fef3c7;border-color:#fcd34d}.insight-pin-btn--active:hover{background:#fde68a}.compliance-card{background:var(--white);border:1px solid var(--gray-100);box-shadow:var(--shadow-xs);border-radius:14px;flex-direction:column;gap:11px;padding:18px 20px;display:flex}.compliance-module-row{align-items:center;gap:10px;display:flex}.compliance-module-name{color:var(--gray-700);white-space:nowrap;text-overflow:ellipsis;flex-shrink:0;width:120px;font-size:13px;font-weight:600;overflow:hidden}.compliance-count{text-align:right;flex-shrink:0;width:28px;font-size:12px;font-weight:700}.compliance-link{color:var(--navy);cursor:pointer;font-size:12px;font-weight:700;font-family:var(--sans);background:0 0;border:none;align-self:flex-start;padding:4px 0 0;transition:color .15s}.compliance-link:hover{color:var(--navy-light)}.compliance-status-badge{text-transform:none;letter-spacing:0;border-radius:100px;align-items:center;margin-left:8px;padding:2px 9px;font-size:11px;font-weight:700;display:inline-flex}.compliance-status--green{color:#059669;background:#0596691a}.compliance-status--amber{color:#d97706;background:#d977061a}.compliance-status--red{color:#dc2626;background:#dc26261a}.news-source{color:var(--gray-400);text-transform:none;letter-spacing:0;margin-left:8px;font-size:10px;font-weight:600}.news-grid{grid-template-columns:repeat(2,1fr);gap:10px;display:grid}.news-card{background:var(--white);border:1px solid var(--gray-100);color:var(--text);box-shadow:var(--shadow-xs);border-radius:12px;flex-direction:column;gap:6px;padding:14px 16px;text-decoration:none;transition:box-shadow .18s,transform .18s;display:flex}.news-card:hover{box-shadow:var(--shadow-sm);transform:translateY(-2px)}.news-card-icon{color:var(--navy);opacity:.5;flex-shrink:0}.news-card-title{color:var(--navy-dark);letter-spacing:-.1px;font-size:13px;font-weight:700;line-height:1.4}.news-card-desc{color:var(--text-light);flex:1;font-size:12px;line-height:1.5}.news-card-read{color:var(--navy);margin-top:2px;font-size:11px;font-weight:700}.news-loading,.news-empty{color:var(--gray-400);padding:12px 0;font-size:14px}.home-section-label{align-items:center;display:flex}.staff-overview-card{background:var(--white);border:1px solid var(--gray-100);box-shadow:var(--shadow-xs);border-radius:16px;padding:24px}.staff-overview-stats{gap:28px;margin-bottom:14px;display:flex}.staff-stat{flex-direction:column;gap:2px;display:flex}.staff-stat-value{color:var(--navy);letter-spacing:-1px;font-size:32px;font-weight:800;line-height:1}.staff-stat-label{color:var(--gray-500);font-size:12px;font-weight:500}.staff-overview-nudge{color:var(--gray-600);background:var(--gray-100);border-radius:9px;margin:10px 0;padding:9px 14px;font-size:13px;font-weight:500}.staff-overview-link{color:var(--navy);font-size:13px;font-weight:700;font-family:var(--sans);cursor:pointer;background:0 0;border:none;padding:4px 0;transition:color .15s}.staff-overview-link:hover{color:var(--navy-light)}.float-chat-btn{background:var(--navy);cursor:pointer;z-index:200;width:54px;height:54px;box-shadow:var(--shadow-md);color:var(--white);border:none;border-radius:50%;justify-content:center;align-items:center;transition:all .22s cubic-bezier(.34,1.5,.64,1);display:flex;position:fixed;bottom:28px;right:28px}.float-chat-btn:hover{background:var(--navy-light);box-shadow:var(--shadow-lg);transform:scale(1.08)}.float-chat-btn.float-chat-btn--active{background:var(--navy-dark)}.float-chat-btn svg{width:21px;height:21px}.profile-panel{background:var(--off-white);flex-direction:column;flex:1;display:flex;overflow:hidden}.profile-panel-body{flex:1;padding:36px 28px 56px;overflow-y:auto}.profile-card{background:var(--white);border:1px solid var(--gray-100);max-width:560px;box-shadow:var(--shadow-sm);border-radius:20px;margin:0 auto;padding:36px}.profile-card-header{border-bottom:1px solid var(--gray-100);align-items:center;gap:18px;margin-bottom:32px;padding-bottom:28px;display:flex}.profile-card-avatar{background:var(--navy);width:54px;height:54px;color:var(--white);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:22px;font-weight:800;display:flex;box-shadow:0 4px 14px #1b3a5652}.profile-card-title h2{color:var(--navy-dark);letter-spacing:-.35px;margin:0 0 3px;font-size:20px;font-weight:800}.profile-card-title p{color:var(--gray-500);margin:0;font-size:13px;font-weight:500}.profile-form{flex-direction:column;gap:14px;display:flex}.profile-form-section{color:var(--gray-500);letter-spacing:.8px;text-transform:uppercase;margin-top:10px;margin-bottom:-2px;font-size:11px;font-weight:700}.profile-form-actions{flex-wrap:wrap;align-items:center;gap:12px;margin-top:10px;display:flex}.profile-save-btn{background:var(--navy);color:var(--white);font-size:14px;font-weight:700;font-family:var(--sans);cursor:pointer;letter-spacing:-.01em;border:none;border-radius:10px;padding:12px 28px;transition:background .18s,box-shadow .18s,transform .18s}.profile-save-btn:hover:not(:disabled){background:var(--navy-light);transform:translateY(-1px);box-shadow:0 4px 16px #1b3a5652}.profile-save-btn:disabled{opacity:.52;cursor:not-allowed}.profile-cancel-btn{color:var(--gray-600);border:1.5px solid var(--gray-200);font-size:14px;font-weight:600;font-family:var(--sans);cursor:pointer;background:0 0;border-radius:10px;padding:12px 22px;transition:border-color .15s,color .15s}.profile-cancel-btn:hover{border-color:var(--gray-400);color:var(--gray-800)}.staff-section-card{background:var(--white);border:1px solid var(--gray-100);max-width:640px;box-shadow:var(--shadow-sm);border-radius:20px;margin:0 auto;padding:28px}.staff-section-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:22px;display:flex}.staff-section-title{color:var(--navy-dark);letter-spacing:-.35px;margin:0 0 4px;font-size:18px;font-weight:800}.staff-section-sub{color:var(--gray-500);margin:0;font-size:13px;font-weight:500}.staff-pip{color:#fff;letter-spacing:-.3px;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:10px;font-weight:800;display:inline-flex}.staff-pip--sm{width:22px;height:22px;font-size:9px}.shift-block--compact{padding:7px 8px}.shift-block-compact-row{align-items:center;gap:6px;margin-top:5px;display:flex}.shift-block-time-sm{color:var(--gray-700);white-space:nowrap;flex:1;font-size:11px;font-weight:600}.modal-avail-list{background:var(--off-white);border:1px solid var(--gray-100);border-radius:10px;margin-bottom:4px;overflow:hidden}.modal-avail-heading{color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--gray-100);padding:8px 12px 6px;font-size:11px;font-weight:700}.modal-avail-row{border:none;border-bottom:1px solid var(--gray-100);cursor:pointer;width:100%;font-family:var(--sans);text-align:left;background:0 0;align-items:center;gap:10px;padding:8px 12px;transition:background .12s;display:flex}.modal-avail-row:last-child{border-bottom:none}.modal-avail-row:hover{background:var(--white)}.modal-avail-row--selected{background:#1b3a560d}.modal-avail-name{color:var(--navy-dark);flex:1;font-size:13px;font-weight:600}.modal-avail-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.modal-avail-dot--available{background:#059669}.modal-avail-dot--unavailable{background:#dc2626}.modal-avail-dot--none{background:var(--gray-300)}.staff-slots-bar{background:var(--off-white);border:1px solid var(--gray-100);border-radius:10px;align-items:center;gap:10px;margin-bottom:14px;padding:10px 14px;display:flex}.staff-slots-bar--full{background:#fef9ee;border-color:#fcd34d}.staff-slots-label{color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;flex:1;font-size:11px;font-weight:700}.staff-slots-pips{gap:4px;display:flex}.staff-slot-pip{background:var(--gray-200);border-radius:4px;width:28px;height:8px;transition:background .15s}.staff-slot-pip--used{background:var(--navy)}.staff-slot-pip--full{background:#d97706}.staff-slots-count{color:var(--gray-600);text-align:right;min-width:36px;font-size:12px;font-weight:700}.staff-slots-count--full{color:#d97706}.staff-limit-banner{background:#fef9ee;border:1px solid #fcd34d;border-radius:10px;flex-wrap:wrap;align-items:center;gap:14px;margin-bottom:4px;padding:14px 16px;display:flex}.staff-limit-banner p{color:#92400e;flex:1;margin:0;font-size:13px;font-weight:500;line-height:1.5}.staff-limit-cta{color:#fff;font-size:13px;font-weight:700;font-family:var(--sans);white-space:nowrap;background:#d97706;border-radius:8px;padding:8px 18px;text-decoration:none;transition:background .15s;display:inline-block}.staff-limit-cta:hover{background:#b45309}.invite-toggle-btn{background:var(--navy);color:var(--white);font-size:13px;font-weight:700;font-family:var(--sans);cursor:pointer;white-space:nowrap;letter-spacing:-.01em;border:none;border-radius:10px;flex-shrink:0;padding:9px 18px;transition:background .18s,box-shadow .18s}.invite-toggle-btn:hover{background:var(--navy-light);box-shadow:0 4px 14px #1b3a564d}.invite-form{flex-direction:column;gap:10px;padding-top:4px;display:flex}.invite-fields-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.invite-row{gap:8px;display:flex}.invite-colour-row{align-items:center;gap:12px;display:flex}.invite-colour-label{color:var(--gray-600);white-space:nowrap;font-size:12px;font-weight:700}.colour-swatch-picker{flex-wrap:wrap;gap:6px;display:flex}.colour-swatch{cursor:pointer;border:2px solid #0000;border-radius:50%;flex-shrink:0;width:26px;height:26px;transition:transform .12s,border-color .12s}.colour-swatch:hover{transform:scale(1.15)}.colour-swatch--selected{border-color:var(--navy-dark);box-shadow:0 0 0 2px #0d1f332e}.colour-swatch--sm{width:20px;height:20px}.colour-swatch-picker--sm{gap:4px}.team-colour-row{border-bottom:1px solid var(--gray-100);align-items:center;gap:12px;padding:8px 0;display:flex}.team-colour-row:last-child{border-bottom:none}.team-colour-name{color:var(--navy-dark);flex:1;font-size:13px;font-weight:600}.rota-legend-bar{border-bottom:1px solid var(--gray-100);background:var(--white);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:16px;padding:8px 20px;display:flex}.rota-legend-person{align-items:center;gap:6px;display:flex}.rota-legend-name{color:var(--gray-700);white-space:nowrap;font-size:12px;font-weight:600}.invite-input{border:1.5px solid var(--gray-200);font-size:14px;font-family:var(--sans);color:var(--text);border-radius:10px;outline:none;flex:1;padding:10px 14px;transition:border-color .15s,box-shadow .15s}.invite-input:focus{border-color:var(--navy);box-shadow:0 0 0 3px #1b3a561a}.invite-send-btn{background:var(--gold);color:var(--navy-dark);font-size:14px;font-weight:700;font-family:var(--sans);cursor:pointer;white-space:nowrap;letter-spacing:-.01em;border:none;border-radius:10px;padding:10px 22px;transition:background .18s,box-shadow .18s}.invite-send-btn:hover:not(:disabled){background:var(--gold-hover);box-shadow:0 4px 14px #c8973b59}.invite-send-btn:disabled{opacity:.5;cursor:not-allowed}.invite-hint{color:var(--gray-500);margin:0;font-size:12px;line-height:1.55}.staff-list{flex-direction:column;gap:10px;max-width:640px;margin:16px auto 0;display:flex}.staff-card{background:var(--white);border:1px solid var(--gray-100);box-shadow:var(--shadow-xs);border-radius:14px;align-items:flex-start;gap:14px;padding:18px 20px;display:flex}.staff-card-avatar{background:var(--navy);width:40px;height:40px;color:var(--white);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:15px;font-weight:700;display:flex;box-shadow:0 2px 8px #1b3a5647}.staff-card-info{flex:1;min-width:0}.staff-card-name{color:var(--navy-dark);letter-spacing:-.2px;margin-bottom:2px;font-size:15px;font-weight:700}.staff-card-email{color:var(--gray-500);margin-bottom:4px;font-size:13px}.staff-card-meta{color:var(--gray-400);font-size:12px}.staff-card-topics{color:var(--gray-500);text-overflow:ellipsis;white-space:nowrap;margin-top:6px;font-size:12px;overflow:hidden}.staff-empty{text-align:center;color:var(--gray-500);max-width:640px;margin:0 auto;padding:40px 16px;font-size:14px;line-height:1.6}.pending-invite{border-top:1px solid var(--gray-100);justify-content:space-between;align-items:center;gap:12px;padding:10px 0;display:flex}.pending-invite:first-of-type{border-top:none}.pending-invite-left{flex-direction:column;gap:2px;min-width:0;display:flex}.pending-invite-email{color:var(--gray-700);text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:500;overflow:hidden}.pending-invite-time{color:var(--gray-400);font-size:12px}.resend-btn{border:1.5px solid var(--gray-200);font-size:12px;font-weight:700;font-family:var(--sans);color:var(--navy);cursor:pointer;white-space:nowrap;background:0 0;border-radius:8px;flex-shrink:0;padding:5px 14px;transition:all .15s}.resend-btn:hover:not(:disabled){background:var(--navy);border-color:var(--navy);color:var(--white)}.resend-btn:disabled{opacity:.45;cursor:not-allowed}.pending-invite-actions{flex-shrink:0;align-items:center;gap:6px;display:flex}.cancel-invite-btn{border:1px solid var(--gray-200);color:var(--gray-500);cursor:pointer;font-size:12px;font-weight:600;font-family:var(--sans);background:0 0;border-radius:7px;padding:5px 10px;transition:all .12s}.cancel-invite-btn:hover{border-color:var(--error);color:var(--error);background:#bf3b2e0d}.pending-invite-confirm{flex-wrap:wrap;flex-shrink:0;align-items:center;gap:6px;display:flex}.pending-invite-confirm-msg{color:var(--gray-600);white-space:nowrap;font-size:12px;font-weight:600}.pending-invite-confirm-yes{color:var(--error);cursor:pointer;font-size:11px;font-weight:700;font-family:var(--sans);background:#bf3b2e14;border:1px solid #bf3b2e66;border-radius:6px;padding:4px 10px}.pending-invite-confirm-yes:hover{background:#bf3b2e29}.pending-invite-confirm-no{border:1px solid var(--gray-200);color:var(--gray-500);cursor:pointer;font-size:11px;font-weight:600;font-family:var(--sans);background:0 0;border-radius:6px;padding:4px 10px}.pending-invite-confirm-no:hover{background:var(--gray-100)}.resend-inline-btn{border:1.5px solid var(--navy);font-size:13px;font-weight:700;font-family:var(--sans);color:var(--navy);cursor:pointer;background:0 0;border-radius:8px;margin-top:8px;padding:7px 16px;transition:background .15s,color .15s;display:inline-block}.resend-inline-btn:hover:not(:disabled){background:var(--navy);color:var(--white)}.resend-inline-btn:disabled{opacity:.5;cursor:not-allowed}.loading-screen{background:var(--off-white);justify-content:center;align-items:center;min-height:100vh;display:flex}.loading-spinner{border:3px solid var(--gray-200);border-top-color:var(--navy);border-radius:50%;width:36px;height:36px;animation:.75s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.learning-home{flex:1;padding:40px 36px 100px;overflow-y:auto}.learning-home-header{margin-bottom:36px}.learning-title{color:var(--navy-dark);letter-spacing:-.6px;margin:0 0 6px;font-size:26px;font-weight:800}.learning-subtitle{color:var(--text-light);margin:0;font-size:14px;line-height:1.6}.module-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;margin-bottom:44px;display:grid}.module-card{background:var(--white);border:1px solid var(--gray-100);box-shadow:var(--shadow-xs);border-radius:18px;flex-direction:column;gap:10px;padding:24px;transition:box-shadow .2s,transform .2s;display:flex}.module-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.module-card--passed{background:#f8fdf9;border-color:#1c7a4233}.module-card-top{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.module-card-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.module-card-meta{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;display:flex}.module-difficulty{letter-spacing:.3px;border:1px solid;border-radius:100px;align-items:center;padding:3px 10px;font-size:11px;font-weight:700;display:inline-flex}.module-completion-badge{color:var(--success);background:#1c7a421a;border:1px solid #1c7a4240;border-radius:100px;align-items:center;gap:5px;padding:3px 10px;font-size:11px;font-weight:700;display:inline-flex}.module-card-title{color:var(--navy-dark);letter-spacing:-.2px;margin:0;font-size:16px;font-weight:700}.module-card-desc{color:var(--text-light);flex:1;margin:0;font-size:13px;line-height:1.6}.module-topics{flex-direction:column;gap:4px;margin:0;padding:0;list-style:none;display:flex}.module-topics li{color:var(--gray-600);align-items:baseline;gap:7px;font-size:12px;display:flex}.module-topic-dot{background:var(--gold);border-radius:50%;flex-shrink:0;width:5px;height:5px;margin-top:1px;display:inline-block}.module-topics-more{color:var(--gray-400);padding-left:12px;font-size:12px;font-style:italic}.module-card-footer{justify-content:space-between;align-items:center;margin-top:4px;display:flex}.module-card-time{color:var(--gray-500);align-items:center;gap:5px;font-size:12px;font-weight:500;display:flex}.module-start-btn{background:var(--navy);color:var(--white);font-size:13px;font-weight:700;font-family:var(--sans);cursor:pointer;border:none;border-radius:8px;align-items:center;gap:4px;padding:8px 16px;transition:background .15s,box-shadow .15s;display:inline-flex}.module-start-btn:hover{background:var(--navy-light);box-shadow:0 3px 10px #1b3a5647}.module-start-btn--retake{color:var(--navy);border:1.5px solid var(--navy);background:0 0}.module-start-btn--retake:hover{background:var(--navy);color:var(--white)}.module-session{flex-direction:column;flex:1;display:flex;overflow:hidden}.module-session-header{background:var(--white);border-bottom:1px solid var(--gray-100);flex-shrink:0;align-items:center;gap:16px;padding:14px 24px;display:flex}.module-back-btn{color:var(--navy);font-size:13px;font-weight:600;font-family:var(--sans);cursor:pointer;background:0 0;border:none;flex-shrink:0;align-items:center;gap:6px;padding:6px 0;transition:color .15s;display:flex}.module-back-btn:hover:not(:disabled){color:var(--navy-light)}.module-back-btn:disabled{opacity:.45;cursor:default}.module-session-info{flex:1;min-width:0}.module-session-title{color:var(--navy-dark);white-space:nowrap;text-overflow:ellipsis;letter-spacing:-.2px;font-size:14px;font-weight:700;overflow:hidden}.module-progress-wrap{flex-shrink:0;align-items:center;gap:10px;display:flex}.module-progress-bar{background:var(--gray-200);border-radius:100px;width:120px;height:6px;overflow:hidden}.module-progress-fill{background:linear-gradient(90deg, var(--navy-light), var(--gold));border-radius:100px;height:100%;transition:width .5s}.module-progress-label{color:var(--gray-500);text-align:right;width:32px;font-size:12px;font-weight:700}.module-messages{background:var(--off-white);flex-direction:column;flex:1;gap:16px;padding:24px;display:flex;overflow-y:auto}.module-complete-bar{background:var(--white);border-top:1px solid var(--gray-100);flex-shrink:0;justify-content:center;padding:12px 24px;display:flex}.module-complete-btn{background:var(--gold);color:var(--navy-dark);font-size:14px;font-weight:700;font-family:var(--sans);cursor:pointer;letter-spacing:-.01em;border:none;border-radius:10px;align-items:center;gap:8px;padding:12px 28px;transition:background .15s,box-shadow .15s,transform .15s;display:inline-flex}.module-complete-btn:hover:not(:disabled){background:var(--gold-hover);transform:translateY(-1px);box-shadow:0 4px 14px #c8973b61}.module-complete-btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.module-result{flex:1;width:100%;max-width:680px;margin:0 auto;padding:40px 36px 80px;overflow-y:auto}.result-pass,.result-fail{text-align:center;flex-direction:column;align-items:center;display:flex}.result-icon{border-radius:50%;justify-content:center;align-items:center;width:68px;height:68px;margin-bottom:20px;display:flex}.result-icon--pass{color:var(--success);background:#1c7a421f}.result-icon--fail{color:var(--error);background:#bf3b2e1a}.result-heading{color:var(--navy-dark);letter-spacing:-.5px;margin:0 0 10px;font-size:26px;font-weight:800}.result-sub{color:var(--text-light);margin:0 0 32px;font-size:15px;line-height:1.6}.certificate{background:var(--white);border:1px solid var(--gray-200);width:100%;max-width:580px;box-shadow:var(--shadow-md);border-radius:18px;margin-bottom:28px;overflow:hidden}.certificate-stripe{background:linear-gradient(90deg, var(--gold), #e0b870, var(--gold));height:5px}.certificate-stripe--bottom{margin-top:0}.certificate-body{text-align:center;padding:36px 40px 32px}.certificate-brand{color:var(--navy);letter-spacing:-.3px;margin-bottom:4px;font-size:15px;font-weight:800}.certificate-label{color:var(--gray-400);letter-spacing:1px;text-transform:uppercase;margin-bottom:20px;font-size:11px;font-weight:700}.certificate-module{color:var(--navy-dark);letter-spacing:-.5px;margin:0 0 20px;font-size:22px;font-weight:800}.certificate-divider{background:var(--gray-100);height:1px;margin:0 0 20px}.certificate-copy{color:var(--gray-400);margin:0 0 4px;font-size:13px}.certificate-name{color:var(--navy-dark);letter-spacing:-.8px;margin:0 0 6px;font-size:28px;font-weight:800}.certificate-pub{color:var(--text-light);margin:0 0 24px;font-size:14px;line-height:1.5}.certificate-score-row{justify-content:center;margin-bottom:24px;display:flex}.certificate-score-box{background:var(--navy-dark);text-align:center;border-radius:12px;padding:16px 32px}.certificate-score-label{color:#ffffff73;letter-spacing:.8px;text-transform:uppercase;margin-bottom:4px;font-size:10px;font-weight:700;display:block}.certificate-score{color:var(--gold);letter-spacing:-2px;font-size:40px;font-weight:800;line-height:1}.certificate-score-denom{color:#c8973b99;font-size:20px}.certificate-meta{justify-content:center;gap:36px;display:flex}.certificate-meta-label{color:var(--gray-400);letter-spacing:.6px;text-transform:uppercase;margin-bottom:3px;font-size:10px;font-weight:700;display:block}.certificate-meta-value{color:var(--navy-dark);font-size:13px;font-weight:600;display:block}.certificate-id{color:var(--gray-500);font-family:monospace;font-size:11px}.result-score-display{justify-content:center;align-items:baseline;gap:4px;margin-bottom:20px;display:flex}.result-score-num{color:var(--error);letter-spacing:-3px;font-size:64px;font-weight:800;line-height:1}.result-score-sep{color:var(--gray-400);font-size:32px}.result-score-total{color:var(--gray-400);font-size:32px;font-weight:700}.result-fail-tip{color:var(--text-light);max-width:420px;margin:0 0 28px;font-size:14px;line-height:1.65}.result-actions{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.result-email-btn{background:var(--navy);color:var(--white);font-size:14px;font-weight:700;font-family:var(--sans);cursor:pointer;border:none;border-radius:10px;align-items:center;gap:8px;padding:12px 24px;transition:background .15s,box-shadow .15s;display:inline-flex}.result-email-btn:hover:not(:disabled){background:var(--navy-light);box-shadow:0 4px 14px #1b3a564d}.result-email-btn:disabled{opacity:.55;cursor:not-allowed}.result-retake-btn{color:var(--gray-600);border:1.5px solid var(--gray-200);font-size:14px;font-weight:600;font-family:var(--sans);cursor:pointer;background:0 0;border-radius:10px;align-items:center;gap:7px;padding:12px 22px;transition:border-color .15s,color .15s;display:inline-flex}.result-retake-btn:hover{border-color:var(--gray-400);color:var(--gray-800)}.compliance-section{background:var(--white);border:1px solid var(--gray-100);box-shadow:var(--shadow-xs);border-radius:18px;max-width:700px;padding:24px}.compliance-header{color:var(--navy);align-items:center;gap:10px;margin-bottom:20px;display:flex}.compliance-title{color:var(--navy-dark);letter-spacing:-.2px;flex:1;margin:0;font-size:16px;font-weight:700}.compliance-staff-count{color:var(--gray-500);background:var(--gray-100);border-radius:100px;padding:3px 10px;font-size:12px;font-weight:600}.compliance-table{flex-direction:column;gap:0;display:flex}.compliance-row{border-top:1px solid var(--gray-100);grid-template-columns:1fr 80px 160px;align-items:center;gap:16px;padding:10px 0;display:grid}.compliance-row:first-child{border-top:none}.compliance-row--head{padding-bottom:6px}.compliance-row--head span{color:var(--gray-400);letter-spacing:.5px;text-transform:uppercase;font-size:11px;font-weight:700}.compliance-module-name{color:var(--navy-dark);letter-spacing:-.1px;font-size:14px;font-weight:600}.compliance-passed{color:var(--gray-600);text-align:center;font-size:13px;font-weight:600}.compliance-bar-wrap{align-items:center;gap:10px;display:flex}.compliance-bar-track{background:var(--gray-100);border-radius:100px;flex:1;height:7px;overflow:hidden}.compliance-bar-fill{border-radius:100px;height:100%;transition:width .5s}.compliance-pct{text-align:right;width:34px;font-size:12px;font-weight:700}.rota-view{background:var(--off-white);flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.rota-header{background:var(--white);border-bottom:1px solid var(--gray-100);flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:10px;padding:12px 20px;display:flex}.rota-nav{align-items:center;gap:8px;display:flex}.rota-nav-btn{background:var(--gray-100);cursor:pointer;width:32px;height:32px;color:var(--navy);border:none;border-radius:8px;justify-content:center;align-items:center;transition:background .15s;display:flex}.rota-nav-btn:hover{background:var(--gray-200)}.rota-nav-label{color:var(--navy-dark);letter-spacing:-.2px;min-width:0;font-size:14px;font-weight:700}.rota-today-btn{border:1.5px solid var(--gray-200);font-size:12px;font-weight:600;font-family:var(--sans);color:var(--navy);cursor:pointer;background:0 0;border-radius:7px;padding:5px 12px;transition:all .15s}.rota-today-btn:hover{background:var(--navy);border-color:var(--navy);color:var(--white)}.rota-controls{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.rota-view-toggle{background:var(--gray-100);border-radius:8px;padding:2px;display:flex}.rota-toggle-btn{font-size:12px;font-weight:600;font-family:var(--sans);cursor:pointer;color:var(--gray-600);background:0 0;border:none;border-radius:6px;align-items:center;gap:5px;padding:5px 12px;transition:all .15s;display:flex}.rota-toggle-btn.active{background:var(--white);color:var(--navy);box-shadow:var(--shadow-xs)}.rota-manager-actions{align-items:center;gap:8px;display:flex}.rota-publish-btn{background:var(--navy);color:var(--white);font-size:13px;font-weight:700;font-family:var(--sans);cursor:pointer;border:none;border-radius:8px;padding:7px 16px;transition:background .15s,box-shadow .15s}.rota-publish-btn:hover{background:var(--navy-light);box-shadow:0 3px 10px #1b3a5647}.rota-swaps-btn{color:#92400e;font-size:13px;font-weight:700;font-family:var(--sans);cursor:pointer;background:#fef3c7;border:1px solid #fcd34d;border-radius:8px;align-items:center;gap:6px;padding:7px 14px;transition:background .15s;display:flex}.rota-swaps-btn:hover{background:#fde68a}.rota-loading{flex:1;justify-content:center;align-items:center;display:flex}.rota-week-wrap{flex-direction:column;flex:1;display:flex;overflow:auto}.rota-legend{flex-wrap:wrap;flex-shrink:0;align-items:center;gap:14px;padding:8px 16px;display:flex}.rota-legend-item{color:var(--gray-600);align-items:center;gap:5px;font-size:12px;font-weight:500;display:flex}.rota-legend-dot{border-radius:50%;flex-shrink:0;width:9px;height:9px}.rota-week-grid{border-left:1px solid var(--gray-100);flex:1;grid-template-columns:repeat(7,minmax(120px,1fr));gap:0;min-width:0;display:grid;overflow-x:auto}.rota-day-col{border-right:1px solid var(--gray-100);flex-direction:column;min-height:200px;display:flex}.rota-day-col--today .rota-day-header{background:#1b3a560f}.rota-day-header{border-bottom:1px solid var(--gray-100);flex-direction:column;flex-shrink:0;align-items:center;gap:1px;padding:8px 10px;display:flex}.rota-day-num{color:var(--navy-dark);letter-spacing:-.5px;font-size:18px;font-weight:800}.rota-avail-dots{flex-wrap:wrap;gap:3px;padding:5px 8px 2px;display:flex}.avail-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.rota-add-btn{border:1.5px dashed var(--gray-300);cursor:pointer;color:var(--gray-400);background:0 0;border-radius:8px;justify-content:center;align-items:center;margin:4px 6px 8px;padding:5px;transition:border-color .15s,color .15s;display:flex}.rota-add-btn:hover{border-color:var(--navy);color:var(--navy)}.shift-block{border:1.5px solid;border-radius:8px;flex-direction:column;gap:3px;padding:6px 8px;transition:box-shadow .15s;display:flex;position:relative}.shift-block-top{align-items:center;gap:5px;display:flex}.shift-type-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.shift-block-name{color:var(--gray-800);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:11px;font-weight:700;overflow:hidden}.shift-del-btn{opacity:0;cursor:pointer;color:var(--error);background:0 0;border:none;flex-shrink:0;padding:1px;transition:opacity .15s}.shift-block-time{font-size:11px;font-weight:600}.shift-status-badge{letter-spacing:.3px;text-transform:uppercase;border-radius:4px;padding:1px 6px;font-size:9px;font-weight:700;display:inline-block}.shift-status--draft{background:var(--gray-200);color:var(--gray-600)}.shift-edit-link{color:var(--gray-400);cursor:pointer;background:0 0;border:none;align-self:flex-start;padding:0;font-size:10px;text-decoration:underline}.rota-month-grid{border-left:1px solid var(--gray-100);flex:1;grid-template-columns:repeat(7,1fr);display:grid;overflow-y:auto}.rota-month-head{text-align:center;color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;border-right:1px solid var(--gray-100);border-bottom:1px solid var(--gray-100);background:var(--white);padding:8px;font-size:11px;font-weight:700}.rota-month-cell{border-right:1px solid var(--gray-100);border-bottom:1px solid var(--gray-100);background:var(--white);cursor:pointer;min-height:70px;padding:8px;transition:background .12s}.rota-month-cell:hover{background:var(--off-white)}.rota-month-cell--out{background:#fafaf9}.rota-month-cell--out .rota-month-day{color:var(--gray-300)}.rota-month-cell--today{background:#1b3a560a}.rota-month-cell--today .rota-month-day{background:var(--navy);color:var(--white);border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;display:flex}.rota-month-day{color:var(--navy-dark);margin-bottom:4px;font-size:13px;font-weight:700}.rota-month-dots{flex-wrap:wrap;gap:3px;display:flex}.rota-month-dot{border-radius:50%;width:7px;height:7px}.rota-avatar{background:var(--navy);color:var(--white);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:inline-flex}.rota-overlay{z-index:300;background:#0d1f3373;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.rota-modal{background:var(--white);width:100%;max-width:440px;max-height:90vh;box-shadow:var(--shadow-lg);border-radius:18px;overflow-y:auto}.rota-modal--wide{max-width:560px}.rota-modal-header{justify-content:space-between;align-items:center;margin-bottom:16px;padding:20px 24px 0;display:flex}.rota-modal-header h3{color:var(--navy-dark);letter-spacing:-.3px;margin:0;font-size:17px;font-weight:800}.rota-modal-close{cursor:pointer;color:var(--gray-400);background:0 0;border:none;padding:4px;transition:color .15s}.rota-modal-close:hover{color:var(--navy)}.rota-modal-body{padding:0 24px 16px}.rota-modal-footer{border-top:1px solid var(--gray-100);justify-content:flex-end;gap:10px;padding:16px 24px 20px;display:flex}.rota-field-label{color:var(--gray-700);letter-spacing:-.1px;margin-bottom:6px;font-size:12px;font-weight:700;display:block}.shift-type-pills{flex-wrap:wrap;gap:7px;display:flex}.shift-type-pill{border:1.5px solid var(--gray-200);font-size:13px;font-weight:600;font-family:var(--sans);cursor:pointer;background:var(--white);color:var(--gray-700);border-radius:8px;padding:7px 14px;transition:all .15s}.shift-type-pill:hover{border-color:var(--navy);color:var(--navy)}.shift-type-pill--active{font-weight:700}.rota-time-row{grid-template-columns:1fr 1fr;gap:12px;margin-top:16px;display:grid}.rota-time-input{border:1.5px solid var(--gray-200);width:100%;font-size:14px;font-family:var(--sans);color:var(--text);border-radius:9px;outline:none;padding:9px 12px;transition:border-color .15s,box-shadow .15s}.rota-time-input:focus{border-color:var(--navy);box-shadow:0 0 0 3px #1b3a561a}.rota-notes-input{border:1.5px solid var(--gray-200);width:100%;font-size:14px;font-family:var(--sans);color:var(--text);border-radius:9px;outline:none;padding:9px 12px;transition:border-color .15s,box-shadow .15s}.rota-notes-input:focus{border-color:var(--navy);box-shadow:0 0 0 3px #1b3a561a}.avail-hint{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;margin-top:12px;padding:8px 12px;font-size:12px}.avail-hint--unavail{color:var(--error);background:#fdf2f2;border-color:#fecaca}.rota-btn-primary{background:var(--navy);color:var(--white);font-size:14px;font-weight:700;font-family:var(--sans);cursor:pointer;border:none;border-radius:9px;padding:10px 22px;transition:background .15s}.rota-btn-primary:hover:not(:disabled){background:var(--navy-light)}.rota-btn-primary:disabled{opacity:.5;cursor:not-allowed}.rota-btn-ghost{color:var(--gray-600);border:1.5px solid var(--gray-200);font-size:14px;font-weight:600;font-family:var(--sans);cursor:pointer;background:0 0;border-radius:9px;padding:10px 18px;transition:all .15s}.rota-btn-ghost:hover{border-color:var(--gray-400);color:var(--gray-800)}.swap-staff-list{flex-direction:column;gap:6px;display:flex}.swap-staff-item{border:1.5px solid var(--gray-100);background:var(--white);cursor:pointer;color:var(--text);font-size:14px;font-weight:500;font-family:var(--sans);text-align:left;border-radius:10px;align-items:center;gap:12px;padding:10px 12px;transition:all .15s;display:flex}.swap-staff-item:hover{border-color:var(--navy);background:var(--off-white)}.swap-staff-item--selected{border-color:var(--navy);background:#1b3a560d;font-weight:700}.swap-request-row{border-top:1px solid var(--gray-100);flex-direction:column;gap:8px;padding:14px 0;display:flex}.swap-request-row:first-child{border-top:none}.swap-request-info{color:var(--text);flex-wrap:wrap;align-items:baseline;gap:4px;font-size:14px;line-height:1.5;display:flex}.swap-status-pill{border-radius:100px;padding:2px 8px;font-size:11px;font-weight:700}.swap-status--pending{color:#92400e;background:#fef3c7}.swap-status--accepted{color:#065f46;background:#d1fae5}.swap-status--declined{background:var(--gray-100);color:var(--gray-500)}.swap-manager-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.avail-section{border-top:1px solid var(--gray-100);background:var(--white);flex-shrink:0;padding:24px}.avail-section-title{color:var(--navy-dark);letter-spacing:-.3px;margin:0 0 4px;font-size:16px;font-weight:800}.avail-section-sub{color:var(--text-light);margin:0 0 16px;font-size:13px}.avail-week-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px;margin-bottom:16px;display:grid}.avail-day-card{background:var(--off-white);border:1px solid var(--gray-100);border-radius:10px;flex-direction:column;gap:7px;padding:12px;display:flex}.avail-day-name{color:var(--navy-dark);letter-spacing:-.1px;font-size:12px;font-weight:700}.avail-toggle{color:var(--text);cursor:pointer;align-items:center;gap:6px;font-size:12px;font-weight:600;display:flex}.avail-toggle input{cursor:pointer;accent-color:var(--navy)}.avail-pref-select{border:1.5px solid var(--gray-200);width:100%;font-size:12px;font-family:var(--sans);color:var(--text);background:var(--white);cursor:pointer;border-radius:7px;outline:none;padding:6px 10px}.avail-pref-select:focus{border-color:var(--navy)}.avail-notes{border:1.5px solid var(--gray-200);width:100%;font-size:12px;font-family:var(--sans);color:var(--text);border-radius:7px;outline:none;padding:6px 10px}.avail-notes:focus{border-color:var(--navy)}.avail-save-row{justify-content:flex-end;display:flex}@media (width<=640px){.rota-header{flex-direction:column;align-items:flex-start}.rota-controls{width:100%}.rota-manager-actions{flex-wrap:wrap}.avail-week-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}.rota-modal{border-radius:18px 18px 0 0;max-width:100%;max-height:85vh;margin:0;position:fixed;bottom:0;left:0;right:0}.rota-overlay{align-items:flex-end;padding:0}.avail-sidebar{display:none}.rota-week-grid{grid-template-columns:repeat(7,minmax(130px,1fr))}}.rota-body{flex:1;min-height:0;display:flex;overflow:hidden}.avail-sidebar{background:var(--white);border-right:1px solid var(--gray-100);flex-direction:column;flex-shrink:0;width:210px;min-width:210px;display:flex;overflow-y:auto}.avail-sidebar-header{color:var(--gray-700);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--gray-100);align-items:center;gap:7px;padding:14px 16px 10px;font-size:12px;font-weight:700;display:flex}.avail-sidebar-legend{border-bottom:1px solid var(--gray-100);flex-direction:column;gap:5px;padding:12px 16px;display:flex}.avail-legend-dot-item{color:var(--text-light);align-items:center;gap:6px;font-size:12px;display:flex}.avail-legend-swatch{border-radius:50%;flex-shrink:0;width:9px;height:9px}.avail-sidebar-empty{color:var(--gray-400);padding:16px;font-size:12px;line-height:1.5}.avail-sidebar-table{flex-direction:column;gap:2px;padding:12px 10px;display:flex}.avail-row{grid-template-columns:68px repeat(7,1fr);align-items:center;gap:2px;display:grid}.avail-row--head .avail-row-name{color:var(--gray-500);text-transform:uppercase;letter-spacing:.4px;font-size:10px;font-weight:700}.avail-row--head .avail-row-cell{color:var(--gray-500);text-align:center;text-transform:uppercase;font-size:10px;font-weight:700}.avail-row-name{color:var(--navy-dark);text-overflow:ellipsis;white-space:nowrap;padding-right:4px;font-size:12px;font-weight:600;overflow:hidden}.avail-row-cell{text-align:center;cursor:default;border-radius:4px;padding:3px 0;font-size:13px;position:relative}.avail-row-cell--none{color:var(--gray-300)}.avail-note-dot{background:var(--gold);border-radius:50%;width:5px;height:5px;display:inline-block;position:absolute;top:1px;right:2px}.avail-staff-block{flex-direction:column;gap:0;display:flex}.avail-notes-lines{border-bottom:1px solid var(--gray-100);flex-direction:column;gap:2px;margin-bottom:2px;padding:3px 0 6px;display:flex}.avail-note-line{color:var(--gray-500);white-space:nowrap;text-overflow:ellipsis;padding:0 4px;font-size:10px;line-height:1.4;overflow:hidden}.avail-note-day{color:var(--gray-600);font-weight:700}.notes-toggle{margin-top:4px}.notes-toggle-btn{font-size:11px;font-weight:600;font-family:var(--sans);color:var(--navy);cursor:pointer;opacity:.7;background:0 0;border:none;padding:0;transition:opacity .15s}.notes-toggle-btn:hover{opacity:1}.notes-toggle-text{background:#0000000a;border-radius:5px;margin:4px 0 0;padding:5px 8px}.notes-toggle-line{color:var(--gray-600);margin:0;font-size:12px;font-style:italic;line-height:1.5}.notes-toggle-line+.notes-toggle-line{margin-top:5px}.rota-month-chips{flex-direction:column;gap:2px;margin-top:3px;display:flex}.month-chip{color:var(--gray-800);cursor:pointer;border-left:2px solid;border-radius:3px;flex-direction:column;align-items:flex-start;gap:1px;padding:2px 5px 2px 4px;font-size:11px;font-weight:600;line-height:1.3;display:flex;overflow:hidden}.month-chip-row{align-items:center;gap:4px;width:100%;display:flex}.month-chip-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.month-chip-name{text-overflow:ellipsis;white-space:nowrap;font-size:11px;font-weight:700;overflow:hidden}.month-chip-detail{opacity:.8;white-space:nowrap;text-overflow:ellipsis;width:100%;padding-left:10px;font-size:10px;overflow:hidden}.month-chip-more{color:var(--gray-400);padding-left:4px;font-size:10px;font-weight:500}.rota-staff-scroll{flex-direction:column;flex:1;min-height:0;display:flex;overflow-y:auto}.rota-staff-scroll .rota-week-scroll{flex:none;overflow-x:auto}.rota-staff-scroll .rota-week-grid{min-height:320px}.rota-month-day--today{background:var(--navy);color:var(--white);border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:12px;display:inline-flex}.rota-month-cell{min-height:80px}.rota-calendar-col{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.rota-week-scroll{flex:1;overflow:auto}.rota-week-grid{border-left:1px solid var(--gray-100);grid-template-columns:repeat(7,minmax(155px,1fr));min-height:100%;display:grid}.rota-day-col{border-right:1px solid var(--gray-100);background:var(--white);flex-direction:column;display:flex}.rota-day-col--today{background:#fafbff}.rota-day-header{border-bottom:1px solid var(--gray-100);z-index:1;background:inherit;flex-direction:column;flex-shrink:0;align-items:center;gap:2px;padding:10px 12px 8px;display:flex;position:sticky;top:0}.rota-day-name{color:var(--gray-500);text-transform:uppercase;letter-spacing:.6px;font-size:10px;font-weight:700}.rota-day-num{color:var(--navy-dark);letter-spacing:-.5px;font-size:20px;font-weight:800;line-height:1}.rota-day-num--today{background:var(--navy);color:var(--white);border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;display:flex}.rota-avail-strips{border-bottom:1px solid var(--gray-100);background:var(--off-white);flex-direction:column;gap:3px;padding:6px 8px;display:flex}.avail-strip{cursor:default;border-left:3px solid #0000;border-radius:5px;justify-content:space-between;align-items:center;padding:3px 7px 3px 8px;font-size:11px;transition:background .1s;display:flex}.avail-strip--unavail{opacity:.75}.avail-strip-name{color:var(--gray-700);text-overflow:ellipsis;white-space:nowrap;font-weight:600;overflow:hidden}.avail-strip-badge{border:1px solid;border-radius:4px;flex-shrink:0;margin-left:4px;padding:1px 5px;font-size:10px;font-weight:800}.my-avail-banner{cursor:default;background:#05966912;border-left:3px solid;border-radius:6px;margin:6px 8px 0;padding:4px 9px;font-size:11px;font-weight:600}.my-avail-banner--unavail{background:#dc262612}.rota-day-shifts{flex-direction:column;flex:1;gap:7px;padding:8px;display:flex}.shift-block{border:1.5px solid;border-radius:10px;flex-direction:column;gap:5px;min-height:90px;padding:9px 11px;transition:box-shadow .15s;display:flex;position:relative}.shift-block:hover{box-shadow:0 3px 12px #0d1f331f}.shift-block--me{box-shadow:0 0 0 2px}.shift-block-header{justify-content:space-between;align-items:center;gap:6px;display:flex}.shift-type-badge{color:#fff;text-transform:uppercase;letter-spacing:.4px;border-radius:4px;align-items:center;padding:2px 8px;font-size:10px;font-weight:800;display:inline-flex}.shift-block-header-actions{align-items:center;gap:4px;display:flex}.shift-status-pill{background:var(--gray-200);color:var(--gray-600);text-transform:uppercase;letter-spacing:.3px;border-radius:4px;padding:1px 6px;font-size:9px;font-weight:700}.shift-status-pill--confirmed{color:#059669;background:#0596691f}.shift-status-pill--sent{color:#92400e;background:#fef3c7}.shift-status-pill--accepted{color:#059669;background:#0596691f;align-items:center;gap:3px;display:inline-flex}.shift-status-pill--declined{color:#dc2626;background:#dc262617}.shift-del-btn{cursor:pointer;color:var(--gray-400);opacity:0;background:0 0;border:none;border-radius:4px;align-items:center;padding:2px;transition:opacity .15s,color .15s;display:flex}.shift-block:hover .shift-del-btn{opacity:1}.shift-del-btn:hover{color:var(--error)}.shift-block-name{letter-spacing:-.2px;font-size:14px;font-weight:800;line-height:1.2}.shift-block-time{color:var(--gray-600);align-items:center;gap:5px;font-size:12px;font-weight:600;display:flex}.shift-block-notes{color:var(--gray-500);text-overflow:ellipsis;white-space:nowrap;font-size:11px;font-style:italic;overflow:hidden}.shift-actions{flex-wrap:wrap;gap:4px;margin-top:2px;display:flex}.shift-action-btn{font-size:11px;font-weight:700;font-family:var(--sans);cursor:pointer;border:none;border-radius:6px;align-items:center;gap:3px;padding:4px 9px;display:inline-flex}.shift-action--confirm{color:#059669;background:#0596691f}.shift-action--confirm:hover{background:#05966938}.shift-action--swap{color:#1d4ed8;background:#2563eb1a}.shift-action--swap:hover{background:#2563eb33}.shift-action--decline{color:var(--error);background:#dc262617}.shift-action--decline:hover{background:#dc26262e}.shift-swap-pending{color:var(--gray-500);font-size:11px;font-style:italic}.shift-swap-request{color:#1d4ed8;font-size:11px;font-weight:600}.shift-edit-link{color:var(--gray-400);cursor:pointer;background:0 0;border:none;align-self:flex-start;margin-top:auto;padding:0;font-size:11px;text-decoration:underline}.shift-edit-link:hover{color:var(--navy)}.rota-add-btn{border:1.5px dashed var(--gray-300);cursor:pointer;color:var(--gray-400);font-size:12px;font-weight:600;font-family:var(--sans);background:0 0;border-radius:9px;justify-content:center;align-items:center;gap:5px;margin:6px 8px 10px;padding:7px;transition:border-color .15s,color .15s,background .15s;display:flex}.rota-add-btn:hover{border-color:var(--navy);color:var(--navy);background:#1b3a560a}.pending-screen{text-align:center}.pending-icon{border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 22px;display:flex}.pending-icon--success{color:#065f46;background:#d1fae5}.pending-icon--waiting{color:#92400e;background:#fef3c7}.pending-icon--declined{color:var(--error);background:#fee2e2}.pending-heading{color:var(--navy-dark);letter-spacing:-.5px;margin:0 0 14px;font-size:24px;font-weight:800}.pending-body{color:var(--text-light);margin:0 0 14px;font-size:15px;line-height:1.65}.pending-signout-btn{border:1.5px solid var(--gray-200);font-size:14px;font-weight:600;font-family:var(--sans);color:var(--gray-600);cursor:pointer;background:0 0;border-radius:9px;align-items:center;gap:7px;margin-top:22px;padding:10px 20px;transition:all .15s;display:inline-flex}.pending-signout-btn:hover{border-color:var(--gray-400);color:var(--gray-800)}.pending-approval-header{flex-direction:column;gap:4px;margin-bottom:16px;display:flex}.pending-approval-badge{color:#92400e;background:#fef3c7;border:1px solid #fcd34d;border-radius:100px;align-self:flex-start;align-items:center;margin-bottom:6px;padding:4px 12px;font-size:12px;font-weight:700;display:inline-flex}.pending-member-row{border-top:1px solid var(--gray-100);align-items:flex-start;gap:14px;padding:14px 0;display:flex}.pending-member-row:first-of-type{border-top:none}.pending-member-info{flex:1;min-width:0}.pending-member-actions{flex-direction:column;flex-shrink:0;gap:7px;display:flex}.pending-approve-btn{background:var(--navy);color:var(--white);font-size:13px;font-weight:700;font-family:var(--sans);cursor:pointer;white-space:nowrap;border:none;border-radius:8px;padding:7px 16px;transition:background .15s}.pending-approve-btn:hover{background:var(--navy-light)}.pending-decline-btn{color:var(--error);font-size:13px;font-weight:700;font-family:var(--sans);cursor:pointer;white-space:nowrap;background:0 0;border:1.5px solid #fecaca;border-radius:8px;padding:7px 16px;transition:all .15s}.pending-decline-btn:hover{border-color:var(--error);background:#fee2e2}.staff-pub-info{background:var(--off-white);border:1px solid var(--gray-100);border-radius:10px;margin-bottom:20px;padding:12px 16px}.staff-pub-info-label{color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;margin-bottom:3px;font-size:11px;font-weight:700}.staff-pub-info-name{color:var(--navy-dark);letter-spacing:-.2px;font-size:16px;font-weight:700}.staff-pub-readonly{margin-top:8px}.staff-pub-readonly-row{border-bottom:1px solid var(--gray-100);align-items:baseline;gap:12px;padding:8px 0;display:flex}.staff-pub-readonly-row:first-of-type{border-top:1px solid var(--gray-100)}.staff-pub-readonly-label{color:var(--gray-500);flex-shrink:0;width:72px;font-size:12px;font-weight:600}.staff-pub-readonly-value{color:var(--navy-dark);font-size:14px;font-weight:600}.staff-pub-readonly-note{color:var(--gray-400);margin-top:10px;font-size:12px;font-style:italic}.sidebar-badge{color:#fff;letter-spacing:0;background:#d97706;border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;min-width:18px;height:18px;margin-left:auto;padding:0 5px;font-size:10px;font-weight:800;display:flex}.action-required-card{cursor:pointer;text-align:left;width:100%;font-family:var(--sans);background:#fef3c7;border:1px solid #fcd34d;border-left:3px solid #d97706;border-radius:13px;align-items:center;gap:14px;padding:16px 20px;transition:background .15s;display:flex}.action-required-card:hover{background:#fde68a}.action-required-icon{color:#d97706;flex-shrink:0;display:flex}.action-required-content{flex:1;min-width:0}.action-required-title{color:#92400e;letter-spacing:-.1px;margin:0 0 3px;font-size:14px;font-weight:700}.action-required-sub{color:#b45309;text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:13px;line-height:1.5;overflow:hidden}.action-required-arrow{color:#d97706;flex-shrink:0;font-size:16px;font-weight:700}.staff-pending-banner{color:#92400e;background:#fef3c7;border-bottom:1px solid #fcd34d;flex-shrink:0;align-items:center;gap:10px;padding:13px 24px;font-size:14px;font-weight:500;display:flex}.staff-pending-banner-btn{color:#fff;font-size:12px;font-weight:700;font-family:var(--sans);cursor:pointer;background:#d97706;border:none;border-radius:7px;flex-shrink:0;margin-left:auto;padding:5px 16px;transition:background .15s}.staff-pending-banner-btn:hover{background:#b45309}.rota-tabs{border-bottom:1px solid var(--gray-100);background:var(--white);flex-shrink:0;gap:4px;padding:0 20px;display:flex}.rota-tab{color:var(--gray-500);cursor:pointer;font-size:13px;font-weight:600;font-family:var(--sans);white-space:nowrap;letter-spacing:-.1px;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:13px 16px;transition:color .15s,border-color .15s}.rota-tab:hover{color:var(--navy-dark)}.rota-tab--active{color:var(--navy-dark);border-bottom-color:var(--navy);font-weight:700}.rota-tab-body{flex:1;min-height:0;overflow-y:auto}.avail-tab{flex-direction:column;min-height:0;display:flex}.avail-tab-header{flex-shrink:0;justify-content:space-between;align-items:flex-start;padding:20px 24px 0;display:flex}.avail-tab-title{color:var(--navy-dark);letter-spacing:-.4px;margin:0 0 3px;font-size:18px;font-weight:800}.avail-tab-sub{color:var(--text-light);margin:0;font-size:13px}.avail-submitted-badge{color:#065f46;background:#d1fae5;border-radius:100px;flex-shrink:0;align-items:center;gap:6px;padding:5px 12px;font-size:12px;font-weight:700;display:inline-flex}.avail-submitted-notice{color:#1e40af;background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;flex-shrink:0;margin:12px 24px 0;padding:10px 14px;font-size:13px;line-height:1.5}.avail-changes-banner{color:#92400e;background:#fef9ee;border:1px solid #fcd34d;border-radius:8px;flex-shrink:0;align-items:center;gap:8px;margin:10px 24px 0;padding:9px 14px;font-size:13px;display:flex}.avail-v2-legend{flex-wrap:wrap;flex-shrink:0;align-items:center;gap:16px;padding:14px 24px 0;display:flex}.avail-v2-legend-item{color:var(--gray-600);align-items:center;gap:5px;font-size:12px;font-weight:500;display:flex}.avail-v2-legend-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.avail-v2-legend-hint{color:var(--gray-400);font-style:italic}.avail-week-section{flex-shrink:0;padding:16px 24px 0}.avail-week-card{border:1px solid var(--gray-100);background:var(--white);box-shadow:var(--shadow-xs);border-radius:14px;flex-shrink:0;margin:0 24px 16px;overflow:hidden}.avail-week-card--saved{border-color:#6ee7b7}.avail-week-card--change-requested,.avail-week-card--in-progress{border-color:#fcd34d}.avail-week-card-header{border-bottom:1px solid var(--gray-100);background:var(--off-white);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.avail-week-card--saved .avail-week-card-header{background:#f0fdf4}.avail-week-card--change-requested .avail-week-card-header{background:#fefce8}.avail-week-card-title{color:var(--navy-dark);font-size:13px;font-weight:700}.avail-week-status{border-radius:100px;align-items:center;gap:5px;padding:3px 10px;font-size:11px;font-weight:700;display:inline-flex}.avail-week-status--not-started{background:var(--gray-100);color:var(--gray-500)}.avail-week-status--in-progress{color:#92400e;background:#fef3c7}.avail-week-status--saved{color:#065f46;background:#d1fae5}.avail-week-status--change-requested{color:#92400e;background:#fef3c7}.avail-week-card .avail-v2-grid{padding:12px}.avail-week-card-footer{border-top:1px solid var(--gray-100);background:var(--off-white);padding:12px 16px}.avail-week-confirm{flex-direction:column;gap:10px;display:flex}.avail-week-confirm-msg{color:var(--gray-700);margin:0;font-size:13px;line-height:1.5}.avail-week-amend-hint{color:var(--text-light);margin:0 0 10px;font-size:12px;font-style:italic;line-height:1.5}.avail-request-changes-btn{cursor:pointer;color:var(--navy);font-size:12px;font-weight:600;font-family:var(--sans);background:0 0;border:none;padding:0;text-decoration:underline}.avail-request-changes-btn:hover{color:var(--navy-light)}.avail-next-month{text-align:center;background:#1b3a560a;border:1px solid #1b3a561f;border-radius:12px;flex-direction:column;flex-shrink:0;align-items:center;gap:12px;margin:0 24px 24px;padding:18px 20px;display:flex}.avail-next-month p{color:var(--text-light);margin:0;font-size:14px}.avail-week-heading{color:var(--gray-600);letter-spacing:-.1px;text-transform:uppercase;letter-spacing:.4px;margin:0 0 10px;font-size:13px;font-weight:700}.avail-v2-grid{grid-template-columns:repeat(7,1fr);gap:6px;display:grid}.avail-v2-day{background:var(--white);border:1px solid var(--gray-100);border-radius:10px;flex-direction:column;gap:5px;min-width:0;padding:10px 8px;display:flex}.avail-v2-day--today{background:#1b3a5605;border-color:#1b3a564d}.avail-v2-day-header{border-bottom:1px solid var(--gray-100);flex-direction:column;align-items:center;margin-bottom:2px;padding-bottom:6px;display:flex}.avail-v2-day-name{color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;font-size:10px;font-weight:700}.avail-v2-day-num{color:var(--navy-dark);letter-spacing:-.3px;font-size:16px;font-weight:800;line-height:1.1}.avail-v2-slot{align-items:center;gap:5px;min-width:0;display:flex}.avail-v2-slot-label{text-transform:uppercase;letter-spacing:.3px;text-align:center;flex-shrink:0;width:12px;font-size:10px;font-weight:800}.avail-v2-btns{flex:1;gap:2px;min-width:0;display:flex}.avail-v2-btn{background:var(--gray-100);min-width:0;color:var(--gray-500);border:1px solid var(--gray-200);cursor:pointer;font-size:10px;font-weight:700;font-family:var(--sans);text-align:center;border-radius:4px;flex:1;padding:3px 2px;transition:all .1s}.avail-v2-btn:hover{border-color:var(--gray-400);color:var(--gray-700)}.avail-v2-btn--active{font-weight:800}.avail-v2-chip{border:1px solid var(--gray-200);cursor:pointer;font-size:10px;font-weight:800;font-family:var(--sans);text-align:center;background:var(--gray-100);color:var(--gray-500);border-radius:4px;flex:1;padding:3px 4px;transition:all .1s}.avail-v2-chip:hover{opacity:.8}.avail-v2-chip--pending{color:#92400e;cursor:pointer;background:#fef3c7;border-color:#fcd34d}.avail-slot-row{align-items:center;gap:4px;padding:3px 0;display:flex}.avail-slot-label{text-align:right;letter-spacing:-.2px;flex-shrink:0;width:28px;font-size:10px;font-weight:700}.avail-slot-toggle{border:1.5px solid var(--gray-200);background:var(--gray-100);width:22px;height:22px;color:var(--gray-500);cursor:pointer;font-size:11px;font-weight:800;font-family:var(--sans);border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;transition:all .1s;display:flex}.avail-slot-toggle--avail{color:#059669;background:#d1fae5;border-color:#6ee7b7}.avail-slot-toggle--unavail{color:#dc2626;background:#fee2e2;border-color:#fca5a5}.avail-slot-notes{min-width:0;height:22px;font-size:11px;font-family:var(--sans);color:var(--text);background:var(--white);border:1px solid var(--gray-200);border-radius:4px;outline:none;flex:1;padding:0 5px;transition:border-color .15s}.avail-slot-notes::placeholder{color:var(--gray-300)}.avail-slot-notes:focus{border-color:var(--navy)}.avail-slot-chip{border:1.5px solid var(--gray-200);cursor:pointer;width:22px;height:22px;font-size:11px;font-weight:800;font-family:var(--sans);border-radius:4px;justify-content:center;align-items:center;transition:opacity .1s;display:flex}.avail-slot-chip:hover{opacity:.75}.avail-slot-chip--avail{color:#059669;background:#d1fae5;border-color:#6ee7b7}.avail-slot-chip--unavail{color:#dc2626;background:#fee2e2;border-color:#fca5a5}.avail-slot-chip--pending{color:#92400e;background:#fef3c7;border-color:#fcd34d}.avail-tab-footer{border-top:1px solid var(--gray-100);background:var(--white);flex-shrink:0;justify-content:flex-end;margin-top:16px;padding:20px 24px;display:flex}@media (width<=700px){.avail-v2-grid{grid-template-columns:repeat(7,minmax(80px,1fr));overflow-x:auto}.avail-week-section{padding:12px 16px 0}.avail-tab-header{padding:16px 16px 0}.avail-v2-legend{padding:12px 16px 0}}.builder-tab{flex-direction:column;height:100%;min-height:0;display:flex}.builder-header{border-bottom:1px solid var(--gray-100);background:var(--white);flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:14px 20px;display:flex}.builder-nav{align-items:center;gap:8px;display:flex}.builder-week-label{color:var(--navy-dark);letter-spacing:-.2px;white-space:nowrap;font-size:14px;font-weight:700}.builder-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.builder-publish-msg{color:#059669;background:#d1fae5;border:1px solid #6ee7b7;border-radius:7px;padding:5px 12px;font-size:13px;font-weight:600}.builder-week-stats{gap:6px;display:flex}.builder-stat{border-radius:100px;padding:4px 10px;font-size:11px;font-weight:700}.builder-stat--draft{background:var(--gray-100);color:var(--gray-600)}.builder-stat--sent{color:#92400e;background:#fef3c7;font-weight:500}.rota-send-btn{color:#fff;font-size:13px;font-weight:700;font-family:var(--sans);cursor:pointer;background:#d97706;border:none;border-radius:9px;align-items:center;gap:6px;padding:9px 18px;transition:background .15s,box-shadow .15s;display:inline-flex}.rota-send-btn:hover:not(:disabled){background:#b45309;box-shadow:0 3px 10px #b453094d}.rota-send-btn:disabled{opacity:.5;cursor:not-allowed}.rota-generate-btn{color:#fff;font-size:13px;font-weight:700;font-family:var(--sans);cursor:pointer;background:linear-gradient(135deg,#6c4de6,#4f46e5);border:none;border-radius:8px;align-items:center;gap:6px;padding:7px 14px;transition:opacity .15s,box-shadow .15s;display:inline-flex}.rota-generate-btn:hover:not(:disabled){opacity:.88;box-shadow:0 3px 10px #4f46e54d}.rota-generate-btn:disabled{opacity:.5;cursor:not-allowed}.rota-gen-error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;align-items:center;gap:8px;margin:0 20px 12px;padding:10px 14px;font-size:13px;display:flex}.rota-gen-error span{flex:1}.rota-gen-error button{cursor:pointer;color:#dc2626;background:0 0;border:none;flex-shrink:0;align-items:center;padding:2px;display:flex}.pub-hours-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.suggested-shift-card{background:var(--gray-50);border:1.5px dashed var(--gray-300);border-radius:10px;flex-direction:column;gap:5px;padding:9px 11px;display:flex}.suggested-shift-header{align-items:center;display:flex}.suggested-shift-time{color:var(--gray-500);letter-spacing:-.1px;font-size:11px;font-weight:700}.suggested-shift-note{color:var(--gray-400);margin:0;font-size:11px;line-height:1.4}.suggested-shift-actions{gap:5px;margin-top:3px;display:flex}.suggested-shift-accept{background:var(--navy);color:#fff;font-size:11px;font-weight:700;font-family:var(--sans);cursor:pointer;border:none;border-radius:6px;flex:1;padding:5px 6px;transition:background .15s}.suggested-shift-accept:hover{background:var(--navy-light)}.suggested-shift-skip{color:var(--gray-500);border:1.5px solid var(--gray-200);font-size:11px;font-weight:600;font-family:var(--sans);cursor:pointer;background:0 0;border-radius:6px;flex:1;padding:5px 6px;transition:all .15s}.suggested-shift-skip:hover{border-color:var(--gray-400);color:var(--gray-700)}.rota-generating-wrap{flex-direction:column;justify-content:center;align-items:center;gap:14px;padding:60px 20px;display:flex}.reset-rota-bar{flex-shrink:0;justify-content:flex-end;padding:2px 20px 6px;display:flex}.reset-rota-link{cursor:pointer;font-family:var(--sans);color:var(--gray-400);background:0 0;border:none;font-size:11px;text-decoration:underline;transition:color .15s}.reset-rota-link:hover{color:var(--error)}.reset-confirm-bar{background:#fef9ee;border-bottom:1px solid #fcd34d;flex-wrap:wrap;flex-shrink:0;align-items:center;gap:10px;padding:8px 20px;display:flex}.reset-confirm-bar--danger{background:#fef2f2;border-bottom-color:#fecaca}.reset-confirm-msg{color:var(--gray-700);flex:1;font-size:13px;line-height:1.4}.reset-confirm-cancel{border:1px solid var(--gray-200);color:var(--gray-600);cursor:pointer;font-size:12px;font-weight:600;font-family:var(--sans);background:0 0;border-radius:7px;padding:5px 14px;transition:all .12s}.reset-confirm-cancel:hover{border-color:var(--gray-400);color:var(--gray-800)}.reset-confirm-continue{color:#92400e;cursor:pointer;font-size:12px;font-weight:700;font-family:var(--sans);background:#fef3c7;border:1px solid #fcd34d;border-radius:7px;padding:5px 14px;transition:background .12s}.reset-confirm-continue:hover{background:#fde68a}.reset-confirm-final{background:var(--error);color:#fff;cursor:pointer;font-size:12px;font-weight:700;font-family:var(--sans);border:none;border-radius:7px;padding:5px 14px;transition:background .12s}.reset-confirm-final:hover:not(:disabled){background:#b91c1c}.reset-confirm-final:disabled{opacity:.6;cursor:not-allowed}.response-summary{border-top:1px solid var(--gray-100);background:var(--white);flex-shrink:0;padding:10px 16px}.response-summary-header{color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:11px;font-weight:700;display:flex}.response-summary-counts{letter-spacing:0;text-transform:none;font-size:12px;font-weight:500}.response-row{border-radius:7px;align-items:center;gap:8px;margin-bottom:3px;padding:6px 8px;font-size:13px;display:flex}.response-row--accepted{background:#0596690f}.response-row--declined{background:#dc26260f}.response-row--draft_sent{background:var(--off-white)}.response-row-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.response-row-name{color:var(--navy-dark);min-width:100px;font-weight:700}.response-row-shift{color:var(--text-light);flex:1}.response-row-status{text-align:right;min-width:80px;font-size:12px;font-weight:700}.response-status--accepted{color:#059669}.response-status--declined{color:#dc2626}.response-status--draft_sent{color:var(--gray-400)}.response-row-reason{color:var(--gray-500);border-left:2px solid #fca5a5;flex:1;padding-left:6px;font-size:12px;font-style:italic}.draft-review-section{background:#fef9ee;border:1px solid #fcd34d;border-radius:14px;margin:0 0 16px;overflow:hidden}.draft-review-heading{color:#92400e;border-bottom:1px solid #fde68a;align-items:center;gap:7px;padding:11px 16px;font-size:13px;font-weight:700;display:flex}.draft-review-grid-wrap{overflow-x:auto}.draft-review-grid{background:var(--white);grid-template-columns:repeat(7,minmax(120px,1fr));gap:0;min-width:700px;display:grid}.draft-review-col{border-right:1px solid #fef3c7;flex-direction:column;display:flex}.draft-review-col:last-child{border-right:none}.draft-review-col--today{background:#1b3a5606}.draft-review-col-header{background:#fef9ee;border-bottom:1px solid #fde68a;flex-direction:column;align-items:center;padding:8px 4px 6px;display:flex}.draft-review-col-day{color:#b45309;text-transform:uppercase;letter-spacing:.5px;font-size:10px;font-weight:700}.draft-review-col-date{color:#92400e;font-size:17px;font-weight:800;line-height:1.1}.draft-review-col-shifts{flex-direction:column;flex:1;gap:6px;padding:8px 6px;display:flex}.draft-review-col-off{color:var(--gray-300);text-align:center;padding:10px 0;font-size:12px}.draft-review-shift-card{background:var(--white);border:1px solid var(--gray-100);box-shadow:var(--shadow-xs);border-top:3px solid;border-radius:8px;flex-direction:column;gap:4px;padding:8px;display:flex}.draft-review-shift-type{text-transform:uppercase;letter-spacing:.3px;font-size:11px;font-weight:800}.draft-review-shift-time{color:var(--gray-700);font-size:12px;font-weight:600}.draft-review-shift-notes{color:var(--text-light);font-size:11px;font-style:italic;line-height:1.4}.draft-grid-actions{flex-wrap:wrap;gap:4px;margin-top:2px;display:flex}.draft-grid-btn{cursor:pointer;min-width:0;font-size:11px;font-weight:700;font-family:var(--sans);border:none;border-radius:5px;flex:1;justify-content:center;align-items:center;gap:3px;padding:4px 6px;transition:background .12s;display:inline-flex}.draft-grid-btn--accept{color:#059669;background:#0596691f}.draft-grid-btn--accept:hover{background:#05966938}.draft-grid-btn--decline{color:#dc2626;background:#dc262617}.draft-grid-btn--decline:hover{background:#dc26262e}.draft-decline-form{flex-direction:column;gap:5px;margin-top:2px;display:flex}.draft-decline-input{border:1px solid var(--gray-200);width:100%;font-size:11px;font-family:var(--sans);border-radius:6px;outline:none;padding:5px 8px;transition:border-color .15s}.draft-decline-input:focus{border-color:#dc2626}.draft-decline-btns{gap:4px;display:flex}.builder-stat--pub{color:#065f46;background:#d1fae5}.builder-changes-section{background:#fef9ee;border-bottom:1px solid #fcd34d;flex-direction:column;flex-shrink:0;gap:8px;margin:0;padding:12px 20px;display:flex}.builder-changes-header{color:#92400e;align-items:center;gap:6px;font-size:13px;display:flex}.builder-change-row{background:var(--white);border:1px solid #fde68a;border-radius:8px;flex-wrap:wrap;align-items:center;gap:10px;padding:8px 10px;display:flex}.builder-change-who{color:var(--navy-dark);flex-shrink:0;font-size:13px;font-weight:700}.builder-change-detail{color:var(--text);flex:1;min-width:0;font-size:13px}.builder-change-reason{color:var(--gray-500);flex-shrink:0;font-size:12px;font-style:italic}.builder-change-btns{flex-shrink:0;gap:6px;display:flex}.builder-no-avail{color:#92400e;background:#fef3c7;border-bottom:1px solid #fcd34d;flex-shrink:0;align-items:center;gap:8px;padding:10px 20px;font-size:13px;display:flex}.builder-body{flex-direction:column;flex:1;min-height:0;display:flex}.bat-wrap{border-bottom:2px solid var(--gray-100);background:var(--white);flex-shrink:0;overflow-x:auto}.bat{border-collapse:collapse;width:100%;font-size:12px;font-family:var(--sans)}.bat-th{background:var(--off-white);border:1px solid var(--gray-100);color:var(--gray-500);text-align:center;white-space:nowrap;padding:6px 4px;font-size:11px;font-weight:700}.bat-td{border:1px solid var(--gray-100);text-align:center;vertical-align:middle;padding:4px}.bat-name{text-align:left;color:var(--navy-dark);white-space:nowrap;min-width:70px;padding-left:12px;font-weight:700}.bat-day-head{min-width:60px}.bat-day-num{color:var(--navy-dark);font-size:13px;font-weight:800;line-height:1.1}.bat-day-head--today{background:#1b3a560f}.bat-cell--today{background:#1b3a5608}.bat-no-data{color:var(--gray-300);font-size:12px}.bat-slots{flex-direction:column;align-items:stretch;gap:2px;display:flex}.bat-slot-row{align-items:center;gap:3px;display:flex}.bat-slot-lbl{text-align:right;letter-spacing:-.2px;flex-shrink:0;width:26px;font-size:9px;font-weight:700}.bat-slot{cursor:default;border-radius:3px;flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;font-size:9px;font-weight:800;display:inline-flex}.bat-slot--avail{color:#059669;background:#d1fae5}.bat-slot--unavail{color:#dc2626;background:#fee2e2}.bat-slot--unknown{background:var(--gray-100);color:var(--gray-300)}.pub-tab{flex-direction:column;display:flex}.pub-tab-header{flex-shrink:0;justify-content:space-between;align-items:center;padding:20px 24px 8px;display:flex}.pub-week-section{flex-shrink:0;padding:12px 24px 0}.pub-week-header{align-items:center;gap:12px;margin-bottom:10px;display:flex}.pub-week-title{color:var(--gray-600);text-transform:uppercase;letter-spacing:.4px;margin:0;font-size:13px;font-weight:700}.pub-week-empty-badge{background:var(--gray-100);color:var(--gray-500);border-radius:100px;padding:3px 10px;font-size:11px;font-weight:600}.pub-no-shifts{color:var(--gray-300);padding:8px 4px;font-size:13px;display:block}.swap-manager-actions{flex-wrap:wrap;align-items:center;gap:8px;margin-top:6px;display:flex}@media (width<=700px){.builder-header{padding:12px 16px}.pub-tab-header{padding:16px 16px 8px}.pub-week-section{padding:10px 16px 0}.avail-tab-footer{padding:16px}}
