:root{--bg:#f7f4ee;--bg-warm:#fbf8f2;--surface:#ffffff;--surface-soft:#fcfaf6;--green:#5b8c6e;--green-deep:#46735a;--green-soft:#e8f1ea;--green-tint:#f1f7f2;--apricot:#e8956b;--apricot-soft:#fbe9dd;--ink:#3b3a36;--ink-soft:#6f6c64;--ink-faint:#a39f95;--line:#ece7dd;--done:#5b8c6e;--done-bg:#e8f1ea;--wip:#d98a4e;--wip-bg:#fbe9dd;--r-sm:10px;--r-md:16px;--r-lg:22px;--r-xl:28px;--shadow-sm:0 2px 8px rgba(91,140,110,.07),0 1px 2px rgba(59,58,54,.04);--shadow-md:0 8px 24px rgba(91,140,110,.1),0 2px 6px rgba(59,58,54,.05);--shadow-lg:0 18px 48px rgba(91,140,110,.14),0 4px 12px rgba(59,58,54,.06);--font-display:"Zen Maru Gothic",sans-serif;--font-body:"Zen Kaku Gothic New",sans-serif}*{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{font-family:var(--font-body);color:var(--ink);line-height:1.7;min-height:100vh;background:radial-gradient(1200px 600px at 85% -10%,#f0f5ee 0%,transparent 60%),radial-gradient(900px 500px at -5% 110%,#fbeee2 0%,transparent 55%),var(--bg);background-attachment:fixed;-webkit-font-smoothing:antialiased}.reveal{opacity:0;transform:translateY(14px);animation:rise .6s cubic-bezier(.2,.7,.3,1) forwards}@keyframes rise{to{opacity:1;transform:none}}.d1{animation-delay:.05s}.d2{animation-delay:.13s}.d3{animation-delay:.21s}.d4{animation-delay:.29s}.d5{animation-delay:.37s}.d6{animation-delay:.45s}.d7{animation-delay:.53s}@keyframes breathe{0%,to{box-shadow:0 0 #ffffff8c;opacity:.95}50%{box-shadow:0 0 0 7px #fff0;opacity:1}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}.reveal{opacity:1;transform:none}}.brand{display:flex;align-items:center;gap:11px;padding:6px 10px 26px}.brand-mark{width:42px;height:42px;border-radius:13px;flex-shrink:0;background:linear-gradient(145deg,var(--green) 0%,var(--green-deep) 100%);display:grid;place-items:center;color:#fff;box-shadow:var(--shadow-sm)}.brand-mark svg{width:23px;height:23px}.brand-name{font-family:var(--font-display);font-weight:700;font-size:1.12rem;letter-spacing:.02em;line-height:1.25}.brand-sub{font-size:.66rem;color:var(--ink-faint);letter-spacing:.16em}.nav-link{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:var(--r-md);color:var(--ink-soft);text-decoration:none;font-weight:500;font-size:.94rem;transition:background .18s,color .18s,transform .18s}.nav-link svg{width:20px;height:20px;flex-shrink:0;opacity:.85}.nav-link:hover{background:var(--surface-soft);color:var(--ink);transform:translate(2px)}.nav-link.active{background:var(--green-soft);color:var(--green-deep);font-weight:700}.nav-link.active svg{opacity:1}.side-foot{margin-top:auto;padding:14px 12px;border-top:1px solid var(--line)}.user-chip{display:flex;align-items:center;gap:10px}.avatar{width:34px;height:34px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,#e8956b,#e6b87f);color:#fff;display:grid;place-items:center;font-family:var(--font-display);font-weight:700;font-size:.85rem}.user-name{font-size:.86rem;font-weight:500}.user-role{font-size:.68rem;color:var(--ink-faint)}.page-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:24px}.greet{font-family:var(--font-display);font-weight:700;font-size:1.7rem;line-height:1.3}.greet .accent{color:var(--green)}.greet-sub{color:var(--ink-soft);font-size:.92rem;margin-top:2px}.today-pill{display:inline-flex;align-items:center;gap:7px;background:var(--surface);border:1px solid var(--line);padding:7px 15px;border-radius:999px;font-size:.82rem;color:var(--ink-soft);box-shadow:var(--shadow-sm)}.today-pill b{color:var(--green-deep);font-family:var(--font-display)}.date-nav{display:flex;align-items:center;gap:12px;background:var(--surface);border-radius:var(--r-lg);padding:10px 14px;box-shadow:var(--shadow-sm);margin-bottom:26px}.date-arrow{width:40px;height:40px;border-radius:13px;border:none;cursor:pointer;flex-shrink:0;background:var(--surface-soft);color:var(--ink-soft);font-size:1.15rem;display:grid;place-items:center;transition:.18s}.date-arrow:hover:not(:disabled){background:var(--green-soft);color:var(--green-deep);transform:scale(1.05)}.date-arrow:disabled{opacity:.32;cursor:default}.date-label{flex:1;text-align:center;font-family:var(--font-display);font-weight:700;font-size:1.15rem}.date-label .tag{font-family:var(--font-body);font-size:.72rem;font-weight:700;background:var(--apricot-soft);color:var(--apricot);padding:2px 9px;border-radius:999px;margin-left:8px;vertical-align:middle}.btn-today{border:1px solid var(--line);background:var(--surface-soft);cursor:pointer;padding:7px 16px;border-radius:11px;font-size:.82rem;font-weight:700;color:var(--ink-soft);font-family:var(--font-body);transition:.18s}.btn-today:hover{background:var(--green-soft);color:var(--green-deep);border-color:transparent}.day-bar{margin:-12px 0 26px}.day-bar-track{position:relative;height:46px;border-radius:14px;background:var(--surface-soft);border:1px solid var(--line);box-shadow:inset 0 1px 2px #3c32280a;overflow:hidden}.dbt-grid{position:absolute;top:0;bottom:0;width:1px;background:var(--line);opacity:.55}.dbt-empty{position:absolute;inset:0;display:grid;place-items:center;font-size:.78rem;color:var(--ink-faint);pointer-events:none}.dbt-seg{position:absolute;top:6px;bottom:6px;min-width:5px;padding:0;border:none;border-radius:7px;cursor:pointer;transition:filter .14s,transform .14s,box-shadow .14s}.dbt-seg.done{background:linear-gradient(180deg,#7fb592 0%,var(--green-deep) 100%);box-shadow:0 1px 3px #5b8c6e59}.dbt-seg.wip{background:repeating-linear-gradient(45deg,var(--apricot) 0,var(--apricot) 6px,#e79a6d 6px,#e79a6d 12px);box-shadow:0 1px 3px #d88a4e59}.dbt-seg:hover{filter:brightness(1.07);transform:translateY(-1px);box-shadow:0 4px 10px #3c32282e;z-index:3}.dbt-seg:focus-visible{outline:2px solid var(--green-deep);outline-offset:2px}.dbt-now{position:absolute;top:-1px;bottom:-1px;width:2px;background:var(--ink);z-index:2}.dbt-now:before{content:"";position:absolute;top:-3px;left:50%;transform:translate(-50%);width:8px;height:8px;border-radius:50%;background:var(--ink)}.day-bar-axis{position:relative;height:15px;margin-top:5px}.dba-tick{position:absolute;top:0;font-size:.68rem;color:var(--ink-faint);font-variant-numeric:tabular-nums;line-height:1}.active-card{position:relative;overflow:hidden;background:linear-gradient(135deg,#fff,#f6fbf7);border:1.5px solid #d9ebde;border-radius:var(--r-xl);padding:26px 28px;box-shadow:var(--shadow-md);margin-bottom:26px}.active-card:before{content:"";position:absolute;top:-40%;right:-8%;width:280px;height:280px;background:radial-gradient(circle,rgba(91,140,110,.1) 0%,transparent 70%);pointer-events:none}.active-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.live-badge{display:inline-flex;align-items:center;gap:9px;background:var(--green);color:#fff;padding:8px 16px 8px 13px;border-radius:999px;font-weight:700;font-size:.9rem;box-shadow:0 4px 14px #5b8c6e4d}.live-dot{width:10px;height:10px;border-radius:50%;background:#fff;box-shadow:0 0 #ffffffb3;animation:breathe 2.4s ease-in-out infinite}.elapsed-num{font-family:var(--font-display);font-weight:700;letter-spacing:.01em}.sub-badge{display:inline-grid;place-items:center;min-width:34px;height:34px;padding:0 8px;background:var(--surface);border:1.5px solid var(--green-soft);border-radius:11px;font-family:var(--font-display);font-weight:700;font-size:.9rem;color:var(--green-deep)}.active-body{position:relative;z-index:1}.active-cat{font-family:var(--font-display);font-weight:700;font-size:1.35rem;color:var(--ink);margin-bottom:3px}.active-content{font-size:1.02rem;color:var(--ink-soft);margin-bottom:8px}.active-order{display:inline-flex;align-items:center;gap:6px;font-size:.84rem;color:var(--green-deep);background:var(--green-tint);padding:4px 11px;border-radius:999px;font-weight:500}.active-actions{display:flex;justify-content:flex-end;align-items:center;gap:10px;margin-top:18px}.btn-edit-active{display:inline-flex;align-items:center;gap:7px;background:var(--surface-soft);color:var(--ink-soft);border:1.5px solid var(--line);cursor:pointer;padding:12px 22px;border-radius:15px;font-size:.96rem;font-weight:700;font-family:var(--font-display);transition:.16s}.btn-edit-active:hover{border-color:var(--green);color:var(--green-deep);background:var(--green-soft);transform:translateY(-1px)}.btn-edit-active:active{transform:translateY(0)}.btn-edit-active .bea-icon{font-size:.92rem;line-height:1}.btn-end{background:linear-gradient(135deg,var(--apricot) 0%,#dd7e54 100%);color:#fff;border:none;cursor:pointer;padding:13px 30px;border-radius:15px;font-size:1rem;font-weight:700;font-family:var(--font-display);box-shadow:0 6px 18px #d88a4e52;transition:transform .16s,box-shadow .16s}.btn-end:hover{transform:translateY(-2px);box-shadow:0 10px 26px #d88a4e66}.btn-end:active{transform:translateY(0)}.section-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin:34px 2px 14px}.sh-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.section-title{font-family:var(--font-display);font-weight:700;font-size:1.18rem;display:flex;align-items:center;gap:9px}.section-title .leaf{color:var(--green)}.btn-ghost{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--line);background:var(--surface);cursor:pointer;padding:8px 15px;border-radius:12px;font-size:.84rem;font-weight:700;color:var(--ink-soft);font-family:var(--font-body);transition:.18s;box-shadow:var(--shadow-sm)}.btn-ghost:hover{background:var(--green-soft);color:var(--green-deep);transform:translateY(-1px)}.btn-ghost svg{width:16px;height:16px}.timeline{position:relative;padding-left:6px}.log-row{display:flex;gap:18px;align-items:stretch;background:var(--surface);border-radius:var(--r-md);padding:16px 20px;box-shadow:var(--shadow-sm);margin-bottom:12px;transition:transform .16s,box-shadow .16s}.log-row:hover{transform:translate(3px);box-shadow:var(--shadow-md)}.log-time{flex-shrink:0;width:118px;display:flex;flex-direction:column;justify-content:center;border-right:1px solid var(--line);padding-right:16px}.log-time .range{font-family:var(--font-display);font-weight:700;font-size:.96rem;color:var(--ink)}.log-time .dur{font-size:.72rem;color:var(--ink-faint);margin-top:1px}.log-mid{flex:1;display:flex;flex-direction:column;justify-content:center;gap:3px}.log-cat-line{display:flex;align-items:center;gap:9px;flex-wrap:wrap}.log-cat{font-family:var(--font-display);font-weight:700;font-size:1.02rem}.log-content{color:var(--ink-soft);font-size:.94rem}.log-order{font-size:.78rem;color:var(--green-deep);background:var(--green-tint);padding:2px 9px;border-radius:999px;display:inline-block;width:fit-content;font-weight:500}.log-acts{flex-shrink:0;align-self:center;display:flex;align-items:center;gap:7px}.log-edit,.log-del{background:var(--surface-soft);border:1px solid var(--line);cursor:pointer;color:var(--ink-soft);width:38px;height:38px;border-radius:12px;display:grid;place-items:center;font-size:16px;line-height:1;transition:.16s}.log-edit:hover{background:var(--green-soft);border-color:var(--green);color:var(--green-deep);transform:translateY(-1px)}.log-del:hover{background:#fcefe9;border-color:transparent;color:var(--apricot);transform:translateY(-1px)}.log-edit:active,.log-del:active{transform:translateY(0)}.log-del svg{width:17px;height:17px}.empty{text-align:center;padding:48px 20px;color:var(--ink-faint);background:var(--surface-soft);border-radius:var(--r-lg);border:1.5px dashed var(--line)}.empty .emoji{font-size:2rem;display:block;margin-bottom:8px}.title{font-family:var(--font-display);font-weight:700;font-size:1.7rem;display:flex;align-items:center;gap:11px}.title .leaf{color:var(--green)}.title small{display:block;font-family:var(--font-body);font-weight:400;font-size:.84rem;color:var(--ink-soft)}.btn-export{display:inline-flex;align-items:center;gap:9px;background:linear-gradient(135deg,var(--green) 0%,var(--green-deep) 100%);color:#fff;border:none;cursor:pointer;padding:13px 24px;border-radius:15px;font-size:.96rem;font-weight:700;font-family:var(--font-display);box-shadow:0 8px 20px #5b8c6e47;transition:transform .15s,box-shadow .15s}.btn-export:hover{transform:translateY(-2px);box-shadow:0 12px 28px #5b8c6e57}.btn-export svg{width:19px;height:19px}.toolbar{display:flex;align-items:center;gap:16px;flex-wrap:wrap;background:var(--surface);border-radius:var(--r-lg);padding:14px 18px;box-shadow:var(--shadow-sm);margin-bottom:24px}.month-pick{display:flex;align-items:center;gap:10px}.month-pick label{font-size:.84rem;font-weight:700;color:var(--ink-soft);display:flex;align-items:center;gap:7px}.month-pick label svg{width:17px;height:17px;stroke:var(--green)}.month-nav-grp{display:flex;align-items:center;gap:6px}.month-arrow{width:36px;height:36px;border-radius:11px;border:none;background:var(--surface-soft);color:var(--ink-soft);cursor:pointer;display:grid;place-items:center;font-size:1.05rem;transition:.16s}.month-arrow:hover{background:var(--green-soft);color:var(--green-deep)}.month-val{font-family:var(--font-display);font-weight:700;font-size:1.1rem;min-width:140px;text-align:center}.tb-spacer{flex:1}.stat{display:flex;gap:22px;flex-wrap:wrap}.stat-item{text-align:right}.stat-item .v{font-family:var(--font-display);font-weight:700;font-size:1.2rem;color:var(--green-deep);line-height:1.1}.stat-item .l{font-size:.7rem;color:var(--ink-faint)}.day-group{margin-bottom:22px}.day-label{display:flex;align-items:center;gap:10px;margin:0 4px 11px}.day-label .dnum{font-family:var(--font-display);font-weight:900;font-size:1.05rem;color:var(--ink)}.day-label .dwk{font-size:.78rem;color:var(--ink-faint)}.day-label .dline{flex:1;height:1px;background:var(--line)}.day-label .dtotal{font-size:.74rem;color:var(--green-deep);background:var(--green-tint);padding:2px 11px;border-radius:999px;font-weight:700}.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:14px}.log-card{background:var(--surface);border-radius:var(--r-lg);padding:18px 20px;box-shadow:var(--shadow-sm);border:1px solid var(--line);transition:transform .16s,box-shadow .16s;display:flex;flex-direction:column;gap:7px}.log-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.lc-top{display:flex;align-items:center;justify-content:space-between;gap:10px}.lc-time{font-family:var(--font-display);font-weight:700;font-size:.98rem;display:flex;align-items:center;gap:8px}.lc-time .sub-badge{display:inline-grid;place-items:center;min-width:30px;height:30px;padding:0 7px;background:var(--green-tint);border:1.5px solid var(--green-soft);border-radius:10px;font-family:var(--font-display);font-weight:700;font-size:.82rem;color:var(--green-deep)}.status{font-size:.74rem;font-weight:700;padding:4px 12px;border-radius:999px;display:inline-flex;align-items:center;gap:5px;font-family:var(--font-body)}.status.done{background:var(--done-bg);color:var(--done)}.status.wip{background:var(--wip-bg);color:var(--wip)}.status .sdot{width:7px;height:7px;border-radius:50%;background:currentColor}.lc-cat{font-family:var(--font-display);font-weight:700;font-size:1.1rem;margin-top:2px}.lc-content{color:var(--ink-soft);font-size:.92rem}.lc-meta{display:flex;flex-wrap:wrap;gap:7px;margin-top:2px}.lc-order{font-size:.76rem;color:var(--green-deep);background:var(--green-tint);padding:3px 11px;border-radius:999px;font-weight:500}.lc-remarks{font-size:.78rem;color:var(--ink-soft);background:var(--surface-soft);border-left:3px solid var(--apricot-soft);padding:6px 11px;border-radius:0 9px 9px 0;margin-top:3px}.lc-actions{display:flex;gap:8px;margin-top:9px;padding-top:11px;border-top:1px solid var(--line)}.lc-btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid var(--line);background:var(--surface-soft);cursor:pointer;padding:9px;border-radius:11px;font-size:.82rem;font-weight:700;color:var(--ink-soft);font-family:var(--font-body);transition:.16s}.lc-btn svg{width:14px;height:14px}.lc-btn.edit:hover{background:var(--green-soft);color:var(--green-deep);border-color:transparent}.lc-btn.del:hover{background:#fcefe9;color:var(--apricot);border-color:transparent}.topbar{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:16px 18px 12px;background:linear-gradient(180deg,var(--bg) 70%,rgba(247,244,238,0));backdrop-filter:blur(6px)}.tabbar{position:fixed;bottom:0;left:0;right:0;z-index:60;display:flex;justify-content:space-around;background:#ffffffeb;backdrop-filter:blur(12px);border-top:1px solid var(--line);padding:8px 8px calc(8px + env(safe-area-inset-bottom,0px));box-shadow:0 -6px 24px #3b3a360d}.tab{display:flex;flex-direction:column;align-items:center;gap:3px;text-decoration:none;color:var(--ink-faint);font-size:.66rem;font-weight:700;padding:6px 14px;border-radius:13px}.tab svg{width:23px;height:23px}.tab.active{color:var(--green-deep)}.tab.active svg{stroke:var(--green)}.btn-start{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;background:linear-gradient(135deg,var(--green) 0%,var(--green-deep) 100%);color:#fff;border:none;cursor:pointer;padding:20px;border-radius:var(--r-lg);font-size:1.18rem;font-weight:700;font-family:var(--font-display);box-shadow:0 10px 26px #5b8c6e4d;margin-bottom:8px;transition:transform .15s}.btn-start:active{transform:scale(.985)}.btn-start svg{width:24px;height:24px}.form-card{background:var(--surface);border-radius:var(--r-xl);padding:20px 18px;box-shadow:var(--shadow-md);border:1px solid var(--line);margin-bottom:18px}.form-head{font-family:var(--font-display);font-weight:700;font-size:1.05rem;margin-bottom:14px;display:flex;align-items:center;gap:8px}.field{margin-bottom:14px}.field label{display:block;font-size:.8rem;font-weight:700;color:var(--ink-soft);margin-bottom:6px}.field-row{display:flex;gap:10px}.field-row .field{flex:1;margin-bottom:0}select,input[type=text]{width:100%;font-family:var(--font-body);font-size:1rem;color:var(--ink);background:var(--surface-soft);border:1.5px solid var(--line);border-radius:13px;padding:13px 14px;transition:border-color .16s,box-shadow .16s;-webkit-appearance:none;appearance:none}select{background-image:url("data:image/svg+xml;charset=UTF-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236f6c64' stroke-width='2.4' stroke-linecap='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:38px}select:focus,input:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 4px var(--green-soft)}input::placeholder{color:var(--ink-faint)}.hint{font-size:.7rem;color:var(--ink-faint);margin-top:5px}.btn-submit{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;background:linear-gradient(135deg,var(--green),var(--green-deep));color:#fff;border:none;cursor:pointer;padding:16px;border-radius:15px;font-size:1.08rem;font-weight:700;font-family:var(--font-display);box-shadow:0 8px 20px #5b8c6e47;margin-top:6px}.btn-cancel{width:100%;background:none;border:none;cursor:pointer;color:var(--ink-faint);font-family:var(--font-body);font-size:.86rem;padding:12px;margin-top:6px}.sheet-overlay{position:fixed;inset:0;z-index:100;background:#3b3a366b;display:flex;align-items:flex-end;justify-content:center}.sheet{width:100%;max-width:412px;background:var(--surface);border-radius:var(--r-xl) var(--r-xl) 0 0;padding:8px 18px calc(20px + env(safe-area-inset-bottom,0px));max-height:84vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);animation:slideUp .34s cubic-bezier(.2,.75,.25,1)}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:none}}.sheet-grip{width:42px;height:5px;border-radius:99px;background:var(--line);margin:6px auto 14px}.sheet-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.sheet-title{font-family:var(--font-display);font-weight:700;font-size:1.08rem}.sheet-title small{display:block;font-family:var(--font-body);font-weight:400;font-size:.74rem;color:var(--ink-faint)}.sheet-close{background:var(--surface-soft);border:none;width:34px;height:34px;border-radius:50%;cursor:pointer;color:var(--ink-soft);font-size:1.1rem}.sheet-tools{display:flex;align-items:center;gap:10px;margin:10px 0 6px}.btn-selall{font-size:.78rem;font-weight:700;padding:6px 13px;border-radius:10px;border:1px solid var(--line);background:var(--surface-soft);color:var(--ink-soft);cursor:pointer;font-family:var(--font-body)}.sel-count{font-size:.78rem;color:var(--ink-faint)}.sel-count b{color:var(--green-deep)}.sheet-list{overflow-y:auto;flex:1;margin:6px -4px 4px;padding:0 4px}.copy-item{display:flex;align-items:flex-start;gap:12px;padding:13px 4px;border-bottom:1px solid var(--line);cursor:pointer}.copy-item:last-child{border-bottom:none}.cb{width:24px;height:24px;border-radius:8px;border:2px solid var(--line);flex-shrink:0;margin-top:1px;display:grid;place-items:center;transition:.14s;background:var(--surface)}.copy-item.on .cb{background:var(--green);border-color:var(--green)}.cb svg{width:14px;height:14px;stroke:#fff;opacity:0}.copy-item.on .cb svg{opacity:1}.btn-copy{width:100%;background:linear-gradient(135deg,var(--green),var(--green-deep));color:#fff;border:none;cursor:pointer;padding:16px;border-radius:15px;font-size:1.06rem;font-weight:700;font-family:var(--font-display);box-shadow:0 8px 20px #5b8c6e47;margin-top:12px}.dialog-overlay{position:fixed;inset:0;z-index:110;background:#2b2a268c;backdrop-filter:blur(3px);display:none;align-items:center;justify-content:center;padding:20px;animation:dlgFade .2s ease}.dialog-overlay.show{display:flex}.dialog{width:100%;max-width:412px;background:var(--surface);border-radius:var(--r-xl);padding:24px 20px calc(22px + env(safe-area-inset-bottom,0px));box-shadow:var(--shadow-lg);max-height:calc(100dvh - 40px);overflow-y:auto;animation:dlgPop .26s cubic-bezier(.2,.8,.25,1)}@keyframes dlgFade{0%{opacity:0}to{opacity:1}}@keyframes dlgPop{0%{opacity:0;transform:translateY(14px) scale(.96)}to{opacity:1;transform:none}}.time-stepper{display:flex;align-items:flex-start;justify-content:center;gap:5px;border:1.6px solid var(--line);border-radius:16px;background:var(--surface-soft);padding:5px 12px}.time-stepper .ts-unit{display:flex;flex-direction:column;align-items:center;padding:0;min-width:56px}.time-stepper .ts-arrow{appearance:none;border:none;background:none;cursor:pointer;color:var(--green-deep);font-size:.78rem;line-height:1;padding:5px 14px;border-radius:8px;transition:.14s;width:100%}.time-stepper .ts-arrow:hover{background:var(--green-soft);color:var(--green)}.time-stepper .ts-arrow:active{transform:scale(.9)}.time-stepper .ts-val{border:none;background:none;text-align:center;font-family:var(--font-display);font-weight:700;font-size:1.45rem;width:58px;color:var(--ink);padding:2px 0}.time-stepper .ts-val:focus{outline:none}.time-stepper .ts-cap{font-size:.66rem;color:var(--ink-faint);margin-top:1px}.time-stepper .ts-colon{font-family:var(--font-display);font-weight:700;font-size:1.45rem;color:var(--ink-soft);padding-top:23px}.time-stepper.disabled{opacity:.45}.time-stepper.disabled .ts-arrow{cursor:not-allowed}.ts-hint{font-size:.72rem;color:var(--ink-faint);font-weight:400}.field-row.time-row{gap:22px}.radio-group{display:flex;gap:10px;margin-bottom:16px}.radio-pill{flex:1;border:1.5px solid var(--line);border-radius:14px;padding:14px;text-align:center;cursor:pointer;font-weight:700;font-family:var(--font-display);color:var(--ink-soft);transition:.16s;background:var(--surface-soft)}.radio-pill.on{border-color:var(--green);background:var(--green-soft);color:var(--green-deep);box-shadow:0 0 0 3px var(--green-soft)}.radio-pill.on.wip{border-color:var(--apricot);background:var(--apricot-soft);color:var(--wip);box-shadow:0 0 0 3px var(--apricot-soft)}.dialog-actions{display:flex;gap:10px;margin-top:18px}.dialog-actions .btn-d-cancel{flex:0 0 36%;background:var(--surface-soft);border:1px solid var(--line);border-radius:15px;padding:15px;font-weight:700;color:var(--ink-soft);cursor:pointer;font-family:var(--font-body);font-size:.95rem}.dialog-actions .btn-d-save{flex:1;background:linear-gradient(135deg,var(--green),var(--green-deep));color:#fff;border:none;border-radius:15px;padding:15px;font-weight:700;font-family:var(--font-display);font-size:1.02rem;cursor:pointer;box-shadow:0 8px 20px #5b8c6e47}.month-bar{display:flex;align-items:center;gap:8px;background:var(--surface);border-radius:var(--r-lg);padding:8px 10px;box-shadow:var(--shadow-sm);margin-bottom:8px}.summary{display:flex;gap:8px;margin-bottom:18px;overflow-x:auto;padding:2px;scrollbar-width:none}.summary::-webkit-scrollbar{display:none}.sum-chip{flex:1;min-width:74px;background:var(--surface);border-radius:var(--r-md);padding:10px 12px;box-shadow:var(--shadow-sm);text-align:center}.sum-chip .v{font-family:var(--font-display);font-weight:700;font-size:1.18rem;color:var(--green-deep);line-height:1.1}.sum-chip .l{font-size:.66rem;color:var(--ink-faint)}.sum-chip.wip .v{color:var(--wip)}.icon-btn{width:40px;height:40px;border-radius:13px;border:none;background:var(--surface);box-shadow:var(--shadow-sm);display:grid;place-items:center;color:var(--ink-soft);text-decoration:none}.icon-btn svg{width:20px;height:20px}.tb-title{font-family:var(--font-display);font-weight:700;font-size:1.12rem;text-align:center}.tb-export{width:40px;height:40px;border-radius:13px;border:none;background:linear-gradient(135deg,var(--green),var(--green-deep));box-shadow:var(--shadow-sm);display:grid;place-items:center;color:#fff;cursor:pointer}.tb-export svg{width:19px;height:19px}.app{min-height:100vh}.app-side{display:none}.app-topbar{display:flex;align-items:center;justify-content:space-between;gap:8px;position:sticky;top:0;z-index:50;padding:14px 16px 12px;background:linear-gradient(180deg,var(--bg) 72%,rgba(247,244,238,0));backdrop-filter:blur(6px)}.app-tabbar{display:flex;justify-content:space-around;position:fixed;bottom:0;left:0;right:0;z-index:60;background:#ffffffeb;backdrop-filter:blur(12px);border-top:1px solid var(--line);padding:8px 8px calc(8px + env(safe-area-inset-bottom,0px));box-shadow:0 -6px 24px #3b3a360d}.app-main{padding:6px 16px 96px;max-width:760px;margin:0 auto}@media(min-width:900px){.app{display:grid;grid-template-columns:248px 1fr}.app-side{display:flex;flex-direction:column;gap:6px;padding:28px 20px;position:sticky;top:0;height:100vh}.app-topbar,.app-tabbar{display:none}.app-main{padding:34px 46px 80px;max-width:1040px;margin:0}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px}.login-card{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-xl);box-shadow:var(--shadow-md);padding:32px 28px}.login-brand{display:flex;align-items:center;gap:10px;justify-content:center;margin-bottom:22px}.login-brand .brand-name{font-family:var(--font-display);font-weight:700;font-size:1.2rem}.login-card .field{margin-bottom:14px}.login-card .btn-submit{margin-top:6px}.copy-item .ci-time{font-size:.76rem;color:var(--ink-faint);display:flex;align-items:center;gap:7px}.copy-item .ci-cat{font-family:var(--font-display);font-weight:700;font-size:.96rem;margin-top:1px;display:block}.copy-item .ci-content{font-size:.85rem;color:var(--ink-soft);display:block}.copy-item .ci-order{font-size:.72rem;color:var(--green-deep);margin-top:2px;display:block}.dialog .dsub{font-size:.8rem;color:var(--ink-faint);margin-bottom:16px}.radio-pill .rp-icon{font-size:1.2rem;display:block;margin-bottom:3px}.radio-pill .rp-text{display:block}.field label .req{color:var(--apricot);margin-left:3px;font-size:.74rem;font-weight:700}input[type=number]{width:100%;font-family:var(--font-body);font-size:1rem;color:var(--ink);background:var(--surface-soft);border:1.5px solid var(--line);border-radius:13px;padding:13px 14px;-webkit-appearance:none;appearance:none}input[type=number]:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 4px var(--green-soft)}.cal{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);padding:12px;margin-bottom:18px}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.cal-head{margin-bottom:4px}.cal-grid+.cal-grid{margin-top:6px}.cal-dow{text-align:center;font-size:.72rem;font-weight:700;color:var(--ink-faint);padding:4px 0}.cal-empty{min-height:64px}.cal-cell{display:flex;flex-direction:column;align-items:flex-start;gap:3px;min-height:64px;padding:6px 8px;border:1px solid var(--line);border-radius:12px;background:var(--surface-soft);cursor:pointer;font-family:var(--font-body);text-align:left;transition:transform .14s,box-shadow .14s,border-color .14s}.cal-cell:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}.cal-cell.has{background:var(--green-tint);border-color:var(--green-soft)}.cal-cell.sel{border-color:var(--green);box-shadow:0 0 0 2px var(--green-soft)}.cal-num{font-family:var(--font-display);font-weight:700;font-size:.92rem;color:var(--ink)}.cal-sum{font-size:.68rem;color:var(--green-deep);line-height:1.25;font-weight:700}.day-detail{margin-top:8px}@media(max-width:560px){.cal{padding:8px}.cal-grid{gap:4px}.cal-cell,.cal-empty{min-height:50px}.cal-cell{padding:4px 5px;gap:1px}.cal-num{font-size:.82rem}.cal-sum{font-size:.58rem}.cal-dow{font-size:.62rem}}
