@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600&display=swap";:root{--ink: #191b26;--muted: #6a7081;--line: rgba(25, 27, 38, .09);--surface: rgba(255, 255, 255, .46);--surface-2: rgba(245, 246, 250, .38);--panel: rgba(255, 255, 255, .46);--panel-subtle: rgba(245, 246, 250, .38);--panel-elevated: rgba(255, 255, 255, .88);--accent: #4d54d4;--accent-ink: #ffffff;--accent-soft: rgba(77, 84, 212, .1);--green: #4d54d4;--green-dark: #3a40b0;--gold: #c08a2a;--blue: #0a84ff;--red: #d4453e;--danger-bg: rgba(212, 69, 62, .1);--danger-text: #d4453e;--ok: #2f9e6a;--ok-soft: rgba(47, 158, 106, .12);--warn: #c08a2a;--warn-soft: rgba(192, 138, 42, .14);--neutral-soft: rgba(25, 27, 38, .06);--focus: rgba(77, 84, 212, .18);--glass-blur: blur(10px) saturate(1.9);--shadow: inset 0 1px 0 rgba(255,255,255,.72), inset 0 0 0 1px rgba(255,255,255,.22), inset 0 -12px 26px rgba(255,255,255,.18), 0 1px 2px rgba(20,22,45,.05), 0 12px 32px rgba(20,22,45,.14);--shadow-strong: inset 0 1px 0 rgba(255,255,255,.72), inset 0 0 0 1px rgba(255,255,255,.22), 0 4px 16px rgba(20,22,45,.12), 0 24px 56px rgba(20,22,45,.2);--shadow-card: inset 0 1px 0 rgba(255,255,255,.72), inset 0 0 0 1px rgba(255,255,255,.22), 0 1px 2px rgba(20,22,45,.05), 0 8px 24px rgba(20,22,45,.1);--body-bg: radial-gradient(at 10% 6%, rgba(99, 102, 241, .55) 0%, transparent 40%), radial-gradient(at 92% 0%, rgba(56, 189, 248, .45) 0%, transparent 42%), radial-gradient(at 74% 98%, rgba(168, 85, 247, .42) 0%, transparent 44%), linear-gradient(165deg, #edeff7 0%, #e4e7f1 100%);--control: rgba(255, 255, 255, .82);--table-head: rgba(250, 253, 252, .9);--th-bg: #f5f6f9;--row-hover: rgba(77, 84, 212, .04);--soft: rgba(245, 246, 250, .6);--app-bg: #F5F4F0;--sidebar-bg: #eaecf6;--sidebar-ink: #1b1d27;--sidebar-muted: #6c7286;--sidebar-active-bg: rgba(77, 84, 212, .15);--sidebar-active-ink: #3a40b0;--sidebar-hover: rgba(25, 27, 38, .05);--sidebar-line: rgba(25, 27, 38, .08);--sidebar-card: rgba(255, 255, 255, .6);--sidebar-border: rgba(25, 27, 38, .08);--sidebar-sub: #6c7286;--sidebar-nav-hover: rgba(25, 27, 38, .05);--sidebar-nav-active-bg: rgba(77, 84, 212, .15);--sidebar-nav-active-border: rgba(77, 84, 212, .3);--sidebar-nav-active-color: #3a40b0;--sidebar-nav-active-shadow: inset 3px 0 0 #4d54d4;--font-ui: "Plus Jakarta Sans", system-ui, "Microsoft JhengHei", "PingFang TC", sans-serif;--font-display: "Plus Jakarta Sans", system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, monospace;--radius: 16px;--radius-sm: 11px;--radius-lg: 20px;--sidebar-w: 262px;--transition-spring: cubic-bezier(.34, 1.56, .64, 1);--sidebar-overlay: rgba(5, 18, 24, .44)}@keyframes rmTwinkle{0%,to{transform:scale(1);opacity:.9}50%{transform:scale(1.14);opacity:1}}@keyframes rmSpark{0%,to{opacity:0;transform:scale(.3)}40%{opacity:1;transform:scale(1)}72%{opacity:0;transform:scale(.4)}}@keyframes rmHalo{0%,to{opacity:.26;transform:scale(.78)}50%{opacity:.6;transform:scale(1.22)}}@keyframes rmShine{0%{background-position:150% 0}55%,to{background-position:-150% 0}}@keyframes liqA{0%,to{transform:translate(0) scale(1)}50%{transform:translate(18px,12px) scale(1.18)}}@keyframes liqB{0%,to{transform:translate(0) scale(1)}50%{transform:translate(-16px,-10px) scale(1.22)}}@keyframes liqC{0%,to{transform:translate(0) scale(1)}50%{transform:translate(10px,16px) scale(.86)}}@keyframes liqShine{0%{left:-50%}60%,to{left:120%}}:root[data-theme=dark]{--ink: #e7e9f1;--muted: #8b91a6;--line: rgba(255, 255, 255, .09);--surface: rgba(32, 36, 54, .8);--surface-2: rgba(26, 29, 44, .7);--panel: rgba(32, 36, 54, .8);--panel-subtle: rgba(26, 29, 44, .7);--panel-elevated: rgba(34, 38, 58, .96);--accent: #7c82f6;--green: #7c82f6;--green-dark: #6068e8;--accent-soft: rgba(124, 130, 246, .16);--focus: rgba(124, 130, 246, .2);--shadow: inset 0 1px 0 rgba(255,255,255,.18), inset 0 0 0 1px rgba(255,255,255,.07), inset 0 -12px 26px rgba(255,255,255,.05), 0 2px 4px rgba(0,0,0,.4), 0 16px 40px rgba(0,0,0,.55);--shadow-strong: inset 0 1px 0 rgba(255,255,255,.1), 0 4px 16px rgba(0,0,0,.5), 0 24px 56px rgba(0,0,0,.6);--shadow-card: inset 0 1px 0 rgba(255,255,255,.1), 0 1px 3px rgba(0,0,0,.4), 0 8px 24px rgba(0,0,0,.44);--body-bg: radial-gradient(at 10% 6%, rgba(99, 102, 241, .5) 0%, transparent 40%), radial-gradient(at 92% 0%, rgba(56, 189, 248, .34) 0%, transparent 42%), radial-gradient(at 74% 98%, rgba(168, 85, 247, .36) 0%, transparent 44%), linear-gradient(165deg, #0c0d14 0%, #0a0b10 100%);--control: rgba(255, 255, 255, .06);--app-bg: #0a0b10;--table-head: rgba(255, 255, 255, .04);--th-bg: #141620;--row-hover: rgba(124, 130, 246, .06);--soft: rgba(20, 22, 32, .6);--danger-bg: rgba(236, 122, 114, .16);--danger-text: #ec7a72;--ok: #52c98c;--ok-soft: rgba(82, 201, 140, .16);--warn: #e0b257;--warn-soft: rgba(224, 178, 87, .18);--neutral-soft: rgba(255, 255, 255, .06);--sidebar-bg: #080910;--sidebar-ink: #e7e9f1;--sidebar-muted: #8b91a6;--sidebar-active-bg: rgba(124, 130, 246, .22);--sidebar-active-ink: #c9ccff;--sidebar-hover: rgba(255, 255, 255, .05);--sidebar-line: rgba(255, 255, 255, .08);--sidebar-card: rgba(255, 255, 255, .04);--sidebar-border: rgba(255, 255, 255, .08);--sidebar-sub: #8b91a6;--sidebar-nav-hover: rgba(255, 255, 255, .05);--sidebar-nav-active-bg: rgba(124, 130, 246, .22);--sidebar-nav-active-border: rgba(124, 130, 246, .3);--sidebar-nav-active-color: #c9ccff;--sidebar-nav-active-shadow: inset 3px 0 0 #7c82f6}*{box-sizing:border-box}body{margin:0;color:var(--ink);background:var(--body-bg);font-family:var(--font-ui);background-attachment:fixed;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;letter-spacing:-.005em}button,input,select{font:inherit}button{min-height:40px;border:1px solid var(--line);border-radius:var(--radius);background:var(--control);color:var(--ink);padding:0 16px;cursor:pointer;touch-action:manipulation;font-weight:600;letter-spacing:-.01em;-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);position:relative;overflow:hidden;transition:border-color .2s ease,color .2s ease,transform .15s cubic-bezier(.34,1.56,.64,1),box-shadow .2s ease;isolation:isolate}button:before{content:"";position:absolute;inset:0;background:color-mix(in srgb,var(--green) 14%,transparent);border-radius:50%;transform:scale(0) translate(var(--lx, 0),var(--ly, 0));transform-origin:center;transition:transform .5s cubic-bezier(.22,1,.36,1),border-radius .5s cubic-bezier(.22,1,.36,1),opacity .3s ease;opacity:0;z-index:-1}button:hover:not(:disabled):before{transform:scale(2.8) translate(var(--lx, 0),var(--ly, 0));border-radius:40%;opacity:1}button:active:not(:disabled):before{transform:scale(3.5) translate(var(--lx, 0),var(--ly, 0));border-radius:30%;transition-duration:.18s}button.primary,.primary{background:linear-gradient(160deg,var(--green) 0%,var(--green-dark) 100%);border-color:var(--green-dark);color:#fff;font-weight:700;box-shadow:0 4px 16px #4d54d447,0 1px 3px #4d54d433}button.primary:before,.primary:before{background:#ffffff2e}button:hover:not(:disabled){border-color:color-mix(in srgb,var(--line) 48%,var(--green));box-shadow:0 10px 28px #00000024;transform:translateY(-2px)}button.primary:hover:not(:disabled),.primary:hover:not(:disabled){background:var(--green-dark);border-color:var(--green-dark)}button:active:not(:disabled){transform:translateY(0) scale(.97);box-shadow:0 3px 10px #0000001a}button:disabled{cursor:not-allowed;opacity:.55;box-shadow:none}.auth-screen{min-height:100dvh;display:grid;place-items:center;padding:20px;background:var(--body-bg)}.auth-panel{width:min(460px,100%);display:grid;gap:18px;background:var(--panel-elevated);border:1px solid var(--line);border-radius:var(--radius-lg);padding:32px;box-shadow:var(--shadow-strong);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur)}.auth-panel.wide{width:min(580px,100%)}.auth-logo{width:220px;max-width:100%;height:70px;object-fit:contain;justify-self:center}.auth-panel h1,.topbar h1{margin:0;font-size:26px;line-height:1.15}.auth-panel p,.topbar p,.status-card p{color:var(--muted);margin:6px 0 0}.auth-ghost-link{margin-top:14px;background:none;border:none;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;color:var(--muted);font-size:13px;font-weight:600;text-decoration:underline;text-underline-offset:3px;cursor:pointer;min-height:auto;padding:4px 8px}.auth-ghost-link:hover{color:var(--ink)}.google-btn{width:100%;justify-content:center;display:inline-flex;align-items:center;gap:10px;font-weight:700}.secondary-btn{background:transparent;color:var(--muted);box-shadow:none}.google-dot{width:18px;height:18px;border-radius:50%;background:conic-gradient(#4285f4 0 25%,#34a853 0 50%,#fbbc05 0 75%,#ea4335 0)}.google-g{display:inline-grid;place-items:center;width:22px;height:22px;font-family:Arial,sans-serif;font-size:20px;font-weight:800;line-height:1;background:conic-gradient(from -35deg,#4285f4 0 28%,#34a853 28% 45%,#fbbc05 45% 65%,#ea4335 65% 82%,#4285f4 82% 100%);-webkit-background-clip:text;background-clip:text;color:transparent}.preference-controls{display:grid;gap:8px;margin-top:auto;padding:12px;border:1px solid var(--line);border-radius:8px;background:color-mix(in srgb,var(--panel) 72%,transparent);box-shadow:0 1px #ffffff14 inset;-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur)}.preference-controls strong{font-size:12px;color:var(--ink);white-space:nowrap}.preference-controls label{display:grid;gap:4px;font-size:11px;color:var(--muted)}.preference-controls select{width:100%;min-height:34px;padding:6px 30px 6px 9px;font-size:13px}.error-box{position:fixed;top:50%;left:50%;z-index:20;width:min(560px,calc(100vw - 32px));border:1px solid #f3b8b1;border-radius:8px;background:#fde8e5;color:#9f1f16;padding:22px 24px;font-size:18px;line-height:1.45;box-shadow:var(--shadow-strong);animation:popup-in .18s ease-out,popup-out .22s ease-in 4.2s forwards;transform:translate(-50%,-50%)}form{display:grid;gap:12px}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}label{display:grid;gap:6px;color:var(--muted);font-size:13px}input,select,textarea{min-height:40px;border:1px solid var(--line);border-radius:var(--radius-sm);padding:8px 12px;width:100%;min-width:0;max-width:100%;box-sizing:border-box;background:var(--control);color:var(--ink);transition:border-color .16s ease,box-shadow .16s ease,background .16s ease;-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur)}input[type=date],input[type=month],input[type=time]{-webkit-appearance:none;appearance:none;min-width:0;max-width:100%}input::placeholder,textarea::placeholder{color:color-mix(in srgb,var(--muted) 76%,transparent)}input:focus,select:focus,textarea:focus{outline:0;border-color:var(--green);box-shadow:0 0 0 4px var(--focus)}textarea{resize:vertical}input[readonly]{background:var(--panel-subtle)}input[type=checkbox]{width:18px;min-width:18px;min-height:18px;padding:0}.app-shell{min-height:100dvh;display:flex;flex-direction:column;overflow-x:hidden;background:var(--app-bg)}.app-content-col{display:flex;flex-direction:column;flex:1;min-width:0;overflow:hidden}aside{display:none}.sidebar{display:none;flex-direction:column;width:var(--sidebar-w);flex-shrink:0;min-height:100dvh;position:sticky;top:0;height:100dvh;overflow-y:auto;background:var(--sidebar-bg);border-right:1px solid var(--sidebar-line);gap:18px;padding:22px 16px}.sidebar-brand{padding:8px 8px 4px;display:flex;align-items:center;gap:12px}.sidebar-logo-mark{flex-shrink:0}.sidebar-logo-text{display:flex;flex-direction:column;gap:2px;line-height:1}.sidebar-logo-name{font-size:16px;font-weight:800;letter-spacing:.24em;background:linear-gradient(110deg,var(--sidebar-ink) 0%,var(--sidebar-ink) 38%,var(--accent) 50%,var(--sidebar-ink) 62%,var(--sidebar-ink) 100%);background-size:240% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:rmShine 5s linear infinite}.sidebar-logo-sub{font-size:8px;font-weight:700;letter-spacing:.42em;color:var(--sidebar-muted);text-transform:uppercase}.sidebar-user{display:grid;gap:3px;padding:13px 14px;border:1px solid var(--sidebar-line);border-radius:var(--radius-sm);background:var(--sidebar-card)}.sidebar-user strong{font-size:15px;color:var(--sidebar-ink);font-weight:700}.sidebar-user span{font-size:12px;color:var(--sidebar-muted)}.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:6px}.sidebar-nav-item{display:flex;align-items:center;gap:11px;width:100%;padding:0 13px;height:42px;border:1px solid transparent;border-radius:var(--radius-sm);background:transparent;color:var(--sidebar-muted);font-size:13.5px;font-weight:600;text-align:left;cursor:pointer;min-height:unset;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;letter-spacing:.005em;transition:background .15s ease,color .15s ease}.sidebar-nav-item:before{display:none}.sidebar-nav-item:hover:not(:disabled){background:var(--sidebar-hover);color:var(--sidebar-ink);transform:none;box-shadow:none}.sidebar-nav-item.active{background:var(--sidebar-active-bg);color:var(--sidebar-active-ink);font-weight:700;box-shadow:inset 3px 0 0 var(--accent)}.sidebar-nav-item.active:hover:not(:disabled){background:var(--sidebar-active-bg);color:var(--sidebar-active-ink)}.sidebar-nav-icon{display:flex;align-items:center;flex-shrink:0}.sidebar-footer{margin-top:auto;display:flex;flex-direction:column;gap:2px}.sidebar-footer-btn{display:flex;align-items:center;gap:8px;width:100%;height:38px;padding:0 13px;border:1px solid var(--sidebar-line);border-radius:var(--radius-sm);background:transparent;color:var(--sidebar-muted);font-size:12.5px;font-weight:600;text-align:left;cursor:pointer;min-height:unset;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;transition:color .15s ease,border-color .15s ease}.sidebar-footer-btn:before{display:none}.sidebar-footer-btn+.sidebar-footer-btn{border-top:none}.sidebar-footer-btn:hover:not(:disabled){color:var(--sidebar-ink);border-color:var(--sidebar-ink);transform:none;box-shadow:none}.sidebar-footer-btn.danger:hover:not(:disabled){color:var(--red);border-color:var(--red)}.app-topbar{display:none;align-items:center;gap:16px;padding:0 28px;height:56px;flex-shrink:0;border-bottom:1px solid var(--line);background:var(--surface);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur)}.app-topbar-kicker{flex:1;font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--accent)}.app-topbar-user{display:inline-flex;align-items:center;gap:10px;padding:7px 14px;border:1px solid var(--line);border-radius:999px;background:var(--surface-2);font-size:13px;color:var(--muted);white-space:nowrap}.app-topbar-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);flex-shrink:0}.app-topbar-divider{width:1px;height:16px;background:var(--line)}.app-topbar-logout{display:inline-flex;align-items:center;cursor:pointer;color:var(--muted);background:none;border:none;padding:0;min-height:unset;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;transition:color .15s}.app-topbar-logout:before{display:none}.app-topbar-logout:hover{color:var(--ink);transform:none;box-shadow:none}.app-header{flex:none;height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 18px;border-bottom:1px solid var(--line);background:var(--surface);backdrop-filter:blur(16px) saturate(1.6);-webkit-backdrop-filter:blur(16px) saturate(1.6);position:sticky;top:0;z-index:12}.app-header-titles{display:flex;flex-direction:column;gap:1px;line-height:1.05}.app-header-title{font-family:var(--font-display);font-size:18px;font-weight:800;letter-spacing:-.01em;color:var(--ink)}.app-header-kicker{font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--accent)}.app-user-avatar{width:38px;height:38px;border-radius:50%;background:var(--accent-soft);border:1px solid var(--line);color:var(--accent);font-family:var(--font-display);font-size:15px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;cursor:default}.app-main{flex:1;padding:16px 18px calc(84px + env(safe-area-inset-bottom,20px));min-width:0}.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:15;display:flex;align-items:stretch;height:calc(84px + env(safe-area-inset-bottom,0px));padding:8px 8px calc(20px + env(safe-area-inset-bottom,0px));border-top:1px solid var(--line);background:var(--surface);backdrop-filter:blur(20px) saturate(1.7);-webkit-backdrop-filter:blur(20px) saturate(1.7)}.bottom-nav-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;border:none;background:transparent;color:var(--muted);font-size:10px;font-weight:700;letter-spacing:.01em;cursor:pointer;transition:color .15s ease;padding:0;min-height:unset;-webkit-backdrop-filter:none;backdrop-filter:none;box-shadow:none}.bottom-nav-tab:before{display:none}.bottom-nav-tab:hover:not(:disabled){color:var(--accent);background:transparent;transform:none;box-shadow:none}.bottom-nav-tab.active,.bottom-nav-tab.more-open{color:var(--accent)}.bottom-nav-tab span{display:block;line-height:1}.more-overlay{position:fixed;inset:0;z-index:16;background:#05121870;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);animation:fade-in .22s ease}.more-sheet{position:fixed;bottom:0;left:0;right:0;z-index:17;background:#fff;border-radius:24px 24px 0 0;padding:8px 20px calc(92px + env(safe-area-inset-bottom,0px));display:flex;flex-direction:column;gap:4px;box-shadow:0 -4px 32px #0000001f;animation:sheet-up .28s cubic-bezier(.32,0,.66,1);max-height:80dvh;overflow-y:auto}@keyframes sheet-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.more-sheet-handle{width:36px;height:4px;background:#0000001f;border-radius:2px;align-self:center;margin-bottom:12px;flex-shrink:0}.more-sheet-user{display:flex;align-items:center;gap:12px;padding:12px 4px 16px;border-bottom:1px solid rgba(0,0,0,.06);margin-bottom:8px}.more-sheet-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#0d6b54,#0a5040);color:#fff;font-size:18px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 20px #0d6b5452}.more-sheet-user strong{display:block;font-size:15px;font-weight:700;color:#111}.more-sheet-user span{display:block;font-size:12px;color:#6b7280;margin-top:2px}.more-sheet-tabs,.more-sheet-actions{display:flex;flex-direction:column;gap:2px}.more-sheet-prefs{padding:4px 0;border-top:1px solid rgba(0,0,0,.06);border-bottom:1px solid rgba(0,0,0,.06);margin:4px 0}.more-sheet-item{display:flex;align-items:center;gap:14px;width:100%;min-height:52px;padding:0 12px;background:transparent;border:none;border-radius:16px;color:#111;font-size:15px;font-weight:600;text-align:left;cursor:pointer;transition:background .16s ease;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}.more-sheet-item:before{display:none}.more-sheet-item:hover:not(:disabled){background:#0d6b5412;transform:none;box-shadow:none}.more-sheet-item.active{background:#0d6b5417;color:#0d6b54}.more-sheet-item.danger{color:#ef4444}.more-sheet-item.danger:hover:not(:disabled){background:#ef444414}.more-sheet-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;background:#0d6b5417;color:#0d6b54;flex-shrink:0}.more-sheet-item.danger .more-sheet-icon{background:#ef444414;color:#ef4444}.brand-logo{width:100%;max-width:100%;height:54px;object-fit:contain;background:#ffffffeb;border-radius:var(--radius-sm);padding:10px 16px;box-shadow:0 0 0 1px #0000000f,0 4px 14px #0000001a}.sidebar-user{display:grid;gap:4px;border:1px solid color-mix(in srgb,var(--sidebar-border) 120%,transparent);border-radius:var(--radius-sm);padding:12px 14px;background:color-mix(in srgb,var(--sidebar-ink) 7%,transparent);box-shadow:inset 0 1px color-mix(in srgb,var(--sidebar-ink) 10%,transparent),0 4px 12px #00000014;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.sidebar-user strong{color:var(--sidebar-ink);font-size:16px;line-height:1.25;overflow-wrap:anywhere}.sidebar-user span{color:var(--sidebar-sub);font-size:12px}nav{display:grid;gap:7px}nav button{color:var(--sidebar-sub);background:transparent;text-align:left;border-color:transparent;min-height:40px;font-size:13.5px;padding:0 14px;border-radius:var(--radius-sm);-webkit-backdrop-filter:none;backdrop-filter:none}nav button.active{background:var(--sidebar-nav-active-bg);border-color:var(--sidebar-nav-active-border);color:var(--sidebar-nav-active-color);box-shadow:var(--sidebar-nav-active-shadow);font-weight:700}nav button:hover:not(.active){background:var(--sidebar-nav-hover);border-color:color-mix(in srgb,var(--sidebar-border) 80%,transparent);color:var(--sidebar-ink);box-shadow:none}main{padding:24px;min-width:0}.topbar{display:none}.topbar h1{font-size:30px;letter-spacing:0}.topbar p,.status-grid{display:none}.topbar-actions{display:inline-flex;align-items:center;justify-content:flex-end;gap:10px;min-width:0}.ghost-btn{min-height:40px;background:linear-gradient(180deg,color-mix(in srgb,var(--control) 92%,white 8%),var(--control));color:var(--text);border-color:color-mix(in srgb,var(--line) 82%,transparent);white-space:nowrap}.user-chip{display:inline-flex;align-items:center;gap:8px;background:var(--control);border:1px solid var(--line);border-radius:8px;min-height:40px;padding:0 12px;color:var(--muted);box-shadow:0 10px 26px #0000001a;-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur)}.user-chip button{width:32px;min-height:32px;padding:0}.status-grid{display:grid;grid-template-columns:repeat(4,minmax(160px,1fr));gap:14px}.status-grid{display:none}.status-card,.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur)}.status-card span{color:var(--muted);font-size:12px}.status-card h2,.panel h2{margin:4px 0 8px;font-size:20px;letter-spacing:0}.panel{margin-top:0;min-height:60dvh;min-width:0;overflow:hidden;background:transparent;border:none;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;padding:0}.bootstrap-box{border:1px solid color-mix(in srgb,var(--green) 34%,var(--line));border-radius:8px;background:color-mix(in srgb,var(--green) 10%,var(--panel));padding:14px;margin-bottom:16px}.status-message{position:fixed;top:50%;left:50%;z-index:20;width:min(560px,calc(100vw - 32px));border:1px solid color-mix(in srgb,var(--green) 38%,var(--line));border-radius:8px;background:color-mix(in srgb,var(--panel) 86%,#e7fff5);color:var(--green);padding:22px 24px;font-size:18px;line-height:1.45;margin:0;box-shadow:var(--shadow-strong);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);cursor:pointer;-webkit-user-select:none;user-select:none;animation:popup-in .18s ease-out,popup-out .22s ease-in 4.2s forwards;transform:translate(-50%,-50%)}.install-prompt{position:fixed;inset:0;z-index:30;display:grid;place-items:center;padding:18px;background:#071b2085;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.install-prompt-card{position:relative;width:min(420px,100%);display:grid;gap:14px;background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:22px;box-shadow:var(--shadow-strong);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur)}.install-prompt-icon{width:68px;height:68px;border-radius:16px;box-shadow:0 10px 24px #13222a29}.install-prompt-card h2{margin:0;font-size:22px}.install-prompt-card p{margin:6px 0 0;color:var(--muted);line-height:1.45}.install-prompt-card ol{margin:0;padding-left:22px;display:grid;gap:8px;color:var(--ink)}.install-prompt-close{position:absolute;top:10px;right:10px;width:34px;min-height:34px;padding:0;font-size:22px;line-height:1;color:var(--muted);background:transparent;border-color:transparent;box-shadow:none}.install-prompt-close:hover:not(:disabled){box-shadow:none}@keyframes popup-in{0%{opacity:0;transform:translate(-50%,calc(-50% - 8px))}to{opacity:1;transform:translate(-50%,-50%)}}@keyframes popup-out{to{opacity:0;transform:translate(-50%,calc(-50% - 8px));visibility:hidden}}.hint{color:var(--muted);font-size:13px;margin:4px 0}.check-label{display:flex;align-items:center;gap:8px;cursor:pointer;color:var(--ink);font-size:13px}.confirm-delete-row{display:inline-flex;align-items:center;gap:6px}.loading-row td{color:var(--muted);font-style:italic}.panel li{margin:8px 0}.stack{display:grid;gap:18px;min-width:0}.section-head{display:flex;justify-content:space-between;align-items:start;gap:12px}.section-head h2,.section-head h3,.subpanel h3{margin:0 0 6px;letter-spacing:0}.section-head p{margin:0;color:var(--muted)}.data-form,.subpanel,.rate-card{border:1px solid var(--line);border-radius:var(--radius);background:var(--panel-subtle);padding:18px;box-shadow:0 1px #ffffff24 inset,0 8px 24px #0000000d;-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);min-width:0}.card-edit-cell{padding:6px 0}.card-edit-form{width:100%;border-color:color-mix(in srgb,var(--accent) 38%,var(--line));box-shadow:0 1px #ffffff24 inset,0 10px 28px #14162d1a}.card-edit-form h3{margin:0 0 4px}.cam-icon-btn{width:44px;min-width:44px;height:44px;min-height:44px;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--ink)}.subpanel{scroll-margin-top:96px}.form-grid.compact{grid-template-columns:repeat(3,minmax(160px,1fr))}.button-row,.actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.button-row.align-end{align-items:end;align-self:end}.uid-list{display:grid;gap:8px;margin-top:10px}.uid-list-head,.uid-row{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center}.uid-list-head span{color:var(--muted);font-size:12px;font-weight:700}.uid-row input{width:100%}.table-wrap{width:100%;max-width:100%;overflow-x:auto;border-radius:var(--radius);scroll-behavior:smooth;-webkit-overflow-scrolling:touch;border:1px solid var(--line);background:color-mix(in srgb,var(--control) 88%,transparent);overscroll-behavior-x:contain;-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);box-shadow:var(--shadow-card)}table{width:100%;border-collapse:collapse;min-width:760px}th,td{border-bottom:1px solid color-mix(in srgb,var(--line) 76%,transparent);padding:12px 10px;text-align:left;vertical-align:middle}th{color:var(--muted);font-size:12px;font-weight:700;position:sticky;top:0;z-index:1;background:var(--table-head);text-transform:none;-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur)}tbody tr{transition:background .14s ease}tbody tr:hover{background:var(--row-hover)}.clock-status{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:var(--radius);border:1px solid var(--line);margin-bottom:12px}.clock-status.on{background:color-mix(in srgb,var(--green) 14%,transparent);border-color:color-mix(in srgb,var(--green) 45%,var(--line))}.clock-status.off{background:color-mix(in srgb,var(--control) 70%,transparent)}.clock-status-dot{width:12px;height:12px;border-radius:50%;flex:0 0 auto;background:var(--muted)}.clock-status.on .clock-status-dot{background:var(--green);box-shadow:0 0 0 4px color-mix(in srgb,var(--green) 25%,transparent)}.clock-status strong{display:block;font-size:15px}.clock-status span{display:block;color:var(--muted);font-size:12px;margin-top:2px}.camera-box{display:flex;flex-direction:column;gap:10px;margin-top:4px}.camera-preview,.camera-placeholder{width:100%;max-width:420px;aspect-ratio:3 / 4;border-radius:var(--radius)}.camera-preview{object-fit:cover;background:#000;border:1px solid var(--line)}.camera-preview.mirror{transform:scaleX(-1)}.camera-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;border:1px dashed color-mix(in srgb,var(--line) 80%,var(--muted));background:color-mix(in srgb,var(--control) 60%,transparent);color:var(--muted);text-align:center}.camera-placeholder span{font-size:15px;font-weight:600}.camera-placeholder small{font-size:12px;max-width:240px}.error-text{color:var(--danger-text);font-size:13px;margin:0}.sidebar-refresh-btn{width:100%;background:transparent;border:1px solid var(--line);color:var(--muted);border-radius:var(--radius);min-height:36px;font-size:13px;cursor:pointer;transition:color .14s ease,border-color .14s ease}.sidebar-refresh-btn:hover{color:var(--text);border-color:var(--muted)}.inline-loading{color:var(--muted);animation:rml-pulse 1s ease-in-out infinite}@keyframes rml-pulse{0%,to{opacity:.45}50%{opacity:1}}details.collapsible{border:1px solid var(--line);border-radius:var(--radius);background:color-mix(in srgb,var(--control) 70%,transparent);padding:2px 14px}details.collapsible>summary{cursor:pointer;font-weight:700;font-size:15px;padding:11px 0;list-style:none;display:flex;align-items:center;justify-content:space-between}details.collapsible>summary::-webkit-details-marker{display:none}details.collapsible>summary:after{content:"▾";color:var(--muted);font-size:12px}details.collapsible[open]>summary:after{content:"▴"}details.collapsible[open]{padding-bottom:14px}.form-section-title{margin:0 0 2px;font-size:13px;font-weight:700;color:var(--muted)}td input{min-width:180px}.batch-table td input,.batch-table td select{min-width:140px}.batch-table td:nth-child(2) input,.batch-table td:nth-child(7) input{min-width:220px}.batch-table .actions{min-width:132px}.sheet-sync{display:grid;gap:10px;margin:12px 0}button.danger{border-color:#f1b2aa;color:var(--danger-text);background:var(--danger-bg)}button.danger:hover:not(:disabled){border-color:#e2857a;background:color-mix(in srgb,var(--danger-bg) 82%,#fff)}.tier-grid{display:grid;gap:10px;margin-top:12px}.tier-row{display:grid;grid-template-columns:repeat(2,minmax(140px,1fr));gap:10px}.month-input{max-width:180px}.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(130px,1fr));gap:10px;overflow-x:auto;max-width:100%;overscroll-behavior-x:contain}.calendar-head,.calendar-cell{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--control);min-height:42px;padding:10px;-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur)}.calendar-head{color:var(--muted);font-size:12px;font-weight:700;min-height:auto;background:transparent;border-color:transparent}.calendar-cell{display:grid;align-content:start;gap:6px;min-height:112px;box-shadow:0 8px 22px #00000014}.calendar-cell.blank{background:color-mix(in srgb,var(--control) 62%,var(--body-bg));border-color:color-mix(in srgb,var(--line) 72%,transparent);box-shadow:none;opacity:.62}.calendar-shift{display:block;border-radius:6px;background:color-mix(in srgb,var(--green) 16%,var(--control));border:1px solid color-mix(in srgb,var(--green) 28%,var(--line));color:var(--green);padding:5px 6px;font-size:12px;line-height:1.3;transition:background .16s ease,border-color .16s ease,transform .12s ease}.calendar-shift:hover{background:color-mix(in srgb,var(--green) 22%,var(--control));border-color:color-mix(in srgb,var(--green) 48%,var(--line));transform:translateY(-1px)}.calendar-shift strong,.calendar-shift span{display:block}.calendar-shift span{margin-top:3px;color:color-mix(in srgb,var(--green) 58%,var(--ink))}.week-calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(160px,1fr));gap:10px;overflow-x:auto;max-width:100%;overscroll-behavior-x:contain}.week-calendar-day{border:1px solid var(--line);border-radius:8px;background:var(--control);min-height:220px;padding:10px;display:grid;align-content:start;gap:8px;box-shadow:0 8px 20px #13222a0a}.week-day-head{border-bottom:1px solid var(--line);padding-bottom:8px;display:grid;gap:3px}.week-day-head span{color:var(--muted);font-size:12px}.segmented-control{display:inline-flex;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--control);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);padding:3px;gap:2px}.segmented-control button{border-radius:var(--radius-sm)!important}.segmented-control button{border:0;border-radius:0;min-height:38px}.segmented-control button.active{background:var(--green);color:#fff;font-weight:700}.metric-grid{display:grid;grid-template-columns:repeat(5,minmax(120px,1fr));gap:14px}.metric-grid article{border:1px solid var(--line);border-radius:var(--radius);background:var(--panel-elevated);padding:20px 22px;display:grid;gap:8px;box-shadow:var(--shadow-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);transition:transform .2s var(--transition-spring),box-shadow .2s ease;position:relative;overflow:hidden}.metric-grid article:after{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--green),color-mix(in srgb,var(--green) 40%,transparent));border-radius:var(--radius) var(--radius) 0 0}.metric-grid article:hover{transform:translateY(-2px);box-shadow:var(--shadow-card),0 12px 36px #00000014}.metric-grid span{color:var(--muted);font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.metric-grid strong{font-size:30px;letter-spacing:-.02em;font-weight:700}.project-tabs{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.project-tabs button{white-space:nowrap}.project-tabs button.active{background:var(--green);border-color:var(--green);color:#fff;font-weight:700;box-shadow:0 8px 18px #4d54d42e}.payroll-metrics{grid-template-columns:repeat(3,minmax(120px,1fr))}.status-pill{display:inline-flex;align-items:center;padding:3px 11px;border-radius:999px;font-size:12px;font-weight:700;line-height:1.5;white-space:nowrap;background:var(--neutral-soft);color:var(--muted)}.status-pill.ok{background:var(--ok-soft);color:var(--ok)}.status-pill.warn{background:var(--warn-soft);color:var(--warn)}.status-pill.danger{background:var(--danger-bg);color:var(--danger-text)}.status-pill.accent{background:var(--accent-soft);color:var(--accent)}.payroll-table{min-width:1180px}.cell-subtext{display:block;color:var(--muted);font-size:12px;margin-top:4px}button.checked-btn{background:color-mix(in srgb,var(--gold) 16%,var(--control));border-color:#efcf91;color:var(--ink);font-weight:700}.hamburger-btn{display:none;width:40px;min-height:40px;padding:0;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;border-radius:var(--radius-sm)}.drawer-overlay{display:none;position:fixed;inset:0;z-index:17;background:var(--sidebar-overlay);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.drawer-overlay.open{display:block;animation:fade-in .22s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@media(min-width:768px){.app-shell{flex-direction:row;align-items:stretch}.sidebar{display:flex}.app-header,.bottom-nav{display:none}.more-overlay,.more-sheet{display:none!important}.app-topbar{display:flex}.app-main{padding:28px}}@media(max-width:980px){.metric-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:640px){.preference-controls{display:grid;grid-template-columns:auto minmax(0,1fr) minmax(0,1fr);gap:8px;margin-top:0;padding:8px}.preference-controls strong{align-self:end;padding-bottom:9px;font-size:12px}.preference-controls label{min-width:0;font-size:10px}.preference-controls select{width:100%;min-height:32px;padding:5px 26px 5px 8px;font-size:12px}.auth-screen{align-items:start;padding:16px}.auth-panel{padding:18px}.form-grid,.status-grid,.metric-grid{grid-template-columns:1fr}.section-head{display:grid}.form-grid.compact,.tier-row{grid-template-columns:1fr}.calendar-grid,.week-calendar-grid{gap:8px;grid-template-columns:1fr;overflow-x:visible}.calendar-view-toggle,.calendar-head,.calendar-cell.blank{display:none}.calendar-cell,.week-calendar-day{min-height:auto}.calendar-cell>strong{font-size:15px}table{min-width:620px}th,td{padding:10px 8px}td input,.batch-table td input,.batch-table td select{min-width:120px}.actions,.button-row{gap:6px}.actions button,.button-row button{min-height:36px;padding:0 10px}.segmented-control button{min-height:36px}.data-form,.subpanel,.rate-card{padding:12px}.month-input{max-width:none}.table-wrap.cards{overflow-x:visible;border:none;background:transparent;box-shadow:none;padding:0;-webkit-backdrop-filter:none;backdrop-filter:none}.table-wrap.cards table{min-width:0;width:100%}.table-wrap.cards thead{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}.table-wrap.cards tbody tr{display:block;margin-bottom:12px;padding:4px 14px;border:1px solid var(--line);border-radius:var(--radius);background:color-mix(in srgb,var(--control) 88%,transparent);box-shadow:var(--shadow-card)}.table-wrap.cards tbody td{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:9px 0;text-align:right;border-bottom:1px solid color-mix(in srgb,var(--line) 55%,transparent)}.table-wrap.cards tbody td:last-child{border-bottom:none}.table-wrap.cards tbody td:before{content:attr(data-label);flex:0 0 auto;color:var(--muted);font-size:12px;font-weight:700;text-align:left}.table-wrap.cards tbody td.actions{justify-content:flex-end;flex-wrap:wrap}.table-wrap.cards tbody td.actions:before{content:""}.table-wrap.cards tbody td[colspan]{justify-content:center;text-align:center;color:var(--muted)}.table-wrap.cards tbody td[colspan]:before{content:""}.table-wrap.cards tbody td input,.table-wrap.cards tbody td select{min-width:0;flex:1 1 auto}.table-wrap.cards tbody tr.card-edit-row{padding:0;border:none;background:transparent;box-shadow:none;margin-bottom:12px}.table-wrap.cards tbody td.card-edit-cell{display:block;text-align:left;padding:0;border:none}.table-wrap.cards tbody td.card-edit-cell:before{content:"";display:none}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}}@keyframes loginFloatUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes loginTwinkle{0%,to{transform:scale(1);filter:drop-shadow(0 2px 8px rgba(40,20,90,.3)) brightness(1)}50%{transform:scale(1.05);filter:drop-shadow(0 0 14px rgba(255,255,255,.55)) brightness(1.15)}}@keyframes loginCoreGlow{0%,to{opacity:0;transform:scale(.6)}50%{opacity:.9;transform:scale(1)}}@keyframes loginDrift{0%{transform:translate(0)}50%{transform:translate(20px,-26px)}to{transform:translate(0)}}@keyframes loginShimmer{0%{transform:translate(-180%)}to{transform:translate(180%)}}@keyframes loginBlobA{0%{transform:translate(-12%,8%) scale(1)}33%{transform:translate(38%,-14%) scale(1.25)}66%{transform:translate(70%,18%) scale(.95)}to{transform:translate(-12%,8%) scale(1)}}@keyframes loginBlobB{0%{transform:translate(60%,-10%) scale(1.1)}33%{transform:translate(20%,22%) scale(.9)}66%{transform:translate(-15%,-18%) scale(1.3)}to{transform:translate(60%,-10%) scale(1.1)}}@keyframes loginBlobC{0%{transform:translate(30%,30%) scale(.9)}50%{transform:translate(45%,-10%) scale(1.2)}to{transform:translate(30%,30%) scale(.9)}}.login-root{min-height:100vh;width:100%;display:flex;background:#0b1220;font-family:Manrope,Inter,system-ui,sans-serif;overflow:hidden}.login-brand{position:relative;flex:1.15;min-width:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:64px 72px;background:linear-gradient(155deg,#141e36,#0e1729 48%,#0b1220);overflow:hidden;gap:0}.login-glow{position:absolute;border-radius:50%;pointer-events:none}.login-glow-tl{top:-180px;left:-140px;width:540px;height:540px;background:radial-gradient(circle,#6366f152,#6366f100 70%);animation:loginDrift 16s ease-in-out infinite}.login-glow-br{bottom:-160px;right:-80px;width:460px;height:460px;background:radial-gradient(circle,#38bdf833,#38bdf800 70%);animation:loginDrift 20s ease-in-out infinite reverse}.login-brand-top{position:relative;display:flex;flex-direction:column;align-items:center;gap:20px;margin-bottom:52px}.login-logo-tile{position:relative;width:112px;height:112px;border-radius:30px;background:linear-gradient(140deg,#6366f1,#8b5cf6 58%,#38bdf8);box-shadow:0 16px 42px -10px #6366f1b3,inset 0 1px #ffffff4d;flex-shrink:0}.login-logo-core{position:absolute;inset:20px;border-radius:50%;background:radial-gradient(circle,#ffffff80,#fff0 70%);animation:loginCoreGlow 2.8s ease-in-out infinite}.login-logo-rm{position:absolute;bottom:13px;right:15px;font-family:Manrope,sans-serif;font-weight:800;font-size:17px;letter-spacing:-.05em;color:#fff;text-shadow:0 1px 3px rgba(40,20,90,.5)}.login-wordmark{color:#fff;font-size:38px;font-weight:800;letter-spacing:-.02em;line-height:1;text-align:center}.login-submark{color:#aab4d4;font-size:13px;font-weight:700;letter-spacing:.32em;text-transform:uppercase;margin-top:9px;text-align:center}.login-badge{display:inline-flex;align-items:center;gap:9px;padding:7px 14px;border:1px solid rgba(255,255,255,.12);border-radius:999px;background:#ffffff0a;margin-bottom:28px;color:#c3cbe2;font-size:12px;font-weight:600;letter-spacing:.02em}.login-badge-dot{width:7px;height:7px;border-radius:50%;background:#4ade80;box-shadow:0 0 8px #4ade80;flex-shrink:0}.login-headline{margin:0;color:#fff;font-size:52px;font-weight:800;letter-spacing:-.03em;line-height:1.08;text-align:center}.login-sub{margin:24px 0 0;color:#8b97b3;font-size:17px;font-weight:500;line-height:1.6;max-width:440px;text-align:center}.login-footer{position:absolute;bottom:40px;left:50%;transform:translate(-50%);white-space:nowrap;margin:0;color:#4f5a7e;font-size:13px;font-weight:500}.login-form-panel{flex:.85;min-width:440px;display:flex;align-items:center;justify-content:center;padding:48px;background:#0b1220;position:relative}.login-lang-toggle{position:absolute;top:28px;right:32px;display:flex;align-items:center;gap:7px;padding:7px 14px;border:1px solid rgba(255,255,255,.14);background:#ffffff0d;color:#9aa4c4;font-family:Manrope,Inter,sans-serif;font-size:13px;font-weight:600;border-radius:999px;cursor:pointer;transition:background .16s}.login-lang-toggle:hover{background:#ffffff1a}.login-card{width:100%;max-width:380px}.login-welcome{margin:0;color:#fff;font-size:28px;font-weight:800;letter-spacing:-.02em}.login-welcome-sub{margin:10px 0 0;color:#8b97b3;font-size:15px;font-weight:500}.login-error{margin-top:16px;padding:12px 14px;background:#ef44441f;border:1px solid rgba(239,68,68,.28);border-radius:12px;color:#fca5a5;font-size:13px;font-weight:500;line-height:1.5}.login-google-btn{position:relative;width:100%;height:58px;border:none;padding:0;border-radius:18px;cursor:pointer;overflow:hidden;background:linear-gradient(135deg,#4f46e5,#6d28d9,#0ea5e9);box-shadow:0 16px 40px -12px #4f46e5b3,inset 0 1px #ffffff40;transition:transform .2s cubic-bezier(.34,1.56,.64,1),box-shadow .2s;font-family:Manrope,Inter,sans-serif}.login-google-btn:hover{transform:translateY(-1px);box-shadow:0 20px 48px -12px #4f46e5d9,inset 0 1px #ffffff40}.login-google-btn:active{transform:translateY(1px) scale(.995)}.login-google-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-blob{position:absolute;inset:0;filter:blur(16px);opacity:.9;pointer-events:none;border-radius:50%}.login-blob-a{top:-40%;left:-10%;width:60%;height:180%;background:#38bdf8;animation:loginBlobA 7s ease-in-out infinite}.login-blob-b{top:-40%;left:10%;width:55%;height:180%;background:#a855f7;animation:loginBlobB 9s ease-in-out infinite}.login-blob-c{top:-30%;left:30%;width:45%;height:160%;background:#6366f1;animation:loginBlobC 6s ease-in-out infinite}.login-btn-gloss{position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,#ffffff59,#fff0);pointer-events:none}.login-btn-shimmer{position:absolute;top:0;bottom:0;width:45%;background:linear-gradient(105deg,transparent,rgba(255,255,255,.45),transparent);animation:loginShimmer 4.5s ease-in-out infinite;pointer-events:none}.login-btn-content{position:relative;z-index:2;display:flex;align-items:center;justify-content:center;gap:12px;height:100%;transition:transform .2s cubic-bezier(.34,1.56,.64,1)}.login-google-btn:active .login-btn-content{transform:scale(.98)}.login-google-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:#fff;box-shadow:0 2px 6px #0003;flex-shrink:0}.login-btn-label{color:#fff;font-size:16px;font-weight:700;letter-spacing:.01em;text-shadow:0 1px 8px rgba(0,0,0,.25)}.login-divider{display:flex;align-items:center;gap:14px;margin:24px 0}.login-divider-line{flex:1;height:1px;background:#ffffff1a}.login-divider-text{color:#56618a;font-size:12px;font-weight:600;white-space:nowrap}.login-label{display:block;color:#8b97b3;font-size:13px;font-weight:600;margin-bottom:8px}.login-forgot{color:#8b8ff5;font-weight:600;cursor:pointer;font-size:13px;background:none;border:none;padding:0;font-family:inherit}.login-forgot:hover{color:#a5b4fc}.login-forgot:disabled{opacity:.55;cursor:default}.login-notice{margin-top:16px;padding:12px 14px;background:#34a8531f;border:1px solid rgba(52,168,83,.3);border-radius:12px;color:#6ee7a8;font-size:13px;font-weight:500;line-height:1.5}.login-email-btn{width:100%;height:54px;margin-top:22px;display:flex;align-items:center;justify-content:center;gap:8px;border:1px solid rgba(255,255,255,.14);background:#ffffff0d;color:#fff;font-family:Manrope,Inter,sans-serif;font-size:15px;font-weight:700;border-radius:16px;cursor:pointer;transition:background .18s,transform .12s}.login-email-btn:hover:not(:disabled){background:#ffffff1a}.login-email-btn:active:not(:disabled){transform:scale(.99)}.login-email-btn:disabled{opacity:.4;cursor:not-allowed}.login-redirect-btn{display:block;width:100%;margin-top:12px;padding:10px;background:transparent;border:none;color:#4f5a7e;font-family:Manrope,Inter,sans-serif;font-size:12px;font-weight:500;text-align:center;cursor:pointer;transition:color .16s}.login-redirect-btn:hover:not(:disabled){color:#8b97b3}.login-terms{margin:28px 0 0;text-align:center;color:#4f5a7e;font-size:12px;line-height:1.6}@media(max-width:860px){.login-brand{display:none}.login-form-panel{flex:1;min-width:0;padding:32px 24px;background:#0b1220}.login-lang-toggle{top:20px;right:20px}.login-headline{font-size:36px}}.shift-panel-grid{display:flex;flex-direction:column;gap:18px}.shift-form-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px;display:flex;flex-direction:column;gap:13px;-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur)}.shift-calendar-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;display:flex;flex-direction:column;gap:14px;-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur)}.shift-form-title{margin:0 0 2px;font-family:var(--font-display);font-size:16px;font-weight:800;color:var(--ink)}.sf-label{display:grid;gap:6px;font-size:12.5px;font-weight:600;color:var(--muted);min-width:0}.sf-label-text{font-size:12.5px;font-weight:600;color:var(--muted)}.sf-input{height:42px;padding:0 12px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);color:var(--ink);font:inherit;font-size:14px;min-width:0;width:100%;-webkit-backdrop-filter:none;backdrop-filter:none}.sf-mono{font-family:var(--font-mono)}.sf-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:12px}.sf-status-group{display:grid;gap:6px}.sf-segmented{display:inline-flex;padding:3px;gap:2px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface-2);align-self:start}.sf-segmented button{height:36px;padding:0 16px;border:0;border-radius:calc(var(--radius-sm) - 1px);background:transparent;color:var(--muted);font:inherit;font-size:13px;font-weight:600;cursor:pointer;transition:background .14s,color .14s}.sf-segmented button.active{background:var(--accent);color:var(--accent-ink);font-weight:700}.sf-submit{width:100%;display:inline-flex;align-items:center;justify-content:center;height:46px;padding:0 20px;border:1px solid var(--accent);border-radius:var(--radius-sm);background:var(--accent);color:var(--accent-ink);font:inherit;font-size:14px;font-weight:700;cursor:pointer;margin-top:4px;transition:opacity .15s}.sf-submit:hover{opacity:.91}.sf-cancel{width:100%;display:inline-flex;align-items:center;justify-content:center;height:40px;padding:0 20px;border:1px solid var(--line);border-radius:var(--radius-sm);background:transparent;color:var(--muted);font:inherit;font-size:13px;font-weight:600;cursor:pointer;transition:background .14s}.sf-cancel:hover{background:var(--surface-2)}@media(min-width:768px){.shift-panel-grid{display:grid;grid-template-columns:360px minmax(0,1fr);gap:18px;align-items:start}}@media(max-width:600px){.sf-row{grid-template-columns:1fr}}.mob-hub-header{display:none}@media(max-width:767px){.sidebar,.app-topbar,.bottom-nav{display:none!important}.app-shell{flex-direction:column;min-height:100dvh;overflow:visible}.app-content-col{flex:1;display:flex;flex-direction:column;min-height:0;overflow:visible}.app-main{flex:1;padding:0 0 env(safe-area-inset-bottom,20px)}.mob-hub-header{display:flex;align-items:center;justify-content:center;height:64px;padding:0 20px;border-bottom:1px solid var(--line);background:var(--surface);-webkit-backdrop-filter:blur(20px) saturate(1.6);backdrop-filter:blur(20px) saturate(1.6);flex-shrink:0;position:sticky;top:0;z-index:20}.mob-hub-logo{display:flex;align-items:center;gap:10px}.mob-hub-logo-text{display:flex;flex-direction:column;gap:1px;line-height:1}.mob-hub-logo-name{font-family:var(--font-display);font-size:16px;font-weight:800;letter-spacing:.24em;color:var(--ink)}.mob-hub-logo-sub{font-size:8px;font-weight:700;letter-spacing:.42em;color:var(--muted)}.mob-menu-btn{width:36px;height:36px;border-radius:50%;border:1px solid var(--line);background:var(--surface);color:var(--muted);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.mob-back-header{display:flex;align-items:center;gap:10px;height:56px;padding:0 16px;border-bottom:1px solid var(--line);background:var(--surface);-webkit-backdrop-filter:blur(20px) saturate(1.6);backdrop-filter:blur(20px) saturate(1.6);flex-shrink:0;position:sticky;top:0;z-index:20}.mob-back-btn{width:38px;height:38px;display:flex;align-items:center;justify-content:center;border:none;background:var(--accent);color:var(--accent-ink);cursor:pointer;border-radius:50%;flex-shrink:0;box-shadow:0 2px 8px #4d54d447;transition:filter .15s,transform .12s}.mob-back-btn:hover{filter:brightness(.93)}.mob-back-btn:active{transform:scale(.93)}.mob-screen-title{font-family:var(--font-display);font-size:17px;font-weight:800;color:var(--ink);letter-spacing:-.01em}.app-main .panel>.stack>.section-head:first-child>div:first-child{display:none}.app-main .panel>.stack>.section-head:first-child:not(:has(.button-row)){display:none}.app-main .panel{padding:16px 16px 96px}.mob-hub{padding:18px 16px 100px;display:flex;flex-direction:column;gap:20px}.mob-hero{border-radius:18px;background:linear-gradient(135deg,var(--accent) 0%,#7b5ea7 100%);padding:20px 20px 16px;display:flex;flex-direction:column;gap:16px;box-shadow:0 8px 28px #4d54d461}.mob-hero-top{display:flex;align-items:flex-start;justify-content:space-between}.mob-hero-text{display:flex;flex-direction:column;gap:4px}.mob-hero-kicker{font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:#ffffffb3}.mob-hero-status{font-family:var(--font-display);font-size:22px;font-weight:800;color:#fff;letter-spacing:-.01em}.mob-hero-icon-wrap{width:40px;height:40px;border-radius:12px;background:#ffffff2e;display:flex;align-items:center;justify-content:center;color:#ffffffe0;flex-shrink:0}.mob-hero-btn{position:relative;isolation:isolate;display:flex;align-items:center;justify-content:center;height:50px;border-radius:14px;background:#fff3;border:1px solid rgba(255,255,255,.42);color:#fff;font:inherit;font-size:15px;font-weight:800;cursor:pointer;padding:0 18px;overflow:hidden;-webkit-backdrop-filter:blur(10px) saturate(1.4);backdrop-filter:blur(10px) saturate(1.4);box-shadow:0 10px 26px #14162d38,inset 0 1px #ffffff80;transition:transform .15s var(--transition-spring),box-shadow .2s ease}.mob-hero-btn:active{transform:scale(.97)}.mob-hero-btn-label{position:relative;z-index:3;display:inline-flex;align-items:center;gap:8px}.mob-hero-btn .liq-blob{position:absolute;border-radius:50%;filter:blur(14px);opacity:.6;z-index:1;pointer-events:none}.mob-hero-btn .liq-blob-a{width:96px;height:96px;background:#ffffffe6;left:-12px;top:-46px;animation:liqA 7s ease-in-out infinite}.mob-hero-btn .liq-blob-b{width:74px;height:74px;background:#aac8ffd9;right:-8px;bottom:-40px;animation:liqB 8.5s ease-in-out infinite}.mob-hero-btn .liq-blob-c{width:64px;height:64px;background:#cdb9ffcc;left:42%;top:-34px;animation:liqC 6.5s ease-in-out infinite}.mob-hero-btn .liq-gloss{position:absolute;inset:0 0 52%;background:linear-gradient(180deg,rgba(255,255,255,.5),transparent);z-index:2;pointer-events:none}.mob-hero-btn .liq-shine{position:absolute;top:0;bottom:0;width:42%;left:-50%;background:linear-gradient(105deg,transparent,rgba(255,255,255,.6),transparent);transform:skew(-18deg);z-index:2;pointer-events:none;animation:liqShine 4.5s ease-in-out infinite}.mob-hero-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.mob-hero-metric{display:flex;flex-direction:column;gap:4px;padding:12px 10px;border-radius:15px;background:var(--panel-elevated);border:1px solid var(--line);box-shadow:var(--shadow-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur)}.mob-hero-metric span{font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}.mob-hero-metric strong{font-family:var(--font-mono);font-size:18px;font-weight:700;letter-spacing:-.02em;color:var(--ink)}.mob-personal-total{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-radius:16px;background:var(--accent-soft);border:1px solid color-mix(in srgb,var(--accent) 24%,transparent)}.mob-personal-total>span{display:flex;flex-direction:column;gap:2px;font-size:13px;font-weight:700;color:var(--ink)}.mob-personal-total>span small{font-size:11px;font-weight:600;color:var(--muted)}.mob-personal-total strong{font-family:var(--font-mono);font-size:22px;font-weight:700;letter-spacing:-.02em;color:var(--accent)}.mob-section-label{font-size:10px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);padding:0 2px}.mob-modules{display:grid;grid-template-columns:1fr 1fr;gap:12px}.mob-module-tile{display:flex;flex-direction:column;gap:10px;padding:16px 14px 14px;border-radius:16px;background:var(--panel-elevated);border:1px solid var(--line);box-shadow:var(--shadow-card);text-align:left;cursor:pointer;transition:box-shadow .15s,transform .12s}.mob-module-tile:hover{transform:translateY(-1px);box-shadow:var(--shadow-strong)}.mob-module-tile:active{transform:translateY(0)}.mob-module-icon{width:40px;height:40px;border-radius:11px;background:var(--accent-soft);border:1px solid rgba(77,84,212,.12);display:flex;align-items:center;justify-content:center;color:var(--accent)}.mob-module-info{display:flex;flex-direction:column;gap:2px}.mob-module-info strong{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--ink)}.mob-module-info span{font-size:11px;color:var(--muted);font-weight:500}.mob-signout-btn{margin-top:4px;height:44px;border-radius:12px;border:1px solid var(--line);background:var(--surface);color:var(--muted);font:inherit;font-size:14px;font-weight:600;cursor:pointer;transition:background .14s,color .14s}.mob-signout-btn:hover{background:var(--danger-bg);color:var(--danger-text)}.mob-refresh-btn{height:42px;border-radius:12px;border:1px solid var(--line);background:transparent;color:var(--muted);font:inherit;font-size:13px;font-weight:600;cursor:pointer;transition:color .14s,border-color .14s}.mob-refresh-btn:hover{color:var(--accent);border-color:var(--accent)}.mob-fab{position:fixed;right:20px;bottom:calc(24px + env(safe-area-inset-bottom,0px));display:flex;align-items:center;gap:8px;height:52px;padding:0 22px;border-radius:999px;background:var(--accent);color:var(--accent-ink);font:inherit;font-size:15px;font-weight:700;border:none;box-shadow:0 6px 24px #4d54d466;cursor:pointer;z-index:50;transition:box-shadow .15s,transform .12s}.mob-fab:hover{box-shadow:0 8px 30px #4d54d480}.mob-fab:active{transform:scale(.97)}}
