@import"https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700&display=swap";:root{font-family:Manrope,Helvetica Neue,sans-serif;font-size:16px;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--font-weight-medium: 500;--font-weight-normal: 400;--radius: .625rem;--radius-sm: calc(var(--radius) - 4px);--radius-md: calc(var(--radius) - 2px);--radius-lg: var(--radius);--radius-xl: calc(var(--radius) + 4px);--app-bg: #f0f2f5;--surface: #ffffff;--input-bg: #f5f7fa;--text-primary: #1a2b42;--text-secondary: #8a9ab8;--text-muted: #8a9ab8;--border: #e4e8f0;--accent: #1a2b42;--accent-faint: rgba(26, 43, 66, .08);--accent-gradient: #1a2b42;--header-bg: #1a2b42;--shadow-soft: 0 2px 12px rgba(26, 43, 66, .08);--shadow-strong: 0 8px 32px rgba(26, 43, 66, .16);--icon-clock-bg: #eef0f6;--icon-clock-fg: #8a9ab8;--icon-lunch-bg: #fff8e6;--icon-lunch-fg: #f59e0b;--icon-money-bg: #e8f8ee;--icon-money-fg: #22c55e}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;background:var(--app-bg)}#root{overflow-x:hidden}h1{font-size:1.5rem;font-weight:var(--font-weight-medium);line-height:1.5;margin:0}h2{font-size:1.25rem;font-weight:var(--font-weight-medium);line-height:1.5;margin:0}h3{font-size:1.125rem;font-weight:var(--font-weight-medium);line-height:1.5;margin:0}h4{font-size:1rem;font-weight:var(--font-weight-medium);line-height:1.5;margin:0}button,input,textarea,label{font-family:inherit;font-size:1rem;line-height:1.5}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px 20px;background:var(--app-bg)}.auth-card{width:100%;max-width:400px;background:var(--surface);border-radius:24px;padding:40px 32px 36px;box-shadow:var(--shadow-strong);color:var(--text-primary)}.auth-logo-wrap{margin-bottom:44px;overflow:hidden;width:fit-content;max-width:160px}.auth-logo-img{height:44px;width:auto;display:block}.auth-title{font-size:24px;font-weight:700;margin:0 0 6px}.auth-subtitle{font-size:14px;color:var(--text-muted);margin:0 0 28px}.auth-field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.auth-label{font-size:13px;font-weight:600;color:var(--text-muted)}.auth-input{width:100%;padding:12px 14px;background:var(--input-bg);border:1.5px solid var(--border);border-radius:12px;font-size:15px;color:var(--text-primary);outline:none;transition:border-color .2s ease}.auth-input:focus{border-color:var(--accent)}.auth-error{font-size:13px;color:#f87171;margin:4px 0 10px}.auth-success{font-size:13px;color:#22c55e;margin:4px 0 10px}.auth-btn{width:100%;padding:14px;background:var(--header-bg);color:#fff;border:none;border-radius:14px;font-size:15px;font-weight:700;cursor:pointer;margin-top:8px;transition:opacity .2s ease}.auth-btn:hover{opacity:.88}.auth-footer{margin-top:20px;text-align:center;font-size:14px;color:var(--text-muted)}.auth-footer a{color:var(--accent);text-decoration:none;font-weight:600}.auth-footer a:hover{text-decoration:underline}.billing-shell{min-height:100vh;background:var(--app-bg)}.billing-topbar{padding:calc(16px + env(safe-area-inset-top,0px)) 24px 16px;border-bottom:1px solid var(--border);background:var(--surface)}.billing-back-btn{background:none;border:none;font-size:14px;font-weight:600;color:var(--accent);cursor:pointer;padding:0}.billing-back-btn:hover{text-decoration:underline}.billing-loading{padding:40px;color:var(--text-muted);text-align:center}.billing-page{padding:24px 24px 40px;max-width:700px}.billing-title{font-size:20px;font-weight:700;color:var(--text-primary);margin:0 0 20px}.billing-status-card{background:var(--surface);border:1.5px solid var(--border);border-radius:16px;padding:20px 22px;margin-bottom:28px;display:flex;align-items:center;gap:14px;flex-wrap:wrap;box-shadow:var(--shadow-soft)}.billing-badge{display:inline-block;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.billing-badge--trial{background:#fbbf2426;color:#d97706}.billing-badge--solo{background:var(--accent-faint);color:var(--accent)}.billing-badge--pro{background:#a78bfa33;color:#7c3aed}.billing-badge--cancelled{background:#f8717126;color:#dc2626}.billing-status-text{font-size:14px;color:var(--text-muted);margin:0;flex:1}.billing-portal-btn{padding:8px 16px;background:var(--input-bg);border:1.5px solid var(--border);border-radius:10px;font-size:13px;font-weight:600;color:var(--text-primary);cursor:pointer;transition:border-color .2s ease;white-space:nowrap}.billing-portal-btn:hover{border-color:var(--accent)}.billing-plans{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media(max-width:540px){.billing-plans{grid-template-columns:1fr}}.billing-plan-card{background:var(--surface);border:1.5px solid var(--border);border-radius:20px;padding:24px 22px;position:relative;box-shadow:var(--shadow-soft);transition:border-color .2s ease}.billing-plan-card--active{border-color:var(--accent)}.billing-plan-current-label{position:absolute;top:-1px;right:18px;background:var(--accent-gradient);color:#fff;font-size:11px;font-weight:700;padding:3px 10px;border-radius:0 0 10px 10px;letter-spacing:.04em;text-transform:uppercase}.billing-plan-name{font-size:18px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.billing-plan-price{margin-bottom:18px}.billing-plan-amount{font-size:28px;font-weight:700;color:var(--text-primary)}.billing-plan-period{font-size:14px;color:var(--text-muted)}.billing-plan-features{list-style:none;padding:0;margin:0 0 22px;display:flex;flex-direction:column;gap:8px}.billing-plan-feature{font-size:13px;color:var(--text-muted);display:flex;align-items:center;gap:8px}.billing-plan-check{color:var(--accent);font-weight:700}.billing-plan-btn{width:100%;padding:12px;border-radius:12px;font-size:14px;font-weight:700;cursor:pointer;border:none;transition:opacity .2s ease}.billing-plan-btn--upgrade{background:var(--accent-gradient);color:#fff}.billing-plan-btn--upgrade:hover{opacity:.88}.billing-plan-btn--active{background:var(--input-bg);color:var(--text-muted);cursor:default}.billing-plan-btn:disabled{opacity:.6;cursor:not-allowed}.legal-page{min-height:100vh;background:var(--app-bg);padding:3rem 1.5rem 5rem}.legal-container{max-width:760px;margin:0 auto}.legal-back{display:inline-block;margin-bottom:2rem;font-size:.875rem;color:var(--accent);text-decoration:none;font-weight:600}.legal-back:hover{text-decoration:underline}.legal-title{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem}.legal-meta{font-size:.85rem;color:var(--text-muted);margin-bottom:2.5rem}.legal-body{color:var(--text-primary);line-height:1.75;font-size:.95rem}.legal-body p{margin-bottom:1rem}.legal-body h2{font-size:1.15rem;font-weight:700;margin-top:2rem;margin-bottom:.5rem;color:var(--text-primary)}.legal-body ul{padding-left:1.5rem;margin-bottom:1rem}.legal-body li{margin-bottom:.4rem}.legal-body a{color:var(--accent);text-decoration:underline}.legal-body code{background:var(--input-bg, #f7f8fc);border:1px solid var(--border, #e5e7ef);border-radius:4px;padding:.1em .4em;font-size:.88em;font-family:monospace}.auth-consent{font-size:.78rem;color:var(--text-muted);text-align:center;line-height:1.5;margin-top:.5rem}.auth-consent a{color:var(--accent);text-decoration:underline}.splash-screen{position:fixed;inset:0;background:#1a2b42;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:40px;z-index:9999}.splash-logo{width:160px;opacity:0;animation:splash-logo-in .5s ease .1s forwards}.splash-dots{display:flex;gap:8px}.splash-dots span{width:8px;height:8px;border-radius:50%;background:#ffffff80;animation:splash-dot 1.2s ease-in-out infinite}.splash-dots span:nth-child(2){animation-delay:.2s}.splash-dots span:nth-child(3){animation-delay:.4s}@keyframes splash-logo-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes splash-dot{0%,80%,to{transform:scale(.7);opacity:.4}40%{transform:scale(1);opacity:1}}.app-shell{max-width:520px;margin:0 auto;min-height:100vh;padding:90px 0 100px;color:var(--text-primary);background:var(--app-bg);overflow-x:hidden;width:100%}.top-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;position:fixed;top:0;left:50%;transform:translate(-50%);width:100%;max-width:520px;z-index:40;padding:calc(14px + env(safe-area-inset-top,0px)) 20px 14px;background:var(--header-bg)}.date-block .today-label{font-size:13px;color:#ffffff8c;font-weight:500;letter-spacing:.01em}.date-block .today-value{font-size:20px;font-weight:700;color:#fff}.date-trigger{border:0;background:transparent;color:inherit;padding:0;text-align:left;cursor:pointer}.actions{display:flex;gap:8px;align-items:center}.burger{width:44px;height:44px;border-radius:14px;border:none;background:#ffffff1f;display:inline-flex;flex-direction:column;justify-content:center;gap:6px;padding:0 12px;cursor:pointer}.burger span{display:block;width:100%;height:2px;background:#fff;border-radius:999px}.content{display:flex;flex-direction:column;gap:0;padding:0 16px}.menu-overlay{position:fixed;inset:0;background:#0003;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:199;animation:fade-in .18s ease}.menu-panel{position:fixed;right:0;top:0;bottom:0;width:min(320px,88%);background:var(--surface);z-index:200;display:flex;flex-direction:column;box-shadow:-8px 0 32px #0000002e;animation:slide-in-right .22s ease}.menu-panel-header{background:var(--header-bg);padding:calc(20px + env(safe-area-inset-top,0px)) 20px 18px;display:flex;align-items:center;gap:12px}.menu-panel-avatar{width:40px;height:40px;border-radius:50%;background:#ffffff2e;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.menu-panel-email{flex:1;font-size:14px;font-weight:600;color:#fff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.menu-panel-close{width:36px;height:36px;border-radius:50%;border:none;background:#ffffff26;color:#fff;font-size:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.menu-panel-items{flex:1;padding:12px 12px 0;display:flex;flex-direction:column;gap:2px;overflow-y:auto}.menu-panel-item{display:flex;align-items:center;gap:12px;padding:13px 14px;border-radius:12px;background:transparent;border:none;color:var(--text-primary);font-size:15px;font-weight:600;cursor:pointer;text-align:left;transition:background .15s ease}.menu-panel-item:hover{background:var(--input-bg)}.menu-panel-item-icon{font-size:20px;width:28px;text-align:center;flex-shrink:0}.menu-panel-divider{height:1px;background:var(--border);margin:8px 12px}.menu-panel-item.danger{color:#e11d48}@keyframes slide-in-right{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.overview{border-radius:16px;padding:16px;background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-soft);margin-bottom:20px}.overview-label{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:6px}.overview-period{font-size:13px;color:var(--text-muted);margin-bottom:6px}.overview-value{font-size:26px;font-weight:700;margin-bottom:2px}.overview-sub{font-size:13px;color:var(--text-muted)}.section-header{font-size:16px;font-weight:700;color:var(--text-primary);padding:4px 0 10px;margin-top:8px}.section-header:first-child{margin-top:0}.shift-list{display:flex;flex-direction:column}.show-more-btn{display:block;width:100%;padding:14px;margin-top:8px;background:#fff;border:1.5px solid var(--border);border-radius:12px;color:var(--text-secondary);font-size:14px;cursor:pointer}.show-more-btn:hover{background:var(--app-bg)}.shift-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:14px 16px;box-shadow:var(--shadow-soft);margin-bottom:10px;position:relative}.shift-card__header{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:12px;position:relative}.shift-card__header>div:first-child{min-width:0;overflow:hidden}.shift-card__header>div:last-child{flex-shrink:0}.shift-date{font-weight:700;font-size:15px}.shift-menu-btn{width:30px;height:30px;border-radius:50%;border:none;background:#eef0f6;color:var(--text-muted);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.shift-menu-btn:hover{background:#dde1ec}.shift-context-menu{position:absolute;top:calc(100% + 4px);right:0;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow-strong);z-index:50;min-width:160px;overflow:hidden;animation:slide-down .14s ease}.shift-context-item{display:flex;align-items:center;gap:10px;padding:11px 14px;background:transparent;border:none;width:100%;text-align:left;font-size:14px;font-weight:600;color:var(--text-primary);cursor:pointer}.shift-context-item:hover{background:var(--input-bg)}.shift-context-item.danger{color:#e11d48}.shift-info-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.shift-icon-item{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--text-primary);flex:1;min-width:90px}.shift-icon-badge{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.shift-icon-badge.clock{background:var(--icon-clock-bg);color:var(--icon-clock-fg)}.shift-icon-badge.lunch{background:var(--icon-lunch-bg);color:var(--icon-lunch-fg)}.shift-icon-badge.money{background:var(--icon-money-bg);color:var(--icon-money-fg)}.shift-pay{color:var(--icon-money-fg);font-weight:700}.comment{margin-top:10px;color:var(--text-muted);font-size:13px;line-height:1.4;font-style:italic}.floating-btn{position:fixed;bottom:24px;right:24px;width:58px;height:58px;border-radius:50%;border:none;color:#fff;font-size:28px;font-weight:300;background:var(--header-bg);cursor:pointer;box-shadow:0 6px 20px #1a2b4259;display:flex;align-items:center;justify-content:center;z-index:100;transition:transform .2s ease}.floating-btn:hover{transform:scale(1.05)}.fab-backdrop{position:fixed;inset:0;background:#0003;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:99}.fab-menu{position:fixed;bottom:96px;right:20px;z-index:100;display:flex;flex-direction:column;gap:8px;animation:slide-up .18s ease}.fab-menu-item{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--surface);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-strong);cursor:pointer;font-size:15px;font-weight:600;color:var(--text-primary);white-space:nowrap;min-width:180px;text-align:left}.fab-menu-item:hover{background:var(--input-bg)}.fab-menu-icon{font-size:20px;width:28px;text-align:center}.fab-menu-icon-badge{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}@keyframes slide-up{0%{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slide-down{0%{transform:translateY(-6px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-backdrop{position:fixed;inset:0;background:#0003;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:grid;place-items:center;padding:calc(16px + env(safe-area-inset-top,0px)) 16px calc(16px + env(safe-area-inset-bottom,0px));overflow-y:auto;z-index:120}.modal{width:min(520px,100%);max-height:90vh;overflow:hidden;background:var(--surface);border-radius:18px;border:1px solid var(--border);display:flex;flex-direction:column;box-shadow:var(--shadow-strong)}.modal.wide{width:min(620px,100%)}.modal.modal-pinned{margin-top:50px;max-height:min(86vh,calc(100dvh - 104px))}.modal.modal--fullscreen{width:100%;height:100dvh;max-height:100dvh;border-radius:0;border:none}.modal--fullscreen .form-grid{flex:1}.modal--fullscreen .modal-header-dark,.modal--fullscreen .inv-header{padding-top:calc(16px + env(safe-area-inset-top,0px))}.modal-backdrop:has(.modal--fullscreen){padding:0;background:none;backdrop-filter:none;-webkit-backdrop-filter:none}.modal-header-dark{background:var(--header-bg);padding:16px 20px;display:flex;align-items:center;gap:12px;border-radius:18px 18px 0 0;flex-shrink:0}.modal-header-dark-icon{font-size:20px;color:#ffffffb3}.modal-title-dark{flex:1;font-size:17px;font-weight:700;color:#fff}.modal-close-btn{width:34px;height:34px;border-radius:50%;border:none;background:#ffffff26;color:#fff;font-size:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;line-height:1}.modal-close-btn:hover{background:#ffffff40}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 0;flex-shrink:0}.modal-header.end{justify-content:flex-end;gap:8px}.modal-title{font-weight:700;font-size:17px}.modal-body{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:20px}.modal-footer{padding:12px 20px 20px;flex-shrink:0}.form-grid{display:flex;flex-direction:column;gap:20px;overflow-y:auto;padding:20px}.field{display:flex;flex-direction:column;gap:8px}.field input,.field textarea,.field select{border:1.5px solid var(--border);border-radius:14px;padding:13px 16px;background:var(--input-bg);color:var(--text-primary);font-size:15px;font-weight:500;transition:border-color .15s,box-shadow .15s}.field select{appearance:none;width:100%;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='9' viewBox='0 0 14 9'%3E%3Cpath d='M1 1.5l6 6 6-6' stroke='%231a2b42' stroke-width='1.8' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:42px}.field select:hover{border-color:#1a2b4259}.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #1a2b4214}.form-field-btn{width:100%;text-align:left;background:var(--input-bg);border:1px solid var(--border);border-radius:14px;padding:14px 16px;font-size:15px;font-weight:500;color:var(--text-primary);cursor:pointer;transition:border-color .15s ease}.form-field-btn:hover{border-color:var(--accent)}.form-field-btn.placeholder{color:var(--text-muted)}.double{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.value{font-size:16px;font-weight:700}.accent{color:var(--accent)}.hint{color:var(--text-muted);font-size:13px}.segment{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:8px}.segment-btn{border:1px solid var(--border);border-radius:12px;padding:10px 12px;background:var(--surface);color:var(--text-primary);cursor:pointer;font-weight:600;font-size:13px;transition:all .15s ease}.segment-btn.compact{padding:8px 10px}.segment-btn.is-active{border-color:var(--accent);background:var(--accent-faint)}.segment-btn:hover{border-color:var(--accent)}.primary-btn{border:none;color:#fff;padding:16px;border-radius:14px;background:var(--header-bg);font-weight:700;font-size:16px;cursor:pointer;transition:opacity .15s ease}.modal>.primary-btn{margin:0 20px 20px;width:calc(100% - 40px)}.primary-btn:hover{opacity:.88}.primary-btn:disabled{opacity:.45;cursor:not-allowed}.toggle-row{display:flex;align-items:center;justify-content:space-between}.toggle-btn{position:relative;width:44px;height:26px;border-radius:13px;border:none;background:var(--border);cursor:pointer;padding:0;transition:background .2s;flex-shrink:0}.toggle-btn.is-on{background:var(--header-bg)}.toggle-knob{position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 1px 4px #0003;transition:transform .2s}.toggle-btn.is-on .toggle-knob{transform:translate(18px)}.ghost-button{background:transparent;border:1px solid var(--border);color:var(--text-primary);padding:9px 14px;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;transition:border-color .15s ease,background .15s ease}.ghost-button:hover{border-color:var(--accent)}.ghost-button.danger{color:#e11d48;border-color:#e11d4859}.ghost-button.danger:hover{border-color:#e11d48;background:#e11d480f}.icon-button{border:1px solid var(--border);background:var(--surface);color:var(--text-primary);padding:8px 12px;border-radius:999px;font-size:13px;cursor:pointer}.actions-row{display:flex;justify-content:space-between;align-items:center;gap:12px}.picker-sheet .actions-row{margin-top:20px;gap:12px}.picker-sheet .actions-row .ghost-button,.picker-sheet .actions-row .primary-btn{flex:1;text-align:center;padding:14px 16px;font-size:15px;border-radius:14px}.actions-row.center{justify-content:center}.actions-row.center .primary-btn{width:min(320px,100%)}.checkbox-inline{flex-direction:row;align-items:center;justify-content:space-between;gap:12px;padding:4px 2px}.checkbox-inline .label{margin:0}.wheel{position:relative;background:var(--input-bg);border:1px solid var(--border);border-radius:16px;overflow:hidden}.wheel__viewport{height:100%;overflow-y:auto;scroll-snap-type:y mandatory;scrollbar-width:none}.wheel__viewport::-webkit-scrollbar{display:none}.wheel__item{scroll-snap-align:center;display:grid;place-items:center;font-size:16px;color:var(--text-muted);font-weight:600}.wheel__item.is-active{color:var(--text-primary);font-size:18px;font-weight:800}.wheel__mask{position:absolute;inset:0;background:linear-gradient(to bottom,#0000000f,#0000 40% 60%,#0000000f);pointer-events:none}.wheel__highlight{position:absolute;left:8px;right:8px;top:50%;transform:translateY(-50%);border-radius:10px;pointer-events:none;box-shadow:0 0 0 1px #64646459}.picker-sheet-backdrop{position:fixed;inset:0;background:#0003;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:300}.picker-sheet{position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-radius:22px 22px 0 0;padding:20px 20px calc(32px + env(safe-area-inset-bottom,0px));z-index:301;box-shadow:0 -8px 32px #0000002e;animation:slide-sheet-up .22s ease;max-width:520px;margin:0 auto}@keyframes slide-sheet-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.picker-sheet-title{font-size:18px;font-weight:700;margin-bottom:4px}.picker-sheet-subtitle{font-size:13px;color:var(--text-muted);margin-bottom:16px}.picker-display{background:var(--header-bg);border-radius:14px;padding:16px;text-align:center;margin-bottom:20px}.picker-display-label{font-size:12px;color:#ffffff8c;text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}.picker-display-value{font-size:40px;font-weight:800;color:#fff;letter-spacing:-.02em}.picker-cols{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px}.picker-col-label{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.picker-col-title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.picker-badge{background:var(--input-bg);border:1px solid var(--border);border-radius:20px;padding:2px 10px;font-size:13px;font-weight:700;color:var(--text-primary)}.form-calendar{background:var(--input-bg);border:1px solid var(--border);border-radius:14px;padding:12px}.form-calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.form-calendar-title{font-size:14px;font-weight:700}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:4px;margin-bottom:4px}.calendar-weekday{font-size:11px;font-weight:700;color:var(--text-muted);text-align:center}.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:4px}.calendar-day,.calendar-day-empty{min-height:36px}.calendar-day{border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text-primary);cursor:pointer;display:grid;place-items:center;position:relative;font-size:13px;font-weight:700}.calendar-day:hover{border-color:var(--accent)}.calendar-day.has-shifts{border-color:#1a2b4233}.calendar-day.is-selected{border-color:var(--accent);background:var(--accent-faint)}.calendar-day.is-today{box-shadow:inset 0 0 0 1.5px var(--accent)}.calendar-day-empty{border-radius:8px;background:transparent}.calendar-day-number{line-height:1}.calendar-day-dot{position:absolute;bottom:3px;width:4px;height:4px;border-radius:999px;background:var(--accent)}.calendar-selected-label{font-size:13px;color:var(--text-muted);font-weight:700}.reports-page{display:flex;flex-direction:column;gap:12px}.reports-header{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:4px 0 8px}.reports-period-label{font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--text-primary);line-height:1.25;flex-shrink:0}.reports-nav-row{display:flex;align-items:center;gap:4px;flex:1;justify-content:space-between;margin-left:32px}.reports-range{font-weight:600;font-size:14px;color:var(--text-primary);display:flex;flex-direction:column;align-items:center;gap:1px;text-align:center}.reports-close-btn{width:32px;height:32px;border-radius:50%;border:none;background:var(--input-bg);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.reports-close-btn:hover{background:var(--border)}.nav-btn{width:28px;height:28px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center}.nav-btn:disabled{opacity:.4;cursor:not-allowed}.reports-client-wrap{position:relative}.reports-client-select{border:1.5px solid var(--border);border-radius:14px;padding:13px 42px 13px 16px;background:var(--surface);color:var(--text-primary);font-size:15px;font-weight:500;width:100%;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='9' viewBox='0 0 14 9'%3E%3Cpath d='M1 1.5l6 6 6-6' stroke='%231a2b42' stroke-width='1.8' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;cursor:pointer;box-shadow:var(--shadow-soft);transition:border-color .15s,box-shadow .15s}.reports-client-select:hover{border-color:#1a2b4259}.reports-client-select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #1a2b4214}.reports-create-invoice-btn{border:none;color:#fff;padding:16px;background:var(--header-bg);font-weight:700;font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;border-radius:14px;width:100%;transition:opacity .15s ease}.reports-create-invoice-btn:hover:not(:disabled){opacity:.88}.reports-create-invoice-btn:disabled{opacity:.4;cursor:not-allowed}.reports-stats-card{display:flex;align-items:stretch;background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-soft);overflow:hidden}.reports-stat-item{flex:1;padding:16px 12px;display:flex;flex-direction:column;align-items:center;gap:4px}.reports-stat-icon{color:var(--text-muted);margin-bottom:2px}.reports-stat-label{font-size:11px;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.06em}.reports-stat-value{font-size:15px;font-weight:700;color:var(--text-primary)}.reports-stat-divider{width:1px;background:var(--border);align-self:stretch;margin:12px 0}.field-label-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.field-label-row .label{margin-bottom:0}.reports-shift-list{display:flex;flex-direction:column;gap:10px}.report-row.empty{text-align:center;color:var(--text-muted);font-weight:600;padding:20px}.reports-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-soft);overflow:hidden;display:flex;flex-direction:column}.clients-section{display:flex;flex-direction:column;gap:0}.add-action-btn{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:8px 14px;font-size:13px;font-weight:600;color:var(--text-primary);cursor:pointer;transition:border-color .15s,background .15s;white-space:nowrap}.add-action-btn:hover{border-color:var(--header-bg);background:var(--accent-faint)}.calendar-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-soft);padding:14px 16px;display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.picker-group{display:flex;flex-direction:column;gap:8px}.picker-title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);padding:0 4px}.picker-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.picker-row.single{grid-template-columns:1fr}.invoice-section-label{font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin-bottom:2px;margin-top:8px}.invoice-line-item{background:var(--input-bg);border:1px solid var(--border);border-radius:14px;padding:14px;display:flex;flex-direction:column;gap:10px}.invoice-item-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.invoice-item-amount{display:flex;align-items:center;justify-content:space-between;font-size:14px;color:var(--text-muted)}.invoice-item-amount-value{font-weight:700;font-size:15px;color:var(--text-primary)}.invoice-totals-bar{background:var(--header-bg);border-radius:14px;padding:14px 16px;display:flex;flex-direction:column;gap:8px}.invoice-totals-row{display:flex;align-items:center;justify-content:space-between;font-size:14px;color:#ffffffb3}.invoice-totals-row.total{color:#fff;font-weight:700;font-size:16px;padding-top:4px;border-top:1px solid rgba(255,255,255,.15);margin-top:4px}.inv-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:var(--header-bg);flex-shrink:0}.inv-header-left{display:flex;align-items:center;gap:10px;color:#fff}.inv-header-title{font-size:18px;font-weight:700;color:#fff}.inv-close-btn{width:32px;height:32px;border-radius:50%;border:1px solid rgba(255,255,255,.3);background:transparent;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}.inv-close-btn:hover{background:#ffffff26}.inv-section-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-primary)}.inv-section-title-row,.inv-item-title-row{display:flex;justify-content:space-between;align-items:center}.inv-remove-item-btn{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:4px;border-radius:6px;display:flex;align-items:center;transition:color .15s}.inv-remove-item-btn:hover{color:#e53e3e}.inv-add-menu{position:absolute;right:0;top:100%;z-index:100;background:var(--surface, #fff);border:1px solid var(--border);border-radius:8px;padding:4px 0;min-width:160px;box-shadow:0 4px 12px #0000001f}.inv-add-menu button{display:block;width:100%;padding:8px 14px;background:none;border:none;text-align:left;cursor:pointer;font-size:14px;color:var(--text-primary)}.inv-add-menu button:hover{background:var(--app-bg)}.inv-line-item-card{background:var(--input-bg);border:1px solid var(--border);border-radius:14px;padding:16px;display:flex;flex-direction:column;gap:14px}.inv-line-item-card .field input{background:var(--surface)}.inv-line-item-card .field input[type=number]::-webkit-inner-spin-button,.inv-line-item-card .field input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.inv-line-item-card .field input[type=number]{-moz-appearance:textfield}.inv-item-title{font-weight:700;font-size:14px;color:var(--text-primary)}.inv-item-amount{display:flex;justify-content:space-between;align-items:center;padding-top:4px;font-size:13px;color:var(--text-muted)}.inv-item-amount strong{font-size:16px;font-weight:700;color:var(--text-primary)}.duration-input{display:flex;align-items:center;gap:6px}.duration-input input{width:60px;text-align:center;padding:13px 8px;border:1.5px solid var(--border);border-radius:14px;background:var(--input-bg);color:var(--text-primary);font-size:15px;font-weight:500;transition:border-color .15s,box-shadow .15s}.duration-input input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #1a2b4214}.duration-sep{font-size:15px;font-weight:600;color:var(--text-muted)}.inv-summary-card{background:var(--header-bg);border-radius:14px;padding:16px 20px;display:flex;flex-direction:column;gap:10px}.inv-summary-row{display:flex;justify-content:space-between;align-items:center;color:#fffc;font-size:14px}.inv-summary-total{color:#fff;font-size:16px}.inv-summary-divider{height:1px;background:#ffffff26}.inv-footer{display:flex;gap:12px;padding:16px 20px 20px;flex-shrink:0}.inv-footer .ghost-button{flex:1;padding:14px;font-size:15px;border-radius:14px;text-align:center}@media(max-width:520px){.app-shell{padding:calc(90px + env(safe-area-inset-top,0px)) 0 90px}.content{padding:0 14px}.modal.modal-pinned{margin-top:44px;max-height:min(88vh,calc(100dvh - 84px))}}.radio-group{display:flex;flex-direction:column;gap:10px;margin-top:4px}.radio-option{display:flex;align-items:center;gap:8px;font-size:14px;cursor:pointer}.radio-option input[type=radio]{width:16px;height:16px;cursor:pointer;accent-color:var(--primary, #2563eb)}@media(min-width:768px){.app-shell,.top-bar{max-width:min(66vw,860px)}.floating-btn,.fab-menu{right:calc(50% - min(33vw,430px) + 24px)}.menu-panel{right:calc(50% - min(33vw,430px))}.modal--fullscreen{width:min(66vw,860px);height:100dvh;border-radius:0;margin:0 auto}.modal-backdrop:has(.modal--fullscreen){padding:0;background:#0003;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}}
