/* ValueBridge home.css — index.html 인라인 <style> 분리본 */

  :root{
    --bg:#0A0E0C;
    --bg-deep:#11160F;
    --text:#F5F2E6;
    --text-sec:#9AA39A;
    --gold:#C9A84C;
    --gold-soft:rgba(201,168,76,0.55);
    --gold-line:rgba(201,168,76,0.22);
    --deep-green:#1E3A2B;
    --card-bg:rgba(10,14,12,0.74);
    --card-border:rgba(201,168,76,0.22);

    --serif:'Cormorant Garamond','Noto Serif KR',serif;
    --serif-kr:'Noto Serif KR','Cormorant Garamond',serif;
    --sans:'Manrope','Noto Sans KR',sans-serif;
    --sans-kr:'Noto Sans KR','Manrope',sans-serif;

    --ease:cubic-bezier(0.22,1,0.36,1);
  }

  *{box-sizing:border-box;margin:0;padding:0;}
  html,body{background:var(--bg);color:var(--text);}
  html{scroll-behavior:auto;}
  body{
    font-family:var(--sans-kr);
    font-weight:300;
    -webkit-font-smoothing:antialiased;
    -moz-osx-font-smoothing:grayscale;
    text-rendering:optimizeLegibility;
    /* Section 1 lives in fixed/position layers and stays pinned to the
       viewport.  Native vertical scrolling is kept available so that — once
       the cinematic sequence reaches its final anchor — the page can hand
       off to Section 2 (which slides up over the fixed stage at z-index 20).
       While inside the video sequence, scroll is held at 0 via JS. */
    overflow-x:hidden;
    overflow-y:auto;
    overscroll-behavior-y:none;
  }

  /* ── Video background ──────────────────────────────────── */
  #bg-video{
    position:fixed;
    inset:0;
    width:100vw;
    height:100vh;
    height:100dvh;
    object-fit:cover;
    z-index:1;
    background:#000;
    will-change:transform;
    pointer-events:none;
  }

  /* Atmospheric layers over the video */
  .vignette{
    position:fixed;inset:0;z-index:2;pointer-events:none;
    background:
      radial-gradient(ellipse at 50% 60%, rgba(0,0,0,0) 40%, rgba(0,0,0,0.55) 100%),
      linear-gradient(180deg, rgba(10,14,12,0.35) 0%, rgba(10,14,12,0) 18%, rgba(10,14,12,0) 70%, rgba(10,14,12,0.55) 100%);
  }
  .grain{
    position:fixed;inset:0;z-index:3;pointer-events:none;opacity:0.045;
    mix-blend-mode:overlay;
    background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  }

  /* Hairline frame — editorial museum-catalog feel */
  .frame{
    position:fixed;inset:18px;z-index:4;pointer-events:none;
    border:1px solid rgba(201,168,76,0.10);
  }
  .frame::before,.frame::after{
    content:"";position:absolute;background:var(--gold);opacity:0.5;
  }
  .frame::before{left:-1px;top:0;width:1px;height:34px;}
  .frame::after{right:-1px;bottom:0;width:1px;height:34px;}

  .corner-mark{
    position:fixed;z-index:5;font-family:var(--sans);
    font-size:10px;letter-spacing:0.32em;color:var(--text-sec);
    text-transform:uppercase;font-weight:500;pointer-events:none;
  }
  .corner-mark.tl{top:34px;left:38px;}
  .corner-mark.tr{top:34px;right:38px;text-align:right;}
  .corner-mark .dot{color:var(--gold);}

  /* Top-left brand logo — replaces the old "밸류브릿지 · VALUE BRIDGE" text.
     z-index 30 keeps it above the video, keywords, overlays AND Section 2
     (z-index 20) so it persists across the whole site as a fixed brand mark.
     The element is shrink-wrapped to the image, so only the logo itself is
     clickable — the surrounding corner area passes clicks straight through. */
  .corner-logo{
    position:fixed;
    top:32px;left:38px;
    z-index:30;
    display:inline-flex;
    line-height:0;
    opacity:0.85;
    cursor:pointer;
    transition:opacity 0.4s var(--ease),transform 0.4s var(--ease);
    -webkit-tap-highlight-color:transparent;
  }
  .corner-logo img{
    height:54px;width:auto;display:block;
    filter:drop-shadow(0 1px 3px rgba(0,0,0,0.45));
  }
  .corner-logo:hover{opacity:1;transform:translateY(-1px);}
  .corner-logo:focus-visible{outline:1px solid var(--gold-soft);outline-offset:6px;}
  .skip-intro{position:fixed;right:30px;bottom:30px;z-index:45;
    font-family:var(--sans);font-size:13.5px;font-weight:600;letter-spacing:.04em;
    color:var(--bg);background:var(--gold);border:none;border-radius:99px;
    padding:14px 24px;cursor:pointer;display:inline-flex;align-items:center;gap:7px;
    box-shadow:0 6px 26px rgba(0,0,0,.4);
    transition:transform .25s var(--ease),background .25s var(--ease),opacity .35s;}
  .skip-intro:hover{transform:translateY(-2px);background:#d9bd6a;}
  .skip-intro span{font-size:17px;line-height:1;}
  @media(max-width:600px){.skip-intro{right:16px;bottom:16px;padding:12px 20px;font-size:12.5px;}}

  /* ── Scroll track — placeholder; native scroll is disabled and chapters
       are now driven by discrete wheel/touch/key events (see script). ── */
  .scroll-track{
    position:relative;
    width:100%;
    height:0;
    z-index:1;
  }

  /* ── Readability scrim ─ subtle dark layer between video and text ── */
  .scrim{
    position:fixed;inset:0;z-index:6;pointer-events:none;
    background:
      radial-gradient(ellipse 82% 68% at 50% 56%,
        rgba(0,0,0,0.20) 0%,
        rgba(0,0,0,0.13) 38%,
        rgba(0,0,0,0.06) 65%,
        rgba(0,0,0,0) 95%),
      linear-gradient(180deg,
        rgba(0,0,0,0) 0%,
        rgba(0,0,0,0.05) 35%,
        rgba(0,0,0,0.09) 70%,
        rgba(0,0,0,0.03) 100%);
  }

  /* ── Overlay layer ─────────────────────────────────────── */
  .overlays{
    position:fixed;inset:0;z-index:10;pointer-events:none;
  }
  .overlay{
    position:absolute;inset:0;
    opacity:0;
    visibility:hidden;
    transition: opacity 1.0s var(--ease), visibility 0s linear 1.0s;
    will-change:opacity;
  }
  .overlay.is-active{
    opacity:1;
    visibility:visible;
    transition: opacity 1.0s var(--ease), visibility 0s linear 0s;
  }
  .overlay > .inner{
    position:absolute;inset:0;
    display:flex;
    padding:clamp(28px,6vw,96px);
  }

  /* === 1. Early micro label === */
  .ov-1 .inner{align-items:flex-end;justify-content:center;padding-bottom:clamp(80px,12vh,140px);}
  .ov-1 .mark{
    display:flex;flex-direction:column;align-items:center;gap:14px;
    transform:translateY(20px);
    transition:transform 1s var(--ease);
  }
  .overlay.is-active .ov-1-mark{transform:translateY(0);}
  .ov-1 .rule{
    width:36px;height:1px;background:var(--gold);opacity:0.7;
    transform-origin:left center;
  }
  .ov-1 .eyebrow{
    font-family:var(--sans);font-size:13px;font-weight:500;
    letter-spacing:0.42em;color:var(--text);text-transform:uppercase;
  }
  .ov-1 .since{
    font-family:var(--serif);font-style:italic;font-weight:300;
    font-size:15px;letter-spacing:0.08em;color:var(--text-sec);
  }
  .ov-1 .since b{color:var(--gold);font-style:normal;font-weight:400;}

  /* === 2. Quiet line === */
  .ov-2 .inner{align-items:center;justify-content:center;}
  .ov-2 .quiet{
    font-family:var(--serif-kr);font-weight:300;
    font-size:clamp(26px,3.6vw,42px);
    letter-spacing:0.05em;color:var(--text);
    text-align:center;
    line-height:1.5;
  }
  .ov-2 .quiet::before,
  .ov-2 .quiet::after{
    content:"";display:block;margin:18px auto;
    width:48px;height:1px;background:var(--gold);opacity:0.6;
  }

  /* === 3. Main headline === */
  .ov-3 .inner{
    flex-direction:column;
    justify-content:flex-end;
    align-items:flex-start;
    padding-bottom:clamp(80px,14vh,160px);
    padding-left:clamp(36px,8vw,120px);
    padding-right:clamp(36px,8vw,120px);
  }
  .ov-3 .eyebrow-stack{
    position:absolute;
    top:clamp(80px,14vh,150px);
    left:50%;
    transform:translateX(-50%);
    display:flex;flex-direction:column;align-items:center;
    gap:18px;
    text-align:center;
    pointer-events:none;
    isolation:isolate;
    padding:18px 40px;
  }
  /* soft dark backing so the line stays legible over bright frames */
  .ov-3 .eyebrow-stack::before{
    content:"";
    position:absolute;
    left:50%;top:50%;
    width:140%;height:230%;
    transform:translate(-50%,-50%);
    background:radial-gradient(ellipse,
      rgba(0,0,0,0.55) 0%,
      rgba(0,0,0,0.32) 45%,
      rgba(0,0,0,0.10) 75%,
      rgba(0,0,0,0) 100%);
    filter:blur(10px);
    z-index:-1;
    pointer-events:none;
  }
  .ov-3 .eyebrow-line-1{
    font-family:var(--sans-kr);
    font-size:15px;
    font-weight:500;
    letter-spacing:0.38em;
    color:var(--gold);
    text-indent:0.38em;
    text-shadow:0 1px 2px rgba(0,0,0,0.7), 0 2px 14px rgba(0,0,0,0.55);
  }
  .ov-3 .eyebrow-rule{
    width:1px;height:26px;background:var(--gold);opacity:0.7;
    box-shadow:0 0 8px rgba(0,0,0,0.5);
  }
  .ov-3 .eyebrow-line-2{
    font-family:var(--serif-kr);
    font-weight:300;
    font-size:18px;
    letter-spacing:0.06em;
    color:var(--text);
    text-shadow:0 1px 2px rgba(0,0,0,0.8), 0 2px 16px rgba(0,0,0,0.55);
  }
  .ov-3 .label-row{
    display:flex;align-items:center;gap:18px;margin-bottom:28px;
  }
  .ov-3 .label-row .rule{width:42px;height:1px;background:var(--gold);}
  .ov-3 .label-row span{
    font-family:var(--sans);font-size:11px;letter-spacing:0.42em;
    color:var(--gold);text-transform:uppercase;font-weight:500;
  }
  .headline{
    font-family:var(--serif-kr);
    font-weight:300;
    font-size:clamp(42px,7.4vw,104px);
    line-height:1.08;
    letter-spacing:-0.02em;
    color:var(--text);
    max-width:18ch;
    text-wrap:balance;
  }
  .headline .accent{color:var(--gold);font-style:normal;font-weight:400;}
  .ov-3 .sub{
    margin-top:30px;
    font-family:var(--sans-kr);font-weight:300;
    font-size:clamp(16px,1.35vw,20px);
    line-height:1.7;color:var(--text);
    max-width:46ch;
    letter-spacing:0.005em;
  }

  /* === Cards === */
  .card{
    pointer-events:auto;
    width:min(420px, 38vw);
    padding:34px 34px 38px;
    background:var(--card-bg);
    border:1px solid var(--card-border);
    backdrop-filter:blur(14px) saturate(120%);
    -webkit-backdrop-filter:blur(14px) saturate(120%);
    position:relative;
  }
  .card::before{
    content:"";position:absolute;left:0;right:0;top:0;height:1px;
    background:linear-gradient(90deg,transparent,var(--gold) 30%,var(--gold) 70%,transparent);
    transform:scaleX(0);transform-origin:left center;
    transition:transform 1.2s var(--ease) 0.05s;
  }
  .overlay.is-active .card::before{transform:scaleX(1);}
  .card .card-label{
    display:inline-flex;align-items:center;gap:10px;
    font-family:var(--sans);font-size:12px;letter-spacing:0.4em;
    color:var(--gold);text-transform:uppercase;font-weight:500;
    margin-bottom:24px;
  }
  .card .card-label::before{
    content:"";width:20px;height:1px;background:var(--gold);
  }
  .card .card-title{
    font-family:var(--serif-kr);font-weight:400;
    font-size:clamp(23px,2.1vw,32px);
    line-height:1.3;letter-spacing:-0.012em;
    color:var(--text);
    margin-bottom:20px;
  }
  .card .card-body{
    font-family:var(--sans-kr);font-weight:300;
    font-size:16.5px;line-height:1.78;
    color:var(--text-sec);letter-spacing:0.01em;
    /* 폭에 따라 자연스럽게 줄바꿈하되, 한글 단어는 중간에서 끊지 않음 */
    white-space:normal;
    word-break:keep-all;
    overflow-wrap:break-word;
  }

  .ov-card .inner{align-items:center;}
  /* ov-4, ov-5, ov-new, ov-6 all share the same lower-center placement */
  .ov-4 .inner,
  .ov-5 .inner,
  .ov-new .inner,
  .ov-6 .inner{
    justify-content:center;align-items:flex-end;
    padding-bottom:clamp(80px,12vh,140px);
  }
  /* Card widths bumped slightly so every defined-line break fits on
     a single line at all desktop viewport widths (down to ~768 px). */
  .ov-5 .card,
  .ov-new .card,
  .ov-6 .card{width:min(560px,60vw);}

  /* CONNECT card — enlarged for substance */
  .ov-4 .card{
    width:min(600px,58vw);
    padding:50px 54px 56px;
  }
  .ov-4 .card .card-title{
    font-size:clamp(29px,2.75vw,42px);
    line-height:1.26;
    margin-bottom:24px;
  }
  .ov-4 .card .card-body{
    font-size:18.5px;
    line-height:1.82;
  }
  .ov-4 .card .card-label{margin-bottom:28px;}

  /* === Final overlay === */
  /* Opacity + transform are driven by JS, tied to the final segment's
     progress (see updateFinalProgress in the script).  Override the
     inherited 1s CSS opacity transition so the JS controls the fade
     directly each frame for smooth, eased emergence. */
  .ov-final{
    transition: opacity 0s linear, visibility 0s linear;
    --final-rise: 22px;
    --final-scale: 0.982;
  }
  .ov-final.is-active{
    transition: opacity 0s linear, visibility 0s linear;
  }
  .ov-final .inner{
    flex-direction:column;align-items:center;justify-content:center;
    text-align:center;
    padding:clamp(28px,6vw,80px);
  }
  /* Large logo sits as a backdrop, anchored upper-center (~33vh minus 75px) */
  .ov-final .logo-wrap{
    position:absolute;
    left:50%;
    top:calc(33vh - 75px);
    width:clamp(300px, 52vw, 760px);
    pointer-events:none;
    z-index:0;
    opacity:0.92;                                              /* sharp, defined logo (was 0.65) */
    transform:translate(-50%, calc(-50% + var(--final-rise))) scale(var(--final-scale));
    transition:none;                                           /* parent opacity carries the fade */
  }
  .ov-final .logo-wrap img{
    width:100%;
    height:auto;
    display:block;
    /* Subtle near-black 1px outline to refine the PNG's edges without
       creating a visible heavy border. Two stacked drop-shadows with
       sub-pixel blur build a tight, even stroke around the artwork. */
    filter:
      drop-shadow(0 0 0.6px rgba(0,0,0,0.95))
      drop-shadow(0 0 0.6px rgba(0,0,0,0.7));
    image-rendering:auto;
  }
  /* Text + CTA always sit on top, fully readable */
  .ov-final .closing,
  .ov-final .closing-body,
  .ov-final .cta,
  .ov-final .final-micro{position:relative;z-index:2;}
  /* lower-center group — center sits around 70% from top */
  .ov-final .final-copy{
    position:absolute;
    left:50%;
    bottom:clamp(70px, 9vh, 140px);
    /* small coordinated rise that eases out as the final segment plays */
    transform: translateX(-50%) translateY(calc(var(--final-rise) * 0.5));
    width:min(820px, 90vw);
    text-align:center;
    z-index:2;
    isolation:isolate;
    padding:30px 40px;
    transition:none;
  }
  /* soft dark scrim behind the closing group — fully feathered, no visible edges */
  .ov-final .final-copy::before{
    content:"";
    position:absolute;
    left:50%;top:50%;
    width:160%;height:240%;
    transform:translate(-50%,-50%);
    background:radial-gradient(
      ellipse 50% 38% at center,
      rgba(0,0,0,0.52) 0%,
      rgba(0,0,0,0.36) 28%,
      rgba(0,0,0,0.18) 55%,
      rgba(0,0,0,0.06) 80%,
      rgba(0,0,0,0) 100%);
    z-index:-1;
    pointer-events:none;
  }
  .ov-final .closing{
    font-family:var(--serif-kr);font-weight:300;
    font-size:clamp(40px,6.6vw,92px);
    line-height:1.14;letter-spacing:-0.02em;
    color:var(--text);
    margin-bottom:30px;
    text-wrap:balance;
    text-shadow:0 2px 4px rgba(0,0,0,0.55), 0 4px 24px rgba(0,0,0,0.45);
    /* Headline removed visually; layout space preserved so the body copy
       below stays at its exact current position (desktop AND mobile, whatever
       the line-wrap of the original headline). */
    visibility:hidden;
  }
  .ov-final .closing-body{
    font-family:var(--sans-kr);font-weight:300;
    font-size:clamp(16px,1.4vw,21px);line-height:1.78;
    color:var(--text);
    margin:0 auto 46px;
    max-width:42ch;
    letter-spacing:0.01em;
    text-shadow:0 1px 2px rgba(0,0,0,0.65), 0 2px 14px rgba(0,0,0,0.4);
  }
  .cta{
    pointer-events:auto;
    display:inline-flex;align-items:center;gap:16px;
    font-family:var(--sans);font-size:14.5px;font-weight:500;
    letter-spacing:0.34em;text-transform:uppercase;
    color:var(--bg);background:var(--gold);
    padding:22px 44px;
    border:1px solid var(--gold);
    text-decoration:none;
    transition:background 0.4s var(--ease),color 0.4s var(--ease),transform 0.4s var(--ease),box-shadow 0.4s var(--ease);
    box-shadow:0 12px 42px rgba(0,0,0,0.45), 0 10px 36px rgba(201,168,76,0.22);
  }
  .cta:hover{
    background:transparent;color:var(--gold);
    transform:translateY(-2px);
    box-shadow:0 14px 44px rgba(201,168,76,0.28);
  }
  .cta .arrow{display:inline-block;transition:transform 0.4s var(--ease);}
  .cta:hover .arrow{transform:translateX(4px);}
  .ov-final .final-micro{
    margin-top:36px;
    font-family:var(--sans);font-size:12px;letter-spacing:0.36em;
    color:var(--text);text-transform:uppercase;font-weight:400;
    text-shadow:0 1px 2px rgba(0,0,0,0.7), 0 2px 12px rgba(0,0,0,0.45);
  }

  /* ── Business-info footer ─────────────────────────────── */
  .biz-footer{
    position:fixed;left:0;right:0;bottom:0;
    z-index:11;padding:18px 40px 22px;
    text-align:center;pointer-events:none;
    opacity:0;
    transition:opacity 0.8s var(--ease);
    background:linear-gradient(180deg, rgba(10,14,12,0) 0%, rgba(10,14,12,0.72) 60%, rgba(10,14,12,0.92) 100%);
  }
  .biz-footer.is-visible{opacity:1;}
  .biz-footer p{
    font-family:var(--sans-kr);font-weight:300;
    font-size:11.5px;line-height:1.7;color:var(--text-sec);
    letter-spacing:0.02em;
    max-width:1100px;margin:0 auto;
    word-break:keep-all;
  }
  .biz-footer .sep{margin:0 6px;color:rgba(154,163,154,0.45);}
  /* 링크는 푸터가 '보일 때만' 클릭 가능 — 숨김(opacity:0) 상태에선 투명 링크가
     스크롤 힌트 뒤에 깔려 잘못 눌리던(메일 앱 열림) 문제 방지 */
  .biz-footer a{color:var(--text-sec);text-decoration:none;border-bottom:1px solid rgba(154,163,154,0.25);}
  .biz-footer.is-visible a{pointer-events:auto;}
  .biz-footer a:hover{color:var(--gold);border-color:var(--gold-soft);}

  /* ── Scroll hint (각 앵커마다 재등장 — "아래로 스크롤" 안내) ─────── */
  .scroll-hint{
    position:fixed;bottom:32px;left:50%;transform:translateX(-50%);
    z-index:12;display:flex;flex-direction:column;align-items:center;gap:8px;
    font-family:var(--sans-kr);font-size:14px;letter-spacing:0.2em;font-weight:600;
    color:rgba(255,251,242,0.98);
    text-shadow:0 2px 16px rgba(0,0,0,0.72),0 0 24px rgba(0,0,0,0.45);
    transition:opacity 0.5s var(--ease);
    pointer-events:none;
    animation:vbHintBob 1.5s var(--ease) infinite;
  }
  /* 아래를 가리키는 v자 화살표(크게·강하게 통통 튀어 시선 유도) */
  .scroll-hint .chev{
    width:14px;height:14px;
    border-right:2px solid var(--gold);border-bottom:2px solid var(--gold);
    transform:rotate(45deg);
    filter:drop-shadow(0 2px 8px rgba(0,0,0,0.6));
  }
  @keyframes vbHintBob{
    0%,100%{ transform:translateX(-50%) translateY(0); }
    50%{    transform:translateX(-50%) translateY(9px); }
  }
  .scroll-hint.is-hidden{opacity:0;}

  /* ── Loader ──────────────────────────────────────────── */
  .loader{
    position:fixed;inset:0;z-index:9999;background:var(--bg);
    display:flex;align-items:center;justify-content:center;flex-direction:column;gap:24px;
    transition:opacity 0.8s var(--ease),visibility 0s linear 0.8s;
  }
  .loader.is-done{opacity:0;visibility:hidden;}
  .loader .brand{
    font-family:var(--serif);font-style:italic;font-weight:300;
    font-size:22px;letter-spacing:0.08em;color:var(--text);
  }
  .loader .brand b{font-style:normal;font-weight:400;color:var(--gold);}
  .loader .bar{
    width:160px;height:1px;background:rgba(245,242,230,0.12);position:relative;overflow:hidden;
  }
  .loader .bar::after{
    content:"";position:absolute;left:0;top:0;height:100%;background:var(--gold);
    width:0%;animation:loaderBar 2.2s var(--ease) infinite;
  }
  @keyframes loaderBar{
    0%{width:0%;left:0;}
    50%{width:100%;left:0;}
    100%{width:0%;left:100%;}
  }

  /* ── Mobile ──────────────────────────────────────────── */
  @media (max-width: 768px){
    .scroll-track{height:0;}
    .frame{inset:10px;}
    .corner-mark{font-size:8.5px;letter-spacing:0.28em;}
    .corner-mark.tr{top:22px;right:22px;}
    .corner-logo{top:20px;left:22px;}
    .corner-logo img{height:40px;}

    .ov-1 .inner{padding-bottom:90px;}
    .ov-2 .quiet{font-size:clamp(22px,5.6vw,28px);}
    .ov-3 .inner{
      align-items:flex-start;justify-content:flex-end;
      padding-top:14vh;padding-bottom:14vh;
      padding-left:28px;padding-right:28px;
    }
    .ov-3 .eyebrow-stack{top:clamp(54px,8vh,100px);padding:14px 22px;}
    .ov-3 .eyebrow-line-1{font-size:12.5px;letter-spacing:0.32em;}
    .ov-3 .eyebrow-rule{height:20px;}
    .ov-3 .eyebrow-line-2{font-size:15px;}
    .headline{font-size:clamp(36px,10vw,52px);max-width:14ch;}
    .ov-3 .sub{font-size:15px;}

    /* Mobile: cards widened + body font scaled down so each defined-line
       break fits on a single line all the way down to ~320px viewports. */
    .card{width:calc(100vw - 24px); padding:30px 22px 32px;}
    .ov-4 .inner,
    .ov-5 .inner,
    .ov-new .inner,
    .ov-6 .inner{
      justify-content:center;align-items:flex-end;
      padding:14vh 28px 14vh;
    }
    .ov-5 .card,
    .ov-new .card,
    .ov-6 .card{width:calc(100vw - 24px);}
    .ov-4 .card{width:calc(100vw - 24px);padding:34px 26px 38px;}
    .ov-4 .card .card-title{font-size:clamp(22px,5.8vw,28px);}
    .ov-4 .card .card-body{font-size:clamp(12px,3.7vw,15.5px);line-height:1.78;}
    .card .card-body{font-size:clamp(11px,3.4vw,14.5px);line-height:1.78;}

    .ov-final .final-copy{
      bottom:clamp(40px,6vh,80px);
      width:calc(100vw - 28px);
      padding:22px 22px;
    }
    .ov-final .closing{font-size:clamp(32px,8.4vw,48px);margin-bottom:22px;}
    .ov-final .closing-body{font-size:15.5px;margin-bottom:34px;}
    .ov-final .final-micro{font-size:11px;margin-top:28px;}
    .cta{padding:18px 30px;font-size:12.5px;letter-spacing:0.3em;}
    .biz-footer{padding:14px 18px 18px;}
    .biz-footer p{font-size:10.5px;letter-spacing:0.015em;}
  }

  @media (max-width: 480px){
    /* 모바일에서도 안내 노출 — 폰은 정지화면 오인이 가장 잦아 힌트가 더 중요 */
    .scroll-hint{bottom:24px;font-size:13px;letter-spacing:0.16em;}
  }

  @media (prefers-reduced-motion: reduce){
    .overlay{transition:opacity 0.001s linear;}
    *{transition-duration:0.001s !important;animation-duration:0.001s !important;}
  }

  /* ── Floating keywords ─────────────────────────────── */
  .kw-layer{position:fixed;inset:0;z-index:8;pointer-events:none;}
  .kw{
    position:absolute;top:50%;
    font-family:var(--serif-kr);font-weight:300;
    font-size:clamp(1.8rem,2.4vw,2.6rem);
    letter-spacing:0.05em;
    /* soft off-white carrying a subtle warm/gold tint */
    color:rgba(246,239,218,0.93);
    text-shadow:0 2px 18px rgba(0,0,0,0.78),0 0 40px rgba(0,0,0,0.5),
                0 0 26px rgba(201,168,76,0.12);
    opacity:0;will-change:opacity,transform;
  }
  .kw.kw-left  {left:33%;}
  .kw.kw-right {left:67%;}
  .kw.kw-center{left:50%;}

  /* ── Segment 4 transition copy ──────────────────────── */
  .seg4-copy{
    position:fixed;top:50%;left:50%;
    z-index:9;pointer-events:none;
    text-align:center;
    opacity:0;will-change:opacity,transform;
  }
  .seg4-copy p{
    font-family:var(--serif-kr);font-weight:300;
    font-size:clamp(1.5rem,2.3vw,2.3rem);
    line-height:1.7;letter-spacing:0.03em;
    color:rgba(245,242,230,0.95);
    text-shadow:0 2px 20px rgba(0,0,0,0.78),0 4px 44px rgba(0,0,0,0.52);
  }

  /* ── White flash ─────────────────────────────────────── */
  /* z-index 9: above the video/scrim, BELOW the final-screen logo + text
     (the .overlays layer is z-index 10) — so the wash covers the doorway
     cut, then dissolves to reveal the sunrise + logo emerging above it. */
  .white-flash{
    position:fixed;inset:0;z-index:9;
    background:radial-gradient(ellipse 85% 85% at 50% 50%,
      rgba(255,250,235,1)    0%,
      rgba(255,248,228,0.82) 45%,
      rgba(255,245,218,0.50) 100%);
    opacity:0;pointer-events:none;
  }

  @media(max-width:768px){
    .kw{font-size:clamp(1.4rem,5.5vw,2rem);}
    .kw.kw-left {left:26%;}
    .kw.kw-right{left:74%;}
    .seg4-copy p{font-size:clamp(1.2rem,4.5vw,1.8rem);}
  }

  /* ═══════════════════════════════════════════════════════
   * "더 알아보기 ↓" — secondary ghost button on the final
   * screen.  Thin gold outline, no fill, visually quieter
   * than the gold-filled CTA.  Sits at the top of the lower
   * copy group, directly under the logo area.
   * ═══════════════════════════════════════════════════════ */
  .ov-final .more-link{
    pointer-events:auto;
    display:inline-flex;align-items:center;gap:10px;
    font-family:var(--sans);font-size:12.5px;font-weight:500;
    letter-spacing:0.26em;text-transform:uppercase;
    color:var(--gold);background:transparent;
    padding:13px 30px;
    border:1px solid var(--gold-soft);
    text-decoration:none;
    margin-bottom:32px;
    transition:border-color .35s var(--ease),background .35s var(--ease),
               transform .35s var(--ease),color .35s var(--ease);
    text-shadow:0 1px 8px rgba(0,0,0,0.5);
  }
  .ov-final .more-link:hover{
    border-color:var(--gold);
    background:rgba(201,168,76,0.08);
    transform:translateY(-2px);
  }
  .ov-final .more-link .more-arrow{
    display:inline-block;transition:transform .35s var(--ease);
  }
  .ov-final .more-link:hover .more-arrow{transform:translateY(3px);}

  /* ═══════════════════════════════════════════════════════
   * SECTION 2 — "더 알아보기"
   * Restrained museum-catalog / documentary tone.  Sits in
   * normal flow below a 100vh spacer (margin-top) so the
   * fixed cinematic stage shows through first; at z-index 20
   * it slides up over Section 1 as the user scrolls down.
   * Skeleton styling for structure review.
   * ═══════════════════════════════════════════════════════ */
  #section2{
    position:relative;
    z-index:20;
    margin-top:100vh;
    background:#FAF8F2;
    color:#1F2A24;
    --s2-gold:#C9A84C;
    --s2-text:#1F2A24;
    --s2-muted:#3D4A42;
    --s2-line:rgba(168,132,46,0.30);
    --s2-line-soft:rgba(168,132,46,0.12);
  }
  .s2-wrap{
    max-width:1080px;
    margin-inline:auto;
    padding-inline:clamp(22px,6vw,72px);
  }
  .s2-block{ padding-block:clamp(58px,9vh,118px); }
  .s2-block + .s2-block{ border-top:1px solid var(--s2-line); }

  .s2-eyebrow{
    font-family:var(--sans);
    font-size:11px;font-weight:500;letter-spacing:0.34em;
    text-transform:uppercase;color:var(--s2-gold);
    margin-bottom:24px;
  }
  .s2-title{
    font-family:var(--serif-kr);font-weight:400;
    font-size:clamp(28px,4vw,52px);line-height:1.18;
    letter-spacing:-0.012em;color:var(--s2-text);
    margin-bottom:18px;
  }
  .s2-intro{
    font-family:var(--sans-kr);font-weight:400;
    font-size:clamp(15.5px,1.6vw,18px);line-height:1.82;
    color:#1A1A1A;letter-spacing:0.01em;
    /* 한글은 전각(영문 2배 폭)이라 ch 대신 em 기준으로 넓혀, 넓은 화면에선 한 줄로 */
    max-width:46em;margin-bottom:clamp(42px,6vh,72px);
    word-break:keep-all;
  }

  /* A · People */
  .s2-people{
    display:grid;grid-template-columns:repeat(3,1fr);
    gap:clamp(28px,4vw,56px);
  }
  .person-photo{
    position:relative;aspect-ratio:4/3;width:100%;
    background:linear-gradient(135deg,#FFFFFF 0%,#FBF8F1 55%,#F4F0E5 100%);border:1px solid rgba(168,132,46,0.18);
    border:1px solid var(--s2-line);
    margin-bottom:24px;filter:grayscale(1);
  }
  img.person-photo{
    object-fit:cover;object-position:center 22%;display:block;
  }
  .person-photo span{
    position:absolute;left:14px;bottom:12px;
    font-family:var(--sans);font-size:9.5px;letter-spacing:0.3em;
    text-transform:uppercase;color:var(--s2-muted);
  }
  .person-name{
    font-family:var(--serif-kr);font-weight:500;
    font-size:clamp(20px,2.2vw,26px);color:var(--s2-text);
    margin-bottom:8px;
  }
  .person-role{
    font-family:var(--sans);font-size:11px;letter-spacing:0.2em;
    text-transform:uppercase;color:var(--s2-gold);margin-bottom:14px;
  }
  .person-desc{
    font-family:var(--sans-kr);font-weight:300;
    font-size:14.5px;line-height:1.75;color:var(--s2-muted);
    word-break:keep-all;
  }

  /* B · Roadmap */
  .road-entry{
    display:grid;grid-template-columns:auto 1fr;
    gap:clamp(24px,4vw,56px);align-items:start;
    padding-block:clamp(34px,5vh,54px);
  }
  .road-entry:first-child{padding-top:0;}
  .road-entry + .road-entry{ border-top:1px solid var(--s2-line); }
  .road-num{
    font-family:var(--serif);font-weight:400;
    font-size:clamp(42px,6vw,84px);line-height:0.86;
    color:var(--s2-gold);opacity:0.85;
    font-variant-numeric:tabular-nums;
  }
  .road-phase{
    font-family:var(--serif-kr);font-weight:500;
    font-size:clamp(20px,2.4vw,30px);color:var(--s2-text);
    letter-spacing:0.005em;margin-bottom:14px;
  }
  .road-sum{
    font-family:var(--sans-kr);font-weight:400;
    font-size:clamp(15px,1.6vw,18px);line-height:1.7;
    color:var(--s2-text);margin-bottom:12px;word-break:keep-all;
  }
  .road-detail{
    font-family:var(--sans-kr);font-weight:300;
    font-size:14.5px;line-height:1.8;color:var(--s2-muted);
    max-width:56ch;word-break:keep-all;
  }

  /* ── 비전 단계 진행 상태 (완료 / 진행 중 / 예정) ── */
  .road-status{
    display:inline-flex;align-items:center;gap:7px;
    font-family:var(--sans);font-size:10px;font-weight:600;
    letter-spacing:.16em;text-transform:uppercase;
    padding:4px 12px;border-radius:20px;margin-bottom:16px;
  }
  .road-status::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;}
  /* 흐림은 큰 숫자에만 — 본문 글자는 모두 또렷하게 유지(가독성 우선) */
  .road-entry.is-done .road-num{opacity:.42;}
  .road-entry.is-done .road-status{color:#F2EEE2;background:var(--deep-green);border:1px solid var(--deep-green);}
  .road-entry.is-now .road-num{opacity:1;}
  .road-entry.is-now .road-phase{color:var(--s2-gold);}
  .road-entry.is-now .road-status{color:#1F2A24;background:var(--s2-gold);border:1px solid var(--s2-gold);}
  .road-entry.is-now .road-status::before{background:#1F2A24;}
  @media (prefers-reduced-motion:no-preference){
    .road-entry.is-now .road-status::before{animation:rvpulse 2s ease-out infinite;}
  }
  .road-entry.is-next .road-num{opacity:.55;}
  .road-entry.is-next .road-status{color:#9C7A1E;border:1px solid var(--gold-soft);}

  /* C · Partners */
  .s2-partners{
    display:grid;grid-template-columns:repeat(3,1fr);
    gap:clamp(28px,4vw,56px);
  }
  .partner-col h4{
    font-family:var(--serif-kr);font-weight:500;
    font-size:clamp(18px,2vw,22px);color:var(--s2-text);
    margin-bottom:8px;
  }
  .partner-col .pc-en{
    font-family:var(--sans);font-size:10.5px;letter-spacing:0.24em;
    text-transform:uppercase;color:var(--s2-gold);margin-bottom:26px;
  }
  .partner-col ul{list-style:none;}
  .partner-col li{
    font-family:var(--sans-kr);font-weight:300;
    font-size:15px;line-height:1.6;color:var(--s2-muted);
    padding-block:13px;
    border-bottom:1px solid var(--s2-line-soft);
    word-break:keep-all;
  }

  /* Footer */
  .s2-footer{
    text-align:center;
    padding:clamp(50px,8vh,92px) clamp(22px,6vw,72px) clamp(42px,6vh,72px);
  }
  .s2-footer .hair{
    width:100%;max-width:680px;height:1px;
    margin:0 auto clamp(32px,5vh,48px);
    background:linear-gradient(90deg,transparent,var(--s2-line),transparent);
  }
  .s2-footer p{
    font-family:var(--sans-kr);font-weight:300;
    font-size:12px;line-height:1.95;color:var(--s2-muted);
    letter-spacing:0.015em;max-width:860px;margin:0 auto 28px;
    word-break:keep-all;
  }
  .s2-footer .sep{color:rgba(138,139,133,0.4);margin:0 7px;}
  .s2-footer a[href^="mailto"]{color:var(--s2-muted);text-decoration:none;
    border-bottom:1px solid rgba(138,139,133,0.3);}
  .s2-footer a[href^="mailto"]:hover{color:var(--s2-gold);border-color:var(--gold-soft);}
  .s2-footer .back-top{
    display:inline-block;
    font-family:var(--sans);font-size:11px;letter-spacing:0.28em;
    text-transform:uppercase;color:var(--s2-gold);
    text-decoration:none;padding:10px 6px;
    border-bottom:1px solid transparent;
    transition:border-color .3s var(--ease);
  }
  .s2-footer .back-top:hover{border-color:var(--s2-gold);}

  @media (max-width:768px){
    .s2-people{grid-template-columns:1fr;gap:clamp(34px,6vh,48px);}
    .s2-partners{grid-template-columns:1fr;gap:0;}
    .partner-col{padding-block:clamp(30px,5vh,42px);}
    .partner-col + .partner-col{border-top:1px solid var(--s2-line);}
    .road-entry{grid-template-columns:1fr;gap:14px;}
    .road-num{font-size:clamp(38px,13vw,58px);line-height:1;}
    .ov-final .more-link{font-size:11.5px;letter-spacing:0.22em;padding:12px 24px;margin-bottom:26px;}
  }

  /* ═══ ADD · Value Structure (가치 구조 / How it works) ═══ */
  .vbv-flow{
    display:flex;align-items:stretch;justify-content:center;gap:0;
    margin-bottom:clamp(46px,7vh,78px);
  }
  .flow-node{
    flex:1 1 0;min-width:0;display:flex;flex-direction:column;
    padding:clamp(26px,3vw,38px) clamp(18px,2.2vw,30px);
    background:linear-gradient(160deg,rgba(201,168,76,0.07),#FFFFFF);
    border:1px solid var(--s2-line);text-align:center;
  }
  .flow-node.is-bridge{
    background:linear-gradient(160deg,rgba(201,168,76,0.14),rgba(30,58,43,0.30));
    border-color:var(--gold-soft);
  }
  .flow-role{
    font-family:var(--sans);font-size:10.5px;font-weight:500;
    letter-spacing:0.26em;text-transform:uppercase;color:var(--s2-gold);
    margin-bottom:14px;
  }
  .flow-name{
    font-family:var(--serif-kr);font-weight:500;
    font-size:clamp(19px,2.1vw,26px);color:var(--s2-text);margin-bottom:12px;
  }
  .flow-desc{
    font-family:var(--sans-kr);font-weight:300;font-size:13.5px;line-height:1.7;
    color:var(--s2-muted);word-break:keep-all;
  }
  .flow-link{
    flex:0 0 clamp(28px,4vw,64px);display:flex;align-items:center;
    justify-content:center;color:var(--s2-gold);font-size:18px;opacity:0.7;
  }
  .vbv-caption{
    text-align:center;font-family:var(--serif-kr);font-weight:300;
    font-size:clamp(15px,1.7vw,20px);color:var(--s2-text);letter-spacing:0.01em;
    margin-bottom:clamp(44px,7vh,74px);word-break:keep-all;
  }
  .vbv-steps{
    display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,3vw,44px);
    border-top:1px solid var(--s2-line);padding-top:clamp(38px,5vh,58px);
  }
  .vbv-step .step-n{
    font-family:var(--serif);font-weight:400;font-size:clamp(30px,3.4vw,46px);
    color:var(--s2-gold);opacity:0.85;line-height:1;margin-bottom:16px;
    font-variant-numeric:tabular-nums;
  }
  .vbv-step .step-t{
    font-family:var(--serif-kr);font-weight:500;font-size:clamp(17px,1.9vw,21px);
    color:var(--s2-text);margin-bottom:10px;
  }
  .vbv-step .step-d{
    font-family:var(--sans-kr);font-weight:300;font-size:13.5px;line-height:1.7;
    color:var(--s2-muted);word-break:keep-all;
  }

  /* ═══ ADD · Join / Contact (함께하기) ═══ */
  .join-lead{
    font-family:var(--sans-kr);font-weight:300;font-size:14.5px;line-height:1.8;
    color:var(--s2-muted);max-width:52ch;margin-bottom:clamp(34px,5vh,52px);
    word-break:keep-all;
  }
  .join-form{
    display:grid;grid-template-columns:1fr 1fr;gap:clamp(18px,2vw,26px);
    max-width:760px;
  }
  .join-field{display:flex;flex-direction:column;gap:9px;}
  .join-field.full{grid-column:1 / -1;}
  .join-field label{
    font-family:var(--sans);font-size:10.5px;letter-spacing:0.22em;
    text-transform:uppercase;color:var(--s2-gold);
  }
  .join-field input,.join-field select,.join-field textarea{
    font-family:var(--sans-kr);font-weight:300;font-size:15px;color:var(--s2-text);
    background:#FFFFFF;border:1px solid var(--s2-line);
    padding:13px 15px;border-radius:0;outline:none;width:100%;
    transition:border-color .3s var(--ease),background .3s var(--ease);
  }
  .join-field textarea{resize:vertical;min-height:108px;line-height:1.7;}
  .join-field input::placeholder,.join-field textarea::placeholder{color:rgba(138,139,133,0.55);}
  .join-field input:focus,.join-field select:focus,.join-field textarea:focus{
    border-color:var(--gold-soft);background:rgba(30,58,43,0.18);
  }
  .join-field select{
    appearance:none;-webkit-appearance:none;cursor:pointer;
    background-image:linear-gradient(45deg,transparent 50%,var(--s2-gold) 50%),
                     linear-gradient(135deg,var(--s2-gold) 50%,transparent 50%);
    background-position:calc(100% - 19px) 20px,calc(100% - 13px) 20px;
    background-size:6px 6px,6px 6px;background-repeat:no-repeat;
  }
  .join-field select option{background:#FFFFFF;color:#1F2A24;}
  .join-submit{
    grid-column:1 / -1;justify-self:start;
    font-family:var(--sans);font-size:12px;font-weight:500;letter-spacing:0.22em;
    text-transform:uppercase;color:var(--bg);
    background:var(--s2-gold);border:1px solid var(--s2-gold);
    padding:15px 40px;cursor:pointer;margin-top:6px;
    transition:opacity .3s var(--ease),transform .3s var(--ease);
  }
  .join-submit:hover{opacity:0.88;}
  .join-submit:active{transform:translateY(1px);}
  .join-submit:disabled{opacity:.4;cursor:not-allowed;}
  .join-submit:disabled:hover{opacity:.4;}
  /* 개인정보 동의 체크박스 */
  .join-consent{grid-column:1 / -1;display:flex;align-items:flex-start;gap:10px;cursor:pointer;
    font-family:var(--sans-kr);font-weight:300;font-size:13.5px;line-height:1.6;
    color:var(--s2-muted);margin-top:4px;}
  .join-consent input{width:18px;height:18px;margin-top:1px;flex:0 0 auto;
    accent-color:var(--s2-gold);cursor:pointer;}
  .join-consent b{font-weight:500;color:var(--s2-text);}
  .join-msg{grid-column:1 / -1;font-family:var(--sans-kr);font-weight:400;font-size:13.5px;
    color:#1E3A2B;margin-top:2px;}
  .join-alt{
    grid-column:1 / -1;display:flex;flex-wrap:wrap;gap:18px 24px;align-items:center;
    margin-top:8px;
  }
  .join-alt .ja-lab{
    font-family:var(--sans);font-size:10.5px;letter-spacing:0.2em;
    text-transform:uppercase;color:var(--s2-muted);
  }
  .join-alt a{
    font-family:var(--sans-kr);font-weight:300;font-size:13.5px;color:var(--s2-muted);
    text-decoration:none;border-bottom:1px solid rgba(138,139,133,0.3);padding-bottom:2px;
    transition:color .3s var(--ease),border-color .3s var(--ease);
  }
  .join-alt a:hover{color:var(--s2-gold);border-color:var(--gold-soft);}
  .join-note{
    grid-column:1 / -1;font-family:var(--sans-kr);font-weight:300;font-size:11.5px;
    line-height:1.65;color:rgba(138,139,133,0.7);margin-top:4px;word-break:keep-all;
  }

  @media (max-width:768px){
    .vbv-flow{flex-direction:column;gap:0;}
    .flow-link{flex-basis:auto;padding:14px 0;transform:rotate(90deg);}
    .vbv-steps{grid-template-columns:1fr;gap:clamp(26px,4vh,38px);}
    .vbv-step{border-top:1px solid var(--s2-line-soft);padding-top:24px;}
    .vbv-step:first-child{border-top:none;padding-top:0;}
    .join-form{grid-template-columns:1fr;}
  }

  /* ═══ APP SHELL — Section 2 재구성 (좌측 메뉴 + 패널) ═══ */
  #section2.vbv-app{
    position:fixed;inset:0;margin-top:0;z-index:9000;display:none;
    background:#FAF8F2;color:#1F2A24;
    --s2-gold:#C9A84C;--s2-text:#1F2A24;--s2-muted:#3D4A42;
    --s2-line:rgba(168,132,46,0.30);--s2-line-soft:rgba(168,132,46,0.12);
  }
  #section2.vbv-app.is-open{display:flex;animation:appfade .5s var(--ease);}
  @keyframes appfade{from{opacity:0}to{opacity:1}}

  .app-nav{background:linear-gradient(180deg,#21402F 0%,#16301F 100%);border-right:1px solid rgba(201,168,76,0.22);--s2-text:#F2EEE2;--s2-muted:rgba(242,238,226,0.66);
    flex:0 0 clamp(210px,18vw,276px);display:flex;flex-direction:column;
    padding:clamp(28px,3.4vh,46px) clamp(20px,1.8vw,32px);
    border-right:1px solid var(--s2-line);
  }
  .app-brand{display:block;margin-bottom:clamp(34px,5vh,58px);}
  .app-brand img{height:54px;width:auto;opacity:.92;}
  .app-menu{display:flex;flex-direction:column;gap:3px;}
  .app-link{
    display:grid;grid-template-columns:auto 1fr;align-items:baseline;column-gap:12px;
    padding:13px 12px;cursor:pointer;text-decoration:none;
    border-left:2px solid transparent;transition:background .3s var(--ease),border-color .3s var(--ease);
  }
  .app-link .lk-no{font-family:var(--sans);font-size:10px;letter-spacing:.2em;color:var(--s2-muted);}
  .app-link .lk-ko{font-family:var(--serif-kr);font-weight:400;font-size:16px;color:var(--s2-text);word-break:keep-all;}
  .app-link .lk-en{grid-column:2;font-family:var(--sans);font-size:9.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--s2-muted);margin-top:3px;}
  .app-link:hover{background:rgba(201,168,76,0.05);border-left-color:var(--gold-soft);}
  .app-link.is-active{background:transparent;border-left-color:var(--s2-gold);}
  .app-link.is-active .lk-ko{color:var(--s2-gold);}

  /* 로그인 상태 분기 메뉴 */
  .app-auth{margin-top:18px;padding-top:16px;border-top:1px solid rgba(201,168,76,0.18);display:flex;flex-direction:column;gap:4px;}
  .auth-link{display:flex;flex-direction:column;padding:9px 14px;text-decoration:none;border-left:2px solid transparent;transition:background .25s,border-color .25s;}
  .auth-link .al-ko{font-family:var(--serif-kr);font-weight:500;font-size:15.5px;color:var(--s2-text);word-break:keep-all;}
  .auth-link .al-en{font-family:var(--sans);font-size:9.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--s2-gold);opacity:.8;margin-top:3px;}
  #authName{text-transform:none;letter-spacing:.01em;font-size:11.5px;font-family:var(--sans-kr);font-weight:400;color:var(--s2-text);opacity:.85;}
  .auth-link:hover{background:rgba(201,168,76,0.05);border-left-color:var(--gold-soft);}
  .auth-link:hover .al-ko{color:var(--s2-text);}
  .auth-link.auth-primary .al-ko{color:var(--s2-gold);}
  .app-nav-foot{margin-top:auto;padding-top:24px;}
  .app-nav-foot p{font-family:var(--sans-kr);font-weight:300;font-size:11px;line-height:1.8;color:rgba(138,139,133,.7);}
  .app-nav-foot a{display:inline-block;margin-top:11px;font-family:var(--sans-kr);font-weight:400;font-size:11px;letter-spacing:.02em;color:rgba(238,234,222,.66);text-decoration:none;border-bottom:1px solid rgba(201,168,76,.4);padding-bottom:2px;transition:color .25s var(--ease),border-color .25s var(--ease);}
  .app-nav-foot a:hover{color:var(--s2-gold);border-color:var(--gold-soft);}

  .app-main{flex:1 1 auto;min-width:0;position:relative;overflow-y:auto;}
  .app-panel{display:none;min-height:100%;padding:clamp(42px,6.5vh,86px) clamp(26px,5vw,92px);}
  .app-panel.is-active{display:block;animation:panelin .45s var(--ease);}
  @keyframes panelin{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
  .app-inner{max-width:1060px;margin-inline:auto;}
  .app-panel .s2-intro{margin-bottom:clamp(34px,5vh,56px);}

  /* 마인드맵 */
  .mindmap{width:100%;max-width:660px;height:auto;display:block;margin:6px auto clamp(28px,4vh,46px);}
  .mm-line{stroke:var(--gold-line);stroke-width:1.4;}
  .mm-line.is-on{stroke:var(--gold-soft);stroke-width:1.8;}
  .mm-node .mm-hit{fill:rgba(255,255,255,0.92);stroke:var(--s2-gold);stroke-width:1.8;stroke-opacity:0;}
  .mm-node.is-on .mm-hit{fill:rgba(201,168,76,.14);stroke:var(--s2-gold);stroke-width:2;}
  .mm-line2{stroke:var(--gold-line);stroke-width:1;opacity:.42;}
  .mm-sub .mm-subhit{fill:rgba(255,255,255,0.85);stroke:rgba(201,168,76,.28);stroke-width:1.2;}
  .mm-sub{cursor:pointer;}
  .mm-sub .mm-subhit{transition:stroke .25s var(--ease),fill .25s var(--ease);}
  .mm-sub:hover .mm-subhit,.mm-sub:focus-visible .mm-subhit{stroke:var(--gold-soft);fill:rgba(201,168,76,.10);outline:none;}
  .mm-sub:focus{outline:none;}
  .mm-sub .mm-subname{font-family:var(--serif-kr);font-weight:400;fill:#3C463F;paint-order:stroke;stroke:rgba(255,255,255,0.85);stroke-width:2px;stroke-linejoin:round;}
  .mm-center circle{fill:rgba(30,58,43,0.85);stroke:var(--gold-soft);stroke-width:2;}
  .mm-name{font-family:var(--serif-kr);font-weight:500;fill:var(--s2-text);}
  .mm-node.is-off .mm-name{fill:var(--s2-muted);}
  .mm-status{font-family:var(--sans);letter-spacing:.16em;text-transform:uppercase;}
  .mm-node.is-on .mm-status{fill:var(--s2-gold);}
  .mm-node.is-off .mm-status{fill:rgba(138,139,133,.7);}
  .mm-cn-main{font-family:var(--serif);font-weight:400;fill:var(--s2-gold);}
  .mm-cn-sub{font-family:var(--sans);letter-spacing:.3em;fill:var(--s2-text);}
  .mm-node .mm-pulse{fill:none;stroke:var(--s2-gold);stroke-width:1.6;pointer-events:none;transform-box:fill-box;transform-origin:center;}
  @media (prefers-reduced-motion:no-preference){
    .mm-pulse{animation:mmpulse 3.2s ease-out infinite;}
  }
  @keyframes mmpulse{0%{transform:scale(1);opacity:.55}70%{transform:scale(1.5);opacity:0}100%{opacity:0}}
  @media (prefers-reduced-motion:no-preference){
    .mm-node .mm-hit{animation:mmBlink 4.8s ease-in-out infinite;}
    .mm-node:nth-of-type(2) .mm-hit{animation-delay:.95s;}
    .mm-node:nth-of-type(3) .mm-hit{animation-delay:1.9s;}
    .mm-node:nth-of-type(4) .mm-hit{animation-delay:2.85s;}
    .mm-node:nth-of-type(5) .mm-hit{animation-delay:3.8s;}
  }
  @media (prefers-reduced-motion:reduce){
    .mm-node .mm-hit{stroke-opacity:.3;}
  }
  @keyframes mmBlink{0%,100%{stroke-opacity:0;}50%{stroke-opacity:.95;}}
  /* ═══ 마인드맵 v2 (궤도형) — 데모 mindmap-v2 이식 ═══ */
  .mindmap{overflow:visible;}
  .mindmap .orbit{fill:none;stroke:rgba(201,168,76,.34);stroke-width:1.1;stroke-dasharray:2 7;stroke-linecap:round;opacity:0;}
  .mindmap .orbit-out{stroke-dasharray:2 9;opacity:0;}
  .mindmap .spoke{stroke:#C9A84C;stroke-width:1.5;opacity:0;}
  .mindmap .spoke-sub{stroke:rgba(201,168,76,.34);stroke-width:1;}
  .mindmap .node{cursor:pointer;}
  .mindmap .node .dot{fill:#FFFFFF;filter:url(#nodeShadow);transition:fill .28s var(--ease),transform .28s var(--ease);transform-box:fill-box;transform-origin:center;}
  .mindmap .node .lbl{font-family:var(--serif-kr);fill:#1A1A1A;pointer-events:none;transition:fill .28s var(--ease);}
  .mindmap .node.main .dot{stroke:#C9A84C;stroke-width:1.6;}
  .mindmap .node.main .lbl{font-weight:500;}
  .mindmap .node.sub .dot{stroke:rgba(201,168,76,.40);stroke-width:1.2;}
  .mindmap .node.sub .lbl{font-weight:400;}
  .mindmap .node:hover .dot,.mindmap .node:focus-visible .dot{fill:#FBF4DE;stroke:#C9A84C;stroke-width:2.2;transform:scale(1.07);}
  .mindmap .node:hover .lbl,.mindmap .node:focus-visible .lbl{fill:#A9831F;}
  .mindmap .node:focus{outline:none;}
  .mindmap .node.is-sel .dot{fill:#C9A84C;stroke:#A9831F;}
  .mindmap .node.is-sel .lbl{fill:#1A1A1A;}
  .mindmap .center-ring{fill:none;stroke:#C9A84C;stroke-width:1;opacity:.4;}
  .mindmap .center-dot{fill:url(#greenGrad);stroke:#C9A84C;stroke-width:2;filter:url(#centerGlow);}
  .mindmap .tap-hint{font-family:var(--sans-kr);font-weight:300;fill:#A9831F;letter-spacing:.04em;}
  @keyframes mmRingDraw{to{opacity:1;}}
  @keyframes mmNodePop{from{opacity:0;transform:translateY(8px) scale(.6);}to{opacity:1;transform:translateY(0) scale(1);}}
  @media(prefers-reduced-motion:no-preference){
    .mindmap .orbit{animation:mmRingDraw 1s var(--ease) .2s forwards;}
    .mindmap .orbit-out{animation:mmRingDraw 1s var(--ease) .45s forwards;}
    .mindmap .spoke{animation:mmRingDraw .9s var(--ease) .7s forwards;}
    .mindmap .node{opacity:0;transform-box:view-box;animation:mmNodePop .55s var(--ease) forwards;animation-delay:calc(.85s + var(--i) * .055s);}
  }
  @media(prefers-reduced-motion:reduce){
    .mindmap .orbit,.mindmap .orbit-out,.mindmap .spoke{opacity:1;}
  }


  /* 함께하기 — 실연결 채널 */
  .join-channels{display:grid;grid-template-columns:1fr;gap:16px;max-width:760px;margin-bottom:clamp(30px,4vh,44px);}
  .join-channels a{display:flex;flex-direction:column;gap:7px;padding:22px 24px;text-decoration:none;border:1px solid var(--s2-line);transition:border-color .3s var(--ease),background .3s var(--ease),transform .3s var(--ease);}
  .join-channels a:hover{transform:translateY(-2px);}
  .ch-primary{background:rgba(201,168,76,0.12);border-color:var(--gold-soft);}
  .ch-primary:hover{border-color:var(--s2-gold);}
  .ch-secondary:hover{border-color:var(--gold-soft);background:rgba(30,58,43,0.16);}
  .join-channels .ch-k{font-family:var(--serif-kr);font-weight:500;font-size:clamp(16px,1.8vw,19px);color:var(--s2-text);}
  .ch-primary .ch-k{color:var(--s2-gold);}
  .join-channels .ch-sub{font-family:var(--sans-kr);font-weight:300;font-size:12.5px;color:var(--s2-muted);}
  .join-or{font-family:var(--sans-kr);font-weight:300;font-size:13px;color:var(--s2-muted);letter-spacing:.02em;margin-bottom:22px;}

  .app-bizfoot{margin-top:clamp(46px,7vh,76px);}
  .app-bizfoot .hair{width:100%;max-width:680px;height:1px;margin:0 0 26px;background:linear-gradient(90deg,var(--s2-line),transparent);}
  .app-bizfoot p{font-family:var(--sans-kr);font-weight:300;font-size:12px;line-height:1.95;color:var(--s2-muted);letter-spacing:.015em;max-width:860px;word-break:keep-all;}
  .app-bizfoot .sep{color:rgba(138,139,133,.4);margin:0 7px;}
  .app-bizfoot a{color:var(--s2-muted);text-decoration:none;border-bottom:1px solid rgba(138,139,133,.3);}

  /* 모바일 공통 푸터 — 좌측 메뉴가 상단바로 가도 본문 맨 아래에 처리방침 상시 노출 */
  .app-foot{display:none;}
  @media(max-width:760px){
    .app-bizfoot{display:none;}
    .app-foot{display:block;border-top:1px solid var(--s2-line);margin:10px 4px 0;padding:22px 0 34px;text-align:center;}
    .app-foot p{font-family:var(--sans-kr);font-weight:300;font-size:11.5px;line-height:1.85;color:var(--s2-muted);word-break:keep-all;}
    .app-foot .sep{color:rgba(138,139,133,.45);margin:0 6px;}
    .app-foot a{text-decoration:none;color:var(--s2-muted);border-bottom:1px solid rgba(168,132,46,.4);padding-bottom:1px;}
    .app-foot .app-foot-links{margin-top:9px;}
    .app-foot .app-foot-links a.pp{color:#7A5E14;font-weight:500;}
  }
  .app-bizfoot a:hover{color:var(--s2-gold);border-color:var(--gold-soft);}

  @media (max-width:760px){
    #section2.vbv-app.is-open{flex-direction:column;}
    .app-nav{flex:0 0 auto;flex-direction:row;flex-wrap:wrap;align-items:center;overflow:visible;
      border-right:none;border-bottom:1px solid var(--s2-line);
      padding:12px 14px;gap:8px;}
    .app-brand{order:1;margin:0;flex:0 0 auto;}
    .app-brand img{height:38px;}
    /* 인증 메뉴: 상단 바 우측 */
    .app-auth{order:2;margin:0 0 0 auto;padding:0;border-top:none;flex-direction:row;gap:4px;}
    .app-auth .auth-link{flex-direction:row;align-items:baseline;gap:5px;padding:5px 9px;border-left:none;}
    .app-auth .al-en{display:none;}
    .app-auth .al-ko{font-size:13.5px;}
    /* 4개 탭: 한 줄 균등 분할(가로 스크롤 없음) */
    .app-menu{order:3;flex:1 1 100%;flex-direction:row;gap:2px;justify-content:space-between;
      margin-top:2px;padding-top:8px;border-top:1px solid var(--s2-line-soft);}
    .app-link{flex:1 1 0;display:flex;align-items:center;justify-content:center;text-align:center;
      border-left:none;padding:8px 4px;}
    .app-link .lk-no,.app-link .lk-en{display:none;}
    .app-link .lk-ko{font-size:13.5px;white-space:nowrap;
      border-bottom:2px solid transparent;padding-bottom:3px;transition:border-color .25s var(--ease);}
    .app-link.is-active{border-left:none;}
    .app-link.is-active .lk-ko{border-bottom-color:var(--s2-gold);}
    .app-nav-foot{display:none;}
    .app-panel{padding:30px 20px 64px;}
    .join-channels{grid-template-columns:1fr;}
  }

  /* ═══ 마인드맵 인터랙션 + 팝업 + 후기 ═══ */
  .mindmap{max-width:720px;}
  .mm-node{cursor:pointer;}
  .mm-node .mm-hit{transition:stroke .25s var(--ease),fill .25s var(--ease),stroke-opacity .25s var(--ease);}
  .mm-node:hover .mm-hit{stroke:var(--s2-gold);stroke-opacity:1;animation:none;}
  .mm-node:focus{outline:none;}
  .mm-node:focus-visible .mm-hit{stroke:var(--s2-gold);stroke-width:2.6;stroke-opacity:1;animation:none;}
  .mm-name,.mm-status,.mm-cn-main,.mm-cn-sub{pointer-events:none;}
  .mm-hint{text-align:center;font-family:var(--sans-kr);font-weight:300;font-size:13px;
    color:var(--s2-gold);letter-spacing:.02em;margin-bottom:10px;opacity:.9;}

  .mm-modal{position:absolute;inset:0;z-index:60;display:none;align-items:center;justify-content:center;padding:24px;}
  .mm-modal.is-open{display:flex;}
  .mm-modal-backdrop{position:absolute;inset:0;background:rgba(20,28,24,0.46);}
  .mm-modal-card{position:relative;z-index:1;width:100%;max-width:460px;
    background:linear-gradient(160deg,#FFFFFF,#F7F3EA);
    border:1px solid var(--gold-soft);padding:clamp(30px,4vw,46px);
    box-shadow:0 30px 80px rgba(30,40,34,0.20);animation:modalpop .3s var(--ease);}
  @keyframes modalpop{from{opacity:0;transform:translateY(14px) scale(.98)}to{opacity:1;transform:none}}
  .mm-modal-x{position:absolute;top:14px;right:16px;width:34px;height:34px;
    background:none;border:1px solid var(--s2-line);color:var(--s2-muted);
    font-size:17px;line-height:1;cursor:pointer;border-radius:50%;
    transition:color .25s var(--ease),border-color .25s var(--ease);}
  .mm-modal-x:hover{color:var(--s2-gold);border-color:var(--s2-gold);}
  .mm-modal-tag{font-family:var(--sans);font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--s2-gold);margin-bottom:14px;}
  .mm-modal-title{font-family:var(--serif-kr);font-weight:500;font-size:clamp(24px,3vw,32px);color:var(--s2-text);margin-bottom:16px;}
  .mm-modal-body{font-family:var(--sans-kr);font-weight:300;font-size:15px;line-height:1.85;color:var(--s2-muted);word-break:keep-all;}

  .rv-live{display:inline-flex;align-items:center;gap:10px;margin-bottom:clamp(30px,4vh,46px);
    font-family:var(--sans-kr);font-weight:300;font-size:13.5px;color:var(--s2-text);letter-spacing:.01em;}
  .rv-dot{width:8px;height:8px;border-radius:50%;background:var(--s2-gold);}
  @media (prefers-reduced-motion:no-preference){
    .rv-dot{animation:rvpulse 2s ease-out infinite;}
  }
  @keyframes rvpulse{0%{box-shadow:0 0 0 0 rgba(201,168,76,.5)}70%{box-shadow:0 0 0 9px rgba(201,168,76,0)}100%{box-shadow:0 0 0 0 rgba(201,168,76,0)}}
  .rv-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:clamp(18px,2vw,26px);}
  /* 넓은 화면 3개 → 중간 2개 → 좁은 화면 1개 */
  @media (max-width:1040px){.rv-grid{grid-template-columns:repeat(2,minmax(0,1fr));}}
  .rv-card{position:relative;border:1px solid var(--s2-line);padding:clamp(24px,2.4vw,32px);
    background:linear-gradient(160deg,rgba(30,58,43,0.16),rgba(11,13,12,0));}
  .rv-ex{position:absolute;top:14px;right:14px;font-family:var(--sans);font-size:9px;
    letter-spacing:.18em;text-transform:uppercase;color:rgba(138,139,133,.7);
    border:1px solid var(--s2-line);padding:3px 8px;}
  .rv-quote{font-family:var(--serif-kr);font-weight:300;font-size:clamp(15px,1.5vw,17px);
    line-height:1.9;color:var(--s2-text);margin:6px 0 22px;word-break:keep-all;}
  .rv-meta{display:flex;align-items:center;gap:12px;}
  .rv-name{font-family:var(--sans-kr);font-weight:400;font-size:13px;color:var(--s2-muted);filter:blur(3.5px);user-select:none;}
  .rv-src{font-family:var(--sans);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:rgba(138,139,133,.65);}
  .rv-tags{margin-top:16px;display:flex;flex-wrap:wrap;gap:8px;}
  .rv-tag{font-family:var(--sans-kr);font-weight:300;font-size:11.5px;color:var(--s2-gold);
    border:1px solid var(--gold-line);padding:4px 11px;border-radius:20px;}
  .rv-foot{margin-top:clamp(26px,4vh,40px);font-family:var(--sans-kr);font-weight:300;
    font-size:11.5px;line-height:1.6;color:rgba(138,139,133,.6);word-break:keep-all;}

  @media (max-width:760px){
    .rv-grid{grid-template-columns:1fr;}
  }

  /* ═══ 후기 베스트/일반 분리 + 자동연동 ═══ */
  .rv-section{margin-bottom:clamp(30px,4.5vh,48px);}
  .rv-label{display:flex;align-items:center;gap:14px;margin:0 0 20px;}
  .rv-label-no{font-family:var(--sans);font-size:10.5px;letter-spacing:.22em;color:var(--s2-gold);}
  .rv-label-ko{font-family:var(--serif-kr);font-weight:400;font-size:16px;color:var(--s2-text);white-space:nowrap;}
  .rv-label-rule{flex:1;height:1px;background:var(--s2-line);}
  .rv-ex.rv-best{color:var(--bg);background:var(--s2-gold);border-color:var(--s2-gold);font-weight:600;}
  a.rv-card{text-decoration:none;color:inherit;display:block;
    transition:border-color .3s var(--ease),transform .3s var(--ease);}
  a.rv-card:hover{border-color:var(--gold-line);transform:translateY(-3px);}

  /* ═══ 블로그 후기 카드 (썸네일+제목+날짜, 자동연동용) ═══ */
  .rv-card{padding:0;overflow:hidden;display:flex;flex-direction:column;
    background:linear-gradient(160deg,rgba(30,58,43,0.20),rgba(11,13,12,0));}
  .rv-thumb{aspect-ratio:16/10;overflow:hidden;background:#EFEAE0;}
  .rv-thumb img{width:100%;height:100%;object-fit:cover;display:block;
    transition:transform .5s var(--ease);}
  a.rv-card:hover .rv-thumb img{transform:scale(1.04);}
  .rv-noimg{aspect-ratio:3/2;position:relative;display:flex;align-items:center;padding:26px;
    background:linear-gradient(160deg,#FFFFFF,#F6F2E9);overflow:hidden;}
  .rv-noimg::before{content:"\201C";position:absolute;top:-14px;left:16px;
    font-family:var(--serif);font-size:90px;color:var(--gold-soft);opacity:.45;line-height:1;}
  .rv-noimg-t{position:relative;font-family:var(--serif-kr);font-weight:400;font-size:clamp(15px,1.6vw,17px);
    line-height:1.6;color:var(--s2-text);
    display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden;}
  .rv-body{position:relative;padding:clamp(18px,1.8vw,22px);display:flex;flex-direction:column;gap:12px;flex:1;}
  .rv-badge{position:absolute;top:-11px;left:clamp(18px,1.8vw,22px);
    font-family:var(--sans);font-size:9.5px;font-weight:600;letter-spacing:.16em;
    color:var(--bg);background:var(--s2-gold);padding:4px 10px;}
  .rv-t{font-family:var(--serif-kr);font-weight:400;font-size:clamp(15px,1.5vw,16.5px);
    line-height:1.55;color:#2A332D;
    display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.9em;}
  .rv-by{font-family:var(--sans-kr);font-weight:500;font-size:12px;color:#A8853E;margin:-2px 0 9px;letter-spacing:.01em;}
  .rv-foot2{display:flex;align-items:center;justify-content:space-between;margin-top:auto;}
  .rv-src2{font-family:var(--sans);font-size:10px;letter-spacing:.06em;color:#03C75A;font-weight:600;
    border:1px solid rgba(3,199,90,.4);padding:3px 8px;}
  .rv-date{font-family:var(--sans);font-size:11.5px;color:rgba(160,160,152,.7);}
  .rv-loading{grid-column:1/-1;text-align:center;padding:40px 0;
    font-family:var(--sans-kr);font-weight:300;font-size:14px;color:rgba(160,160,152,.7);}

  /* ═══ 가독성 강화 + 모달 문의 버튼 ═══ */
  .mm-name{fill:#1F2A24;paint-order:stroke;stroke:rgba(255,255,255,0.9);stroke-width:2.4px;stroke-linejoin:round;}
  .mm-node.is-off .mm-name{fill:#8E968F;}
  .mm-cn-main{paint-order:stroke;stroke:rgba(255,255,255,0.85);stroke-width:2px;stroke-linejoin:round;}
  .mm-cn-sub{fill:#1F2A24;letter-spacing:.32em;}
  .mm-hint{font-size:15px;color:#A8842E;opacity:1;margin-bottom:12px;}
  .vbv-caption{font-size:clamp(16px,1.9vw,22px)!important;color:#2A332D;}
  .app-panel .s2-intro{font-size:15.5px;color:#1A1A1A;}
  .mm-modal-body{font-size:16.5px;line-height:1.9;color:#1A1A1A;}
  .mm-modal-tag{font-size:11px;}
  .mm-cta{display:inline-block;margin-top:26px;font-family:var(--sans);font-size:12px;font-weight:500;
    letter-spacing:.18em;text-transform:uppercase;color:var(--bg);background:var(--s2-gold);
    border:1px solid var(--s2-gold);padding:13px 32px;text-decoration:none;
    transition:opacity .25s var(--ease),transform .2s var(--ease);}
  .mm-cta:hover{opacity:.9;}
  .mm-cta:active{transform:translateY(1px);}
  .rv-quote{font-size:clamp(16px,1.6vw,18px)!important;color:#2A332D;}
  .rv-src{font-size:11px;color:rgba(160,160,152,.85);}
  .rv-tag{font-size:12px;}
  #section2.vbv-app,.mm-modal,.mm-modal-backdrop{top:0;left:0;right:0;bottom:0;}

  /* ═══ 설계사 입장 게이트 ═══ */
  .mm-actions{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin-top:26px;}
  .mm-actions .mm-cta{margin-top:0;}
  .mm-cta-ghost{background:transparent;color:var(--s2-gold);border:1px solid var(--gold-soft);}
  .mm-cta-ghost:hover{background:rgba(168,132,46,0.12);opacity:1;}
  .mm-gate{margin-top:18px;padding-top:18px;border-top:1px solid var(--s2-line);}
  .mm-gate-label{display:block;font-family:var(--sans);font-size:10.5px;letter-spacing:.22em;
    text-transform:uppercase;color:var(--s2-gold);margin-bottom:10px;}
  .mm-gate-row{display:flex;gap:8px;}
  .mm-gate-row input{flex:1;min-width:0;font-family:var(--sans-kr);font-size:15px;color:var(--s2-text);
    background:#FFFFFF;border:1px solid var(--s2-line);padding:12px 14px;outline:none;
    transition:border-color .25s var(--ease);}
  .mm-gate-row input:focus{border-color:var(--gold-soft);}
  .mm-gate-row input::placeholder{color:rgba(138,139,133,0.55);}
  .mm-gate-go{font-family:var(--sans);font-size:12px;font-weight:500;letter-spacing:.16em;
    text-transform:uppercase;color:var(--bg);background:var(--s2-gold);border:1px solid var(--s2-gold);
    padding:0 22px;cursor:pointer;white-space:nowrap;transition:opacity .25s var(--ease);}
  .mm-gate-go:hover{opacity:.9;}
  .mm-gate-err{margin-top:10px;font-family:var(--sans-kr);font-size:12.5px;color:#e0896f;}
  .mm-tap{font-family:var(--serif-kr);font-weight:500;fill:#A8842E;paint-order:stroke;stroke:rgba(255,255,255,0.85);stroke-width:2px;stroke-linejoin:round;}

  /* ═══ [리디자인] 회사소개 히어로 ═══ */
  .home-hero{text-align:center;display:flex;flex-direction:column;align-items:center;
    padding:clamp(6px,2vh,24px) 0 clamp(30px,5vh,52px);}
  .hh-eyebrow{font-family:var(--sans);font-size:clamp(12px,1.5vw,14px);letter-spacing:.4em;
    text-transform:uppercase;color:var(--s2-gold);margin-bottom:clamp(16px,3vh,26px);}
  .hh-slogan{font-family:var(--serif-kr);font-weight:500;line-height:1.08;letter-spacing:-.01em;
    font-size:clamp(34px,7vw,72px);margin:0;color:var(--s2-text);}
  .hh-slogan .ln{display:block;white-space:nowrap;}
  .hh-slogan em{font-style:normal;color:var(--gold);}
  .hh-bridge{position:relative;width:min(320px,64vw);height:1px;
    margin:clamp(24px,4vh,32px) 0 clamp(22px,4vh,28px);}
  .hh-bridge::before,.hh-bridge::after{content:"";position:absolute;top:0;height:1px;width:50%;
    background:linear-gradient(90deg,transparent,var(--gold-soft),var(--gold));}
  .hh-bridge::after{right:50%;background:linear-gradient(270deg,transparent,var(--gold-soft),var(--gold));}
  .hh-node{position:absolute;top:50%;left:50%;width:7px;height:7px;border-radius:50%;
    transform:translate(-50%,-50%);background:var(--gold);box-shadow:0 0 14px 2px var(--gold-soft);}
  .hh-lede{font-family:var(--sans-kr);font-weight:400;font-size:clamp(17px,2.2vw,20px);line-height:1.78;
    color:#1A1A1A;max-width:560px;margin:0 0 clamp(26px,4vh,36px);}
  .hh-lede b{font-weight:500;color:#000;opacity:1;}
  .hh-cta{display:flex;gap:13px;flex-wrap:wrap;justify-content:center;}
  .hh-btn{font-family:var(--sans-kr);font-size:15px;font-weight:500;text-decoration:none;padding:14px 28px;min-width:210px;
    border-radius:999px;cursor:pointer;transition:.2s var(--ease);display:inline-flex;
    align-items:center;justify-content:center;gap:8px;border:1px solid var(--gold);white-space:nowrap;}
  .hh-btn .ar{transition:transform .2s var(--ease);}
  .hh-btn:hover .ar{transform:translateX(4px);}
  .hh-btn.primary{background:var(--gold);color:var(--bg);font-weight:500;}
  .hh-btn.primary:hover{background:#dcb95a;box-shadow:0 8px 30px -10px var(--gold-soft);}
  .hh-btn.ghost{background:transparent;color:var(--gold);border-color:var(--gold-line);}
  .hh-btn.ghost:hover{border-color:var(--gold);background:rgba(201,168,76,.06);}

  /* 연결분야 라벨 */
  .conn-eyebrow{margin-top:clamp(18px,4vh,36px);}
  .conn-title{font-family:var(--serif-kr);font-weight:500;font-size:clamp(22px,3.4vw,34px);
    line-height:1.25;color:var(--s2-text);margin:0 0 12px;word-break:keep-all;overflow-wrap:break-word;}

  /* [전역] 섹션2 내부 모든 텍스트: 한글을 음절 단위로 끊지 않고 단어 단위로만 줄바꿈 */
  #section2,#section2 *{word-break:keep-all;overflow-wrap:break-word;}

  /* ═══ [리디자인] 전문가 / 크리에이터 가치 밴드 ═══ */
  .who-band{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--gold-line);
    border:1px solid var(--gold-line);border-radius:16px;overflow:hidden;
    margin-top:clamp(40px,6vh,72px);}
  .who-col{background:#FFFFFF;padding:clamp(26px,3vw,40px);display:flex;flex-direction:column;}
  .who-pro{background:linear-gradient(180deg,rgba(30,58,43,.22),rgba(10,14,12,0) 62%);}
  .who-tag{font-family:var(--sans);font-size:13px;letter-spacing:.2em;text-transform:uppercase;
    color:#9C7A1E;margin-bottom:16px;}
  .who-h{font-family:var(--serif-kr);font-weight:500;font-size:clamp(20px,2.6vw,27px);
    line-height:1.28;color:var(--s2-text);margin:0 0 20px;}
  .who-list{list-style:none;margin:0 0 24px;padding:0;display:flex;flex-direction:column;gap:13px;}
  .who-list li{position:relative;padding-left:20px;font-family:var(--sans-kr);font-weight:400;
    font-size:16.5px;line-height:1.72;color:#1A1A1A;}
  .who-list li::before{content:"";position:absolute;left:0;top:9px;width:7px;height:7px;
    border-radius:50%;background:var(--gold-soft);}
  .who-list b{color:var(--s2-text);font-weight:500;}
  .who-link{margin-top:auto;align-self:flex-start;font-family:var(--sans-kr);font-size:15px;
    color:var(--gold);border-bottom:1px solid var(--gold-line);padding-bottom:2px;
    transition:.2s var(--ease);}
  .who-link:hover{border-bottom-color:var(--gold);}

  @media(max-width:760px){
    .hh-slogan{font-size:clamp(25px,7.6vw,44px);}
    .who-band{grid-template-columns:1fr;}
  }

  /* 히어로 로드 모션 — section2 열릴 때만 (인트로 핸드오프 후 재생), reduced-motion 존중 */
  @media(prefers-reduced-motion:no-preference){
    #section2.is-open .home-hero .hh-eyebrow{opacity:0;transform:translateY(10px);animation:hhRise .8s var(--ease) .1s forwards;}
    #section2.is-open .home-hero .hh-slogan .ln1{opacity:0;transform:translateY(18px);animation:hhRise .9s var(--ease) .25s forwards;}
    #section2.is-open .home-hero .hh-slogan .ln2{opacity:0;transform:translateY(18px);animation:hhRise .9s var(--ease) .4s forwards;}
    #section2.is-open .home-hero .hh-bridge::before{width:0;animation:hhDraw 1s var(--ease) .9s forwards;}
    #section2.is-open .home-hero .hh-bridge::after{width:0;animation:hhDraw 1s var(--ease) .9s forwards;}
    #section2.is-open .home-hero .hh-node{transform:translate(-50%,-50%) scale(0);animation:hhPop .5s var(--ease) 1.7s forwards;}
    #section2.is-open .home-hero .hh-lede{opacity:0;transform:translateY(12px);animation:hhRise .9s var(--ease) 1.4s forwards;}
    #section2.is-open .home-hero .hh-cta{opacity:0;transform:translateY(12px);animation:hhRise .9s var(--ease) 1.6s forwards;}
    @keyframes hhRise{to{opacity:1;transform:translateY(0);}}
    @keyframes hhDraw{to{width:50%;}}
    @keyframes hhPop{to{transform:translate(-50%,-50%) scale(1);}}
  }

  /* [LIGHT] 전역변수 section2 스코프 한정 (인트로 불변) */
  #section2.vbv-app,#section2{--gold-line:rgba(168,132,46,0.32);--gold-soft:rgba(201,168,76,0.80);--text:#1F2A24;--text-sec:#3D4A42;}
  #section2.vbv-app .hh-btn.ghost{color:#A8842E;border-color:rgba(168,132,46,0.45);}
  #section2.vbv-app .hh-btn.ghost:hover{border-color:var(--gold);background:rgba(201,168,76,.08);}
  @media(max-width:760px){#section2.vbv-app .hh-btn{width:100%;min-width:0;}}

  /* [LIGHT] 좌측 섹션선택 네비 = 딥그린 + 밝은 텍스트 가독성 */
  #section2.vbv-app .app-nav-foot p{color:rgba(238,234,222,0.52);}
  #section2.vbv-app .app-link:hover,#section2.vbv-app .auth-link:hover{background:rgba(255,255,255,0.07);}
  #section2.vbv-app .app-link.is-active{background:transparent;}
  #section2.vbv-app .auth-link.auth-primary .al-ko{color:var(--s2-gold);}
