/* M4W-pro-v3 Design System */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Noto+Sans+SC:wght@300;400;500;600;700&display=swap');
:root{
  --primary:#4F46E5;--primary-dark:#4338CA;--primary-light:#818CF8;
  --primary-alpha:rgba(79,70,229,0.08);--primary-alpha2:rgba(79,70,229,0.12);
  --accent:#F59E0B;--accent-dark:#D97706;--accent-alpha:rgba(245,158,11,0.12);
  --success:#10B981;--success-alpha:rgba(16,185,129,0.1);
  --danger:#EF4444;--danger-alpha:rgba(239,68,68,0.1);
  --sky:#0EA5E9;--sky-alpha:rgba(14,165,233,0.1);
  --gray-50:#FAFAFA;--gray-100:#F3F4F6;--gray-200:#E5E7EB;--gray-300:#D1D5DB;
  --gray-400:#9CA3AF;--gray-500:#6B7280;--gray-600:#4B5563;--gray-700:#374151;
  --gray-800:#1F2937;--gray-900:#111827;
  --bg:#FAFAFA;--bg-card:#FFFFFF;--border:#E5E7EB;--border-2:#D1D5DB;
  --text-1:#111827;--text-2:#374151;--text-3:#6B7280;--text-muted:#9CA3AF;
  --s-1:4px;--s-2:8px;--s-3:12px;--s-4:16px;--s-5:20px;--s-6:24px;
  --s-8:32px;--s-10:40px;--s-12:48px;--s-16:64px;--s-20:80px;
  --r-sm:6px;--r-md:10px;--r-lg:16px;--r-xl:24px;--r-full:9999px;
  --sh-xs:0 1px 2px rgba(0,0,0,0.04);
  --sh-sm:0 1px 3px rgba(0,0,0,0.06),0 1px 2px rgba(0,0,0,0.04);
  --sh-md:0 4px 6px -1px rgba(0,0,0,0.07),0 2px 4px -1px rgba(0,0,0,0.05);
  --sh-lg:0 10px 15px -3px rgba(0,0,0,0.08),0 4px 6px -2px rgba(0,0,0,0.04);
  --sh-xl:0 20px 25px -5px rgba(0,0,0,0.1),0 10px 10px -5px rgba(0,0,0,0.04);
  --sh-card-hover:0 8px 24px -4px rgba(79,70,229,0.12),0 4px 8px -2px rgba(0,0,0,0.06);
  --font:'Inter','Noto Sans SC',-apple-system,BlinkMacSystemFont,sans-serif;
  --fs-xs:11px;--fs-sm:13px;--fs-base:15px;--fs-md:16px;
  --fs-lg:18px;--fs-xl:20px;--fs-2xl:24px;--fs-3xl:30px;--fs-4xl:36px;--fs-5xl:48px;
  --t-fast:120ms ease;--t-base:200ms ease;--t-slow:300ms ease;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;-webkit-font-smoothing:antialiased;scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg);color:var(--text-1);line-height:1.6;min-height:100vh}
a{color:inherit;text-decoration:none}
button{font-family:var(--font);cursor:pointer;border:none;background:none}
img,svg{display:block}
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:var(--r-full)}
::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}
::selection{background:var(--primary-alpha2);color:var(--primary-dark)}
:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:var(--r-sm)}
#app{min-height:100vh;display:flex;flex-direction:column}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--s-2);font-size:var(--fs-sm);font-weight:600;padding:var(--s-3) var(--s-5);border-radius:var(--r-full);transition:all var(--t-fast);cursor:pointer;border:none;letter-spacing:0.01em;white-space:nowrap}
.btn:active{transform:scale(0.97)}
.btn-primary{background:var(--primary);color:#fff;box-shadow:0 2px 8px rgba(79,70,229,0.25)}
.btn-primary:hover{background:var(--primary-dark);box-shadow:0 4px 12px rgba(79,70,229,0.35)}
.btn-secondary{background:var(--gray-100);color:var(--text-2);border:1px solid var(--border)}
.btn-secondary:hover{background:var(--gray-200)}
.btn-lg{padding:var(--s-4) var(--s-8);font-size:var(--fs-md)}
.btn-xl{padding:14px var(--s-10);font-size:var(--fs-lg)}
.btn-accent{background:var(--accent);color:#fff;box-shadow:0 2px 8px rgba(245,158,11,0.3)}
.btn-accent:hover{background:var(--accent-dark)}

/* Tags */
.tag{display:inline-flex;align-items:center;font-size:var(--fs-xs);font-weight:600;padding:3px 10px;border-radius:var(--r-full)}
.tag-primary{background:var(--primary-alpha);color:var(--primary)}
.tag-accent{background:var(--accent-alpha);color:var(--accent-dark)}
.tag-success{background:var(--success-alpha);color:var(--success)}
.tag-danger{background:var(--danger-alpha);color:var(--danger)}
.tag-sky{background:var(--sky-alpha);color:var(--sky)}

/* Shared */
.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--s-6);box-shadow:var(--sh-sm);transition:all var(--t-base)}
.card:hover{box-shadow:var(--sh-lg);transform:translateY(-1px)}
.footer{padding:var(--s-6) var(--s-8);border-top:1px solid var(--border);text-align:center;font-size:var(--fs-sm);color:var(--text-muted);margin-top:auto}

