/* ==================================================================
   INDEX V2 — 메인 페이지 스타일 (2026-05-17)
   - 앱 홈 탭 디자인과 정렬
   - 격리: body.index-v2 안에서만 작동 (다른 페이지 영향 0)
   - 베이스: 시스템 회색 + 흰 카드 + 얇은 테두리 + 진한 갈색 강조
   - 등급: 신호등 6단계 색
   ================================================================== */
body.index-v2{
  --v2-bg:#F2F4F7;
  --v2-bg-mute:#EAEDF2;
  --v2-surface:#FFFFFF;
  --v2-surface-2:#FAFAFB;
  --v2-surface-3:#F6F7F9;

  --v2-ink:#0E1116;
  --v2-ink-2:#5B6473;
  --v2-ink-3:#8E96A4;
  --v2-ink-4:#C3C9D2;

  --v2-hair:rgba(14,17,22,.06);
  --v2-hair-2:rgba(14,17,22,.12);
  --v2-shadow-1:0 1px 0 rgba(14,17,22,.04), 0 4px 16px rgba(14,17,22,.04);
  --v2-shadow-2:0 1px 0 rgba(14,17,22,.04), 0 8px 28px rgba(14,17,22,.08);
  --v2-shadow-3:0 12px 40px -10px rgba(14,17,22,.18), 0 4px 12px rgba(14,17,22,.06);

  --v2-accent:#009D62;       /* 미리 deep green (앱 챗봇 mascot 색과 동일) */
  --v2-accent-2:#007A4D;     /* darker */
  --v2-accent-soft:#E6F5EE;  /* light green */
  --v2-accent-bright:#4ADE80;/* bright (그라데이션·강조) */
  --v2-toss:#0064FF;         /* 보조 파란 (보조 CTA / 정보) */
  --v2-toss-soft:#E5F0FF;

  --v2-g-vgood:#34C759; --v2-g-vgood-soft:#E6F8EB;
  --v2-g-good:#5AC8FA;  --v2-g-good-soft:#E0F5FE;
  --v2-g-mid:#FFCC00;   --v2-g-mid-soft:#FFF6D6;
  --v2-g-bad:#FF9500;   --v2-g-bad-soft:#FFEFDA;
  --v2-g-vbad:#FF3B30;  --v2-g-vbad-soft:#FFE4E1;
  --v2-g-haz:#AF52DE;   --v2-g-haz-soft:#F5E6FB;

  --tnum:'tnum' on,'lnum' on;

  background:var(--v2-bg);
  color:var(--v2-ink);
  font-family:'Pretendard Variable',Pretendard,-apple-system,BlinkMacSystemFont,sans-serif;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
body.index-v2 a{color:inherit;text-decoration:none}
body.index-v2 *{box-sizing:border-box}
body.index-v2 .container{max-width:1200px;margin:0 auto;padding:0 24px}

/* === 글래스 NAV === */
.v2-nav{position:sticky;top:0;z-index:100;background:rgba(242,244,247,.78);backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid var(--v2-hair)}
.v2-nav-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:14px 24px;gap:20px}
.v2-brand{display:flex;align-items:center;gap:10px;flex-shrink:0}
.v2-brand-logo{width:34px;height:34px;border-radius:10px;overflow:hidden;display:block;background:var(--v2-accent-soft);border:1px solid var(--v2-hair)}
.v2-brand-logo img{width:100%;height:100%;display:block;object-fit:cover}
.v2-brand-text{display:flex;flex-direction:column;line-height:1.05}
.v2-brand-text b{font-size:15px;font-weight:800;letter-spacing:-.02em;color:var(--v2-ink)}
.v2-brand-text small{font-size:10.5px;color:var(--v2-ink-3);font-weight:600;letter-spacing:.01em}
.v2-nav-links{display:flex;gap:2px;flex:1;justify-content:center}
.v2-nav-links a{padding:8px 13px;border-radius:10px;font-size:13.5px;font-weight:600;color:var(--v2-ink-2);transition:.15s}
.v2-nav-links a:hover{background:var(--v2-surface);color:var(--v2-ink)}
.v2-nav-links a.active{color:var(--v2-ink);font-weight:700}
.v2-nav-right{display:flex;align-items:center;gap:10px;flex-shrink:0}
.v2-livechip{display:inline-flex;align-items:center;gap:8px;padding:6px 12px 6px 8px;background:var(--v2-surface);border:1px solid var(--v2-hair);border-radius:999px;font-size:12px;font-weight:700;color:var(--v2-ink);box-shadow:var(--v2-shadow-1);cursor:pointer;transition:.18s;min-height:32px;font-family:inherit}
.v2-livechip:hover{transform:translateY(-1px);box-shadow:var(--v2-shadow-2)}
.v2-livechip-dot{width:8px;height:8px;border-radius:50%;background:var(--v2-g-mid);box-shadow:0 0 0 3px rgba(255,204,0,.18);position:relative}
.v2-livechip-dot::after{content:'';position:absolute;inset:-3px;border-radius:50%;background:inherit;opacity:.45;animation:v2pulse 1.8s ease-in-out infinite}
@keyframes v2pulse{0%,100%{transform:scale(1);opacity:.45}50%{transform:scale(1.6);opacity:0}}
.v2-livechip-place{font-weight:700;letter-spacing:-.01em;max-width:88px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.v2-livechip-val{font-feature-settings:var(--tnum);color:var(--v2-ink-2)}
.v2-livechip-val b{color:var(--v2-ink);font-weight:800;margin-right:2px}
.v2-livechip[data-grade="vgood"] .v2-livechip-dot{background:var(--v2-g-vgood);box-shadow:0 0 0 3px rgba(52,199,89,.18)}
.v2-livechip[data-grade="good"] .v2-livechip-dot{background:var(--v2-g-good);box-shadow:0 0 0 3px rgba(90,200,250,.18)}
.v2-livechip[data-grade="mid"] .v2-livechip-dot{background:var(--v2-g-mid);box-shadow:0 0 0 3px rgba(255,204,0,.18)}
.v2-livechip[data-grade="bad"] .v2-livechip-dot{background:var(--v2-g-bad);box-shadow:0 0 0 3px rgba(255,149,0,.18)}
.v2-livechip[data-grade="vbad"] .v2-livechip-dot{background:var(--v2-g-vbad);box-shadow:0 0 0 3px rgba(255,59,48,.18)}
.v2-cta{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;background:var(--v2-accent);color:#fff;border-radius:10px;font-size:13.5px;font-weight:800;border:0;cursor:pointer;transition:.15s;box-shadow:0 1px 2px rgba(0,157,98,.18);font-family:inherit}
.v2-cta:hover{background:var(--v2-accent-2);transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,157,98,.26)}
.v2-cta-ghost{background:var(--v2-surface);color:var(--v2-ink);border:1px solid var(--v2-hair-2)}
.v2-cta-ghost:hover{background:var(--v2-surface-2)}
.v2-hamburger{display:none;width:40px;height:40px;border-radius:10px;background:var(--v2-surface);border:1px solid var(--v2-hair);align-items:center;justify-content:center;cursor:pointer;font-family:inherit}
.v2-hamburger svg{color:var(--v2-ink)}

/* === HERO === */
.v2-hero{padding:64px 0 80px;position:relative;overflow:hidden}
.v2-hero::before{content:'';position:absolute;top:-200px;left:50%;transform:translateX(-50%);width:900px;height:600px;background:radial-gradient(circle,rgba(14,17,22,.05) 0%,transparent 60%);pointer-events:none}
.v2-hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center;position:relative;z-index:1}
.v2-eyebrow{display:inline-flex;align-items:center;gap:8px;padding:7px 14px;background:var(--v2-surface);border:1px solid var(--v2-hair);border-radius:999px;font-size:12px;font-weight:700;color:var(--v2-ink-2);box-shadow:var(--v2-shadow-1)}
.v2-eyebrow .em{font-size:14px}
.v2-eyebrow.accent{background:var(--v2-accent-soft);color:var(--v2-accent);border-color:transparent}
h1.v2-h1{font-size:68px;line-height:1.04;letter-spacing:-.035em;margin:20px 0 22px;font-weight:900;color:var(--v2-ink)}
h1.v2-h1 em{font-style:normal;background:linear-gradient(135deg,var(--v2-accent) 0%,var(--v2-accent-bright) 100%);-webkit-background-clip:text;background-clip:text;color:transparent}
.v2-hero-sub{font-size:19px;color:var(--v2-ink-2);line-height:1.6;max-width:520px;font-weight:500}
.v2-hero-cta{display:flex;gap:10px;margin-top:32px;flex-wrap:wrap;align-items:center}
.v2-cta-lg{padding:14px 22px;font-size:15px;border-radius:12px}
.v2-hero-meta{display:flex;align-items:center;gap:18px;margin-top:24px;flex-wrap:wrap}
.v2-hero-meta-item{display:flex;align-items:center;gap:6px;font-size:12.5px;color:var(--v2-ink-3);font-weight:600}
.v2-hero-meta-item b{color:var(--v2-ink);font-weight:800;font-feature-settings:var(--tnum)}
.v2-hero-meta-dot{width:3px;height:3px;border-radius:50%;background:var(--v2-ink-4)}

