*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0d0d0f;--surface: #18181c;--border: #2a2a32;--text: #e8e8ee;--muted: #7a7a8c;--green: #3ce17a;--yellow: #f0c040;--red: #e84646;--blue: #4a9ff5;--radius: 12px}@media (prefers-color-scheme: light){:root:not([data-theme=dark]){--bg: #f2f2f7;--surface: #ffffff;--border: #d8d8e0;--text: #111118;--muted: #6e6e80;--green: #1a9e4a;--yellow: #b87c00;--red: #c0392b;--blue: #2070c8}}:root[data-theme=light]{--bg: #f2f2f7;--surface: #ffffff;--border: #d8d8e0;--text: #111118;--muted: #6e6e80;--green: #1a9e4a;--yellow: #b87c00;--red: #c0392b;--blue: #2070c8}:root[data-theme=dark]{--bg: #0d0d0f;--surface: #18181c;--border: #2a2a32;--text: #e8e8ee;--muted: #7a7a8c;--green: #3ce17a;--yellow: #f0c040;--red: #e84646;--blue: #4a9ff5}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Helvetica Neue,Segoe UI,sans-serif;font-size:14px;font-weight:400;line-height:1.5;min-height:100vh;-webkit-font-smoothing:antialiased}.hidden{display:none!important}#login-screen{display:flex;align-items:center;justify-content:center;min-height:100vh}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:2.5rem 2rem;width:100%;max-width:360px;text-align:center}.logo{color:var(--green);font-weight:500;font-size:.85rem;letter-spacing:.06em}.login-card h1{font-size:1.6rem;font-weight:600;margin:.6rem 0 .4rem}.subtitle{color:var(--muted);font-size:.9rem;margin-bottom:1.6rem}#login-form{display:flex;flex-direction:column;gap:.75rem}#login-form input{background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:1rem;padding:.7rem 1rem;outline:none;transition:border-color .2s}#login-form input:focus{border-color:var(--green)}#login-form button{background:var(--green);border:none;border-radius:8px;color:#000;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem;transition:opacity .2s}#login-form button:hover{opacity:.85}#login-form button:disabled{opacity:.5;cursor:not-allowed}.error{color:var(--red);font-size:.85rem;margin-top:.5rem}header{background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}.header-inner{max-width:1100px;margin:0 auto;padding:.9rem 1.5rem;display:flex;align-items:center;gap:1rem}.fetched-at{flex:1;color:var(--muted);font-size:.8rem}.btn-icon{background:none;border:none;border-radius:8px;color:var(--muted);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;opacity:.5;padding:.3rem .5rem;transition:opacity .2s}.btn-icon:hover{opacity:.9}.btn-icon:disabled{opacity:.2;cursor:not-allowed}.btn-logout{background:none;border:1px solid var(--border);border-radius:8px;color:var(--muted);cursor:pointer;font-size:.78rem;font-weight:400;opacity:.6;padding:.28rem .75rem;transition:opacity .2s}.btn-logout:hover{opacity:1}.tab-bar{background:var(--bg);border-bottom:1px solid var(--border);position:sticky;top:53px;z-index:9}.tab-bar-inner{max-width:1100px;margin:0 auto;padding:1.25rem 1.5rem 0;display:flex;justify-content:center;gap:.3rem;align-items:flex-end}.tab-btn{position:relative;background:var(--bg);border:1px solid var(--border);border-radius:14px 14px 0 0;color:var(--muted);cursor:pointer;font-size:.88rem;font-weight:400;padding:.5rem 1.75rem;margin-bottom:-1px;z-index:1;transition:color .15s}.tab-btn:hover{color:var(--text)}.tab-btn--active{background:var(--surface);border-color:var(--border);border-bottom-color:var(--surface);color:var(--text);z-index:2}main{background:var(--surface);min-height:100vh}.main-inner{max-width:1100px;margin:0 auto;padding:1.5rem;display:flex;flex-direction:column;gap:2rem}.snapshot{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem 1.5rem;position:relative;overflow:hidden}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px}.card--recovery:before{background:var(--green)}.card--strain:before{background:var(--blue)}.card--sleep:before{background:var(--yellow)}.card--hrv:before{background:#c07ef5}.card-label{color:var(--muted);font-size:.75rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-bottom:.5rem}.card-value{font-size:2.4rem;font-weight:700;line-height:1;margin-bottom:.3rem}.card-sub{color:var(--muted);font-size:.82rem}.score-green{color:var(--green)}.score-yellow{color:var(--yellow)}.score-red{color:var(--red)}.charts{display:grid;grid-template-columns:repeat(auto-fit,minmax(420px,1fr));gap:1.25rem}.chart-block{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem 1.5rem}.chart-block h2{font-size:.85rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.07em;margin-bottom:1rem}.bar-chart{display:flex;align-items:flex-end;gap:6px;height:120px}.bar-chart-empty{height:120px;display:flex;align-items:center;color:var(--muted);font-size:.85rem}.bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;height:100%;justify-content:flex-end}.bar{width:100%;border-radius:4px 4px 0 0;min-height:4px;transition:opacity .2s}.bar:hover{opacity:.75}.bar-label{font-size:.65rem;color:var(--muted);white-space:nowrap}.bar-val{font-size:.65rem;color:var(--text);font-weight:600}.detail{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem 1.5rem}.detail h2{font-size:.85rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.07em;margin-bottom:1rem}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:.88rem}th{color:var(--muted);font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.06em;text-align:left;padding:.5rem .75rem;border-bottom:1px solid var(--border)}td{padding:.55rem .75rem;border-bottom:1px solid var(--border)}tr:last-child td{border-bottom:none}tr:hover td{background:#ffffff08}.sleep-day-list{display:flex;flex-direction:column;gap:.75rem;max-width:640px;margin:0 auto}.sleep-day-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem 3.5rem 2.75rem 1.5rem;display:flex;align-items:center;gap:1.5rem;position:relative}.sleep-ring-wrap{position:relative;flex-shrink:0;width:110px;height:110px}.sleep-ring-score{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;line-height:1}.sleep-ring-number{font-size:1.35rem;font-weight:500}.sleep-ring-label{font-size:.52rem;font-weight:400;color:var(--muted);margin-top:3px;text-align:center}.sleep-day-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.sleep-day-name{font-size:.95rem;font-weight:500;margin-bottom:.5rem}.sleep-day-date{color:var(--muted);font-size:.95rem;font-weight:400;margin-left:.35rem}.sleep-no-data{color:var(--muted);font-size:.85rem}.sleep-stats{display:flex;gap:1.5rem;flex-wrap:wrap}.sleep-stat{display:flex;flex-direction:column;gap:.2rem}.sleep-stat-label{color:var(--muted);font-size:.72rem;font-weight:400}.sleep-stat-value{font-size:.9rem;font-weight:500}.emoji-reactions{display:flex;flex-wrap:wrap;gap:4px;align-items:center}.emoji-badge{border:1.5px solid transparent;border-radius:99px;padding:1px 6px;font-size:13px;line-height:1.5}.emoji-badge--mine{border-color:var(--blue)}.emoji-react-wrap{position:absolute;bottom:10px;right:12px;display:flex;align-items:center;gap:6px}.emoji-react-btn{background:none;border:1px solid var(--border);border-radius:50%;color:var(--muted);cursor:pointer;font-size:11px;font-family:monospace;letter-spacing:-.5px;width:26px;height:26px;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:.6;transition:opacity .15s}.emoji-react-btn:hover{opacity:1}.emoji-picker{position:absolute;bottom:36px;right:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:8px;display:grid;grid-template-columns:repeat(5,1fr);gap:4px;z-index:20;box-shadow:0 4px 16px #0000004d}.emoji-picker-item{background:none;border:none;border-radius:6px;cursor:pointer;font-size:20px;line-height:1;padding:4px;transition:transform .1s}.emoji-picker-item:hover{transform:scale(1.2)}.sleep-calendars{display:flex;flex-direction:column;gap:1.25rem;width:640px;max-width:100%;margin:0 auto}.sleep-calendar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem 1.5rem;width:100%;box-sizing:border-box}.sleep-calendar-header{font-size:.85rem;font-weight:500;margin-bottom:1rem}.sleep-calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}.cal-dow{text-align:center;font-size:.65rem;color:var(--muted);padding-bottom:.4rem}.cal-cell{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;min-height:52px;border-radius:6px;cursor:pointer;transition:background .15s}.cal-cell--empty{cursor:default}.cal-cell--future{opacity:.25;cursor:default}.cal-cell--selected{outline:1px solid var(--muted)}.cal-day-num{font-size:.65rem;color:var(--muted);line-height:1}.cal-score{font-size:.88rem;font-weight:500;line-height:1}.cal-detail{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border);min-height:72px;display:flex;flex-direction:column;gap:.5rem;font-size:.82rem}.cal-detail-date{font-weight:500}.cal-detail-stats{display:flex;gap:2rem}.cal-detail-stat{display:flex;flex-direction:column;gap:.15rem}.cal-detail-label{font-size:.68rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.cal-detail-value{font-size:.88rem;font-weight:500}.cal-detail-empty{color:var(--muted)}.error-banner{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);background:var(--red);color:#fff;font-size:.88rem;padding:.75rem 1.5rem;border-radius:8px;box-shadow:0 4px 20px #00000080;z-index:100;cursor:pointer}@media (max-width: 600px){.charts{grid-template-columns:1fr}.snapshot{grid-template-columns:1fr 1fr}.card-value{font-size:1.8rem}}
