/* ===== MyPaceMaker — 공유 디자인 시스템 (데스크톱 우선 / 모바일 반응형) ===== */
:root{
  --lavender-50:#F3F0FB;--lavender-100:#E6E0F7;--lavender-300:#BCB0EC;
  --lavender-500:#8B7FD6;--lavender-600:#7468C4;--lavender-700:#5B50A0;
  --coral-pink:#FF8BA0;--coral-pink-dark:#E66B82;
  --bg:#FAF8FF;--surface:#fff;--ink:#2E2A3A;--muted:#6B6480;--line:#E8E3F2;
  --navy:#5B50A0;--indigo:#5B7CFA;--coral:#8B7FD6;--amber:#FFC24B;--mint:#15C49A;
  /* 시맨틱 초록(성공·무료·추천) 단일 스케일 — 페이지마다 다른 초록 쓰지 말 것 */
  --mint-600:#0FA37F;--mint-700:#0B8F6E;--mint-50:#E7F7F0;--mint-100:#BFE9D4;
  /* 시맨틱 골드(강조·후기 별점) 단일 스케일 */
  --gold-700:#9A7415;--gold-50:#FFF3D4;--gold-100:#FFE0A8;
  /* 다크 서피스(어두운 보라 패널) */
  --navy-deep:#2A2640;--navy-deep-2:#3A3556;
  --r:20px;--rs:14px;--shadow:0 12px 34px rgba(32,48,40,.10);--shadow-sm:0 5px 16px rgba(32,48,40,.06);
  --shadow-lg:0 30px 70px -30px rgba(91,80,160,.5);
  --side-w:248px;--bar-h:64px;
  --ease:cubic-bezier(.16,1,.3,1);
  --brand-500:#8B7FD6;--brand-700:#5B50A0; /* 보라 앵커 — 세그 무관 브랜드 실(thread) 고정 */
}
/* ===== 세그먼트 테마 — 한 곳에서 3색 정의 (구조·UI 동일, accent만 분기 / 유지비 1배) ===== */
/* 금융권: 딥 네이비 + 골드 (신뢰·보수) */
[data-seg="financial"]{
  --lavender-50:#EEF3FB;--lavender-100:#DCE6F5;--lavender-300:#A7BCE0;
  --lavender-500:#4C6FB5;--lavender-600:#3A5894;--lavender-700:#2C4373;
  --coral-pink:#C9A34E;--coral-pink-dark:#A9863A;
  --navy:#243B66;--indigo:#3A5894;--coral:#4C6FB5;
}
/* 마케터: 비비드 마젠타·코랄 (에너지·트렌디) */
[data-seg="marketing"]{
  --lavender-50:#FDEEF4;--lavender-100:#FBD9E6;--lavender-300:#F5A8C8;
  --lavender-500:#E8568E;--lavender-600:#D43F7C;--lavender-700:#B12D63;
  --coral-pink:#FF7A45;--coral-pink-dark:#E6622F;
  --navy:#7A2249;--indigo:#FF7A8A;--coral:#E8568E;
}
/* International: 틸·뉴트럴 (글로벌·차분) */
[data-seg="international"]{
  --lavender-50:#E9F6F4;--lavender-100:#CFEAE5;--lavender-300:#9BDDD5;
  --lavender-500:#2BB3A3;--lavender-600:#1E9A8C;--lavender-700:#157A70;
  --coral-pink:#F2A65A;--coral-pink-dark:#DB8E42;
  --navy:#134E4A;--indigo:#1E9A8C;--coral:#2BB3A3;
}
/* 세그 테마 이미지 색 시프트 — 보라 PNG/SVG(러너·트랙·Why 일러스트)를 accent색으로 (hue-rotate) */
.track-viz,.why-ill{transition:filter .3s var(--ease)}
[data-seg="financial"] .track-viz,[data-seg="financial"] .why-ill{filter:hue-rotate(-38deg) saturate(.82) brightness(.96)}
[data-seg="marketing"] .track-viz,[data-seg="marketing"] .why-ill{filter:hue-rotate(82deg) saturate(1.12)}
[data-seg="international"] .track-viz,[data-seg="international"] .why-ill{filter:hue-rotate(-84deg) saturate(1.06)}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
html,body{overflow-x:clip}
body{font-family:"Pretendard Variable",Pretendard,system-ui,"맑은 고딕",sans-serif;background:var(--bg);color:var(--ink);line-height:1.7;font-size:1.0625rem;-webkit-font-smoothing:antialiased;letter-spacing:-.003em;word-break:keep-all}
a{color:inherit;text-decoration:none}
img{max-width:100%}
.container{max-width:1180px;margin:0 auto;padding:0 32px}
.narrow{max-width:880px}
@media(max-width:720px){.container{padding:0 18px}}

