@import"https://fonts.googleapis.com/css2?family=Manrope:wght@400;600;700&family=Space+Grotesk:wght@500;700&display=swap";:root{color-scheme:light;--bg: #fdf6ec;--bg-accent: #f6ead6;--surface: #ffffff;--text: #2a231c;--muted: #6b5a4a;--accent: #e06a3c;--accent-strong: #b8501f;--grid-filled: #f07e4a;--grid-empty: #fff6ea;--grid-border: #f3e6d5;--grid-sleep: #6eb1de;--shadow: 0 12px 40px rgba(36, 31, 26, .08);--sun-glow: rgba(255, 194, 120, .6);--sky-soft: rgba(255, 255, 255, .6);--line-soft: rgba(180, 126, 84, .2)}*{box-sizing:border-box}body{margin:0;font-family:Manrope,Segoe UI,sans-serif;color:var(--text);background:radial-gradient(circle at top,var(--bg),var(--bg-accent));min-height:100vh}#root{min-height:100vh}.app{position:relative;min-height:100vh}.backdrop{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden;background:linear-gradient(180deg,#fff6e9 0%,#f6ead6 50%,#f3e0c6 100%)}.parallax{position:absolute;inset:-12% -10%;transform:translateY(0);will-change:transform}.layer-sun{background:radial-gradient(520px 520px at 78% 12%,var(--sun-glow),rgba(255,194,120,0) 60%),radial-gradient(320px 320px at 70% 20%,rgba(255,224,176,.8),rgba(255,224,176,0) 65%);transform:translateY(calc(var(--scroll-y, 0) * .06))}.layer-clouds{background:radial-gradient(480px 220px at 14% 18%,var(--sky-soft),rgba(255,255,255,0) 70%),radial-gradient(520px 240px at 86% 30%,rgba(255,255,255,.45),rgba(255,255,255,0) 72%),radial-gradient(420px 200px at 38% 34%,rgba(255,255,255,.4),rgba(255,255,255,0) 70%);transform:translateY(calc(var(--scroll-y, 0) * .03))}.layer-lines{background:repeating-linear-gradient(-12deg,transparent 0 22px,var(--line-soft) 22px 24px),radial-gradient(900px 340px at 10% 85%,rgba(255,220,180,.5),rgba(255,220,180,0) 72%);opacity:.7;transform:translateY(calc(var(--scroll-y, 0) * .12))}.page{max-width:1200px;margin:0 auto;padding:clamp(20px,4vw,48px);display:flex;flex-direction:column;gap:clamp(20px,3.5vw,32px);position:relative;z-index:1}.hero{display:flex;justify-content:space-between;align-items:center;gap:24px}.hero h1{font-family:Space Grotesk,Manrope,sans-serif;font-size:clamp(28px,4vw,44px);margin:0 0 8px}.hero-title-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.hero-actions{display:inline-flex;align-items:center;gap:8px}.hero-title-row h1{margin-bottom:0}.hero-description{margin:0;color:var(--muted);font-size:clamp(14px,2vw,18px);max-width:640px}.hero-note{margin:8px 0 0;color:#7a6a5a;font-size:clamp(13px,1.8vw,16px);max-width:640px}.intro-restart{width:28px;height:28px;min-width:28px;min-height:28px;aspect-ratio:1 / 1;padding:0;border-radius:999px;border:1px solid rgba(36,31,26,.2);background:rgba(255,255,255,.6);color:#241f1a99;font-weight:700;font-size:14px;line-height:1;box-shadow:none;opacity:.8;display:grid;place-items:center;touch-action:manipulation}.intro-restart:hover{opacity:1}.share-btn{width:28px;height:28px;min-width:28px;min-height:28px;border-radius:999px;border:1px solid rgba(36,31,26,.2);background:rgba(255,255,255,.6);color:#241f1ab3;display:grid;place-items:center;padding:0;cursor:pointer;opacity:.85}.share-btn:hover{opacity:1}.share-icon{width:16px;height:16px;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b5a4a' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><path d='M12 16V4'/><path d='M7 9l5-5 5 5'/><path d='M5 20h14a1 1 0 0 0 1-1v-5'/></svg>");background-repeat:no-repeat;background-position:center;background-size:contain}.print-btn{width:28px;height:28px;min-width:28px;min-height:28px;border-radius:999px;border:1px solid rgba(36,31,26,.2);background:rgba(255,255,255,.6);color:#241f1ab3;display:grid;place-items:center;padding:0;cursor:pointer;opacity:.85}.print-btn:hover{opacity:1}.print-icon{width:16px;height:16px;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b5a4a' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><path d='M6 9V3h12v6'/><rect x='6' y='13' width='12' height='8' rx='1'/><rect x='4' y='9' width='16' height='6' rx='2'/></svg>");background-repeat:no-repeat;background-position:center;background-size:contain}.subtitle{margin:0;color:var(--muted);font-size:clamp(14px,2vw,18px);display:grid;gap:6px;max-width:570px}.subtitle-line{display:block}.badge{background:var(--surface);border:1px solid var(--grid-border);padding:18px 22px;border-radius:16px;box-shadow:var(--shadow);min-width:160px;text-align:right;min-height:180px;display:grid;align-content:start;gap:6px}.badge-label{display:block;font-size:13px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}.badge-value{display:block;font-family:Space Grotesk,Manrope,sans-serif;font-size:22px;margin-top:6px}.badge-sub{display:block;margin-top:2px;font-size:14px;color:var(--muted)}.card{background:var(--surface);border:1px solid var(--grid-border);padding:clamp(16px,3vw,28px);border-radius:20px;box-shadow:var(--shadow)}.card h2{margin:0;font-size:20px}.card-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.card-body{display:flex;flex-direction:column;gap:16px}.card-toggle{width:32px;height:32px;border-radius:999px;border:1px solid var(--grid-border);background:#fff;position:relative;cursor:pointer;padding:0;transition:transform .2s ease,box-shadow .2s ease}.card-toggle:after{content:"";position:absolute;width:8px;height:8px;border-right:2px solid var(--muted);border-bottom:2px solid var(--muted);transform:rotate(-135deg);top:11px;left:11px;transition:transform .2s ease}.card-toggle[aria-expanded=false]:after{transform:rotate(45deg)}.form-grid{display:grid;grid-template-columns:repeat(3,minmax(200px,1fr));gap:20px}.form-column{padding:14px 16px;border-radius:16px;border:1px solid var(--grid-border);background:#fffaf2;display:grid;gap:12px;align-content:start}.column-title{font-size:13px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}label{display:grid;gap:8px;font-size:14px;color:var(--muted);max-width:200px}.card select{width:100%;padding:10px 40px 10px 12px;border-radius:12px;border:1px solid var(--grid-border);font-size:16px;background:#fff;color:var(--text);appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='10' viewBox='0 0 16 10' fill='none' stroke='%236b5a4a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M1 1l7 7 7-7'/></svg>");background-repeat:no-repeat;background-position:right 12px center}input[type=text]{width:100%;padding:10px 12px;border-radius:12px;border:1px solid var(--grid-border);font-size:16px;background:#fff;color:var(--text)}.profile-row{display:grid;grid-template-columns:minmax(160px,220px) minmax(220px,1fr);gap:16px;align-items:end}.profile-row label{max-width:100%}.form-actions{margin-top:16px;display:flex;gap:12px;flex-wrap:wrap}button{border-radius:999px;padding:10px 18px;border:none;font-size:15px;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}button.primary{background:var(--accent);color:#fff;box-shadow:0 10px 20px #e07a3f47}button.ghost{background:transparent;color:var(--accent-strong);border:1px solid var(--grid-border)}button:active{transform:translateY(1px)}button:disabled{cursor:not-allowed;opacity:.7;box-shadow:none}.grid-wrap{display:flex;flex-direction:column;gap:14px}.grid-header{display:flex;justify-content:space-between;align-items:center;gap:16px}.grid-header h2{margin:0;font-size:20px}.legend{display:grid;grid-auto-flow:column;gap:12px;align-items:center;font-size:13px;color:var(--muted)}.legend-pair{display:inline-flex;align-items:center;gap:6px}.legend-item{width:16px;height:16px;border-radius:4px;background:var(--grid-empty);border:1px solid var(--grid-border)}.legend-item.filled{background:var(--grid-filled);border:none}.legend-item.sleep{background:var(--grid-sleep);border:none}.legend-item.loss-alcohol,.legend-item.loss-smoking{background:#f6d2bf;border:none;position:relative}.legend-item.loss-alcohol:after,.legend-item.loss-smoking:after{content:"";position:absolute;inset:2px;background-repeat:no-repeat;background-position:center;background-size:contain}.legend-item.loss-alcohol:after{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%239a4b2f' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><path d='M9 2h6v3c0 1.7 1.1 3.2 2.6 3.7v9.5a3.8 3.8 0 0 1-3.8 3.8H10.2A3.8 3.8 0 0 1 6.4 18.2V8.7C7.9 8.2 9 6.7 9 5V2Z'/><path d='M8 11h8'/></svg>")}.legend-item.loss-smoking:after{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%239a4b2f' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><path d='M3 16h14'/><path d='M17 16h4v-3h-4z'/><path d='M7 13c0-2 1-3 1-4'/><path d='M10 13c0-2 1-3 1-4'/></svg>")}.legend-item.gain{background:#e0f5e6;border:1px solid #6bbf7a}.legend-item.event{background:#f7c44c;border:1px solid #b37a14;position:relative}.legend-item.event:after{content:"";position:absolute;inset:0;background-repeat:no-repeat;background-position:center;background-size:100% 100%;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 48 48'><path d='M24 6l5.2 10.8 12 1.6-8.6 8.3 2 11.9L24 32.6l-10.6 5.8 2-11.9-8.6-8.3 12-1.6z' fill='%231d1d1d'/></svg>")}.week-grid{display:grid;gap:clamp(4px,.8vw,8px);background:var(--surface);padding:clamp(12px,2vw,18px);border-radius:22px;border:1px solid var(--grid-border);box-shadow:var(--shadow)}.week-row{display:grid;grid-template-columns:32px repeat(52,minmax(4px,1fr));gap:clamp(1px,.4vw,3px);align-items:center}.week-divider{display:grid;grid-template-columns:32px 1fr;align-items:center;gap:8px;padding:0}.week-divider-label{font-size:12px;color:var(--muted);text-align:right;padding-right:6px}.week-divider-line{height:1px;background:var(--grid-border);opacity:.8}.week-row-label{font-size:12px;color:var(--muted);text-align:right;padding-right:6px}.week-cell{aspect-ratio:1 / 1;width:100%;background:var(--grid-empty);border-radius:4px;border:1px solid var(--grid-border)}.week-cell.filled{background:var(--grid-filled);border:none}.week-cell.sleep{background:var(--grid-sleep);border:none}.week-cell.loss-alcohol,.week-cell.loss-smoking{background:#f6d2bf;border:none;position:relative}.week-cell.loss-alcohol:after,.week-cell.loss-smoking:after{content:"";position:absolute;inset:2px;background-repeat:no-repeat;background-position:center;background-size:contain}.week-cell.loss-alcohol:after{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%239a4b2f' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><path d='M9 2h6v3c0 1.7 1.1 3.2 2.6 3.7v9.5a3.8 3.8 0 0 1-3.8 3.8H10.2A3.8 3.8 0 0 1 6.4 18.2V8.7C7.9 8.2 9 6.7 9 5V2Z'/><path d='M8 11h8'/></svg>")}.week-cell.loss-smoking:after{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%239a4b2f' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><path d='M3 16h14'/><path d='M17 16h4v-3h-4z'/><path d='M7 13c0-2 1-3 1-4'/><path d='M10 13c0-2 1-3 1-4'/></svg>")}.week-cell.gain{background:#e0f5e6;border:1px solid #6bbf7a}.week-cell.event{position:relative;background:#f7c44c;border:1px solid #b37a14;animation:event-pulse-strong 1.8s ease-in-out infinite}.week-cell.event:before{content:"";position:absolute;width:100%;height:100%;top:50%;left:50%;transform:translate(-50%,-50%);background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 48 48'><path d='M24 6l5.2 10.8 12 1.6-8.6 8.3 2 11.9L24 32.6l-10.6 5.8 2-11.9-8.6-8.3 12-1.6z' fill='%231d1d1d'/></svg>");background-repeat:no-repeat;background-position:center;background-size:100% 100%;pointer-events:none}.week-cell.event:after{content:attr(data-event);position:absolute;left:50%;bottom:calc(100% + 8px);transform:translate(-50%);background:rgba(34,28,20,.95);color:#fff;padding:8px 10px;border-radius:8px;font-size:14px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .15s ease,transform .15s ease}.week-cell.event:hover:after{opacity:1;transform:translate(-50%) translateY(-2px)}.week-cell.empty{opacity:0;pointer-events:none}.error{margin-top:12px;color:#b3261e;font-size:14px}.note{margin:0;color:var(--muted);font-size:13px}.events-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:16px;align-items:end}.events-form label{max-width:100%}.intro-overlay{position:fixed;inset:0;z-index:50;pointer-events:none}.intro-spotlight{position:fixed;border-radius:16px;box-shadow:0 0 0 9999px #14100cb8;transition:all .2s ease;pointer-events:none}.intro-card{position:fixed;width:320px;background:#fff;border-radius:16px;padding:14px 16px;box-shadow:0 18px 36px #120e0a4d;border:1px solid var(--grid-border);pointer-events:auto}.intro-card.above{transform:translateY(-100%)}.intro-title{font-weight:700;font-size:16px;margin-bottom:6px}.intro-text{font-size:14px;color:var(--muted)}.intro-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:12px;flex-wrap:wrap}.intro-btn{padding:8px 14px;font-size:14px}.event-title{grid-column:span 2}.events-list{display:grid;gap:10px}.event-row{display:grid;grid-template-columns:96px 1fr 32px;align-items:center;gap:12px;padding:10px 12px;border-radius:14px;background:#fffaf2;border:1px solid var(--grid-border)}.event-date{font-size:13px;color:var(--muted)}.event-title-text{font-size:15px}.event-delete{width:28px;height:28px;border-radius:999px;border:1px solid var(--grid-border);background:#fff;position:relative;cursor:pointer}.event-delete:before{content:"";position:absolute;inset:6px;background-repeat:no-repeat;background-position:center;background-size:contain;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b5a4a' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><path d='M3 6h18'/><path d='M8 6V4h8v2'/><path d='M6 6l1 14h10l1-14'/><path d='M10 10v7'/><path d='M14 10v7'/></svg>")}.summary-card{background:var(--surface);border:1px solid var(--grid-border);border-radius:20px;box-shadow:var(--shadow);padding:clamp(16px,3vw,28px);display:grid;gap:16px}.summary-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.summary-title{margin:0;font-size:20px}.summary-intro .subtitle{max-width:100%}.summary-main{display:grid;grid-template-columns:minmax(220px,300px) minmax(320px,480px);gap:24px;align-items:start}.summary-left{display:grid;gap:16px}.summary-metric{background:#fffaf2;border:1px solid var(--grid-border);border-radius:16px;padding:16px;display:grid;gap:8px}.summary-metric.summary-highlight{background:#fff1dd;border-color:#f2d3b3}.summary-label{font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}.summary-value{font-family:Space Grotesk,Manrope,sans-serif;font-size:22px}.summary-list{display:grid;gap:10px}.summary-row{display:grid;grid-template-columns:minmax(240px,1.25fr) minmax(170px,.55fr);align-items:center;gap:20px;padding:10px 8px 10px 12px;border-radius:12px;background:#fffaf2;border:1px solid var(--grid-border);font-size:14px}.summary-row span:last-child{justify-self:start;font-weight:600;color:#3a2e22}.summary-row.total{background:#fff1dd;border-color:#f2d3b3;font-weight:600}.share-toast{position:fixed;right:20px;bottom:24px;background:rgba(34,28,20,.95);color:#fff;padding:10px 14px;border-radius:12px;font-size:13px;z-index:60}.footer{margin-top:12px;font-size:13px;color:var(--muted)}.footer a{color:var(--accent-strong);text-decoration:none}.footer a:hover{text-decoration:underline}@media (max-width: 720px){.hero{flex-direction:column;align-items:flex-start}.badge{width:100%;text-align:left}.grid-header{flex-direction:column;align-items:flex-start}.legend{grid-auto-flow:row;grid-template-columns:repeat(2,minmax(0,1fr));row-gap:6px;column-gap:12px;width:100%}.legend-pair{justify-content:flex-start}.week-grid{padding:10px;overflow-x:auto}.week-row{grid-template-columns:36px repeat(52,minmax(8px,1fr));gap:1.5px;min-width:560px}.week-divider{grid-template-columns:36px 1fr}.week-cell{border-radius:2px}.week-cell.event{animation:event-pulse 1.8s ease-in-out infinite}.form-grid{grid-template-columns:1fr}label{max-width:100%}.profile-row{grid-template-columns:1fr}.event-title{grid-column:span 1}.summary-main{grid-template-columns:1fr}.summary-row{grid-template-columns:1fr;gap:6px}}@keyframes event-pulse{0%{box-shadow:0 0 #f7c44c8c}70%{box-shadow:0 0 0 6px #f7c44c00}to{box-shadow:0 0 #f7c44c00}}@keyframes event-pulse-strong{0%{box-shadow:0 0 #f7c44cbf}70%{box-shadow:0 0 0 12px #f7c44c00}to{box-shadow:0 0 #f7c44c00}}@media (prefers-reduced-motion: reduce){.parallax{transform:none}.week-cell.event{animation:none}}@media print{*{-webkit-print-color-adjust:exact;print-color-adjust:exact}@page{size:A4 portrait;margin:12mm}header,footer{display:none!important}body{background:#fff!important}.backdrop,.intro-overlay,.share-toast,.hero,.card,.summary-card{display:none!important}.grid-wrap{display:block!important;position:absolute;inset:0;padding:12px!important;box-shadow:none!important}.week-grid{box-shadow:none!important;border:none!important;background:#fff!important}.week-row,.week-divider{break-inside:avoid;page-break-inside:avoid}.week-cell{background:var(--grid-empty)!important;border:1px solid var(--grid-border)!important}.week-cell.filled{background:var(--grid-filled)!important}.week-cell.sleep{background:var(--grid-sleep)!important}.week-cell.loss-alcohol,.week-cell.loss-smoking{background:#f6d2bf!important}.week-cell.gain{background:#e0f5e6!important}.week-cell.event{background:#f7c44c!important;border:1px solid #b37a14!important}.week-cell.event:before,.legend-item.event:after,.week-cell.loss-alcohol:after,.week-cell.loss-smoking:after{-webkit-print-color-adjust:exact;print-color-adjust:exact}}