/* === iPhone Frame (Hero · Scroll-scrub 공용) === */
.v2-phone{width:320px;height:660px;border-radius:42px;background:#0E0E10;padding:11px;box-shadow:0 30px 80px -20px rgba(14,17,22,.4),0 8px 24px rgba(14,17,22,.12);position:relative;margin:0 auto}
.v2-phone::before{content:'';position:absolute;top:14px;left:50%;transform:translateX(-50%);width:96px;height:26px;background:#0E0E10;border-radius:0 0 14px 14px;z-index:50}
.v2-phone-screen{width:100%;height:100%;border-radius:32px;overflow:hidden;background:var(--v2-bg);position:relative}
.v2-phone-screen::after{content:'';position:absolute;inset:0;background-image:repeating-linear-gradient(0deg,transparent 0 23px,rgba(14,17,22,.05) 23px 24px),repeating-linear-gradient(90deg,transparent 0 23px,rgba(14,17,22,.05) 23px 24px),radial-gradient(circle at 50% 0%,rgba(0,157,98,.08),transparent 60%);pointer-events:none;z-index:1}
.v2-phone-status{height:36px;padding:0 20px 0 24px;display:flex;align-items:center;justify-content:space-between;font-size:13px;font-weight:700;color:var(--v2-ink);position:relative;z-index:10}
.v2-phone-status .ic{font-size:11px;letter-spacing:1px}
.v2-phone-content{height:calc(100% - 36px);overflow:hidden;position:relative;z-index:2;padding:4px 0 0}

/* === Hero phone home replica === */
.v2-pn-head{display:flex;justify-content:space-between;align-items:flex-end;padding:6px 16px 12px}
.v2-pn-head-left .greet{font-size:10px;color:var(--v2-ink-3);font-weight:500;margin-bottom:2px}
.v2-pn-head-left .place{font-size:18px;font-weight:900;color:var(--v2-ink);letter-spacing:-.03em}
.v2-pn-head-left .place .arr{font-size:11px;color:var(--v2-ink-3);font-weight:600;margin-left:3px}
.v2-pn-head-actions{display:flex;gap:5px}
.v2-pn-iconbtn{width:32px;height:32px;border-radius:50%;background:var(--v2-surface);border:1px solid var(--v2-hair);display:flex;align-items:center;justify-content:center;font-size:14px;box-shadow:var(--v2-shadow-1)}
.v2-pn-hero{margin:0 12px 10px;background:var(--v2-surface);border:1px solid var(--v2-hair);border-radius:20px;box-shadow:var(--v2-shadow-2);overflow:hidden}
.v2-pn-hero-top{display:grid;grid-template-columns:1fr 104px;gap:0;padding:14px 14px 8px}
.v2-pn-hero-left{display:flex;flex-direction:column;gap:4px}
.v2-pn-hero-cap{font-size:9.5px;color:var(--v2-ink-3);font-weight:600;letter-spacing:.2px}
.v2-pn-hero-num{font-size:64px;font-weight:900;line-height:1;color:var(--v2-ink);font-feature-settings:var(--tnum);letter-spacing:-2.5px}
.v2-pn-hero-unit{font-size:11px;color:var(--v2-ink-2);font-weight:600;margin-top:-1px}
.v2-pn-hero-chip{display:inline-flex;align-items:center;gap:4px;background:var(--v2-g-bad-soft);color:var(--v2-g-bad);padding:4px 9px;border-radius:999px;font-size:10.5px;font-weight:800;margin-top:8px;width:fit-content}
.v2-pn-hero-chip-dot{width:5px;height:5px;border-radius:50%;background:var(--v2-g-bad)}
.v2-pn-hero-weather{background:linear-gradient(160deg,#93D8F7 0%,#B4E0F6 55%,#DCEFFA 100%);border-radius:14px;padding:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;height:104px;position:relative;overflow:hidden}
.v2-pn-hero-weather::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at 30% 25%,rgba(255,255,255,.45),transparent 60%);pointer-events:none}
.v2-pn-hero-weather .em{font-size:24px;line-height:1;position:relative;z-index:1}
.v2-pn-hero-weather .temp{font-size:22px;font-weight:900;color:#1A4A6E;margin-top:3px;letter-spacing:-.8px;position:relative;z-index:1;font-feature-settings:var(--tnum)}
.v2-pn-hero-weather .mm{font-size:10px;color:#2D6285;font-weight:600;position:relative;z-index:1;font-feature-settings:var(--tnum)}
.v2-pn-narr{margin:0 14px 10px;padding:8px 12px;background:var(--v2-accent-soft);border-radius:11px;font-size:11px;color:var(--v2-accent-2);font-weight:600;line-height:1.4}
.v2-pn-pillbar{display:flex;align-items:center;gap:10px;margin:0 12px 12px;padding:10px 12px;background:var(--v2-surface-3);border-radius:13px;border:1px solid var(--v2-hair)}
.v2-pn-pillbar-illust{width:36px;height:36px;flex-shrink:0;border-radius:10px;background:linear-gradient(135deg,#FFE2C2 0%,#FFD0A0 100%);display:flex;align-items:center;justify-content:center;font-size:18px}
.v2-pn-pillbar-info{flex:1;display:flex;flex-direction:column;gap:1px}
.v2-pn-pillbar-info .cap{font-size:9.5px;color:var(--v2-ink-3);font-weight:600}
.v2-pn-pillbar-info .tm{font-size:17px;font-weight:900;color:var(--v2-ink);font-feature-settings:var(--tnum);letter-spacing:-.4px}
.v2-pn-pillbar-cd{background:var(--v2-accent);color:#fff;padding:4px 10px;border-radius:999px;font-size:10.5px;font-weight:800;font-feature-settings:var(--tnum)}
.v2-pn-trend{margin:0 12px 10px;background:var(--v2-surface);border:1px solid var(--v2-hair);border-radius:18px;box-shadow:var(--v2-shadow-1);padding:12px}
.v2-pn-trend-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}
.v2-pn-trend-title{font-size:10px;color:var(--v2-ink-3);font-weight:700}
.v2-pn-trend-now{font-size:22px;font-weight:900;color:var(--v2-ink);line-height:1;font-feature-settings:var(--tnum);letter-spacing:-.8px}
.v2-pn-trend-now small{font-size:11px;font-weight:600;color:var(--v2-ink-2);margin-left:2px}
.v2-pn-trend-bars{display:flex;align-items:flex-end;gap:2px;height:54px;border-bottom:1px dashed var(--v2-ink-4);padding-bottom:2px}
.v2-pn-trend-bars i{flex:1;border-radius:2px 2px 0 0;min-width:5px}
.v2-pn-trend-labels{display:flex;justify-content:space-between;font-size:9px;color:var(--v2-ink-3);font-weight:600;margin-top:4px}
.v2-pn-tabbar{position:absolute;bottom:0;left:0;right:0;height:54px;background:rgba(255,255,255,.94);backdrop-filter:blur(12px);border-top:1px solid var(--v2-hair);display:flex;align-items:center;justify-content:space-around;padding:0 8px;z-index:20}
.v2-pn-tabbar .tab{display:flex;flex-direction:column;align-items:center;gap:2px;font-size:9px;font-weight:700;color:var(--v2-ink-3);flex:1}
.v2-pn-tabbar .tab .ic{font-size:18px}
.v2-pn-tabbar .tab.on{color:var(--v2-accent)}

/* Hero floating chips */
.v2-hero-phone-wrap{position:relative;display:flex;justify-content:center;align-items:center;min-height:680px}
.v2-hero-bgblob{position:absolute;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(90,200,250,.22) 0%,transparent 65%);top:50%;left:50%;transform:translate(-50%,-50%);z-index:0;filter:blur(8px)}
.v2-hero-floatchip{position:absolute;background:var(--v2-surface);border:1px solid var(--v2-hair);border-radius:14px;padding:10px 14px;font-size:12px;font-weight:700;box-shadow:var(--v2-shadow-2);display:flex;align-items:center;gap:8px;z-index:5}
.v2-hero-floatchip.f1{top:8%;left:-8px;animation:v2float 4.5s ease-in-out infinite}
.v2-hero-floatchip.f2{top:36%;right:-18px;animation:v2float 5.2s ease-in-out -1.5s infinite}
.v2-hero-floatchip.f3{bottom:14%;left:6px;animation:v2float 4.8s ease-in-out -3s infinite}
.v2-hero-floatchip .em{font-size:18px}
.v2-hero-floatchip .lbl{display:flex;flex-direction:column;line-height:1.2}
.v2-hero-floatchip .lbl small{font-size:10px;color:var(--v2-ink-3);font-weight:600}
@keyframes v2float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

/* === LIVE AIR STRIP === */
.v2-strip-section{padding:60px 0 40px;background:var(--v2-surface);border-top:1px solid var(--v2-hair);border-bottom:1px solid var(--v2-hair)}
.v2-strip-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:24px;flex-wrap:wrap;gap:12px}
.v2-strip-title{font-size:13px;font-weight:800;color:var(--v2-ink-3);letter-spacing:.04em;text-transform:uppercase}
.v2-strip-title b{color:var(--v2-accent);margin-right:4px}
.v2-strip-meta{font-size:11.5px;color:var(--v2-ink-3);font-weight:600}
.v2-strip-meta b{color:var(--v2-ink);font-weight:700;margin-right:2px}
.v2-strip{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}
.v2-strip-card{background:var(--v2-bg);border-radius:18px;padding:16px;border:1px solid var(--v2-hair);transition:.18s;cursor:pointer;position:relative}
.v2-strip-card:hover{transform:translateY(-3px);background:var(--v2-surface);box-shadow:var(--v2-shadow-2)}
.v2-strip-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}
.v2-strip-name{font-size:13px;font-weight:800;color:var(--v2-ink);letter-spacing:-.01em}
.v2-strip-grade{font-size:10.5px;font-weight:800;padding:2px 8px;border-radius:999px;font-feature-settings:var(--tnum)}
.v2-strip-num{font-size:26px;font-weight:900;color:var(--v2-ink);line-height:1;font-feature-settings:var(--tnum);letter-spacing:-1px;margin-bottom:8px}
.v2-strip-num small{font-size:11px;color:var(--v2-ink-2);font-weight:600;margin-left:2px}
.v2-strip-bars{display:flex;align-items:flex-end;gap:1.5px;height:34px}
.v2-strip-bars i{flex:1;border-radius:1.5px 1.5px 0 0;min-width:3px;background:var(--v2-ink-4)}

/* === SCROLL-SCRUB === */
.v2-scrub-section{padding:80px 0;position:relative}
.v2-scrub-head{text-align:center;max-width:680px;margin:0 auto 56px}
h2.v2-h2{font-size:48px;line-height:1.08;letter-spacing:-.03em;font-weight:900;color:var(--v2-ink);margin:12px 0 14px}
h2.v2-h2 em{font-style:normal;color:var(--v2-accent)}
.v2-sub{font-size:17px;color:var(--v2-ink-2);line-height:1.65;font-weight:500}
.v2-scrub-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start;position:relative}
.v2-scrub-sticky{position:sticky;top:100px;display:flex;justify-content:center;align-self:start;min-height:720px}
.v2-scrub-phone{position:relative}
.v2-scrub-stages{display:flex;flex-direction:column;gap:0}
.v2-scrub-stage{min-height:520px;display:flex;flex-direction:column;justify-content:center;padding:80px 0;transition:opacity .4s,transform .4s;opacity:.32;transform:translateY(12px)}
.v2-scrub-stage.on{opacity:1;transform:translateY(0)}
.v2-scrub-stage .step{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;background:var(--v2-accent-soft);color:var(--v2-accent);border-radius:999px;font-size:11.5px;font-weight:800;letter-spacing:.04em;width:fit-content}
.v2-scrub-stage h3{font-size:36px;line-height:1.15;letter-spacing:-.025em;font-weight:900;color:var(--v2-ink);margin:18px 0 14px}
.v2-scrub-stage h3 em{font-style:normal;color:var(--v2-accent)}
.v2-scrub-stage p{font-size:16px;color:var(--v2-ink-2);line-height:1.65;font-weight:500;max-width:480px}
.v2-scrub-stage ul{list-style:none;padding:0;margin:18px 0 0;display:flex;flex-direction:column;gap:10px}
.v2-scrub-stage ul li{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;background:var(--v2-surface);border:1px solid var(--v2-hair);border-radius:12px;font-size:13.5px;color:var(--v2-ink);font-weight:600;box-shadow:var(--v2-shadow-1)}
.v2-scrub-stage ul li .ck{width:18px;height:18px;flex-shrink:0;border-radius:50%;background:var(--v2-accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:900;margin-top:1px}
.v2-scrub-stage ul li b{color:var(--v2-accent);font-weight:800;margin-right:4px}

/* Phone screen variants — Scrub stages */
.v2-pn-screen-set{position:absolute;inset:0;border-radius:32px;overflow:hidden}
.v2-pn-screen-set .v2-pn-screen{position:absolute;inset:0;opacity:0;transition:opacity .5s ease;pointer-events:none;display:flex;flex-direction:column}
.v2-pn-screen-set .v2-pn-screen.on{opacity:1;pointer-events:auto}

/* Weather mini */
.v2-pn-weather{padding:6px 14px 0}
.v2-pn-weather .head{font-size:11px;font-weight:800;color:var(--v2-ink-3);letter-spacing:.04em;text-transform:uppercase;margin:2px 0 6px}
.v2-pn-weather .whero{background:linear-gradient(165deg,#93D8F7,#DCEFFA);border-radius:18px;padding:16px;display:flex;flex-direction:column;align-items:center;gap:4px;color:#1A4A6E;position:relative;overflow:hidden}
.v2-pn-weather .whero::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at 30% 25%,rgba(255,255,255,.5),transparent 60%)}
.v2-pn-weather .whero .em{font-size:42px;position:relative;z-index:1}
.v2-pn-weather .whero .tm{font-size:42px;font-weight:900;letter-spacing:-1.5px;line-height:1;font-feature-settings:var(--tnum);position:relative;z-index:1}
.v2-pn-weather .whero .mm{font-size:11px;font-weight:600;position:relative;z-index:1}
.v2-pn-weather .days{display:flex;flex-direction:column;gap:5px;margin-top:8px}
.v2-pn-weather .day{display:flex;align-items:center;gap:8px;background:var(--v2-surface);border:1px solid var(--v2-hair);border-radius:11px;padding:6px 10px;font-size:11px;font-weight:600;color:var(--v2-ink)}
.v2-pn-weather .day .dw{width:36px;font-weight:800;color:var(--v2-ink)}
.v2-pn-weather .day .em{font-size:14px;width:18px}
.v2-pn-weather .day .lo{color:var(--v2-ink-3);font-weight:700;font-feature-settings:var(--tnum)}
.v2-pn-weather .day .bar{flex:1;height:4px;background:var(--v2-bg);border-radius:2px;position:relative;overflow:hidden}
.v2-pn-weather .day .bar i{position:absolute;height:100%;background:linear-gradient(90deg,var(--v2-g-good),var(--v2-g-bad));border-radius:2px}
.v2-pn-weather .day .hi{color:var(--v2-ink);font-weight:800;font-feature-settings:var(--tnum)}

/* Region popover */
.v2-pn-region{padding:6px 14px 0;position:relative}
.v2-pn-region-map{height:200px;border-radius:18px;background:linear-gradient(135deg,#EAF1F8 0%,#DCE5EF 100%);border:1px solid var(--v2-hair);position:relative;overflow:hidden}
.v2-pn-region-map::before{content:'';position:absolute;inset:0;background-image:repeating-linear-gradient(45deg,transparent 0 12px,rgba(14,17,22,.05) 12px 13px),repeating-linear-gradient(-45deg,transparent 0 12px,rgba(14,17,22,.05) 12px 13px)}
.v2-pn-region-map .pin{position:absolute;width:10px;height:10px;border-radius:50%;border:2px solid #fff;box-shadow:0 1px 4px rgba(0,0,0,.2)}
.v2-pn-region-map .pin.p1{top:35%;left:42%;background:var(--v2-g-vbad)}
.v2-pn-region-map .pin.p2{top:62%;left:58%;background:var(--v2-g-vgood)}
.v2-pn-region-map .pin.p3{top:48%;left:28%;background:var(--v2-accent)}
.v2-pn-region-map .pin.p4{top:30%;left:68%;background:var(--v2-g-mid)}
.v2-pn-region-map .selected{position:absolute;top:42%;left:35%;width:60px;height:48px;background:rgba(0,100,255,.18);border:1.5px solid var(--v2-toss);border-radius:8px}
.v2-pn-region-pop{margin-top:-30px;margin-left:8px;margin-right:8px;background:var(--v2-surface);border:1px solid var(--v2-hair);border-radius:16px;padding:12px;box-shadow:var(--v2-shadow-2);position:relative;z-index:2}
.v2-pn-region-pop .nm{font-size:14px;font-weight:900;color:var(--v2-ink);letter-spacing:-.02em;margin-bottom:4px}
.v2-pn-region-pop .sub{font-size:10px;color:var(--v2-ink-3);font-weight:600;margin-bottom:8px}
.v2-pn-region-pop .chips{display:flex;gap:5px;margin-bottom:8px;flex-wrap:wrap}
.v2-pn-region-pop .chip{padding:4px 9px;border-radius:999px;background:var(--v2-bg);font-size:9.5px;font-weight:700;color:var(--v2-ink-2);border:1px solid var(--v2-hair);display:flex;align-items:center;gap:3px}
.v2-pn-region-pop .chip.on{background:var(--v2-accent);color:#fff;border-color:transparent}
.v2-pn-region-pop .row{display:flex;gap:8px;align-items:center;margin-bottom:4px}
.v2-pn-region-pop .pmkey{font-size:10.5px;color:var(--v2-ink-3);font-weight:600;width:50px}
.v2-pn-region-pop .pmval{font-size:14px;font-weight:900;color:var(--v2-ink);font-feature-settings:var(--tnum)}
.v2-pn-region-pop .pmval small{font-size:9px;color:var(--v2-ink-3);font-weight:700;margin-left:2px}
.v2-pn-region-pop .pmgrade{margin-left:auto;font-size:9px;font-weight:800;padding:2px 7px;border-radius:999px;background:var(--v2-g-bad-soft);color:var(--v2-g-bad)}

/* 모자이크 mini (스크럽 4단계) */
.v2-pn-bento{padding:6px 14px 0}
.v2-pn-bento .head{font-size:11px;font-weight:800;color:var(--v2-ink-3);letter-spacing:.04em;text-transform:uppercase;margin:2px 0 8px}
.v2-pn-bento .grid{display:grid;grid-template-columns:1fr 1fr;gap:7px}
.v2-pn-bento .cell{background:var(--v2-surface);border:1px solid var(--v2-hair);border-radius:13px;padding:10px;height:112px;display:flex;flex-direction:column;box-shadow:var(--v2-shadow-1)}
.v2-pn-bento .cell .ic{width:24px;height:24px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:12px;margin-bottom:5px}
.v2-pn-bento .cell.diary .ic{background:var(--v2-g-good-soft);color:var(--v2-g-good)}
.v2-pn-bento .cell.pharm .ic{background:var(--v2-g-vgood-soft);color:var(--v2-g-vgood)}
.v2-pn-bento .cell.hosp .ic{background:var(--v2-g-vbad-soft);color:var(--v2-g-vbad)}
.v2-pn-bento .cell.map .ic{background:var(--v2-accent-soft);color:var(--v2-accent)}
.v2-pn-bento .cell .ttl{font-size:11px;font-weight:800;color:var(--v2-ink);margin-bottom:2px}
.v2-pn-bento .cell .sub{font-size:9px;color:var(--v2-ink-3);font-weight:500}
.v2-pn-bento .cell .strip{display:flex;gap:2px;margin-top:auto}
.v2-pn-bento .cell .strip i{width:14px;height:14px;border-radius:50%;background:var(--v2-bg);font-size:7px;display:flex;align-items:center;justify-content:center;font-weight:800;color:var(--v2-ink-3);border:1px solid var(--v2-hair)}
.v2-pn-bento .cell .strip i.done{background:var(--v2-g-good-soft);color:var(--v2-g-good);border-color:transparent}

/* === MIRI CHATBOT DEMO === */
.v2-miri-section{padding:96px 0;background:var(--v2-surface);border-top:1px solid var(--v2-hair);border-bottom:1px solid var(--v2-hair)}
.v2-miri-head{text-align:center;max-width:660px;margin:0 auto 48px}
.v2-miri-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:60px;align-items:center;max-width:1080px;margin:0 auto}
.v2-miri-pitch{max-width:440px}
.v2-miri-pitch h3{font-size:34px;line-height:1.18;letter-spacing:-.025em;font-weight:900;color:var(--v2-ink);margin:14px 0 14px}
.v2-miri-pitch h3 em{font-style:normal;color:var(--v2-accent)}
.v2-miri-pitch p{font-size:15.5px;color:var(--v2-ink-2);line-height:1.65;font-weight:500;margin-bottom:16px}
.v2-miri-bullets{display:flex;flex-direction:column;gap:8px;margin-top:14px}
.v2-miri-bullets .b{display:flex;align-items:flex-start;gap:10px;padding:11px 14px;background:var(--v2-bg);border-radius:11px;font-size:13.5px;color:var(--v2-ink);font-weight:600}
.v2-miri-bullets .b .em{font-size:18px;flex-shrink:0}
.v2-miri-bullets .b b{color:var(--v2-accent);font-weight:800;margin-right:4px}
.v2-miri-note{display:flex;align-items:center;gap:8px;margin-top:18px;padding:10px 14px;background:var(--v2-g-mid-soft);border-radius:11px;font-size:12px;color:#8A6600;font-weight:600;line-height:1.5}
.v2-miri-note .em{font-size:16px;flex-shrink:0}
.v2-miri-dialog{background:var(--v2-bg);border:1px solid var(--v2-hair);border-radius:24px;padding:0;box-shadow:var(--v2-shadow-3);overflow:hidden;max-width:440px;justify-self:center;width:100%}
.v2-miri-dlg-head{display:flex;align-items:center;gap:11px;padding:16px 18px;background:var(--v2-surface);border-bottom:1px solid var(--v2-hair)}
.v2-miri-ava{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--v2-accent-bright),var(--v2-accent));display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;box-shadow:0 2px 8px rgba(0,157,98,.28);color:#fff}
.v2-miri-dlg-head .info{flex:1}
.v2-miri-dlg-head .nm{font-size:15px;font-weight:900;color:var(--v2-ink);letter-spacing:-.01em;display:flex;align-items:center;gap:6px}
.v2-miri-dlg-head .nm .badge{font-size:9px;padding:1px 6px;background:var(--v2-g-vgood-soft);color:#157C3A;border-radius:999px;font-weight:800;letter-spacing:.02em}
.v2-miri-dlg-head .role{font-size:11.5px;color:var(--v2-ink-3);font-weight:600;margin-top:1px}
.v2-miri-dlg-close{width:30px;height:30px;border-radius:50%;background:var(--v2-bg);border:0;display:flex;align-items:center;justify-content:center;font-size:15px;color:var(--v2-ink-3);cursor:pointer;font-family:inherit}
.v2-miri-dlg-body{padding:18px;max-height:380px;min-height:280px;overflow-y:auto;display:flex;flex-direction:column;gap:12px}
.v2-miri-dlg-body::-webkit-scrollbar{width:6px}
.v2-miri-dlg-body::-webkit-scrollbar-thumb{background:var(--v2-ink-4);border-radius:3px}
.v2-miri-bubble{max-width:82%;padding:11px 14px;border-radius:16px;font-size:13.5px;line-height:1.55;font-weight:500;animation:v2bubble .3s cubic-bezier(.34,1.56,.64,1)}
.v2-miri-bubble.bot{align-self:flex-start;background:var(--v2-surface);border:1px solid var(--v2-hair);color:var(--v2-ink);border-bottom-left-radius:6px}
.v2-miri-bubble.user{align-self:flex-end;background:var(--v2-accent);color:#fff;border-bottom-right-radius:6px;font-weight:600}
.v2-miri-bubble.bot b{color:var(--v2-accent);font-weight:800}
.v2-miri-bubble small{display:block;margin-top:6px;font-size:10.5px;color:var(--v2-ink-3);font-weight:600}
@keyframes v2bubble{from{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}
.v2-miri-typing{align-self:flex-start;display:flex;gap:4px;padding:14px 16px;background:var(--v2-surface);border:1px solid var(--v2-hair);border-radius:16px;border-bottom-left-radius:6px}
.v2-miri-typing i{width:6px;height:6px;border-radius:50%;background:var(--v2-ink-3);animation:v2typ 1.2s infinite ease-in-out}
.v2-miri-typing i:nth-child(2){animation-delay:.15s}
.v2-miri-typing i:nth-child(3){animation-delay:.3s}
@keyframes v2typ{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}
.v2-miri-chips{padding:0 18px 12px;display:flex;gap:6px;flex-wrap:wrap}
.v2-miri-chip{padding:7px 12px;background:var(--v2-surface);border:1px solid var(--v2-hair);border-radius:999px;font-size:12px;font-weight:700;color:var(--v2-ink-2);cursor:pointer;transition:.15s;font-family:inherit}
.v2-miri-chip:hover{background:var(--v2-accent-soft);color:var(--v2-accent);border-color:transparent}
.v2-miri-input-row{display:flex;gap:8px;padding:12px 18px 18px;background:var(--v2-surface);border-top:1px solid var(--v2-hair)}
.v2-miri-input{flex:1;padding:11px 14px;background:var(--v2-bg);border:1px solid var(--v2-hair);border-radius:12px;font-size:13.5px;font-family:inherit;color:var(--v2-ink);outline:none;transition:.15s}
.v2-miri-input:focus{background:var(--v2-surface);border-color:var(--v2-accent)}
.v2-miri-send{padding:0 16px;background:var(--v2-accent);color:#fff;border:0;border-radius:12px;font-weight:800;font-size:13px;cursor:pointer;font-family:inherit;transition:.15s}
.v2-miri-send:hover{background:var(--v2-accent-2)}

/* === BENTO 9-cell === */
.v2-bento-section{padding:96px 0}
.v2-bento-head{text-align:center;max-width:680px;margin:0 auto 48px}
.v2-bento-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px;grid-auto-flow:dense}
.v2-bento-cell{background:var(--v2-surface);border:1px solid var(--v2-hair);border-radius:22px;padding:22px;display:flex;flex-direction:column;position:relative;overflow:hidden;transition:.2s;box-shadow:var(--v2-shadow-1)}
.v2-bento-cell:hover{transform:translateY(-3px);box-shadow:var(--v2-shadow-2)}
.v2-bento-cell .em-bg{position:absolute;font-size:140px;right:-20px;bottom:-30px;opacity:.06;line-height:1;pointer-events:none}
.v2-bento-cell h4{font-size:18px;font-weight:900;letter-spacing:-.02em;color:var(--v2-ink);margin:0 0 6px}
.v2-bento-cell p{font-size:13px;color:var(--v2-ink-2);line-height:1.55;font-weight:500;margin:0}
.v2-bento-cell .ico{width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:18px;margin-bottom:14px}
.v2-bento-cell.c-med{grid-column:span 2;grid-row:span 1}
.v2-bento-cell.c-med .ico{background:var(--v2-g-bad-soft);color:var(--v2-g-bad)}
.v2-bento-cell.c-diary{grid-column:span 1;grid-row:span 2}
.v2-bento-cell.c-diary .ico{background:var(--v2-g-good-soft);color:var(--v2-g-good)}
.v2-bento-cell.c-fortune{grid-column:span 1;grid-row:span 1}
.v2-bento-cell.c-fortune .ico{background:var(--v2-g-haz-soft);color:var(--v2-g-haz)}
.v2-bento-cell.c-ocr .ico{background:var(--v2-toss-soft);color:var(--v2-toss)}
.v2-bento-cell.c-119{grid-column:span 1}
.v2-bento-cell.c-119 .ico{background:var(--v2-g-vbad-soft);color:var(--v2-g-vbad)}
.v2-bento-cell.c-widget{grid-column:span 2;grid-row:span 1}
.v2-bento-cell.c-widget .ico{background:var(--v2-accent-soft);color:var(--v2-accent)}
.v2-bento-cell.c-news .ico{background:var(--v2-g-mid-soft);color:#8A6600}
.v2-bento-cell.c-region .ico{background:var(--v2-g-vgood-soft);color:var(--v2-g-vgood)}
.v2-bento-cell.c-chat .ico{background:var(--v2-accent-soft);color:var(--v2-accent)}
.v2-bento-mini{margin-top:auto;display:flex;gap:6px;align-items:center;font-size:11px;color:var(--v2-ink-3);font-weight:700;flex-wrap:wrap}
.v2-bento-mini .pill{padding:4px 10px;border-radius:999px;background:var(--v2-bg);font-weight:700}
.v2-bento-mini .pill.accent{background:var(--v2-accent-soft);color:var(--v2-accent)}
.v2-bento-medring{margin-top:auto;display:flex;align-items:center;gap:12px}
.v2-bento-medring .ring{width:54px;height:54px;border-radius:50%;background:conic-gradient(var(--v2-g-bad) 0% 62%,var(--v2-bg) 62% 100%);display:flex;align-items:center;justify-content:center;position:relative;flex-shrink:0}
.v2-bento-medring .ring::before{content:'';position:absolute;inset:5px;background:var(--v2-surface);border-radius:50%}
.v2-bento-medring .ring span{position:relative;z-index:1;font-size:12px;font-weight:900;color:var(--v2-ink);font-feature-settings:var(--tnum)}
.v2-bento-medring .info{font-size:11px;color:var(--v2-ink-3);font-weight:700}
.v2-bento-medring .info b{display:block;font-size:13px;color:var(--v2-ink);font-weight:800;margin-bottom:2px}
.v2-bento-heatmap{margin-top:14px;display:grid;grid-template-columns:repeat(8,1fr);gap:3px;flex:1}
.v2-bento-heatmap i{aspect-ratio:1;border-radius:3px;background:var(--v2-bg)}
.v2-bento-heatmap i.lv1{background:var(--v2-g-vgood-soft)}
.v2-bento-heatmap i.lv2{background:#A8E6B5}
.v2-bento-heatmap i.lv3{background:var(--v2-g-mid-soft)}
.v2-bento-heatmap i.lv4{background:#FFB7A0}
.v2-bento-heatmap i.lv5{background:var(--v2-g-bad)}
.v2-bento-wmini{margin-top:auto;display:grid;grid-template-columns:1fr 1fr 1.5fr;gap:6px}
.v2-bento-wmini .w{padding:7px 6px;background:var(--v2-bg);border:1px solid var(--v2-hair);border-radius:8px;text-align:center}
.v2-bento-wmini .w .l{font-size:7px;color:var(--v2-ink-3);font-weight:800;text-transform:uppercase;letter-spacing:.04em}
.v2-bento-wmini .w .v{font-size:14px;color:var(--v2-accent);font-weight:900;margin:2px 0}
.v2-bento-wmini .w small{font-size:7px;color:var(--v2-ink-3);font-weight:700}
.v2-bento-news{margin-top:12px;display:flex;flex-direction:column;gap:5px}
.v2-bento-news .n{display:flex;gap:6px;align-items:center;font-size:10px;color:var(--v2-ink-2);font-weight:600;padding:5px 8px;background:var(--v2-bg);border-radius:7px}
.v2-bento-news .n .src{font-size:8px;font-weight:800;padding:2px 6px;border-radius:999px;background:var(--v2-g-mid-soft);color:#8A6600;flex-shrink:0}
.v2-bento-sos{margin-top:auto;padding:11px 12px;background:linear-gradient(135deg,#FF3B30,#D92923);border-radius:12px;color:#fff;display:flex;align-items:center;gap:8px;font-size:12px;font-weight:800}
.v2-bento-sos .em{font-size:18px;animation:v2siren 1.4s ease infinite}
@keyframes v2siren{0%,100%{transform:rotate(-8deg)}50%{transform:rotate(8deg)}}
.v2-bento-sos .arr{margin-left:auto;font-size:14px}

/* === 6-COLOR GRADE GUIDE === */
.v2-grade-section{padding:96px 0;background:var(--v2-surface);border-top:1px solid var(--v2-hair);border-bottom:1px solid var(--v2-hair)}
.v2-grade-head{text-align:center;max-width:680px;margin:0 auto 40px}
.v2-grade-strip{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;margin-bottom:24px}
.v2-grade-cell{background:var(--v2-bg);border-radius:16px;padding:18px;text-align:center;border:1px solid var(--v2-hair);transition:.18s;position:relative;overflow:hidden}
.v2-grade-cell::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:currentColor}
.v2-grade-cell.vgood{color:var(--v2-g-vgood)}
.v2-grade-cell.good{color:var(--v2-g-good)}
.v2-grade-cell.mid{color:var(--v2-g-mid)}
.v2-grade-cell.bad{color:var(--v2-g-bad)}
.v2-grade-cell.vbad{color:var(--v2-g-vbad)}
.v2-grade-cell.haz{color:var(--v2-g-haz)}
.v2-grade-cell .em{font-size:32px;margin-top:8px;display:block}
.v2-grade-cell .lvl{font-size:14px;font-weight:900;color:var(--v2-ink);margin:8px 0 4px;letter-spacing:-.01em}
.v2-grade-cell .rng{font-size:11px;color:var(--v2-ink-3);font-weight:700;font-feature-settings:var(--tnum)}
.v2-grade-cell .act{font-size:11.5px;color:var(--v2-ink-2);font-weight:600;margin-top:10px;line-height:1.5;min-height:48px}
.v2-grade-note{text-align:center;font-size:12.5px;color:var(--v2-ink-3);font-weight:600;line-height:1.6}
.v2-grade-note b{color:var(--v2-ink);font-weight:700}

/* === WIDGET 4-종 미리보기 === */
/* === 위젯 4종 미리보기 (v3 — 1 위젯 = 1 메시지, 큰 활자) === */
.v2-widget-section{padding:96px 0}
.v2-widget-head{text-align:center;max-width:680px;margin:0 auto 48px}
.v2-widget-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;max-width:1180px;margin:0 auto;align-items:start}
.v2-widget-frame{background:linear-gradient(135deg,#1A1D2E 0%,#2B3148 100%);border-radius:28px;padding:22px;display:flex;flex-direction:column;align-items:stretch;gap:14px;border:1px solid rgba(255,255,255,.08);box-shadow:var(--v2-shadow-3)}
.v2-widget-frame .lbl{font-size:11px;color:rgba(255,255,255,.55);font-weight:800;letter-spacing:.04em;text-transform:uppercase;text-align:center}

/* 위젯 mock 공통 — 흰 베이스 + 얇은 테두리 + soft shadow */
.v2-widget-mock{
  background:#FFFFFF;
  border-radius:18px;
  border:1px solid rgba(14,17,22,.08);
  box-shadow:0 1px 2px rgba(14,17,22,.04),0 8px 24px rgba(14,17,22,.10);
  width:100%;
  color:var(--v2-ink);
  font-feature-settings:var(--tnum);
  position:relative;
  overflow:hidden;
  display:flex;
  flex-direction:column;
}
.v2-widget-mock.s42{aspect-ratio:2/1;padding:12px 14px}
.v2-widget-mock.s43{aspect-ratio:4/3;padding:14px 16px}

.v2-widget-frame .desc{font-size:12px;color:rgba(255,255,255,.7);font-weight:600;text-align:center;line-height:1.5;margin-top:2px}
.v2-widget-frame .desc b{color:#fff;font-weight:800}

/* ① 오늘 공기 + 다음 약 (4×2) */
.wm-today{flex-direction:row;align-items:stretch;gap:10px}
.wm-today .col{flex:1;display:flex;flex-direction:column;justify-content:center;gap:3px;min-width:0}
.wm-today .vrule{width:1px;background:rgba(14,17,22,.08);align-self:stretch}
.wm-today .meta{font-size:9.5px;font-weight:700;color:var(--v2-ink-3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wm-today .grade{font-size:26px;font-weight:900;letter-spacing:-.5px;line-height:1.05;color:var(--v2-g-vgood)}
.wm-today .temp{display:flex;align-items:baseline;gap:4px;font-size:11px;font-weight:800;color:var(--v2-ink-2);flex-wrap:wrap}
.wm-today .temp .feel{color:var(--v2-ink-3);font-weight:700}
.wm-today .med-lab{display:flex;align-items:center;gap:3px;font-size:9.5px;font-weight:800;color:#0EA371}
.wm-today .med-time{font-size:24px;font-weight:900;letter-spacing:-.5px;line-height:1;color:var(--v2-ink)}
.wm-today .med-name{font-size:11px;font-weight:800;color:var(--v2-ink-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wm-today .med-delta{font-size:10px;font-weight:800;color:#0EA371}

/* ② 오늘 + 4일 예보 (4×3) */
.wm-fc .hero{display:flex;flex-direction:column;flex:1.3;padding-bottom:8px}
.wm-fc .hero .head{display:flex;justify-content:space-between;align-items:flex-start;gap:6px}
.wm-fc .hero .meta{font-size:10px;font-weight:700;color:var(--v2-ink-3)}
.wm-fc .hero .temp{font-size:14px;font-weight:900;color:var(--v2-ink);letter-spacing:-.3px}
.wm-fc .grade-big{font-size:46px;font-weight:900;line-height:.95;letter-spacing:-1.6px;color:var(--v2-g-vgood);margin-top:4px}
.wm-fc .dust{display:flex;gap:10px;font-size:11px;font-weight:800;color:var(--v2-ink);margin-top:6px;flex-wrap:wrap}
.wm-fc .dust .lab{color:var(--v2-ink-3);margin-right:3px;font-weight:700}
.wm-fc .narrative{font-size:11px;font-weight:700;color:var(--v2-ink-2);line-height:1.35;margin-top:4px}
.wm-fc .strip{flex:1;display:flex;flex-direction:column;gap:3px;padding-top:8px;border-top:1px solid rgba(14,17,22,.08)}
.wm-fc .strip-lbl{font-size:9px;font-weight:800;color:var(--v2-ink-3);letter-spacing:.3px;margin-bottom:2px}
.wm-fc .day{display:grid;grid-template-columns:42px 18px 1fr 56px;column-gap:6px;align-items:center;height:18px}
.wm-fc .day .d{font-size:10px;font-weight:800;color:var(--v2-ink-2)}
.wm-fc .day .em{font-size:13px;text-align:center}
.wm-fc .day .bar{height:4px;border-radius:999px;background:rgba(14,17,22,.08);overflow:hidden}
.wm-fc .day .fill{height:100%;border-radius:999px}
.wm-fc .day .t{font-size:10px;font-weight:800;text-align:right}
.wm-fc .day .lo{color:var(--v2-ink-3);margin-right:4px}
.wm-fc .day .hi{color:var(--v2-ink)}

/* ③ 시간별 + 환경 4종 (4×3) */
.wm-wk .head{display:flex;justify-content:space-between;align-items:flex-end;gap:6px;margin-bottom:4px}
.wm-wk .head .meta{font-size:10px;font-weight:700;color:var(--v2-ink-3)}
.wm-wk .head .right{display:flex;align-items:center;gap:6px}
.wm-wk .head .grade{font-size:16px;font-weight:900;color:var(--v2-g-vgood);letter-spacing:-.3px}
.wm-wk .head .temp{font-size:16px;font-weight:900;color:var(--v2-ink);letter-spacing:-.3px}
.wm-wk .hr-lbl{font-size:9px;font-weight:800;color:var(--v2-ink-3);letter-spacing:.3px;margin:8px 0 6px}
.wm-wk .hours{display:grid;grid-template-columns:repeat(6,1fr);gap:3px;flex:1;align-items:end}
.wm-wk .h{display:flex;flex-direction:column;align-items:center;gap:3px}
.wm-wk .h .hr{font-size:9px;font-weight:800;color:var(--v2-ink-2)}
.wm-wk .h .em{font-size:13px}
.wm-wk .h .bar{width:5px;border-radius:3px}
.wm-wk .h .t{font-size:11px;font-weight:900;color:var(--v2-ink)}
.wm-wk .env{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;padding-top:10px;margin-top:10px;border-top:1px solid rgba(14,17,22,.08)}
.wm-wk .env .c{display:flex;flex-direction:column;align-items:center;gap:2px;min-width:0}
.wm-wk .env .lb{font-size:9px;font-weight:700;color:var(--v2-ink-3)}
.wm-wk .env .vl{font-size:12px;font-weight:900;letter-spacing:-.2px;white-space:nowrap}
.wm-wk .env .vl.uv{color:var(--v2-g-bad)}
.wm-wk .env .vl.po{color:var(--v2-g-vgood)}
.wm-wk .env .vl.df{color:var(--v2-ink-4)}
.wm-wk .env .vl.hu{color:var(--v2-ink)}

/* ④ 복약 일정 (4×3) */
.wm-med .meta{display:flex;align-items:center;gap:3px;font-size:10px;font-weight:800;color:#0EA371;letter-spacing:.3px}
.wm-med .hero{flex:1.4;display:flex;flex-direction:column;justify-content:center;gap:5px;padding:8px 0}
.wm-med .time{font-size:54px;font-weight:900;line-height:.92;letter-spacing:-2.4px;color:var(--v2-ink)}
.wm-med .name{font-size:13px;font-weight:900;color:var(--v2-ink)}
.wm-med .delta{display:inline-flex;align-self:flex-start;align-items:center;background:#DCFCE7;color:#0EA371;padding:3px 9px;border-radius:999px;font-size:10px;font-weight:900}
.wm-med .footer{flex:1;display:flex;flex-direction:column;justify-content:center;gap:8px;padding-top:10px;border-top:1px solid rgba(14,17,22,.08)}
.wm-med .progress{display:flex;align-items:center;gap:8px}
.wm-med .progress .tr{flex:1;height:6px;border-radius:999px;background:rgba(14,17,22,.08);overflow:hidden}
.wm-med .progress .fl{height:100%;border-radius:999px;background:#0EA371}
.wm-med .progress .lb{font-size:11px;font-weight:900;color:var(--v2-ink)}
.wm-med .stats{display:flex;gap:8px}
.wm-med .chip{flex:1;display:flex;flex-direction:column;align-items:center;padding:6px 4px;background:var(--v2-bg);border-radius:8px;gap:1px}
.wm-med .chip .lb{font-size:9px;font-weight:700;color:var(--v2-ink-3)}
.wm-med .chip .vl{font-size:13px;font-weight:900;color:var(--v2-ink)}

/* === FORTUNE 5-Persona === */
.v2-fortune-section{padding:96px 0;background:linear-gradient(180deg,var(--v2-bg) 0%,#E8E2D8 100%);border-top:1px solid var(--v2-hair)}
.v2-fortune-head{text-align:center;max-width:680px;margin:0 auto 48px}
.v2-fortune-rail{display:flex;gap:18px;overflow-x:auto;padding:8px 24px 24px;scroll-snap-type:x mandatory;scrollbar-width:none}
.v2-fortune-rail::-webkit-scrollbar{display:none}
.v2-fortune-card{flex:0 0 280px;background:linear-gradient(180deg,#FBF6EC 0%,#F4ECD9 100%);border:1px solid rgba(120,90,50,.18);border-radius:24px;padding:24px;scroll-snap-align:center;position:relative;overflow:hidden;box-shadow:0 8px 28px rgba(120,90,50,.12)}
.v2-fortune-card::before{content:'';position:absolute;top:0;left:0;right:0;height:6px;background:linear-gradient(90deg,#8B2E2E 0%,#D4A373 50%,#8B2E2E 100%)}
.v2-fortune-card .em{font-size:48px;line-height:1;display:block;margin-bottom:14px}
.v2-fortune-card .nm{font-size:20px;font-weight:900;color:var(--v2-ink);letter-spacing:-.02em;margin-bottom:4px}
.v2-fortune-card .role{font-size:11.5px;color:#8B6F47;font-weight:700;margin-bottom:14px;letter-spacing:.04em;text-transform:uppercase}
.v2-fortune-card .quote{font-size:13.5px;color:#5A4329;line-height:1.65;font-weight:500;padding:12px 14px;background:rgba(255,255,255,.5);border-radius:12px;border:1px solid rgba(120,90,50,.12);min-height:96px}
.v2-fortune-card .quote::before{content:'"';font-size:20px;color:#B89968;font-weight:900;margin-right:2px;line-height:0;vertical-align:-6px}
.v2-fortune-rail-nav{display:flex;justify-content:center;gap:8px;margin-top:14px}
.v2-fortune-rail-nav button{width:36px;height:36px;border-radius:50%;background:var(--v2-surface);border:1px solid var(--v2-hair);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--v2-ink);transition:.15s;font-family:inherit}
.v2-fortune-rail-nav button:hover{background:var(--v2-accent);color:#fff;border-color:transparent}

/* === SCREENSHOTS V2 === */
.v2-shots-section{padding:96px 0}
.v2-shots-head{text-align:center;max-width:680px;margin:0 auto 48px}
.v2-shots-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}
.v2-shots-grid figure{margin:0;display:flex;flex-direction:column;gap:10px}
.v2-shots-grid img{width:100%;aspect-ratio:9/19.5;object-fit:cover;border-radius:22px;background:var(--v2-surface);box-shadow:var(--v2-shadow-3);transition:.25s;border:1px solid var(--v2-hair)}
.v2-shots-grid figure:hover img{transform:translateY(-5px);box-shadow:0 20px 50px -10px rgba(14,17,22,.22)}
.v2-shots-grid figcaption{font-size:12.5px;color:var(--v2-ink-2);text-align:center;font-weight:600;line-height:1.4;padding:0 4px}
.v2-more-shots{margin-top:32px;background:var(--v2-surface);border:1px solid var(--v2-hair);border-radius:18px;padding:0;overflow:hidden}
.v2-more-shots summary{cursor:pointer;list-style:none;padding:18px 24px;display:flex;justify-content:space-between;align-items:center;font-size:14px;font-weight:800;color:var(--v2-ink)}
.v2-more-shots summary::-webkit-details-marker{display:none}
.v2-more-shots summary .cnt{font-size:11.5px;color:var(--v2-ink-3);font-weight:700;margin-left:8px}
.v2-more-shots summary .cta{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;background:var(--v2-accent);color:#fff;border-radius:999px;font-size:12px;font-weight:800}
.v2-more-shots[open] summary .cta .arr{transform:rotate(180deg)}
.v2-more-shots summary .cta .arr{transition:.25s}
.v2-more-shots-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;padding:0 24px 24px;animation:v2fade .35s ease}
.v2-more-shots-grid img{width:100%;aspect-ratio:9/19.5;object-fit:cover;border-radius:14px;border:1px solid var(--v2-hair);background:var(--v2-surface);box-shadow:var(--v2-shadow-1)}
@keyframes v2fade{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}

/* === STORY === */
.v2-story-section{padding:96px 0;background:var(--v2-surface);border-top:1px solid var(--v2-hair);border-bottom:1px solid var(--v2-hair)}
.v2-story-head{text-align:center;max-width:680px;margin:0 auto 48px}
.v2-story-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.v2-story-card{background:var(--v2-bg);border:1px solid var(--v2-hair);border-radius:20px;padding:28px;position:relative;transition:.18s}
.v2-story-card:hover{transform:translateY(-3px);background:var(--v2-surface);box-shadow:var(--v2-shadow-2)}
.v2-story-card .quote{font-size:48px;color:var(--v2-accent);font-weight:900;line-height:1;margin-bottom:8px}
.v2-story-card h4{font-size:18px;font-weight:900;color:var(--v2-ink);letter-spacing:-.02em;margin:0 0 10px}
.v2-story-card p{font-size:14px;color:var(--v2-ink-2);line-height:1.65;font-weight:500;margin:0}
.v2-story-link{display:inline-flex;align-items:center;gap:6px;margin-top:32px;padding:11px 18px;background:var(--v2-bg);border:1px solid var(--v2-hair);border-radius:999px;font-size:13px;color:var(--v2-ink);font-weight:700;transition:.15s}
.v2-story-link:hover{background:var(--v2-accent);color:#fff;border-color:transparent}

/* === DONORS slide V2 === */
.v2-donors-section{padding:96px 0}
.v2-donors-wrap{background:var(--v2-surface);border:1px solid var(--v2-hair);border-radius:28px;padding:40px;box-shadow:var(--v2-shadow-2)}
.v2-donors-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:28px;flex-wrap:wrap;gap:12px}
.v2-donors-head h3{font-size:24px;font-weight:900;letter-spacing:-.02em;color:var(--v2-ink);margin:0}
.v2-donors-head h3 em{font-style:normal;color:var(--v2-accent)}
.v2-donors-head a{font-size:13px;color:var(--v2-accent);font-weight:700;display:inline-flex;align-items:center;gap:4px}
.v2-donors-slide{display:flex;gap:14px;overflow-x:auto;padding-bottom:14px;scroll-snap-type:x mandatory;scrollbar-width:none}
.v2-donors-slide::-webkit-scrollbar{display:none}
.v2-donors-card{flex:0 0 260px;background:var(--v2-bg);border:1px solid var(--v2-hair);border-radius:16px;padding:18px;scroll-snap-align:start}
.v2-donors-card .nm{font-size:14px;font-weight:800;color:var(--v2-ink);margin-bottom:4px}
.v2-donors-card .nm .em{margin-right:4px}
.v2-donors-card .dt{font-size:11px;color:var(--v2-ink-3);font-weight:600;margin-bottom:10px;font-feature-settings:var(--tnum)}
.v2-donors-card .msg{font-size:13px;color:var(--v2-ink-2);line-height:1.55;font-weight:500;font-style:italic}
.v2-donors-dots{display:flex;justify-content:center;gap:6px;margin-top:14px}
.v2-donors-dots i{width:6px;height:6px;border-radius:50%;background:var(--v2-ink-4);cursor:pointer;transition:.2s}
.v2-donors-dots i.on{background:var(--v2-accent);width:18px;border-radius:3px}

/* === SIGNATURE CTA === */
.v2-sig-section{padding:96px 0}
.v2-sig{background:linear-gradient(135deg,#007A4D 0%,#009D62 50%,#4ADE80 100%);border-radius:36px;padding:64px 40px;text-align:center;color:#fff;position:relative;overflow:hidden;box-shadow:0 30px 60px -10px rgba(0,157,98,.32)}
.v2-sig::before{content:'';position:absolute;top:-100px;right:-100px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.08) 0%,transparent 60%);pointer-events:none}
.v2-sig::after{content:'';position:absolute;bottom:-150px;left:-100px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.05) 0%,transparent 60%);pointer-events:none}
.v2-sig .v2-eyebrow{background:rgba(255,255,255,.16);color:#fff;border-color:transparent;backdrop-filter:blur(8px);position:relative;z-index:1}
.v2-sig h3{font-size:38px;font-weight:900;letter-spacing:-.025em;line-height:1.2;margin:18px 0 18px;position:relative;z-index:1}
.v2-sig p{font-size:16px;color:rgba(255,255,255,.85);line-height:1.65;font-weight:500;max-width:560px;margin:0 auto 12px;position:relative;z-index:1}
.v2-sig p b{color:#fff;font-weight:800}
.v2-sig p a{color:#fff;font-weight:800;text-decoration:underline;text-underline-offset:3px}
.v2-sig .sig-name{display:inline-block;margin-top:18px;font-size:13px;color:rgba(255,255,255,.7);font-weight:700;letter-spacing:.04em;position:relative;z-index:1}
.v2-sig-cta{display:inline-flex;gap:10px;margin-top:32px;flex-wrap:wrap;justify-content:center;position:relative;z-index:1}
.v2-sig-cta .v2-cta{background:#fff;color:var(--v2-accent);box-shadow:0 4px 14px rgba(0,0,0,.18)}
.v2-sig-cta .v2-cta:hover{background:#FAFAFB;color:var(--v2-accent-2)}
.v2-sig-cta .v2-cta-ghost{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.3);backdrop-filter:blur(8px)}
.v2-sig-cta .v2-cta-ghost:hover{background:rgba(255,255,255,.2)}

/* === FOOTER V2 === */
.v2-footer{background:var(--v2-surface);border-top:1px solid var(--v2-hair);padding:48px 0 36px}
.v2-footer-grid{display:flex;justify-content:space-between;flex-wrap:wrap;gap:24px;align-items:center}
.v2-footer-cp{font-size:12.5px;color:var(--v2-ink-3);font-weight:600}
.v2-footer-cp b{color:var(--v2-ink);font-weight:700}
.v2-footer-links{display:flex;gap:18px;flex-wrap:wrap;align-items:center}
.v2-footer-links a{font-size:12px;color:var(--v2-ink-2);font-weight:600;transition:.15s}
.v2-footer-links a:hover{color:var(--v2-accent)}
.v2-footer-ig{display:inline-flex;align-items:center;gap:5px;padding:5px 11px;background:linear-gradient(135deg,#feda75,#fa7e1e,#d62976,#962fbf,#4f5bd5);background-size:200% 200%;color:#fff;border-radius:999px;font-size:11.5px;font-weight:800;animation:v2igshift 6s ease infinite}
@keyframes v2igshift{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}

/* === Mobile menu (햄버거) === */
.v2-mobile-menu{position:fixed;top:0;right:-100%;bottom:0;width:280px;background:var(--v2-surface);box-shadow:-10px 0 40px rgba(0,0,0,.18);z-index:200;transition:right .3s ease;padding:24px;display:flex;flex-direction:column;gap:6px;overflow-y:auto}
.v2-mobile-menu.open{right:0}
.v2-mobile-menu-back{position:fixed;inset:0;background:rgba(0,0,0,.32);z-index:199;opacity:0;pointer-events:none;transition:.3s}
.v2-mobile-menu-back.open{opacity:1;pointer-events:auto}
.v2-mobile-menu .mm-close{align-self:flex-end;width:36px;height:36px;border-radius:50%;background:var(--v2-bg);border:0;font-size:18px;color:var(--v2-ink);cursor:pointer;display:flex;align-items:center;justify-content:center;margin-bottom:12px;font-family:inherit}
.v2-mobile-menu a{padding:13px 16px;border-radius:12px;font-size:14px;font-weight:700;color:var(--v2-ink);display:flex;align-items:center;gap:10px;transition:.15s}
.v2-mobile-menu a:hover{background:var(--v2-bg)}
.v2-mobile-menu a .em{font-size:18px;width:24px;text-align:center}
.v2-mobile-menu a.cta{background:var(--v2-accent);color:#fff;margin-top:8px}

/* ==================================================================
   SCREENSHOTS V2 — 실제 앱 캡처 (카테고리별 7 섹션)
   ================================================================== */
.v2-shots2-section{padding:96px 0;background:var(--v2-bg)}
.v2-shots2-head{text-align:center;max-width:680px;margin:0 auto 56px}
.v2-shots2-cats{display:flex;flex-direction:column;gap:64px}
.v2-shots2-cat{display:grid;grid-template-columns:280px 1fr;gap:36px;align-items:start;background:var(--v2-surface);border:1px solid var(--v2-hair);border-radius:28px;padding:36px;box-shadow:var(--v2-shadow-1)}
.v2-shots2-cat-meta{position:sticky;top:100px}
.v2-shots2-cat-tag{display:inline-flex;align-items:center;gap:7px;padding:6px 12px;background:var(--v2-accent-soft);color:var(--v2-accent);border-radius:999px;font-size:11.5px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;margin-bottom:14px}
.v2-shots2-cat h3{font-size:28px;font-weight:900;color:var(--v2-ink);letter-spacing:-.025em;line-height:1.18;margin:0 0 12px}
.v2-shots2-cat h3 em{font-style:normal;color:var(--v2-accent)}
.v2-shots2-cat p{font-size:14.5px;color:var(--v2-ink-2);line-height:1.65;font-weight:500;margin:0 0 14px}
.v2-shots2-cat ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}
.v2-shots2-cat ul li{display:flex;align-items:flex-start;gap:8px;font-size:12.5px;color:var(--v2-ink-2);font-weight:600;line-height:1.5}
.v2-shots2-cat ul li::before{content:'';display:inline-block;width:4px;height:4px;border-radius:50%;background:var(--v2-accent);margin-top:8px;flex-shrink:0}
.v2-shots2-cat ul li b{color:var(--v2-accent);font-weight:800;margin-right:4px}
.v2-shots2-cat-imgs{display:grid;gap:16px}
.v2-shots2-cat-imgs.cols-1{grid-template-columns:minmax(0,300px)}
.v2-shots2-cat-imgs.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.v2-shots2-cat-imgs.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.v2-shots2-cat-imgs.cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.v2-shots2-cat-imgs figure{margin:0;display:flex;flex-direction:column;gap:8px}
.v2-shots2-cat-imgs img{width:100%;height:auto;display:block;border-radius:18px;background:var(--v2-surface-3);box-shadow:0 8px 28px -8px rgba(14,17,22,.18),0 0 0 1px var(--v2-hair);transition:.25s}
.v2-shots2-cat-imgs figure:hover img{transform:translateY(-4px);box-shadow:0 18px 40px -10px rgba(14,17,22,.25),0 0 0 1px var(--v2-hair-2)}
.v2-shots2-cat-imgs figcaption{font-size:11.5px;color:var(--v2-ink-3);text-align:center;font-weight:600;line-height:1.4;padding:0 4px}
.v2-shots2-cat-imgs figcaption b{color:var(--v2-ink-2);font-weight:700}
.v2-shots2-cat-tag.t-home    {background:var(--v2-accent-soft);color:var(--v2-accent)}
.v2-shots2-cat-tag.t-weather {background:var(--v2-g-good-soft);color:#0070A8}
.v2-shots2-cat-tag.t-diary   {background:var(--v2-toss-soft);color:var(--v2-toss)}
.v2-shots2-cat-tag.t-med     {background:var(--v2-g-vgood-soft);color:#1A7A2D}
.v2-shots2-cat-tag.t-advice  {background:var(--v2-g-mid-soft);color:#8A6600}
.v2-shots2-cat-tag.t-map     {background:var(--v2-g-bad-soft);color:#B05B00}
.v2-shots2-cat-tag.t-chatbot {background:var(--v2-g-haz-soft);color:#7A2D9B}

@media(max-width:960px){
  body.index-v2 .v2-shots2-cat{grid-template-columns:1fr;gap:24px;padding:28px}
  body.index-v2 .v2-shots2-cat-meta{position:relative;top:auto}
  body.index-v2 .v2-shots2-cat h3{font-size:24px}
}
@media(max-width:560px){
  body.index-v2 .v2-shots2-cat-imgs.cols-2,
  body.index-v2 .v2-shots2-cat-imgs.cols-3,
  body.index-v2 .v2-shots2-cat-imgs.cols-4{grid-template-columns:1fr 1fr;gap:10px}
  body.index-v2 .v2-shots2-cat-imgs.cols-1{grid-template-columns:1fr}
  body.index-v2 .v2-shots2-cat{padding:22px;border-radius:22px}
}

/* === RESPONSIVE === */
@media(max-width:1100px){
  body.index-v2 .v2-nav-links{display:none}
  body.index-v2 .v2-hamburger{display:flex}
  body.index-v2 .v2-bento-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:auto;grid-auto-flow:row}
  body.index-v2 .v2-bento-cell.c-med,body.index-v2 .v2-bento-cell.c-widget{grid-column:span 2}
  body.index-v2 .v2-bento-cell.c-diary{grid-column:span 2;grid-row:span 1;min-height:240px}
  body.index-v2 .v2-bento-cell{min-height:200px}
  body.index-v2 .v2-shots-grid{grid-template-columns:repeat(3,1fr)}
  body.index-v2 .v2-more-shots-grid{grid-template-columns:repeat(4,1fr)}
  body.index-v2 .v2-widget-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  body.index-v2 h1.v2-h1{font-size:44px}
  body.index-v2 h2.v2-h2{font-size:34px}
  body.index-v2 .v2-hero-grid,body.index-v2 .v2-scrub-grid,body.index-v2 .v2-miri-grid{grid-template-columns:1fr;gap:48px}
  body.index-v2 .v2-scrub-sticky{position:relative;top:auto;min-height:auto;margin-bottom:24px}
  body.index-v2 .v2-scrub-stage{min-height:auto;padding:40px 0}
  body.index-v2 .v2-strip{grid-template-columns:repeat(2,1fr)}
  body.index-v2 .v2-strip-card:last-child{grid-column:span 2}
  body.index-v2 .v2-grade-strip{grid-template-columns:repeat(3,1fr)}
  body.index-v2 .v2-shots-grid{grid-template-columns:repeat(2,1fr)}
  body.index-v2 .v2-more-shots-grid{grid-template-columns:repeat(3,1fr)}
  body.index-v2 .v2-widget-grid{grid-template-columns:1fr 1fr}
  body.index-v2 .v2-story-grid{grid-template-columns:1fr}
  body.index-v2 .v2-sig{padding:48px 28px;border-radius:24px}
  body.index-v2 .v2-sig h3{font-size:28px}
  body.index-v2 .v2-hero-phone-wrap{min-height:580px}
  body.index-v2 .v2-phone{transform:scale(.9);transform-origin:top center}
  body.index-v2 .v2-livechip-place{max-width:62px}
}
@media(max-width:480px){
  body.index-v2 .v2-nav-right .v2-cta{display:none}
  body.index-v2 h1.v2-h1{font-size:36px;line-height:1.08}
  body.index-v2 h2.v2-h2{font-size:28px}
  body.index-v2 .v2-hero{padding:40px 0 56px}
  body.index-v2 .v2-strip{grid-template-columns:1fr 1fr}
  body.index-v2 .v2-strip-card:last-child{grid-column:span 2}
  body.index-v2 .v2-grade-strip{grid-template-columns:repeat(2,1fr)}
  body.index-v2 .v2-shots-grid,body.index-v2 .v2-bento-grid{grid-template-columns:1fr}
  body.index-v2 .v2-bento-cell.c-med,body.index-v2 .v2-bento-cell.c-widget,body.index-v2 .v2-bento-cell.c-diary{grid-column:span 1}
  body.index-v2 .v2-bento-cell{height:auto;min-height:180px}
  body.index-v2 .v2-more-shots-grid{grid-template-columns:repeat(2,1fr)}
  body.index-v2 .v2-fortune-card{flex-basis:240px}
}

/* === SCROLL-SCRUB 영상 모드 (2026-05-19) ============================
   기존 폰 프레임(검은 베젤+노치) 그대로 보존. 영상만 안쪽 풀필.
   4 stage 모두 autoplay loop (스크롤-싱크 사용 안 함, IntersectionObserver 로 전환).
   - 가짜 status bar 그리드(::after) 제거 — 영상에 실제 상태바가 이미 있음
   - object-fit:contain — 영상 9:16 vs 폰 9:19.5 비율 차로 좌우 잘림 회피 (위아래 검은 letterbox 가 베젤색과 매칭)
   ================================================================== */
/* scrub 폰 한정 — 영상 자체에 박혀있던 좌우 검은띠(74px×2) 크롭 → 영상 572×1280 (1:2.24).
   폰 외곽 = 영상 비율 그대로. 검은 프레임·노치 제거, 둥근 모서리 + 드롭 섀도만. */
.v2-scrub-phone{
  width:320px;
  height:716px;           /* 320 × 1280/572 = 715.9 → 영상 비율 정확 매칭 */
  padding:0;
  border-radius:32px;
  background:transparent;
  box-shadow:0 26px 70px -18px rgba(14,17,22,.35), 0 6px 18px -4px rgba(14,17,22,.12);
  aspect-ratio:auto;
}
.v2-scrub-phone::before{display:none}  /* 노치 제거 (영상에 실제 상태바 있음) */
.v2-scrub-phone .v2-phone-screen{background:transparent;border-radius:32px}
.v2-scrub-phone .v2-phone-screen::after{display:none}
.v2-scrub-phone .v2-pn-screen-set{position:absolute;inset:0;border-radius:32px;overflow:hidden;z-index:2}
.v2-scrub-phone .v2-pn-screen{position:absolute;inset:0;opacity:0;transition:opacity .4s ease;pointer-events:none;background:#0E0E10}
.v2-scrub-phone .v2-pn-screen.on{opacity:1;pointer-events:auto}
.v2-scrub-phone .v2-pn-screen video{width:100%;height:100%;display:block;object-fit:cover;border-radius:32px;background:#0E0E10}
