:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}:root{--yellow:#ffb800;--yellow-light:#fff3cc;--yellow-dark:#cc9200;--purple:#6c3fc8;--purple-light:#ede5ff;--purple-dark:#4e2d9a;--white:#fff;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-400:#9ca3af;--gray-500:#6b7280;--gray-700:#374151;--gray-900:#111827;--radius:12px;--shadow:0 2px 12px #00000014}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--gray-50);color:var(--gray-900);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5}.app-header{background:linear-gradient(135deg, var(--purple) 0%, var(--purple-dark) 100%);color:#fff;text-align:center;padding:2rem 1.5rem}.header-logo{opacity:.9;margin-bottom:.75rem;font-size:1.4rem;font-weight:900}.logo-g{color:var(--yellow)}.header-title{text-shadow:0 1px 3px #0003;margin-bottom:.5rem;font-size:clamp(1.3rem,5vw,1.9rem);font-weight:800}.header-sub{opacity:.85;max-width:500px;margin:0 auto;font-size:.95rem}.container{max-width:700px;margin:0 auto;padding:1.5rem 1rem}.live-score-bar{border-radius:var(--radius);box-shadow:var(--shadow);background:#fff;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding:1rem 1.25rem;display:flex}.live-score-left{flex-direction:column;gap:.15rem;display:flex}.live-score-title{color:var(--gray-700);font-size:1rem;font-weight:700}.live-score-sub{color:var(--gray-500);font-size:.8rem}.live-score-badge{border-radius:99px;padding:.3rem .9rem;font-size:1.3rem;font-weight:800;transition:background .3s}.live-label{margin-bottom:1rem;padding-left:.25rem;font-size:.85rem}.categories{flex-direction:column;gap:.75rem;margin-bottom:1.5rem;display:flex}.cat-card{border-radius:var(--radius);box-shadow:var(--shadow);background:#fff;border:1.5px solid #0000;padding:1.1rem 1.25rem;transition:border-color .2s}.cat-card.cat-rated{border-color:var(--purple-light)}.cat-header{align-items:flex-start;gap:.75rem;margin-bottom:.5rem;display:flex}.cat-icon{flex-shrink:0;margin-top:1px;font-size:1.3rem}.cat-info{flex:1}.cat-title{color:var(--gray-900);margin-bottom:.2rem;font-size:.95rem;font-weight:700}.cat-what-5{color:var(--purple);cursor:pointer;text-underline-offset:2px;background:0 0;border:none;padding:0;font-size:.75rem;font-weight:600;text-decoration:underline}.cat-desc{background:var(--purple-light);color:var(--purple-dark);border-radius:8px;margin-bottom:.6rem;padding:.6rem .75rem;font-size:.83rem;line-height:1.5}.cat-desc-badge{margin-right:.25rem;font-weight:700}.star-row{align-items:center;gap:.25rem;display:flex}.star-btn{cursor:pointer;color:var(--gray-200);background:0 0;border:none;padding:0;font-size:1.6rem;line-height:1;transition:color .15s,transform .1s}.star-btn:hover{color:var(--yellow-dark);transform:scale(1.2)}.star-btn.star-active{color:var(--yellow)}.star-label{color:var(--gray-500);min-width:3rem;margin-left:.25rem;font-size:.8rem;font-weight:600}.submit-area{text-align:center;margin-bottom:1.5rem}.submit-hint{color:var(--gray-500);margin-bottom:.75rem;font-size:.85rem}.btn{cursor:pointer;border:none;border-radius:8px;padding:.7rem 1.5rem;font-size:.95rem;font-weight:700;transition:opacity .2s,transform .1s}.btn:active{transform:scale(.97)}.btn-submit{background:var(--gray-200);color:var(--gray-500);cursor:not-allowed;padding:.85rem 2.5rem;font-size:1rem}.btn-submit.btn-submit-active{background:var(--purple);color:#fff;cursor:pointer;box-shadow:0 4px 14px #6c3fc84d}.btn-submit.btn-submit-active:hover{background:var(--purple-dark)}.btn-primary{background:var(--yellow);color:var(--gray-900)}.btn-primary:hover{background:var(--yellow-dark)}.btn-secondary{color:var(--gray-700);border:1.5px solid var(--gray-200);background:#fff}.btn-secondary:hover{background:var(--gray-100)}.btn-print{background:var(--gray-100);color:var(--gray-700)}.results-page{flex-direction:column;gap:1.25rem;display:flex}.score-banner{border-radius:var(--radius);align-items:center;gap:1.25rem;padding:1.5rem;display:flex}.score-circle{border:4px solid;border-radius:50%;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;width:80px;height:80px;display:flex}.score-number{font-size:1.8rem;font-weight:900;line-height:1}.score-denom{opacity:.7;font-size:.75rem;font-weight:600}.score-info{flex:1}.score-label{margin-bottom:.5rem;font-size:1.1rem;font-weight:800}.score-bar-track{background:#0000001a;border-radius:99px;height:10px;margin-bottom:.35rem;overflow:hidden}.score-bar-fill{border-radius:99px;height:100%;transition:width .5s}.score-pct{opacity:.7;font-size:.8rem;font-weight:600}.results-section{border-radius:var(--radius);box-shadow:var(--shadow);background:#fff;padding:1.25rem}.results-section-title{color:var(--gray-900);margin-bottom:1rem;font-size:1rem;font-weight:700}.all-scores{flex-direction:column;gap:.5rem;display:flex}.score-row{align-items:center;gap:.6rem;display:flex}.score-row-icon{flex-shrink:0;width:1.5rem;font-size:1rem}.score-row-label{color:var(--gray-700);flex:1;min-width:0;font-size:.82rem}.score-row-bar{background:var(--gray-100);border-radius:99px;flex-shrink:0;width:80px;height:8px;overflow:hidden}.score-row-fill{border-radius:99px;height:100%;transition:width .4s}.score-row-val{text-align:right;flex-shrink:0;width:2.2rem;font-size:.8rem;font-weight:700}.gap-card{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:10px;align-items:flex-start;gap:.75rem;margin-bottom:.6rem;padding:.9rem;display:flex}.gap-rank{color:var(--purple);background:var(--purple-light);border-radius:6px;flex-shrink:0;padding:.25rem .5rem;font-size:1rem;font-weight:900}.gap-content{flex:1}.gap-title{margin-bottom:.35rem;font-size:.9rem;font-weight:700}.gap-score{color:#ef4444;font-weight:600}.gap-target{color:var(--gray-500);font-size:.8rem;line-height:1.4}.what-means-text{color:var(--gray-700);font-size:.9rem;line-height:1.6}.results-actions{flex-wrap:wrap;gap:.75rem;margin-bottom:.5rem;display:flex}.app-footer{border-radius:var(--radius);border:1.5px dashed var(--yellow);color:var(--gray-700);background:#fff;margin-top:1.5rem;padding:1.25rem;font-size:.82rem;line-height:1.6}.app-footer p+p{margin-top:.5rem}.footer-copy{color:var(--gray-500);font-size:.78rem}@media print{body{background:#fff}.app-header{color:#000;background:#fff;border-bottom:2px solid #333}.header-logo,.header-title{color:#000}.live-score-bar,.submit-area,.results-actions,.cat-what-5{display:none!important}.cat-card,.results-section,.score-banner{box-shadow:none;break-inside:avoid;border:1px solid #ddd}.score-banner{border:1px solid #999}}@media (width<=480px){.app-header{padding:1.5rem 1rem}.container{padding:1rem .75rem}.score-banner{flex-direction:column;align-items:flex-start}.score-row-bar{width:50px}.results-actions{flex-direction:column}.results-actions .btn{text-align:center;width:100%}}