/* HOME */
.home-shell{min-height:100vh;display:flex;flex-direction:column;background:var(--gray-50)}
.home-nav{display:flex;align-items:center;justify-content:space-between;padding:var(--s-4) var(--s-8);background:rgba(255,255,255,0.95);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;backdrop-filter:blur(16px)}
.home-nav-logo{display:flex;align-items:center;gap:var(--s-3)}
.home-nav-brand{font-size:var(--fs-md);font-weight:800;color:var(--gray-900);letter-spacing:-0.02em}
.home-nav-links{display:flex;align-items:center;gap:var(--s-6)}
.home-nav-links a{font-size:var(--fs-sm);font-weight:500;color:var(--text-3);transition:color var(--t-fast)}
.home-nav-links a:hover{color:var(--primary)}
.hero{position:relative;flex:0 0 auto;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--s-20) var(--s-8) var(--s-16);text-align:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse 90% 60% at 50% -5%,rgba(79,70,229,0.08) 0%,transparent 60%),radial-gradient(ellipse 50% 40% at 85% 85%,rgba(245,158,11,0.05) 0%,transparent 55%);pointer-events:none}
.hero-pattern{position:absolute;inset:0;opacity:0.4;pointer-events:none}
.hero-badge{position:relative;display:inline-flex;align-items:center;gap:var(--s-2);background:var(--primary-alpha);border:1px solid rgba(79,70,229,0.18);border-radius:var(--r-full);padding:6px 14px;margin-bottom:var(--s-6);font-size:var(--fs-xs);font-weight:700;color:var(--primary);letter-spacing:0.08em;text-transform:uppercase}
.hero-badge-dot{width:6px;height:6px;border-radius:50%;background:var(--primary);animation:pulse-dot 2.5s ease-in-out infinite}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.5;transform:scale(0.8)}}
.hero-title{position:relative;font-size:clamp(2.25rem,6vw,3.75rem);font-weight:800;letter-spacing:-0.03em;color:var(--gray-900);line-height:1.08;margin-bottom:var(--s-5)}
.hero-title-accent{color:var(--primary)}
.hero-sub{position:relative;font-size:var(--fs-lg);color:var(--text-3);line-height:1.8;max-width:480px;margin:0 auto var(--s-10)}
.hero-cta{position:relative}
.walls-section{flex:1;padding:var(--s-12) var(--s-8) var(--s-16)}
.walls-grid{max-width:960px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s-4)}
.wall-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--s-5);display:flex;flex-direction:column;box-shadow:var(--sh-sm);position:relative;overflow:hidden;transition:box-shadow var(--t-base),transform var(--t-base),border-color var(--t-base)}
.wall-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;transition:height var(--t-base)}
.wall-card:hover{box-shadow:var(--sh-card-hover);transform:translateY(-2px);border-color:transparent}
.wall-card:hover::before{height:4px}
.wall-indigo::before{background:var(--primary)}
.wall-sky::before{background:var(--sky)}
.wall-amber::before{background:var(--accent)}
.wall-emerald::before{background:var(--success)}
.wall-icon{width:44px;height:44px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;margin-bottom:var(--s-3);transition:transform var(--t-base)}
.wall-card:hover .wall-icon{transform:scale(1.05)}
.wall-indigo .wall-icon{background:var(--primary-alpha);color:var(--primary)}
.wall-sky    .wall-icon{background:var(--sky-alpha);color:var(--sky)}
.wall-amber  .wall-icon{background:var(--accent-alpha);color:var(--accent)}
.wall-emerald .wall-icon{background:var(--success-alpha);color:var(--success)}
.wall-name{font-size:var(--fs-md);font-weight:700;color:var(--gray-900);margin-bottom:2px}
.wall-abbr{font-size:var(--fs-xs);font-weight:700;letter-spacing:0.1em;text-transform:uppercase;margin-bottom:var(--s-2)}
.wall-indigo .wall-abbr{color:var(--primary)}
.wall-sky    .wall-abbr{color:var(--sky)}
.wall-amber  .wall-abbr{color:var(--accent)}
.wall-emerald .wall-abbr{color:var(--success)}
.wall-poles{display:flex;gap:6px;align-items:center;margin-bottom:var(--s-3);font-size:var(--fs-sm);font-weight:600;color:var(--text-2)}
.pole-sep{color:var(--text-muted);font-weight:400}
.wall-desc{font-size:var(--fs-sm);color:var(--text-3);line-height:1.65;flex:1}
.home-footer{padding:var(--s-5) var(--s-8);border-top:1px solid var(--border);text-align:center;font-size:var(--fs-sm);color:var(--text-muted)}
@media(max-width:900px){.walls-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.hero{padding:var(--s-12) var(--s-5) var(--s-10)}.walls-section{padding:var(--s-8) var(--s-5) var(--s-12)}.home-nav,.home-footer{padding-left:var(--s-5);padding-right:var(--s-5)}}
@media(max-width:480px){.walls-grid{grid-template-columns:1fr}}

