:root{color-scheme:dark;--bg: #050708;--surface: #0b1012;--surface-2: #11181b;--surface-3: #172024;--line: rgba(255, 255, 255, .1);--line-strong: rgba(22, 213, 207, .42);--text: #f2fbfb;--muted: #94a7aa;--accent: #16d5cf;--accent-2: #68f0e8;--accent-dark: #064947;--warning: #f5b84b;--danger: #ef6461;--blue: #5aa9ff;--radius: 8px;--shadow: 0 14px 30px rgba(0, 0, 0, .28);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Hiragino Sans,Noto Sans JP,sans-serif;background:var(--bg);color:var(--text)}*,*:before,*:after{box-sizing:border-box}html,body,#root{width:100%;min-height:100%;margin:0;overflow-x:hidden}html{background:var(--bg);-webkit-text-size-adjust:100%}body{background:linear-gradient(180deg,rgba(22,213,207,.08),transparent 260px),var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:rgba(22,213,207,.18);overscroll-behavior-y:contain;text-rendering:optimizeLegibility}#root{min-height:100dvh;isolation:isolate}button,input,select,textarea{font:inherit;font-size:16px;max-width:100%}button{-webkit-tap-highlight-color:transparent;touch-action:manipulation}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:3px solid rgba(22,213,207,.55);outline-offset:2px}input,select,textarea{width:100%;min-width:0;min-height:48px;border:1px solid var(--line);border-radius:var(--radius);background:#070b0c;color:var(--text);padding:12px 13px}textarea{resize:vertical;line-height:1.5}select{-webkit-appearance:none;-moz-appearance:none;appearance:none}table{border-collapse:collapse}img,svg,canvas,video{max-width:100%}.app-shell{width:100%;max-width:480px;min-height:100dvh;margin:0 auto;padding-bottom:calc(168px + env(safe-area-inset-bottom));background:#050708f5;overflow-x:hidden}.app-shell *{min-width:0}.app-main{width:100%;max-width:100%;min-width:0;padding:16px;overflow-x:hidden}.app-header{position:sticky;top:0;z-index:20;display:grid;grid-template-columns:1fr;align-items:stretch;gap:12px;width:100%;max-width:100%;min-width:0;padding:calc(12px + env(safe-area-inset-top)) 16px 12px;border-bottom:1px solid var(--line);background:#050708eb;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);overflow-x:hidden}.app-header h1{margin:0;font-size:28px;line-height:1.05;letter-spacing:0}.app-header__eyebrow,.app-header__subtitle,.muted,.fine-print{margin:0;color:var(--muted)}.app-header__eyebrow{font-size:11px;font-weight:700;color:var(--accent-2)}.app-header__subtitle{max-width:270px;margin-top:5px;font-size:12px}.app-header__select{display:grid;gap:5px;width:100%;max-width:100%;color:var(--muted);font-size:11px}.app-header__select select{min-height:42px;padding:9px 10px;font-size:13px}.page-stack{display:grid;gap:12px;width:100%;max-width:100%;min-width:0;overflow-x:hidden}.card{width:100%;max-width:100%;min-width:0;border:1px solid var(--line);border-radius:var(--radius);background:linear-gradient(180deg,#ffffff09,#ffffff04),var(--surface);box-shadow:var(--shadow);padding:14px;overflow-wrap:anywhere}.clock-panel{display:grid;gap:10px;width:100%;max-width:100%;text-align:center;border-color:var(--line-strong);overflow:hidden}.input-page{gap:10px}.input-page .card{padding:12px}.input-page .clock-panel{gap:8px}.current-clock{font-variant-numeric:tabular-nums;font-size:clamp(48px,16vw,72px);font-weight:800;line-height:1;max-width:100%;color:var(--accent-2);text-align:center}.input-page .current-clock{font-size:clamp(48px,15vw,68px)}.section-title{display:grid;grid-template-columns:1fr;align-items:start;gap:12px;margin-bottom:12px;min-width:0}.section-title h2,.section-title h3{margin:0;font-size:18px;letter-spacing:0}.section-title p{margin:4px 0 0;color:var(--muted);font-size:12px}.section-title--compact{align-items:center;margin-top:14px;margin-bottom:8px}.button,.file-button{display:inline-flex;min-height:48px;max-width:100%;align-items:center;justify-content:center;border:1px solid transparent;border-radius:var(--radius);padding:12px 14px;color:var(--text);font-weight:800;text-align:center;cursor:pointer;white-space:normal;overflow-wrap:anywhere}.button--primary{background:var(--accent);color:#001314}.button--secondary,.file-button{border-color:#16d5cf5c;background:#16d5cf24;color:var(--accent-2)}.button--ghost{border-color:var(--line);background:#ffffff0a}.button--danger{border-color:#ef646173;background:#ef646129;color:#ffc7c4}.button--checkout{border-color:#f5b84b85;background:linear-gradient(180deg,#f5d26f,#f5b84b);color:#171000;font-size:18px;box-shadow:0 12px 24px #f5b84b2e}.button:disabled,.button.is-saving{opacity:.64;cursor:progress}.button.is-saved{border-color:#16d5cf9e;background:#16d5cf42;color:var(--accent-2)}.button--compact{min-height:38px;padding:8px 10px;font-size:12px}.button--block{width:100%}.time-card-grid{display:grid;grid-template-columns:1fr;gap:12px;width:100%;max-width:100%;min-width:0}.time-input{display:grid;gap:8px;width:100%;max-width:100%;min-width:0;padding:12px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-2)}.input-page .time-input{gap:6px;padding:10px}.time-input>span,.field>span{color:var(--muted);font-size:12px;font-weight:700}.time-input input{min-height:54px;padding:10px;font-size:clamp(32px,10vw,48px);font-weight:800;text-align:center}.input-page .time-input input{min-height:58px;font-size:clamp(32px,10vw,44px)}.time-input__row{display:grid;gap:8px;width:100%;max-width:100%}.field{display:grid;gap:7px;margin-top:12px}.input-page .field{margin-top:10px}.number-row{display:grid;grid-template-columns:1fr auto;align-items:center;gap:10px;width:100%;max-width:100%}.number-row span{color:var(--muted);font-weight:800}.chip-row{display:flex;flex-wrap:wrap;gap:8px;width:100%;max-width:100%;margin-top:10px;overflow:visible;padding-bottom:2px}.chip,.tag{min-height:38px;flex:1 1 calc(33.333% - 8px);max-width:100%;border:1px solid var(--line);border-radius:var(--radius);background:#ffffff0a;color:var(--text);padding:8px 11px;font-weight:700}.chip.is-active,.tag.is-active{border-color:#16d5cf94;background:#16d5cf2e;color:var(--accent-2)}.toggle-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:12px}.input-page .toggle-grid{grid-template-columns:1fr;gap:7px;margin-top:10px}.input-page .toggle-button{min-height:48px;padding:10px 12px}.toggle-button{min-height:48px;border:1px solid var(--line);border-radius:var(--radius);background:#ffffff0a;color:var(--text);font-weight:800}.toggle-button.is-active{border-color:var(--accent);background:#16d5cf33;color:var(--accent-2)}.toggle-button--danger.is-active{border-color:var(--danger);background:#ef646133;color:#ffc7c4}.template-scroller{display:grid;grid-template-columns:1fr;gap:8px;width:100%;max-width:100%;overflow:visible;padding-bottom:4px}.template-button{display:grid;gap:5px;min-height:76px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-2);color:var(--text);padding:10px;text-align:left}.input-page .template-button{min-height:64px;padding:9px}.template-button span{color:var(--muted);font-size:12px}.result-panel{border-color:#16d5cf47}.result-panel__main{display:grid;grid-template-columns:1fr;align-items:start;gap:12px}.result-panel__main span{color:var(--muted)}.result-panel__main strong{font-size:34px;color:var(--accent-2)}.input-result-panel .result-panel__main strong{font-size:30px}.mini-metrics{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.mini-metrics span{border:1px solid var(--line);border-radius:var(--radius);background:#ffffff0a;padding:7px 9px;color:var(--muted);font-size:12px;font-weight:700}.mini-metrics--spaced{margin-top:16px}.warning-list{display:grid;gap:7px;margin-top:12px}.warning-list p,.insight-list p{margin:0;border:1px solid rgba(245,184,75,.35);border-radius:var(--radius);background:#f5b84b1a;color:#ffe2a4;padding:10px;font-size:13px;line-height:1.45}.danger-panel{border-color:#ef646159}.save-state-panel{display:grid;gap:3px;margin-bottom:12px;border:1px solid var(--line);border-radius:var(--radius);background:#ffffff0a;padding:10px}.save-state-panel strong{font-size:13px}.save-state-panel span{color:var(--muted);font-size:12px}.save-state-panel.is-dirty{border-color:#f5b84b70;background:#f5b84b1a}.save-state-panel.is-dirty strong{color:#ffe2a4}.save-state-panel.is-saved{border-color:#16d5cf70;background:#16d5cf1a}.save-state-panel.is-saved strong{color:var(--accent-2)}.sticky-actions{position:sticky;bottom:calc(124px + env(safe-area-inset-bottom));z-index:10;display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:8px;width:100%;max-width:100%;border:1px solid var(--line);border-radius:var(--radius);background:#050708db;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.sticky-actions .button:first-child{grid-column:1 / -1}.month-toolbar{display:grid;grid-template-columns:1fr;align-items:center;gap:10px;text-align:center}.month-toolbar h2{margin:0;font-size:20px}.segmented{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(0,1fr);gap:4px;width:100%;max-width:100%;margin-top:12px;border:1px solid var(--line);border-radius:var(--radius);background:#070b0c;padding:4px}.segmented button{min-height:38px;border:0;border-radius:6px;background:transparent;color:var(--muted);font-weight:800}.segmented button.is-active{background:var(--accent);color:#001314}.notice-card{border-color:#f5b84b6b}.notice-card strong{color:#ffe2a4}.notice-card p{color:var(--muted);line-height:1.5}.range-row{display:grid;grid-template-columns:1fr;align-items:center;gap:8px;margin:12px 0;width:100%;max-width:100%}.range-row span{color:var(--muted);font-weight:800}.table-card{padding:0;overflow:hidden}.table-scroll{width:100%;max-width:100%;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain}.records-table{width:max-content;min-width:720px;max-width:none;font-size:12px}.records-table th,.records-table td{border-bottom:1px solid var(--line);padding:10px 9px;text-align:left;vertical-align:top}.records-table th{position:sticky;top:0;background:var(--surface-2);color:var(--muted);font-size:11px;z-index:1}.records-table tr{cursor:pointer}.records-table tr.is-today{background:#16d5cf21}.records-table tr.saturday td:first-child strong{color:var(--blue)}.records-table tr.sunday td:first-child strong{color:#ff8c88}.records-table small{display:block;margin-top:4px;color:var(--muted)}.table-action-stack{display:grid;gap:6px;min-width:86px}.warning-text{color:#ffe2a4!important}.holiday-label,.status-pill{display:inline-block;margin-top:4px;border-radius:6px;background:#16d5cf24;color:var(--accent-2);padding:3px 6px;font-size:10px;font-weight:800}.calendar-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.calendar-day{display:grid;gap:5px;min-height:92px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-2);color:var(--text);padding:10px;text-align:left}.calendar-day.is-today{border-color:var(--accent);background:#16d5cf26}.calendar-day.saturday span{color:var(--blue)}.calendar-day.sunday span{color:#ff8c88}.calendar-day strong{font-size:16px}.calendar-day em{color:var(--warning);font-size:11px;font-style:normal}.google-calendar-card .section-title{margin-bottom:0}.import-log{border:1px solid rgba(90,169,255,.28);border-radius:var(--radius);background:#5aa9ff14;padding:10px}.ical-candidate-list{display:grid;gap:8px;width:100%;max-width:100%;margin-top:12px}.ical-candidate-row{display:grid;grid-template-columns:auto 1fr;align-items:start;gap:10px;width:100%;max-width:100%;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-2);padding:10px}.ical-candidate-row input{width:22px;min-height:22px;margin-top:2px;accent-color:var(--accent)}.ical-candidate-row span,.ical-candidate-row strong,.ical-candidate-row small{display:block;max-width:100%;overflow-wrap:anywhere}.ical-candidate-row small{margin-top:4px;color:var(--muted)}.month-calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:5px;width:100%;max-width:100%}.month-calendar-grid--header{margin-bottom:7px}.month-calendar-grid--header span{color:var(--muted);font-size:11px;font-weight:800;text-align:center}.month-calendar-grid--header span:first-child,.month-calendar-day.sunday>span{color:#ff8c88}.month-calendar-grid--header span:last-child,.month-calendar-day.saturday>span{color:var(--blue)}.month-calendar-blank,.month-calendar-day{min-height:58px;border-radius:var(--radius)}.month-calendar-blank{border:1px solid transparent}.month-calendar-day{display:grid;align-content:space-between;gap:3px;min-width:0;border:1px solid var(--line);background:var(--surface-2);color:var(--text);padding:6px 4px;text-align:center}.month-calendar-day>span{font-size:13px;font-weight:900}.month-calendar-day strong{color:var(--muted);font-size:10px;line-height:1.1}.month-calendar-day em{color:var(--warning);font-size:9px;font-style:normal;line-height:1.1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.month-calendar-day.has-record{border-color:#16d5cf80;background:#16d5cf29}.month-calendar-day.has-record strong{color:var(--accent-2)}.month-calendar-day.has-plan{border-color:#5aa9ff80;background:#5aa9ff21}.month-calendar-day.has-plan strong{color:#b8d9ff}.month-calendar-day.is-today{border-color:var(--accent);box-shadow:inset 0 0 0 1px #16d5cf80}.month-calendar-day.is-delete-pending{border-color:#ef6461b8;background:#ef64612e}.month-calendar-day.is-delete-pending strong{color:#ffc7c4}.hero-metric{display:grid;gap:6px;border-color:#16d5cf66;background:linear-gradient(135deg,#16d5cf29,#ffffff05),var(--surface)}.hero-metric span{color:var(--accent-2);font-weight:800}.hero-metric strong{font-size:42px;line-height:1.05}.hero-metric p{margin:0;color:var(--muted)}.hero-metric--danger{border-color:#ef646175;background:linear-gradient(135deg,#ef646129,#ffffff05),var(--surface)}.hero-metric--danger span,.hero-metric--danger strong{color:#ffc7c4}.summary-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;width:100%;max-width:100%}.summary-grid--compact{margin-top:12px}.summary-card{display:grid;min-height:92px;align-content:space-between;gap:8px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-2);padding:12px}.summary-card__label,.summary-card__detail{color:var(--muted);font-size:12px;font-weight:700}.summary-card strong{font-size:20px;line-height:1.15}.summary-card--accent{border-color:#16d5cf73}.summary-card--accent strong{color:var(--accent-2)}.summary-card--warning{border-color:#f5b84b6b}.summary-card--warning strong{color:#ffe2a4}.summary-card--danger{border-color:#ef64616b}.summary-card--danger strong{color:#ffc7c4}.breakdown-list{display:grid;gap:8px;margin-top:12px}.breakdown-list div{display:flex;justify-content:space-between;gap:12px;border-bottom:1px solid var(--line);padding:9px 0}.breakdown-list span{color:var(--muted)}.breakdown-list__total{border-bottom:0!important;color:var(--accent-2);font-size:18px}.fine-print{margin-top:12px;font-size:12px;line-height:1.5}.chart-card{overflow:hidden}.pie-layout{display:grid;grid-template-columns:140px 1fr;align-items:center;gap:16px;width:100%;max-width:100%}.pie-chart{width:140px;aspect-ratio:1;border:14px solid rgba(255,255,255,.06);border-radius:50%;box-shadow:inset 0 0 0 18px var(--surface)}.legend-list{display:grid;gap:10px}.legend-list span{display:flex;align-items:center;gap:8px;color:var(--muted);font-weight:700}.legend-dot{width:11px;height:11px;border-radius:50%}.legend-dot--accent{background:var(--accent)}.legend-dot--warning{background:var(--warning)}.legend-dot--danger{background:var(--danger)}.bar-chart{display:grid;grid-template-columns:repeat(6,minmax(42px,1fr));gap:8px;width:100%;max-width:100%;min-height:190px;align-items:end}.bar-chart__item{display:grid;grid-template-rows:1fr auto auto;gap:5px;height:180px;align-items:end;text-align:center}.bar-chart__bar{width:100%;min-height:8px;border-radius:6px 6px 0 0;background:linear-gradient(180deg,var(--accent-2),var(--accent-dark))}.bar-chart__item span,.bar-chart__item strong{font-size:11px}.bar-chart__item span{color:var(--muted)}.insight-list{display:grid;gap:8px}.sim-result{margin:12px 0 0;color:var(--accent-2);font-weight:800}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;width:100%;max-width:100%}.editable-list{display:grid;gap:10px}.editable-item{display:grid;gap:10px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-2);padding:10px}.switch-row{display:grid;grid-template-columns:1fr auto;align-items:center;justify-content:space-between;gap:12px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-2);padding:12px;font-weight:800}.switch-row input{width:24px;min-height:24px;accent-color:var(--accent)}.tag-list{display:flex;flex-wrap:wrap;gap:8px}.tag-list--spaced{margin-top:12px}.expense-list{display:grid;gap:8px}.expense-list--compact{margin-top:12px}.expense-row{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-2);padding:10px}.expense-row strong,.expense-row span,.expense-row small{overflow-wrap:anywhere}.expense-row small{display:block;margin-top:3px;color:var(--muted)}.expense-row.is-paid{opacity:.64}.expense-row.is-paid strong,.expense-row.is-paid span{text-decoration:line-through;text-decoration-color:#ffffff47}.switch-row--compact{grid-template-columns:auto auto;min-height:38px;padding:6px 8px;font-size:12px}.toast{position:fixed;left:50%;bottom:calc(98px + env(safe-area-inset-bottom));z-index:1200;width:calc(100% - 32px);max-width:440px;transform:translate(-50%);border:1px solid rgba(22,213,207,.38);border-radius:12px;background:#080f10f5;box-shadow:0 14px 34px #0006;padding:12px 14px;color:var(--text);font-weight:800}.toast--success{border-color:#16d5cf94;color:var(--accent-2)}.toast--error{border-color:#ef646180;color:#ffc7c4}.toast--info{border-color:#5aa9ff80;color:#b8d9ff}.action-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;width:100%;max-width:100%}.file-button{position:relative;overflow:hidden}.file-button--block{width:100%;margin-top:10px}.file-button input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0}.date-picker{width:100%;max-width:100%;min-height:48px;padding:10px 11px;font-size:16px}.bottom-nav{position:fixed;left:50%;bottom:calc(8px + env(safe-area-inset-bottom));z-index:1000;display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:3px;width:calc(100% - 24px);max-width:456px;transform:translate(-50%);padding:7px;padding-bottom:calc(8px + env(safe-area-inset-bottom));border:1px solid var(--line);border-radius:16px;background:#050708f0;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:0 18px 36px #00000061}.bottom-nav__item{display:grid;gap:2px;min-width:0;min-height:56px;place-items:center;border:1px solid transparent;border-radius:var(--radius);background:transparent;color:var(--muted);font-size:10px;font-weight:800;line-height:1.12;text-align:center;overflow:hidden}.bottom-nav__item span:last-child{max-width:100%;overflow-wrap:anywhere}.bottom-nav__mark{display:grid;min-width:24px;width:24px;height:24px;place-items:center;border-radius:7px;background:#ffffff0f;color:var(--text);font-size:12px}.bottom-nav__item.is-active{border-color:#16d5cf52;background:#16d5cf1a;color:var(--accent-2)}.bottom-nav__item.is-active .bottom-nav__mark{background:var(--accent);color:#001314}@media(max-width:430px){.app-main,.app-header{padding-inline:16px}.app-header h1{font-size:24px}.app-header__subtitle{display:none}.current-clock{font-size:clamp(48px,15vw,64px)}.form-grid,.action-grid,.pie-layout{grid-template-columns:1fr}.input-page .time-card-grid{grid-template-columns:1fr;gap:12px}.input-page .time-input{padding:12px}.input-page .time-input input{min-height:58px;font-size:clamp(32px,10vw,44px)}.input-page .time-input .button--compact{min-height:44px;padding:8px 10px;font-size:13px}.input-page .clock-panel .button{min-height:48px}.sticky-actions{grid-template-columns:1fr 1fr}.button,.file-button{padding-inline:10px}}@media(max-width:380px){.app-main,.app-header{padding-inline:12px}.sticky-actions{grid-template-columns:1fr}.sticky-actions .button:first-child{grid-column:auto}}@media(min-width:768px){.app-header{grid-template-columns:1fr minmax(150px,180px);align-items:end}.section-title{grid-template-columns:1fr auto;align-items:start}.date-picker{max-width:172px}.month-toolbar{grid-template-columns:auto 1fr auto}.range-row{grid-template-columns:1fr auto 1fr}}@media(max-height:740px){.input-page{gap:8px}.input-page .card{padding:10px}.input-page .current-clock{font-size:42px}.input-page .clock-panel{gap:6px}.input-page .section-title{margin-bottom:8px}.input-page .chip-row{margin-top:8px}.input-page textarea{min-height:58px}.input-page .template-scroller{grid-auto-columns:minmax(124px,1fr)}.input-result-panel .mini-metrics{margin-top:6px}}.desktop-sidebar{display:none}.dashboard-page,.desktop-report-page,.desktop-attendance-page{width:100%;min-width:0}.desktop-page-header,.desktop-basic-header,.desktop-report-title{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:20px}.desktop-page-header p,.desktop-basic-header p,.desktop-report-title p{margin:0 0 6px;color:var(--accent);font-size:11px;font-weight:900}.desktop-page-header h1,.desktop-basic-header h1,.desktop-report-title h1{margin:0;font-size:30px;line-height:1.15}.desktop-page-header span,.desktop-basic-header span,.desktop-report-title span{display:block;margin-top:6px;color:var(--muted);font-size:13px}.desktop-page-header__filters{display:flex;align-items:flex-end;gap:10px}.desktop-page-header__filters label,.desktop-basic-header label{display:grid;gap:5px;min-width:190px}.desktop-month-control{display:grid;grid-template-columns:40px minmax(130px,auto) 40px;align-items:center;min-height:48px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);overflow:hidden}.desktop-month-control button{height:100%;border:0;background:transparent;color:var(--text);font-size:25px;cursor:pointer}.desktop-month-control strong{text-align:center;font-size:14px}.kpi-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:16px}.kpi-card{display:grid;gap:9px;min-height:132px;padding:16px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow)}.kpi-card__header{display:flex;align-items:center;justify-content:space-between;gap:8px;color:var(--muted);font-size:12px;font-weight:800}.kpi-card__header i{display:grid;width:34px;height:34px;place-items:center;border-radius:var(--radius);background:#16b8b21a;color:var(--accent)}.kpi-card>strong{color:var(--text);font-size:26px;line-height:1.05}.kpi-card>small{color:var(--muted);font-size:11px}.kpi-card--success{border-top:3px solid var(--accent)}.kpi-card--warning{border-top:3px solid var(--warning)}.kpi-card--danger{border-top:3px solid var(--danger)}.dashboard-highlight-grid,.dashboard-planning-grid,.dashboard-chart-grid{display:grid;grid-template-columns:1fr;gap:16px;margin-bottom:16px}.salary-summary,.payday-countdown{display:grid;grid-template-columns:1.2fr 1fr;gap:18px;min-width:0;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow);padding:18px}.salary-summary__main{display:grid;align-content:center;gap:7px}.salary-summary__main>span,.payday-countdown span{display:flex;align-items:center;gap:7px;color:var(--muted);font-size:12px;font-weight:800}.salary-summary__main>strong{font-size:35px;color:var(--accent-dark)}.salary-summary__main p{display:flex;align-items:center;gap:4px;margin:0;font-size:12px;font-weight:800}.is-positive{color:var(--accent-dark)}.is-negative{color:var(--danger)}.salary-summary dl,.free-time-panel dl{display:grid;gap:0;margin:0}.salary-summary dl div,.free-time-panel dl div{display:flex;justify-content:space-between;gap:10px;border-bottom:1px solid var(--line);padding:9px 0;font-size:12px}.salary-summary dt,.free-time-panel dt{color:var(--muted)}.salary-summary dd,.free-time-panel dd{margin:0;font-weight:800;text-align:right}.payday-countdown>div{display:grid;align-content:center;gap:7px;padding:4px 8px}.payday-countdown>div+div{border-left:1px solid var(--line)}.payday-countdown strong{font-size:22px}.payday-countdown p{margin:0;color:var(--muted);font-size:12px}.payday-countdown.is-danger strong{color:var(--danger)}.trend-chart{display:grid;gap:8px;min-width:0}.trend-chart svg{width:100%;height:210px;overflow:visible}.trend-chart__line{fill:none;stroke:var(--accent);stroke-width:2.2;vector-effect:non-scaling-stroke}.trend-chart__line.is-danger{stroke:var(--danger)}.trend-chart__point{fill:var(--surface);stroke:var(--accent);stroke-width:1.4;vector-effect:non-scaling-stroke}.trend-chart__zero{stroke:var(--line);stroke-width:1;vector-effect:non-scaling-stroke}.trend-chart__labels,.trend-chart__values{display:grid;grid-auto-flow:column;grid-auto-columns:1fr;gap:4px;color:var(--muted);font-size:10px;text-align:center}.trend-chart__values{grid-template-columns:1fr 1fr 1fr;grid-auto-flow:initial;font-size:11px}.trend-chart__values strong{color:var(--text)}.stacked-chart{position:relative;display:grid;grid-template-columns:repeat(6,minmax(0,1fr));align-items:end;gap:12px;min-height:250px;padding-bottom:35px}.stacked-chart__item{display:grid;grid-template-rows:auto 180px auto;gap:6px;min-width:0;color:var(--muted);font-size:10px;text-align:center}.stacked-chart__value{color:var(--text);font-weight:800}.stacked-chart__bar{display:flex;flex-direction:column;justify-content:flex-end;min-width:18px;max-width:48px;width:70%;height:180px;margin:0 auto;overflow:hidden;border-radius:5px 5px 0 0;background:var(--surface-2)}.stacked-chart__bar i{display:block;width:100%;min-height:1px}.stacked-chart__regular{background:var(--accent)}.stacked-chart__overtime{background:var(--warning)}.chart-legend{position:absolute;right:0;bottom:0;display:flex;gap:14px;font-size:11px;color:var(--muted)}.chart-legend span{display:flex;align-items:center;gap:5px}.expense-breakdown{display:grid;grid-template-columns:minmax(160px,210px) 1fr;align-items:center;gap:24px}.expense-breakdown__pie{display:grid;aspect-ratio:1;place-items:center;border-radius:50%;background:var(--surface-2)}.expense-breakdown__pie>span{display:grid;width:66%;aspect-ratio:1;place-content:center;border-radius:50%;background:var(--surface);text-align:center}.expense-breakdown__pie strong{font-size:16px}.expense-breakdown__pie small{color:var(--muted);font-size:10px}.expense-breakdown__legend{display:grid;gap:8px}.expense-breakdown__legend>div{display:flex;justify-content:space-between;gap:10px;border-bottom:1px solid var(--line);padding-bottom:7px;font-size:12px}.expense-breakdown__legend span{display:flex;align-items:center;gap:7px;color:var(--muted)}.expense-breakdown__legend i{width:9px;height:9px;border-radius:3px}.budget-simulator{display:grid;gap:14px}.budget-simulator__result{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.budget-simulator__result div{display:grid;gap:5px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-2);padding:12px}.budget-simulator__result span{color:var(--muted);font-size:11px}.budget-simulator__result strong{font-size:17px}.budget-simulator>p{margin:0;color:var(--muted);font-size:12px;line-height:1.6}.free-time-panel{display:grid;gap:16px}.free-time-panel__hero{display:grid;gap:5px}.free-time-panel__hero span{color:var(--muted);font-size:12px}.free-time-panel__hero strong{color:var(--accent-dark);font-size:34px}.free-time-panel__hero p{margin:0;color:var(--muted);font-size:12px}.time-allocation-bar{display:flex;width:100%;height:18px;overflow:hidden;border-radius:5px;background:var(--surface-2)}.time-allocation-bar i{display:block;height:100%}.time-allocation-bar .is-work{background:var(--accent)}.time-allocation-bar .is-commute{background:var(--blue)}.time-allocation-bar .is-sleep{background:#7268b0}.time-allocation-bar .is-free{background:var(--warning)}.advice-panel{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.advice-item{display:grid;grid-template-columns:auto 1fr;align-items:start;gap:10px;border:1px solid var(--line);border-left-width:4px;border-radius:var(--radius);background:var(--surface-2);padding:12px}.advice-item strong{font-size:13px}.advice-item p{margin:5px 0 0;color:var(--muted);font-size:12px;line-height:1.55}.advice-item--success{border-left-color:var(--accent);color:var(--accent-dark)}.advice-item--info{border-left-color:var(--blue);color:var(--blue)}.advice-item--warning{border-left-color:var(--warning);color:#a56a00}.advice-item--danger{border-left-color:var(--danger);color:var(--danger)}.candidate-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.candidate-grid article{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-2);padding:13px;font-size:12px;line-height:1.5}.investment-disclaimer{border:1px solid rgba(239,100,97,.35);border-radius:var(--radius);background:#ef646114;padding:14px}.investment-disclaimer strong{color:var(--danger)}.investment-disclaimer p{margin:5px 0 0;color:var(--muted);font-size:12px}.fixed-cost-list{display:grid;gap:8px;margin-top:14px}.fixed-cost-list article{display:grid;grid-template-columns:1fr auto;align-items:center;gap:12px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-2);padding:10px}.fixed-cost-list article.is-disabled{opacity:.55}.fixed-cost-list article span{display:block;margin-top:4px;color:var(--muted);font-size:11px}.fixed-cost-list__actions{display:flex;align-items:center;gap:6px}.action-row{display:flex;gap:8px;margin-top:12px}@media(min-width:768px)and (max-width:1023px){.app-shell{max-width:960px}.app-main{padding:24px}.summary-grid{gap:12px}}@media(min-width:1024px){:root{color-scheme:light;--bg: #edf1f4;--surface: #ffffff;--surface-2: #f5f7f8;--surface-3: #e7edef;--line: #dce4e7;--line-strong: rgba(22, 184, 178, .42);--text: #172326;--muted: #67787d;--accent: #16b8b2;--accent-2: #087e7a;--accent-dark: #075f5c;--warning: #f0a33b;--danger: #dc5260;--blue: #517bd0;--shadow: 0 8px 22px rgba(32, 51, 56, .07)}html,body{background:var(--bg)}body{background-image:none;overscroll-behavior-y:auto}.app-layout{display:grid;grid-template-columns:252px minmax(0,1fr);width:100%;min-height:100dvh}.desktop-sidebar{position:sticky;top:0;z-index:50;display:flex;flex-direction:column;width:252px;height:100dvh;padding:22px 15px;background:#152326;color:#eefafa}.desktop-sidebar__brand{display:grid;grid-template-columns:42px 1fr;align-items:center;gap:10px;padding:3px 6px 24px}.desktop-sidebar__brand>span{display:grid;width:42px;height:42px;place-items:center;border-radius:var(--radius);background:var(--accent);color:#062f2d;font-weight:950}.desktop-sidebar__brand strong,.desktop-sidebar__brand small{display:block}.desktop-sidebar__brand strong{font-size:14px}.desktop-sidebar__brand small{margin-top:3px;color:#8fa5a8;font-size:9px}.desktop-sidebar__nav{display:grid;gap:5px}.desktop-sidebar__nav button{display:flex;align-items:center;gap:11px;width:100%;min-height:47px;border:1px solid transparent;border-radius:var(--radius);background:transparent;color:#a9bbbe;padding:10px 12px;font-size:13px;font-weight:750;text-align:left;cursor:pointer}.desktop-sidebar__nav button:hover{background:#ffffff0d;color:#fff}.desktop-sidebar__nav button.is-active{border-color:#16b8b252;background:#16b8b229;color:#74e1dc}.desktop-sidebar__note{margin:auto 8px 0;color:#829699;font-size:10px;line-height:1.5}.app-shell{width:100%;max-width:none;min-height:100dvh;margin:0;padding:0;background:var(--bg);overflow:visible}.app-main{width:100%;max-width:1680px;margin:0 auto;padding:28px 30px 48px;overflow:visible}.app-header,.bottom-nav{display:none}.page-stack{gap:16px;overflow:visible}.card{background:var(--surface);box-shadow:var(--shadow);padding:18px}input,select,textarea{border-color:var(--line);background:#fff;color:var(--text)}.segmented{border-color:var(--line);background:var(--surface-2)}.segmented button{color:var(--muted)}.segmented button.is-active{background:var(--accent);color:#063b39}.summary-card,.time-input,.template-button,.editable-item,.switch-row,.expense-row,.calendar-day,.month-calendar-day{background:var(--surface-2)}.summary-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.desktop-summary-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.summary-card{min-height:104px}.summary-card strong{font-size:22px}.sticky-actions{position:static;background:var(--surface)}.input-page .time-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.input-page .toggle-grid,.template-scroller{grid-template-columns:repeat(3,minmax(0,1fr))}.records-table th{background:var(--surface-2)}.toast{bottom:28px}.desktop-attendance-switch,.desktop-mode-switch{max-width:420px;margin:0 0 16px}.desktop-report-page>.page-stack{gap:16px}}@media(min-width:1180px){.dashboard-highlight-grid,.dashboard-planning-grid,.dashboard-chart-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.dashboard-chart-grid>:nth-child(5){grid-column:1 / -1}}@media(min-width:1280px){.kpi-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}@media(max-width:767px){.fixed-cost-list article{grid-template-columns:1fr}.fixed-cost-list__actions{flex-wrap:wrap}.action-row{display:grid;grid-template-columns:1fr}}
