:root{--bg: #f6f7fb;--card: #ffffff;--accent: #E46E33;--muted: #65748b;--success: #cb7b2a;--font-family: "Poppins", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial}*{box-sizing:border-box}html,body,#root{height:100%;overflow:hidden}*{overscroll-behavior:contain;touch-action:manipulation}body{margin:0;font-family:var(--font-family);background:linear-gradient(180deg,#F2F2F2 0%,#ECECEC 100%);color:#0f172a;-webkit-font-smoothing:antialiased;font-size:24px}.app{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;max-width:880px;margin:0 auto;height:100%}header{text-align:center;margin-top:8px}h1{margin:0;font-size:28px}.company-logo{height:42px}@media (max-width: 380px){.company-logo{height:42px}}.subtitle{color:var(--muted);margin:6px 0 18px}.form{padding-inline:24px;width:100%;display:flex;flex-direction:column;justify-content:center;margin-bottom:32px}.choice{width:110px;height:110px;border-radius:999px;border:0;font-family:var(--font-family);font-weight:400;font-size:2em;cursor:pointer;-webkit-user-select:none;user-select:none;animation:button-appear .6s cubic-bezier(.2,.8,.2,1) both}.choices-grid{width:100%;display:grid;gap:36px;grid-template-columns:1fr 36px 1fr;justify-items:center;align-items:center;margin-top:16px}@media (min-width: 480px){.question-container{max-height:340px;margin-bottom:12px}.choice{width:140px;height:140px;font-size:3em}}@keyframes button-appear{0%{opacity:0;transform:scale(.8) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}.step-1 .choice{color:#ffb472;background:radial-gradient(142% 142% at 0% 0%,#F8661D 47%,#C93C00 100%);box-shadow:4px 5px 32px #ffeed54d inset;filter:drop-shadow(0 1px 2px rgba(187,25,25,.16))}.step-2 .choice{color:#ff8317;background:radial-gradient(142% 142% at 0% 0%,#FFCA7A 47%,#FF7B00 100%);box-shadow:4px 5px 32px #fff9 inset;filter:drop-shadow(0 1px 2px rgba(187,25,25,.16))}.choice:nth-child(2n){grid-column:1/3}.choice:nth-child(odd){grid-column:2/4}.choice:nth-child(1){grid-row:1 / span 2;animation-delay:calc(var(--duration-delay) + 0ms)}.choice:nth-child(2){grid-row:2 / span 2;animation-delay:calc(var(--duration-delay) + 50ms)}.choice:nth-child(3){grid-row:3 / span 2;animation-delay:calc(var(--duration-delay) + .1s)}.choice:nth-child(4){grid-row:4 / span 2;animation-delay:calc(var(--duration-delay) + .15s)}.choice:nth-child(5){grid-row:5 / span 2;animation-delay:calc(var(--duration-delay) + .2s)}.choice:active{transform:translateY(1px) scale(.98)}.choice[disabled]{opacity:.5;cursor:not-allowed}.thanks-overlay{position:fixed;left:0;right:0;top:0;bottom:0;display:flex;align-items:center;justify-content:center;pointer-events:none}.thanks-text{color:#333;font-size:28px;text-align:center}.heart-container{display:flex;align-items:center;justify-content:center;width:100%;height:38vh;max-height:360px}.heart{display:inline-flex;align-items:center;justify-content:center;transition:transform .28s cubic-bezier(.2,.8,.2,1);will-change:transform}.step{opacity:0;transform:translate(12px);transition:opacity .28s cubic-bezier(.2,.8,.2,1),transform .28s cubic-bezier(.2,.8,.2,1)}.step.show{opacity:1;transform:translate(0)}.stepper{position:relative;min-height:180px}.step-panel{position:absolute;top:0;right:0;bottom:0;left:0}.step-panel.active{opacity:1}@keyframes slideInRight{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:translate(0)}}@keyframes slideOutLeft{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(-24px)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-24px)}to{opacity:1;transform:translate(0)}}@keyframes slideOutRight{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(24px)}}.step-panel.entering.forward{animation:slideInRight 1.6s cubic-bezier(.2,.8,.2,1) both}.step-panel.leaving.forward{animation:slideOutLeft 1.6s cubic-bezier(.2,.8,.2,1) both}.step-panel.entering.backward{animation:slideInLeft 1.6s cubic-bezier(.2,.8,.2,1) both}.step-panel.leaving.backward{animation:slideOutRight 1.6s cubic-bezier(.2,.8,.2,1) both}.step-anim{min-height:180px;will-change:transform,opacity}.step-inner{display:flex;flex-direction:column}.question-container{margin-bottom:6px;line-height:1.24;max-height:310px}.question{font-weight:400;font-size:1.5rem;color:#0f172a}.preheader{font-weight:600;text-transform:uppercase;font-size:14px;font-size:.5em;margin-bottom:8px;margin-top:0}.preheader span{color:#999;font-weight:700;margin-left:8px}.slider-wrap{position:relative;padding:12px 0}.slider{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:100%;height:36px;background:transparent}.slider[disabled]{opacity:.45;cursor:not-allowed;pointer-events:none}.slider::-webkit-slider-runnable-track{height:8px;background:#ffffff;border-radius:999px;border:0}.slider::-moz-range-track{height:8px;background:#ffffff;border-radius:999px}.slider::-webkit-slider-thumb{-webkit-appearance:none;height:28px;width:28px;border-radius:50%;background:var(--accent);border:4px solid white;margin-top:-10px;box-shadow:0 6px 18px #ffffff29}.slider::-moz-range-thumb{height:28px;width:28px;border-radius:50%;background:var(--accent);border:4px solid white;box-shadow:0 6px 18px #6b46c129}.tick-row{display:flex;justify-content:space-between;margin-top:8px}.current{background:rgba(255,255,255,.2);color:#333;padding:6px 10px;border-radius:999px;font-weight:400;font-size:1rem;display:flex;gap:12px;margin-bottom:24px}.current span{font-weight:600}.submit{background:var(--accent);color:#fff;border:0;padding:12px;border-radius:10px;font-weight:600;font-size:16px}.submit[disabled]{opacity:.6}.status{padding:10px;border-radius:8px;font-size:13px;position:absolute;bottom:50%;left:50%;transform:translate(-50%)}.status.success{background:#ecfdf5;color:var(--success)}.status.error{background:#fff5f5;color:#b91c1c}.info{text-align:center;color:var(--muted);font-size:13px;margin:12px 0}.dashboard{min-height:100vh;background:linear-gradient(180deg,#F2F2F2 0%,#ECECEC 100%);padding:40px;font-family:var(--font-family);color:#0f172a;display:flex;flex-direction:column;justify-content:space-between}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:80px}.dashboard-title{display:flex;flex-direction:column;align-items:flex-start;gap:4px}.dashboard-title h1{font-size:72px;font-weight:300;margin:0;line-height:.9}.dashboard-title-graphic{display:block;height:72px;width:auto}.dashboard-title p{font-size:18px;color:#666;margin:8px 0 0;font-weight:400}.dashboard-qr{display:flex;align-items:center;gap:20px}.qr-placeholder{width:80px;height:80px;background:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center}.qr-image{width:80px;height:80px;display:block}.qr-code{width:60px;height:60px;background:linear-gradient(45deg,#000 25%,transparent 25%),linear-gradient(-45deg,#000 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#000 75%),linear-gradient(-45deg,transparent 75%,#000 75%);background-size:4px 4px;background-position:0 0,0 2px,2px -2px,-2px 0px}.qr-text{font-size:14px;color:#666;line-height:1.4}.dashboard-content{display:flex;flex-direction:column;align-items:center;margin-bottom:120px}.week-view{display:flex;align-items:center;justify-content:space-between;width:100%;height:200px}.day-item{display:flex;flex-direction:column;align-items:center;flex:1 0 auto}.day-item.no-data{opacity:.2}.circle-container{width:100%;height:300px;display:flex;align-items:center;justify-content:center}.day-circle{position:relative;background:#2d2d2d;border-radius:50%;transition:all .3s ease;opacity:1}.day-item.today .day-circle{animation:pulse 1.6s cubic-bezier(.2,.8,.2,1) infinite both}.day-item.today .day-circle:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;border-radius:50%;background:var(--accent)}.day-item.today .day-circle:after{animation:pulse-ring 1.6s cubic-bezier(.2,.8,.2,1) infinite both}.day-item.today .day-circle{background:var(--accent, #E46E33)}.day-label{text-align:center}.day-name{font-size:16px;font-weight:500;margin-bottom:4px}.day-item.today .day-name{color:var(--accent, #E46E33)}.day-count{font-size:14px;color:#666}.dashboard-footer{text-align:left;font-size:14px;color:#999;height:10vh;min-height:80px;width:100%;padding:0}.alltime-chart-container{width:100%;height:100%}.dashboard-loading,.dashboard-error{display:flex;align-items:center;justify-content:center;height:100vh;font-size:18px}.dashboard-error{color:#b91c1c}.no-data{color:#666;font-style:italic;text-align:center}.nav-link{position:fixed;top:20px;right:20px;background:var(--accent);color:#fff;padding:8px 16px;border-radius:20px;text-decoration:none;font-size:14px;font-weight:500;transition:opacity .2s ease;z-index:1000}.nav-link:hover{opacity:.8}@media (max-width: 768px){.dashboard{padding:20px}.dashboard-title h1{font-size:48px}.dashboard-title-graphic{height:48px}.week-view{gap:40px}.dashboard-header{flex-direction:column;gap:20px;margin-bottom:40px}.qr-placeholder{width:60px;height:60px}.qr-code{width:40px;height:40px}.qr-image{width:60px;height:60px}}@media (max-width:420px){.app{padding:16px}h1{font-size:24px}.dashboard-title h1{font-size:36px}.dashboard-title-graphic{height:36px}.week-view{gap:20px;overflow-x:auto;padding:10px}}@keyframes pulse{0%{transform:scale(1)}20%{transform:scale(1.05)}30%{transform:scale(.8)}to{transform:scale(1)}}@keyframes pulse-ring{20%{transform:scale(1.05);opacity:1}to{transform:scale(2);opacity:0}}@media (min-width: 480px){.app{padding:24px;display:flex;flex-direction:column;justify-content:center;align-items:center}.choices-grid{width:100%;display:flex;flex-direction:row-reverse;gap:12px;justify-content:center}.choice{aspect-ratio:1 / 1;font-size:3em}.company-logo{height:72px;margin-bottom:42px}}
