*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #282828;--bg-card: #3C3836;--bg-elevated: #504945;--text: #EBDBB2;--text-secondary: #A89984;--text-muted: #665C54;--green: #B8BB26;--yellow: #FABD2F;--red: #FB4934;--aqua: #8EC07C;--orange: #FE8019;--purple: #D3869B;--blue: #83A598;--radius: 10px;--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-top: env(safe-area-inset-top, 0px);--tab-height: 56px}html{height:100dvh;background:var(--bg);color:var(--text);font-family:-apple-system,system-ui,Segoe UI,sans-serif;font-size:16px;line-height:1.4;-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;-webkit-text-size-adjust:100%}body{height:100dvh;overflow:hidden;background:var(--bg)}#app{display:flex;flex-direction:column;height:100dvh;padding-top:var(--safe-top)}#view-container{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding:0 16px 16px;scroll-behavior:smooth}#tab-bar{display:flex;justify-content:space-around;align-items:center;background:var(--bg-card);border-top:1px solid var(--bg-elevated);padding-bottom:var(--safe-bottom);height:calc(var(--tab-height) + var(--safe-bottom));flex-shrink:0}.tab{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 12px;text-decoration:none;color:var(--text-muted);font-size:10px;font-weight:500;letter-spacing:.02em;transition:color .15s;min-width:56px}.tab svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.tab.active{color:var(--green)}.page-header{display:flex;justify-content:space-between;align-items:baseline;padding:16px 0 8px;position:sticky;top:0;background:var(--bg);z-index:20}.page-title{font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary)}.page-progress{font-size:22px;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums}.page-progress .done{color:var(--green)}.mode-toggles{display:flex;gap:10px;padding:8px 0 16px}.mode-toggle{flex:1;display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--bg-card);border-radius:var(--radius);border:1px solid transparent;cursor:pointer;-webkit-user-select:none;user-select:none}.mode-toggle.active{border-color:var(--yellow)}.mode-toggle.active.drinking{border-color:var(--orange);background:#fe801914}.mode-toggle.active.kava{border-color:var(--purple);background:#d3869b14}.mode-toggle-label{font-size:13px;font-weight:600;color:var(--text-secondary)}.mode-toggle.active .mode-toggle-label{color:var(--text)}.toggle-switch{position:relative;width:44px;height:26px;background:var(--bg-elevated);border-radius:13px;transition:background .2s;flex-shrink:0}.toggle-switch:after{content:"";position:absolute;width:20px;height:20px;top:3px;left:3px;background:var(--text-secondary);border-radius:50%;transition:transform .2s,background .2s}.mode-toggle.active .toggle-switch{background:var(--green)}.mode-toggle.active.drinking .toggle-switch{background:var(--orange)}.mode-toggle.active.kava .toggle-switch{background:var(--purple)}.mode-toggle.active .toggle-switch:after{transform:translate(18px);background:#fff}.section{margin-bottom:8px;scroll-margin-top:60px}.section-header{display:flex;align-items:center;gap:8px;padding:10px 0;min-height:44px;cursor:pointer;-webkit-user-select:none;user-select:none;position:sticky;top:52px;background:var(--bg);z-index:10}.section-label{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-secondary);flex:1}.section-count{font-size:12px;font-weight:600;color:var(--text-secondary);font-variant-numeric:tabular-nums}.section-count.complete{color:var(--green)}.section-chevron{font-size:12px;color:var(--text-muted);transition:transform .2s;width:16px;text-align:center}.section.collapsed .section-chevron{transform:rotate(0)}.section.expanded .section-chevron{transform:rotate(90deg)}.section-items{overflow:hidden;transition:max-height .25s ease-out,opacity .2s}.section.collapsed .section-items{max-height:0;opacity:0}.section.expanded .section-items{max-height:2000px;opacity:1}.section.drinking-section .section-label{color:var(--orange)}.section.drinking-section .section-header{border-left:3px solid var(--orange);padding-left:10px}.item-row{display:flex;align-items:center;gap:12px;padding:10px 8px;min-height:44px;border-radius:8px;cursor:pointer;transition:background .1s;-webkit-user-select:none;user-select:none}.item-row:active{background:var(--bg-card)}.item-row.taken{opacity:.45}.item-row.empty{opacity:.35;cursor:default}.item-row.not-taking{opacity:.7}.item-check{width:28px;height:28px;border-radius:50%;border:2px solid var(--text-muted);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color .15s,background .15s}.item-row.taken .item-check{border-color:var(--green);background:var(--green)}.item-row.taken .item-check svg{opacity:1}.item-check svg{width:14px;height:14px;stroke:var(--bg);stroke-width:2.5;fill:none;opacity:0;transition:opacity .1s}.item-row.empty .item-check{border-color:var(--bg-elevated);border-style:dashed}.item-info{flex:1;min-width:0}.item-name{font-size:15px;font-weight:500;color:var(--text);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.item-row.taken .item-name{text-decoration:line-through;text-decoration-color:var(--text-muted)}.item-meta{font-size:12px;color:var(--text-secondary);display:block;margin-top:1px}.item-timing{font-size:11px;color:var(--text-muted);display:block;margin-top:2px;letter-spacing:.01em}.item-row.taken .item-timing{display:none}.badge{font-size:9px;font-weight:700;letter-spacing:.06em;padding:2px 6px;border-radius:4px;flex-shrink:0;text-transform:uppercase}.badge-restock{background:var(--bg-elevated);color:var(--text-secondary)}.badge-finishing{background:#fabd2f26;color:var(--yellow)}.badge-resume{background:#fe801926;color:var(--orange)}.badge-prn{background:#83a59826;color:var(--blue)}.badge-grade{background:transparent;color:var(--text-muted);font-weight:600}.badge-grade.grade-a-plus{color:var(--green)}.badge-grade.grade-a{color:var(--aqua)}.badge-grade.grade-b{color:var(--text-secondary)}.item-warning-btn{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border:none;background:#fabd2f1f;color:var(--yellow);border-radius:50%;font-size:12px;cursor:pointer;flex-shrink:0;padding:10px;box-sizing:content-box;margin:-10px}.item-warnings{display:none;padding:6px 8px 6px 48px;font-size:12px;color:var(--yellow);line-height:1.4}.item-warnings.open{display:block}.hard-stops{padding:12px;background:#fb493414;border:1px solid rgba(251,73,52,.25);border-radius:var(--radius);margin:8px 0}.hard-stop-title{font-size:11px;font-weight:700;color:var(--red);letter-spacing:.08em;text-transform:uppercase;margin-bottom:6px}.hard-stop-item{font-size:13px;color:var(--red);padding:3px 0;opacity:.85}.diary-form{display:flex;flex-direction:column;gap:16px;padding-top:8px}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted)}.form-input,.form-select,.form-textarea{background:var(--bg-card);border:1px solid var(--bg-elevated);border-radius:8px;padding:12px;color:var(--text);font-size:16px;font-family:inherit;-webkit-appearance:none}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--aqua)}.form-textarea{resize:vertical;min-height:60px}.type-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.type-btn{padding:10px 4px;background:var(--bg-card);border:1px solid var(--bg-elevated);border-radius:8px;color:var(--text-secondary);font-size:12px;font-weight:600;text-align:center;cursor:pointer;transition:border-color .15s,color .15s}.type-btn.active{border-color:var(--aqua);color:var(--text);background:#8ec07c14}.context-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.context-btn{padding:10px 4px;background:var(--bg-card);border:1px solid var(--bg-elevated);border-radius:8px;color:var(--text-secondary);font-size:12px;font-weight:600;text-align:center;cursor:pointer;transition:border-color .15s,color .15s}.context-btn.active{border-color:var(--aqua);color:var(--text);background:#8ec07c14}.count-control{display:flex;align-items:center;gap:16px}.count-btn{width:44px;height:44px;border-radius:50%;border:1px solid var(--bg-elevated);background:var(--bg-card);color:var(--text);font-size:20px;display:flex;align-items:center;justify-content:center;cursor:pointer}.count-btn:active{background:var(--bg-elevated)}.count-value{font-size:32px;font-weight:700;color:var(--text);min-width:48px;text-align:center;font-variant-numeric:tabular-nums}.diary-save{padding:14px;background:var(--green);color:var(--bg);border:none;border-radius:var(--radius);font-size:15px;font-weight:700;cursor:pointer;text-align:center}.diary-save:active{opacity:.85}.diary-saved{font-size:13px;color:var(--green);text-align:center;padding:8px}.cal-nav{display:flex;justify-content:space-between;align-items:center;padding:8px 0 16px}.cal-nav-btn{background:none;border:none;color:var(--text-secondary);font-size:18px;cursor:pointer;padding:8px 12px}.cal-month{font-size:15px;font-weight:600;color:var(--text)}.cal-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:4px}.cal-weekday{font-size:10px;font-weight:600;color:var(--text-muted);text-align:center;text-transform:uppercase;letter-spacing:.06em}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.cal-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:8px;font-size:13px;color:var(--text-secondary);cursor:pointer;position:relative;gap:2px}.cal-day.today{font-weight:700;color:var(--text)}.cal-day.empty{cursor:default}.cal-day.future{opacity:.3;cursor:default}.cal-dot{width:6px;height:6px;border-radius:50%}.cal-dot.green{background:var(--green)}.cal-dot.yellow{background:var(--yellow)}.cal-dot.red{background:var(--red)}.cal-dot.none{background:var(--bg-elevated)}.cal-dot.drink{background:var(--orange)}.cal-detail{padding:16px;background:var(--bg-card);border-radius:var(--radius);margin-top:16px}.cal-detail-date{font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:8px}.cal-detail-stat{font-size:14px;color:var(--text);padding:4px 0}.skin-section{margin-bottom:20px}.skin-time{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--purple);padding:10px 0}.skin-item{display:flex;align-items:center;gap:12px;padding:10px 8px;min-height:44px;cursor:pointer;-webkit-user-select:none;user-select:none}.skin-item.taken{opacity:.45}.skin-item .item-check{border-color:var(--purple)}.skin-item.taken .item-check{background:var(--purple);border-color:var(--purple)}.skin-schedule{font-size:10px;font-weight:600;color:var(--purple);opacity:.7}.skin-inactive{font-size:12px;color:var(--text-muted);font-style:italic;padding:6px 8px}.settings-section{margin-bottom:24px}.settings-title{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);padding:10px 0 8px}.settings-btn{display:flex;align-items:center;gap:10px;width:100%;padding:14px;background:var(--bg-card);border:none;border-radius:var(--radius);color:var(--text);font-size:15px;font-family:inherit;cursor:pointer;margin-bottom:8px;text-align:left}.settings-btn:active{background:var(--bg-elevated)}.settings-btn-icon{font-size:18px;width:24px;text-align:center}.settings-btn-label{flex:1}.settings-btn-sub{font-size:12px;color:var(--text-secondary)}.persistence-status{padding:12px;background:var(--bg-card);border-radius:var(--radius);font-size:13px;color:var(--text-secondary)}.persistence-ok{color:var(--green)}.persistence-warn{color:var(--yellow)}.file-input-hidden{position:absolute;opacity:0;width:0;height:0}.toast{position:fixed;bottom:calc(var(--tab-height) + var(--safe-bottom) + 16px);left:50%;transform:translate(-50%);background:var(--bg-elevated);color:var(--text);padding:10px 20px;border-radius:20px;font-size:14px;font-weight:500;z-index:100;animation:toast-in .2s ease-out,toast-out .2s ease-in 1.8s forwards}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(10px)}}@keyframes toast-out{to{opacity:0;transform:translate(-50%) translateY(-10px)}}#view-container::-webkit-scrollbar{width:0}.empty-state{text-align:center;padding:40px 20px;color:var(--text-muted);font-size:14px}