/* 버튼 */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:800;border:none;border-radius:13px;padding:13px 24px;font-size:1rem;cursor:pointer;transition:.18s var(--ease);font-family:inherit;line-height:1.2;white-space:nowrap}
.btn-primary{background:linear-gradient(135deg,var(--coral),var(--indigo));color:#fff;box-shadow:0 10px 24px rgba(91,124,250,.3)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 32px rgba(91,124,250,.42)}
.btn-ghost{background:#fff;color:var(--navy);border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:var(--navy)}
.btn-kakao{background:#FEE500;color:#191600;box-shadow:0 8px 20px rgba(254,229,0,.4)}
.btn-kakao:hover{transform:translateY(-2px)}
.btn-lg{padding:16px 30px;font-size:1.08rem;border-radius:15px}
.btn-block{width:100%}
.btn:disabled{opacity:.55;cursor:not-allowed;transform:none}

.eyebrow{display:inline-block;font-weight:700;font-size:.82rem;letter-spacing:.04em;color:var(--coral);background:#EDE9F9;padding:.42em .95em;border-radius:999px;border:1px solid #D9D0F0}
.badge{font-size:.7rem;font-weight:800;padding:.22em .7em;border-radius:999px;white-space:nowrap}
.badge.live{color:#fff;background:var(--mint)}.badge.beta{color:#3a55b0;background:#e9eeff;border:1px solid #cdd8ff}
.badge.soon{color:#8a6d2a;background:#fff3d4;border:1px solid #ffe0a8}.badge.lock{color:#8a6d2a;background:#fff3d4;border:1px solid #ffe0a8}

/* 상단바 */
.appbar{position:sticky;top:0;z-index:50;height:var(--bar-h);backdrop-filter:saturate(160%) blur(12px);background:rgba(250,248,255,.85);border-bottom:1px solid var(--line)}
.appbar-in{height:100%;display:flex;align-items:center;gap:16px}
.hamb{display:inline-grid;place-items:center;width:42px;height:42px;border-radius:11px;border:1px solid var(--line);background:#fff;cursor:pointer;flex-shrink:0;transition:.15s}
.hamb:hover{border-color:var(--navy)}
.hamb span{display:block;width:18px;height:2px;background:var(--navy);border-radius:2px;position:relative}
.hamb span::before,.hamb span::after{content:"";position:absolute;left:0;width:18px;height:2px;background:var(--navy);border-radius:2px}
.hamb span::before{top:-6px}.hamb span::after{top:6px}
.brand-logo{height:42px;width:auto}
.appbar nav{margin-left:auto;display:flex;align-items:center;gap:6px}
.appbar nav a{padding:8px 13px;border-radius:9px;font-weight:700;font-size:.95rem;color:var(--muted);transition:.15s}
.appbar nav a:hover{color:var(--navy);background:var(--lavender-50)}
@media(max-width:720px){.appbar nav a.hide-m{display:none}}

/* 사이드바 (좌측 드로어) */
.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--side-w);background:#fff;border-right:1px solid var(--line);z-index:70;transform:translateX(-100%);transition:transform .3s var(--ease);display:flex;flex-direction:column;box-shadow:0 0 60px rgba(91,80,160,.12)}
.sidebar.open{transform:translateX(0)}
.sb-head{height:var(--bar-h);display:flex;align-items:center;gap:10px;padding:0 18px;border-bottom:1px solid var(--line)}
.sb-head img{height:38px}
.sb-close{margin-left:auto;width:34px;height:34px;border-radius:9px;border:1px solid var(--line);background:#fff;cursor:pointer;font-size:1rem;color:var(--muted)}
.sb-user{padding:16px 18px;border-bottom:1px solid var(--line)}
.sb-user b{color:var(--navy)}
.sb-plan{font-size:.8rem;font-weight:800;color:var(--mint);margin-top:2px}
.sb-nav{flex:1;overflow-y:auto;padding:12px 12px 24px}
.sb-sec{font-size:.72rem;font-weight:800;color:var(--muted);letter-spacing:.06em;padding:14px 12px 6px;text-transform:uppercase}
.sb-link{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:11px;font-weight:700;color:var(--ink);font-size:.97rem;cursor:pointer;transition:.13s;position:relative}
.sb-link:hover{background:var(--lavender-50);color:var(--navy)}
.sb-link.active{background:linear-gradient(135deg,rgba(139,127,214,.16),rgba(91,124,250,.13));color:var(--navy)}
.sb-link .ico{width:24px;text-align:center;font-size:1.05rem;flex-shrink:0}
.sb-link .lk{margin-left:auto;font-size:.85rem;opacity:.6}
.sb-foot{padding:14px 18px;border-top:1px solid var(--line);font-size:.82rem;color:var(--muted)}
.scrim{position:fixed;inset:0;background:rgba(40,36,58,.42);z-index:65;opacity:0;pointer-events:none;transition:.3s}
.scrim.show{opacity:1;pointer-events:auto}

/* 섹션·헤더 */
.section{padding:clamp(56px,7vw,108px) 0}
.sec-head{max-width:720px;margin-bottom:42px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head h2{font-size:clamp(1.7rem,1.2rem+2vw,2.6rem);font-weight:800;color:var(--navy);letter-spacing:-.025em;line-height:1.18;margin:14px 0 12px}
.sec-head p{color:var(--muted);font-size:1.1rem;line-height:1.6}
.hl{position:relative;white-space:nowrap}
.hl::after{content:"";position:absolute;left:-2%;right:-2%;bottom:.06em;height:.36em;background:var(--coral-pink);opacity:.42;z-index:-1;border-radius:4px}

/* 카드·패널 */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-sm)}
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-sm);padding:clamp(22px,3vw,34px)}

/* 폼 */
.field{margin-bottom:16px}
.field label{display:block;font-weight:700;color:var(--navy);font-size:.92rem;margin-bottom:7px}
.input,.select,.textarea{width:100%;font-family:inherit;font-size:1rem;color:var(--ink);background:#fff;border:1.5px solid var(--line);border-radius:12px;padding:12px 14px;transition:.15s}
.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--indigo);box-shadow:0 0 0 3px rgba(91,124,250,.14)}
.textarea{min-height:130px;resize:vertical;line-height:1.6}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:600px){.grid2{grid-template-columns:1fr}}

/* 블러 / 잠금 (바이럴 티저) */
.blur{filter:blur(7px);-webkit-filter:blur(7px);user-select:none;pointer-events:none}
.locked{position:relative;overflow:hidden}
.lock-veil{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;text-align:center;padding:20px;background:linear-gradient(180deg,rgba(255,255,255,.1),rgba(250,248,255,.86) 55%);backdrop-filter:blur(1px);z-index:3}
.lock-veil .lk-ico{font-size:1.8rem}
.lock-veil b{color:var(--navy);font-size:1.05rem}
.lock-veil span{color:var(--muted);font-size:.92rem;max-width:30ch}

/* 큰 점수 (공유용) */
.score-hero{text-align:center;padding:clamp(26px,4vw,44px);border-radius:24px;background:radial-gradient(120% 120% at 50% 0%,#fff,#F4EFFB);border:1px solid var(--line);box-shadow:var(--shadow)}
.score-hero .lbl{font-weight:800;color:var(--muted);font-size:.95rem}
.score-hero .big{font-size:clamp(4rem,2rem+9vw,7rem);font-weight:800;line-height:1;letter-spacing:-.04em;background:linear-gradient(135deg,var(--coral),var(--indigo));-webkit-background-clip:text;background-clip:text;color:transparent;margin:6px 0}
.score-hero .of{font-size:1.4rem;color:var(--muted);font-weight:700}
.score-hero .rank{margin-top:10px;display:inline-block;font-weight:800;color:var(--navy);background:#EDE9F9;border:1px solid #D9D0F0;border-radius:999px;padding:.4em 1.1em}

/* 토스트 / 모달 */
.toast{position:fixed;left:50%;bottom:32px;transform:translateX(-50%) translateY(20px);background:var(--navy);color:#fff;padding:13px 22px;border-radius:14px;font-weight:700;font-size:.95rem;box-shadow:0 12px 30px rgba(0,0,0,.25);opacity:0;pointer-events:none;transition:.3s;z-index:120;max-width:90vw;text-align:center}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.modal{position:fixed;inset:0;z-index:100;display:none;align-items:center;justify-content:center;padding:20px;background:rgba(40,36,58,.5);backdrop-filter:blur(3px)}
.modal.on{display:flex}
.modal-card{background:#fff;border-radius:22px;max-width:480px;width:100%;max-height:90vh;overflow-y:auto;padding:30px;position:relative;box-shadow:var(--shadow-lg)}
.modal-x{position:absolute;top:16px;right:16px;width:34px;height:34px;border-radius:10px;border:1px solid var(--line);background:#fff;cursor:pointer;color:var(--muted);font-size:1rem}
.modal-h{font-size:1.4rem;color:var(--navy);font-weight:800;margin-bottom:6px}
.modal-sub{color:var(--muted);font-size:.96rem;margin-bottom:18px}

/* 앱 페이지 본문 (사이드바 고정형은 JS로 토글) */
.page-head{padding:clamp(30px,4vw,52px) 0 0}
.page-head .eyebrow{margin-bottom:14px}
.page-head h1{font-size:clamp(1.8rem,1.2rem+2.4vw,2.7rem);font-weight:800;color:var(--navy);letter-spacing:-.025em;line-height:1.18}
.page-head .lead{color:var(--muted);font-size:1.12rem;margin-top:12px;max-width:60ch}

footer.foot{border-top:1px solid var(--line);background:#fff;padding:36px 0;color:var(--muted);font-size:.88rem}
.foot-in{display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:space-between}
.foot-in a{color:var(--muted)}.foot-in a:hover{color:var(--navy)}

.muted{color:var(--muted)}
.center{text-align:center}
.mt{margin-top:24px}.mt2{margin-top:40px}
/* 모바일: 하이라이트 줄바꿈 허용(오버플로우 방지) */
@media(max-width:560px){.hl{white-space:normal}}
/* 모바일 가로 오버플로우 차단 */
html{overflow-x:hidden}
/* 모바일 폭 방어 */
@media(max-width:560px){html,body{overflow-x:clip;max-width:100%}.unroll,.appbar-in,.container{overflow-x:clip;max-width:100%}.page-head h1{font-size:1.55rem;line-height:1.3;word-break:keep-all;overflow-wrap:anywhere}.page-head .lead{font-size:1rem;max-width:100%;word-break:keep-all}.hl{white-space:normal}}
