/* ============================================================
   alphakin/alphakin.css — 적응형 골격
   · 데스크톱: IBM Carbon UI Shell 구조 + Microsoft Fluent2 표면
   · 모바일: Google Material 3 (하단 내비·FAB·상태레이어·큰 타깃)
   · 색/타입/반경 감성: JNC Holdings Design System 토큰(alphakin-tokens.css 호환층) 사용
   토큰만으로는 "구성·밀도의 적정성"이 보장되지 않으므로(규칙 6) 구조는 각 DS를 따른다.
   ============================================================ */

/* ───────────────────────── 공통 규약 (CONVENTIONS) ─────────────────────────
   [타입 바닥] 모든 실제 텍스트의 최소 글자 크기 = 12px.
     · 근거: IBM Carbon 타입셋 최소 = 12px(Caption/Label/Helper/Legal-01),
       Microsoft Fluent2 Caption1 = 12px, Google Material 3 body-small = 12sp.
       → 세 시스템 공통 바닥 12px 를 단일 규약으로 채택.
     · 예외(글리프형 배지): 알림 카운트 .nbadge, 시장 코드 MarketBadge = 11px.
   [터치 바닥] 모바일(.m3) 상호작용 요소의 터치 타깃 ≥ 48dp.
     · 근거: Material/Android 최소 권장 48×48dp(≈9mm).
     · 적용: 하단탭/아이콘버튼/행 ≥48, 칩은 시각 36 유지 + ::before 로 히트영역 50.
   [구조 바닥] M3 small top app bar 64dp, navigation bar 80dp, FAB 56dp, nav 아이콘 24dp.
   ※ 인라인 스타일이 CSS 를 이기므로, 위반은 컴포넌트(JS) 단에서 12px 로 클램프한다.
   ───────────────────────────────────────────────────────────────────────── */
* { box-sizing: border-box; }
html, body { margin: 0; height: 100%; }
body {
  font-family: var(--font-sans);
  color: var(--text-primary);
  background: #1a130c;
  -webkit-font-smoothing: antialiased;
}
button { font-family: inherit; }
/* [오버플로 방지 규약 — 가로 스크롤 절대 금지]
   세로로 스크롤하는 모든 피드 컨테이너는 X축으로 절대 스크롤하지 않는다.
   · 근거: 모바일 세로 피드에서 의도치 않은 가로 스크롤은 UX 결함이며,
     원인은 거의 항상 grid/flex 자식의 min-width/min-height:auto 기본값
     (자식 min-content 가 1fr 트랙보다 커지면 트랙이 viewport 밖으로 팽창).
     [✓ 검증: CSS Grid/Flexbox 의 item 은 기본 min-width:auto → 콘텐츠보다 작아지지
      못해 트랙을 밀어냄. 해결 = minmax(0,1fr) + minWidth:0.
      css-tricks.com/preventing-a-grid-blowout · defensivecss.dev/tip/flexbox-min-content-size
      · developer.mozilla.org Flexbox/Wrapping_items]
   · ★ 근본 원인(이전까지 반복된 이유): backstop 이 .scroll-y 한 클래스에만 걸려
     있었으나, 정작 화면 콘텐츠 대부분이 렌더되는 '주 피드 컨테이너'(.m3-body·
     .cds-content)와 앱 셸(.m3·.cds·#root)에는 걸려 있지 않았다 → 안전망에 구멍.
     새 화면을 .m3-body 에 그릴 때마다 자식 하나만 넘쳐도 가로 스크롤이 그대로 샜다.
     → backstop 을 '스크롤하는 모든 컨테이너 + 셸'로 일반화해 구멍을 막는다.
   · 1차 방어(backstop): X 넘침을 '스크롤' 대신 'clip' 처리(clip 은 스크롤 컨테이너를
     만들지 않아 position:sticky 가 그대로 동작; overflow-y:auto 와 병행 가능).
   · 근본 해결(필수): 트랙은 'minmax(0,1fr)', 줄어들어야 하는 flex/grid 자식엔
     'minWidth:0'(또는 minHeight:0) 을 항상 부여한다. backstop 에 의존하지 말 것. */
.scroll-y { overflow-y: auto; overflow-x: clip; scrollbar-width: thin; }
/* 셸 — 마지막 방어선: 앱 루트가 절대 가로로 새지 않게(독립 화면 #root 는 overflow:hidden,
   임베드/실앱 컨텍스트에선 셸이 직접 막는다). */
.m3, .cds { overflow-x: clip; }
.scroll-y::-webkit-scrollbar { width: 8px; }
.scroll-y::-webkit-scrollbar-thumb { background: var(--line); border-radius: 8px; }