/* TEST */
.test-shell{min-height:100vh;background:var(--gray-50);display:flex;flex-direction:column}
.test-topbar{display:flex;align-items:center;gap:var(--s-4);padding:var(--s-4) var(--s-6);background:rgba(255,255,255,0.95);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50;backdrop-filter:blur(12px)}
.test-progress-info{flex:1;display:flex;align-items:center;gap:var(--s-4);min-width:0}
.test-q-counter{font-size:var(--fs-sm);font-weight:700;color:var(--gray-900);white-space:nowrap;flex-shrink:0}
.test-progress-bar{flex:1;height:5px;background:var(--gray-200);border-radius:var(--r-full);overflow:hidden}
.test-progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--primary-light));border-radius:var(--r-full);transition:width 0.4s cubic-bezier(0.4,0,0.2,1);width:0%}
.test-close{width:34px;height:34px;border-radius:50%;background:var(--gray-100);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-3);flex-shrink:0;transition:all var(--t-fast)}
.test-close:hover{background:var(--gray-200);color:var(--text-1)}
.q-grid{flex:1;max-width:680px;width:100%;margin:0 auto;padding:var(--s-6) var(--s-4) var(--s-4);display:flex;flex-direction:column;gap:var(--s-3)}
.q-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--r-lg);padding:var(--s-5) var(--s-6);box-shadow:var(--sh-xs);transition:border-color var(--t-base),box-shadow var(--t-base)}
.q-card-answered{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-alpha),var(--sh-sm)}
.q-card:hover:not(.q-card-answered){border-color:var(--border-2);box-shadow:var(--sh-sm)}
.q-text{font-size:var(--fs-md);font-weight:600;color:var(--text-1);line-height:1.65;margin-bottom:var(--s-4);font-family:var(--font)}
.q-options{display:flex;align-items:center;justify-content:space-between;padding:0;gap:var(--s-1)}
.q-option{display:flex;flex-direction:column;align-items:center;gap:6px;flex:1;cursor:pointer;padding:var(--s-1) 0}
.q-option-circle{border-radius:50%;border:2px solid var(--gray-300);background:var(--bg-card);transition:border-color var(--t-fast),background var(--t-fast),transform var(--t-fast);display:flex;align-items:center;justify-content:center;width:26px;height:26px}
.q-option-circle:hover{border-color:var(--primary);background:var(--primary-alpha);transform:scale(1.08)}
.q-option.selected .q-option-circle{border-color:var(--primary);background:var(--primary)}
.q-option.selected .q-option-circle::after{content:'';width:8px;height:8px;border-radius:50%;background:#fff;display:block}
.q-option-label{font-size:10px;color:var(--text-muted);text-align:center;line-height:1.3;font-weight:500;transition:color var(--t-fast)}
.q-option.selected .q-option-label{color:var(--primary);font-weight:700}
.test-bottom{padding:var(--s-4) var(--s-4) var(--s-8);max-width:680px;width:100%;margin:0 auto}
.test-btn-submit{width:100%;padding:15px var(--s-8);border-radius:var(--r-lg);border:none;background:var(--accent);color:#fff;font-size:var(--fs-md);font-weight:700;cursor:pointer;letter-spacing:0.02em;box-shadow:0 4px 14px rgba(245,158,11,0.35);display:none;text-align:center;transition:background var(--t-fast),box-shadow var(--t-fast),transform var(--t-fast)}
.test-btn-submit:hover{background:var(--accent-dark);box-shadow:0 6px 20px rgba(245,158,11,0.45)}
.test-btn-submit:active{transform:scale(0.99)}
@media(max-width:640px){.test-topbar{padding:var(--s-3) var(--s-4)}.q-grid{padding:var(--s-4) var(--s-3) var(--s-3)}.q-card{padding:var(--s-4)}.q-text{font-size:var(--fs-base)}.q-option-circle{width:22px;height:22px}.test-bottom{padding:var(--s-3) var(--s-3) var(--s-6)}}

/* RESULT */
.rp-shell{min-height:100vh;background:var(--gray-50);display:flex;flex-direction:column}
.rp-hero{background:linear-gradient(135deg,#0f172a 0%,#1e1b4b 40%,#312e81 70%,#4f46e5 100%);color:#fff;min-height:40vh;display:flex;align-items:center;padding:1.25rem 3rem;position:relative;overflow:hidden}
.rp-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 70% 50%,rgba(245,158,11,0.07) 0%,transparent 60%);pointer-events:none}
.rp-hero-inner{max-width:960px;width:100%;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;position:relative}
.rp-hero-left{flex:1;min-width:0}
.rp-type-row{display:flex;align-items:center;gap:var(--s-4);margin-bottom:var(--s-3);flex-wrap:wrap}
.rp-badge{font-size:var(--fs-xl);font-weight:800;letter-spacing:0.06em;background:rgba(245,215,0,0.12);color:#fbbf24;padding:var(--s-2) var(--s-5);border-radius:var(--r-md);border:1px solid rgba(245,215,0,0.25)}
.rp-type-name{font-size:clamp(1.5rem,4vw,2.25rem);font-weight:800;letter-spacing:-0.02em;color:#fff;line-height:1.15}
.rp-tags{display:flex;flex-wrap:wrap;gap:var(--s-2);margin-bottom:var(--s-6)}
.rp-tags .tag{font-size:var(--fs-xs);padding:4px 12px;background:rgba(255,255,255,0.1);color:rgba(255,255,255,0.85);font-weight:500}
.rp-hero-actions{display:flex;gap:var(--s-3);flex-wrap:wrap}
.rp-btn{display:inline-flex;align-items:center;gap:var(--s-2);font-size:var(--fs-sm);font-weight:600;padding:10px 20px;border-radius:var(--r-md);cursor:pointer;border:none;font-family:var(--font);transition:all var(--t-fast)}
.rp-btn-primary{background:rgba(245,215,0,0.9);color:#1c1917}
.rp-btn-primary:hover{background:#fbbf24}
.rp-btn-secondary{background:rgba(255,255,255,0.1);color:rgba(255,255,255,0.85);border:1px solid rgba(255,255,255,0.2)}
.rp-btn-secondary:hover{background:rgba(255,255,255,0.18);color:#fff}
.rp-hero-right{width:220px;height:220px;flex-shrink:0}
#radar-container{width:220px;height:220px}
.rp-body{flex:1;padding:1rem 3rem 1.5rem}
.rp-body-inner{max-width:960px;margin:0 auto;display:flex;flex-direction:column;gap:var(--s-4)}
.rp-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--s-6);box-shadow:var(--sh-sm);width:100%}
.rp-label{font-size:var(--fs-xs);font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.1em;margin-bottom:var(--s-3);display:flex;align-items:center;gap:6px}
.rp-desc{font-size:var(--fs-base);color:var(--text-2);line-height:1.9;margin:0}
.rp-scores{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:auto auto auto;gap:var(--s-2)}
.rp-dim-headers{display:grid;grid-template-columns:repeat(4,1fr);grid-column:1/-1;gap:var(--s-2)}
.rp-dim-h{text-align:center;font-size:var(--fs-sm);font-weight:700;color:var(--text-2);padding:var(--s-2) 0;border-bottom:2px solid var(--border);letter-spacing:0.01em}
.rp-score-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);padding:var(--s-3);display:flex;flex-direction:column;gap:6px;box-shadow:var(--sh-xs)}
.rp-score-label{font-size:11px;font-weight:700;color:var(--text-2);display:flex;align-items:center;justify-content:center;gap:5px}
.rp-score-label span{font-size:10px;font-weight:700;padding:1px 6px;border-radius:var(--r-full)}
.rp-score-A .rp-score-label span,.rp-score-E .rp-score-label span{background:var(--primary-alpha);color:var(--primary)}
.rp-score-D .rp-score-label span,.rp-score-O .rp-score-label span{background:var(--success-alpha);color:var(--success)}
.rp-score-P .rp-score-label span,.rp-score-I .rp-score-label span{background:var(--sky-alpha);color:var(--sky)}
.rp-score-C .rp-score-label span,.rp-score-F .rp-score-label span{background:var(--accent-alpha);color:var(--accent-dark)}
.rp-score-bar-bg{height:6px;background:var(--gray-200);border-radius:var(--r-full);overflow:hidden}
.rp-score-bar{height:100%;border-radius:var(--r-full);transition:width 1.2s cubic-bezier(0.4,0,0.2,1)}
.rp-score-A .rp-score-bar,.rp-score-E .rp-score-bar{background:var(--primary)}
.rp-score-D .rp-score-bar,.rp-score-O .rp-score-bar{background:var(--success)}
.rp-score-P .rp-score-bar,.rp-score-I .rp-score-bar{background:var(--sky)}
.rp-score-C .rp-score-bar,.rp-score-F .rp-score-bar{background:var(--accent-dark)}
.rp-score-num{font-size:var(--fs-sm);font-weight:800;color:var(--text-1);text-align:center}
.rp-3col{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-4)}
.rp-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--s-2)}
.rp-list li{font-size:var(--fs-sm);color:var(--text-2);line-height:1.7;padding-left:var(--s-4);position:relative}
.rp-list li::before{content:'';position:absolute;left:0;top:8px;width:5px;height:5px;border-radius:50%}
#strengths-list li::before{background:var(--success)}
#risks-list li::before{background:var(--danger)}
#suggestions-list li::before{background:var(--sky)}
@media(max-width:800px){.rp-hero{min-height:unset;padding:1.5rem 1.25rem 1.5rem}.rp-hero-inner{flex-direction:column}.rp-hero-right{display:none}.rp-3col{grid-template-columns:1fr}.rp-scores{grid-template-columns:repeat(2,1fr)}.rp-body{padding:1rem 1.25rem 2rem}}
@media(max-width:600px){.rp-body{padding:var(--s-5)}.rp-type-name{font-size:1.375rem}.rp-badge{font-size:var(--fs-lg)}.rp-scores{grid-template-columns:repeat(2,1fr)}}

