*{box-sizing:border-box}html{scroll-behavior:smooth;overflow-x:hidden;-webkit-text-size-adjust:100%}body{margin:0;font-family:Manrope,-apple-system,BlinkMacSystemFont,sans-serif;background:#1e2228;color:#e8e6e3;line-height:1.6;min-height:100dvh;min-height:100vh;-webkit-font-smoothing:antialiased;overflow-x:hidden}#root{min-height:100%}:root{--bg: #1e2228;--surface: #252a33;--surface-hover: #2d333d;--text: #e8e6e3;--text-muted: #9ca3af;--accent: #d4a84b;--accent-soft: rgba(212, 168, 75, .2);--danger: #e05c5c;--danger-soft: rgba(224, 92, 92, .18);--warn: #c9a227;--warn-soft: rgba(201, 162, 39, .18);--safe: #5ba86b;--safe-soft: rgba(91, 168, 107, .18);--radius: 14px;--radius-sm: 10px;--shadow: 0 4px 24px rgba(0, 0, 0, .35);--touch: 44px;--btn-primary-text: #1a1510}.skip-link{position:absolute;top:0;left:0;padding:.75rem 1rem;background:var(--accent);color:var(--btn-primary-text);font-weight:600;text-decoration:none;z-index:100;transform:translateY(-100%);transition:transform .2s}.skip-link:focus{transform:translateY(0);outline:2px solid var(--text);outline-offset:2px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.container{position:relative;width:100%;min-width:0;max-width:680px;margin-inline:auto;padding:clamp(.75rem,4vw,2.5rem) clamp(.75rem,4vw,1.5rem) clamp(2rem,8vw,5rem);padding-left:max(clamp(.75rem,4vw,1.5rem),env(safe-area-inset-left));padding-right:max(clamp(.75rem,4vw,1.5rem),env(safe-area-inset-right));padding-bottom:max(clamp(2rem,8vw,5rem),env(safe-area-inset-bottom))}header{text-align:center;margin-bottom:clamp(1.5rem,4vw,2.5rem)}header h1{font-family:Playfair Display,serif;font-size:clamp(1.25rem,4vw + .5rem,2.1rem);font-weight:600;color:var(--text);margin:0 0 .5rem;word-wrap:break-word;overflow-wrap:break-word}header p{color:var(--text-muted);font-size:clamp(.8125rem,2vw + .5rem,1rem);margin:0}.disclaimer{background:var(--surface);border:1px solid var(--accent-soft);border-radius:var(--radius);padding:1rem 1.25rem;margin-bottom:clamp(1.5rem,4vw,2rem);font-size:.9rem;color:var(--text-muted)}.disclaimer strong{color:var(--accent)}.intro-how-to{background:var(--surface);border-radius:var(--radius);padding:1rem 1.25rem;margin-bottom:clamp(1.25rem,4vw,1.75rem);font-size:.9rem;line-height:1.55;color:var(--text-muted)}.intro-how-to p{margin:0}.admin-page{padding:1rem 0}.admin-page h1{font-size:1.25rem;margin:0 0 .5rem;color:var(--text)}.admin-intro{font-size:.9rem;color:var(--text-muted);margin:0 0 1rem}.admin-stats{font-size:.95rem;margin:0 0 1rem;padding:.75rem;background:var(--surface-hover);border-radius:var(--radius)}.admin-stats p{margin:.25rem 0}.admin-section-title{font-size:1.1rem;margin:1.5rem 0 .5rem;color:var(--text)}.admin-table-wrap{overflow-x:auto;margin-bottom:1rem}.admin-table{width:100%;border-collapse:collapse;font-size:.85rem}.admin-table th,.admin-table td{padding:.5rem .75rem;text-align:left;border-bottom:1px solid var(--surface-hover)}.admin-table th{color:var(--text-muted);font-weight:600}.admin-table td{color:var(--text)}.dim-scores{display:inline-flex;gap:.25rem}.dim-scores span{display:inline-block;min-width:1.5rem;text-align:center}.device-cell{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-empty{color:var(--text-muted);margin:1rem 0}.admin-back{margin:1rem 0 0}.admin-back a{color:var(--accent);text-decoration:none}.admin-back a:hover{text-decoration:underline}.admin-row-clickable{cursor:pointer}.admin-row-clickable:hover{background:var(--surface-hover)}.admin-expand-icon{width:1.5rem;color:var(--text-muted);font-size:.75rem}.admin-detail-cell{padding:0;vertical-align:top;border-bottom:1px solid var(--surface-hover);background:var(--bg)}.admin-row-detail{padding:1rem 1.25rem 1.25rem;text-align:left}.admin-detail-block{margin-bottom:1rem}.admin-detail-block:last-child{margin-bottom:0}.admin-detail-block h4{font-size:.85rem;font-weight:600;margin:0 0 .35rem;color:var(--accent)}.admin-detail-title{font-weight:600;margin:0 0 .25rem;color:var(--text);font-size:.9rem}.admin-detail-body{margin:0;font-size:.875rem;line-height:1.55;color:var(--text-muted)}.admin-dim-list,.admin-alerts-list{margin:0;padding-left:1.25rem;font-size:.875rem;line-height:1.5;color:var(--text)}.admin-dim-list li,.admin-alerts-list li{margin-bottom:.25rem}.admin-answers-raw,.admin-ua-raw{margin:0;font-size:.8rem;color:var(--text-muted);word-break:break-all;line-height:1.4}.admin-actions-cell{white-space:nowrap}.admin-btn-delete{padding:.25rem .5rem;font-size:.8rem;color:var(--text);background:var(--surface-hover);border:1px solid var(--text-muted);border-radius:var(--radius-sm);cursor:pointer}.admin-btn-delete:hover{background:#4a2020;color:#fff;border-color:#6a3030}.questionnaire{margin-top:0}.progress-info{text-align:center;color:var(--text-muted);font-size:.9rem;margin-bottom:.75rem}.progress-bar{height:6px;background:var(--surface-hover);border-radius:3px;overflow:hidden;margin-bottom:1.5rem}.progress-bar .progress-fill{display:block;height:100%;background:var(--accent);border-radius:3px;transition:width .35s ease}.block{background:var(--surface);border-radius:var(--radius);padding:clamp(1.25rem,3vw,1.5rem);margin-bottom:1.25rem;box-shadow:var(--shadow)}.block h2{font-size:clamp(1rem,2vw + .5rem,1.15rem);font-weight:600;margin:0 0 1rem}.block-title-minimal{font-size:.9rem;font-weight:600;color:var(--text-muted);margin:0 0 .75rem}.block-hint-minimal{margin-bottom:.5rem;color:var(--text)}.intro-line{font-size:.9rem;color:var(--text-muted);margin:0 0 1rem;line-height:1.45}.block-hint summary{cursor:pointer;font-size:.875rem;color:var(--accent);list-style:none;display:inline-flex;align-items:center;gap:.35rem}.block-hint summary::-webkit-details-marker{display:none}.block-hint summary:before{content:"▸ "}.block-hint[open] summary:before{content:"▾ "}.block-hint .hint-text{margin-top:.5rem;padding:.75rem;background:var(--bg);border-radius:var(--radius-sm);font-size:.8125rem;color:var(--text-muted);line-height:1.5}.question{margin-bottom:1.25rem}.question:last-child{margin-bottom:0}.question label{display:block;font-size:clamp(.875rem,1.5vw + .4rem,1rem);margin-bottom:.5rem;color:var(--text);overflow-wrap:break-word;word-wrap:break-word}.question .scale{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center}.question .opt-wrap{margin:0}.question .opt-wrap input[type=radio]{position:absolute;opacity:0;width:0;height:0}.question .opt{display:inline-flex;align-items:center;justify-content:center;min-width:max(var(--touch),2.25rem);min-height:var(--touch);padding:0 .5rem;border:1px solid var(--surface-hover);border-radius:var(--radius-sm);background:var(--bg);color:var(--text-muted);font-size:clamp(.75rem,2vw + .4rem,.9rem);cursor:pointer;transition:background .2s,border-color .2s,color .2s;white-space:nowrap}.question .opt-wrap:hover .opt{background:var(--surface-hover);color:var(--text)}.question .opt-wrap input:focus-visible+.opt{outline:2px solid var(--accent);outline-offset:2px}.question .opt-wrap input:checked+.opt{background:var(--accent-soft);border-color:var(--accent);color:var(--accent);font-weight:500}.question .opt-wrap-scenario{display:block;width:100%}.question .opt-wrap-scenario .opt{display:block;min-height:var(--touch);padding:.6rem .75rem;text-align:left;white-space:normal;line-height:1.4}.question .scale:has(.opt-wrap-scenario){flex-direction:column;gap:.5rem}.step{display:none}.step.active{display:block;animation:stepIn .25s ease}@keyframes stepIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.step-nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-top:1.5rem;flex-wrap:wrap}.step-nav .step-info{color:var(--text-muted);font-size:.9rem;order:3;width:100%;text-align:center}@media(min-width:400px){.step-nav .step-info{order:0;width:auto}}.btn{display:inline-flex;align-items:center;justify-content:center;min-height:52px;padding:.9rem 2.25rem;font-family:inherit;font-size:1.05rem;font-weight:700;border:none;border-radius:var(--radius);cursor:pointer;transition:transform .2s,box-shadow .2s,background .2s;box-shadow:0 2px 8px #00000040}.btn:focus-visible{outline:3px solid var(--accent);outline-offset:3px}.btn-primary{background:linear-gradient(180deg,#e0b85a 0%,var(--accent) 50%,#c4983a 100%);color:var(--btn-primary-text);border:2px solid rgba(255,255,255,.2);box-shadow:0 4px 16px #d4a84b66,inset 0 1px #ffffff26}.btn-primary:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 8px 28px #d4a84b80,inset 0 1px #fff3}.btn-primary:active:not(:disabled){transform:translateY(-1px)}.btn-primary:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:0 2px 6px #0003}.btn-secondary{background:var(--surface-hover);color:var(--text);border:2px solid var(--text-muted);box-shadow:0 2px 10px #0003}.btn-secondary:hover:not(:disabled){background:var(--surface);border-color:var(--accent);box-shadow:0 4px 14px #00000040}.btn-outline{background:transparent;color:var(--accent);border:2px solid var(--accent);margin-top:1rem;box-shadow:0 2px 10px #d4a84b33}.btn-outline:hover{background:var(--accent-soft);box-shadow:0 4px 18px #d4a84b59}.result-section{margin-top:2rem}.result-hero{text-align:center;padding:clamp(1.5rem,4vw,2rem);border-radius:var(--radius);margin-bottom:1.5rem;box-shadow:var(--shadow)}.result-hero.low{background:linear-gradient(135deg,var(--safe-soft) 0%,var(--surface) 50%);border:1px solid rgba(91,168,107,.35)}.result-hero.mid{background:linear-gradient(135deg,var(--warn-soft) 0%,var(--surface) 50%);border:1px solid rgba(201,162,39,.35)}.result-hero.high{background:linear-gradient(135deg,var(--danger-soft) 0%,var(--surface) 50%);border:1px solid rgba(224,92,92,.35)}.result-hero h2{font-family:Playfair Display,serif;font-size:clamp(1.35rem,3vw + .5rem,1.75rem);margin:0 0 .5rem;color:var(--text)}.result-hero .score-badge{display:block;font-size:clamp(2rem,5vw,2.75rem);font-weight:700;margin:.5rem 0;letter-spacing:-.02em}.result-hero.low .score-badge{color:var(--safe)}.result-hero.mid .score-badge{color:var(--warn)}.result-hero.high .score-badge{color:var(--danger)}.result-hero .score-label{color:var(--text-muted);font-size:.9rem;margin:0}.charts-row{display:grid;grid-template-columns:1fr;gap:1.25rem;margin-bottom:1.5rem}@media(min-width:520px){.charts-row{grid-template-columns:1fr 1fr;gap:1.5rem}}@media(min-width:768px){.charts-row{grid-template-columns:1fr 1fr}.chart-card-full{grid-column:1 / -1}}.chart-card{background:var(--surface);border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow)}.chart-card h3{font-size:1rem;font-weight:600;margin:0 0 1rem;color:var(--text)}.radar-wrap{min-height:260px}.bar-chart-wrap{min-height:220px}.dim-bars{display:flex;flex-direction:column;gap:.75rem}.dim-bar-row{display:grid;grid-template-columns:1fr auto;gap:.5rem;align-items:center;font-size:.875rem}.dim-bar-row span:first-child{grid-column:1;color:var(--text)}.dim-bar-row span:nth-child(2){grid-column:2;color:var(--text-muted)}.dim-bar-track{grid-column:1 / -1;height:8px;background:var(--surface-hover);border-radius:4px;overflow:hidden}.dim-bar-fill{height:100%;border-radius:4px;transition:width .35s ease}.dim-alerts-list{display:flex;flex-direction:column;gap:.75rem}.dim-alert{padding:.75rem 1rem;border-radius:var(--radius-sm);font-size:.9rem;border-inline-start:3px solid var(--warn);background:#c9a2271a;color:var(--text)}.dim-alert.danger{border-color:var(--danger);background:var(--danger-soft)}.result-card{background:var(--surface);border-radius:var(--radius);padding:1.25rem 1.5rem;margin-bottom:1.25rem;box-shadow:var(--shadow)}.result-card h3{font-size:1rem;font-weight:600;margin:0 0 .75rem;color:var(--text)}.result-card-body p{margin:0;line-height:1.65;color:var(--text)}.result-card-detail{background:var(--surface);border-radius:var(--radius);padding:1.25rem 1.5rem;margin-bottom:1.25rem;box-shadow:var(--shadow)}.result-card-detail h3{font-size:1rem;font-weight:600;margin:0 0 .75rem;color:var(--text)}.result-card-detail .detail-intro,.result-card-detail .detail-closing{font-size:.9rem;line-height:1.6;color:var(--text-muted);margin:0 0 1rem}.result-card-detail .detail-blocks{display:flex;flex-direction:column;gap:1.25rem;margin-bottom:1rem}.result-card-detail .detail-block h4{font-size:.95rem;font-weight:600;margin:0 0 .35rem;color:var(--text)}.result-card-detail .detail-block p{margin:0;font-size:.9rem;line-height:1.6;color:var(--text)}.result-card-detail .detail-ref{font-size:.8rem;color:var(--text-muted);margin-top:.35rem;font-style:italic}.questionnaire-sources-card ul.sources-list{display:flex;flex-wrap:wrap;gap:.5rem 1rem}.questionnaire-sources-card .source-item{margin-bottom:0}.sources-card{background:var(--surface);border-radius:var(--radius);padding:1.25rem 1.5rem;margin-bottom:1.25rem;box-shadow:var(--shadow)}.sources-card h3{font-size:1rem;font-weight:600;margin:0 0 .5rem;color:var(--text)}.sources-intro{font-size:.875rem;color:var(--text-muted);margin:0 0 1rem;line-height:1.5}.sources-list{list-style:none;padding:0;margin:0}.source-item{margin-bottom:.875rem;font-size:.9rem;line-height:1.55;color:var(--text)}.source-item .stat{font-weight:700;color:var(--accent)}.source-link{color:var(--accent);text-decoration:underline;text-underline-offset:2px}.source-link:hover{text-decoration:none}.resources{list-style:none;padding:0;margin:0;font-size:.95rem;line-height:1.6;color:var(--text)}.resources li{margin-bottom:.5rem}@media(max-width:380px){.question .scale{gap:.3rem}.question .opt{min-width:2.25rem;padding:0 .35rem;font-size:.7rem}}@media(max-height:500px)and (orientation:landscape){.container{padding-block:1rem}.block{margin-bottom:1rem}.question{margin-bottom:.875rem}}@media(min-width:1024px){.container{max-width:720px}.charts-row{gap:1.75rem}}
