:root{font-family:Inter,Noto Sans SC,PingFang SC,system-ui,-apple-system,sans-serif;color:#202124;background:#edf0f5;font-synthesis:none;text-rendering:optimizeLegibility;--blue: #1769e0;--blue-soft: #e8f0fe;--green: #1e8e5a;--amber: #e59600;--red: #d93025;--text: #202124;--muted: #6f7378;--line: #e1e5ea;--surface: #ffffff;--background: #f7f8fc}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%}body{background:#edf0f5}button,input{font:inherit;letter-spacing:0}button{-webkit-tap-highlight-color:transparent}.app-shell{position:relative;width:100%;max-width:480px;min-height:100dvh;margin:0 auto;background:var(--background);box-shadow:0 0 40px #20212414;overflow:hidden}.app-shell-today{--blue: #2f75ff;--blue-soft: #ecf2ff;--text: #243052;--muted: #8b93a7;--line: #e8ecf5;--background: #f3f6ff;color:#243052;background:radial-gradient(circle at 18% 12%,rgba(47,117,255,.12),transparent 28%),radial-gradient(circle at 86% 4%,rgba(47,117,255,.1),transparent 22%),linear-gradient(180deg,#f8faff,#f3f6ff);box-shadow:0 26px 70px #1e34622e}.page-scroll{min-height:100dvh;padding:max(26px,env(safe-area-inset-top)) 20px calc(96px + env(safe-area-inset-bottom))}.loading-screen{display:grid;place-content:center;justify-items:center;gap:12px;color:var(--blue)}.loading-screen p{margin:0;color:var(--muted)}.topbar{min-height:58px;display:flex;align-items:center;justify-content:space-between}.topbar h1{margin:2px 0 0;font-size:28px;line-height:1.15;font-weight:650}.eyebrow{margin:0;color:var(--blue);font-size:11px;line-height:1;font-weight:750;letter-spacing:.12em}.icon-button{width:44px;height:44px;border:0;border-radius:50%;display:grid;place-items:center;background:transparent;color:#4b5056;cursor:pointer}.icon-button:hover{background:#e9edf3}.icon-button svg{width:21px;height:21px}.icon-button.small{width:38px;height:38px;background:#f0f3f8}.icon-button:disabled{opacity:.45}.date-line{margin-top:18px;display:flex;align-items:center;justify-content:space-between;color:var(--muted);font-size:14px}.status{padding:4px 8px;border-radius:6px;font-size:12px;font-weight:600}.status.work{color:#156044;background:#e2f4ea}.status.rest{color:#765600;background:#fff2cf}.today-page{color:#243052}.today-hero{padding-top:58px}.today-hero h1{margin:0;max-width:310px;color:#243052;font-size:36px;font-weight:760;line-height:1.16;letter-spacing:0}.today-hero h1 span{display:block;margin-bottom:2px;font-weight:420}.today-date-line{margin-top:43px;display:flex;align-items:center;justify-content:space-between;color:#2b2c2d;font-size:16px}.today-pill{min-width:94px;height:27px;padding:3px 16px 0;border-radius:12px;background:#ecf2ff;color:#5e98ff;text-align:center;white-space:nowrap}.today-pill.rest{background:#fff4da;color:#a46d00}.hero-worktime{position:relative;margin-top:18px;min-height:398px;padding:55px 24px 60px;overflow:hidden;border:1px solid rgba(255,255,255,.9);border-radius:24px;background:radial-gradient(circle at 98% 6%,rgba(47,117,255,.1) 0 88px,transparent 90px),linear-gradient(145deg,#ffffffe6,#ffffff9e);box-shadow:0 18px 40px #2a54aa17;text-align:center}.today-state{display:inline-flex;align-items:center;justify-content:center;gap:5px;color:#7d8597;font-size:16px}.today-state i{width:10px;height:10px;border-radius:50%;background:#b8c0ce;box-shadow:0 0 0 6px #b8c0ce29}.today-state.working i,.today-state.complete i{background:#37c96f;box-shadow:0 0 0 6px #37c96f29}.today-state.leave i{background:#e59600;box-shadow:0 0 0 6px #e5960029}.duration-line{margin-top:10px;display:flex;align-items:center;justify-content:center;gap:8px}.duration-line strong{color:#202942;font-size:clamp(54px,17vw,64px);font-weight:520;line-height:1.1;letter-spacing:0;font-variant-numeric:tabular-nums}.edit-duration{width:28px;height:28px;margin-top:8px;border:0;border-radius:50%;display:grid;place-items:center;background:transparent;color:#9aa8c5;cursor:pointer}.edit-duration svg{width:18px;height:18px}.time-range{margin:36px auto 0;display:grid;grid-template-columns:52px minmax(110px,1fr) 52px;align-items:center;gap:12px;max-width:250px}.time-range span{color:#35415f;font-size:16px;font-variant-numeric:tabular-nums;white-space:nowrap}.range-track{height:7px;overflow:hidden;border-radius:999px;background:#dfe5ef}.range-track i{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#3980ff,#7aa7ff);transition:width .35s ease}.clock-button{width:100%;min-height:62px;margin:73px auto 0;border:0;border-radius:21px;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#3479ff,#2357e8);color:#fff;font-size:20px;font-weight:720;box-shadow:0 16px 30px #245be838;cursor:pointer}.clock-button:active{transform:translateY(1px);box-shadow:0 8px 16px #245be833}.clock-button:disabled{background:linear-gradient(180deg,#aeb7c9,#8d97a9);box-shadow:none}.trend-section{margin-top:25px;min-height:262px;padding:25px 24px 26px;border:1px solid rgba(255,255,255,.9);border-radius:24px;background:#ffffffb8;box-shadow:0 18px 40px #2a54aa14}.section-heading{display:flex;align-items:flex-start;justify-content:space-between}.section-heading h2{margin:0;color:#222b45;font-size:20px;font-weight:520;letter-spacing:0}.section-heading p{margin:5px 0 0;color:var(--muted);font-size:12px}.average{text-align:right}.average span{display:block;color:var(--muted);font-size:11px}.average strong{color:#222b45;font-size:20px;font-weight:520;font-variant-numeric:tabular-nums;white-space:nowrap}.bar-chart{height:132px;margin-top:22px;padding:4px 0 18px;display:grid;grid-template-columns:repeat(31,minmax(4px,1fr));align-items:end;gap:4px;border-bottom:0}.bar-column{position:relative;height:100px;display:flex;align-items:flex-end;justify-content:center}.bar-column i{width:100%;max-width:5px;min-height:3px;border-radius:8px 8px 1px 1px;background:#d5dae3}.bar-column i.worked{background:linear-gradient(180deg,#4b8cff,#1f6eea)}.bar-column i.rest{background:#d5dae3}.bar-column i.leave{background:var(--amber)}.bar-column i.missing{background:var(--red)}.bar-column span{position:absolute;top:108px;color:#a4abba;font-size:12px}.bar-column.current span{color:var(--blue);font-weight:700}.bottom-nav{position:fixed;z-index:10;left:50%;bottom:0;width:min(100%,480px);height:calc(72px + env(safe-area-inset-bottom));padding:4px 12px env(safe-area-inset-bottom);display:grid;grid-template-columns:repeat(3,1fr);background:#fffffff0;border-top:1px solid var(--line);transform:translate(-50%);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.bottom-nav button{border:0;background:transparent;color:#73777d;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;cursor:pointer}.bottom-nav svg{width:21px;height:21px}.bottom-nav span{font-size:11px}.bottom-nav button.active{color:var(--blue);font-weight:650}.app-shell-today .bottom-nav{height:calc(78px + env(safe-area-inset-bottom));padding:5px 12px env(safe-area-inset-bottom);background:#ffffffdb;border-top-color:#dbe1ed;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.app-shell-today .bottom-nav button{color:#8b93a7}.app-shell-today .bottom-nav svg{width:23px;height:23px;stroke-width:2.1}.app-shell-today .bottom-nav button.active{color:#0877ff;font-weight:720}.calendar-topbar{justify-content:center;gap:16px}.calendar-topbar h1{min-width:148px;text-align:center;font-size:22px}.calendar-warning{margin:16px 0;padding:14px;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;border-left:3px solid var(--amber);background:#fff8e8}.calendar-warning svg{color:#8a6200;width:21px}.calendar-warning strong{font-size:13px}.calendar-warning p{margin:3px 0 0;color:var(--muted);font-size:11px}.text-button{border:0;color:var(--blue);background:transparent;font-size:13px;font-weight:650}.stats-strip{margin:18px -20px 22px;padding:18px 20px;display:grid;grid-template-columns:1.5fr repeat(4,1fr);gap:8px;background:#edf3fc}.stats-strip div{min-width:0;display:flex;flex-direction:column;gap:5px}.stats-strip span{color:var(--muted);font-size:10px;white-space:nowrap}.stats-strip strong{font-size:14px;white-space:nowrap}.stats-strip .primary-stat strong{color:var(--blue);font-size:19px}.danger-text{color:var(--red)}.weekday-row,.month-grid{display:grid;grid-template-columns:repeat(7,1fr)}.weekday-row{margin-bottom:8px}.weekday-row span{text-align:center;color:var(--muted);font-size:11px}.month-grid{border-top:1px solid var(--line);border-left:1px solid var(--line)}.calendar-cell{position:relative;min-width:0;height:64px;padding:7px 2px 5px;border:0;border-right:1px solid var(--line);border-bottom:1px solid var(--line);background:#ffffffb8;display:flex;flex-direction:column;align-items:center;gap:4px;color:var(--text);cursor:pointer}.calendar-cell.blank{background:transparent}.calendar-cell>span{width:24px;height:24px;display:grid;place-items:center;border-radius:50%;font-size:12px}.calendar-cell.today>span{background:var(--blue);color:#fff;font-weight:700}.calendar-cell i,.legend i{width:6px;height:6px;border-radius:50%;background:#d2d6db}.calendar-cell i.worked,.legend i.worked{background:var(--blue)}.calendar-cell i.leave,.legend i.leave{background:var(--amber)}.calendar-cell i.missing,.legend i.missing{background:var(--red)}.calendar-cell i.extra,.legend i.extra{background:var(--green)}.calendar-cell i.holiday{background:#9aa0a6}.calendar-cell small{max-width:100%;overflow:hidden;color:var(--muted);font-size:8px;text-overflow:ellipsis;white-space:nowrap}.legend{margin-top:14px;display:flex;flex-wrap:wrap;justify-content:center;gap:14px;color:var(--muted);font-size:10px}.legend span{display:flex;align-items:center;gap:5px}.settings-page .topbar{margin-bottom:28px}.settings-section{padding:22px 0;border-top:1px solid var(--line)}.settings-section h2{margin:0;font-size:17px}.settings-section p{margin:5px 0 0;color:var(--muted);font-size:12px;line-height:1.55}.settings-title{display:flex;gap:12px}.settings-title>svg{color:var(--blue);width:21px}.calendar-list{margin-top:18px}.setting-row{min-height:58px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--line)}.setting-row>div{display:flex;flex-direction:column;gap:4px}.setting-row strong{font-size:14px}.setting-row span{color:var(--muted);font-size:11px}.data-section{margin-top:12px;display:flex;align-items:center;justify-content:space-between;gap:18px}.danger-button{flex:0 0 auto;height:42px;padding:0 14px;border:1px solid #f0c4c0;border-radius:6px;background:#fff7f6;color:var(--red);display:flex;align-items:center;gap:7px;font-size:12px;font-weight:650}.danger-button svg{width:17px}.privacy-note{margin-top:32px;display:flex;align-items:center;justify-content:center;gap:7px;color:var(--muted);font-size:11px}.privacy-note svg{width:15px;color:var(--green)}.sheet-backdrop{position:absolute;z-index:30;top:0;right:0;bottom:0;left:0;display:flex;align-items:flex-end;background:#161c2461}.record-sheet{width:100%;padding:8px 20px calc(24px + env(safe-area-inset-bottom));border-radius:12px 12px 0 0;background:var(--surface);box-shadow:0 -12px 40px #14191f29;animation:sheet-up .22s ease-out}.sheet-handle{width:34px;height:4px;margin:0 auto 12px;border-radius:2px;background:#c7cbd0}.record-sheet header{display:flex;align-items:center;justify-content:space-between}.record-sheet h2{margin:0;font-size:20px}.record-sheet header p{margin:4px 0 0;color:var(--muted);font-size:12px}.time-inputs{margin:24px 0;display:grid;grid-template-columns:1fr auto 1fr;align-items:end;gap:8px}.time-inputs>svg{width:18px;margin-bottom:13px;color:var(--muted)}.time-inputs label{display:flex;flex-direction:column;gap:7px;color:var(--muted);font-size:11px}.time-inputs input{width:100%;height:48px;border:1px solid var(--line);border-radius:6px;padding:0 8px;background:#fafbfc;color:var(--text);font-size:16px}.field-group>span{display:block;margin-bottom:8px;color:var(--muted);font-size:11px}.segmented-control{padding:3px;display:grid;grid-template-columns:repeat(4,1fr);border-radius:7px;background:#edf0f4}.segmented-control button{height:36px;border:0;border-radius:5px;background:transparent;color:#5e636a;font-size:12px}.segmented-control button.active{background:#fff;color:var(--blue);font-weight:650;box-shadow:0 1px 3px #20212421}.duration-preview{margin-top:18px;display:flex;align-items:center;gap:7px;color:var(--muted);font-size:12px}.duration-preview svg{width:16px}.form-error{margin:14px 0 0;color:var(--red);font-size:12px}.sheet-actions{margin-top:24px;display:flex;gap:10px}.delete-icon{width:52px;border:1px solid #f0c4c0;border-radius:7px;display:grid;place-items:center;background:#fff7f6;color:var(--red)}.delete-icon svg{width:19px}.save-button{flex:1;height:52px;border:0;border-radius:7px;background:var(--blue);color:#fff;font-weight:650}.snackbar{position:absolute;z-index:50;left:50%;bottom:calc(84px + env(safe-area-inset-bottom));transform:translate(-50%);min-width:210px;max-width:calc(100% - 40px);min-height:46px;padding:10px 16px;border-radius:6px;background:#303238;color:#fff;display:flex;align-items:center;justify-content:center;gap:8px;font-size:12px;box-shadow:0 6px 18px #00000038;animation:snack 2.6s both}.snackbar svg{flex:0 0 auto;color:#8dd6ad}.spin{animation:spin 1s linear infinite}@keyframes sheet-up{0%{transform:translateY(28px);opacity:.5}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes snack{0%{opacity:0;transform:translate(-50%,8px)}10%,85%{opacity:1;transform:translate(-50%)}to{opacity:0}}@media(max-width:360px){.page-scroll{padding-left:14px;padding-right:14px}.stats-strip{margin-left:-14px;margin-right:-14px;padding-left:14px;padding-right:14px;gap:5px}.stats-strip strong{font-size:12px}.calendar-cell{height:60px}}@media(min-width:700px){.app-shell{min-height:900px;margin-top:24px;margin-bottom:24px;border-radius:8px}.sheet-backdrop{position:absolute}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important}}