/* TYPES */
.types-shell{min-height:100vh;background:var(--gray-50)}
.types-nav{display:flex;align-items:center;padding:var(--s-4) var(--s-6);background:rgba(255,255,255,0.95);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;backdrop-filter:blur(12px)}
.types-nav-back{display:flex;align-items:center;gap:6px;font-size:var(--fs-sm);font-weight:500;color:var(--text-3);background:none;border:none;cursor:pointer;font-family:var(--font);transition:color var(--t-fast)}
.types-nav-back:hover{color:var(--primary)}
.types-nav-title{flex:1;text-align:center;font-size:var(--fs-sm);font-weight:700;color:var(--gray-900)}
.types-header{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;padding:var(--s-8) var(--s-6);text-align:center}
.types-header h1{font-size:var(--fs-2xl);font-weight:800;margin-bottom:var(--s-2);letter-spacing:-0.02em}
.types-header p{font-size:var(--fs-sm);opacity:0.8}
.types-grid-wrap{padding:var(--s-6)}
.types-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s-3);max-width:960px;margin:0 auto}
.type-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--s-4);cursor:pointer;display:flex;flex-direction:column;gap:var(--s-2);box-shadow:var(--sh-sm);transition:all var(--t-base)}
.type-card:hover{box-shadow:var(--sh-card-hover);transform:translateY(-2px);border-color:var(--primary)}
.type-card-code{font-size:var(--fs-xs);font-weight:700;letter-spacing:0.1em;color:var(--primary);text-transform:uppercase}
.type-card-name{font-size:var(--fs-md);font-weight:700;color:var(--gray-900);line-height:1.3}
.type-card-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:auto}
.type-card-tags .tag{font-size:10px;padding:2px 8px}
#modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:200;display:flex;align-items:center;justify-content:center;padding:var(--s-5);backdrop-filter:blur(4px)}
#modal-overlay>div{background:#fff;border-radius:20px;max-width:820px;width:100%;max-height:none;overflow:visible;padding:0;position:relative;box-shadow:0 32px 64px rgba(0,0,0,0.2);animation:slideUp 0.22s ease}
@keyframes slideUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.modal-close{position:absolute;top:var(--s-4);right:var(--s-4);width:32px;height:32px;border-radius:50%;background:var(--gray-100);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-3);font-size:16px;transition:all var(--t-fast)}
.modal-close:hover{background:var(--gray-200);color:var(--text-1)}
.modal-badge{font-size:var(--fs-xs);font-weight:700;letter-spacing:0.1em;color:var(--primary);text-transform:uppercase;margin-bottom:var(--s-2)}
.modal-name{font-size:var(--fs-2xl);font-weight:800;color:var(--gray-900);margin-bottom:var(--s-4);letter-spacing:-0.02em}
.modal-desc{font-size:var(--fs-sm);color:var(--text-2);line-height:1.9;margin-bottom:var(--s-6)}
.modal-3col{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-4);margin-bottom:var(--s-4)}
.modal-section-label{font-size:var(--fs-xs);font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:var(--s-2)}
.modal-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--s-2)}
.modal-list li{font-size:var(--fs-xs);color:var(--text-2);line-height:1.6;padding-left:var(--s-4);position:relative}
.modal-list li::before{content:'';position:absolute;left:0;top:6px;width:4px;height:4px;border-radius:50%}
.modal-strengths li::before{background:var(--success)}
.modal-risks li::before{background:var(--danger)}
.modal-suggestions li::before{background:var(--sky)}
.modal-jobs{display:flex;flex-wrap:wrap;gap:6px;margin-top:var(--s-4);padding-top:var(--s-4);border-top:1px solid var(--border)}
.modal-job-tag{font-size:var(--fs-xs);padding:4px 12px;background:var(--gray-100);color:var(--text-3);border-radius:var(--r-full)}
@media(max-width:1100px){.types-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:768px){.types-grid{grid-template-columns:repeat(2,1fr)}.modal-3col{grid-template-columns:1fr}}
@media(max-width:480px){.types-grid{grid-template-columns:1fr 1fr}}

