/* 소치랩 (Sochi Lab) — 글로벌 스타일 · 빌드 단계 없는 정적 CSS */
:root{
  --bg:#0a0a0a;--surface:#141414;--surface-2:#1c1c1c;--border:#262626;
  --text:#f5f5f5;--text-dim:#a3a3a3;--text-faint:#6b6b6b;
  --accent:#10b981;--accent-soft:rgba(16,185,129,.14);--good:#36d399;
  --radius:14px;--maxw:1080px;
  --font:"Pretendard",-apple-system,BlinkMacSystemFont,system-ui,"Apple SD Gothic Neo",sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.7;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.site-header{position:sticky;top:0;z-index:50;background:rgba(10,10,10,.82);backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--border)}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{display:flex;align-items:center;gap:9px;font-weight:800;font-size:18px;letter-spacing:-.02em}
.brand .dot{width:11px;height:11px;border-radius:50%;background:var(--accent);box-shadow:0 0 14px var(--accent)}
.nav{display:flex;gap:26px;font-size:15px;color:var(--text-dim)}
.nav a:hover{color:var(--text)}
.hero{padding:88px 0 64px;text-align:center}
.eyebrow{display:inline-block;font-size:13px;font-weight:600;letter-spacing:.04em;color:var(--accent);background:var(--accent-soft);padding:6px 14px;border-radius:999px;margin-bottom:22px}
.hero h1{font-size:clamp(32px,6vw,56px);line-height:1.18;letter-spacing:-.035em;font-weight:800;margin-bottom:20px}
.hero h1 .hl{color:var(--accent)}
.hero p.lead{font-size:clamp(16px,2.4vw,20px);color:var(--text-dim);max-width:600px;margin:0 auto 34px}
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:16px;padding:14px 26px;border-radius:999px;border:1px solid transparent;cursor:pointer;transition:transform .15s,opacity .15s}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--accent);color:#0a0a0a}
.btn-ghost{background:transparent;border-color:var(--border);color:var(--text)}
section.block{padding:64px 0}
.section-head{margin-bottom:36px}
.section-head h2{font-size:clamp(24px,4vw,34px);letter-spacing:-.03em;font-weight:800}
.section-head p{color:var(--text-dim);margin-top:8px;font-size:16px}
.grid{display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:26px;transition:border-color .2s,transform .2s;display:flex;flex-direction:column}
.card:hover{border-color:var(--accent);transform:translateY(-3px)}
.card .tag{font-size:12px;color:var(--accent);font-weight:700;letter-spacing:.03em;margin-bottom:12px}
.card h3{font-size:19px;letter-spacing:-.02em;margin-bottom:8px;line-height:1.4}
.card p{color:var(--text-dim);font-size:14.5px;flex:1}
.card .meta{margin-top:16px;font-size:13px;color:var(--text-faint)}
.values{display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
.value{padding:28px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}
.value .ico{font-size:26px;margin-bottom:14px}
.value h3{font-size:18px;margin-bottom:8px;letter-spacing:-.02em}
.value p{color:var(--text-dim);font-size:14.5px}
.capture{background:linear-gradient(135deg,var(--surface-2),var(--surface));border:1px solid var(--border);border-radius:20px;padding:48px 32px;text-align:center}
.capture h2{font-size:clamp(22px,3.6vw,30px);letter-spacing:-.03em;margin-bottom:10px}
.capture p{color:var(--text-dim);margin-bottom:26px}
.capture form{display:flex;gap:10px;max-width:440px;margin:0 auto;flex-wrap:wrap}
.capture input{flex:1;min-width:200px;padding:14px 18px;border-radius:999px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:15px;font-family:inherit}
.capture input:focus{outline:none;border-color:var(--accent)}
.capture small{display:block;margin-top:16px;color:var(--text-faint);font-size:12.5px}
.article{padding:56px 0 40px}
.article-head{max-width:760px;margin:0 auto 40px}
.article-head .tag{color:var(--accent);font-weight:700;font-size:13px}
.article-head h1{font-size:clamp(28px,5vw,44px);letter-spacing:-.035em;line-height:1.25;margin:14px 0 16px}
.article-head .sub{color:var(--text-dim);font-size:17px}
.article-head .byline{margin-top:18px;font-size:13.5px;color:var(--text-faint)}
.article-body{max-width:760px;margin:0 auto}
.article-body h2{font-size:26px;letter-spacing:-.03em;margin:44px 0 16px}
.article-body h3{font-size:20px;margin:28px 0 10px}
.article-body p{color:#d4d4d4;margin-bottom:16px}
.article-body ul{color:#d4d4d4;margin:0 0 16px 20px}
.article-body li{margin-bottom:6px}
.pick{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;margin:22px 0;display:grid;gap:16px;grid-template-columns:88px 1fr;align-items:start}
.pick .rank{width:88px;height:88px;border-radius:12px;background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:30px;font-weight:800}
.pick .badge{font-size:12px;font-weight:700;color:var(--good);margin-bottom:4px}
.pick h3{font-size:19px;margin-bottom:6px}
.pick p{font-size:14.5px;color:var(--text-dim);margin-bottom:14px}
.pick .cta{display:inline-flex;align-items:center;gap:6px;font-weight:700;font-size:14.5px;color:#0a0a0a;background:var(--accent);padding:9px 18px;border-radius:999px}
.disclosure{background:var(--surface-2);border:1px solid var(--border);border-radius:12px;padding:14px 18px;font-size:13px;color:var(--text-faint);margin:24px 0}
table.compare{width:100%;border-collapse:collapse;margin:20px 0;font-size:14px}
table.compare th,table.compare td{border:1px solid var(--border);padding:11px 13px;text-align:left}
table.compare th{background:var(--surface-2);color:var(--text);font-weight:700}
table.compare td{color:var(--text-dim)}
.site-footer{border-top:1px solid var(--border);padding:48px 0 60px;margin-top:40px;color:var(--text-faint)}
.site-footer .cols{display:flex;justify-content:space-between;flex-wrap:wrap;gap:24px;margin-bottom:28px}
.site-footer .fnav{display:flex;gap:22px;font-size:14px}
.site-footer .fnav a:hover{color:var(--text)}
.site-footer .legal{font-size:12.5px;line-height:1.7;max-width:640px}
@media(max-width:640px){.nav{gap:16px;font-size:14px}.hero{padding:60px 0 40px}.pick{grid-template-columns:1fr}.pick .rank{width:56px;height:56px;font-size:22px}}
/* ── 실시간 시세 위젯 ── */
.markets-wrap{padding:28px 0 8px}
.markets-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;flex-wrap:wrap;gap:8px}
.markets-head .mt{display:flex;align-items:center;gap:9px;font-weight:800;font-size:18px;letter-spacing:-.02em}
.live-dot{width:8px;height:8px;border-radius:50%;background:var(--good);box-shadow:0 0 0 0 rgba(54,211,153,.6);animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(54,211,153,.5)}70%{box-shadow:0 0 0 7px rgba(54,211,153,0)}100%{box-shadow:0 0 0 0 rgba(54,211,153,0)}}
.markets-meta{font-size:12.5px;color:var(--text-faint)}
.fxbar{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--text-dim);background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:5px 13px}
.fxbar b{color:var(--text);font-weight:700}
.ticker-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(170px,1fr))}
.tk{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px 18px;transition:border-color .2s, background .4s}
.tk .row1{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.tk .nm{font-weight:700;font-size:14.5px}
.tk .sb{font-size:11.5px;color:var(--text-faint);background:var(--surface-2);padding:2px 7px;border-radius:6px}
.tk .px{font-size:21px;font-weight:800;letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.tk .ch{font-size:13.5px;font-weight:700;margin-top:3px;font-variant-numeric:tabular-nums}
.tk .hl{font-size:11.5px;color:var(--text-faint);margin-top:8px;font-variant-numeric:tabular-nums}
.up{color:var(--good)}
.down{color:#ff5d5d}
.flash-up{background:rgba(54,211,153,.10)}
.flash-down{background:rgba(255,93,93,.10)}
.tk-skeleton{color:var(--text-faint);font-size:13px}
/* ── 차트 페이지 ── */
.chart-page{padding:34px 0 64px}
.chart-top{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:18px}
.chart-price .nmrow{display:flex;align-items:center;gap:10px}
.chart-price .nmrow h1{font-size:26px;letter-spacing:-.03em}
.chart-price .nmrow .sb{font-size:12px;color:var(--text-faint);background:var(--surface-2);padding:3px 8px;border-radius:7px}
.chart-price .pxbig{font-size:34px;font-weight:800;letter-spacing:-.02em;font-variant-numeric:tabular-nums;margin-top:6px}
.chart-price .chbig{font-size:16px;font-weight:700;font-variant-numeric:tabular-nums;margin-left:10px}
.seg{display:inline-flex;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:4px;gap:3px}
.seg button{border:0;background:transparent;color:var(--text-dim);font-family:inherit;font-weight:700;font-size:13.5px;padding:7px 13px;border-radius:7px;cursor:pointer;transition:.15s}
.seg button:hover{color:var(--text)}
.seg button.on{background:var(--accent);color:#06251a}
.chart-controls{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.chart-box{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:10px;overflow:hidden}
#chart{width:100%;height:440px}
.chart-loading{color:var(--text-faint);font-size:13px;text-align:center;padding:30px}

/* ── 히어로 풀배경 (미드저니) ── */
.hero-bg{position:relative;background:#0a0a0a url("https://cdn.midjourney.com/2252f079-700a-4eda-92ee-d5f12d0468b3/0_0.jpeg") center top/cover no-repeat;isolation:isolate}
.hero-bg::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,10,.45) 0%,rgba(10,10,10,.62) 55%,rgba(10,10,10,.92) 88%,#0a0a0a 100%);z-index:-1}
.hero-bg .hero{padding-top:104px;padding-bottom:96px}
.hero-bg .eyebrow{background:rgba(16,185,129,.18);backdrop-filter:blur(4px)}
.hero-bg .hero h1{text-shadow:0 2px 30px rgba(0,0,0,.6)}
/* ── 구독 폼 상태 ── */
.sub-status{margin-top:12px;font-size:13.5px;min-height:18px;font-weight:600}
.sub-status.ok{color:var(--good)}
.sub-status.err{color:#ff5d5d}
/* ── 캘린더 ── */
.cal-table{width:100%;border-collapse:collapse;margin-top:8px;font-size:14.5px}
.cal-table th,.cal-table td{border-bottom:1px solid var(--border);padding:14px 12px;text-align:left;vertical-align:top}
.cal-table th{color:var(--text-dim);font-weight:700;font-size:13px}
.cal-date{white-space:nowrap;font-weight:700;font-variant-numeric:tabular-nums}
.imp{display:inline-block;font-size:11.5px;font-weight:700;padding:3px 9px;border-radius:999px}
.imp.high{background:rgba(255,93,93,.15);color:#ff7a7a}
.imp.mid{background:rgba(255,176,32,.15);color:#ffb020}
.imp.low{background:rgba(163,163,163,.15);color:var(--text-dim)}
.cal-ev{font-weight:700}
.cal-desc{color:var(--text-dim);font-size:13.5px;margin-top:3px}
/* ── 뉴스 ── */
.news-list{display:flex;flex-direction:column;gap:2px;margin-top:8px}
.news-item{display:block;padding:16px 14px;border-bottom:1px solid var(--border);transition:background .15s}
.news-item:hover{background:var(--surface)}
.news-title{font-weight:600;font-size:15.5px;line-height:1.5}
.news-meta{margin-top:6px;font-size:12.5px;color:var(--text-faint)}
.news-loading{color:var(--text-faint);padding:24px 0;font-size:14px}
/* ── FX 스트립 ── */
.fx-strip{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 14px}
.fx-chip{display:inline-flex;align-items:center;gap:7px;font-size:13px;color:var(--text-dim);background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:6px 13px}
.fx-chip b{color:var(--text);font-weight:700;font-variant-numeric:tabular-nums}
/* ── 홈 뉴스 티저 ── */
.news-teaser{display:grid;gap:2px}
.news-teaser a{padding:13px 0;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;gap:14px;align-items:baseline}
.news-teaser a:hover .nt-title{color:var(--accent)}
.nt-title{font-weight:600;font-size:15px;line-height:1.5}
.nt-src{font-size:12px;color:var(--text-faint);white-space:nowrap}
