:root{color:#172026;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f6faf8;font-family:Inter,Pretendard,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}button,input,textarea{font:inherit}button{cursor:pointer}.app-shell{background:linear-gradient(135deg,#14b8a629,#0000 32%),linear-gradient(315deg,#facc1533,#0000 28%),#f6faf8;min-height:100vh;padding:32px}.app-hero{justify-content:space-between;align-items:flex-start;gap:24px;max-width:1180px;margin:0 auto 28px;display:flex}.app-subtitle{color:#0f766e;margin:0 0 8px;font-weight:800}h1,h2,p{margin-top:0}h1{margin-bottom:12px;font-size:42px;line-height:1.15}h2{margin-bottom:4px;font-size:22px;line-height:1.25}.app-intro{color:#52605c;max-width:600px;margin-bottom:0;font-size:18px;line-height:1.7}.app-hero time{color:#0f766e;background:#fff;border:1px solid #c8ebe4;border-radius:999px;flex:none;padding:10px 14px;font-weight:800}.dashboard-grid{grid-template-columns:minmax(0,1.05fr) minmax(360px,.95fr);align-items:start;gap:24px;max-width:1180px;margin:0 auto;display:grid}.input-stack,.result-stack{gap:18px;display:grid}.panel{background:#ffffffeb;border:1px solid #d8e7e2;border-radius:8px;padding:22px;box-shadow:0 18px 44px #17202614}.section-heading{gap:12px;margin-bottom:18px;display:flex}.section-heading p{color:#64726d;margin-bottom:0;line-height:1.5}.section-number{color:#115e59;background:#ccfbf1;border-radius:50%;place-items:center;width:34px;height:34px;font-weight:900;display:grid}.field-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.field{color:#26332f;gap:8px;font-weight:700;display:grid}.input-with-unit{align-items:center;gap:8px;display:flex}.input-with-unit input,textarea{color:#172026;background:#fff;border:1px solid #b8d6cf;border-radius:8px;width:100%;padding:12px 14px}.input-with-unit input:focus,textarea:focus,button:focus-visible{outline-offset:2px;outline:3px solid #14b8a652}.input-with-unit span{color:#52605c;min-width:24px;font-weight:800}.ethics-list{border:0;gap:10px;margin:18px 0;padding:0;display:grid}.ethics-list legend{color:#26332f;margin-bottom:10px;font-weight:800}.check-row{color:#34423e;background:#fbfffd;border:1px solid #e4eee9;border-radius:8px;align-items:flex-start;gap:10px;padding:12px;line-height:1.5;display:flex}.check-row input{accent-color:#0f766e;margin-top:4px}textarea{resize:vertical;line-height:1.6}.character-count{color:#64726d;text-align:right;margin:6px 0 16px;font-size:14px}.primary-button{color:#fff;background:#0f766e;border:0;border-radius:8px;width:100%;padding:14px 18px;font-weight:900;box-shadow:0 12px 24px #0f766e33}.primary-button:hover{background:#115e59}.result-panel{position:relative;overflow:hidden}.result-success{border-color:#86efac}.result-close{border-color:#fde68a}.result-over{border-color:#fecaca}.result-wait{border-color:#e5e7eb}.score-row{gap:8px;margin-bottom:18px;display:grid}.score-row strong{font-size:44px;line-height:1}.score-row span{color:#34423e;line-height:1.6}.progress-track{background:#ddebe6;border-radius:999px;height:18px;overflow:hidden}.progress-fill{border-radius:inherit;background:linear-gradient(90deg,#14b8a6,#84cc16);height:100%;transition:width .36s}.usage-summary{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:18px 0 0;display:grid}.usage-summary div{background:#f2faf7;border-radius:8px;padding:12px}.usage-summary dt{color:#52605c;font-size:14px;font-weight:800}.usage-summary dd{color:#172026;margin:4px 0 0;font-weight:900}.success-stage{place-items:center;min-height:120px;margin-top:18px;display:grid;position:relative}.success-stamp{color:#15803d;letter-spacing:0;background:#dcfce7f0;border:5px solid #16a34a;border-radius:8px;padding:14px 20px;font-size:26px;font-weight:1000;transform:rotate(-6deg);box-shadow:0 14px 24px #16a34a2e}.confetti{border-radius:4px;width:12px;height:24px;animation:.9s ease-out both confetti-burst;position:absolute}.confetti-one{background:#facc15;top:18px;left:18%}.confetti-two{background:#38bdf8;animation-delay:80ms;top:4px;right:24%}.confetti-three{background:#fb7185;animation-delay:.14s;bottom:30px;right:14%}@keyframes confetti-burst{0%{opacity:0;transform:translateY(24px)rotate(0)}30%{opacity:1}to{opacity:0;transform:translateY(-56px)rotate(190deg)}}.privacy-note,.empty-history{color:#64726d;line-height:1.6}.save-error{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;margin:0;padding:12px;line-height:1.6}.history-list{gap:12px;margin:0;padding:0;list-style:none;display:grid}.history-heading-row{justify-content:space-between;align-items:flex-start}.history-heading-copy{gap:12px;display:flex}.clear-history-button{color:#b91c1c;background:#fff7f7;border:1px solid #fecaca;border-radius:8px;flex:none;padding:8px 10px;font-weight:900}.clear-history-button:hover{background:#fee2e2}.history-item{background:#fff;border:1px solid #e4eee9;border-left-width:6px;border-radius:8px;justify-content:space-between;gap:16px;padding:14px;display:flex}.history-success{border-left-color:#22c55e}.history-close{border-left-color:#eab308}.history-over{border-left-color:#ef4444}.history-item strong{margin-bottom:6px;display:block}.history-item p{color:#52605c;margin-bottom:4px;line-height:1.5}.history-item button{color:#34423e;background:#fff;border:1px solid #d7e5df;border-radius:8px;align-self:flex-start;padding:8px 10px;font-weight:800}.sr-status{clip:rect(0, 0, 0, 0);white-space:nowrap;width:1px;height:1px;position:absolute;overflow:hidden}@media (width<=820px){.app-shell{padding:20px}.app-hero{display:grid}h1{font-size:32px}.dashboard-grid,.field-grid,.usage-summary{grid-template-columns:1fr}.score-row strong{font-size:38px}.history-item,.history-heading-row,.history-heading-copy{display:grid}.clear-history-button{width:100%}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}