/* ABOUT */
.about-shell{min-height:100vh;background:var(--gray-50)}
.about-nav{display:flex;align-items:center;gap:var(--s-4);padding:var(--s-4) var(--s-6);background:rgba(255,255,255,0.95);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;backdrop-filter:blur(12px)}
.about-nav-back{display:flex;align-items:center;gap:6px;font-size:var(--fs-sm);font-weight:500;color:var(--text-3);background:none;border:none;cursor:pointer;font-family:var(--font);transition:color var(--t-fast)}
.about-nav-back:hover{color:var(--primary)}
.about-nav-title{flex:1;text-align:center;font-size:var(--fs-sm);font-weight:700;color:var(--gray-900)}
.about-hero{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;padding:var(--s-12) var(--s-8);text-align:center}
.about-hero h1{font-size:var(--fs-3xl);font-weight:800;letter-spacing:-0.02em;margin-bottom:var(--s-3)}
.about-hero p{font-size:var(--fs-md);opacity:0.8;max-width:560px;margin:0 auto;line-height:1.7}
.about-body{padding:var(--s-10) var(--s-8);max-width:720px;margin:0 auto}
.about-section{margin-bottom:var(--s-10)}
.about-section-title{font-size:var(--fs-lg);font-weight:700;color:var(--gray-900);margin-bottom:var(--s-4);padding-bottom:var(--s-3);border-bottom:1px solid var(--border)}
.about-section p{font-size:var(--fs-base);color:var(--text-2);line-height:1.9;margin-bottom:var(--s-4)}
.about-section ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--s-2)}
.about-section ul li{font-size:var(--fs-sm);color:var(--text-2);padding-left:var(--s-5);position:relative;line-height:1.7}
.about-section ul li::before{content:'';position:absolute;left:0;top:9px;width:5px;height:5px;border-radius:50%;background:var(--primary)}
.about-dim-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s-4);margin-top:var(--s-4)}
.about-dim-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--s-5);box-shadow:var(--sh-sm)}
.about-dim-name{font-size:var(--fs-md);font-weight:700;color:var(--gray-900);margin-bottom:var(--s-2)}
.about-dim-abbr{font-size:var(--fs-xs);font-weight:700;color:var(--primary);letter-spacing:0.08em;text-transform:uppercase;margin-bottom:var(--s-3)}
.about-dim-poles{display:flex;gap:var(--s-3)}}
.about-pole{font-size:var(--fs-sm);color:var(--text-2)}
.about-pole strong{color:var(--text-1)}}
@media(max-width:768px){.about-dim-grid{grid-template-columns:1fr}}}