/* ───────────────────────── 스테이지 ───────────────────────── */
.ak-stage { position: fixed; inset: 0; display: flex; flex-direction: column;
  background: radial-gradient(120% 80% at 50% -10%, #2a221c, var(--stone-950) 70%); color: var(--paper); }
.ak-stage-head { display: flex; align-items: center; gap: 18px; padding: 14px var(--sp-6);
  border-bottom: 1px solid rgba(255,247,234,.1); flex-wrap: wrap; }
.ak-stage-title { display: flex; align-items: center; gap: var(--sp-3); }
.ak-stage-title strong { font: 800 16px/1.1 var(--font-sans); letter-spacing: -.02em; }
.ak-stage-title small { display: block; font: 400 12px/1.3 var(--font-sans); color: rgba(251,244,233,.55); margin-top: 3px; }
.ak-stage-controls { display: flex; align-items: center; gap: 18px; margin-left: auto; flex-wrap: wrap; }
.ak-stage-grp { display: flex; align-items: center; gap: var(--sp-2); }
.ak-stage-grp > span.lbl { font: 700 11px/1 var(--font-mono); letter-spacing: .12em; text-transform: uppercase; color: rgba(251,244,233,.5); }
.ak-stage-seg { display: inline-flex; background: rgba(255,247,234,.08); border: 1px solid rgba(255,247,234,.14); border-radius: 999px; padding: 3px; }
.ak-stage-seg button { border: 0; background: none; cursor: pointer; color: rgba(251,244,233,.66);
  font: 700 12px/1 var(--font-sans); padding: 7px 14px; border-radius: 999px; white-space: nowrap; }
.ak-stage-seg button.on { background: var(--ak-gold); color: #1b140d; }
.ak-stage-body { flex: 1; min-height: 0; position: relative; overflow: hidden; }
.ak-stage-frames { position: absolute; top: 50%; left: 50%; display: flex; align-items: flex-start; gap: var(--sp-14);
  transform-origin: center center; }
.ak-stage-cap { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; color: rgba(251,244,233,.85); }
.ak-stage-cap b { font: 800 13px/1 var(--font-sans); }
.ak-stage-cap .ds { font: 700 11px/1.4 var(--font-mono); letter-spacing: .08em; text-transform: uppercase;
  color: var(--ak-gold-soft); border: 1px solid rgba(243,169,78,.4); border-radius: 4px; padding: var(--sp-1) 7px; }
.ak-stage-cap .dim { font: 400 12px/1.3 var(--font-sans); color: rgba(251,244,233,.45); }

/* 윈도우/디바이스 섀시 */
.dwin { width: 1440px; border-radius: 12px; overflow: hidden; background: var(--paper);
  box-shadow: 0 40px 100px rgba(0,0,0,.5); border: 1px solid rgba(0,0,0,.3); }
.dwin-bar { height: 38px; display: flex; align-items: center; gap: var(--sp-2); padding: 0 14px;
  background: var(--stone-100); border-bottom: 1px solid var(--line); }
.dwin-bar .lights { display: flex; gap: 7px; }
.dwin-bar .lights span { width: 11px; height: 11px; border-radius: 999px; background: var(--stone-300); }
.dwin-bar .url { margin: 0 auto; display: inline-flex; align-items: center; gap: 7px;
  font: 600 12px/1 var(--font-mono); color: var(--ink-2); background: var(--paper);
  border: 1px solid var(--line); border-radius: 6px; padding: 5px 14px; }
.dscreen { width: 1440px; height: 900px; overflow: hidden; background: var(--bg-radial); }

.mdev { width: 384px; border-radius: 44px; padding: var(--sp-3); background: #0f0a05;
  box-shadow: 0 40px 90px rgba(0,0,0,.55); position: relative; }
.mdev .notch { position: absolute; top: 22px; left: 50%; transform: translateX(-50%);
  width: 118px; height: 30px; background: #0f0a05; border-radius: 999px; z-index: 30; }
.mscreen { width: 360px; height: 800px; border-radius: 34px; overflow: hidden; background: var(--bg-radial); position: relative; }

/* 통합 뷰가 임베드하는 독립 화면 iframe — 섀시 내부를 가득 채움 */
.ak-embed { width: 100%; height: 100%; border: 0; display: block; background: var(--bg-radial); }

/* ═══════════════ 데스크톱 · CARBON 셸 + FLUENT 표면 ═══════════════ */
.cds { height: 100%; display: grid; grid-template-columns: 256px minmax(0, 1fr); grid-template-rows: 48px 1fr;
  grid-template-areas: "brand header" "side content"; background: var(--bg-radial); color: var(--text-primary); }
/* Carbon 헤더 — 어두운 잉크 바 */
.cds-brand { grid-area: brand; background: var(--ak-ink); display: flex; align-items: center; gap: 10px;
  padding: 0 var(--sp-4); color: var(--paper); border-right: 1px solid rgba(255,255,255,.06); }
.cds-brand strong { font: 800 16px/1 var(--font-sans); letter-spacing: -.035em; }
.cds-brand .en { font: 300 11px/1 var(--font-display); letter-spacing: .24em; color: rgba(251,244,233,.6); }
.cds-header { grid-area: header; background: var(--ak-ink); display: flex; align-items: center; gap: 14px;
  padding: 0 var(--sp-4); color: var(--paper); }
.cds-search { flex: 1; max-width: 520px; display: flex; align-items: center; gap: 10px; height: 34px;
  background: rgba(255,247,234,.08); border: 1px solid transparent; border-radius: 8px; padding: 0 var(--sp-3);
  color: rgba(251,244,233,.6); cursor: text; font: 500 13.5px/1 var(--font-sans); transition: .15s; }
.cds-search:hover { background: rgba(255,247,234,.13); }
.cds-search .kbd { margin-left: auto; font: 700 11px/1 var(--font-mono); border: 1px solid rgba(255,247,234,.25);
  border-radius: 4px; padding: 3px 6px; color: rgba(251,244,233,.55); }
.cds-hbtn { width: 40px; height: 40px; display: grid; place-items: center; border: 0; background: none;
  color: rgba(251,244,233,.8); cursor: pointer; border-radius: 8px; position: relative; }
.cds-hbtn:hover { background: rgba(255,247,234,.1); }
.cds-acct { display: flex; align-items: center; gap: 9px; height: 40px; padding: 0 var(--sp-2) 0 6px; border: 0;
  background: none; color: var(--paper); cursor: pointer; border-radius: 8px; }
.cds-acct:hover { background: rgba(255,247,234,.1); }
.cds-acct .av { width: 30px; height: 30px; border-radius: 999px; background: linear-gradient(150deg, #FF7A1F, #EA5E00); color: #fff;
  display: grid; place-items: center; font: 800 12px/1 var(--font-sans); box-shadow: inset 0 1px 0 rgba(255,255,255,.28); }
.nbadge { position: absolute; top: 5px; right: 5px; min-width: 16px; height: 16px; padding: 0 var(--sp-1);
  background: var(--ak-gold); color: var(--paper); border-radius: 999px; font: 800 9.5px/16px var(--font-num);
  text-align: center; }
/* Carbon 사이드 내비 */
.cds-side { grid-area: side; background: var(--plate); border-right: 1px solid var(--line);
  display: flex; flex-direction: column; padding: var(--sp-3) 0; }
.cds-navlbl { padding: 10px 18px 6px; font: 700 12px/1 var(--font-mono); letter-spacing: .14em;
  text-transform: uppercase; color: var(--text-muted); }
.cds-nav { display: flex; align-items: center; gap: 13px; min-height: 48px; padding: 0 var(--sp-4) 0 var(--sp-3); border: 0;
  background: none; cursor: pointer; text-align: left; color: var(--text-secondary); position: relative;
  border-left: 4px solid transparent; transition: background .12s; }
.cds-nav:hover { background: var(--plate-2); }
.cds-nav:focus-visible { outline: 2px solid var(--brand); outline-offset: -2px; }
/* 선택 상태 = 색(브랜드 wash) + 형태(4px 좌측 막대) + 굵기(800) + 아이콘 채움 — 색 단독 의존 금지(WCAG 1.4.1), 고령/초심자 대비 강화 */
.cds-nav.on { background: color-mix(in srgb, var(--brand) 13%, transparent); border-left-color: var(--brand); color: var(--text-primary); }
.cds-nav.on .ico { color: var(--brand); }
.cds-nav.on .tx b { font-weight: 800; }
.cds-nav .ico { display: grid; place-items: center; color: inherit; }
.cds-nav .tx { display: flex; flex-direction: column; gap: 2px; }
.cds-nav .tx b { font: 700 14px/1.1 var(--font-sans); }
.cds-nav .tx small { font: 400 12px/1.2 var(--font-sans); color: var(--text-muted); }
.cds-foot { padding: 8px var(--sp-3) var(--sp-1); }
/* 데스크톱 주 콘텐츠 — overflow-x:clip 로 backstop 적용(위 규약). min-width:0 로 grid 트랙 팽창 차단. */
.cds-content { grid-area: content; min-width: 0; min-height: 0; overflow-y: auto; overflow-x: clip; }
/* 공통 레이아웃 계약 — 전 페이지 동일 상단/좌우/하단 (페이지는 자기 paddingTop 금지) */
.cds-pad { padding: var(--ak-pad-top) var(--ak-pad-x) var(--ak-pad-bottom); max-width: 1000px; }

/* ── 규약 1 · 도입 단락은 아래 콘텐츠와 같은 폭 ────────────────────────────────
   본문 도입/설명 단락(.cds-pad·.m3-body 직속 <p>)은 자체 폭 캡을 두지 않고 콘텐츠
   열(카드 그리드)과 좌우 끝을 공유한다 → 단락이 그리드보다 좁아 '엉뚱한 곳'에서 끊기는
   불일치 제거. 측정 폭은 열 자체(.cds-pad max-width:1000)에서 보장. 히어로/콜아웃 내부
   <p>는 직속이 아니므로 영향 없음(의도적 측정 폭 보존). */
.cds-pad > p, .m3-body > p { max-width: none; }

/* ── 규약 2 · 한국어 줄바꿈 ──────────────────────────────────────────────────
   어절(낱말) 중간에서 끊지 않음(word-break:keep-all) + 고아줄/들쭉 방지(text-wrap:pretty).
   제목은 줄 길이를 고르게(text-wrap:balance). 의미 단위가 어색하게 쪼개지지 않게 한다. */
.cds-pad p, .cds-pad li, .m3-body p, .m3-body li { word-break: keep-all; text-wrap: pretty; }
.cds-pad h1, .cds-pad h2, .cds-pad h3, .m3-body h1, .m3-body h2, .m3-body h3,
.sec-head .ttl, .m3-sec-ttl, .ak-page-title, .ak-sec-title { word-break: keep-all; text-wrap: balance; }
.ak-page-desc { word-break: keep-all; text-wrap: pretty; }


/* 지수 밴드 (공통) */
.idxband { display: flex; align-items: center; gap: 22px; padding: 9px var(--ak-pad-x);
  border-bottom: 1px solid var(--line); background: color-mix(in srgb, var(--ak-canvas) 50%, var(--surface)); flex-wrap: wrap; }
.idxband .ix { display: inline-flex; align-items: baseline; gap: 7px; }
.idxband .nm { font: 700 12px/1 var(--font-sans); color: var(--text-secondary); }
.idxband .vl { font: 700 12px/1 var(--font-num); font-variant-numeric: tabular-nums; color: var(--text-primary); }
.idxband .note { margin-left: auto; font: 400 12px/1 var(--font-sans); color: var(--text-muted); }

/* Fluent 카드 — 둥근 8px, 부드러운 깊이, hover reveal */
.flu { background: var(--ak-card); border: 1px solid var(--ak-card-border); border-radius: 8px;
  box-shadow: var(--ak-card-shadow); }
.flu-hover { transition: box-shadow .16s, transform .16s, border-color .16s; }
.flu-hover:hover { transform: translateY(-2px); border-color: var(--ak-card-border-hover);
  box-shadow: var(--ak-card-shadow-hover); }

/* 인페이지 '차례' 레일 항목(데스크톱 'On this page' · Carbon/Fluent) — 활성/배경은 인라인(동적),
   기본 레이아웃·hover·focus 는 여기. 종목 이동 외 전역 액션형 상태 택소노미(hover·focus-visible) 준수. */
.ak-toc-item { appearance: none; cursor: pointer; text-align: left; width: 100%; display: flex; align-items: center; gap: 11px;
  border: 0; padding: 9px 12px; border-radius: 0 6px 6px 0; color: var(--text-secondary);
  transition: background .14s, color .14s, border-color .14s; }
.ak-toc-item:hover { background: var(--surface-tinted); color: var(--text-primary); }
.ak-toc-item:focus-visible { outline: 2px solid var(--ak-sunset); outline-offset: -2px; }

/* ── 수급 한 줄 브리핑 — 섹터(어디로) 형광 하이라이트용 토큰. 방향색은 KRX(매수 red·매도 blue).
   장식 애니메이션 없이 '의미를 가리키는' 최소 단서만 사용(Mayer 코헤런스). ── */

/* ════════════════════════════════════════════════════════════════════════
   적응형 타이포그래피 위계 (ADAPTIVE TYPE HIERARCHY) — 단일 규약, 전 페이지 공통
   ────────────────────────────────────────────────────────────────────────
   문제(근본 원인): 페이지 타이틀·서브타이틀·설명·섹션 타이틀·섹션 서브타이틀이
     화면마다 인라인 스타일로 개별 지정돼(28/30/22/23/24px, h1~h3 혼용, 설명 13~16px,
     섹션 15~21px) 위계·통일성이 무너짐. → 5개 '의미 역할'을 토큰화하고, 같은 역할은
     같은 클래스로만 쓴다(단일 진실 공급원).
   적응형(필수): 같은 역할이 환경별로 자동 리사이즈 된다 —
     · 데스크톱(.cds): IBM Carbon + Microsoft Fluent 2 (엔터프라이즈/생산성 램프)
     · 모바일(.m3) : Google Material 3 (모바일 타입 스케일)
   근거(검증된 공식 스케일):
     ┌ 페이지 타이틀  데스크톱 28 = Carbon heading-04(28/lh36) ∩ Fluent Title2(28/600)
     │               모바일   24 = M3 Headline Small(24)         [carbondesignsystem.com·fluent2.microsoft.design·m3.material.io]
     ├ 섹션 타이틀    데스크톱 20 = Carbon heading-03(20) ∩ Fluent Subtitle1(20/600)
     │               모바일   18 = M3 Title 계열(16~22) 내 강조 단계(브랜드 커스텀)
     ├ 페이지 설명    데스크톱 16 = Carbon body-02(16) ∩ Fluent Body2(16)  /  모바일 14 = M3 Body Medium(14)
     └ 서브타이틀(오버라인) 12 = Carbon label-01(12) ∩ Fluent Caption1(12) ∩ M3 Body/Label(12)  ※ 세 시스템 공통 바닥
   위계 단서(직관성·심미성): 크기(28→20·24→18) + 굵기(타이틀 800 / 섹션 700) + 색
     (페이지 오버라인=브랜드 오렌지, 섹션 오버라인=muted) — 색 단독 의존 금지(WCAG 1.4.1).
   ──────────────────────────────────────────────────────────────────────── */
/* 1·페이지 서브타이틀 (오버라인/kicker) — 브랜드 오렌지, 페이지 타이틀 위 */
.ak-page-over { display: block; font: 700 12px/1 var(--font-mono); letter-spacing: .14em;
  text-transform: uppercase; color: var(--ak-sunset); }
/* 2·페이지 타이틀 — 화면당 1개(h1). 디스플레이 톤(800) */
.ak-page-title { margin: 0; font: 800 28px/1.18 var(--font-sans); letter-spacing: -.022em; color: var(--text-primary); }
/* 3·페이지 설명 — 본문 도입 단락 */
.ak-page-desc { margin: 0; font: 400 16px/1.6 var(--font-sans); color: var(--text-secondary); text-wrap: pretty; }
/* 4·섹션 서브타이틀 (오버라인) — muted (페이지 오버라인보다 낮은 위계) */
.ak-sec-over, .sec-head .ttl small { display: block; font: 700 12px/1 var(--font-mono); letter-spacing: .14em;
  text-transform: uppercase; color: var(--text-muted); }
/* 5·섹션 타이틀 — Bold(700), 페이지 타이틀보다 한 단계 작게 */
.ak-sec-title, .sec-head .ttl .tx { margin: 0; font: 700 20px/1.25 var(--font-sans); letter-spacing: -.014em; color: var(--text-primary); }

/* 헤더 컨테이너 간격 규약 */
.ak-phead { margin-bottom: 26px; }
.ak-phead .ak-page-over { margin-bottom: 11px; }
.ak-phead .ak-page-title + .ak-page-desc { margin-top: 11px; }

/* ── 모바일(Material 3) 적응 리사이즈 — 같은 역할, M3 스케일 ── */
.m3 .ak-page-title { font-size: 24px; line-height: 1.2; letter-spacing: -.02em; }
.m3 .ak-page-desc  { font-size: 14px; line-height: 1.55; }
.m3 .ak-sec-title, .m3 .sec-head .ttl .tx { font-size: 18px; }
.m3 .ak-page-over, .m3 .ak-sec-over { letter-spacing: .12em; }
.m3 .ak-phead { margin-bottom: 24px; }
.m3 .ak-phead .ak-page-over { margin-bottom: var(--sp-2); }
.m3 .ak-phead .ak-page-title + .ak-page-desc { margin-top: var(--sp-2); }

/* 섹션 헤더 레이아웃 — 오버라인(낮은 위계) + 타이틀, 우측 액션 */
.sec-head { display: flex; align-items: flex-end; justify-content: space-between; gap: var(--sp-4);
  margin-bottom: 22px; }
.sec-head .ttl { display: flex; flex-direction: column; gap: 7px; min-width: 0; }
/* [모바일 공통 규약] 섹션 전환 간격 — 단일 소스 토큰(alphakin-tokens.css --ak-msec-*).
   위 32(이전 섹션과 분리) ≫ 아래 12(제목-본문 결속). 전 모바일 화면 동일 적용.
   근거: M3 spacing(그룹 경계)·Gestalt 근접성(제목을 본문에 더 가깝게). */
.m3 .sec-head { margin: var(--ak-msec-top) 0 var(--ak-msec-bottom); }
.m3 .sec-head .ttl { gap: 6px; }
.sec-head .ak-shead-trail { flex: none; font: 400 12px/1.4 var(--font-mono); color: var(--text-muted); }
/* 타이틀 마커 하이라이트 — full-bleed 디바이더 대체. 글자 아래쪽에 살짝 걸쳐 ‘뒤에’ 깔리는 형광펜 느낌.
   폭은 타이틀 텍스트에 정확히 일치(줄바꿈 시 clone 으로 줄별 폭). em 기준이라 데스크톱·모바일 폰트 크기에 자동 비례(적응형). */
/* 타이틀 마커 하이라이트 — 형광펜. font-weight 는 .ak-sec-title(700)/.ak-page-title(800)이 정함(여기서 inherit 강제 금지). */
.sec-head .ttl .tx, .akmark {
  background-image: linear-gradient(to top,
    color-mix(in srgb, var(--ak-sunset) 46%, transparent) 0%,
    color-mix(in srgb, var(--ak-sunset) 34%, transparent) 33%,
    transparent 33%);
  -webkit-box-decoration-break: clone; box-decoration-break: clone; border-radius: 2px; }
/* [공통 규약] 마커 폭 = 타이틀 텍스트 폭. .tx 는 flex column 자식이라 기본 stretch 로 .ttl(=오버라인 등
   가장 넓은 자식) 폭까지 늘어나 하이라이트가 글자보다 길어졌다 → align-self:flex-start 로 자기 텍스트
   폭에만 맞춤(줄바꿈 시 box-decoration-break:clone 이 줄별 폭 처리). */
.sec-head .ttl .tx { align-self: flex-start; }
/* 수급 매수 픽 — 클릭 가능한 종목 행(전역 규칙: 종목상세로 이동) */
.smrow { appearance: none; border: 0; background: none; width: 100%; text-align: left;
  cursor: pointer; color: inherit; font: inherit; transition: background .14s; }
.smrow:hover { background: var(--surface-tinted); }
.smrow:active { background: color-mix(in srgb, var(--brand) 9%, var(--surface)); }
.smrow:focus-visible { outline: 2px solid var(--brand); outline-offset: -2px; }
/* 모바일 — 탭 행 터치 타깃 ≥48dp(초심자·고령자 사용성: Fitts·M3 최소 타깃). 데스크톱 밀도는 불변 */
.m3 .smrow { min-height: 52px; }

/* 큰 버튼 (Carbon/Fluent 액션) */
.act { display: inline-flex; align-items: center; gap: var(--sp-2); min-height: 44px; padding: 0 18px; border: 0;
  border-radius: 8px; cursor: pointer; font: 700 13.5px/1 var(--font-sans); transition: .15s; white-space: nowrap; }
.act-pri { background: var(--ak-gold); color: #fff; }
.act-pri svg { color: #fff; }
.act-pri:hover { background: var(--brand-stronger); color: #fff; box-shadow: 0 6px 16px rgba(232,95,0,.32); }
.act-gho { background: none; color: var(--ak-sunset); border: 1.5px solid var(--line); }
.act-gho:hover { border-color: var(--ak-sunset); background: var(--plate-2); }

/* ═══════════════ 모바일 · MATERIAL 3 ═══════════════ */
.m3 { height: 100%; display: flex; flex-direction: column; background: var(--bg-radial); color: var(--text-primary); }
.m3-status { height: 30px; display: flex; align-items: center; justify-content: space-between; padding: 0 22px;
  font: 700 12px/1 var(--font-num); color: var(--text-primary); flex: none; }
.m3-status .dots { letter-spacing: 2px; color: var(--text-secondary); }
/* M3 상단 앱바 */
/* M3 상단 앱바 — small top app bar 64dp(M3 규격) */
.m3-appbar { display: flex; align-items: center; gap: 6px; padding: 6px var(--sp-2) 6px 14px; flex: none; min-height: 64px; }
.m3-appbar h1 { flex: 1; margin: 0; font: 800 22px/1.1 var(--font-sans); letter-spacing: -.025em; }
.m3-appbar .lead { display: flex; align-items: center; gap: 9px; }
.m3-appbar .lead strong { font: 800 19px/1 var(--font-sans); letter-spacing: -.035em; }
/* M3 아이콘 버튼 — 48dp 타깃, 상태레이어 */
.m3-icon { width: 48px; height: 48px; border-radius: 999px; border: 0; background: none; cursor: pointer;
  display: grid; place-items: center; color: var(--text-primary); position: relative; -webkit-tap-highlight-color: transparent; }
.m3-icon::after { content: ""; position: absolute; inset: 6px; border-radius: 999px; background: var(--ak-sunset);
  opacity: 0; transition: opacity .15s; }
.m3-icon:active::after { opacity: .12; }
.m3-icon .nbadge { top: 8px; right: 8px; }
/* 주 피드 컨테이너 — overflow-x:clip 로 backstop 적용(위 규약). 세로만 스크롤, 가로는 clip. */
.m3-body { flex: 1; min-width: 0; min-height: 0; overflow-y: auto; overflow-x: clip; padding: var(--ak-pad-top-m) var(--ak-pad-x-m) var(--ak-pad-bottom-m); -webkit-overflow-scrolling: touch; }
/* M3 하단 내비 바 — 3~5개, 활성 pill 인디케이터 (Material 3) */
.m3-navbar { display: flex; flex: none; height: 84px; padding: 9px var(--sp-2) var(--sp-4);
  background: var(--surface); border-top: 1px solid var(--line);
  position: relative; z-index: 10;
  box-shadow: 0 -12px 28px -14px rgba(26,22,19,.22), 0 -1px 0 rgba(26,22,19,.04); }
/* 탭 = 단순 hit-box(전체폭 균등). 시각 강조는 안쪽 .cell 이 전담 */
.m3-tab { flex: 1; border: 0; background: none; cursor: pointer; display: flex;
  align-items: center; justify-content: center; padding: 2px 5px;
  -webkit-tap-highlight-color: transparent; }
/* .cell — 아이콘+라벨을 함께 감싸는 '공통영역'(Gestalt common region).
   활성 표식이 아이콘만이 아니라 라벨까지 한 덩어리로 감싸 '아이콘만 탭' 오해를 제거 */
.m3-tab .cell { width: 100%; display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 5px; padding: 7px 6px 6px; border-radius: 15px; color: var(--text-secondary);
  border: 1px solid transparent;
  transition: background .18s ease, color .18s ease, box-shadow .18s ease, border-color .18s ease, transform .14s ease; }
.m3-tab .cell .ico { display: grid; place-items: center; }
.m3-tab .lbl { font: 700 12px/1 var(--font-sans); letter-spacing: -.01em; }
/* 활성 — 아이콘·라벨을 함께 감싼 소프트 오렌지 틴트 컨테이너.
   색 의존 회피(접근성): ① 공통영역 컨테이너(형태) ② 브랜드색 ③ 라벨 800 굵기 — 3중 단서.
   수직 들섬(translateY) 제거 — 아이콘이 따로 녹는 '흔들림' 원인 제거 */
.m3-tab.on .cell { background: color-mix(in srgb, var(--brand) 13%, var(--surface));
  color: var(--ak-orange-text); border-color: color-mix(in srgb, var(--brand) 24%, transparent);
  box-shadow: 0 4px 13px -5px rgba(232,95,0,.34); }
.m3-tab.on .lbl { color: var(--ak-orange-text); font-weight: 800; }
/* 선택 모션 — 인디케이터가 '한 번' 또렷하게 자리잡는 단일 모션.
   ease-out(오버슈트 없음) = JNC '바운스 금지' 준수. 손가락 제스처 환경엔 비활성 */
@media (prefers-reduced-motion: no-preference) {
  .m3-tab.on .cell { animation: m3TabSettle .22s cubic-bezier(.22,.61,.36,1); }
  @keyframes m3TabSettle { from { transform: scale(.84); } to { transform: scale(1); } }
}
/* 누름 — 셀 전체(아이콘+라벨)가 하나로, 균일하게 반응(방향성 없음) */
.m3-tab:active .cell { transform: scale(.93); }
.m3-tab.on:active .cell { transform: scale(.97); }
/* 검색 — 브랜드 1차 FAB: 오렌지 채움 + 흰 α-돋보기 픽토그램 */
.m3-fab { position: absolute; right: 16px; bottom: 96px; width: 48px; height: 48px; padding: 0;
  border: none; border-radius: 999px; cursor: pointer;
  /* 안쪽은 채우지 않고 투명 — 오렌지 α-돋보기 + 얇은 오렌지 링만. 뒤 콘텐츠가 그대로 비침 */
  background: transparent; color: var(--brand);
  display: grid; place-items: center; z-index: 20;
  box-shadow: 0 5px 15px rgba(27,20,13,.14), 0 2px 6px rgba(27,20,13,.10), inset 0 0 0 1px color-mix(in srgb, var(--brand) 32%, transparent);
  transition: background .15s, box-shadow .15s, transform .12s; }
.m3-fab:hover { background: color-mix(in srgb, var(--brand) 10%, transparent); color: var(--brand-strong); box-shadow: 0 7px 19px rgba(27,20,13,.18), 0 3px 8px rgba(27,20,13,.12), inset 0 0 0 1px color-mix(in srgb, var(--brand) 48%, transparent); }
.m3-fab:active { transform: scale(.93); background: color-mix(in srgb, var(--brand) 16%, transparent); color: var(--brand-stronger); }
/* M3 카드 — 둥근 16~20 */
.m3-card { background: var(--ak-card); border: 1px solid var(--ak-card-border); border-radius: 20px;
  box-shadow: var(--ak-card-shadow); }
.m3-card.filled { background: var(--surface-tinted); border-color: transparent; }
/* M3 큰 탭 행 (질문형) — 56px+ 타깃 */
.m3-row { display: flex; align-items: center; gap: 14px; width: 100%; min-height: 76px; padding: var(--sp-4);
  border: 1px solid var(--ak-card-border); background: var(--ak-card); border-radius: 20px; cursor: pointer; text-align: left;
  -webkit-tap-highlight-color: transparent; box-shadow: var(--ak-card-shadow); transition: transform .12s; }
.m3-row:active { transform: scale(.985); }
/* M3 칩 */
.m3-chip { display: inline-flex; align-items: center; gap: 6px; min-height: 36px; padding: 0 14px; white-space: nowrap;
  border-radius: 999px; border: 1px solid var(--ak-card-border); background: var(--ak-card);
  font: 700 13px/1 var(--font-sans); color: var(--text-secondary); cursor: pointer; -webkit-tap-highlight-color: transparent; }
/* 선택 칩 = 브랜드 채움 + 흰 글자(색+명도 동시 변화) — 옅은 wash 대비 부족 보완(고령/초심자) */
.m3-chip.on { background: var(--brand-stronger); border-color: var(--brand-stronger); color: #fff; font-weight: 800; }
/* 모바일 칩 — 시각 높이(36)는 유지하되 터치 영역을 ≥48dp 로 확장(M3 최소 타깃) */
.m3 .m3-chip { position: relative; }
.m3 .m3-chip::before { content: ""; position: absolute; left: 0; right: 0; top: -7px; bottom: -7px; }

/* 엣지 페이드 가로 스크롤러 — 스크롤바 숨김(페이드가 어포던스 전담). 터치 모멘텀 유지 */
.edgefade-scroll { scrollbar-width: none; -ms-overflow-style: none; overscroll-behavior-x: contain; }
.edgefade-scroll::-webkit-scrollbar { display: none; }
.edgefade-scroll > * { scroll-snap-align: start; }

/* M3 입력 — 글자 ≥16px(iOS 자동확대 회피) */
.m3-field { display: flex; align-items: center; gap: 10px; min-height: 52px; padding: 0 var(--sp-4);
  background: var(--ak-card); border: 1px solid var(--ak-card-border); border-radius: 16px; }
.m3-field input { flex: 1; border: 0; outline: none; background: none; font: 500 16px/1 var(--font-sans);
  color: var(--text-primary); }

/* 메뉴 전환 모션 — 위치 이동 없는 '조용한 페이드'(top-level destination = quick fade)
   근거: 최상위 메뉴는 서로 관계가 약하므로 공간 이동이 아닌 짧은 페이드가 정석이며
   (Material 3 motion/transitions — "a quick fade ... intentionally does not create a connection"),
   자주 반복되는 전환은 위치 이동이 있으면 '움찔'거림·피로를 유발한다
   (NN/g: 반복 노출되는 애니메이션은 콘텐츠로 가는 길을 막는 장애물 — animation-usability).
   → translateY 제거(레이아웃 흔들림 0). 투명도만, 짧게, ease-out. reduced-motion 존중. */
.rise { opacity: 1; }   /* 휴지(rest) 상태 = 보임. 애니메이션이 틱하지 않아도 콘텐츠는 항상 보인다 */
@media (prefers-reduced-motion: no-preference) {
  .rise { animation: p2fade .14s ease-out; }   /* 'both' 미사용 — 정지 시 기본 opacity:1 유지(캡처/인쇄 안전) */
  @keyframes p2fade { from { opacity: 0; } }    /* to 생략 → 휴지 상태인 기본값(1)로 복귀 */
}
/* 인쇄/캡처 — 애니메이션이 틱하지 않는 맥락에서 from(투명) 프레임 고착 방지 */
@media print { .rise { animation: none; opacity: 1; } .m3-tab.on .cell { animation: none; transform: none; } }

/* ── 밸류체인 상세 바텀시트(M3 modal bottom sheet) ─────────────────────────────
   선택→상세가 '화면 밖'에서 갱신되면 변화맹(change blindness: 시선에서 먼 영역의
   변화는 못 알아챔 — NN/g)으로 사용자가 인지하지 못한다. 해법은 상세를 시선 지점으로
   끌어올리는 것. 아래서 슬라이드업(모션)+스크림(대비)+thumb zone 도착으로 '놓칠 수
   없는' 피드백을 만든다(NN/g 변화맹 방어 3종). reduced-motion에선 모션 생략(즉시 표시).
   ※ 진입 모션은 '쓰로틀 안전' 설계 — 휴지(rest)=올바른 위치(translateY 0). from 프레임이
     얼어붙어도(백그라운드 iframe) 시트는 12px만 낮을 뿐 항상 완전히 보인다(100% 이동 금지). */
@media (prefers-reduced-motion: no-preference) {
  .vc-scrim { animation: vcScrimIn .16s ease-out; }
  @keyframes vcScrimIn { from { opacity: 0; } }
  .vc-sheet { animation: vcSheetIn .22s cubic-bezier(.22,.61,.36,1); }
  @keyframes vcSheetIn { from { transform: translateY(12px); } }
}

/* 시트 안 '다음 단계로 이동'(forward) — Material forward(Y축) 전환: 짧은 페이드+상승.
   시트는 그대로 둔 채 본문만 새 단계로 교체되면 변화맹(시선에서 먼 헤더 갱신을 놓침)이 생긴다.
   본문을 key로 다시 마운트해 위로 살짝 떠오르며 페이드인 → '새 단계로 들어왔다'를 인지시키고,
   동시에 본문 스크롤을 맨 위로 되돌려 새 헤더(=변화 지점)를 시선에 둔다.
   (m3.material.io/styles/motion/transitions — forward=슬라이드+페이드 / NN/g change-blindness)
   휴지(rest)=제자리(throttle 안전). reduced-motion에선 모션 생략. */
.vc-forward { opacity: 1; }
@media (prefers-reduced-motion: no-preference) {
  .vc-forward { animation: vcForwardIn .26s cubic-bezier(.22,.61,.36,1); }
  @keyframes vcForwardIn { from { opacity: 0; transform: translateY(10px); } }
}
@media print { .vc-forward { animation: none; opacity: 1; transform: none; } }

/* 터치 환경에서만 큰 타깃 강제(데스크톱 무영향) */
@media (pointer: coarse) {
  .m3-tab .cell { min-height: 44px; }
}

/* ─────────────── Tweaks: 정보 밀도(컴팩트) ───────────────
   컨테이너 거터·여백만 줄여(인라인 카드 px 는 보존) 밀도를 높인다.
   data-density="컴팩트" 를 .ak-stage-frames 에 부여하면 양 프레임에 동시 반영. */
/* 셀렉터를 속성 단독으로 일반화 — 통합 뷰(.ak-stage-frames)·독립 화면(<html>) 양쪽에서 동작 */
[data-density="컴팩트"] .cds-pad { padding-left: 22px; padding-right: 22px; max-width: 940px; }
[data-density="컴팩트"] .idxband { padding-top: 6px; padding-bottom: 6px; gap: var(--sp-4); }
[data-density="컴팩트"] .sec-head { margin-bottom: var(--sp-4); }
[data-density="컴팩트"] .m3-body { padding-left: var(--sp-3); padding-right: var(--sp-3); }
[data-density="컴팩트"] .cds-side .cds-nav { min-height: 44px; }

/* 다크 모드에서 윈도우 크롬도 함께 어둡게(아이보리 바 이질감 제거) */
.ak-stage-frames[data-theme="dark"] .dwin-bar { background: #2a2420; border-bottom-color: #322b25; }
.ak-stage-frames[data-theme="dark"] .dwin-bar .lights span { background: #463e37; }
.ak-stage-frames[data-theme="dark"] .dwin-bar .url { background: #1a1613; border-color: #322b25; color: #b8ada3; }

/* ═══════════════ 글로벌 검색 · 알림 · LNB 프로필 (정리된 헤더/사이드) ═══════════════
   · 헤더 = 검색 + 알림만(계정은 LNB 하단으로 이동, 영역 정리)
   · 검색 = 자동완성 + 세션별 주도(종목·섹터·테마) 보드 (스코핑·그룹화·랭킹, Baymard/NN)
   · LNB 하단 = 실제 프로필 + 설정(테마·밀도) 팝오버 (Slack 패턴: 계정=사이드 하단)         */
.cds-header { position: relative; z-index: 30; }
.cds-search-wrap { position: relative; flex: 1; max-width: 520px; z-index: 101; }
.cds-searchbox { display: flex; align-items: center; gap: 10px; height: 34px; background: rgba(255,247,234,.08);
  border: 1px solid transparent; border-radius: 8px; padding: 0 var(--sp-3); transition: background .15s, border-color .15s; }
.cds-searchbox:hover { background: rgba(255,247,234,.12); }
.cds-searchbox:focus-within { background: rgba(255,247,234,.16); border-color: rgba(243,169,78,.55); }
.cds-searchbox input { flex: 1; min-width: 0; border: 0; outline: 0; background: none; color: var(--paper); font: 500 13.5px/1 var(--font-sans); }
.cds-searchbox input::placeholder { color: rgba(251,244,233,.5); }
.cds-searchbox .kbd { flex: none; font: 700 11px/1 var(--font-mono); border: 1px solid rgba(255,247,234,.25);
  border-radius: 4px; padding: 3px 6px; color: rgba(251,244,233,.55); }
.cds-bell-wrap { position: relative; z-index: 101; margin-left: auto; }

/* 공통 팝오버 표면 */
.ak-scrim { position: fixed; inset: 0; z-index: 100; background: transparent; }
.ak-pop, .ak-notif, .ak-acct { background: var(--ak-card); border: 1px solid var(--ak-card-border);
  border-radius: 12px; box-shadow: 0 18px 44px rgba(26,22,19,.22); z-index: 101; overflow: hidden; }
.ak-pop { position: absolute; top: calc(100% + 8px); left: 0; right: 0; }
.ak-notif { position: absolute; top: calc(100% + 8px); right: 0; width: 374px; padding: 0; display: flex; flex-direction: column; max-height: min(560px, 80vh); }
.ak-scroll { max-height: 392px; overflow-y: auto; padding: 2px 6px var(--sp-2); }
.ak-pop-head { display: flex; align-items: center; gap: 9px; padding: 13px 14px 10px; }
.ak-pop-head .ttl { font: 800 13.5px/1 var(--font-sans); color: var(--text-primary); white-space: nowrap; }
.ak-pop-head .ak-seg { margin-left: auto; }
.ak-sub-note { padding: 0 15px 9px; font: 400 12px/1.4 var(--font-sans); color: var(--text-muted);
  border-bottom: 1px solid var(--line-2); margin-bottom: 2px; }
.ak-grp { padding: 6px 0 2px; }
.ak-grp-lbl { display: flex; align-items: center; gap: 7px; padding: var(--sp-2) var(--sp-3) 6px;
  font: 700 11px/1 var(--font-mono); letter-spacing: .12em; text-transform: uppercase; color: var(--text-muted); }
.ak-grp-lbl .ct { font: 700 11px/1 var(--font-num); color: var(--text-muted); opacity: .65; }
.ak-row { display: flex; align-items: center; gap: 11px; width: 100%; padding: 9px 10px; border: 0; background: none;
  cursor: pointer; text-align: left; border-radius: 8px; transition: background .12s; }
.ak-row:hover { background: #FFF3EA; }
[data-theme="dark"] .ak-row:hover { background: var(--surface-tinted); }
.ak-rank { width: 22px; flex: none; text-align: center; font: 800 13px/1 var(--font-num); color: var(--ak-sunset); }
.ak-ico { width: 22px; flex: none; display: grid; place-items: center; }
.ak-tx { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 3px; }
.ak-tx .nm { display: flex; align-items: center; gap: 7px; font: 700 14px/1.2 var(--font-sans); color: var(--text-primary); }
.ak-tx .nm .cd { font: 500 11.5px/1 var(--font-mono); color: var(--text-muted); }
.ak-tx .sub { font: 400 12px/1.3 var(--font-sans); color: var(--text-muted); overflow: hidden;
  text-overflow: ellipsis; white-space: nowrap; max-width: 360px; }
.ak-when { font: 400 11.5px/1 var(--font-mono); color: var(--text-muted); flex: none; }
.ak-empty { padding: 34px 18px; text-align: center; font: 400 13px/1.5 var(--font-sans); color: var(--text-muted);
  display: flex; flex-direction: column; align-items: center; gap: 10px; }
/* 알림 패널 — Carbon NotificationPanel 해부 + Fluent2 안읽음(점+톤) · 상단 정렬 */
.ak-notif-head { display: flex; align-items: center; gap: 9px; padding: 14px var(--sp-4) var(--sp-3); border-bottom: 1px solid var(--line-2); }
.ak-notif-head strong { font: 800 15px/1 var(--font-sans); color: var(--text-primary); white-space: nowrap; }
.ak-nunread { font: 700 11.5px/1 var(--font-num); color: var(--ak-rose-deep); background: var(--surface-tinted); border-radius: 999px; padding: 5px 9px; white-space: nowrap; }
.ak-nunread.done { color: var(--text-muted); }
.ak-nmark { margin-left: auto; appearance: none; border: 0; background: none; cursor: pointer; font: 700 12.5px/1 var(--font-sans); color: var(--ak-sunset); padding: 7px var(--sp-2); border-radius: 6px; transition: background .12s; white-space: nowrap; }
.ak-nmark:hover:not(:disabled) { background: #FFF3EA; }
[data-theme="dark"] .ak-nmark:hover:not(:disabled) { background: var(--surface-tinted); }
.ak-nmark:disabled { color: var(--ink-3); cursor: default; }
.ak-nscroll { flex: 1; min-height: 0; overflow-y: auto; padding: 2px 0 var(--sp-1); }
.ak-nrow { display: flex; align-items: flex-start; gap: 9px; width: 100%; padding: var(--sp-3) 14px var(--sp-3) var(--sp-2); border: 0; border-bottom: 1px solid var(--line-2); background: none; cursor: pointer; text-align: left; transition: background .12s; }
.ak-nrow:hover { background: #FFF3EA; }
[data-theme="dark"] .ak-nrow:hover { background: var(--surface-tinted); }
.ak-nrow.unread { background: var(--surface-tinted); }
.ak-nrow.unread:hover { background: #FFE9D6; }
[data-theme="dark"] .ak-nrow.unread:hover { background: var(--surface-tinted); }
.ak-nrow .dotcol { width: 8px; flex: none; display: flex; justify-content: center; padding-top: 17px; }
.ak-nrow .udot { width: 8px; height: 8px; border-radius: 999px; background: var(--ak-gold); }
.ak-nico { width: 34px; height: 34px; flex: none; border-radius: 8px; display: grid; place-items: center;
  background: var(--surface); border: 1px solid var(--ak-card-border); }
.ak-ntx { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 5px; padding-top: 1px; }
.ak-ntx .ttl { font: 700 13.5px/1.35 var(--font-sans); letter-spacing: -.005em; color: var(--text-primary);
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.ak-nrow.unread .ak-ntx .ttl { font-weight: 800; }
.ak-ntx .meta { display: flex; align-items: center; gap: 7px; flex-wrap: nowrap; overflow: hidden; font: 400 11.5px/1.2 var(--font-sans); color: var(--text-muted); }
.ak-ntx .meta b { font-weight: 700; color: var(--text-secondary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; min-width: 0; }
.ak-ntx .meta .sep { width: 3px; height: 3px; flex: none; border-radius: 999px; background: var(--ink-3); }
.ak-ntx .meta span { flex: none; white-space: nowrap; }
.ak-ntx .meta em { flex: none; font: 700 11.5px/1 var(--font-num); font-style: normal; white-space: nowrap; }
.ak-nwhen { flex: none; align-self: flex-start; font: 400 11px/1 var(--font-mono); color: var(--text-muted); padding-top: 3px; white-space: nowrap; }
.ak-nfoot { display: flex; align-items: center; justify-content: center; gap: 6px; width: 100%; padding: 13px 0 13px; flex: none;
  border: 0; border-top: 1px solid var(--line-2); background: var(--surface); cursor: pointer; font: 700 12.5px/1 var(--font-sans); color: var(--ak-sunset); }
.ak-nfoot:hover { text-decoration: underline; }

/* 세그먼티드 (설정·세션 전환) */
.ak-seg { display: inline-flex; background: var(--bg-sunken); border: 1px solid var(--line); border-radius: 8px; padding: 3px; gap: 2px; }
.ak-seg button { border: 0; background: none; cursor: pointer; font: 700 12px/1 var(--font-sans);
  color: var(--text-secondary); padding: 6px 11px; border-radius: 6px; white-space: nowrap; transition: .12s; }
.ak-seg button:hover { color: var(--text-primary); }
.ak-seg button.on { background: var(--surface); color: var(--text-primary); box-shadow: 0 1px 2px rgba(26,22,19,.12); }
.ak-sess button { padding: 5px 9px; font-size: 11.5px; }
/* 현재 세션 배지 (스위처 대체 — 지금 세션을 '표시'만, 전환 버튼 없음) */
.ak-sess-now { margin-left: auto; display: inline-flex; align-items: center; gap: 6px; flex: none;
  font: 700 11.5px/1 var(--font-sans); color: var(--ak-rose-deep); background: var(--surface-tinted);
  border-radius: 999px; padding: 5px 11px; }
.ak-sess-now .dot { width: 6px; height: 6px; border-radius: 999px; background: var(--ak-sunset); }
/* 검색 결과 초과 안내 (Baymard: 8개 제한 + 질의 구체화 유도) */
.ak-more { padding: 9px var(--sp-3) var(--sp-1); font: 400 12px/1.4 var(--font-sans); color: var(--text-muted); display: flex; align-items: center; gap: 7px; }

/* LNB 프로필 (사이드 하단) — 프로필 설정 팝오버가 'Alphakin이란?' 위로 올라오게 about-wrap(102)보다 높게 */
.cds-foot { position: relative; z-index: 104; }
.cds-profile { display: flex; align-items: center; gap: 11px; width: 100%; padding: 9px; border: 0; background: none;
  cursor: pointer; text-align: left; border-radius: 10px; transition: background .12s; }
.cds-profile:hover, .cds-profile.on { background: var(--plate-2); }
.cds-profile .av { width: 36px; height: 36px; border-radius: 999px; flex: none; display: grid; place-items: center;
  background: linear-gradient(150deg, #FF7A1F, #EA5E00); color: #fff; font: 800 14px/1 var(--font-sans);
  box-shadow: 0 2px 7px -2px rgba(234,94,0,.55), inset 0 1px 0 rgba(255,255,255,.28); }
.cds-profile .meta { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.cds-profile .meta b { font: 700 13px/1.1 var(--font-sans); color: var(--text-primary); }
.cds-profile .meta small { font: 400 12px/1 var(--font-sans); color: var(--text-muted); }
.ak-acct { position: absolute; bottom: calc(100% + 8px); left: 6px; right: 6px; }
.ak-acct-id { display: flex; align-items: center; gap: 11px; padding: 15px 15px 13px; border-bottom: 1px solid var(--line-2); }
.ak-acct-id .av { width: 40px; height: 40px; border-radius: 999px; flex: none; display: grid; place-items: center;
  background: linear-gradient(150deg, #FF7A1F, #EA5E00); color: #fff; font: 800 16px/1 var(--font-sans);
  box-shadow: 0 2px 8px -2px rgba(234,94,0,.55), inset 0 1px 0 rgba(255,255,255,.28); }
.ak-acct-id .who { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 3px; }
.ak-acct-id .who b { font: 800 14px/1 var(--font-sans); color: var(--text-primary); }
.ak-acct-id .who small { font: 400 12px/1 var(--font-mono); color: var(--text-muted); }
.ak-plan { flex: none; font: 700 11px/1 var(--font-sans); color: var(--ak-rose-deep); background: var(--surface-tinted);
  border-radius: 999px; padding: 5px 10px; }
.ak-acct-menu { padding: 6px; border-bottom: 1px solid var(--line-2); }
.ak-mi { display: flex; align-items: center; gap: 11px; width: 100%; min-height: 40px; padding: 0 10px; border: 0;
  background: none; cursor: pointer; text-align: left; border-radius: 8px; font: 600 13px/1 var(--font-sans); color: var(--text-primary); }
.ak-mi:hover { background: var(--plate-2); }
.ak-acct-set { padding: var(--sp-3) 13px; display: flex; flex-direction: column; gap: 11px; border-bottom: 1px solid var(--line-2); }
.ak-acct-set .row { display: flex; align-items: center; gap: 10px; }
.ak-acct-set .row > span { font: 600 12.5px/1 var(--font-sans); color: var(--text-secondary); }
.ak-acct-set .row .ak-seg { margin-left: auto; }
.ak-logout { display: flex; align-items: center; gap: 9px; width: 100%; min-height: 42px; padding: 0 14px; border: 0;
  background: none; cursor: pointer; text-align: left; font: 600 13px/1 var(--font-sans); color: var(--text-secondary); }
.ak-logout:hover { background: var(--plate-2); color: var(--text-primary); }
[data-density="컴팩트"] .cds-profile .meta small { display: none; }

/* LNB 가족방 연장 CTA — 평소 숨김(미렌더), 만료 4주 전 트리거 시에만 노출.
   margin-top:auto 로 레일 바닥에 정렬(아래 about-wrap 의 auto 는 0 이 되어 바로 밑에 붙음).
   색: gold-amber(--warning) 주의(비방향, KRX 빨강과 분리) + 브랜드 오렌지 액션. */
.cds-renew { margin-top: auto; position: relative; z-index: 103; padding: 12px 10px 6px; border-top: 1px solid var(--line); }
.cds-renew-card { display: flex; flex-direction: column; gap: 10px; width: 100%; padding: 11px 11px 11px;
  border: 1px solid var(--warning); border-left: 4px solid var(--warning); background: var(--warning-container);
  border-radius: 11px; cursor: pointer; text-align: left; transition: box-shadow .15s, transform .12s; }
.cds-renew-card:hover { box-shadow: var(--ak-card-shadow); }
.cds-renew-card:active { transform: translateY(1px); }
.cds-renew-card:focus-visible { outline: 2px solid var(--brand); outline-offset: 2px; }
.cds-renew-card.on { box-shadow: 0 0 0 2px var(--brand); }
.cds-renew-row { display: flex; align-items: center; gap: 9px; min-width: 0; }
.cds-renew-ico { width: 28px; height: 28px; flex: none; border-radius: 8px; display: grid; place-items: center;
  background: color-mix(in srgb, var(--warning) 28%, transparent); }
.cds-renew-meta { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.cds-renew-meta b { font: 800 13px/1.1 var(--font-sans); color: var(--on-warning-container); white-space: nowrap; }
.cds-renew-meta small { font: 400 11px/1.2 var(--font-sans); color: var(--on-warning-container); opacity: .82;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cds-renew-act { display: inline-flex; align-items: center; justify-content: center; gap: 6px; min-height: 38px;
  border-radius: 8px; background: var(--ak-gold); color: #fff; font: 700 13px/1 var(--font-sans); }
.cds-renew-card:hover .cds-renew-act { background: var(--brand-stronger); }

/* 알림 행 — 멤버십(가족방 만료) 강조: gold-amber 좌측 룰 + 아이콘 타일 */
.ak-nrow-mem { border-left: 3px solid var(--warning); }
.ak-nrow-mem .ak-nico { background: var(--warning-container); border-color: color-mix(in srgb, var(--warning) 40%, transparent); }

/* LNB 하단 — Alphakin 브랜드 소개(저비중 어포던스) + 팝오버 */
.cds-about-wrap { position: relative; z-index: 102; padding: 6px 8px 4px; }
.cds-about { display: flex; align-items: center; gap: 9px; width: 100%; min-height: 34px; padding: 0 9px; border: 0;
  background: none; cursor: pointer; text-align: left; border-radius: 9px; transition: background .12s;
  font: 500 12px/1 var(--font-sans); color: var(--text-muted); }
.cds-about span { color: inherit; }
.cds-about:hover, .cds-about.on { background: var(--plate-2); color: var(--text-secondary); }
.cds-about:focus-visible { outline: 2px solid var(--brand); outline-offset: -2px; }
.ak-about-pop { position: absolute; bottom: calc(100% + 8px); left: 8px; width: 304px;
  background: var(--ak-card); border: 1px solid var(--ak-card-border); border-radius: 14px;
  box-shadow: 0 18px 46px rgba(26,22,19,.24); z-index: 103; overflow: hidden; padding: 16px; }
.ak-about-head { display: flex; align-items: center; gap: 12px; padding-bottom: 14px; border-bottom: 1px solid var(--line-2); }
.ak-about-lead { margin: 13px 0 0; font: 400 12.5px/1.6 var(--font-sans); color: var(--text-secondary); text-wrap: pretty; }
.ak-about-lead b { font-weight: 700; color: var(--text-primary); }
.ak-about-rows { display: flex; flex-direction: column; gap: 9px; margin-top: 14px; }
.ak-about-row { display: flex; align-items: center; gap: 11px; }
.ak-about-row .k { flex: none; width: 38px; height: 38px; border-radius: 10px; display: grid; place-items: center;
  background: var(--surface-tinted); color: var(--ak-sunset); font: 800 17px/1 var(--font-sans); letter-spacing: -.02em; }
.ak-about-row > div { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.ak-about-row b { font: 700 13px/1.1 var(--font-sans); color: var(--text-primary); }
.ak-about-row small { font: 400 11.5px/1.3 var(--font-sans); color: var(--text-muted); }
.ak-about-foot { margin-top: 14px; padding-top: 12px; border-top: 1px solid var(--line-2);
  font: 500 11px/1.4 var(--font-mono); letter-spacing: .01em; color: var(--text-muted); }
