:root{--background:#f6f8fb;--foreground:#0f172a;--muted:#475569;--card:#ffffff;--border:#dbe2ea;--primary:#0f172a;--primary-foreground:#ffffff;--accent:#eff6ff;--danger:#7f1d1d;--danger-bg:#fef2f2;--shadow:0 10px 30px rgba(15,23,42,0.08)}*{box-sizing:border-box}body,html{padding:0;margin:0;background:var(--background);color:var(--foreground);font-family:Arial,Helvetica,sans-serif}body{min-height:100vh}a{color:inherit;text-decoration:none}.page{max-width:960px;margin:0 auto;padding:32px 20px 56px}.hero{margin-bottom:28px}.hero h1{margin:0 0 8px;font-size:2.2rem;line-height:1.15}.hero p{margin:0;color:var(--muted);max-width:760px;line-height:1.5}.card{background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:20px;padding:18px}.card h2,.card h3{margin-top:0}.label{display:block;font-size:.95rem;margin-bottom:8px;font-weight:700}.textarea{width:100%;min-height:220px;resize:vertical;border-radius:14px;border:1px solid var(--border);padding:14px;font:inherit;line-height:1.45;background:#fff}.textarea+.label{margin-top:18px}.actions{display:flex;gap:12px;margin-top:16px;flex-wrap:wrap}.button{border:none;border-radius:999px;padding:12px 18px;font-weight:700;cursor:pointer;font:inherit;transition:transform .12s ease,opacity .12s ease}.button:hover{transform:translateY(-1px)}.button:disabled{opacity:.55;transform:none}.button.primary{background:var(--primary);color:var(--primary-foreground)}.button.secondary{background:var(--accent);color:var(--foreground)}.muted{color:var(--muted)}.error{margin-top:12px;padding:12px 14px;border-radius:14px;border:1px solid #fecaca;background:var(--danger-bg);color:var(--danger)}.score{display:flex;align-items:baseline;gap:12px;margin-bottom:12px}.score-value{font-size:3rem;font-weight:800}.badge{display:inline-block;padding:6px 10px;border-radius:999px;font-size:.9rem;font-weight:700;border:1px solid transparent}.badge.strong{background:#dcfce7;color:#166534;border-color:#bbf7d0}.badge.good{background:#dbeafe;color:#1d4ed8;border-color:#bfdbfe}.badge.moderate{background:#fef3c7;color:#92400e;border-color:#fde68a}.badge.weak{background:#fee2e2;color:#b91c1c;border-color:#fecaca}.breakdown{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:12px;gap:12px}.breakdown-item{background:#f8fafc;border:1px solid var(--border);border-radius:16px;padding:12px}.section-list{margin:0;padding-left:18px;line-height:1.6}.section-list li+li{margin-top:8px}.chips{display:flex;flex-wrap:wrap;gap:8px}.chip{display:inline-flex;padding:8px 10px;border-radius:999px;background:#f8fafc;border:1px solid var(--border);font-size:.9rem}.stack{grid-gap:20px}.dual,.stack{display:grid;gap:20px}.dual{grid-template-columns:1fr 1fr;grid-gap:20px}@media (max-width:720px){.breakdown,.dual{grid-template-columns:1fr}}.bullet-card{border:1px solid var(--border);border-radius:16px;padding:14px;background:#f8fafc}.bullet-card p{margin:8px 0 0;line-height:1.5}.small{font-size:.9rem}.progress-bar{height:6px;margin-top:8px}.progress-fill{background:#0f172a}.score-card{padding:22px}.score-hero{margin-bottom:16px}.score-scale{padding-bottom:6px}.score-summary{line-height:1.65}.hero-card{background:linear-gradient(180deg,#ffffff,#f8fbff);border:1px solid var(--border);border-radius:28px;box-shadow:var(--shadow);padding:28px 24px;margin-bottom:24px}.hero-eyebrow{display:inline-flex;padding:7px 12px;border-radius:999px;background:#eef2ff;color:#3730a3;font-size:.85rem;font-weight:700;margin-bottom:12px}.hero-subtitle{font-size:1.05rem;margin-top:8px;color:var(--muted);max-width:720px;line-height:1.65}.hero-pills{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}.hero-pill{display:inline-flex;padding:8px 12px;border-radius:999px;background:#ffffff;border:1px solid var(--border);color:var(--foreground);font-size:.9rem;font-weight:600}.section-card{padding:22px;margin-bottom:4px;border-left:4px solid #e5e7eb}.section-card-accent{border-left-color:#c7d2fe}.section-header{display:flex;align-items:flex-start;gap:14px;margin-bottom:18px}.section-header h2{margin:0 0 6px;font-size:1.35rem}.section-header p{margin:0}.section-step{width:34px;height:34px;min-width:34px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-weight:800;background:var(--primary);color:var(--primary-foreground)}.score-card{padding:24px;text-align:center}.score-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:18px;flex-wrap:wrap;text-align:left}.score-card-subtitle{margin:6px 0 0;max-width:520px}.score-hero{display:flex;align-items:end;justify-content:center;gap:12px;margin-bottom:18px;flex-wrap:wrap}.score-value{font-size:4rem;font-weight:900;line-height:1}.score-scale{font-size:.95rem;padding-bottom:8px}.score-summary{line-height:1.75;max-width:760px;margin:0 auto;text-align:left;background:#fbfdff;border:1px solid #eef2f7;border-radius:18px;padding:16px}.breakdown-subtitle{margin:-6px 0 14px}.breakdown-topline{display:flex;justify-content:space-between;gap:12px;align-items:center}.breakdown-score{margin-top:4px}.breakdown-percent{font-weight:700}.progress-bar{height:8px;border-radius:999px;background:#e5e7eb;margin-top:10px;overflow:hidden}.progress-fill{height:100%}.progress-fill.strong{background:#16a34a}.progress-fill.good{background:#2563eb}.progress-fill.moderate{background:#d97706}.progress-fill.weak{background:#dc2626}.button.primary{background:#111827;color:white;box-shadow:0 4px 12px rgba(0,0,0,.12)}.button.primary:hover{background:#0b1220}.button.secondary{background:#f3f4f6;color:#111827}.button.ghost{background:#f8fafc;color:var(--foreground);border:1px solid var(--border)}.helper-text,.trust-note{margin-top:14px;line-height:1.55}.trust-note{padding:12px 14px;border-radius:14px;background:#f8fafc;border:1px solid var(--border);color:var(--muted);font-size:.95rem}.empty-state{padding:10px 4px 4px}.empty-state h3{margin:0 0 8px}.inner-card{box-shadow:none;background:#fbfdff;border:1px solid #eef2f7}.subheading{margin:18px 0 10px;font-size:1rem}.footer{margin-top:40px;text-align:center}.button:disabled{background:#e5e7eb!important;color:#9ca3af!important;border:1px solid #e5e7eb!important;box-shadow:none!important;cursor:not-allowed;opacity:1}.copy-header{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.copy-header h3{margin:0}.copy-header-spaced{margin-top:12px}.small-button{padding:8px 12px;font-size:.9rem;border-radius:999px}.toggle{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap}.upload-box{border:1px dashed var(--border);border-radius:16px;background:#fbfdff;padding:16px;margin-bottom:14px}.upload-box input[type=file]{display:block;margin-bottom:10px}.success-message{margin:10px 0 14px;padding:12px 14px;border-radius:14px;background:#ecfdf5;border:1px solid #bbf7d0;color:#166534;line-height:1.5}