/* ══════════════════════════════════════════════
   V4 IP 形象样式
══════════════════════════════════════════════ */

/* ══════════════════════════════════════════════
   V4.2 改版：16型卡片(左右) + 弹窗(全页)
   🔴红=A+P  🟡金=A+F  🟣紫=D+P  🔵蓝=D+F
══════════════════════════════════════════════ */

/* ── 16型风格卡片（左右布局，自适应高度） ── */
.types-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}

.type-card {
  background: #fff;
  border-radius: 12px;
  border: 1px solid #E8E9EF;
  overflow: hidden;
  cursor: pointer;
  display: flex;
  flex-direction: row;
  box-shadow: 0 1px 3px rgba(0,0,0,0.05);
  transition: box-shadow 0.2s, transform 0.2s, border-color 0.2s;
  align-items: stretch;
}
.type-card:hover {
  box-shadow: 0 6px 20px rgba(0,0,0,0.1);
  transform: translateY(-2px);
}

/* 左侧色条 + 头像 */
.type-card-red    { border-left: 3px solid #E63946; }
.type-card-gold  { border-left: 3px solid #D4A017; }
.type-card-purple { border-left: 3px solid #7B2D8E; }
.type-card-blue   { border-left: 3px solid #2E86AB; }
.type-card-red:hover    { border-left-color: #C1121F; }
.type-card-gold:hover  { border-left-color: #B8860B; }
.type-card-purple:hover { border-left-color: #5B1A6B; }
.type-card-blue:hover   { border-left-color: #1B4F72; }

.tc-left {
  width: 72px;
  flex-shrink: 0;
  background: #F3F4F6;
  display: flex;
  align-items: stretch;
  overflow: hidden;
}
.tc-portrait {
  width: 72px;
  min-height: 80px;
  object-fit: cover;
  display: block;
  transition: transform 0.25s ease;
  flex: 1;
}
.type-card:hover .tc-portrait { transform: scale(1.04); }

/* 右侧信息 */
.tc-right {
  flex: 1;
  min-width: 0;
  padding: 10px 10px 10px 10px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 3px;
}

.tc-code {
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  line-height: 1;
  margin-bottom: 1px;
}
.type-card-red    .tc-code { color: #E63946; }
.type-card-gold  .tc-code { color: #D4A017; }
.type-card-purple .tc-code { color: #7B2D8E; }
.type-card-blue   .tc-code { color: #2E86AB; }

.tc-style {
  font-size: 14px;
  font-weight: 700;
  color: #111827;
  line-height: 1.25;
}

.tc-name {
  font-size: 10px;
  font-weight: 400;
  color: #9CA3AF;
  line-height: 1.4;
}

.tc-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 3px;
  margin-top: 4px;
}
.tc-tag {
  font-size: 9px;
  font-weight: 600;
  padding: 1px 6px;
  background: #F3F4F6;
  color: #6B7280;
  border-radius: 9999px;
  white-space: nowrap;
}

/* ── 弹窗 Modal — 全页无滚动 ── */
#modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.5);
  z-index: 200;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  backdrop-filter: blur(4px);
}
.modal-box {
  background: #fff;
  border-radius: 20px;
  max-width: 820px;
  width: 100%;
  max-height: 94vh;
  overflow-y: visible; overflow-x: hidden;
  box-shadow: 0 32px 64px rgba(0,0,0,0.2);
  animation: slideUp 0.22s ease;
  display: flex;
  flex-direction: column;
}
@keyframes slideUp {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}

.modal-close {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: #F3F4F6;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #6B7280;
  font-size: 16px;
  transition: background 0.15s;
  z-index: 10;
}
.modal-close:hover { background: #E5E7EB; color: #1F2937; }

.mdl-inner {
  display: flex;
  gap: 28px;
  padding: 28px 28px 24px;
  align-items: flex-start;
  overflow: visible;
}

.mdl-portrait {
  flex-shrink: 0;
  width: 160px;
}
.mdl-portrait-img {
  width: 160px;
  height: 200px;
  object-fit: cover;
  border-radius: 16px;
  box-shadow: 0 6px 20px rgba(0,0,0,0.14);
  display: block;
}

.mdl-content {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.mdl-top-row {
  display: flex;
  align-items: center;
  gap: 10px;
}
.mdl-badge {
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 4px 12px;
  border-radius: 9999px;
}
.mdl-badge-red    { background: rgba(230,57,70,0.1);   color: #E63946; }
.mdl-badge-gold  { background: rgba(212,160,23,0.12); color: #B8860B; }
.mdl-badge-purple { background: rgba(123,45,142,0.1);  color: #7B2D8E; }
.mdl-badge-blue   { background: rgba(46,134,171,0.1);  color: #2E86AB; }

.mdl-style-name {
  font-size: 18px;
  font-weight: 800;
  color: #111827;
  letter-spacing: -0.01em;
}

.mdl-name {
  font-size: 13px;
  font-weight: 500;
  color: #6B7280;
  line-height: 1.4;
  margin-top: -4px;
}
.mdl-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.mdl-tag {
  font-size: 12px;
  font-weight: 600;
  padding: 3px 10px;
  background: #F3F4F6;
  color: #4B5563;
  border-radius: 9999px;
}
.mdl-desc {
  font-size: 14px;
  color: #374151;
  line-height: 1.75;
  margin: 0;
}

/* 3列分析 */
.mdl-3col {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.mdl-sec-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 7px;
}
.mdl-green { color: #10B981; }
.mdl-red   { color: #EF4444; }
.mdl-blue  { color: #0EA5E9; }

.mdl-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.mdl-list li {
  font-size: 13px;
  color: #374151;
  line-height: 1.6;
  padding-left: 14px;
  position: relative;
}
.mdl-list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 8px;
  width: 5px;
  height: 5px;
  border-radius: 50%;
}
.mdl-3col > div:nth-child(1) .mdl-list li::before { background: #10B981; }
.mdl-3col > div:nth-child(2) .mdl-list li::before { background: #EF4444; }
.mdl-3col > div:nth-child(3) .mdl-list li::before { background: #0EA5E9; }

/* 典型岗位 */
.mdl-jobs { display: flex; flex-direction: column; gap: 8px; }
.mdl-jobs-label {
  font-size: 11px;
  font-weight: 700;
  color: #9CA3AF;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.mdl-job-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.mdl-job {
  font-size: 12px;
  padding: 4px 12px;
  background: #F9FAFB;
  color: #6B7280;
  border-radius: 9999px;
  border: 1px solid #E5E7EB;
}


/* ── 结果页风格名 ── */
.rp-style-name {
  font-size: 20px;
  font-weight: 800;
  color: #fff;
  letter-spacing: -0.02em;
  line-height: 1.1;
  margin-bottom: 4px;
}

/* ── 结果页 IP ── */
.rp-hero-red    { background: linear-gradient(135deg, #7f1d1d 0%, #991b1b 30%, #C1121F 60%, #E63946 100%); }
.rp-hero-gold   { background: linear-gradient(135deg, #7a5c00 0%, #92710a 30%, #D4A017 60%, #F4A261 100%); }
.rp-hero-purple { background: linear-gradient(135deg, #1e1b4b 0%, #312e81 30%, #5B1A6B 60%, #7B2D8E 100%); }
.rp-hero-blue   { background: linear-gradient(135deg, #0c3446 0%, #1B4F72 30%, #2E86AB 60%, #5DADE2 100%); }

.rp-ip-wrap { margin-bottom: var(--s-5); }
.rp-ip-img {
  width: 80px;
  height: 80px;
  object-fit: cover;
  border-radius: 14px;
  box-shadow: 0 6px 20px rgba(0,0,0,0.25);
  border: 2px solid rgba(255,255,255,0.2);
  display: block;
}

/* ── 响应式 ── */
@media (max-width: 1100px) { .types-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 768px) {
  .types-grid { grid-template-columns: repeat(2, 1fr); }
  .type-card { height: auto; flex-direction: column; }
  .tc-left { width: 100%; height: 72px; }
  .tc-portrait { width: 100%; height: 72px; }
  .mdl-inner { flex-direction: column; align-items: center; padding: 20px; }
  .mdl-portrait { width: 120px; }
  .mdl-portrait-img { width: 120px; height: 150px; }
  .mdl-3col { grid-template-columns: 1fr; }
  .modal-box { max-height: 94vh; overflow-y: visible; }
  .mdl-style-name { font-size: 16px; }
}
@media (max-width: 480px) { .types-grid { grid-template-columns: repeat(2, 1fr); } }