/* ════════════════════════════════════════════
   AutoConti SaaS — The Modern Script-Room
   Design System v3.0 (DESIGN.md)
   ════════════════════════════════════════════ */

/* ── Google Fonts: Manrope + Newsreader ── */
@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@300;400;500;600;700;800&family=Newsreader:ital,wght@0,300;0,400;0,600;0,700;1,400;1,600&display=swap');

:root {
  /* ══ DESIGN.md — Color Tokens ══ */
  /* Primary */
  --primary:#555f71;
  --primary-dark:#495365;
  --primary-gradient:linear-gradient(135deg,#555f71,#495365);

  /* Surface layers (No-Line rule — use background shifts) */
  --surface-lowest:#ffffff;          /* canvas / cards */
  --surface:#f7f9fc;                 /* workspace / page bg */
  --surface-container:#e8eff4;       /* sidebar, panels */
  --surface-container-low:#f0f4f8;   /* subtle section fill */
  --surface-container-high:#e1e9f0;  /* input field bg */
  --surface-container-highest:#d9e4ec; /* strongest fill */
  --surface-dim:#cedce5;             /* disabled state */

  /* Outline (ghost border — 15% opacity) */
  --outline-variant:rgba(168,179,187,0.15);
  --outline:rgba(168,179,187,0.40);

  /* Text */
  --on-surface:#1c2b37;
  --on-surface-variant:#4a5a66;
  --muted:#7a8a96;
  --on-primary:#ffffff;

  /* Semantic */
  --teal:#1D9E75;--blue:#3B82F6;--amber:#e8a030;
  --red:#c0392b;--red-dark:#a93226;

  /* Ambient shadow */
  --shadow-ambient:0 24px 48px -12px rgba(41,52,58,0.08);
  --shadow-card:0 2px 8px rgba(41,52,58,0.06);

  /* ── Legacy aliases (기존 컴포넌트 호환) ── */
  --bg:var(--surface);
  --bg2:var(--surface-lowest);
  --bg3:var(--surface-container-low);
  --surface2:var(--surface-container-low);
  --border:var(--outline-variant);
  --border2:var(--outline);
  --text:var(--on-surface-variant);
  --text-dim:var(--muted);
  --text-bright:var(--on-surface);
  --accent:#c0392b;
  --accent2:#a93226;
  --accent-hover:#a93226;

  /* ── Editor (paper/dark) — unchanged ── */
  --dark:#0e0c0a;--dark2:#141210;--dark3:#1a1816;
  --dark-border:#2a2620;--dark-border2:#3a3630;--dark-muted:#5a5650;
  --dark-text-dim:#7a7670;--dark-text:#c0bcb4;--dark-text-bright:#e0dcd4;
  --paper:#f6f3ed;--ink:#1a1814;--ink2:#3a3630;--ink3:#6a6458;--ink4:#9a9488;
  --rule:#d5cdc0;--paper2:#ede8dc;

  /* Editor accent (가편/완편 — kept) */
  --editor-accent:#c0392b;

  /* ── Spacing scale ── */
  --space-1:0.5rem;
  --space-3:1rem;
  --space-6:2rem;
  --space-12:4rem;
  --space-16:5.5rem;

  /* ── Radius ── */
  --radius-sm:4px;
  --radius-md:8px;
  --radius-lg:12px;

  /* ══ 반응형 토큰 (데스크탑 기본값) ══
     @media 모바일에서 이 변수만 바꾸면
     모든 컴포넌트가 자동으로 따라옴      */
  --page-px:48px;          /* 좌우 페이지 여백 */
  --nav-h:60px;            /* 랜딩 네브 높이 */
  --editor-nav-h:48px;     /* 에디터 TopNav 높이 */
  --hero-logo-size:64px;   /* 히어로 로고 */
  --hero-sub-size:22px;    /* 히어로 서브타이틀 */
  --hero-desc-size:15px;   /* 히어로 설명문 */
  --section-title-size:36px; /* 섹션 제목 */
  --card-gap:16px;         /* 카드 그리드 gap */
  --modal-w:400px;         /* 모달 최대 너비 */
  --editor-tab-h:0px;      /* 모바일 탭바 높이 (데스크탑은 0) */
}
*{box-sizing:border-box;margin:0;padding:0;}
/* 브랜드 em 태그 — 이탤릭 방지 전역 기본값 */
/* 각 컴포넌트 클래스에서 color와 font-style:normal을 지정하지만,
   혹시라도 누락된 경우를 위한 안전망 */
.logo em,.landing-logo em,.landing-nav-logo em,.lf-logo em,
.landing-section-title em,.landing-cta-title em,.landing-cta-banner-inner em,
.modal-title em,.share-footer-logo em,.icard-title em,.upload-text em{
  font-style:normal;
}
html,body{
  height:100%;overflow:hidden;
  background:var(--surface);color:var(--on-surface-variant);
  /* UI font: Manrope → Inter fallback → system */
  font-family:'Manrope','Inter','Noto Sans KR',sans-serif;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
/* Creative canvas areas use Newsreader */
textarea, .newsreader, .canvas-font {
  font-family:'Newsreader','Georgia',serif;
}
#app{height:100%;overflow:hidden;}
html.landing-active,body.landing-active{overflow:hidden;}

/* ── PAGES SYSTEM ── */
/* ── PAGES SYSTEM (6 pages) ── */
/* PAGE CONTAINER SYSTEM (조건부 렌더링 — 현재 페이지만 DOM에 존재) */
.page-container{
  width:100%;height:100%;
  display:flex;flex-direction:column;
  overflow:hidden;
  position:relative;
}
@keyframes pageEnter{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:translateY(0);}}
@keyframes pageLeave{from{opacity:1;}to{opacity:0;}}
.page-container.page-entering{animation:pageEnter 0.22s ease forwards;}
.page-container.page-leaving{animation:pageLeave 0.18s ease forwards;pointer-events:none;}
/* .page \uae30\ubcf8: \ud3ec\uc9d0 \ud654\uc2a4 - overflow:hidden\uc73c\ub85c \ub0b4\ubd80 \uc2a4\ud06c\ub864 \uc601\uc5ed\ub9cc \uc2a4\ud06c\ub864 */
.page{width:100%;height:100%;display:flex;flex-direction:column;overflow:hidden;position:relative;}
/* \ub79c\ub529 \ud398\uc774\uc9c0(p0):\ud3f0\ud2b8 \ub79c\ub529 \ud398\uc774\uc9c0\uc758 .landing-body\uac00 \uc2a4\ud06c\ub864\ub418\ub3c4\ub85d overflow:visible\uc774 \uc544\ub2cc overflow:hidden */



/* ── TOPNAV ── */
.tnav{
  height:48px;min-height:48px;flex-shrink:0;
  background:rgba(247,249,252,0.85);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--outline-variant);
  display:flex;align-items:center;padding:0 20px;gap:10px;
  box-shadow:0 1px 4px rgba(41,52,58,0.05);
}
.logo{font-family:'Manrope',serif;font-size:18px;font-weight:800;color:var(--on-surface);letter-spacing:1px;cursor:pointer;flex-shrink:0;}
.logo em{color:var(--editor-accent);font-style:normal;}
.tsep{width:1px;height:18px;background:var(--outline-variant);}
.tstep{display:flex;align-items:center;gap:6px;font-family:'Manrope',sans-serif;font-size:10px;font-weight:500;letter-spacing:0.5px;color:var(--muted);text-transform:uppercase;padding:4px 12px;border-radius:var(--radius-md);border:none;background:transparent;transition:background .15s;}
.tstep.on{color:var(--on-surface);background:var(--surface-container-low);}
.tstep .dot{width:6px;height:6px;border-radius:50%;background:var(--muted);}
.tstep.on .dot{background:var(--editor-accent);}
/* Primary CTA button — gradient */
.tarrow{
  background:var(--primary-gradient);
  border:none;
  color:var(--on-primary);
  font-family:'Manrope',sans-serif;
  font-size:11px;font-weight:600;
  letter-spacing:0.3px;
  padding:7px 16px;
  cursor:pointer;
  transition:all .2s;
  border-radius:var(--radius-md);
  box-shadow:0 2px 6px rgba(85,95,113,0.25);
}
.tarrow:hover:not(:disabled){filter:brightness(1.08);box-shadow:0 4px 12px rgba(85,95,113,0.3);transform:translateY(-1px);}
.tarrow:disabled{opacity:.3;cursor:not-allowed;transform:none;box-shadow:none;}
.tnav-r{margin-left:auto;display:flex;gap:6px;align-items:center;}
/* Secondary / Ghost button */
.tbtn{
  background:transparent;
  border:1px solid rgba(168,179,187,0.35);
  color:var(--on-surface-variant);
  font-family:'Manrope',sans-serif;
  font-size:10px;font-weight:500;
  letter-spacing:0.3px;
  padding:5px 12px;
  cursor:pointer;
  transition:all .15s;
  border-radius:var(--radius-md);
}
.tbtn:hover:not(:disabled){
  background:var(--surface-container-low);
  border-color:rgba(85,95,113,0.4);
  color:var(--on-surface);
}
.tbtn:disabled{opacity:.3;cursor:not-allowed;}

/* ── LANDING PAGE (Page 0) — The Modern Script-Room ── */
.landing-body{flex:1;overflow-y:auto;overflow-x:hidden;background:var(--surface);min-height:0;}

/* 랜딩 전용 네브바 */
.landing-nav{
  height:60px;display:flex;align-items:center;justify-content:space-between;
  padding:0 48px;
  background:rgba(247,249,252,0.92);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--outline-variant);
  position:sticky;top:0;z-index:100;
  box-shadow:0 1px 8px rgba(41,52,58,0.06);
}
.landing-nav-logo{font-family:'Manrope',serif;font-size:18px;font-weight:800;color:var(--on-surface);letter-spacing:1px;cursor:pointer;}
.landing-nav-logo em{color:var(--editor-accent);font-style:normal;}
.landing-nav-menu{display:flex;align-items:center;gap:32px;}
.landing-nav-link{font-family:'Manrope',sans-serif;font-size:12px;font-weight:500;letter-spacing:0.3px;color:var(--muted);cursor:pointer;text-decoration:none;transition:color .15s;}
.landing-nav-link:hover{color:var(--on-surface);}
.landing-nav-actions{display:flex;align-items:center;gap:12px;}

/* 히어로 */
.landing-hero{min-height:calc(100vh - 60px);display:grid;grid-template-columns:1fr 1fr;align-items:center;padding:0 48px;gap:60px;max-width:1280px;margin:0 auto;}
.landing-hero-text{}
.landing-hero-eyebrow{font-family:'Manrope',sans-serif;font-size:11px;font-weight:600;letter-spacing:3px;color:var(--muted);text-transform:uppercase;margin-bottom:20px;display:flex;align-items:center;gap:10px;}
.landing-hero-eyebrow::before{content:'';width:32px;height:1px;background:var(--outline);}
.landing-logo{font-family:'Manrope',sans-serif;font-size:64px;font-weight:800;color:var(--on-surface);letter-spacing:2px;margin-bottom:8px;line-height:1;}
.landing-logo em{color:var(--editor-accent);font-style:normal;}
.landing-hero-sub{font-family:'Newsreader',serif;font-size:22px;font-weight:400;color:var(--on-surface-variant);font-style:italic;margin-bottom:28px;line-height:1.5;}
.landing-tagline{font-family:'Manrope',sans-serif;font-size:11px;font-weight:600;letter-spacing:3px;color:var(--muted);text-transform:uppercase;margin-bottom:24px;}
.landing-desc{font-family:'Newsreader',serif;font-size:16px;color:var(--on-surface-variant);line-height:1.85;max-width:500px;margin-bottom:40px;}
.landing-hero-visual{background:var(--on-surface);aspect-ratio:16/10;border-radius:var(--radius-md);overflow:hidden;position:relative;box-shadow:var(--shadow-ambient);}
.landing-hero-visual-inner{width:100%;height:100%;background:linear-gradient(135deg,#0D0D0D 0%,#1a1816 40%,#2a2620 100%);display:flex;align-items:center;justify-content:center;position:relative;}
.landing-hero-mockup{padding:24px;width:100%;}
.lhm-bar{height:2px;border-radius:1px;margin-bottom:10px;}
.lhm-bar.w100{width:100%;background:rgba(255,255,255,.15);}
.lhm-bar.w70{width:70%;background:rgba(255,255,255,.1);}
.lhm-bar.w85{width:85%;background:rgba(255,255,255,.12);}
.lhm-bar.w50{width:50%;background:rgba(255,255,255,.08);}
.lhm-cut{display:flex;gap:10px;margin-bottom:8px;align-items:flex-start;}
.lhm-num{font-family:'DM Mono',monospace;font-size:10px;color:rgba(255,255,255,.35);width:24px;flex-shrink:0;margin-top:2px;}
.lhm-content{flex:1;}
.lhm-title{font-family:serif;font-size:13px;color:rgba(255,255,255,.75);margin-bottom:4px;}
.lhm-lines{display:flex;flex-direction:column;gap:3px;}
.lhm-line{height:2px;border-radius:1px;background:rgba(255,255,255,.12);}
.lhm-accent-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0;margin-top:4px;}
.landing-hero-badge{position:absolute;bottom:20px;right:20px;background:rgba(255,255,255,.1);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.15);color:#fff;font-family:'DM Mono',monospace;font-size:10px;letter-spacing:1px;padding:8px 14px;border-radius:3px;}

/* ── Hero 인터랙티브 AI 데모 비주얼 ── */
@keyframes heroCursorBlink{0%,100%{opacity:1}50%{opacity:0}}
@keyframes heroCutSlideIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@keyframes heroStatusPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.25)}}
@keyframes heroAnalyzeFill{from{width:0}to{width:100%}}

.hero-demo-wrap{
  border-radius:var(--radius-md);
  overflow:hidden;
  background:linear-gradient(155deg,#0e0f11 0%,#16181c 55%,#1c1f26 100%);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 32px 80px rgba(0,0,0,.35),0 0 0 1px rgba(255,255,255,.04);
  cursor:pointer;
  transition:box-shadow .3s,transform .3s;
  aspect-ratio:16/10;
  display:flex;
  flex-direction:column;
  position:relative;
}
.hero-demo-wrap:hover{
  box-shadow:0 40px 100px rgba(0,0,0,.45),0 0 0 1px rgba(255,255,255,.1);
  transform:translateY(-3px);
}

/* 상단 탭 바 */
.hero-demo-topbar{
  display:flex;align-items:center;gap:12px;
  padding:0 14px;
  height:34px;
  background:rgba(255,255,255,.035);
  border-bottom:1px solid rgba(255,255,255,.06);
  flex-shrink:0;
}
.hero-demo-dots{display:flex;gap:5px;flex-shrink:0;}
.hero-demo-dots span{
  width:9px;height:9px;border-radius:50%;
  background:rgba(255,255,255,.12);
}
.hero-demo-dots span:nth-child(1){background:#ff5f57;}
.hero-demo-dots span:nth-child(2){background:#febc2e;}
.hero-demo-dots span:nth-child(3){background:#28c840;}
.hero-demo-tabs{display:flex;gap:2px;flex:1;padding:0 8px;}
.hero-demo-tab{
  font-family:'DM Mono',monospace;
  font-size:9px;letter-spacing:1px;
  color:rgba(255,255,255,.3);
  padding:4px 10px;
  border-radius:3px;
  transition:all .2s;
}
.hero-demo-tab.active{
  color:rgba(255,255,255,.85);
  background:rgba(255,255,255,.08);
  color:var(--tab-color,rgba(255,255,255,.85));
}
.hero-demo-status{
  font-family:'DM Mono',monospace;
  font-size:9px;letter-spacing:1px;
  color:rgba(255,255,255,.35);
  display:flex;align-items:center;gap:5px;
  flex-shrink:0;
}
.hero-demo-status-dot{
  width:5px;height:5px;border-radius:50%;flex-shrink:0;
}
.hero-demo-status-dot.typing{
  background:#facc15;
  animation:heroStatusPulse 1s ease-in-out infinite;
}
.hero-demo-status-dot.analyzing{
  background:#60a5fa;
  animation:heroStatusPulse .6s ease-in-out infinite;
}
.hero-demo-status-dot.done{background:#4ade80;}

/* 본문 2열 */
.hero-demo-body{
  display:grid;
  grid-template-columns:1fr 1fr;
  flex:1;
  overflow:hidden;
}
.hero-demo-left{
  padding:14px 16px;
  border-right:1px solid rgba(255,255,255,.05);
  display:flex;flex-direction:column;gap:10px;
  overflow:hidden;
}
.hero-demo-right{
  padding:14px 16px;
  display:flex;flex-direction:column;gap:8px;
  overflow:hidden;
}
.hero-demo-panel-label{
  font-family:'DM Mono',monospace;
  font-size:8px;letter-spacing:2px;
  color:rgba(255,255,255,.2);
  text-transform:uppercase;
  display:flex;align-items:center;justify-content:space-between;
  flex-shrink:0;
}
.hero-demo-cut-count{
  font-size:9px;letter-spacing:1px;
  font-family:'DM Mono',monospace;
}

/* 시나리오 텍스트 */
.hero-demo-scenario-text{
  font-family:'DM Mono',monospace;
  font-size:10px;line-height:1.7;
  color:rgba(255,255,255,.55);
  white-space:pre-wrap;
  flex:1;
  min-height:0;
  overflow:hidden;
}
.hero-demo-cursor{
  display:inline-block;
  width:1px;height:12px;
  background:rgba(255,255,255,.7);
  margin-left:1px;
  vertical-align:middle;
  animation:heroCursorBlink .8s step-end infinite;
}

/* 분석 진행 바 */
.hero-demo-analyze-bar-wrap{display:flex;flex-direction:column;gap:5px;flex-shrink:0;}
.hero-demo-analyze-label{
  font-family:'DM Mono',monospace;
  font-size:8px;letter-spacing:.5px;
  color:rgba(255,255,255,.4);
}
.hero-demo-analyze-track{
  height:2px;
  background:rgba(255,255,255,.08);
  border-radius:1px;
  overflow:hidden;
}
.hero-demo-analyze-fill{
  height:100%;
  border-radius:1px;
  transition:width .15s ease-out;
}

/* 컷 카드들 */
.hero-demo-cuts{display:flex;flex-direction:column;gap:5px;flex:1;min-height:0;overflow:hidden;}
.hero-demo-cut{
  display:flex;align-items:center;gap:8px;
  padding:6px 8px;
  border-radius:4px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.05);
  opacity:0;
  pointer-events:none;
  transition:none;
}
.hero-demo-cut.visible{
  opacity:1;
  pointer-events:auto;
  animation:heroCutSlideIn .3s ease-out forwards;
  border-color:rgba(var(--cut-color,255,255,255),.15);
}
.hero-demo-cut-num{
  font-family:'DM Mono',monospace;
  font-size:8px;letter-spacing:1px;
  color:rgba(255,255,255,.2);
  width:26px;flex-shrink:0;
}
.hero-demo-cut-info{flex:1;min-width:0;}
.hero-demo-cut-shot{
  font-family:'DM Mono',monospace;
  font-size:9px;letter-spacing:.5px;
  color:rgba(255,255,255,.7);
  margin-bottom:1px;
}
.hero-demo-cut-subject{
  font-family:'DM Mono',monospace;
  font-size:8px;
  color:rgba(255,255,255,.35);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.hero-demo-cut-tags{display:flex;flex-direction:column;gap:2px;flex-shrink:0;align-items:flex-end;}
.hero-demo-cut-tag{
  font-family:'DM Mono',monospace;
  font-size:7px;letter-spacing:.5px;
  padding:1px 5px;
  border-radius:2px;
  background:rgba(255,255,255,.06);
  color:rgba(255,255,255,.35);
}
.hero-demo-cut-tag.emotion{
  color:var(--cut-color,rgba(255,255,255,.5));
  background:rgba(255,255,255,.04);
}

/* Try 버튼 */
.hero-demo-try{
  flex-shrink:0;
  text-align:right;
}
.hero-demo-try-text{
  font-family:'DM Mono',monospace;
  font-size:9px;letter-spacing:1px;
  color:rgba(255,255,255,.25);
  transition:color .2s;
}
.hero-demo-wrap:hover .hero-demo-try-text{color:rgba(255,255,255,.6);}

/* 하단 배지 바 */
.hero-demo-footer{
  padding:7px 14px;
  background:rgba(255,255,255,.025);
  border-top:1px solid rgba(255,255,255,.05);
  display:flex;align-items:center;gap:8px;
  flex-shrink:0;
}
.hero-demo-footer-item{
  font-family:'DM Mono',monospace;
  font-size:8px;letter-spacing:1px;
  color:rgba(255,255,255,.2);
}
.hero-demo-footer-sep{color:rgba(255,255,255,.1);}

/* CTA 버튼들 */
.landing-cta{display:flex;gap:12px;flex-wrap:wrap;}
.btn-primary{
  padding:10px 24px;
  background:var(--primary-gradient);
  color:var(--on-primary);
  border:none;
  font-family:'Manrope',sans-serif;font-size:14px;font-weight:700;
  letter-spacing:0.3px;
  cursor:pointer;transition:all .2s;
  border-radius:var(--radius-md);
  box-shadow:0 2px 8px rgba(85,95,113,0.25);
}
.btn-primary:hover{filter:brightness(1.08);transform:translateY(-1px);box-shadow:0 4px 16px rgba(85,95,113,0.3);}
.btn-ghost{
  padding:9px 22px;
  background:transparent;
  color:var(--on-surface-variant);
  border:1px solid rgba(168,179,187,0.45);
  font-family:'Manrope',sans-serif;font-size:13px;font-weight:500;
  letter-spacing:0.3px;
  cursor:pointer;transition:all .2s;
  border-radius:var(--radius-md);
}
.btn-ghost:hover{background:var(--surface-container-low);border-color:rgba(85,95,113,0.4);color:var(--on-surface);}

/* 스텝 섹션 */
.landing-steps{background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:80px 48px;}
.landing-steps-inner{max-width:960px;margin:0 auto;}
.landing-section-eyebrow{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:3px;color:var(--muted);text-transform:uppercase;margin-bottom:12px;}
.landing-section-title{font-family:serif;font-size:36px;font-weight:800;color:var(--text-bright);letter-spacing:1px;margin-bottom:48px;}
.landing-section-title em{color:var(--editor-accent);font-style:normal;}
.steps-flow{display:flex;gap:0;position:relative;}
.steps-flow::before{content:'';position:absolute;top:28px;left:28px;right:28px;height:1px;background:var(--border2);}
.step-item{flex:1;display:flex;flex-direction:column;align-items:center;text-align:center;padding:0 16px;position:relative;}
.step-num{width:56px;height:56px;border-radius:50%;background:var(--surface);border:2px solid var(--border2);display:flex;align-items:center;justify-content:center;font-family:'DM Mono',monospace;font-size:14px;font-weight:700;color:var(--text-bright);margin-bottom:16px;position:relative;z-index:1;transition:all .2s;}
.step-item:hover .step-num{background:var(--accent);border-color:var(--accent);color:#fff;}
.step-num-label{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:2px;color:var(--muted);margin-bottom:8px;}
.step-title{font-family:serif;font-size:15px;font-weight:700;color:var(--text-bright);letter-spacing:.5px;margin-bottom:6px;}
.step-desc{font-size:12px;color:var(--text-dim);line-height:1.6;}

/* 피처 섹션 */
.landing-features{padding:80px 48px;background:var(--bg);}
.landing-features-inner{max-width:960px;margin:0 auto;}
.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1px;background:var(--border);border:1px solid var(--border);}
.feature-card{background:var(--surface);padding:32px 28px;text-align:left;transition:background .2s;}
.feature-card:hover{background:var(--bg3);}
.feature-icon{font-size:24px;margin-bottom:16px;}
.feature-title{font-family:serif;font-size:16px;font-weight:700;color:var(--text-bright);letter-spacing:.5px;margin-bottom:8px;}
.feature-desc{font-size:12px;color:var(--text-dim);letter-spacing:.3px;line-height:1.75;}

/* 프라이싱 */
.landing-pricing{background:var(--surface);border-top:1px solid var(--border);padding:80px 48px;}
.landing-pricing-inner{max-width:880px;margin:0 auto;}
.pricing-title{font-family:serif;font-size:36px;font-weight:800;color:var(--text-bright);letter-spacing:1px;margin-bottom:8px;}
.pricing-sub{font-family:'DM Mono',monospace;font-size:11px;color:var(--muted);letter-spacing:2px;margin-bottom:48px;}
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--border);}
.plan-card{background:var(--surface);border-right:1px solid var(--border);padding:36px 28px;position:relative;}
.plan-card:last-child{border-right:none;}
.plan-card.popular{background:var(--text-bright);}
.plan-badge{display:inline-block;font-family:'DM Mono',monospace;font-size:8px;letter-spacing:2px;padding:3px 10px;background:var(--editor-accent);color:#fff;margin-bottom:16px;text-transform:uppercase;}
.plan-name{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:3px;color:var(--muted);text-transform:uppercase;margin-bottom:16px;}
.plan-card.popular .plan-name{color:rgba(255,255,255,.5);}
.plan-price{font-family:serif;font-size:40px;font-weight:800;color:var(--text-bright);margin-bottom:4px;line-height:1;}
.plan-card.popular .plan-price{color:#fff;}
.plan-price span{font-size:16px;font-weight:400;color:var(--muted);}
.plan-card.popular .plan-price span{color:rgba(255,255,255,.5);}
.plan-period{font-family:'DM Mono',monospace;font-size:10px;color:var(--muted);margin-bottom:28px;}
.plan-card.popular .plan-period{color:rgba(255,255,255,.4);}
.plan-features{list-style:none;margin-bottom:28px;}
.plan-features li{font-size:13px;color:var(--text);padding:8px 0;border-bottom:1px solid var(--border);display:flex;gap:10px;align-items:flex-start;}
.plan-card.popular .plan-features li{color:rgba(255,255,255,.8);border-color:rgba(255,255,255,.12);}
.plan-features li::before{content:'✓';color:var(--teal);font-weight:700;flex-shrink:0;}
.plan-card.popular .plan-features li::before{color:#6ee7b7;}
.plan-btn{width:100%;padding:13px;background:var(--primary-gradient);color:#fff;border:none;font-family:'Manrope',sans-serif;font-size:14px;font-weight:700;letter-spacing:0.5px;cursor:pointer;transition:all .2s;border-radius:var(--radius-md);box-shadow:0 2px 8px rgba(85,95,113,0.2);}
.plan-btn:hover{filter:brightness(1.08);transform:translateY(-1px);box-shadow:0 4px 16px rgba(85,95,113,0.3);}
.plan-card.popular .plan-btn{background:#fff;color:var(--primary);}
.plan-card.popular .plan-btn:hover{background:var(--surface-container-low);color:var(--primary-dark);}

/* 다크 CTA 배너 */
.landing-cta-banner{background:#0D0D0D;padding:80px 48px;text-align:center;}
.landing-cta-banner-inner{max-width:640px;margin:0 auto;}
.landing-cta-title{font-family:serif;font-size:42px;font-weight:800;color:#fff;letter-spacing:2px;margin-bottom:16px;line-height:1.2;}
.landing-cta-title em{color:var(--editor-accent);font-style:normal;}
.landing-cta-desc{font-size:15px;color:rgba(255,255,255,.5);line-height:1.7;margin-bottom:36px;}
.landing-cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}
.btn-cta-white{padding:16px 40px;background:#fff;color:#0D0D0D;border:none;font-family:serif;font-size:16px;font-weight:700;letter-spacing:2px;cursor:pointer;transition:all .2s;border-radius:8px;}
.btn-cta-white:hover{background:var(--bg3);transform:translateY(-1px);}
.btn-cta-outline{padding:15px 36px;background:none;color:rgba(255,255,255,.8);border:1.5px solid rgba(255,255,255,.25);font-family:'DM Mono',monospace;font-size:12px;letter-spacing:2px;cursor:pointer;transition:all .2s;text-transform:uppercase;border-radius:8px;}
.btn-cta-outline:hover{border-color:rgba(255,255,255,.6);color:#fff;}

/* ── 랜딩 푸터 (Full) ── */
.lf-root{
  background:#0D0F12;
  border-top:1px solid rgba(255,255,255,.07);
  padding:56px 48px 32px;
  color:rgba(255,255,255,.55);
}
.lf-inner{max-width:1100px;margin:0 auto;}

/* 상단 4열 그리드 */
.lf-top{
  display:grid;
  grid-template-columns:1.8fr 1fr 1fr 1fr;
  gap:40px;
  margin-bottom:40px;
}

/* 브랜드 열 */
.lf-logo{
  font-family:'Manrope',sans-serif;
  font-size:20px;font-weight:800;
  color:#fff;letter-spacing:1.5px;
  margin-bottom:12px;
}
.lf-logo em{color:var(--editor-accent);font-style:normal;}
.lf-tagline{
  font-size:12px;line-height:1.8;
  color:rgba(255,255,255,.38);
  margin-bottom:20px;
  max-width:220px;
}

/* 소셜 버튼 */
.lf-social{display:flex;gap:8px;}
.lf-social-btn{
  display:flex;align-items:center;justify-content:center;
  width:32px;height:32px;
  border-radius:6px;
  border:1px solid rgba(255,255,255,.1);
  color:rgba(255,255,255,.4);
  text-decoration:none;
  transition:all .2s;
}
.lf-social-btn:hover{
  border-color:rgba(255,255,255,.3);
  color:#fff;
  background:rgba(255,255,255,.06);
}

/* 링크 열 공통 */
.lf-col-title{
  font-family:'Manrope',sans-serif;
  font-size:11px;font-weight:700;
  letter-spacing:2px;text-transform:uppercase;
  color:rgba(255,255,255,.25);
  margin-bottom:16px;
}
.lf-links{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;}
.lf-link{
  font-size:13px;
  color:rgba(255,255,255,.45);
  text-decoration:none;
  transition:color .15s;
  display:flex;align-items:center;gap:6px;
}
.lf-link:hover{color:#fff;}
.lf-link-soon{cursor:default;color:rgba(255,255,255,.28);}
.lf-link-soon:hover{color:rgba(255,255,255,.28);}
.lf-badge-soon{
  font-family:'DM Mono',monospace;
  font-size:8px;letter-spacing:1px;
  padding:1px 6px;border-radius:3px;
  background:rgba(255,255,255,.07);
  color:rgba(255,255,255,.3);
  border:1px solid rgba(255,255,255,.08);
}

/* 구분선 */
.lf-divider{
  border:none;
  border-top:1px solid rgba(255,255,255,.06);
  margin-bottom:24px;
}

/* 하단 3열 */
.lf-bottom{
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:12px;
}
.lf-copy{
  font-family:'DM Mono',monospace;
  font-size:11px;letter-spacing:.5px;
  color:rgba(255,255,255,.22);
}
.lf-stack{
  display:flex;align-items:center;gap:6px;
}
.lf-stack-item{
  font-family:'DM Mono',monospace;
  font-size:10px;letter-spacing:.5px;
  color:rgba(255,255,255,.22);
}
.lf-stack-sep{
  font-size:9px;
  color:rgba(255,255,255,.12);
}
.lf-contact .lf-link{color:rgba(255,255,255,.3);}
.lf-contact .lf-link:hover{color:rgba(255,255,255,.7);}

/* ── 반응형 ── */
@media(max-width:960px){
  .lf-top{grid-template-columns:1fr 1fr;gap:32px;}
  .lf-brand{grid-column:1/-1;}
}
@media(max-width:640px){
  .lf-root{padding:40px 20px 28px;}
  .lf-top{grid-template-columns:1fr 1fr;gap:24px;}
  .lf-brand{grid-column:1/-1;}
  .lf-bottom{flex-direction:column;align-items:flex-start;gap:8px;}
  .lf-stack{flex-wrap:wrap;}
}
@media(max-width:400px){
  .lf-top{grid-template-columns:1fr;}
}

/* 기존 단순 푸터 유지 (공유 페이지 등 다른 곳에서 사용) */

/* ── AUTH MODAL — Glassmorphism ── */
.modal-overlay{
  display:none;position:fixed;inset:0;z-index:1000;
  background:rgba(28,43,55,0.5);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  align-items:center;justify-content:center;
}
.modal-overlay.show{display:flex;}
.modal{
  background:rgba(247,249,252,0.80);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,0.55);
  box-shadow:var(--shadow-ambient),0 0 0 1px var(--outline-variant);
  padding:36px;width:100%;max-width:400px;position:relative;
  border-radius:var(--radius-lg);
}
.modal-close{
  position:absolute;top:12px;right:12px;
  background:var(--surface-container-low);
  border:none;
  color:var(--muted);font-size:16px;cursor:pointer;
  line-height:1;border-radius:var(--radius-md);
  width:28px;height:28px;display:flex;align-items:center;justify-content:center;
  transition:all .15s;
}
.modal-close:hover{background:var(--surface-container-highest);color:var(--on-surface);}
.modal-title{font-family:'Manrope',sans-serif;font-size:22px;font-weight:800;color:var(--on-surface);letter-spacing:0.5px;margin-bottom:8px;}
.modal-title em{color:var(--editor-accent);font-style:normal;}
.modal-sub{font-family:'Manrope',sans-serif;font-size:11px;font-weight:500;color:var(--muted);letter-spacing:0.3px;margin-bottom:24px;}
.social-btn{
  width:100%;padding:13px 16px;
  display:flex;align-items:center;justify-content:center;gap:10px;
  background:var(--surface-lowest);
  border:1px solid var(--outline);
  color:var(--on-surface-variant);
  font-family:'Manrope',sans-serif;font-size:13px;font-weight:500;
  cursor:pointer;transition:all .2s;
  border-radius:var(--radius-md);margin-bottom:10px;
  box-shadow:var(--shadow-card);
}
.social-btn:hover{background:var(--surface-container-low);border-color:var(--outline);}
.social-btn.kakao{background:#FEE500;color:#191919;border-color:#FEE500;}
.social-btn.kakao:hover{background:#F0D900;}
.social-btn.google{background:#4285F4;color:#fff;border-color:#4285F4;}
.social-btn.google:hover{background:#3367D6;}
.modal-divider{display:flex;align-items:center;gap:10px;margin:16px 0;font-family:'Manrope',sans-serif;font-size:10px;font-weight:500;color:var(--muted);letter-spacing:1px;}
.modal-divider::before,.modal-divider::after{content:'';flex:1;height:1px;background:var(--outline-variant);}
.form-group{margin-bottom:14px;}
.form-label{font-family:'Manrope',sans-serif;font-size:10px;font-weight:600;letter-spacing:0.5px;color:var(--muted);text-transform:uppercase;display:block;margin-bottom:6px;}
.form-input{
  width:100%;
  background:var(--surface-container-high);
  border:none;
  outline:2px solid transparent;
  color:var(--on-surface);
  font-family:'Manrope',sans-serif;
  font-size:14px;
  font-weight:400;
  padding:11px 14px;
  transition:all .15s;
  border-radius:var(--radius-md);
}
.form-input:focus{
  background:var(--surface-lowest);
  outline:2px solid var(--primary);
  box-shadow:0 0 0 4px rgba(85,95,113,0.10);
}
.form-btn{
  width:100%;padding:13px;
  background:var(--primary-gradient);
  color:var(--on-primary);
  border:none;
  font-family:'Manrope',sans-serif;font-size:15px;font-weight:700;
  letter-spacing:0.3px;
  cursor:pointer;transition:all .2s;
  border-radius:var(--radius-md);margin-top:6px;
  box-shadow:0 2px 8px rgba(85,95,113,0.25);
}
.form-btn:hover{filter:brightness(1.08);box-shadow:0 4px 16px rgba(85,95,113,0.3);transform:translateY(-1px);}
.form-btn:disabled{background:var(--surface-container-highest);color:var(--muted);cursor:not-allowed;box-shadow:none;transform:none;}
.modal-switch{text-align:center;margin-top:16px;font-family:'Manrope',sans-serif;font-size:11px;font-weight:400;color:var(--muted);}
.modal-switch a{color:var(--primary);cursor:pointer;text-decoration:none;font-weight:600;}
.modal-switch a:hover{text-decoration:underline;}
.modal-error{background:rgba(192,57,43,0.08);border:none;outline:1px solid rgba(192,57,43,0.3);color:var(--accent);font-family:'Manrope',sans-serif;font-size:11px;font-weight:500;padding:10px 14px;margin-bottom:12px;display:none;border-radius:var(--radius-sm);}
.modal-error.show{display:block;}

/* ── USER MENU ── */
.user-menu-wrap{position:relative;}
.user-avatar{
  width:32px;height:32px;border-radius:50%;
  background:var(--primary-gradient);
  color:var(--on-primary);
  font-family:'Manrope',sans-serif;font-size:13px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;flex-shrink:0;
  box-shadow:0 2px 6px rgba(85,95,113,0.3);
  transition:box-shadow .2s;
}
.user-avatar:hover{box-shadow:0 4px 12px rgba(85,95,113,0.4);}
.user-dropdown{
  display:none;position:absolute;top:calc(100% + 8px);right:0;
  background:rgba(247,249,252,0.96);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border:1px solid var(--outline-variant);
  min-width:200px;z-index:100;
  box-shadow:var(--shadow-ambient);
  border-radius:var(--radius-md);
  overflow:hidden;
}
.user-dropdown.show{display:block;}
.user-dropdown-header{padding:14px 16px;background:var(--surface-container-low);}
.user-dropdown-name{font-family:'Manrope',sans-serif;font-size:13px;font-weight:700;color:var(--on-surface);}
.user-dropdown-plan{font-family:'Manrope',sans-serif;font-size:10px;font-weight:500;letter-spacing:0.5px;color:var(--muted);margin-top:2px;text-transform:uppercase;}
.user-dropdown-item{display:flex;align-items:center;gap:8px;padding:10px 16px;font-family:'Manrope',sans-serif;font-size:12px;font-weight:500;color:var(--on-surface-variant);cursor:pointer;transition:background .12s;}
.user-dropdown-item:hover{background:var(--surface-container-low);}
.usage-bar-wrap{padding:10px 16px 14px;background:var(--surface-container-low);}
.usage-label{font-family:'Manrope',sans-serif;font-size:10px;font-weight:600;color:var(--muted);letter-spacing:0.3px;margin-bottom:6px;}
.usage-bar{height:4px;background:var(--outline-variant);border-radius:4px;overflow:hidden;}
.usage-bar-fill{height:100%;background:var(--primary-gradient);border-radius:4px;transition:width .3s;}
.usage-text{font-family:'Manrope',sans-serif;font-size:10px;color:var(--muted);margin-top:4px;}

/* ── MAIN SCREEN (Editor Home) ── */
.main-screen-wrap{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow-y:auto;padding:24px 40px;background:var(--surface);}
.main-screen{display:flex;align-items:center;justify-content:center;gap:20px;flex-wrap:wrap;padding:16px 0;}
.main-card{
  width:220px;height:220px;
  background:var(--surface-lowest);
  border:none;
  outline:1px solid var(--outline-variant);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:14px;cursor:pointer;transition:all .25s;position:relative;
  border-radius:var(--radius-md);
  box-shadow:var(--shadow-card);
}
.main-card:hover{
  outline-color:var(--primary);
  background:var(--surface-container-low);
  transform:translateY(-4px);
  box-shadow:var(--shadow-ambient);
}
.main-card-icon{font-size:44px;opacity:.7;transition:opacity .2s;}
.main-card:hover .main-card-icon{opacity:1;}
.main-card-title{font-family:'Manrope',sans-serif;font-size:15px;font-weight:700;color:var(--on-surface);letter-spacing:0.3px;}
.main-card-desc{font-family:'Manrope',sans-serif;font-size:10px;font-weight:400;color:var(--muted);letter-spacing:0.3px;text-align:center;line-height:1.7;padding:0 18px;}
.main-card-badge{position:absolute;top:10px;right:10px;font-family:'Manrope',sans-serif;font-size:9px;font-weight:600;padding:2px 8px;background:var(--surface-container-low);color:var(--muted);border-radius:var(--radius-sm);}
/* .saved-list \ud074\ub798\uc2a4\ub294 \uc774\uc81c saved-list-wrap\uc73c\ub85c \uad6c\uc870 \ubcc0\uacbd, JS\uc5d0\uc11c display:flex/none \uc9c1\uc811 \uc81c\uc5b4 */
.saved-list-wrap{display:none;flex-direction:column;gap:8px;}
.saved-list{display:flex;flex-direction:column;gap:8px;width:100%;max-width:560px;}
.saved-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--surface);border:1.5px solid var(--border);cursor:pointer;transition:all .15s;border-radius:3px;}
.saved-item:hover{border-color:var(--text-bright);background:var(--bg3);}
.saved-item-title{flex:1;font-family:serif;font-size:14px;font-weight:700;color:var(--text-bright);letter-spacing:.5px;}
.saved-item-meta{font-family:'DM Mono',monospace;font-size:8px;color:var(--muted);letter-spacing:1px;}
.saved-item-del{background:none;border:1px solid var(--border);color:var(--muted);font-size:10px;padding:3px 8px;cursor:pointer;transition:all .15s;border-radius:2px;}
.saved-item-del:hover{border-color:var(--editor-accent);color:var(--editor-accent);}
.saved-empty{font-family:'DM Mono',monospace;font-size:10px;color:var(--muted);text-align:center;padding:32px;letter-spacing:1px;}
.saved-back{background:none;border:1px solid var(--border2);color:var(--text-dim);font-family:'DM Mono',monospace;font-size:9px;letter-spacing:2px;padding:8px 16px;cursor:pointer;margin-bottom:8px;transition:all .15s;border-radius:2px;}
.saved-back:hover{border-color:var(--text-bright);color:var(--text-bright);}

/* ── EDITOR WRAP ── */
/* EditorHome Fragment 대신 div 래퍼 - .page flex column의 올바른 자식 */
.editor-wrap{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0;}

/* ── P1 INPUT ── */
.p1-body{flex:1;display:flex;align-items:flex-start;justify-content:center;padding:32px;overflow-y:auto;min-height:0;}
.icard{width:100%;max-width:660px;background:var(--dark2);border:1px solid var(--border);padding:32px;display:flex;flex-direction:column;gap:18px;margin:0 auto;}
.icard-title{font-family:serif;font-size:22px;font-weight:800;color:var(--text-bright);letter-spacing:2px;}
.icard-title em{color:var(--accent);font-style:normal;}
.icard-desc{font-size:12px;color:var(--muted);line-height:1.7;}
.fl{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:3px;color:var(--muted);text-transform:uppercase;margin-bottom:6px;}
.mta{width:100%;height:260px;background:var(--dark);border:1px solid var(--border);color:var(--text);font-family:'DM Mono',monospace;font-size:11px;line-height:1.9;padding:14px;resize:vertical;outline:none;transition:border-color .2s;}
.mta:focus{border-color:var(--border2);}
.mta::placeholder{color:#252320;}
.srow{display:flex;gap:6px;}
.sbtn{flex:1;background:none;border:1px solid var(--border);color:var(--muted);font-family:'DM Mono',monospace;font-size:9px;padding:6px;cursor:pointer;transition:all .15s;border-radius:4px;letter-spacing:1px;}
.sbtn:hover{border-color:var(--border2);color:var(--text);}
.gbtn{width:100%;padding:15px;background:var(--accent);color:#fff;border:none;font-family:serif;font-size:17px;font-weight:700;letter-spacing:3px;cursor:pointer;transition:background .2s;}
.gbtn:hover{background:var(--accent-hover);}
.gbtn:disabled{background:#2a2620;color:var(--muted);cursor:not-allowed;}
.prog{display:none;}
.prog.show{display:flex;flex-direction:column;align-items:center;gap:16px;padding:10px 0 4px;}
.prog-icon{position:relative;width:56px;height:56px;}
.prog-pencil{font-size:32px;display:block;transform-origin:bottom left;animation:write 0.7s ease-in-out infinite alternate;}
@keyframes write{0%{transform:rotate(-15deg) translateX(0px);}100%{transform:rotate(5deg) translateX(8px);}}
.prog-lines{display:flex;flex-direction:column;gap:5px;width:180px;}
.prog-line{height:2px;border-radius:1px;background:var(--border);overflow:hidden;}
.prog-line-fill{height:100%;background:var(--accent);border-radius:1px;width:0%;}
.prog-line:nth-child(1) .prog-line-fill{animation:lineGrow 1.4s 0.0s ease-in-out infinite;}
.prog-line:nth-child(2) .prog-line-fill{animation:lineGrow 1.4s 0.2s ease-in-out infinite;}
.prog-line:nth-child(3) .prog-line-fill{animation:lineGrow 1.4s 0.4s ease-in-out infinite;}
@keyframes lineGrow{0%{width:0%;opacity:1;}60%{width:100%;opacity:1;}80%{width:100%;opacity:0.3;}100%{width:0%;opacity:0;}}
.prog-msg{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:2px;color:var(--muted);text-align:center;}
.prog-pct{font-family:'DM Mono',monospace;font-size:10px;color:var(--accent);font-weight:600;letter-spacing:1px;}
.mode-row{display:flex;gap:0;}
.mbtn{flex:1;padding:14px 10px;border:1px solid var(--border);background:var(--dark);color:var(--muted);cursor:pointer;font-family:serif;font-size:16px;font-weight:700;letter-spacing:2px;transition:all .2s;position:relative;border-radius:6px;}
.mbtn:first-child{border-right:none;}
.mbtn .msub{display:block;font-family:'DM Mono',monospace;font-size:8px;font-weight:400;letter-spacing:2px;margin-top:3px;color:var(--muted);text-transform:uppercase;}
.mbtn.on{background:var(--dark2);color:var(--text-bright);border-color:var(--accent);}
.mbtn.on .msub{color:var(--text-dim);}
.mbtn.on::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:2px;background:var(--accent);}
.mbtn:hover:not(.on){background:var(--dark2);color:var(--text);}
.mode-desc{font-family:'DM Mono',monospace;font-size:9px;color:var(--muted);letter-spacing:1px;padding:8px 12px;background:var(--dark);border:1px solid var(--border);line-height:1.6;}
.upload-area{border:1px dashed var(--border2);padding:14px 16px;display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;transition:all .2s;background:var(--dark);}
.upload-area:hover,.upload-area.drag{border-color:var(--accent);background:rgba(192,57,43,.05);}
.upload-icon{font-size:22px;opacity:.6;}
.upload-text{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:1px;color:var(--muted);text-align:center;line-height:1.7;}
.upload-text em{color:var(--accent);font-style:normal;}
.upload-badge{display:inline-block;font-family:'DM Mono',monospace;font-size:8px;letter-spacing:1px;padding:2px 7px;border:1px solid var(--border2);color:var(--muted);margin:0 2px;}
.upload-status{font-family:'DM Mono',monospace;font-size:10px;color:#1D9E75;letter-spacing:1px;display:none;text-align:center;}
.upload-status.show{display:block;}
.upload-status.err{color:var(--accent);}
.input-sep{display:flex;align-items:center;gap:8px;font-family:'DM Mono',monospace;font-size:9px;color:var(--muted);letter-spacing:2px;}
.input-sep::before,.input-sep::after{content:'';flex:1;height:1px;background:var(--border);}
.p1-note{font-family:'DM Mono',monospace;font-size:9px;color:#252320;text-align:center;}
.api-key-notice{background:rgba(186,117,23,.1);border:1px solid rgba(186,117,23,.3);padding:10px 14px;font-family:'DM Mono',monospace;font-size:10px;color:#e8a030;line-height:1.7;}
.api-key-notice a{color:var(--accent);text-decoration:underline;cursor:pointer;}


/* ══════════════════════════════════════════
   P1 INPUT — Light Blue Theme Override
   시나리오 입력 영역: 옅은 파랑 라이트 테마
   ══════════════════════════════════════════ */
.p1-body {
  background: #EEF4FB;
}
/* 메인 카드 */
.p1-body .icard {
  background: #FFFFFF;
  border: 1.5px solid #D0DEF0;
  box-shadow: 0 2px 20px rgba(59,130,246,.07);
  border-radius: 10px;
}
.p1-body .icard-title { color: #1A2A3A; }
.p1-body .icard-title em { color: var(--editor-accent); }
.p1-body .icard-desc { color: #5A7A9A; }
.p1-body .fl { color: #6A8AAA; }

/* 시나리오 텍스트에어리아 ← 핵심 */
.p1-body .mta {
  background: #F0F7FF;
  border: 1.5px solid #B8D0EC;
  color: #1A2A3A;
  border-radius: 6px;
}
.p1-body .mta:focus {
  border-color: #5B9BD5;
  background: #EBF4FF;
  box-shadow: 0 0 0 3px rgba(91,155,213,.12);
}
.p1-body .mta::placeholder { color: #9BBAD6; }

/* 모드 버튼 */
.p1-body .mbtn {
  background: #F5F9FF;
  border-color: #C8DDF0;
  color: #5A7A9A;
}
.p1-body .mbtn.on {
  background: #FFFFFF;
  border-color: #5B9BD5;
  color: #1A2A3A;
}
.p1-body .mbtn:hover:not(.on) {
  background: #EBF3FF;
  color: #2A4A6A;
}
.p1-body .mbtn .msub { color: #8AAAC8; }
.p1-body .mbtn.on .msub { color: #5A7A9A; }
.p1-body .mbtn.on::after { background: #5B9BD5; }

/* 모드 설명 */
.p1-body .mode-desc {
  background: #F5F9FF;
  border-color: #D0DEF0;
  color: #5A7A9A;
}

/* 업로드 영역 */
.p1-body .upload-area {
  background: #F5F9FF;
  border-color: #B8D0EC;
}
.p1-body .upload-area:hover, .p1-body .upload-area.drag {
  border-color: #5B9BD5;
  background: rgba(91,155,213,.06);
}
.p1-body .upload-text { color: #6A8AAA; }
.p1-body .upload-text em { color: #3B82C4; }
.p1-body .upload-badge { border-color: #C0D8EE; color: #7A9AB8; }

/* 구분선 */
.p1-body .input-sep { color: #9BBAD6; }
.p1-body .input-sep::before, .p1-body .input-sep::after { background: #C8DDF0; }

/* sbtn (장르/분위기 선택 버튼) */
.p1-body .sbtn {
  background: #F5F9FF;
  border-color: #C8DDF0;
  color: #5A7A9A;
  border-radius: 4px;
}
.p1-body .sbtn:hover {
  border-color: #5B9BD5;
  color: #1A2A3A;
  background: #EBF3FF;
}

/* 분석 시작 버튼 */
.p1-body .gbtn {
  background: #2A6CB3;
  border-radius: 8px;
  letter-spacing: 2px;
}
.p1-body .gbtn:hover { background: #1E5A9A; }
.p1-body .gbtn:disabled { background: #C8DDF0; color: #9BBAD6; }

/* 진행 표시 */
.p1-body .prog-msg { color: #6A8AAA; }
.p1-body .prog-line { background: #D0DEF0; }
.p1-body .prog-line-fill { background: #3B82C4; }
.p1-body .prog-pct { color: #3B82C4; }

/* 노트 */
.p1-body .p1-note { color: #9BBAD6; }

/* api-key notice */
.p1-body .api-key-notice {
  background: rgba(59,130,246,.07);
  border-color: rgba(59,130,246,.25);
  color: #3A6A9A;
}

/* 에피소드 정보 패널 (접기/펼치기) */
.p1-body .icard-ep-wrap,
.p1-body [class*="ep-info"],
.p1-body [class*="ep-form"],
.p1-body [class*="ep-section"] {
  background: #F5F9FF;
  border-color: #D0DEF0;
  color: #3A5A7A;
}

/* 에피소드 입력 필드들 */
.p1-body input[type="text"] {
  background: #F0F7FF;
  border: 1.5px solid #C0D8EE;
  color: #1A2A3A;
  border-radius: 5px;
  padding: 8px 10px;
  outline: none;
  transition: border-color .15s;
  width: 100%;
  font-family: 'Noto Sans KR', sans-serif;
  font-size: 12px;
}
.p1-body input[type="text"]:focus {
  border-color: #5B9BD5;
  background: #EBF4FF;
}
.p1-body input[type="text"]::placeholder { color: #9BBAD6; }

/* 밀도/플롯 섹션 */
.p1-body .density-bar {
  background: #F5F9FF;
  border-color: #D0DEF0;
}
.p1-body .density-label { color: #6A8AAA; }
.p1-body .density-hint { color: #8AAAC8; }
.p1-body .density-count { color: #5A7A9A; }
.p1-body .density-btn {
  background: #F0F7FF;
  border-color: #C8DDF0;
  color: #6A8AAA;
}
.p1-body .density-btn.on {
  background: #DAEEFF;
  border-color: #5B9BD5;
  color: #1A2A3A;
}
.p1-body .density-btn:hover:not(.on) {
  background: #EBF3FF;
  color: #2A4A6A;
}

.p1-body .plot-cat-btn {
  background: #F0F7FF;
  border-color: #C8DDF0;
  color: #5A7A9A;
}
.p1-body .plot-cat-btn:hover, .p1-body .plot-cat-btn.active {
  border-color: #5B9BD5;
  color: #1A2A3A;
  background: #DAEEFF;
}

.p1-body .plot-item {
  border-color: #D0DEF0;
  background: #FAFCFF;
}
.p1-body .plot-item:hover { border-color: #90B8DC; background: #EEF5FF; }
.p1-body .plot-item.selected { border-color: #5B9BD5; background: rgba(91,155,213,.08); }
.p1-body .plot-item-name { color: #1A2A3A; }
.p1-body .plot-item-desc { color: #5A7A9A; }
.p1-body .plot-item-examples { color: #7A9AB8; }

/* AI 자동 감지 버튼 (플롯 선택) */
.p1-body .sel-run-btn {
  background: #3B82C4;
  border-radius: 6px;
}
.p1-body .sel-run-btn:hover { background: #2A6CB3; }
.p1-body .sel-analyze-btn {
  background: rgba(59,130,246,.1);
  color: #2A6CB3;
  border-color: rgba(59,130,246,.3);
}
.p1-body .sel-mini-btn {
  background: #F0F7FF;
  border-color: #C8DDF0;
  color: #5A7A9A;
}

/* ERA 섹션 (시대 배경 선택) */
.p1-body .era-selector { background: transparent; }
.p1-body .era-cat-tabs { border-color: #D0DEF0; background: #F5F9FF; }
.p1-body .era-cat-tab {
  background: transparent;
  color: #6A8AAA;
  border-right-color: #D0DEF0;
}
.p1-body .era-cat-tab.active {
  background: #FFFFFF;
  color: #1A2A3A;
  border-bottom-color: #5B9BD5;
}
.p1-body .era-cat-tab:hover { background: #EEF5FF; color: #2A4A6A; }
.p1-body .era-presets { background: #FAFCFF; }
.p1-body .era-card {
  background: #FFFFFF;
  border-color: #D0DEF0;
}
.p1-body .era-card:hover { border-color: #90B8DC; background: #EEF5FF; }
.p1-body .era-card.selected { border-color: #5B9BD5; background: rgba(91,155,213,.08); }

/* AI 분석 품질 배지 */
.p1-body .ai-badge,
.p1-body [class*="ai-qual"] {
  background: rgba(59,130,246,.1);
  color: #2A6CB3;
  border-color: rgba(59,130,246,.25);
}

/* ep-context 패널 (에피소드 정보) */
.p1-body .ep-context-panel {
  background: #F0F7FF;
  border: 1.5px solid #C8DDF0;
  border-radius: 8px;
}
.p1-body .ep-context-title { color: #5A7A9A; }
.p1-body .ep-context-badge {
  background: rgba(59,130,246,.1);
  color: #3B82C4;
  border-color: rgba(59,130,246,.25);
}
.p1-body .ep-context-toggle {
  background: #FFFFFF;
  border-color: #C8DDF0;
  color: #5A7A9A;
  border-radius: 4px;
}
.p1-body .ep-context-toggle:hover { border-color: #5B9BD5; color: #1A2A3A; }
.p1-body .ep-context-label { color: #7A9AB8; }
.p1-body .ep-context-input {
  background: #FFFFFF;
  border: 1.5px solid #C0D8EE;
  color: #1A2A3A;
  border-radius: 5px;
  width: 100%;
}
.p1-body .ep-context-input:focus {
  border-color: #5B9BD5;
  background: #F0F7FF;
}
.p1-body .ep-context-input::placeholder { color: #9BBAD6; }
.p1-body .ep-context-status.empty { color: #9BBAD6; }

/* ── ROUGH CUT (P2) ── */
.rc-body{flex:1;display:flex;min-height:0;overflow:hidden;}
.rc-panel{flex:1;overflow-y:auto;background:var(--dark3);padding:16px 20px 40px;}
.rc-header{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border);}
.rc-title{font-family:serif;font-size:18px;font-weight:800;color:var(--text-bright);letter-spacing:2px;}
.rc-meta{font-family:'DM Mono',monospace;font-size:9px;color:var(--muted);letter-spacing:1px;}
.rc-card{background:var(--dark2);border:1px solid var(--border);margin-bottom:10px;padding:0;transition:border-color .15s;}
.rc-card:hover{border-color:var(--border2);}
.rc-card-head{display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid var(--border);}
.rc-card-num{font-family:serif;font-size:14px;font-weight:800;color:#fff;padding:2px 8px;line-height:1.2;border-radius:2px;}
.rc-card-lines{font-family:'DM Mono',monospace;font-size:8px;color:var(--muted);letter-spacing:1px;}
.rc-card-body{padding:10px 12px;}
.rc-field{margin-bottom:6px;}
.rc-flabel{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:2px;color:var(--muted);text-transform:uppercase;margin-bottom:2px;}
.rc-fval{font-size:11.5px;color:var(--text);line-height:1.6;}
.rc-fval.dial{font-style:italic;color:var(--text-bright);border-left:2px solid var(--accent);padding-left:8px;}
.rc-scenario{padding:8px 12px;background:var(--dark);border-top:1px solid var(--border);font-family:'DM Mono',monospace;font-size:10px;color:var(--text-dim);line-height:1.7;white-space:pre-wrap;max-height:80px;overflow-y:auto;}
.rc-complete-btn{width:100%;padding:16px;background:var(--accent);color:#fff;border:none;font-family:serif;font-size:18px;font-weight:700;letter-spacing:3px;cursor:pointer;transition:background .2s;margin-top:16px;}
.rc-complete-btn:hover{background:var(--accent-hover);}
.rc-complete-btn:disabled{background:#2a2620;color:var(--muted);cursor:not-allowed;}
.rc-split-bar{height:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .12s;font-family:'DM Mono',monospace;font-size:8px;color:var(--accent);letter-spacing:1px;}
.rc-split-bar:hover{height:22px;opacity:1;background:rgba(192,57,43,.08);/* accent tint */}
.rc-shot-row{display:flex;align-items:center;gap:6px;padding:6px 12px 4px;}
.rc-shot-label{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:2px;color:var(--muted);text-transform:uppercase;flex-shrink:0;}
.rc-shot-select{flex:1;background:var(--dark);border:1px solid var(--border2);color:var(--text);font-family:'DM Mono',monospace;font-size:10px;letter-spacing:1px;padding:4px 8px;outline:none;cursor:pointer;}
.rc-shot-select:hover,.rc-shot-select:focus{border-color:var(--accent);}
.rc-shot-badge{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:1px;padding:2px 7px;border:1px solid;border-radius:2px;flex-shrink:0;}
.rc-char-edit{width:100%;background:transparent;border:none;border-bottom:1px dashed var(--border2);color:var(--text);font-family:'Noto Sans KR',sans-serif;font-size:11.5px;font-weight:300;line-height:1.6;padding:1px 2px;outline:none;resize:none;overflow:hidden;transition:background .15s,border-color .15s;min-height:22px;}
.rc-char-edit:hover{background:rgba(255,255,255,.03);border-color:var(--muted);}
.rc-char-edit:focus{background:rgba(255,255,255,.06);border-bottom:1px solid var(--accent);}
.analysis-panel{border-top:2px solid var(--rule);padding:16px 18px 18px 18px;background:rgba(29,158,117,.05);margin-top:16px;border-radius:2px;}
.analysis-btn{width:100%;padding:12px;background:var(--ink);color:var(--paper);border:none;font-family:serif;font-size:15px;font-weight:700;letter-spacing:3px;cursor:pointer;transition:background .2s;border-radius:4px;}
.analysis-btn:hover{background:var(--ink2);}
.analysis-btn:disabled{background:#2a2620;color:var(--muted);cursor:not-allowed;}
.analysis-result{margin-top:12px;font-size:11.5px;color:var(--text);line-height:1.75;display:none;}
.analysis-result.show{display:block;}
.ar-section{margin-bottom:12px;padding:10px;background:var(--dark2);border:1px solid var(--border);}
.ar-title{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:2px;color:var(--accent);text-transform:uppercase;margin-bottom:4px;}
.tension-chart{height:60px;display:flex;align-items:flex-end;gap:3px;padding:8px;background:var(--dark);border:1px solid var(--border);}
.tension-bar{flex:1;background:var(--accent);border-radius:1px 1px 0 0;min-height:3px;transition:height .3s;opacity:.7;}

/* ── RESIZER ── */
.resizer{width:8px;min-width:8px;flex-shrink:0;cursor:col-resize;background:var(--border);display:flex;align-items:center;justify-content:center;position:relative;transition:background .15s;user-select:none;z-index:10;}
.resizer:hover,.resizer.dragging{background:var(--accent);}
.resizer-dots{display:flex;flex-direction:column;gap:3px;pointer-events:none;}
.resizer-dot{width:2px;height:2px;border-radius:50%;background:var(--muted);transition:background .15s;}
.resizer:hover .resizer-dot,.resizer.dragging .resizer-dot{background:#fff;}

/* ── SCENARIO PANEL ── */
.spanel{flex:1;overflow-y:auto;background:var(--dark3);min-width:160px;}
.sheader{position:sticky;top:0;z-index:5;background:var(--dark2);border-bottom:1px solid var(--border);padding:9px 18px;display:flex;align-items:center;gap:8px;}
.shtitle{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:3px;color:var(--muted);text-transform:uppercase;}
.shhint{font-family:'DM Mono',monospace;font-size:9px;color:#3a3630;}
.sbody{padding:10px 18px 40px;}
.sl{padding:2px 10px 2px 24px;font-family:'DM Mono',monospace;font-size:11.5px;line-height:1.78;border-left:3px solid transparent;white-space:pre-wrap;word-break:break-word;min-height:22px;transition:filter .1s,background .15s;position:relative;cursor:text;}
.sl:hover{filter:brightness(1.25);}
.sl.empty{opacity:.22;min-height:14px;}
.sl.editing{background:rgba(255,255,255,.06);outline:1px solid var(--accent);outline-offset:-1px;cursor:text;}
.sl-scene{color:#c07040!important;font-weight:600!important;letter-spacing:.5px;}
.sl-scene-icon{margin-right:4px;}
.splitline{height:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .12s,height .12s;font-family:'DM Mono',monospace;font-size:8px;letter-spacing:2px;color:var(--text-dim);gap:8px;white-space:nowrap;}
.splitline:hover{opacity:1;height:20px;}
.splitline::before,.splitline::after{content:'';flex:1;height:1px;background:var(--border2);}
.cmark{display:flex;align-items:center;gap:8px;padding:5px 8px 4px;margin-top:6px;font-family:'DM Mono',monospace;font-size:9px;border-left:3px solid;}
.cmnum{font-weight:600;font-size:10px;flex-shrink:0;}
.cmcomp{color:var(--text-dim);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:9px;}

/* ── FULL EDIT (P3) ── */
.p2-body{flex:1;display:flex;min-height:0;overflow:hidden;}
.cpanel{width:360px;min-width:360px;flex-shrink:0;background:var(--paper);border-right:1px solid #c0b8a8;overflow-y:auto;position:relative;}
.cpanel::before{content:'';position:absolute;left:48px;top:0;bottom:0;width:1px;background:rgba(192,57,43,.15)/* accent tint */;pointer-events:none;}
.dheader{padding:22px 18px 16px 64px;border-bottom:2px solid var(--ink);}
.dtitle{font-family:serif;font-size:19px;font-weight:800;color:var(--ink);}
.dmeta{margin-top:5px;font-family:'DM Mono',monospace;font-size:9px;color:var(--ink3);display:flex;gap:12px;}
.dstamp{display:inline-block;border:2px solid var(--accent);color:var(--accent);font-family:serif;font-size:10px;font-weight:700;padding:2px 8px;letter-spacing:2px;margin-top:10px;transform:rotate(-1.5deg);}
.cc{border-bottom:1px solid var(--rule);padding:13px 16px 13px 64px;position:relative;}
.cm{position:absolute;left:0;top:13px;width:56px;text-align:center;}
.cnb{font-family:serif;font-size:13px;font-weight:800;color:#fff;padding:2px 6px;display:inline-block;line-height:1.2;}
.cns{font-family:'DM Mono',monospace;font-size:7px;letter-spacing:1px;display:block;margin-top:2px;}
.ctr{position:absolute;right:8px;top:8px;display:flex;gap:4px;opacity:0;transition:opacity .15s;}
.cc:hover .ctr{opacity:1;}
.ca{background:none;border:1px solid var(--rule);color:var(--ink4);font-family:'DM Mono',monospace;font-size:8px;letter-spacing:1px;padding:3px 7px;cursor:pointer;transition:all .15s;border-radius:4px;}
.ca:hover{border-color:var(--ink3);color:var(--ink2);}
.ca.r:hover{border-color:var(--accent);color:var(--accent);}
.cf{margin-bottom:5px;}
.cfk{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:2px;color:var(--ink4);text-transform:uppercase;margin-bottom:2px;}
.cfv{font-size:11.5px;color:var(--ink2);line-height:1.55;}
.cfv.comp{font-family:serif;font-weight:700;font-size:12px;}
.cfv.mood{font-weight:500;}
.cfv.dial{font-style:italic;color:var(--ink);border-left:2px solid var(--accent);padding-left:8px;}
.cfv.tip{background:rgba(192,57,43,.06);border-left:3px solid var(--accent);padding:5px 8px;font-size:11px;line-height:1.65;}
.cfrow{display:grid;grid-template-columns:1fr 1fr;gap:0 10px;}
.ctags{display:flex;flex-wrap:wrap;gap:3px;margin-top:6px;}
.ctag{font-family:'DM Mono',monospace;font-size:8px;padding:2px 6px;border:1px solid var(--rule);color:var(--ink3);}
.ep-info{background:#f0ece2;border-bottom:2px solid var(--rule);padding:16px 18px 16px 64px;}
.ep-info-title{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:3px;color:var(--accent);text-transform:uppercase;margin-bottom:12px;font-weight:600;}
/* ep-field: 라벨 + 인풋 수직 배치 */
.ep-field{display:flex;flex-direction:column;gap:4px;margin-bottom:10px;}
.ep-field:last-child{margin-bottom:0;}
.ep-row{display:flex;gap:6px;margin-bottom:5px;align-items:baseline;}
.ep-lbl{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:2px;color:var(--ink4);text-transform:uppercase;flex-shrink:0;}
.ep-val{font-size:11px;color:var(--ink2);line-height:1.55;flex:1;}
/* ep-input: 개선된 입력 필드 스타일 */
.ep-input{width:100%;background:var(--paper2);border:1px solid var(--rule);border-radius:4px;padding:7px 10px;outline:none;font-family:'Noto Sans KR',sans-serif;font-size:12px;font-weight:400;color:var(--ink);cursor:text;transition:border-color .15s,box-shadow .15s;box-sizing:border-box;}
.ep-input:focus{border-color:var(--ink3);box-shadow:0 0 0 2px rgba(26,24,20,0.08);}
.ep-input::placeholder{color:var(--ink4);font-size:11px;}
.ep-textarea{resize:vertical;min-height:60px;line-height:1.6;}
.ef{background:#ede8dc;border:1px solid var(--rule);padding:11px;margin-top:8px;}
.efrow{display:grid;grid-template-columns:1fr 1fr;gap:6px 10px;margin-bottom:6px;}
.efg{display:flex;flex-direction:column;gap:2px;}
.efg.full{grid-column:1/-1;}
.efl{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:2px;color:var(--ink4);text-transform:uppercase;}
.efi{background:var(--paper);border:1px solid var(--rule);color:var(--ink2);font-family:'Noto Sans KR',sans-serif;font-size:11px;font-weight:300;padding:5px 7px;outline:none;width:100%;resize:vertical;transition:border-color .15s;}
.efi:focus{border-color:var(--ink4);}
.efbtns{display:flex;gap:6px;margin-top:8px;}
.efsave{flex:1;background:var(--ink);color:var(--paper);border:none;font-family:'DM Mono',monospace;font-size:9px;letter-spacing:2px;padding:7px;cursor:pointer;border-radius:4px;}
.efsave:hover{background:var(--ink2);}
.efcancel{background:none;border:1px solid var(--rule);color:var(--ink3);font-family:'DM Mono',monospace;font-size:9px;letter-spacing:2px;padding:7px 10px;cursor:pointer;border-radius:4px;}
.efregen{background:none;border:1px solid #aed6f1;color:#2471a3;font-family:'DM Mono',monospace;font-size:9px;letter-spacing:1px;padding:7px 10px;cursor:pointer;}
.efregen:hover{background:rgba(55,138,221,.08);}
.imgp-area{border-top:1px solid var(--rule);margin-top:8px;padding:10px 14px 12px;}
.imgp-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:7px;}
.imgp-label{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:2px;color:#378ADD;text-transform:uppercase;}
.imgp-genbtn{background:none;border:1px solid #378ADD;color:#378ADD;font-family:'DM Mono',monospace;font-size:8px;letter-spacing:1px;padding:3px 10px;cursor:pointer;border-radius:4px;}
.imgp-genbtn:hover{background:#378ADD;color:#fff;}
.imgp-genbtn:disabled{opacity:.4;cursor:not-allowed;}
.imgp-box{background:#f0ece4;border:1px solid #c8c0b0;padding:10px 12px;font-family:'DM Mono',monospace;font-size:11px;line-height:1.75;color:#2a2a3a;white-space:pre-wrap;word-break:break-word;min-height:56px;cursor:text;}
.imgp-box.loading{color:#9a9488;font-style:italic;}
.imgp-box.empty{color:#b8b0a4;font-style:italic;font-size:10px;}
.imgp-actions{display:flex;gap:6px;margin-top:6px;}
.imgp-copybtn{background:none;border:1px solid var(--rule);color:var(--ink3);font-family:'DM Mono',monospace;font-size:8px;letter-spacing:1px;padding:3px 10px;cursor:pointer;border-radius:4px;}
.imgp-copybtn:hover{border-color:var(--ink4);color:var(--ink);}

/* ── RoughCut 이미지 프롬프트 버튼 ── */
.rc-imgp-row{padding:6px 12px 10px;border-top:1px solid var(--border);}
.rc-imgp-btn{background:none;border:1px solid rgba(55,138,221,0.5);color:#378ADD;font-family:'DM Mono',monospace;font-size:9px;letter-spacing:1px;padding:4px 12px;cursor:pointer;border-radius:4px;transition:all .15s;display:flex;align-items:center;gap:5px;width:100%;}
.rc-imgp-btn:hover{background:rgba(55,138,221,0.1);border-color:#378ADD;color:#62a8f0;}

/* ── DOWNLOAD BTNS ── */
.dl-group{display:flex;gap:4px;}
.dl-btn{display:flex;align-items:center;gap:5px;background:none;border:1px solid var(--border2);color:var(--text-dim);font-family:'DM Mono',monospace;font-size:9px;letter-spacing:1px;padding:5px 11px;cursor:pointer;transition:all .15s;text-transform:uppercase;border-radius:6px;}
.dl-btn:hover:not(:disabled){border-color:var(--text-dim);color:var(--text);}
.dl-btn:disabled{opacity:.25;cursor:not-allowed;}
.dl-btn.txt{border-color:#3a5a3a;color:#5a9a5a;}
.dl-btn.txt:hover:not(:disabled){background:#3a5a3a22;border-color:#7aba7a;color:#9ada9a;}
.dl-btn.pdf2{border-color:#5a3a2a;color:#c07040;}
.dl-btn.pdf2:hover:not(:disabled){background:#5a3a2a22;border-color:#c07040;color:#e09060;}
.dl-btn.docx{border-color:#2a3a5a;color:#4080c0;}
.dl-btn.docx:hover:not(:disabled){background:#2a3a5a22;border-color:#4080c0;color:#60a0e0;}
.dl-btn.imgp{border-color:#2a5a3a;color:#4a9a6a;}
.dl-btn.imgp:hover:not(:disabled){background:#2a5a3a22;border-color:#4a9a6a;color:#7aca9a;}
.save-btn{background:none;border:1px solid #3a6a3a;color:#5a9a5a;font-family:'DM Mono',monospace;font-size:9px;letter-spacing:1px;padding:5px 10px;cursor:pointer;transition:all .15s;border-radius:4px;}
.save-btn:hover{background:#3a6a3a22;border-color:#7aba7a;color:#9ada9a;}
.save-wrap{position:relative;display:inline-block;}
.save-menu{display:none;position:absolute;top:100%;right:0;margin-top:4px;background:var(--dark2);border:1px solid var(--border2);z-index:20;min-width:180px;box-shadow:0 4px 12px rgba(0,0,0,.4);}
.save-menu.show{display:block;}
.save-menu-item{display:flex;align-items:center;gap:8px;padding:10px 14px;font-family:'DM Mono',monospace;font-size:10px;color:var(--text);cursor:pointer;transition:background .12s;letter-spacing:1px;white-space:nowrap;}
.save-menu-item:hover{background:var(--dark3);}
.smi-icon{font-size:14px;flex-shrink:0;}
.load-btn{background:none;border:1px solid #5a5a3a;color:#9a9a5a;font-family:'DM Mono',monospace;font-size:9px;letter-spacing:1px;padding:5px 10px;cursor:pointer;transition:all .15s;}
.load-btn:hover{background:#5a5a3a22;border-color:#baba7a;color:#dada9a;}

/* ── STORYBOARD (P4) ── */
.sb-body{flex:1;overflow-y:auto;background:#1a1816;padding:32px;}
.sb-header{max-width:1100px;margin:0 auto 24px;display:flex;align-items:baseline;justify-content:space-between;}
.sb-title{font-family:serif;font-size:22px;font-weight:800;color:var(--text-bright);letter-spacing:2px;}
.sb-subtitle{font-family:'DM Mono',monospace;font-size:9px;color:var(--muted);letter-spacing:2px;}
.sb-grid{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;}
.sb-card{background:#111;border:1px solid var(--border);}
.sb-card-img{width:100%;aspect-ratio:16/9;overflow:hidden;background:#0a0a0a;position:relative;}
.sb-card-img-empty{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:'DM Mono',monospace;font-size:9px;color:#2a2620;letter-spacing:2px;}
.sb-card-body{padding:10px 12px 12px;}
.sb-card-top{display:flex;align-items:center;gap:8px;margin-bottom:6px;}
.sb-cut-type{font-family:'DM Mono',monospace;font-size:9px;color:var(--muted);flex:1;letter-spacing:1px;}
.sb-cut-phase{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:1px;}
.sb-comp{font-family:serif;font-size:12px;font-weight:700;margin-bottom:4px;}
.sb-desc{font-size:11px;color:#7a7670;line-height:1.6;margin-bottom:6px;}
.sb-dial{font-size:11px;color:#c0bcb4;font-style:italic;border-left:2px solid var(--accent);padding-left:8px;margin-bottom:6px;}
.sb-img-note{background:#1a1816;border:1px dashed var(--border);padding:8px;font-family:'DM Mono',monospace;font-size:8px;color:#3a3630;letter-spacing:1px;text-align:center;line-height:1.7;}
.pdf-btn{display:flex;align-items:center;gap:7px;background:var(--accent);border:none;color:#fff;font-family:'DM Mono',monospace;font-size:9px;letter-spacing:2px;padding:6px 16px;cursor:pointer;transition:all .15s;text-transform:uppercase;}
.pdf-btn:hover{background:var(--accent-hover);}

/* ── ADMIN DASHBOARD ── */
.admin-body{flex:1;overflow-y:auto;background:var(--dark3);padding:32px;}
.admin-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:24px;}
.admin-stat{background:var(--dark2);border:1px solid var(--border);padding:20px;}
.admin-stat-label{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:3px;color:var(--muted);text-transform:uppercase;margin-bottom:8px;}
.admin-stat-value{font-family:serif;font-size:28px;font-weight:800;color:var(--text-bright);}
.admin-stat-sub{font-family:'DM Mono',monospace;font-size:9px;color:var(--muted);margin-top:4px;}
.admin-table{width:100%;border-collapse:collapse;font-family:'DM Mono',monospace;font-size:10px;}
.admin-table th{padding:8px 12px;background:var(--dark);border-bottom:1px solid var(--border);color:var(--muted);letter-spacing:2px;text-align:left;text-transform:uppercase;}
.admin-table td{padding:8px 12px;border-bottom:1px solid var(--border);color:var(--text);}
.admin-table tr:hover td{background:var(--dark2);}
.badge{display:inline-block;font-family:'DM Mono',monospace;font-size:8px;letter-spacing:1px;padding:2px 7px;border-radius:2px;}
.badge.free{background:rgba(90,90,90,.2);color:var(--muted);border:1px solid var(--border);}
.badge.pro{background:rgba(192,57,43,.15);color:var(--accent);border:1px solid rgba(192,57,43,.3);}/* accent tint bg */
.badge.team{background:rgba(55,138,221,.15);color:#378ADD;border:1px solid rgba(55,138,221,.3);}

/* ── PRICING MODAL ── */
.pricing-modal{max-width:800px;width:100%;}

/* ── TOAST ── */
.toast{
  position:fixed;bottom:28px;right:28px;z-index:9999;
  background:rgba(247,249,252,0.95);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border:none;
  outline:1px solid var(--outline-variant);
  color:var(--on-surface);
  font-family:'Manrope',sans-serif;font-size:12px;font-weight:500;
  padding:12px 20px;display:none;animation:fadeInUp .25s;
  border-radius:var(--radius-md);
  box-shadow:var(--shadow-ambient);
}
.toast.show{display:block;}
.toast.success{outline-color:rgba(29,158,117,0.4);color:#1D9E75;}
.toast.error{outline-color:rgba(192,57,43,0.4);color:var(--red);}
@keyframes fadeInUp{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}
@keyframes spin{to{transform:rotate(360deg);}}
.spin{display:inline-block;animation:spin .8s linear infinite;}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:4px;height:4px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--outline);border-radius:4px;}
::-webkit-scrollbar-thumb:hover{background:var(--muted);}

/* ── DRAG & DROP (컷 순서 변경) ── */
.rc-card{cursor:default;transition:opacity .15s,box-shadow .15s,transform .15s;}
.rc-card.dragging{opacity:.4;box-shadow:none;transform:scale(.98);}
.rc-card.drag-over-above{box-shadow:0 -3px 0 0 var(--accent)!important;background:rgba(74,158,212,.06)!important;}
.rc-card.drag-over-below{box-shadow:0 3px 0 0 var(--accent)!important;background:rgba(74,158,212,.06)!important;}
.rc-drag-handle{font-size:14px;color:var(--muted);cursor:grab;padding:0 6px 0 2px;user-select:none;flex-shrink:0;letter-spacing:-2px;transition:color .15s;}
.rc-drag-handle:hover{color:var(--text);}
.rc-drag-handle:active{cursor:grabbing;}

.cc{cursor:default;transition:opacity .15s,box-shadow .15s,transform .15s;}
.cc.dragging{opacity:.4;transform:scale(.98);}
.cc.drag-over-above{box-shadow:0 -3px 0 0 var(--accent)!important;background:rgba(74,158,212,.06)!important;}
.cc.drag-over-below{box-shadow:0 3px 0 0 var(--accent)!important;background:rgba(74,158,212,.06)!important;}
.cc-drag-handle{position:absolute;left:0;top:0;width:56px;height:100%;display:flex;align-items:flex-start;justify-content:center;padding-top:6px;font-size:13px;color:transparent;cursor:grab;user-select:none;letter-spacing:-2px;transition:color .15s;z-index:1;}
.cc:hover .cc-drag-handle{color:var(--muted);}
.cc-drag-handle:hover{color:var(--text-dim)!important;}
.cc-drag-handle:active{cursor:grabbing;}

/* ── 컷 이미지 첨부 ── */
.cut-img-area{border-top:1px solid var(--rule);padding:10px 14px 6px;margin-top:2px;}
/* 업로드 드롭존 */
.cut-img-upload{border:1.5px dashed var(--border);border-radius:4px;padding:14px 12px;display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;transition:all .2s;background:transparent;}
.cut-img-upload:hover,.cut-img-upload.drag-active{border-color:#4a9ed4;background:rgba(74,158,212,.06);}
.cut-img-upload-icon{font-size:20px;color:var(--muted);line-height:1;}
.cut-img-upload-text{font-size:11px;color:var(--text-dim);letter-spacing:.3px;}
.cut-img-upload-sub{font-size:9px;color:var(--muted);font-family:'DM Mono',monospace;}
/* 썸네일 */
.cut-img-thumb-wrap{position:relative;display:inline-block;width:100%;border-radius:4px;overflow:hidden;line-height:0;}
.cut-img-thumb{width:100%;max-height:220px;object-fit:cover;display:block;border-radius:4px;cursor:pointer;transition:filter .2s;}
.cut-img-thumb:hover{filter:brightness(.75);}
.cut-img-thumb-overlay{position:absolute;top:6px;right:6px;display:flex;gap:4px;opacity:0;transition:opacity .2s;}
.cut-img-thumb-wrap:hover .cut-img-thumb-overlay{opacity:1;}
.cut-img-action-btn{background:rgba(10,10,10,.7);color:#fff;border:none;font-size:12px;width:26px;height:26px;border-radius:3px;cursor:pointer;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px);transition:background .15s;}
.cut-img-action-btn:hover{background:rgba(60,60,60,.9);}
.cut-img-action-btn.del:hover{background:rgba(192,57,43,.85);}/* del accent */
/* 하단 푸터 */
.cut-img-footer{display:flex;align-items:center;justify-content:space-between;margin-top:6px;gap:8px;}
.cut-img-url-toggle{background:transparent;border:none;color:var(--muted);font-size:10px;font-family:'DM Mono',monospace;cursor:pointer;padding:2px 0;transition:color .15s;}
.cut-img-url-toggle:hover{color:var(--text-dim);}
.cut-img-hint{font-size:9px;color:var(--muted);font-family:'DM Mono',monospace;}
/* URL 입력 행 */
.cut-img-url-row{display:flex;gap:5px;margin-top:6px;align-items:center;}
.cut-img-url-input{flex:1;background:var(--surface);border:1px solid var(--border);color:var(--text);font-size:11px;padding:5px 8px;border-radius:3px;outline:none;font-family:'DM Mono',monospace;}
.cut-img-url-input:focus{border-color:#4a9ed4;}
.cut-img-url-apply{background:#4a9ed4;color:#fff;border:none;font-size:11px;padding:5px 10px;border-radius:3px;cursor:pointer;white-space:nowrap;}
.cut-img-url-cancel{background:transparent;color:var(--muted);border:1px solid var(--border);font-size:11px;width:26px;height:26px;border-radius:3px;cursor:pointer;display:flex;align-items:center;justify-content:center;}
/* 라이트박스 */
.cut-img-lightbox{position:fixed;inset:0;background:rgba(0,0,0,.88);z-index:9999;display:flex;align-items:center;justify-content:center;cursor:zoom-out;}
.cut-img-lightbox-inner{position:relative;max-width:90vw;max-height:90vh;}
.cut-img-lightbox-img{max-width:90vw;max-height:88vh;object-fit:contain;border-radius:4px;box-shadow:0 8px 40px rgba(0,0,0,.6);}
.cut-img-lightbox-close{position:absolute;top:-14px;right:-14px;background:#333;color:#fff;border:none;width:28px;height:28px;border-radius:50%;font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;}
.cut-img-lightbox-close:hover{background:#555;}
/* 스토리보드 실제 이미지 */
.sb-card-img-actual{width:100%;height:100%;object-fit:cover;display:block;}

/* ── UNDO / REDO 버튼 ── */
.undo-redo-group{display:flex;align-items:center;gap:1px;}
.ur-btn{background:transparent;color:var(--text-dim);border:1px solid var(--border);font-size:13px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;line-height:1;}
.ur-btn:first-child{border-radius:3px 0 0 3px;}
.ur-btn:last-child{border-radius:0 3px 3px 0;border-left:none;}
.ur-btn:hover:not(:disabled){background:rgba(255,255,255,.08);color:var(--text);border-color:var(--text-dim);}
.ur-btn:disabled{opacity:.25;cursor:not-allowed;}
.ur-btn:active:not(:disabled){transform:scale(.92);}

/* ── 선택적 컷 분석 UI ── */
/* 네브바 버튼 */
.sel-analyze-btn{background:rgba(74,158,212,.12);color:#4a9ed4;border:1px solid rgba(74,158,212,.3);font-family:'DM Mono',monospace;font-size:10px;letter-spacing:1px;padding:5px 12px;cursor:pointer;transition:all .2s;white-space:nowrap;border-radius:4px;}
.sel-analyze-btn:hover{background:rgba(74,158,212,.22);border-color:#4a9ed4;}
.sel-analyze-btn:disabled{opacity:.4;cursor:not-allowed;}
.complete-analysis-btn{background:var(--accent);color:#fff;border:none;font-family:serif;font-size:13px;font-weight:700;letter-spacing:2px;padding:6px 18px;cursor:pointer;}
.complete-analysis-btn:disabled{opacity:.5;cursor:not-allowed;}
/* 선택 모드 컨트롤 바 */
.sel-analyze-bar{display:flex;align-items:center;gap:5px;}
.sel-count{font-family:'DM Mono',monospace;font-size:10px;color:#4a9ed4;letter-spacing:.5px;padding:0 4px;min-width:60px;}
.sel-mini-btn{background:rgba(255,255,255,.06);color:var(--text-dim);border:1px solid var(--border);font-size:10px;font-family:'DM Mono',monospace;padding:4px 8px;cursor:pointer;transition:all .15s;border-radius:4px;}
.sel-mini-btn:hover{background:rgba(255,255,255,.12);color:var(--text);}
.sel-mini-blue{color:#4a9ed4!important;border-color:rgba(74,158,212,.3)!important;}
.sel-run-btn{background:#4a9ed4;color:#fff;border:none;font-family:serif;font-size:11px;font-weight:700;letter-spacing:1px;padding:5px 14px;cursor:pointer;transition:all .2s;white-space:nowrap;border-radius:6px;}
.sel-run-btn:hover{background:#5aaedf;}
.sel-run-btn:disabled{opacity:.5;cursor:not-allowed;}
.sel-cancel-btn{background:transparent;color:var(--muted);border:1px solid var(--border);font-size:12px;padding:4px 8px;cursor:pointer;transition:color .15s;border-radius:4px;}
.sel-cancel-btn:hover{color:var(--text);}
/* 선택 모드 안내 배너 */
.sel-mode-banner{display:flex;align-items:center;gap:8px;padding:8px 14px;margin:0 0 4px;background:rgba(74,158,212,.08);border:1px solid rgba(74,158,212,.2);font-size:11px;color:#4a9ed4;letter-spacing:.3px;}
.sel-mode-icon{font-size:13px;flex-shrink:0;}
/* 컷 카드 선택 상태 */
.rc-card.rc-selectable{cursor:pointer;}
.rc-card.rc-selectable:hover{box-shadow:0 0 0 1px rgba(74,158,212,.4);background:rgba(74,158,212,.04)!important;}
.rc-card.rc-selected{box-shadow:0 0 0 2px #4a9ed4!important;background:rgba(74,158,212,.08)!important;}
.cc.cc-selectable{cursor:pointer;}
.cc.cc-selectable:hover{box-shadow:0 0 0 1px rgba(74,158,212,.4)!important;}
.cc.cc-selected{box-shadow:0 0 0 2px #4a9ed4!important;background:rgba(74,158,212,.08)!important;}
/* 체크박스 스타일 */
.rc-checkbox{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border:2px solid var(--border);border-radius:3px;font-size:11px;font-weight:700;color:transparent;background:transparent;flex-shrink:0;transition:all .15s;}
.rc-checkbox.checked{border-color:#4a9ed4;background:#4a9ed4;color:#fff;}
.cc-checkbox{position:absolute;left:18px;top:50%;transform:translateY(-50%);width:18px;height:18px;border:2px solid var(--border);border-radius:3px;font-size:11px;font-weight:700;color:transparent;display:flex;align-items:center;justify-content:center;background:transparent;transition:all .15s;z-index:2;}
.cc-checkbox.checked{border-color:#4a9ed4;background:#4a9ed4;color:#fff;}
/* 분석됨 배지 */
.rc-analyzed-badge{margin-left:auto;font-size:8px;font-family:'DM Mono',monospace;letter-spacing:.5px;color:#4dcfa0;background:rgba(29,158,117,.1);border:1px solid rgba(29,158,117,.25);padding:1px 6px;border-radius:2px;}

/* ── AUTO SAVE INDICATOR ── */
.autosave-indicator{display:flex;align-items:center;gap:5px;font-family:'DM Mono',monospace;font-size:9px;letter-spacing:1px;padding:4px 10px;border-radius:3px;transition:all .3s;white-space:nowrap;}
.autosave-indicator.saving{color:#e8a030;background:rgba(186,117,23,.12);border:1px solid rgba(186,117,23,.25);}
.autosave-indicator.saved{color:#4dcfa0;background:rgba(29,158,117,.12);border:1px solid rgba(29,158,117,.25);}
.autosave-indicator.error{color:#ff6b6b;background:rgba(192,57,43,.12);border:1px solid rgba(192,57,43,.25);}
.autosave-indicator.idle{color:var(--muted);background:transparent;border:1px solid transparent;}
.autosave-dot{width:5px;height:5px;border-radius:50%;background:currentColor;flex-shrink:0;}
.autosave-indicator.saving .autosave-dot{animation:autosave-pulse 1s ease-in-out infinite;}
@keyframes autosave-pulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.4;transform:scale(.8);}}

/* ── AUTO SAVE RESTORE BANNER ── */
.autosave-restore-banner{width:100%;max-width:560px;margin:0 auto 20px;background:rgba(55,138,221,.1);border:1px solid rgba(55,138,221,.3);border-radius:8px;padding:14px 18px;display:flex;align-items:center;gap:14px;flex-wrap:wrap;}
.autosave-restore-icon{font-size:20px;flex-shrink:0;}
.autosave-restore-text{flex:1;min-width:180px;font-size:13px;color:var(--text);}
.autosave-restore-text strong{color:var(--text-bright);display:block;margin-bottom:2px;}
.autosave-restore-time{font-family:'DM Mono',monospace;font-size:10px;color:var(--muted);letter-spacing:1px;}
.autosave-restore-actions{display:flex;gap:8px;flex-shrink:0;}
.autosave-restore-btn{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:1px;padding:5px 14px;border-radius:4px;cursor:pointer;transition:all .15s;text-transform:uppercase;}
.autosave-restore-btn.primary{background:#378ADD;color:#fff;border:none;}
.autosave-restore-btn.primary:hover{background:#2a6db5;}
.autosave-restore-btn.ghost{background:transparent;color:var(--muted);border:1px solid var(--border);}
.autosave-restore-btn.ghost:hover{color:var(--text);border-color:var(--border2);}

/* ── PRINT ── */
@media print{
  html,body{height:auto!important;overflow:visible!important;background:#fff!important;}
  .page-container{display:block!important;width:100%!important;height:auto!important;overflow:visible!important;animation:none!important;}
  .page{display:flex!important;width:100%!important;height:auto!important;}
  .tnav,.pdf-btn,.imgp-area,.ctr,.spanel,.resizer,.save-wrap,.dl-group,.tbtn,.tarrow,.toast,.modal-overlay,.autosave-indicator,.autosave-restore-banner{display:none!important;}
  .p2-body{display:flex!important;height:auto!important;overflow:visible!important;}
  .cpanel{width:100%!important;border:none!important;overflow:visible!important;height:auto!important;}
  .rc-body{display:block!important;height:auto!important;overflow:visible!important;}
  .rc-panel{overflow:visible!important;height:auto!important;}
  .cc{break-inside:avoid;page-break-inside:avoid;}
  .rc-card{break-inside:avoid;page-break-inside:avoid;}
  .sb-body{display:block!important;background:#fff!important;overflow:visible!important;height:auto!important;padding:16px!important;}
  .sb-grid{display:grid!important;grid-template-columns:repeat(3,1fr)!important;gap:10px!important;}
  .sb-card{break-inside:avoid;page-break-inside:avoid;background:#fff!important;border:1px solid #bbb!important;}
  .sb-card-img-empty{background:#f0f0f0!important;}
  .sb-comp,.sb-desc,.sb-dial{color:#333!important;}
  @page{margin:1.2cm;size:A4 landscape;}
}

/* ════════════════════════════════════════════
   공유 링크 네브바 버튼
   ════════════════════════════════════════════ */
.share-nav-btn{background:none;border:1px solid #2a4a3a;color:#4dcfa0;font-family:'DM Mono',monospace;font-size:9px;letter-spacing:1.5px;padding:5px 12px;cursor:pointer;transition:all .15s;text-transform:uppercase;}
.share-nav-btn:hover{border-color:#4dcfa0;background:rgba(77,207,160,.08);}

/* ════════════════════════════════════════════
   Share Modal
   ════════════════════════════════════════════ */
.share-modal{max-width:540px;width:90%;}
.share-modal-desc{margin:0 0 16px;font-size:12px;color:var(--text-dim);line-height:1.6;}
.share-modal-desc p{margin-bottom:8px;}
.share-feature-list{list-style:none;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:4px;}
.share-feature-list li{font-size:11px;color:var(--text-dim);}
.share-project-info{background:var(--dark3);border:1px solid var(--border);padding:12px 16px;margin-bottom:14px;}
.share-pi-title{font-size:14px;font-weight:700;color:var(--text-bright);margin-bottom:4px;}
.share-pi-meta{font-size:11px;color:var(--text-dim);display:flex;gap:6px;}
.share-url-area{margin-bottom:14px;min-height:56px;}
.share-url-box{display:flex;gap:8px;align-items:center;}
.share-url-input{flex:1;background:var(--dark);border:1px solid var(--border2);color:var(--text);font-family:'DM Mono',monospace;font-size:10px;padding:8px 12px;outline:none;letter-spacing:.5px;}
.share-url-input:focus{border-color:#4dcfa0;}
.share-url-meta{font-size:10px;color:var(--text-dim);margin-top:6px;}
.share-generating{display:flex;align-items:center;gap:10px;color:var(--text-dim);font-size:12px;padding:16px 0;}
.share-error-msg{color:#e8a030;font-size:12px;padding:12px;background:rgba(232,160,48,.08);border:1px solid rgba(232,160,48,.3);}
.share-spinner-sm{width:16px;height:16px;border:2px solid var(--border2);border-top-color:#4dcfa0;border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0;}
.share-modal-btns{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap;}
.share-copy-btn{flex:1;background:#1D9E75;border:none;color:#fff;font-family:'DM Mono',monospace;font-size:10px;letter-spacing:1.5px;padding:10px 16px;cursor:pointer;transition:all .15s;text-transform:uppercase;}
.share-copy-btn:hover{background:#157a5a;}
.share-copy-btn.copied{background:#4a8a70;}
.share-open-btn{background:none;border:1px solid var(--border2);color:var(--text);font-family:'DM Mono',monospace;font-size:9px;letter-spacing:1px;padding:10px 14px;cursor:pointer;transition:all .15s;text-transform:uppercase;border-radius:6px;}
.share-open-btn:hover{border-color:#4a9ed4;color:#4a9ed4;}
.share-cancel-btn{background:none;border:1px solid var(--border);color:var(--muted);font-family:'DM Mono',monospace;font-size:9px;letter-spacing:1.5px;padding:10px 14px;cursor:pointer;transition:all .15s;text-transform:uppercase;border-radius:6px;}
.share-cancel-btn:hover{border-color:var(--border2);color:var(--text);}
.share-notice{font-size:10px;color:var(--text-dim);padding:10px 12px;background:rgba(232,160,48,.06);border:1px solid rgba(232,160,48,.2);line-height:1.6;}
.share-notice strong{color:#e8a030;}

/* ════════════════════════════════════════════
   Share Page (읽기 전용 뷰어)
   ════════════════════════════════════════════ */
.share-page{min-height:100vh;background:var(--dark);color:var(--text);display:flex;flex-direction:column;}

/* 헤더 */
.share-header{height:48px;background:var(--dark2);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 24px;flex-shrink:0;}
.share-header-left{display:flex;align-items:center;gap:12px;}
.share-header-right{display:flex;align-items:center;gap:8px;}
.share-badge{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:2px;color:#4dcfa0;background:rgba(77,207,160,.1);border:1px solid rgba(77,207,160,.3);padding:3px 10px;text-transform:uppercase;}

/* 메타 */
.share-meta{padding:24px 32px 20px;border-bottom:1px solid var(--border);background:var(--dark2);}
.share-title{font-family:serif;font-size:26px;font-weight:700;color:var(--text-bright);margin-bottom:10px;}
.share-meta-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;}
.share-mode-badge{font-size:12px;color:var(--text);background:var(--dark3);border:1px solid var(--border2);padding:3px 10px;}
.share-count{font-size:12px;color:var(--text-dim);}
.share-date{font-size:11px;color:var(--muted);font-family:'DM Mono',monospace;}
.share-ep-info{margin-top:14px;background:var(--dark3);border:1px solid var(--border);padding:12px 16px;display:flex;flex-direction:column;gap:6px;}
.share-ep-row{display:flex;gap:12px;font-size:12px;}
.share-ep-label{color:var(--muted);font-family:'DM Mono',monospace;font-size:10px;letter-spacing:1px;width:56px;flex-shrink:0;}

/* 컷 목록 */
.share-cuts{flex:1;padding:24px 32px;display:flex;flex-direction:column;gap:16px;overflow-y:auto;max-width:900px;margin:0 auto;width:100%;}
.share-cut-card{border:1px solid;padding:0;overflow:hidden;}
.share-cut-header{display:flex;align-items:center;gap:8px;padding:10px 14px;background:rgba(0,0,0,.2);border-bottom:1px solid rgba(255,255,255,.06);}
.share-cut-label{font-family:'DM Mono',monospace;font-size:12px;font-weight:700;letter-spacing:1px;}
.share-cut-range{font-family:'DM Mono',monospace;font-size:10px;color:var(--muted);}
.share-beat-badge{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:1px;padding:2px 7px;color:#fff;}
.share-panel-badge{font-family:'DM Mono',monospace;font-size:9px;background:rgba(255,255,255,.08);color:var(--text-dim);padding:2px 7px;}
.share-cut-img{cursor:zoom-in;overflow:hidden;max-height:260px;border-bottom:1px solid rgba(255,255,255,.06);position:relative;}
.share-cut-img img{width:100%;object-fit:cover;display:block;transition:transform .2s;}
.share-cut-img:hover img{transform:scale(1.02);}
.share-cut-img-overlay{position:absolute;bottom:0;left:0;right:0;background:rgba(0,0,0,.5);color:#fff;font-size:10px;text-align:center;padding:4px;opacity:0;transition:opacity .2s;}
.share-cut-img:hover .share-cut-img-overlay{opacity:1;}
.share-cut-body{padding:12px 14px;display:flex;flex-direction:column;gap:8px;}
.share-cut-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;}
.share-cut-field{display:flex;flex-direction:column;gap:2px;}
.share-field-label{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:1.5px;color:var(--muted);text-transform:uppercase;}
.share-field-val{font-size:12px;color:var(--text);line-height:1.5;}
.share-cut-dialogue{background:rgba(255,255,255,.04);border-left:2px solid var(--accent);padding:8px 12px;}
.share-dialogue-text{font-size:13px;color:var(--text-bright);font-style:italic;line-height:1.6;margin-top:4px;}
.share-cut-tip{font-size:11px;color:#e8a030;display:flex;gap:8px;align-items:flex-start;}
.share-cut-script{border-top:1px solid rgba(255,255,255,.06);padding-top:8px;}
.share-script-text{font-size:11px;color:var(--muted);line-height:1.6;white-space:pre-wrap;margin-top:4px;font-family:'DM Mono',monospace;letter-spacing:.3px;}

/* 로딩/에러 */
.share-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:16px;color:var(--text-dim);}
.share-spinner{width:36px;height:36px;border:3px solid var(--border2);border-top-color:#4dcfa0;border-radius:50%;animation:spin .8s linear infinite;}
.share-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:12px;text-align:center;padding:32px;}
.share-error-icon{font-size:48px;}
.share-error h2{font-size:20px;color:var(--text-bright);}
.share-error p{font-size:13px;color:var(--text-dim);}

/* 푸터 */
.share-footer{background:var(--dark2);border-top:1px solid var(--border);padding:32px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px;}
.share-footer-logo{font-family:serif;font-size:22px;font-weight:800;color:var(--text-bright);letter-spacing:2px;}
.share-footer-logo em{color:var(--accent);font-style:normal;}
.share-footer p{font-size:12px;color:var(--muted);}

/* ════════════════════════════════════════════
   버전 히스토리 네브바 버튼
   ════════════════════════════════════════════ */
.vh-nav-btn{background:none;border:1px solid #2a3a5a;color:#7F77DD;font-family:'DM Mono',monospace;font-size:9px;letter-spacing:1.5px;padding:5px 12px;cursor:pointer;transition:all .15s;text-transform:uppercase;}
.vh-nav-btn:hover{border-color:#7F77DD;background:rgba(127,119,221,.08);}

/* ════════════════════════════════════════════
   Version History Modal
   ════════════════════════════════════════════ */
.vh-modal{max-width:520px;width:92%;max-height:85vh;display:flex;flex-direction:column;}

/* 액션 바 */
.vh-action-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 0;border-bottom:1px solid var(--border);margin-bottom:4px;flex-shrink:0;}
.vh-current-info{display:flex;align-items:center;gap:8px;flex:1;min-width:0;}
.vh-current-label{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:1.5px;color:var(--muted);text-transform:uppercase;flex-shrink:0;}
.vh-current-title{font-size:13px;color:var(--text-bright);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.vh-current-cuts{font-family:'DM Mono',monospace;font-size:10px;color:var(--text-dim);flex-shrink:0;}
.vh-save-btn{background:#7F77DD;border:none;color:#fff;font-family:'DM Mono',monospace;font-size:9px;letter-spacing:1.5px;padding:7px 14px;cursor:pointer;transition:all .15s;text-transform:uppercase;flex-shrink:0;}
.vh-save-btn:hover:not(:disabled){background:#6a62c5;}
.vh-save-btn:disabled{opacity:.3;cursor:not-allowed;}

/* 버전 목록 */
.vh-list{flex:1;overflow-y:auto;padding:8px 0;display:flex;flex-direction:column;gap:0;}
.vh-empty{text-align:center;padding:40px 20px;color:var(--text-dim);font-size:13px;line-height:1.7;}
.vh-empty-icon{font-size:36px;margin-bottom:12px;}

/* 타임라인 아이템 */
.vh-item{display:flex;gap:0;align-items:flex-start;}
.vh-timeline{display:flex;flex-direction:column;align-items:center;width:28px;flex-shrink:0;padding-top:4px;}
.vh-dot{width:10px;height:10px;border-radius:50%;border:2px solid;flex-shrink:0;z-index:1;}
.vh-line{width:2px;flex:1;min-height:16px;background:var(--border);margin-top:2px;}
.vh-item-body{flex:1;padding:0 0 16px 10px;}

/* 아이템 내용 */
.vh-item-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:6px;}
.vh-item-label{font-size:13px;color:var(--text-bright);font-weight:500;cursor:pointer;flex:1;line-height:1.4;}
.vh-item-label:hover{color:#e0dcd4;}
.vh-item-btns{display:flex;gap:4px;flex-shrink:0;}
.vh-btn{background:none;border:1px solid var(--border);color:var(--muted);padding:3px 7px;cursor:pointer;font-size:11px;transition:all .15s;border-radius:4px;}
.vh-btn:hover{border-color:var(--border2);color:var(--text);}
.vh-btn.vh-delete:hover{border-color:var(--accent);color:var(--accent);}

/* 이름 편집 */
.vh-edit-row{display:flex;gap:6px;align-items:center;flex:1;}
.vh-edit-input{flex:1;background:var(--dark);border:1px solid #7F77DD;color:var(--text-bright);font-size:12px;padding:4px 8px;outline:none;}
.vh-edit-ok{background:#7F77DD;border:none;color:#fff;padding:4px 10px;cursor:pointer;font-size:11px;}
.vh-edit-cancel{background:none;border:1px solid var(--border);color:var(--muted);padding:4px 8px;cursor:pointer;font-size:11px;}

/* 메타 정보 */
.vh-item-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:8px;}
.vh-trigger-badge{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:.5px;padding:2px 8px;}
.vh-date{font-family:'DM Mono',monospace;font-size:10px;color:var(--muted);}
.vh-cuts{font-family:'DM Mono',monospace;font-size:10px;color:var(--text-dim);}
.vh-title-diff{font-size:10px;color:var(--text-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:120px;}

/* 복원 확인 */
.vh-confirm{display:flex;align-items:center;gap:8px;padding:8px 10px;background:rgba(255,255,255,.04);border:1px solid var(--border2);margin-bottom:6px;font-size:11px;color:var(--text-dim);}
.vh-confirm-yes{background:var(--accent);border:none;color:#fff;padding:4px 12px;cursor:pointer;font-size:11px;}
.vh-confirm-yes.restore{background:#1D9E75;}
.vh-confirm-no{background:none;border:1px solid var(--border);color:var(--muted);padding:4px 10px;cursor:pointer;font-size:11px;}

/* 복원 버튼 */
.vh-restore-btn{background:none;border:1px solid var(--border);color:var(--text-dim);font-family:'DM Mono',monospace;font-size:9px;letter-spacing:1px;padding:5px 12px;cursor:pointer;transition:all .15s;text-transform:uppercase;border-radius:6px;}
.vh-restore-btn:hover{border-color:#1D9E75;color:#4dcfa0;background:rgba(29,158,117,.08);}

/* 푸터 */
.vh-footer{border-top:1px solid var(--border);padding:10px 0 0;display:flex;justify-content:space-between;font-size:10px;color:var(--muted);font-family:'DM Mono',monospace;flex-shrink:0;}

/* ════════════════════════════════════════════
   [추가] 5대 개선 기능 CSS
   ════════════════════════════════════════════ */

/* ── 1. 히어로 CTA + 샘플 카드 ── */
.hero-cta-area{margin-top:32px;display:flex;flex-direction:column;align-items:center;gap:12px;}
.btn-hero-start{
  padding:16px 44px;
  background:var(--primary-gradient);
  color:var(--on-primary);
  border:none;
  font-family:'Manrope',sans-serif;font-size:17px;font-weight:700;
  letter-spacing:0.5px;
  cursor:pointer;transition:all .25s;
  position:relative;overflow:hidden;
  border-radius:var(--radius-md);
  box-shadow:0 4px 20px rgba(85,95,113,0.3);
}
.btn-hero-start:hover{filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 8px 28px rgba(85,95,113,0.35);}
.btn-hero-start::after{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:linear-gradient(45deg,transparent 40%,rgba(255,255,255,.08) 50%,transparent 60%);animation:heroShine 3s ease-in-out infinite;}
@keyframes heroShine{0%{transform:translateX(-100%) rotate(45deg);}100%{transform:translateX(100%) rotate(45deg);}}
.hero-sub-text{font-family:'DM Mono',monospace;font-size:10px;color:var(--muted);letter-spacing:2px;}

.sample-section{max-width:720px;margin:0 auto;padding:32px 40px 8px;text-align:center;}
.sample-section-title{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:2px;color:var(--muted);margin-bottom:20px;}
.sample-section-title span{color:var(--editor-accent);}
.sample-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.sample-card{background:var(--surface);border:1.5px solid var(--border);padding:24px 18px;cursor:pointer;transition:all .25s;text-align:center;border-radius:4px;}
.sample-card:hover{border-color:var(--text-bright);background:var(--bg3);transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.08);}
.sample-card-icon{font-size:28px;margin-bottom:10px;}
.sample-card-title{font-family:serif;font-size:14px;font-weight:700;color:var(--text-bright);letter-spacing:.5px;margin-bottom:6px;}
.sample-card-desc{font-family:'DM Mono',monospace;font-size:9px;color:var(--text-dim);letter-spacing:.5px;line-height:1.6;}
.sample-card-tag{display:inline-block;font-family:'DM Mono',monospace;font-size:8px;letter-spacing:1px;padding:3px 10px;border:1px solid var(--border2);color:var(--muted);margin-top:10px;border-radius:10px;background:var(--bg);}

/* ── 2. 에피소드 컨텍스트 패널 ── */
.ep-context-panel{background:var(--dark);border:1px solid var(--border);padding:18px;margin-bottom:12px;}
.ep-context-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.ep-context-title{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:2px;color:var(--text-dim);text-transform:uppercase;display:flex;align-items:center;gap:8px;}
.ep-context-badge{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:1px;background:rgba(29,158,117,.12);color:#4dcfa0;border:1px solid rgba(29,158,117,.25);padding:2px 8px;}
.ep-context-toggle{background:none;border:1px solid var(--border);color:var(--muted);font-family:'DM Mono',monospace;font-size:9px;letter-spacing:1px;padding:4px 10px;cursor:pointer;transition:all .15s;}
.ep-context-toggle:hover{border-color:var(--border2);color:var(--text);}
.ep-context-fields{display:grid;grid-template-columns:1fr 1fr;gap:8px 12px;}
.ep-context-fields.collapsed{display:none;}
.ep-context-group{display:flex;flex-direction:column;gap:3px;}
.ep-context-group.full{grid-column:1/-1;}
.ep-context-label{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:2px;color:var(--muted);text-transform:uppercase;}
.ep-context-input{background:var(--dark2);border:1px solid var(--border);color:var(--text);font-family:'Noto Sans KR',sans-serif;font-size:11px;font-weight:300;padding:6px 8px;outline:none;transition:border-color .15s;resize:vertical;}
.ep-context-input:focus{border-color:var(--border2);}
.ep-context-input::placeholder{color:#252320;}
.ep-context-status{display:flex;align-items:center;gap:6px;margin-top:8px;font-family:'DM Mono',monospace;font-size:9px;letter-spacing:1px;}
.ep-context-status.empty{color:var(--muted);}
.ep-context-status.partial{color:#e8a030;}
.ep-context-status.full{color:#4dcfa0;}
.ep-context-dot{width:5px;height:5px;border-radius:50%;background:currentColor;}
.ep-char-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px;}
.ep-char-tag{display:inline-flex;align-items:center;gap:4px;font-family:'DM Mono',monospace;font-size:9px;padding:2px 8px;border:1px solid var(--border2);color:var(--text);background:var(--dark2);}
.ep-char-tag-del{cursor:pointer;color:var(--muted);font-size:11px;line-height:1;}
.ep-char-tag-del:hover{color:var(--accent);}

/* ── 3. 빈 상태 가이드 ── */
.empty-guide{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center;min-height:280px;}
.empty-guide.hidden{display:none;}
.empty-guide-icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center;font-size:28px;margin-bottom:20px;border:1px solid var(--border);background:var(--dark2);}
.empty-guide-title{font-family:serif;font-size:16px;font-weight:700;color:var(--text-bright);letter-spacing:1px;margin-bottom:8px;}
.empty-guide-desc{font-family:'DM Mono',monospace;font-size:10px;color:var(--muted);letter-spacing:.5px;line-height:1.7;max-width:380px;margin-bottom:20px;}
.empty-guide-flow{display:flex;gap:6px;margin-bottom:20px;flex-wrap:wrap;justify-content:center;}
.eg-step{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:1px;padding:4px 10px;border:1px solid var(--border);}
.eg-step.done{border-color:rgba(29,158,117,.3);color:#4dcfa0;background:rgba(29,158,117,.08);}
.eg-step.current{border-color:var(--accent);color:var(--accent);border-style:dashed;}
.eg-step.pending{color:var(--muted);}
.eg-arrow{color:var(--muted);font-size:10px;display:flex;align-items:center;}
.empty-guide-cta{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;}
.btn-empty-primary{padding:10px 22px;background:var(--accent);color:#fff;border:none;font-family:serif;font-size:14px;font-weight:700;letter-spacing:2px;cursor:pointer;transition:all .2s;border-radius:8px;}
.btn-empty-primary:hover{background:#a93226;}
.btn-empty-ghost{padding:10px 22px;background:none;color:var(--text-dim);border:1px solid var(--border);font-family:'DM Mono',monospace;font-size:10px;letter-spacing:1px;cursor:pointer;transition:all .15s;}
.btn-empty-ghost:hover{border-color:var(--border2);color:var(--text);}

/* 미리보기 목업 */
.empty-preview{background:var(--dark2);border:1px solid var(--border);padding:16px;margin-bottom:24px;max-width:360px;width:100%;}
.empty-preview-title{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:2px;color:var(--muted);text-transform:uppercase;margin-bottom:10px;text-align:left;}
.empty-preview-mock{display:flex;flex-direction:column;gap:6px;}
.epm-row{display:flex;gap:8px;align-items:center;}
.epm-num{width:28px;height:16px;background:var(--border);border-radius:1px;}
.epm-bar{flex:1;height:8px;background:var(--dark3);border:1px solid var(--border);border-radius:1px;}
.epm-bar.w60{width:60%;}
.epm-bar.w80{width:80%;}
.epm-bar.w40{width:40%;}

/* ── 4. PDF 다운로드 ── */
.pdf-download-area{display:flex;align-items:center;gap:10px;margin-top:12px;padding:14px 16px;background:var(--dark2);border:1px solid var(--border);}
.pdf-download-title{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:2px;color:var(--muted);text-transform:uppercase;flex-shrink:0;}
.btn-pdf-real{display:inline-flex;align-items:center;gap:7px;padding:10px 20px;background:linear-gradient(135deg,var(--accent),var(--accent-hover));color:#fff;border:none;font-family:serif;font-size:14px;font-weight:700;letter-spacing:2px;cursor:pointer;transition:all .2s;border-radius:8px;}
.btn-pdf-real:hover{background:linear-gradient(135deg,var(--accent-hover),#8e2b20);transform:translateY(-1px);box-shadow:0 4px 12px rgba(192,57,43,.3);}
.btn-pdf-real:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none;}
.pdf-opt-select{background:var(--dark);border:1px solid var(--border);color:var(--text);font-family:'DM Mono',monospace;font-size:10px;padding:6px 10px;outline:none;cursor:pointer;}
.pdf-opt-select:focus{border-color:var(--border2);}
.pdf-progress{display:none;align-items:center;gap:8px;font-family:'DM Mono',monospace;font-size:10px;color:var(--muted);letter-spacing:1px;}
.pdf-progress.show{display:flex;}
.pdf-progress-bar{width:80px;height:3px;background:var(--border);border-radius:2px;overflow:hidden;}
.pdf-progress-fill{height:100%;background:var(--accent);border-radius:2px;width:0%;transition:width .3s;}

/* ── 5. 컷 밀도 토글 ── */
.density-bar{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--dark2);border:1px solid var(--border);margin-bottom:12px;}
.density-label{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:2px;color:var(--muted);text-transform:uppercase;flex-shrink:0;}
.density-toggles{display:flex;gap:0;}
.density-btn{padding:6px 16px;border:1px solid var(--border);background:var(--dark);color:var(--muted);font-family:'DM Mono',monospace;font-size:10px;letter-spacing:1px;cursor:pointer;transition:all .15s;}
.density-btn:first-child{border-right:none;}
.density-btn:last-child{border-left:none;}
.density-btn.on{background:var(--dark3);color:var(--text-bright);border-color:var(--accent);}
.density-btn:hover:not(.on){background:var(--dark3);color:var(--text);}
.density-hint{font-family:'DM Mono',monospace;font-size:9px;color:var(--muted);letter-spacing:.5px;flex:1;}
.density-count{font-family:'DM Mono',monospace;font-size:10px;color:var(--text-dim);letter-spacing:1px;flex-shrink:0;}

/* ── 반응형 ── */
@media(max-width:768px){
  .sample-cards{grid-template-columns:1fr;}
  .ep-context-fields{grid-template-columns:1fr;}
  .density-bar{flex-wrap:wrap;}
  .pdf-download-area{flex-wrap:wrap;}
}

/* ════════════════════════════════════════════
   작업 9: 플롯 구조 분석 시스템
   ════════════════════════════════════════════ */

/* 플롯 선택기 */
.plot-selector{margin-top:12px;}
.plot-cat-btn{background:var(--dark);border:1px solid var(--border);color:var(--muted);font-family:'DM Mono',monospace;font-size:9px;padding:5px 10px;cursor:pointer;transition:all .15s;letter-spacing:1px;}
.plot-cat-btn:hover,.plot-cat-btn.active{border-color:var(--accent);color:var(--text-bright);}
.plot-list{max-height:240px;overflow-y:auto;margin:8px 0;}
.plot-item{display:flex;gap:10px;padding:8px 10px;border:1px solid var(--border);margin-bottom:4px;cursor:pointer;transition:all .15s;}
.plot-item:hover{border-color:var(--border2);background:var(--dark2);}
.plot-item.selected{border-color:var(--accent);background:rgba(192,57,43,.08);}
.plot-item-icon{font-size:20px;flex-shrink:0;padding-top:2px;}
.plot-item-name{font-family:serif;font-size:13px;font-weight:700;color:var(--text-bright);}
.plot-item-desc{font-size:10px;color:var(--muted);margin-top:2px;line-height:1.5;}
.plot-item-examples{font-family:'DM Mono',monospace;font-size:8px;color:var(--text-dim);margin-top:3px;letter-spacing:.5px;}
.plot-selected-info{background:var(--dark2);border:1px solid var(--accent);padding:12px;margin:8px 0;}

/* 플롯 타임라인 */
.plot-timeline{background:var(--dark2);border:1px solid var(--border);padding:10px 14px;margin-bottom:12px;}
.plot-timeline-title{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:2px;color:var(--muted);margin-bottom:8px;text-transform:uppercase;display:flex;align-items:center;}
.plot-timeline-bar{display:flex;height:28px;border-radius:2px;overflow:hidden;gap:1px;}
.plot-timeline-stage{position:relative;display:flex;align-items:center;justify-content:center;transition:opacity .15s;cursor:pointer;}
.plot-timeline-stage:hover{opacity:1!important;filter:brightness(1.3);}
.plot-timeline-label{font-family:'DM Mono',monospace;font-size:7px;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 3px;letter-spacing:.5px;}
.plot-timeline-missing{position:absolute;top:-2px;right:2px;font-size:8px;}
.plot-timeline-summary{font-family:'DM Mono',monospace;font-size:9px;color:var(--muted);margin-top:6px;display:flex;gap:12px;flex-wrap:wrap;}

/* 극적 상황 배지 */
.situation-badge{display:inline-block;font-family:'DM Mono',monospace;font-size:8px;letter-spacing:1px;padding:2px 7px;border-radius:2px;background:rgba(127,119,221,.12);border:1px solid rgba(127,119,221,.3);color:#7F77DD;}

/* 진단 패널 */
.plot-diagnostic{background:var(--dark3);border:1px solid var(--border);padding:14px;margin-top:10px;}
.plot-diag-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;}
.plot-diag-title{font-family:serif;font-size:14px;font-weight:700;color:var(--text-bright);}
.plot-diag-score{font-family:'DM Mono',monospace;font-size:18px;font-weight:700;color:var(--accent);}
.plot-diag-section{margin-bottom:10px;}
.plot-diag-section-title{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:2px;color:var(--accent);text-transform:uppercase;margin-bottom:5px;font-weight:600;}
.plot-diag-text{font-size:11px;color:var(--text);line-height:1.7;}
.plot-diag-item{display:flex;gap:8px;padding:5px 8px;margin-bottom:3px;font-size:11px;color:var(--text);line-height:1.6;border-left:3px solid var(--border);}
.plot-diag-item.good{border-left-color:#1D9E75;background:rgba(29,158,117,.05);}
.plot-diag-item.warn{border-left-color:#BA7517;background:rgba(186,117,23,.05);}
.plot-diag-item.bad{border-left-color:var(--accent);background:rgba(192,57,43,.05);}
.plot-diag-icon{font-size:12px;flex-shrink:0;padding-top:1px;}
/* ════════════════════════════════════════════
   촬영 기법 태그
   ════════════════════════════════════════════ */
.cine-tech-tag{display:inline-block;font-family:'DM Mono',monospace;font-size:8px;letter-spacing:.5px;padding:2px 7px;border-radius:2px;background:rgba(192,120,57,.1);border:1px solid rgba(192,120,57,.25);color:#c07839;cursor:help;margin-right:3px;margin-bottom:2px;}
.cine-tech-tag:hover{background:rgba(192,120,57,.2);border-color:rgba(192,120,57,.4);}
/* ══════════════════════════════════════════════
   구도(Composition) 추천 배지 시스템
   ══════════════════════════════════════════════ */

.comp-tag-row {
  display: flex;
  flex-wrap: wrap;
  gap: 3px;
  margin-top: 4px;
}

.comp-tag {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-family: 'DM Mono', monospace;
  font-size: 8px;
  letter-spacing: 0.5px;
  padding: 2px 7px;
  border-radius: 2px;
  cursor: help;
  transition: all 0.15s ease;
  text-transform: uppercase;
}

.comp-tag--primary {
  background: rgba(88, 166, 255, 0.12);
  border: 1px solid rgba(88, 166, 255, 0.3);
  color: #58a6ff;
}
.comp-tag--primary:hover {
  background: rgba(88, 166, 255, 0.22);
  border-color: rgba(88, 166, 255, 0.5);
}

.comp-tag--secondary {
  background: rgba(139, 148, 158, 0.08);
  border: 1px solid rgba(139, 148, 158, 0.2);
  color: #8b949e;
}
.comp-tag--secondary:hover {
  background: rgba(139, 148, 158, 0.15);
  border-color: rgba(139, 148, 158, 0.35);
}

.comp-tag__icon {
  font-size: 9px;
  line-height: 1;
}
.comp-tag__name {
  white-space: nowrap;
}

/* ── 구도 이유 텍스트 ── */
.comp-reason {
  display: flex;
  align-items: baseline;
  gap: 6px;
  margin-top: 4px;
  padding: 3px 0;
}
.comp-reason__label {
  font-family: 'DM Mono', monospace;
  font-size: 7px;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: #58a6ff;
  background: rgba(88, 166, 255, 0.08);
  padding: 1px 5px;
  border-radius: 2px;
  white-space: nowrap;
}
.comp-reason__text {
  font-size: 10px;
  color: var(--text, #adb5bd);
  line-height: 1.4;
}

/* ── 구도 툴팁 (title 속성 기반이지만, 커스텀 필요시) ── */
.comp-tag[title] {
  position: relative;
}

/* ══════════════════════════════════════════════
   프로젝트 대시보드 (Dashboard) — Light SaaS
   ══════════════════════════════════════════════ */

.dash-body{flex:1;overflow-y:auto;background:var(--surface);padding:0;}
.dash-header{padding:36px 48px 0;max-width:1200px;margin:0 auto;}
.dash-header-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;}
.dash-greeting{font-family:'Manrope',sans-serif;font-size:28px;font-weight:800;color:var(--on-surface);letter-spacing:-.3px;}
.dash-greeting em{color:var(--editor-accent);font-style:italic;}
.dash-header-actions{display:flex;gap:8px;align-items:center;}
.dash-toolbar{display:flex;align-items:center;gap:10px;margin-bottom:20px;flex-wrap:wrap;}
.dash-search{
  display:flex;align-items:center;gap:8px;
  background:var(--surface-lowest);
  border:none;
  outline:1px solid var(--outline-variant);
  padding:8px 14px;
  flex:1;max-width:360px;
  transition:outline-color .15s;border-radius:var(--radius-sm);
}
.dash-search:focus-within{outline-color:var(--primary);outline-width:2px;}
.dash-search-icon{color:var(--muted);font-size:14px;flex-shrink:0;}
.dash-search-input{background:none;border:none;color:var(--text-bright);font-size:13px;outline:none;width:100%;font-family:'Noto Sans KR',sans-serif;}
.dash-search-input::placeholder{color:var(--muted);}
.dash-view-btns{display:flex;gap:0;margin-left:auto;border:1px solid var(--border);border-radius:3px;overflow:hidden;}
.dash-view-btn{background:none;border:none;border-right:1px solid var(--border);color:var(--muted);font-size:14px;width:34px;height:34px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;}
.dash-view-btn:last-child{border-right:none;}
.dash-view-btn.active{background:var(--text-bright);color:#fff;}
.dash-view-btn:hover:not(.active){background:var(--bg3);color:var(--text-bright);}
.dash-sort-btn{background:var(--surface);border:1.5px solid var(--border);color:var(--text-dim);font-family:'DM Mono',monospace;font-size:10px;letter-spacing:1px;padding:7px 14px;cursor:pointer;transition:all .15s;border-radius:6px;}
.dash-sort-btn:hover{border-color:var(--accent);color:var(--text-bright);}
.dash-section-label{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:3px;color:var(--muted);text-transform:uppercase;margin-bottom:16px;padding:0 48px;max-width:1200px;margin-left:auto;margin-right:auto;}
.dash-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;padding:0 48px 48px;max-width:1200px;margin:0 auto;}
.dash-new-card{
  background:var(--surface-lowest);
  border:2px dashed var(--outline);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:12px;padding:32px 20px;cursor:pointer;transition:all .25s;min-height:200px;
  border-radius:var(--radius-md);
}
.dash-new-card:hover{
  border-color:var(--primary);border-style:solid;
  background:var(--surface-container-low);
  transform:translateY(-3px);
  box-shadow:var(--shadow-ambient);
}
.dash-new-icon{width:48px;height:48px;border-radius:50%;background:var(--bg3);border:1.5px solid var(--border2);display:flex;align-items:center;justify-content:center;font-size:22px;color:var(--text-dim);transition:all .2s;}
.dash-new-card:hover .dash-new-icon{background:var(--accent);border-color:var(--accent);color:#fff;transform:scale(1.05);}
.dash-new-title{font-family:serif;font-size:14px;font-weight:700;color:var(--text-bright);letter-spacing:.5px;}
.dash-new-desc{font-family:'DM Mono',monospace;font-size:9px;color:var(--muted);letter-spacing:1px;text-align:center;line-height:1.6;}
.dash-card{
  background:var(--surface-lowest);
  border:none;
  outline:1px solid var(--outline-variant);
  cursor:pointer;transition:all .25s;position:relative;overflow:hidden;
  display:flex;flex-direction:column;
  border-radius:var(--radius-md);
  box-shadow:var(--shadow-card);
}
.dash-card:hover{outline-color:var(--primary);transform:translateY(-3px);box-shadow:var(--shadow-ambient);}
.dash-card-thumb{height:90px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;border-bottom:1px solid var(--border);background:var(--bg);}
.dash-card-thumb-icon{font-size:36px;opacity:.65;transition:transform .2s;}
.dash-card:hover .dash-card-thumb-icon{transform:scale(1.1);opacity:.85;}
.dash-card-status{position:absolute;top:8px;right:8px;font-family:'DM Mono',monospace;font-size:7px;letter-spacing:1.5px;padding:3px 8px;text-transform:uppercase;border-radius:10px;}
.dash-card-status.draft{background:var(--bg3);color:var(--muted);border:1px solid var(--border2);}
.dash-card-status.in-progress{background:rgba(59,130,246,.1);color:#3B82F6;border:1px solid rgba(59,130,246,.25);}
.dash-card-status.complete{background:rgba(29,158,117,.1);color:#1D9E75;border:1px solid rgba(29,158,117,.25);}
.dash-card-body{padding:16px;flex:1;display:flex;flex-direction:column;}
.dash-card-title{font-family:serif;font-size:14px;font-weight:700;color:var(--text-bright);letter-spacing:.3px;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.dash-card-subtitle{font-family:'DM Mono',monospace;font-size:9px;color:var(--muted);letter-spacing:.5px;margin-bottom:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.dash-card-meta{display:flex;align-items:center;justify-content:space-between;margin-top:auto;}
.dash-card-date{font-family:'DM Mono',monospace;font-size:9px;color:var(--muted);letter-spacing:.5px;}
.dash-card-cuts{font-family:'DM Mono',monospace;font-size:9px;color:var(--text-dim);letter-spacing:.5px;}
.dash-card-menu{position:absolute;top:8px;right:8px;background:rgba(255,255,255,.9);border:1px solid var(--border2);color:var(--text-bright);width:26px;height:26px;font-size:14px;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transition:opacity .15s;border-radius:3px;}
.dash-card:hover .dash-card-menu{opacity:1;}
.dash-card-menu:hover{background:var(--bg3);}
.dash-card-dropdown{position:absolute;top:38px;right:8px;background:var(--surface);border:1.5px solid var(--border);z-index:20;min-width:150px;box-shadow:0 8px 24px rgba(0,0,0,.12);display:none;border-radius:4px;overflow:hidden;}
.dash-card-dropdown.show{display:block;}
.dash-card-dropdown-item{display:flex;align-items:center;gap:8px;padding:10px 14px;font-family:'DM Mono',monospace;font-size:10px;color:var(--text);cursor:pointer;transition:background .12s;letter-spacing:.5px;}
.dash-card-dropdown-item:hover{background:var(--bg3);}
.dash-card-dropdown-item.danger{color:var(--editor-accent);}
.dash-card-dropdown-item.danger:hover{background:rgba(192,57,43,.06);}/* accent tint */
.dash-card-progress{height:3px;background:var(--bg3);margin-top:10px;border-radius:2px;overflow:hidden;}
.dash-card-progress-fill{height:100%;border-radius:2px;transition:width .3s;}
.dash-empty{text-align:center;padding:80px 40px;max-width:1200px;margin:0 auto;}
.dash-empty-icon{font-size:56px;margin-bottom:20px;opacity:.4;}
.dash-empty-title{font-family:serif;font-size:20px;font-weight:700;color:var(--text-bright);letter-spacing:.5px;margin-bottom:10px;}
.dash-empty-desc{font-family:'DM Mono',monospace;font-size:11px;color:var(--muted);letter-spacing:.5px;line-height:1.8;margin-bottom:28px;}
.dash-empty-btn{display:inline-flex;align-items:center;gap:8px;padding:13px 28px;background:var(--accent);color:#fff;border:none;font-family:serif;font-size:14px;font-weight:700;letter-spacing:2px;cursor:pointer;transition:all .2s;border-radius:2px;}
.dash-empty-btn:hover{background:var(--accent-hover);transform:translateY(-1px);}
.dash-list{display:flex;flex-direction:column;gap:4px;padding:0 48px 48px;max-width:1200px;margin:0 auto;}
.dash-list-item{display:flex;align-items:center;gap:14px;padding:14px 18px;background:var(--surface);border:1.5px solid var(--border);cursor:pointer;transition:all .15s;border-radius:3px;}
.dash-list-item:hover{border-color:var(--text-bright);background:var(--bg3);}
.dash-list-icon{width:42px;height:42px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;border-radius:3px;background:var(--bg);}
.dash-list-info{flex:1;min-width:0;}
.dash-list-title{font-family:serif;font-size:14px;font-weight:700;color:var(--text-bright);letter-spacing:.3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.dash-list-sub{font-family:'DM Mono',monospace;font-size:9px;color:var(--muted);letter-spacing:.5px;margin-top:3px;}
.dash-list-meta{display:flex;flex-direction:column;align-items:flex-end;gap:2px;flex-shrink:0;}
.dash-list-date{font-family:'DM Mono',monospace;font-size:9px;color:var(--muted);}
.dash-list-cuts{font-family:'DM Mono',monospace;font-size:9px;color:var(--text-dim);}
.dash-list-del{background:none;border:1.5px solid var(--border);color:var(--muted);font-size:11px;padding:4px 10px;cursor:pointer;transition:all .15s;flex-shrink:0;border-radius:2px;}
.dash-list-del:hover{border-color:var(--editor-accent);color:var(--editor-accent);}
.dash-confirm-overlay{position:absolute;inset:0;z-index:200;background:rgba(0,0,0,.4);display:flex;align-items:center;justify-content:center;}
.dash-confirm{background:var(--surface);border:1.5px solid var(--border);padding:32px;max-width:380px;width:90%;text-align:center;border-radius:6px;box-shadow:0 20px 60px rgba(0,0,0,.2);}
.dash-confirm-icon{font-size:36px;margin-bottom:14px;}
.dash-confirm-title{font-family:serif;font-size:17px;font-weight:700;color:var(--text-bright);margin-bottom:8px;}
.dash-confirm-desc{font-size:13px;color:var(--text-dim);line-height:1.6;margin-bottom:24px;}
.dash-confirm-btns{display:flex;gap:8px;justify-content:center;}
.dash-confirm-del{background:var(--editor-accent);color:#fff;border:none;font-family:'DM Mono',monospace;font-size:10px;letter-spacing:1px;padding:10px 24px;cursor:pointer;border-radius:6px;}
.dash-confirm-del:hover{background:var(--accent-hover);}
.dash-confirm-cancel{background:none;border:1.5px solid var(--border2);color:var(--text-dim);font-family:'DM Mono',monospace;font-size:10px;letter-spacing:1px;padding:10px 20px;cursor:pointer;border-radius:6px;}
.dash-confirm-cancel:hover{border-color:var(--text-bright);color:var(--text-bright);}

/* ══════════════════════════════════════════════
   시대 배경 & 대사 톤 선택기
   ══════════════════════════════════════════════ */

.era-selector {
  margin-top: 10px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

/* 카테고리 탭 */
.era-cat-tabs {
  display: flex;
  gap: 0;
  border: 1px solid var(--rule);
  overflow: hidden;
}
.era-cat-tab {
  flex: 1;
  padding: 7px 8px;
  background: var(--paper);
  border: none;
  border-right: 1px solid var(--rule);
  color: var(--ink3);
  font-family: 'DM Mono', monospace;
  font-size: 9px;
  letter-spacing: 0.5px;
  cursor: pointer;
  transition: all 0.15s;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
}
.era-cat-tab:last-child { border-right: none; }
.era-cat-tab:hover { background: var(--paper2); color: var(--ink2); }
.era-cat-tab.active {
  background: var(--ink);
  color: var(--paper);
}

/* 프리셋 카드 */
.era-presets {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 6px;
}
.era-card {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  background: var(--paper);
  border: 1px solid var(--rule);
  cursor: pointer;
  transition: all 0.15s;
  position: relative;
}
.era-card:hover {
  border-color: var(--ink4);
  background: var(--paper2);
}
.era-card.active {
  border-color: var(--accent);
  background: rgba(192, 57, 43, 0.06);
}
.era-card-icon { font-size: 18px; flex-shrink: 0; }
.era-card-info { flex: 1; min-width: 0; }
.era-card-name {
  font-family: serif;
  font-size: 11px;
  font-weight: 700;
  color: var(--ink2);
  letter-spacing: 0.3px;
}
.era-card-period {
  font-family: 'DM Mono', monospace;
  font-size: 8px;
  color: var(--ink4);
  letter-spacing: 0.5px;
}
.era-card-check {
  position: absolute;
  top: 4px;
  right: 6px;
  color: var(--accent);
  font-size: 11px;
  font-weight: 700;
}

/* 미리보기 */
.era-preview {
  background: var(--paper2);
  border: 1px solid var(--rule);
  padding: 10px 12px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.era-preview-header {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: serif;
  font-size: 12px;
  font-weight: 700;
  color: var(--ink2);
}
.era-preview-desc {
  font-family: 'DM Mono', monospace;
  font-size: 9px;
  font-weight: 400;
  color: var(--ink4);
  letter-spacing: 0.5px;
}
.era-preview-sample {
  background: var(--paper);
  border: 1px solid var(--rule);
  padding: 8px 10px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.era-sample-before,
.era-sample-after {
  display: flex;
  gap: 8px;
  align-items: flex-start;
  font-size: 11px;
  line-height: 1.5;
}
.era-sample-label {
  font-family: 'DM Mono', monospace;
  font-size: 8px;
  letter-spacing: 1px;
  padding: 1px 6px;
  flex-shrink: 0;
  text-transform: uppercase;
}
.era-sample-before .era-sample-label {
  background: rgba(90, 90, 90, 0.1);
  color: var(--ink4);
  border: 1px solid var(--rule);
}
.era-sample-after .era-sample-label {
  background: rgba(192, 57, 43, 0.1);
  color: var(--accent);
  border: 1px solid rgba(192, 57, 43, 0.25);
}
.era-sample-text { color: var(--ink2); }
.era-sample-arrow {
  text-align: center;
  color: var(--accent);
  font-size: 12px;
  padding: 2px 0;
}

/* 대표 어휘 */
.era-preview-vocab {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  align-items: center;
}
.era-vocab-label {
  font-family: 'DM Mono', monospace;
  font-size: 8px;
  letter-spacing: 1px;
  color: var(--ink4);
  text-transform: uppercase;
  margin-right: 4px;
}
.era-vocab-tag {
  font-family: 'DM Mono', monospace;
  font-size: 9px;
  padding: 1px 6px;
  background: rgba(192, 120, 57, 0.08);
  border: 1px solid rgba(192, 120, 57, 0.2);
  color: #8a6a3a;
}

/* 커스텀 입력 */
.era-custom { margin-top: 4px; }
.era-custom-input {
  width: 100%;
  background: var(--paper);
  border: 1px solid var(--rule);
  color: var(--ink2);
  font-family: 'Noto Sans KR', sans-serif;
  font-size: 11px;
  font-weight: 300;
  padding: 8px 10px;
  outline: none;
  resize: vertical;
  line-height: 1.6;
  transition: border-color 0.15s;
}
.era-custom-input:focus { border-color: var(--ink4); }
.era-custom-input::placeholder { color: var(--ink4); opacity: 0.6; }


/* ════════════════════════════════════════════════════════
   RESPONSIVE — Mobile First
   브레이크포인트:
     --mobile  : max-width 767px  (폰)
     --tablet  : max-width 1024px (태블릿/소형 노트북)
   변수 기반으로 작성 → 데스크탑 디자인 바뀌어도
   이 블록은 수정 불필요
   ════════════════════════════════════════════════════════ */

/* ── viewport meta 보조 (overflow-x 방지) ── */
html { overflow-x: hidden; }

/* ════════ TABLET (≤1024px) ════════ */
@media (max-width: 1024px) {
  :root {
    --page-px: 32px;
    --hero-logo-size: 52px;
    --section-title-size: 30px;
  }

  .landing-hero {
    grid-template-columns: 1fr;
    padding: 60px var(--page-px) 40px;
    gap: 40px;
    min-height: auto;
    text-align: center;
  }
  .landing-hero-text { max-width: 560px; margin: 0 auto; }
  .landing-hero-eyebrow { justify-content: center; }
  .landing-hero-visual { max-width: 560px; margin: 0 auto; }
  .landing-desc { max-width: 100%; }
  /* Hero 데모 태블릿: 단일 열 */
  .hero-demo-body { grid-template-columns: 1fr; }
  .hero-demo-left { border-right: none; border-bottom: 1px solid rgba(255,255,255,.05); max-height: 140px; }
  .hero-demo-right { max-height: 160px; }

  /* 피처 그리드 2열 */
  .feature-grid { grid-template-columns: repeat(2, 1fr) !important; }

  /* 대시보드 */
  .dash-header { padding: 24px var(--page-px) 0; }
  .dash-grid   { padding: 0 var(--page-px) 40px; }
  .dash-list   { padding: 0 var(--page-px) 40px; }
  .dash-section-label { padding: 0 var(--page-px); }
}

/* ════════ MOBILE (≤767px) ════════ */
@media (max-width: 767px) {
  :root {
    --page-px: 20px;
    --nav-h: 56px;
    --editor-nav-h: 48px;
    --hero-logo-size: 40px;
    --hero-sub-size: 17px;
    --hero-desc-size: 14px;
    --section-title-size: 26px;
    --card-gap: 12px;
    --modal-w: 92vw;
    --editor-tab-h: 52px;   /* 모바일 탭바 높이 */
  }

  /* ── 랜딩 네브 ── */
  .landing-nav {
    height: var(--nav-h);
    padding: 0 var(--page-px);
  }
  .landing-nav-menu { display: none; } /* 메뉴 링크 숨김 */
  .landing-nav-actions { gap: 8px; }

  /* ── 랜딩 히어로 ── */
  .landing-hero {
    grid-template-columns: 1fr;
    padding: 40px var(--page-px) 32px;
    gap: 32px;
    min-height: auto;
    text-align: center;
  }
  .landing-hero-eyebrow { justify-content: center; }
  .landing-logo { font-size: var(--hero-logo-size); letter-spacing: 1px; }
  .landing-hero-sub { font-size: var(--hero-sub-size); }
  .landing-desc { font-size: var(--hero-desc-size); margin-bottom: 28px; }
  .landing-hero-visual { max-width: 100%; }
  .landing-hero-text { max-width: 100%; }
  /* Hero 데모 모바일 */
  .hero-demo-topbar { padding: 0 10px; }
  .hero-demo-tabs { display: none; }
  .hero-demo-body { grid-template-columns: 1fr; }
  .hero-demo-left { border-right: none; border-bottom: 1px solid rgba(255,255,255,.05); max-height: 110px; padding: 10px 12px; }
  .hero-demo-right { max-height: 130px; padding: 10px 12px; }
  .hero-demo-scenario-text { font-size: 9px; }
  .hero-demo-cut-shot { font-size: 8px; }
  .hero-demo-cut-subject { display: none; }

  /* 히어로 CTA 버튼 스택 */
  .hero-cta-area { gap: 10px; }
  .btn-hero-start { padding: 14px 32px; font-size: 15px; width: 100%; }
  .hero-sub-text { font-size: 9px; }

  /* ── 섹션 공통 ── */
  .features-section,
  .how-it-works,
  .pricing-section,
  .landing-cta-banner { padding: 60px var(--page-px); }

  .section-title,
  .features-title,
  .how-title,
  .pricing-title { font-size: var(--section-title-size) !important; }

  /* ── 피처 그리드 1열 ── */
  .feature-grid { grid-template-columns: 1fr !important; gap: var(--card-gap) !important; }
  .feature-card { padding: 20px 18px; }

  /* ── 요금제 ── */
  .pricing-grid { grid-template-columns: 1fr !important; max-width: 380px; margin: 0 auto; }
  .plan-card { border-right: none !important; border-bottom: 1px solid var(--border); }
  .plan-card:last-child { border-bottom: none; }

  /* ── CTA 배너 버튼 스택 ── */
  .landing-cta-actions { flex-direction: column; align-items: center; gap: 10px; }
  .btn-cta-white, .btn-cta-outline { width: 100%; max-width: 320px; padding: 14px 24px; }

  /* ── 샘플 카드 ── */
  .sample-cards { grid-template-columns: 1fr; }
  .sample-section { padding: 24px var(--page-px) 8px; }

  /* ── 랜딩 푸터 ── */
  .landing-footer { padding: 20px var(--page-px); }
  .landing-footer-inner { flex-direction: column; gap: 8px; text-align: center; }

  /* ── TopNav (에디터) ── */
  .tnav { padding: 0 12px; gap: 6px; height: var(--editor-nav-h); overflow-x: auto; overflow-y: hidden; }
  .tnav::-webkit-scrollbar { display: none; }
  .tstep-label { display: none; } /* 단계명 텍스트 숨김, 점만 표시 */
  .tstep { padding: 3px 8px; font-size: 8px; }
  .tarrow { padding: 5px 10px; font-size: 10px; }
  .tbtn  { padding: 4px 8px;  font-size: 9px; }

  /* ── P0 메인화면 카드 ── */
  .main-screen-wrap { padding: 20px 16px; }
  .main-screen { gap: 12px; }
  .main-card { width: 160px; height: 160px; gap: 10px; }
  .main-card-icon { font-size: 32px; }
  .main-card-title { font-size: 13px; }
  .main-card-desc { font-size: 9px; padding: 0 10px; }

  /* ── P1 시나리오 입력 ── */
  .p1-body { padding: 16px; }
  .icard { padding: 20px 16px; gap: 14px; }
  .icard-title { font-size: 17px; letter-spacing: 0.5px; }
  .mta { height: 200px; font-size: 12px; padding: 12px; }
  .mode-row { flex-direction: column; gap: 8px; }
  .mbtn { border-radius: var(--radius-md); }
  .mbtn:first-child { border-right: 1px solid var(--border); }
  .gbtn { font-size: 15px; padding: 13px; }

  /* ── 에피소드 컨텍스트 패널 ── */
  .ep-context-fields { grid-template-columns: 1fr; }
  .ep-context-panel { padding: 14px 12px; }

  /* ── 모바일 탭바 공통 ── */
  .mobile-tab-bar {
    display: flex !important;
    position: fixed;
    bottom: 0; left: 0; right: 0;
    height: var(--editor-tab-h);
    background: rgba(14,12,10,0.96);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-top: 1px solid var(--dark-border2);
    z-index: 200;
  }
  .mobile-tab-btn {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 3px;
    background: none;
    border: none;
    color: var(--dark-muted);
    font-family: 'Manrope', sans-serif;
    font-size: 9px;
    font-weight: 600;
    letter-spacing: 0.5px;
    cursor: pointer;
    transition: color .15s;
    padding: 6px 0;
  }
  .mobile-tab-btn.active { color: #fff; }
  .mobile-tab-btn-icon { font-size: 16px; line-height: 1; }

  /* ── P2 가편 (RoughCut) 모바일 ── */
  .rc-body {
    flex-direction: column;
    padding-bottom: var(--editor-tab-h); /* 탭바 공간 확보 */
  }
  /* 모바일에서 패널 탭 전환 */
  .rc-body .spanel   { display: none; }
  .rc-body .resizer  { display: none; }
  .rc-body .rc-panel { width: 100% !important; min-width: 0; }

  .rc-body.show-scenario .spanel   { display: flex !important; flex: 1; }
  .rc-body.show-scenario .rc-panel { display: none !important; }

  .rc-panel { padding: 12px 12px 24px; }

  /* RC 카드 간소화 */
  .rc-card { padding: 10px 12px; }

  /* ── P3 완성편집 (CompleteEdit) 모바일 ── */
  .p2-body {
    flex-direction: column;
    padding-bottom: var(--editor-tab-h);
  }
  .p2-body .cpanel   { display: none; }
  .p2-body .resizer  { display: none; }

  .p2-body.show-scenario .cpanel { display: flex !important; width: 100% !important; min-width: 0; border-right: none; border-bottom: 1px solid var(--rule); }
  .p2-body.show-scenario .full-edit-body { display: none !important; }

  .full-edit-body { padding-bottom: var(--editor-tab-h); }

  /* cc 카드 모바일 */
  .cc { padding-left: 12px; }
  .cc-drag-handle { display: none; }

  /* ── P4 스토리보드 ── */
  .sb-body { padding: 20px var(--page-px); padding-bottom: calc(var(--editor-tab-h) + 20px); }
  .sb-grid { grid-template-columns: 1fr !important; }

  /* ── 대시보드 ── */
  .dash-body { padding-bottom: 0; }
  .dash-header { padding: 20px var(--page-px) 0; }
  .dash-header-top { flex-direction: column; align-items: flex-start; gap: 12px; }
  .dash-greeting { font-size: 22px; }
  .dash-grid { grid-template-columns: 1fr !important; padding: 0 var(--page-px) 32px; gap: var(--card-gap); }
  .dash-list { padding: 0 var(--page-px) 32px; }
  .dash-section-label { padding: 0 var(--page-px); }
  .dash-toolbar { flex-wrap: wrap; gap: 8px; }
  .dash-search { max-width: 100%; }
  .dash-view-btns { margin-left: 0; }

  /* ── 모달 ── */
  .modal-overlay { align-items: flex-end; } /* 하단 시트로 */
  .modal {
    width: 100% !important;
    max-width: 100% !important;
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
    padding: 28px 20px 36px;
    max-height: 92vh;
    overflow-y: auto;
  }
  /* 모달 상단 드래그 핸들 */
  .modal::before {
    content: '';
    display: block;
    width: 40px; height: 4px;
    background: var(--outline);
    border-radius: 4px;
    margin: 0 auto 20px;
  }

  /* ── CharacterSheet 드로어 모바일 ── */
  .char-drawer {
    width: 100% !important;
    max-width: 100% !important;
    border-left: none !important;
    border-top: 1px solid var(--dark-border2) !important;
    top: auto !important;
    height: 80vh !important;
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  }

  /* ── Toast ── */
  .toast {
    bottom: calc(var(--editor-tab-h) + 12px);
    right: var(--page-px);
    left: var(--page-px);
    text-align: center;
  }

  /* ── 관리자 대시보드 ── */
  .admin-body { padding: 20px var(--page-px); }
  .admin-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .admin-table { font-size: 9px; }
  .admin-table th, .admin-table td { padding: 6px 8px; }

  /* ── 버전 히스토리 모달 ── */
  .vh-modal {
    width: 100% !important;
    max-width: 100% !important;
    max-height: 88vh;
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
    margin: 0;
  }

  /* ── Share 페이지 ── */
  .share-header { padding: 0 var(--page-px); }
  .share-meta   { padding: 16px var(--page-px); }
  .share-cuts   { padding: 16px var(--page-px); }
  .share-cut-grid { grid-template-columns: 1fr; }

  /* ── 밀도 바 ── */
  .density-bar { flex-wrap: wrap; gap: 6px; padding: 8px 12px; }

  /* ── DL 버튼 그룹 ── */
  .dl-group { flex-wrap: wrap; }

  /* ── UndoRedo ── */
  .undo-redo-group { display: none; } /* 모바일에선 숨김 (스와이프 제스처 대체 여지) */

  /* ── 빈 상태 가이드 ── */
  .empty-guide { padding: 32px 16px; }
  .empty-guide-flow { gap: 4px; }
  .eg-step { font-size: 8px; padding: 3px 7px; }

  /* ── 플롯 타임라인 ── */
  .plot-timeline { padding: 8px 10px; }
  .plot-timeline-bar { height: 22px; }

  /* ── 자동저장 배너 ── */
  .autosave-restore-banner { padding: 12px 14px; gap: 10px; }
  .autosave-restore-actions { width: 100%; justify-content: flex-end; }
}

/* ════════ VERY SMALL (≤380px) ════════ */
@media (max-width: 380px) {
  :root {
    --page-px: 14px;
    --hero-logo-size: 34px;
  }
  .landing-logo { letter-spacing: 0; }
  .main-card { width: 140px; height: 140px; }
  .admin-grid { grid-template-columns: 1fr; }
}

/* ════════════════════════════════════════════════════════
   ANALYSIS OVERLAY  (전역 AI 분석 오버레이 + 에러 배너)
   ════════════════════════════════════════════════════════ */

/* ── 전체화면 딤 오버레이 ── */
.analysis-overlay {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(8, 6, 4, 0.82);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  display: flex;
  align-items: center;
  justify-content: center;
}

.analysis-overlay-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  background: var(--surface, #1a1814);
  border: 1px solid var(--border, rgba(255,255,255,.08));
  border-radius: 16px;
  padding: 40px 48px;
  min-width: 320px;
  max-width: 440px;
  text-align: center;
  box-shadow: 0 24px 64px rgba(0,0,0,.6);
}

/* 아이콘 애니메이션 */
.ao-icon {
  font-size: 36px;
  animation: ao-bounce 1.2s ease-in-out infinite;
}
@keyframes ao-bounce {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-8px); }
}

.ao-msg {
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
  font-weight: 600;
  color: var(--text, #e8e0d0);
  letter-spacing: 0.3px;
  min-height: 20px;
}

/* 진행바 */
.ao-bar-wrap {
  width: 100%;
  height: 4px;
  background: rgba(255,255,255,.08);
  border-radius: 4px;
  overflow: hidden;
}
.ao-bar {
  height: 100%;
  background: linear-gradient(90deg, var(--accent, #e05c3a), #f08060);
  border-radius: 4px;
  transition: width 0.4s ease;
}

.ao-pct {
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  color: var(--muted, rgba(255,255,255,.4));
  letter-spacing: 1px;
}

/* 멈춤 경고 */
.ao-stuck-warn {
  font-family: 'Manrope', sans-serif;
  font-size: 12px;
  color: #f0a040;
  background: rgba(240,160,64,.1);
  border: 1px solid rgba(240,160,64,.25);
  border-radius: 8px;
  padding: 8px 12px;
  line-height: 1.5;
}

/* 취소 버튼 */
.ao-cancel-btn {
  margin-top: 4px;
  padding: 8px 24px;
  background: transparent;
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 8px;
  color: var(--muted, rgba(255,255,255,.45));
  font-family: 'Manrope', sans-serif;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.5px;
  cursor: pointer;
  transition: all .15s;
}
.ao-cancel-btn:hover {
  border-color: rgba(224,92,58,.5);
  color: #e05c3a;
  background: rgba(224,92,58,.06);
}

/* ── AI 에러 배너 ── */
.ai-error-banner {
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 9998;
  display: flex;
  align-items: flex-start;
  gap: 12px;
  background: var(--surface, #1a1814);
  border: 1px solid rgba(224,92,58,.4);
  border-radius: 12px;
  padding: 14px 16px;
  max-width: min(560px, calc(100vw - 32px));
  box-shadow: 0 8px 32px rgba(0,0,0,.4);
  animation: banner-in .25s ease;
}
/* 에러 코드별 border 색상 */
.ai-error-banner.ai-error-timeout    { border-color: rgba(240,160,64,.5); }
.ai-error-banner.ai-error-rate_limit { border-color: rgba(100,160,240,.5); }
.ai-error-banner.ai-error-network    { border-color: rgba(180,180,180,.4); }
.ai-error-banner.ai-error-parse_fail { border-color: rgba(160,100,240,.5); }

@keyframes banner-in {
  from { opacity: 0; transform: translateX(-50%) translateY(12px); }
  to   { opacity: 1; transform: translateX(-50%) translateY(0); }
}

.ai-error-icon {
  font-size: 18px;
  flex-shrink: 0;
  margin-top: 1px;
}
.ai-error-body {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.ai-error-msg {
  font-family: 'Manrope', sans-serif;
  font-size: 13px;
  color: var(--text, #e8e0d0);
  line-height: 1.4;
}
.ai-error-hint {
  font-family: 'Manrope', sans-serif;
  font-size: 11px;
  color: var(--muted, rgba(255,255,255,.4));
  line-height: 1.4;
}
.ai-error-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
  margin-top: 2px;
}
.ai-error-retry {
  padding: 6px 14px;
  background: var(--accent, #e05c3a);
  border: none;
  border-radius: 6px;
  color: #fff;
  font-family: 'Manrope', sans-serif;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  transition: opacity .15s;
  white-space: nowrap;
}
.ai-error-retry:hover { opacity: .85; }
.ai-error-dismiss {
  padding: 4px 8px;
  background: transparent;
  border: 1px solid var(--border, rgba(255,255,255,.1));
  border-radius: 6px;
  color: var(--muted, rgba(255,255,255,.4));
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  cursor: pointer;
  transition: color .15s, border-color .15s;
  line-height: 1.4;
  white-space: nowrap;
}
.ai-error-dismiss:hover { color: var(--text, #e8e0d0); border-color: var(--border2, rgba(255,255,255,.2)); }

/* 모바일 */
@media (max-width: 767px) {
  .analysis-overlay-box {
    padding: 28px 24px;
    min-width: 0;
    width: calc(100vw - 40px);
  }
  .ai-error-banner {
    bottom: calc(var(--editor-tab-h, 52px) + 12px);
    flex-wrap: wrap;
  }
}

/* ════════════════════════════════════════════════════════
   ONBOARDING MODAL
   ════════════════════════════════════════════════════════ */

.ob-overlay {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, 0.72);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  padding: 16px;
  animation: ob-overlay-in .2s ease;
}
@keyframes ob-overlay-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}

.ob-modal {
  position: relative;
  background: var(--surface, #1a1814);
  border: 1px solid var(--border, rgba(255,255,255,.1));
  border-radius: 20px;
  width: 100%;
  max-width: 640px;
  max-height: 90vh;
  overflow-y: auto;
  padding: 40px 40px 36px;
  box-shadow: 0 32px 80px rgba(0,0,0,.6);
  animation: ob-modal-in .3s cubic-bezier(.34,1.56,.64,1);
}
@keyframes ob-modal-in {
  from { opacity: 0; transform: translateY(24px) scale(.96); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* ── 진행 점 ── */
.ob-progress {
  display: flex;
  gap: 6px;
  justify-content: center;
  margin-bottom: 32px;
}
.ob-progress-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--border, rgba(255,255,255,.12));
  transition: background .2s, width .2s;
}
.ob-progress-dot.active {
  background: var(--accent, #e05c3a);
  width: 20px;
  border-radius: 3px;
}

/* ── 닫기 ── */
.ob-close {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 32px;
  height: 32px;
  background: transparent;
  border: 1px solid var(--border, rgba(255,255,255,.1));
  border-radius: 8px;
  color: var(--muted, rgba(255,255,255,.4));
  font-size: 14px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: color .15s, border-color .15s;
}
.ob-close:hover {
  color: var(--text, #e8e0d0);
  border-color: var(--border2, rgba(255,255,255,.2));
}

/* ── 공통 step 레이블 ── */
.ob-step-label {
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  letter-spacing: 2px;
  color: var(--accent, #e05c3a);
  margin-bottom: 12px;
  text-transform: uppercase;
}

/* ── 공통 액션 버튼 영역 ── */
.ob-actions {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  margin-top: 32px;
}
.ob-actions-bottom { margin-top: 20px; }

.ob-btn-primary {
  width: 100%;
  max-width: 340px;
  padding: 14px 24px;
  background: linear-gradient(135deg, var(--accent, #e05c3a) 0%, #ff7c54 100%);
  border: none;
  border-radius: 12px;
  color: #fff;
  font-family: 'Manrope', sans-serif;
  font-size: 15px;
  font-weight: 800;
  cursor: pointer;
  transition: transform .15s, box-shadow .15s;
  letter-spacing: .2px;
}
.ob-btn-primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 8px 24px rgba(224,92,58,.4);
}

.ob-btn-ghost {
  background: transparent;
  border: none;
  color: var(--muted, rgba(255,255,255,.4));
  font-family: 'Manrope', sans-serif;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: color .15s;
  padding: 4px 0;
}
.ob-btn-ghost:hover { color: var(--text, #e8e0d0); }

/* ════ STEP 1: 환영 ════ */
.ob-step-welcome { text-align: center; }

.ob-welcome-emoji {
  font-size: 56px;
  margin-bottom: 16px;
  line-height: 1;
  display: block;
}
.ob-welcome-title {
  font-family: 'Newsreader', Georgia, serif;
  font-size: 28px;
  font-weight: 700;
  color: var(--text-bright, #fff);
  line-height: 1.3;
  margin: 0 0 12px;
}
.ob-welcome-desc {
  font-family: 'Manrope', sans-serif;
  font-size: 15px;
  color: var(--text-dim, rgba(255,255,255,.6));
  line-height: 1.6;
  margin: 0 0 24px;
}
.ob-welcome-badges {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  margin-bottom: 4px;
}
.ob-badge {
  padding: 4px 12px;
  background: var(--dark2, rgba(255,255,255,.05));
  border: 1px solid var(--border, rgba(255,255,255,.1));
  border-radius: 20px;
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  letter-spacing: 1px;
  color: var(--text-dim, rgba(255,255,255,.5));
}

/* ════ STEP 2: 사용 방법 ════ */
.ob-how-title {
  font-family: 'Newsreader', Georgia, serif;
  font-size: 22px;
  font-weight: 700;
  color: var(--text-bright, #fff);
  margin: 0 0 24px;
}
.ob-how-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.ob-how-card {
  background: var(--dark2, rgba(255,255,255,.04));
  border: 1px solid var(--border, rgba(255,255,255,.08));
  border-radius: 12px;
  padding: 18px 14px;
  position: relative;
}
.ob-how-card-step {
  font-family: 'DM Mono', monospace;
  font-size: 9px;
  letter-spacing: 2px;
  color: var(--accent, #e05c3a);
  margin-bottom: 8px;
}
.ob-how-card-icon {
  font-size: 24px;
  margin-bottom: 10px;
  line-height: 1;
}
.ob-how-card-title {
  font-family: 'Manrope', sans-serif;
  font-size: 13px;
  font-weight: 700;
  color: var(--text-bright, #fff);
  margin-bottom: 6px;
}
.ob-how-card-desc {
  font-family: 'Manrope', sans-serif;
  font-size: 11px;
  color: var(--text-dim, rgba(255,255,255,.5));
  line-height: 1.5;
  margin-bottom: 10px;
}
.ob-how-card-tag {
  display: inline-block;
  padding: 2px 8px;
  background: var(--dark3, rgba(255,255,255,.06));
  border-radius: 4px;
  font-family: 'DM Mono', monospace;
  font-size: 9px;
  color: var(--muted, rgba(255,255,255,.3));
  letter-spacing: .5px;
}

/* ════ STEP 3: 샘플 선택 ════ */
.ob-sample-title {
  font-family: 'Newsreader', Georgia, serif;
  font-size: 22px;
  font-weight: 700;
  color: var(--text-bright, #fff);
  margin: 0 0 8px;
}
.ob-sample-desc {
  font-family: 'Manrope', sans-serif;
  font-size: 13px;
  color: var(--text-dim, rgba(255,255,255,.5));
  margin: 0 0 24px;
}
.ob-sample-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.ob-sample-card {
  background: var(--dark2, rgba(255,255,255,.04));
  border: 1px solid var(--border, rgba(255,255,255,.08));
  border-radius: 14px;
  padding: 20px 16px;
  cursor: pointer;
  text-align: left;
  transition: border-color .15s, background .15s, transform .15s;
  position: relative;
  overflow: hidden;
}
.ob-sample-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--ob-card-color, var(--accent));
  opacity: 0;
  transition: opacity .15s;
}
.ob-sample-card:hover,
.ob-sample-card.selected {
  border-color: var(--ob-card-color, var(--accent));
  background: rgba(255,255,255,.06);
  transform: translateY(-2px);
}
.ob-sample-card:hover::before,
.ob-sample-card.selected::before { opacity: 1; }

.ob-sample-card-icon {
  font-size: 28px;
  margin-bottom: 10px;
  line-height: 1;
  display: block;
}
.ob-sample-card-title {
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
  font-weight: 800;
  color: var(--text-bright, #fff);
  margin-bottom: 6px;
}
.ob-sample-card-desc {
  font-family: 'Manrope', sans-serif;
  font-size: 11px;
  color: var(--text-dim, rgba(255,255,255,.5));
  line-height: 1.5;
  margin-bottom: 10px;
}
.ob-sample-card-tag {
  display: inline-block;
  padding: 2px 8px;
  background: var(--dark3, rgba(255,255,255,.06));
  border-radius: 4px;
  font-family: 'DM Mono', monospace;
  font-size: 9px;
  color: var(--muted, rgba(255,255,255,.3));
  letter-spacing: .5px;
}
.ob-sample-card-arrow {
  position: absolute;
  bottom: 14px;
  right: 14px;
  font-size: 16px;
  color: var(--ob-card-color, var(--accent));
  opacity: 0;
  transition: opacity .15s, transform .15s;
}
.ob-sample-card:hover .ob-sample-card-arrow,
.ob-sample-card.selected .ob-sample-card-arrow {
  opacity: 1;
  transform: translateX(2px);
}

/* ── 모바일 ── */
@media (max-width: 767px) {
  .ob-modal {
    padding: 32px 20px 28px;
    border-radius: 20px 20px 0 0;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    max-width: 100%;
    max-height: 88vh;
    animation: ob-modal-in-mobile .3s cubic-bezier(.34,1.56,.64,1);
  }
  @keyframes ob-modal-in-mobile {
    from { transform: translateY(100%); }
    to   { transform: translateY(0); }
  }
  .ob-overlay { align-items: flex-end; padding: 0; }

  .ob-welcome-title { font-size: 22px; }
  .ob-welcome-emoji { font-size: 44px; }

  .ob-how-cards { grid-template-columns: 1fr; gap: 8px; }
  .ob-how-card { display: flex; align-items: flex-start; gap: 12px; padding: 14px 12px; }
  .ob-how-card-icon { font-size: 20px; flex-shrink: 0; margin-bottom: 0; }
  .ob-how-card-step { position: absolute; top: 10px; right: 10px; margin-bottom: 0; }

  .ob-sample-cards { grid-template-columns: 1fr; gap: 8px; }
  .ob-sample-card { display: flex; align-items: center; gap: 14px; padding: 14px 12px; }
  .ob-sample-card-icon { font-size: 22px; flex-shrink: 0; margin-bottom: 0; }
  .ob-sample-card-arrow { position: static; opacity: 1; margin-left: auto; flex-shrink: 0; }
  .ob-sample-card:hover .ob-sample-card-arrow { transform: none; }
}


/* ============================================================
   웹툰 세로 콘티 뷰어  (WebtoonVerticalViewer)
   ============================================================ */

/* ── 래퍼 ── */
.wv-wrapper {
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
}

/* ── 테마 버튼 바 ── */
.wv-theme-bar {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 20px;
  background: rgba(255,255,255,0.03);
  border-bottom: 1px solid rgba(255,255,255,0.07);
  flex-shrink: 0;
}
.wv-theme-btn {
  width: 30px; height: 30px;
  border-radius: 8px;
  border: 2px solid transparent;
  cursor: pointer;
  font-size: 14px;
  display: flex; align-items: center; justify-content: center;
  transition: border-color .2s, transform .15s;
  background: rgba(255,255,255,0.06);
}
.wv-theme-btn:hover  { transform: scale(1.1); }
.wv-theme-btn.active { border-color: #a78bfa; }
.wv-theme-btn[data-theme="white"] { background: #fff; }
.wv-theme-btn[data-theme="dark"]  { background: #1a1a2e; }
.wv-theme-btn[data-theme="print"] { background: #f5f0e8; }
.wv-theme-label {
  font-size: 11px; color: #666; margin-left: 6px; letter-spacing: .4px;
}

/* ── 뷰어 컨테이너 ── */
.wv-viewer {
  max-width: 760px;
  margin: 0 auto;
  width: 100%;
  padding: 0 20px 100px;
  overflow-y: auto;
  flex: 1;
  scroll-behavior: smooth;
}
.wv-viewer::-webkit-scrollbar { width: 5px; }
.wv-viewer::-webkit-scrollbar-track { background: transparent; }
.wv-viewer::-webkit-scrollbar-thumb {
  background: rgba(167,139,250,.3); border-radius: 3px;
}

/* 테마 */
.wv-viewer.theme-dark  { background: #0d0d1a; color: #e0e0e0; }
.wv-viewer.theme-white { background: #ffffff; color: #1a1a1a; }
.wv-viewer.theme-print { background: #f5f0e8; color: #2a2a2a; }

/* ── 에피소드 헤더 ── */
.wv-ep-header {
  text-align: center;
  padding: 40px 24px 32px;
  border-bottom: 1px solid rgba(167,139,250,.15);
  margin-bottom: 32px;
}
.wv-ep-badge {
  display: inline-block;
  padding: 4px 14px;
  background: rgba(167,139,250,.12);
  color: #a78bfa;
  border-radius: 20px;
  font-size: 12px; font-weight: 600;
  letter-spacing: .5px;
  margin-bottom: 12px;
}
.wv-ep-title {
  font-size: 22px; font-weight: 700;
  margin: 0 0 8px; line-height: 1.4;
}
.wv-ep-chars { font-size: 12px; color: #a78bfa; margin: 0 0 6px; }
.wv-ep-synopsis {
  font-size: 13px; color: #888; line-height: 1.65;
  max-width: 480px; margin: 0 auto;
}
.theme-white .wv-ep-title   { color: #111; }
.theme-white .wv-ep-synopsis { color: #555; }

/* ── 씬 구분선 ── */
.wv-scene-divider {
  display: flex; align-items: center; gap: 12px;
  padding: 22px 0; margin: 8px 0;
}
.wv-scene-divider::before,
.wv-scene-divider::after {
  content: '';
  flex: 1; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(167,139,250,.4), transparent);
}
.wv-scene-label {
  display: flex; align-items: center; gap: 6px;
  font-size: 13px; font-weight: 600; color: #a78bfa;
  white-space: nowrap;
}
.wv-scene-loc {
  font-weight: 400; color: #777; font-size: 12px;
}

/* ── 소 패널 2열 행 ── */
.wv-small-row {
  display: flex; gap: 12px; margin-bottom: 16px;
}
.wv-small-row .wv-cut-panel { margin-bottom: 0; }

/* ── 컷 패널 공통 ── */
.wv-cut-panel {
  margin-bottom: 16px;
  border-radius: 12px;
  overflow: hidden;
  background: rgba(255,255,255,0.03);
  transition: transform .2s, box-shadow .2s;
  position: relative;
}
.wv-cut-panel:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 32px rgba(0,0,0,.35);
}
.theme-white .wv-cut-panel { background: #f8f8fb; }
.theme-print .wv-cut-panel { background: #edeae2; }

/* 패널 크기별 */
.wv-size-large       { width: 100%; }
.wv-size-medium      { width: 100%; }
.wv-size-small       { width: 48%; flex-shrink: 0; }
.wv-size-small.wv-solo { width: 100%; }

/* 이미지 영역 - padding-top 비율로 높이 결정 */
.wv-image-area {
  position: relative; overflow: hidden;
  cursor: pointer;
}
.wv-size-large  .wv-image-area { padding-top: 56.25%; } /* 16:9 */
.wv-size-medium .wv-image-area { padding-top: 42%; }
.wv-size-small  .wv-image-area { padding-top: 75%; }    /* 세로형 */

/* 이미지 있음 */
.wv-img-has { position: absolute; inset: 0; }
.wv-img-has img {
  width: 100%; height: 100%; object-fit: cover;
  display: block;
}

/* 이미지 없음 — 플레이스홀더 */
.wv-img-placeholder {
  position: absolute; inset: 0;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  padding: 16px; text-align: center;
  background: rgba(255,255,255,.02);
}
.theme-white .wv-img-placeholder { background: #f0f0f8; }
.theme-print .wv-img-placeholder { background: #e8e3d8; }

.wv-ph-icon { font-size: 28px; opacity: .5; margin-bottom: 6px; }
.wv-ph-prompt {
  font-size: 11px; color: #888; line-height: 1.5;
  display: -webkit-box;
  -webkit-line-clamp: 2; -webkit-box-orient: vertical;
  overflow: hidden;
  margin-bottom: 10px;
  max-width: 90%;
  font-style: italic;
}
.wv-ph-hint { font-size: 12px; color: #666; margin-bottom: 10px; }
.wv-ph-actions { display: flex; gap: 6px; flex-wrap: wrap; justify-content: center; }
.wv-ph-btn {
  padding: 5px 11px;
  border-radius: 8px;
  border: 1px solid rgba(167,139,250,.3);
  background: rgba(167,139,250,.08);
  color: #a78bfa;
  font-size: 11px; cursor: pointer;
  transition: background .2s;
}
.wv-ph-btn:hover      { background: rgba(167,139,250,.2); }
.wv-ph-btn.primary    { background: rgba(167,139,250,.18); font-weight: 600; }
.wv-ph-btn:disabled   { opacity: .5; cursor: not-allowed; }

/* ── 컷 메타 ── */
.wv-cut-meta {
  display: flex; align-items: center; gap: 7px;
  padding: 10px 14px;
  flex-wrap: wrap;
}
.wv-cut-id {
  font-size: 12px; font-weight: 700;
  font-family: 'SF Mono', 'Fira Code', monospace;
}
.wv-meta-sep { color: #444; font-size: 10px; }
.wv-composition { font-size: 12px; color: #888; flex: 1; min-width: 0; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; }

/* 패널 크기 배지 버튼 */
.wv-size-badge {
  padding: 2px 10px; border-radius: 10px;
  font-size: 11px; font-weight: 700;
  cursor: pointer;
  border: none;
  transition: filter .2s, transform .15s;
  user-select: none;
  flex-shrink: 0;
}
.wv-size-badge:hover { filter: brightness(1.25); transform: scale(1.06); }
.wv-badge-large  { background: rgba(239,68,68,.15);  color: #ef4444; }
.wv-badge-medium { background: rgba(251,191,36,.15); color: #fbbf24; }
.wv-badge-small  { background: rgba(34,197,94,.15);  color: #22c55e; }

/* 편집 버튼 */
.wv-edit-btn {
  margin-left: auto; flex-shrink: 0;
  width: 28px; height: 28px;
  border-radius: 8px; border: none;
  background: rgba(255,255,255,.06);
  color: #888; font-size: 13px;
  cursor: pointer; transition: background .2s, color .2s;
  display: flex; align-items: center; justify-content: center;
}
.wv-edit-btn:hover { background: rgba(167,139,250,.15); color: #a78bfa; }

/* ── 대사 ── */
.wv-dialogue {
  padding: 2px 14px 12px;
  font-size: 13px; line-height: 1.7; color: #ccc;
}
.theme-white .wv-dialogue { color: #333; }
.wv-dialogue-char { font-weight: 700; color: #a78bfa; margin-right: 5px; font-size: 12px; }

/* ── 프롬프트 복사 바 ── */
.wv-prompt-bar { padding: 0 14px 12px; }
.wv-prompt-copy {
  background: none; border: none;
  color: #666; font-size: 12px;
  cursor: pointer; padding: 2px 0;
  transition: color .2s;
}
.wv-prompt-copy:hover { color: #a78bfa; }

/* ============================================================
   슬라이드 편집 패널
   ============================================================ */
.wv-ep-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.55);
  z-index: 1100;
  animation: wv-fade-in .25s ease;
}
.wv-ep-panel {
  position: fixed;
  top: 0; right: 0;
  width: 460px; max-width: 93vw;
  height: 100vh;
  background: #16162a;
  z-index: 1101;
  overflow-y: auto;
  box-shadow: -10px 0 48px rgba(0,0,0,.55);
  animation: wv-slide-in .32s cubic-bezier(.4,0,.2,1);
  display: flex; flex-direction: column;
}
@keyframes wv-fade-in  { from { opacity:0; } to { opacity:1; } }
@keyframes wv-slide-in { from { transform: translateX(100%); } to { transform: translateX(0); } }

.wv-ep-phead {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 22px;
  border-bottom: 1px solid rgba(255,255,255,.08);
  position: sticky; top: 0; background: #16162a; z-index: 2;
  flex-shrink: 0;
}
.wv-ep-phead h3 { margin: 0; font-size: 15px; color: #e0e0e0; }
.wv-ep-close {
  width: 34px; height: 34px; border-radius: 9px;
  border: none; background: rgba(255,255,255,.06);
  color: #aaa; font-size: 16px; cursor: pointer;
  transition: background .2s, color .2s;
}
.wv-ep-close:hover { background: rgba(255,255,255,.12); color: #fff; }

.wv-ep-body { padding: 20px 22px; flex: 1; }
.wv-ep-field { margin-bottom: 18px; }
.wv-ep-label {
  font-size: 11px; font-weight: 600; color: #777;
  text-transform: uppercase; letter-spacing: .5px;
  margin-bottom: 6px;
}
.wv-ep-input,
.wv-ep-textarea,
.wv-ep-select {
  width: 100%; padding: 9px 13px;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.1);
  background: rgba(255,255,255,.04);
  color: #e0e0e0; font-size: 14px; font-family: inherit;
  transition: border-color .2s;
  box-sizing: border-box;
}
.wv-ep-input:focus,
.wv-ep-textarea:focus,
.wv-ep-select:focus { outline: none; border-color: #a78bfa; }
.wv-ep-textarea     { min-height: 76px; resize: vertical; }
.wv-ep-prompt       { min-height: 110px; }
.wv-ep-select       { appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M0 0l6 8 6-8z' fill='%23888'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 12px center; padding-right: 32px; }

.wv-ep-btns { display: flex; gap: 10px; margin-top: 6px; }
.wv-ep-save {
  flex: 1; padding: 11px;
  border-radius: 10px; border: none;
  background: linear-gradient(135deg, #7c3aed, #a78bfa);
  color: #fff; font-weight: 700; font-size: 14px;
  cursor: pointer; transition: opacity .2s;
}
.wv-ep-save:hover { opacity: .9; }
.wv-ep-cancel {
  padding: 11px 20px;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.1);
  background: transparent; color: #888; font-size: 14px;
  cursor: pointer; transition: background .2s;
}
.wv-ep-cancel:hover { background: rgba(255,255,255,.06); color: #ccc; }

/* ============================================================
   인쇄 최적화
   ============================================================ */
@media print {
  .wv-theme-bar,
  .wv-ph-actions,
  .wv-prompt-bar,
  .wv-edit-btn,
  .wv-ep-overlay,
  .wv-ep-panel { display: none !important; }

  .wv-viewer { max-width: 100%; height: auto; overflow: visible; padding: 0; }
  .wv-cut-panel { break-inside: avoid; page-break-inside: avoid; box-shadow: none; transform: none; }
  .wv-scene-divider { page-break-before: auto; }
}

/* ============================================================
   모바일
   ============================================================ */
@media (max-width: 767px) {
  .wv-viewer { padding: 0 8px 90px; }
  .wv-size-small { width: 47%; }
  .wv-small-row { gap: 6px; }
  .wv-ep-header { padding: 28px 16px 20px; }
  .wv-ep-title { font-size: 18px; }
  .wv-ep-panel { width: 100vw; max-width: 100vw; }
  .wv-cut-meta { padding: 8px 10px; gap: 5px; }
  .wv-size-badge { padding: 2px 7px; }
}

/* ── 웹툰 뷰 전환 버튼 (tnav 내) ── */
.wv-view-toggle {
  display: flex;
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 8px;
  overflow: hidden;
}
.wv-toggle-btn {
  padding: 5px 12px;
  border: none;
  background: transparent;
  color: #888;
  font-size: 12px;
  cursor: pointer;
  transition: background .2s, color .2s;
  font-family: inherit;
  white-space: nowrap;
}
.wv-toggle-btn:hover { background: rgba(255,255,255,.06); color: #ccc; }
.wv-toggle-btn.on    { background: rgba(167,139,250,.18); color: #a78bfa; font-weight: 600; }

/* ── 세로 뷰어 전용 cpanel (스크롤바 없이 전체 채움) ── */
.wv-full-panel {
  overflow: hidden !important;
  display: flex;
  flex-direction: column;
}

/* 이미지 위 액션 버튼 */
.wv-img-actions {
  position: absolute; top: 8px; right: 8px;
  display: flex; gap: 4px;
  opacity: 0; transition: opacity .2s;
}
.wv-cut-panel:hover .wv-img-actions { opacity: 1; }
.wv-img-action-btn {
  width: 30px; height: 30px; border-radius: 8px;
  border: none; background: rgba(0,0,0,.6);
  color: #fff; cursor: pointer; font-size: 14px;
  backdrop-filter: blur(4px);
  transition: background .2s;
  display: flex; align-items: center; justify-content: center;
}
.wv-img-action-btn:hover { background: rgba(0,0,0,.85); }

/* ══════════════════════════════════════════════════════════════
   ⚡ 파이프라인 UI — 단계 진행 표시기 & 결과 배너
   ══════════════════════════════════════════════════════════════ */

/* 파이프라인 버튼 강조 */
.pipeline-btn {
  background: linear-gradient(135deg, #7c3aed, #4f46e5) !important;
  border-color: rgba(124,58,237,.5) !important;
  color: #fff !important;
  font-weight: 600;
  letter-spacing: .02em;
  box-shadow: 0 2px 12px rgba(124,58,237,.35);
  transition: all .2s;
}
.pipeline-btn:hover:not(:disabled) {
  background: linear-gradient(135deg, #6d28d9, #4338ca) !important;
  box-shadow: 0 4px 18px rgba(124,58,237,.5);
  transform: translateY(-1px);
}
.pipeline-btn:disabled {
  opacity: .55;
  cursor: not-allowed;
  transform: none;
}

/* 단계 진행 표시기 */
.pipeline-progress-bar {
  margin: 10px 0 6px;
  padding: 12px 16px;
  background: rgba(124,58,237,.08);
  border: 1px solid rgba(124,58,237,.2);
  border-radius: 10px;
}
.pipeline-stages {
  display: flex;
  align-items: center;
  gap: 0;
  margin-bottom: 8px;
}
.pipeline-stage-step {
  display: flex;
  align-items: center;
  gap: 0;
  flex: 1;
}
.pss-circle {
  width: 28px; height: 28px;
  border-radius: 50%;
  background: rgba(255,255,255,.06);
  border: 2px solid rgba(255,255,255,.15);
  color: rgba(255,255,255,.4);
  font-size: 12px; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  transition: all .3s;
}
.pipeline-stage-step.done .pss-circle {
  background: rgba(124,58,237,.4);
  border-color: #7c3aed;
  color: #c4b5fd;
}
.pipeline-stage-step.active .pss-circle {
  background: #7c3aed;
  border-color: #a78bfa;
  color: #fff;
  box-shadow: 0 0 10px rgba(124,58,237,.6);
  animation: pulse-stage .9s ease-in-out infinite;
}
@keyframes pulse-stage {
  0%, 100% { box-shadow: 0 0 10px rgba(124,58,237,.6); }
  50%       { box-shadow: 0 0 18px rgba(124,58,237,.95); }
}
.pss-label {
  font-size: 11px;
  color: rgba(255,255,255,.4);
  white-space: nowrap;
  margin: 0 4px;
  transition: color .3s;
}
.pipeline-stage-step.done  .pss-label  { color: #c4b5fd; }
.pipeline-stage-step.active .pss-label { color: #a78bfa; font-weight: 600; }
.pss-line {
  flex: 1;
  height: 2px;
  background: rgba(255,255,255,.1);
  border-radius: 1px;
  transition: background .3s;
  min-width: 16px;
}
.pss-line.done { background: rgba(124,58,237,.5); }
.pipeline-msg {
  font-size: 12px;
  color: rgba(255,255,255,.5);
  text-align: center;
  animation: blink-msg 1.4s ease-in-out infinite;
}
@keyframes blink-msg {
  0%, 100% { opacity: 1; }
  50%       { opacity: .6; }
}

/* 파이프라인 결과 배너 */
.pipeline-result-banner {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 14px;
  border-radius: 9px;
  margin: 8px 0;
  font-size: 13px;
  border: 1px solid;
  animation: slide-in-banner .3s ease;
}
@keyframes slide-in-banner {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}
.pipeline-result-banner.clean {
  background: rgba(16,185,129,.08);
  border-color: rgba(16,185,129,.25);
  color: #6ee7b7;
}
.pipeline-result-banner.has-issues {
  background: rgba(245,158,11,.08);
  border-color: rgba(245,158,11,.25);
  color: #fcd34d;
}
.prb-icon { font-size: 16px; flex-shrink: 0; }
.prb-text { flex: 1; }
.prb-text strong { display: block; font-size: 13px; font-weight: 600; }
.prb-detail { font-size: 11px; opacity: .75; margin-top: 1px; }
.prb-close {
  background: none; border: none;
  color: inherit; opacity: .5;
  cursor: pointer; font-size: 14px;
  padding: 2px 6px; border-radius: 4px;
  transition: opacity .2s, background .2s;
}
.prb-close:hover { opacity: 1; background: rgba(255,255,255,.08); }

/* ══════════════════════════════════════════════════════════════════════════
   DemoTutorialOverlay (dto-*) — 체험 전 사용법 가이드 오버레이
   ══════════════════════════════════════════════════════════════════════════ */

/* 배경 오버레이 */
.dto-overlay {
  position: fixed; inset: 0; z-index: 9900;
  background: rgba(0,0,0,.78);
  backdrop-filter: blur(6px);
  display: flex; align-items: center; justify-content: center;
  padding: 16px;
  animation: dtoFadeIn .25s ease;
}
@keyframes dtoFadeIn { from { opacity: 0 } to { opacity: 1 } }

/* 모달 카드 */
.dto-modal {
  background: var(--surface, #131722);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 16px;
  width: min(960px, 100%);
  max-height: 90vh;
  overflow: hidden;
  display: flex; flex-direction: column;
  box-shadow: 0 32px 80px rgba(0,0,0,.6);
  animation: dtoSlideUp .3s cubic-bezier(.22,1,.36,1);
}
@keyframes dtoSlideUp { from { transform: translateY(24px); opacity: 0 } to { transform: translateY(0); opacity: 1 } }

/* 헤더 */
.dto-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 28px 16px;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.dto-header-title { display: flex; align-items: center; gap: 8px; }
.dto-brand { font-family: 'Manrope', serif; font-size: 16px; font-weight: 800; color: var(--text-bright, #fff); letter-spacing: .5px; }
.dto-brand em { color: var(--editor-accent, #5B8CF0); font-style: normal; }
.dto-header-sep { color: rgba(255,255,255,.2); font-size: 14px; }
.dto-header-sub { font-family: 'DM Mono', monospace; font-size: 11px; color: var(--muted, #5a6270); letter-spacing: 1px; text-transform: uppercase; }
.dto-close-btn {
  background: none; border: none;
  color: rgba(255,255,255,.35); font-size: 18px; cursor: pointer;
  width: 32px; height: 32px; border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  transition: background .15s, color .15s;
}
.dto-close-btn:hover { background: rgba(255,255,255,.08); color: rgba(255,255,255,.8); }

/* 진행 단계 도트 */
.dto-progress-steps {
  position: relative;
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 28px;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.dto-progress-steps::before {
  content: ''; position: absolute;
  left: 28px; right: 28px; height: 1px;
  background: rgba(255,255,255,.08);
  top: 50%; transform: translateY(-50%);
  z-index: 0;
}
.dto-step-track-fill {
  position: absolute; left: 28px; height: 1px;
  background: var(--editor-accent, #5B8CF0);
  top: 50%; transform: translateY(-50%);
  z-index: 1;
  transition: width .4s ease;
  pointer-events: none;
}
.dto-step-dot {
  position: relative; z-index: 2;
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  cursor: pointer;
}
.dto-step-dot-inner {
  width: 14px; height: 14px; border-radius: 50%;
  background: rgba(255,255,255,.12);
  border: 2px solid rgba(255,255,255,.18);
  transition: all .2s;
}
.dto-step-dot.active .dto-step-dot-inner {
  background: var(--editor-accent, #5B8CF0);
  border-color: var(--editor-accent, #5B8CF0);
  box-shadow: 0 0 10px rgba(91,140,240,.5);
  transform: scale(1.25);
}
.dto-step-dot.done .dto-step-dot-inner {
  background: rgba(91,140,240,.35);
  border-color: var(--editor-accent, #5B8CF0);
}
.dto-step-dot-label {
  font-family: 'DM Mono', monospace;
  font-size: 9px; font-weight: 600;
  color: rgba(255,255,255,.3);
  letter-spacing: .8px; text-transform: uppercase;
  white-space: nowrap;
}
.dto-step-dot.active .dto-step-dot-label { color: var(--editor-accent, #5B8CF0); }
.dto-step-dot.done .dto-step-dot-label { color: rgba(91,140,240,.7); }

/* 본문 (좌: 설명 / 우: 스크린) */
.dto-body {
  display: grid; grid-template-columns: 280px 1fr;
  gap: 0; flex: 1; overflow: hidden;
}

/* 좌: 설명 영역 */
.dto-info {
  padding: 28px 24px 24px;
  border-right: 1px solid rgba(255,255,255,.06);
  display: flex; flex-direction: column; gap: 14px;
  overflow-y: auto;
  transition: transform .26s ease, opacity .26s ease;
}
.dto-info.anim-next { animation: dtoInfoNext .26s ease }
.dto-info.anim-prev { animation: dtoInfoPrev .26s ease }
@keyframes dtoInfoNext { from { transform: translateX(16px); opacity: 0 } to { transform: translateX(0); opacity: 1 } }
@keyframes dtoInfoPrev { from { transform: translateX(-16px); opacity: 0 } to { transform: translateX(0); opacity: 1 } }

.dto-step-label {
  font-family: 'DM Mono', monospace; font-size: 10px;
  letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--editor-accent, #5B8CF0);
  font-weight: 600;
}
.dto-step-title {
  font-family: 'Manrope', serif; font-size: 18px; font-weight: 800;
  color: var(--text-bright, #fff); line-height: 1.3;
}
.dto-step-desc {
  font-size: 13px; line-height: 1.7;
  color: var(--muted-bright, #8a9bb0);
}

/* 내비게이션 버튼 */
.dto-nav { display: flex; gap: 8px; margin-top: 8px; }
.dto-nav-btn {
  flex: 1; padding: 9px 14px; border-radius: 8px; border: none;
  font-family: 'DM Mono', monospace; font-size: 12px; font-weight: 600;
  cursor: pointer; transition: all .15s; letter-spacing: .3px;
}
.dto-nav-btn:disabled { opacity: .3; cursor: default; }
.dto-nav-btn.secondary {
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.5);
}
.dto-nav-btn.secondary:hover:not(:disabled) { background: rgba(255,255,255,.1); }
.dto-nav-btn.primary {
  background: rgba(91,140,240,.18);
  color: var(--editor-accent, #5B8CF0);
  border: 1px solid rgba(91,140,240,.3);
}
.dto-nav-btn.primary:hover { background: rgba(91,140,240,.28); }
.dto-nav-btn.cta {
  background: var(--editor-accent, #5B8CF0);
  color: #fff; font-size: 13px;
}
.dto-nav-btn.cta:hover { filter: brightness(1.1); }

.dto-skip-btn {
  background: none; border: none; padding: 0;
  font-family: 'DM Mono', monospace; font-size: 10px;
  color: rgba(255,255,255,.22); cursor: pointer;
  letter-spacing: .5px; text-align: left;
  transition: color .15s;
}
.dto-skip-btn:hover { color: rgba(255,255,255,.5); }

/* 우: 스크린 미리보기 */
.dto-preview {
  background: #0d1119;
  overflow: hidden; position: relative;
  transition: transform .26s ease, opacity .26s ease;
}
.dto-preview.anim-next { animation: dtoInfoNext .26s ease }
.dto-preview.anim-prev { animation: dtoInfoPrev .26s ease }

/* ── 스크린 공통 ── */
.dto-screen {
  width: 100%; height: 100%;
  display: flex; flex-direction: column;
  background: #0f1520;
}
.dto-screen-topbar {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 16px;
  background: rgba(255,255,255,.03);
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.dto-dots { display: flex; gap: 5px; }
.dto-dots span { width: 8px; height: 8px; border-radius: 50%; background: rgba(255,255,255,.12); }
.dto-dots span:nth-child(1){ background: #ff5f57; }
.dto-dots span:nth-child(2){ background: #febc2e; }
.dto-dots span:nth-child(3){ background: #28c840; }
.dto-screen-title { font-family: 'DM Mono', monospace; font-size: 10px; color: rgba(255,255,255,.3); letter-spacing: .5px; }

.dto-screen-body { flex: 1; overflow: hidden; }

/* 2-컬럼 레이아웃 */
.dto-split { display: grid; grid-template-columns: 1fr 1fr; height: 100%; }
.dto-panel { padding: 14px; display: flex; flex-direction: column; gap: 10px; overflow: hidden; }
.dto-panel-right { border-left: 1px solid rgba(255,255,255,.06); position: relative; }
.dto-panel-label {
  font-family: 'DM Mono', monospace; font-size: 9px; font-weight: 700;
  letter-spacing: 1.2px; text-transform: uppercase;
  color: rgba(255,255,255,.3);
  display: flex; align-items: center; justify-content: space-between;
  position: relative;
}

/* 텍스트 에리어 모사 */
.dto-textarea {
  flex: 1; background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.08); border-radius: 6px;
  padding: 10px; overflow-y: auto;
  font-family: 'DM Mono', monospace; font-size: 10px; line-height: 1.7;
  color: rgba(255,255,255,.65); white-space: pre-wrap;
}
.dto-cursor { display: inline-block; width: 6px; height: 12px; background: var(--editor-accent, #5B8CF0); vertical-align: middle; margin-left: 1px; }
.dto-cursor.blink { animation: dtoBlink .9s step-end infinite; }
@keyframes dtoBlink { 0%,100%{opacity:1} 50%{opacity:0} }

/* 빈 컷 패널 */
.dto-empty-cuts {
  flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 8px; color: rgba(255,255,255,.15);
}
.dto-empty-icon { font-size: 22px; }
.dto-empty-text { font-family: 'DM Mono', monospace; font-size: 10px; letter-spacing: .5px; }

/* 화살표 포인터 박스 */
.dto-arrow-box {
  position: absolute; z-index: 5;
  display: flex; align-items: center; gap: 6px;
  background: rgba(91,140,240,.15);
  border: 1px solid rgba(91,140,240,.35);
  border-radius: 6px; padding: 5px 10px;
  white-space: nowrap; pointer-events: none;
  animation: dtoPulse 1.8s ease-in-out infinite;
}
@keyframes dtoPulse { 0%,100%{box-shadow:0 0 0 0 rgba(91,140,240,.3)} 50%{box-shadow:0 0 0 6px rgba(91,140,240,0)} }
.dto-arrow-box.left  { left: -8px; top: 50%; transform: translate(-100%, -50%); flex-direction: row-reverse; }
.dto-arrow-box.right { right: 8px; top: 28px; transform: translateX(0); }
.dto-arrow-box.top   { bottom: calc(100% + 8px); left: 50%; transform: translateX(-50%); flex-direction: column-reverse; }
.dto-arrow-box.bottom { top: calc(100% + 8px); left: 50%; transform: translateX(-50%); flex-direction: column; }
.dto-arrow-box.center { bottom: calc(100% + 8px); left: 0; }
.dto-arrow-icon { font-size: 14px; color: var(--editor-accent, #5B8CF0); }
.dto-arrow-text { font-family: 'DM Mono', monospace; font-size: 9px; color: rgba(255,255,255,.75); line-height: 1.4; }

/* 툴바 (분석 버튼 시뮬레이션) */
.dto-center { padding: 14px; display: flex; flex-direction: column; gap: 16px; }
.dto-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 12px;
  background: rgba(255,255,255,.03); border-radius: 8px;
  border: 1px solid rgba(255,255,255,.07);
}
.dto-toolbar-info { font-family: 'DM Mono', monospace; font-size: 10px; color: rgba(255,255,255,.35); }
.dto-analyze-btn-wrap { position: relative; display: flex; justify-content: flex-end; }
.dto-analyze-btn {
  background: var(--editor-accent, #5B8CF0);
  border: none; border-radius: 6px;
  padding: 7px 16px;
  font-family: 'DM Mono', monospace; font-size: 11px; font-weight: 700;
  color: #fff; cursor: pointer; transition: background .2s;
  white-space: nowrap;
}
.dto-analyze-btn.done { background: #28a745; }

/* 진행 바 (분석 화면) */
.dto-progress-wrap { padding: 12px 16px; background: rgba(255,255,255,.03); border-radius: 8px; border: 1px solid rgba(255,255,255,.07); }
.dto-progress-label { font-family: 'DM Mono', monospace; font-size: 10px; color: var(--editor-accent, #5B8CF0); margin-bottom: 8px; }
.dto-progress-track { height: 3px; background: rgba(255,255,255,.08); border-radius: 2px; overflow: hidden; }
.dto-progress-fill { height: 100%; background: var(--editor-accent, #5B8CF0); border-radius: 2px; transition: width .15s ease; }

/* 컷 카드 리스트 */
.dto-cut-list { display: flex; flex-direction: column; gap: 6px; overflow-y: auto; flex: 1; }
.dto-cut-card {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08); border-radius: 6px;
  padding: 8px 10px; display: flex; flex-direction: column; gap: 4px;
  opacity: 0; transform: translateX(10px);
  transition: opacity .3s ease, transform .3s ease;
}
.dto-cut-card.show { opacity: 1; transform: translateX(0); }
.dto-cut-num { font-family: 'DM Mono', monospace; font-size: 9px; font-weight: 700; color: var(--editor-accent, #5B8CF0); letter-spacing: .5px; }
.dto-cut-info { display: flex; gap: 8px; align-items: center; }
.dto-cut-shot { font-family: 'DM Mono', monospace; font-size: 10px; font-weight: 700; color: rgba(255,255,255,.75); }
.dto-cut-subject { font-size: 10px; color: rgba(255,255,255,.45); }
.dto-cut-tags { display: flex; gap: 5px; }
.dto-tag { font-family: 'DM Mono', monospace; font-size: 8px; padding: 2px 6px; border-radius: 3px; background: rgba(255,255,255,.08); color: rgba(255,255,255,.45); }
.dto-tag.emotion { background: rgba(91,140,240,.12); color: rgba(91,140,240,.8); }

.dto-scenario-small .dto-panel-label { font-size: 9px; }
.dto-scenario-text { font-family: 'DM Mono', monospace; font-size: 9px; line-height: 1.65; color: rgba(255,255,255,.4); white-space: pre-line; overflow: hidden; }

/* 편집 화면 */
.dto-edit-layout { display: grid; grid-template-columns: 1fr 1fr; height: 100%; }
.dto-edit-left { padding: 14px; border-right: 1px solid rgba(255,255,255,.06); display: flex; flex-direction: column; gap: 12px; }
.dto-edit-right { padding: 14px; display: flex; flex-direction: column; gap: 10px; }
.dto-highlight-badge {
  font-family: 'DM Mono', monospace; font-size: 8px; padding: 2px 6px;
  background: rgba(91,140,240,.18); color: var(--editor-accent, #5B8CF0);
  border-radius: 4px; margin-left: 6px;
}
.dto-edit-fields { display: flex; flex-direction: column; gap: 7px; }
.dto-field-row { display: flex; align-items: center; gap: 10px; padding: 6px 8px; background: rgba(255,255,255,.03); border-radius: 5px; }
.dto-field-label { font-family: 'DM Mono', monospace; font-size: 9px; color: rgba(255,255,255,.3); min-width: 32px; letter-spacing: .3px; }
.dto-field-value { font-size: 11px; color: rgba(255,255,255,.7); }
.dto-model-select-row { position: relative; }
.dto-model-select {
  width: 100%; background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.12); border-radius: 6px;
  color: rgba(255,255,255,.75); font-family: 'DM Mono', monospace; font-size: 10px;
  padding: 6px 10px; cursor: pointer;
}
.dto-prompt-box {
  flex: 1; background: rgba(91,140,240,.06);
  border: 1px solid rgba(91,140,240,.18); border-radius: 6px;
  padding: 10px; display: flex; flex-direction: column; gap: 8px;
}
.dto-prompt-text { font-family: 'DM Mono', monospace; font-size: 9px; color: rgba(255,255,255,.5); line-height: 1.6; }
.dto-prompt-actions { display: flex; gap: 6px; }
.dto-copy-btn {
  font-family: 'DM Mono', monospace; font-size: 9px; padding: 4px 8px;
  background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1);
  color: rgba(255,255,255,.5); border-radius: 4px; cursor: pointer;
}

/* 내보내기 화면 */
.dto-export-layout { padding: 16px; display: flex; flex-direction: column; gap: 18px; }
.dto-export-section { display: flex; flex-direction: column; gap: 10px; }
.dto-export-btns { display: flex; gap: 8px; flex-wrap: wrap; }
.dto-export-btn {
  font-family: 'DM Mono', monospace; font-size: 10px; padding: 7px 14px;
  background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.1);
  color: rgba(255,255,255,.5); border-radius: 6px; cursor: pointer;
  transition: all .15s;
}
.dto-export-btn.active { background: rgba(91,140,240,.18); border-color: rgba(91,140,240,.3); color: var(--editor-accent, #5B8CF0); }
.dto-share-row { display: flex; gap: 8px; align-items: center; position: relative; padding-bottom: 40px; }
.dto-share-link {
  flex: 1; background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.1); border-radius: 6px;
  padding: 7px 10px; font-family: 'DM Mono', monospace; font-size: 9px;
  color: rgba(255,255,255,.4); overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.dto-export-summary {
  display: flex; align-items: center; gap: 8px;
  font-family: 'DM Mono', monospace; font-size: 10px; color: rgba(255,255,255,.3);
}
.dto-summary-sep { opacity: .3; }

/* 반응형 */
@media (max-width: 700px) {
  .dto-body { grid-template-columns: 1fr; }
  .dto-info { border-right: none; border-bottom: 1px solid rgba(255,255,255,.06); }
  .dto-preview { min-height: 240px; }
  .dto-split { grid-template-columns: 1fr; }
  .dto-panel-right { border-left: none; border-top: 1px solid rgba(255,255,255,.06); }
  .dto-edit-layout { grid-template-columns: 1fr; }
  .dto-arrow-box.left { position: static; transform: none; flex-direction: row; margin-top: 6px; }
  .dto-arrow-box.right { position: static; transform: none; }
  .dto-progress-steps { overflow-x: auto; }
}

/* ══════════════════════════════════════════════════════════════
   라이트 테마 통일 — 편집 페이지 (컷구성 / 완성 / 시나리오)
   Landing Page 디자인 시스템과 일치시키기
   ══════════════════════════════════════════════════════════════ */

/* ── RoughCut 패널 ── */
.rc-panel {
  background: var(--surface);
  padding: 24px 28px 40px;
}
.rc-header { border-bottom-color: var(--outline-variant); }
.rc-title { color: var(--on-surface); font-family: 'Manrope', sans-serif; }
.rc-meta { color: var(--muted); }

/* 컷 카드 */
.rc-card {
  background: var(--surface-lowest);
  border-color: var(--outline-variant);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-card);
  margin-bottom: 12px;
}
.rc-card:hover {
  border-color: var(--outline);
  box-shadow: var(--shadow-ambient);
}
.rc-card-head {
  background: var(--surface-container-low);
  border-bottom-color: var(--outline-variant);
  padding: 10px 14px;
  border-radius: var(--radius-md) var(--radius-md) 0 0;
}
.rc-card-body { padding: 12px 16px; }
.rc-flabel { color: var(--muted); }
.rc-fval { color: var(--on-surface-variant); }
.rc-fval.dial { color: var(--on-surface); border-left-color: var(--editor-accent); }

/* 시나리오 텍스트 영역 */
.rc-scenario {
  background: var(--surface-container-low);
  border-top-color: var(--outline-variant);
  color: var(--on-surface-variant);
}

/* 샷 선택 드롭다운 */
.rc-shot-label { color: var(--muted); }
.rc-shot-select {
  background: var(--surface-container-high);
  border-color: var(--outline);
  color: var(--on-surface);
}
.rc-shot-select:hover, .rc-shot-select:focus { border-color: var(--primary); }

/* 대사 인라인 편집 */
.rc-char-edit {
  color: var(--on-surface);
  border-bottom-color: var(--outline);
}
.rc-char-edit:hover {
  background: var(--surface-container-low);
  border-color: var(--muted);
}
.rc-char-edit:focus {
  background: var(--surface-container-low);
  border-bottom-color: var(--primary);
}

/* 비활성 버튼 */
.rc-complete-btn:disabled { background: var(--surface-dim); color: var(--muted); }

/* 씬 분할 바 */
.rc-split-bar { color: var(--editor-accent); }
.rc-split-bar:hover { background: rgba(192,57,43,.06); }

/* 이미지 프롬프트 버튼 */
.rc-imgp-row { border-top-color: var(--outline-variant); }

/* ── 분석 패널 ── */
.analysis-panel {
  border-top-color: var(--outline-variant);
  background: rgba(29,158,117,.04);
}
.analysis-btn {
  background: var(--primary);
  color: var(--on-primary);
  border-radius: var(--radius-md);
}
.analysis-btn:hover { background: var(--primary-dark); }
.analysis-btn:disabled { background: var(--surface-dim); color: var(--muted); }
.ar-section {
  background: var(--surface-container-low);
  border-color: var(--outline-variant);
}
.ar-title { color: var(--primary); }
.tension-chart {
  background: var(--surface-container-low);
  border-color: var(--outline-variant);
}

/* ── 시나리오 패널 ── */
.spanel { background: var(--surface-container); }
.sheader {
  background: var(--surface-lowest);
  border-bottom-color: var(--outline-variant);
  box-shadow: 0 1px 3px rgba(41,52,58,0.06);
}
.shtitle { color: var(--muted); }
.shhint { color: var(--surface-container-highest); }
.sbody { padding: 16px 24px 40px; }

/* 시나리오 라인 */
.sl { color: var(--on-surface-variant); }
.sl:hover { filter: brightness(0.85); }
.sl.empty { opacity: 0.35; }
.sl.editing {
  background: var(--surface-container-low);
  outline-color: var(--primary);
}
.sl-scene { color: #b05a20 !important; }

/* 씬 분할선 */
.splitline { color: var(--muted); }
.splitline::before, .splitline::after { background: var(--outline); }

/* 컷 마크 */
.cmcomp { color: var(--muted); }

/* ── 리사이저 ── */
.resizer { background: var(--outline-variant); }
.resizer:hover, .resizer.dragging { background: var(--primary); }
.resizer-dot { background: var(--muted); }
.resizer:hover .resizer-dot, .resizer.dragging .resizer-dot { background: var(--on-primary); }

/* ── 저장 메뉴 ── */
.save-menu {
  background: var(--surface-lowest);
  border-color: var(--outline);
  box-shadow: var(--shadow-ambient);
  border-radius: var(--radius-md);
}
.save-menu-item { color: var(--on-surface-variant); }
.save-menu-item:hover { background: var(--surface-container-low); }

/* ── 다운로드 버튼 (라이트 조정) ── */
.dl-btn {
  border-color: var(--outline);
  color: var(--on-surface-variant);
  background: var(--surface-lowest);
  border-radius: var(--radius-md);
}
.dl-btn:hover:not(:disabled) {
  border-color: var(--primary);
  color: var(--on-surface);
  background: var(--surface-container-low);
}
.dl-btn.txt { border-color: rgba(29,158,117,.4); color: var(--teal); }
.dl-btn.txt:hover:not(:disabled) { background: rgba(29,158,117,.06); border-color: var(--teal); }
.dl-btn.docx { border-color: rgba(59,130,246,.4); color: var(--blue); }
.dl-btn.docx:hover:not(:disabled) { background: rgba(59,130,246,.06); border-color: var(--blue); }

/* ── 스토리보드 페이지 라이트 테마 ── */
.sb-body { background: var(--surface); padding: 32px 40px; }
.sb-title { color: var(--on-surface); font-family: 'Manrope', sans-serif; }
.sb-subtitle { color: var(--muted); }
.sb-card {
  background: var(--surface-lowest);
  border-color: var(--outline-variant);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-card);
}
.sb-card-img { background: var(--surface-container-low); }
.sb-card-img-empty { color: var(--muted); }
.sb-cut-type { color: var(--muted); }
.sb-comp { color: var(--on-surface); }
.sb-desc { color: var(--on-surface-variant); }
.sb-dial { color: var(--on-surface); border-left-color: var(--editor-accent); }
.sb-img-note {
  background: var(--surface-container-low);
  border-color: var(--outline);
  color: var(--muted);
}

/* ── Phase 2: 시나리오 정리 대시보드 애니메이션 ── */

/* 페이드인 (범용) */
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: translateY(0); }
}
.animate-fadeIn { animation: fadeIn 0.2s ease-out both; }

/* 툴팁 등장 */
@keyframes tooltipFadeIn {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: translateY(0); }
}
.animate-tooltip { animation: tooltipFadeIn 0.15s ease-out both; }

/* 스케일 펄스 */
@keyframes scalePulse {
  0%, 100% { transform: scale(1); }
  50%       { transform: scale(1.2); }
}
.animate-scale-pulse { animation: scalePulse 1.5s ease-in-out infinite; }

/* 높이 전환 */
.transition-height {
  transition: max-height 0.3s ease-out, opacity 0.3s ease-out;
  overflow: hidden;
}

/* 히트맵 셀 호버 */
.heatmap-cell:hover {
  filter: brightness(1.5);
  transform: scaleY(1.5);
  transition: all 0.15s ease;
}

/* ─── Phase 3: 모달·DnD 애니메이션 ─── */

/* 모달 등장 */
@keyframes modalIn {
  from { opacity: 0; transform: scale(0.95) translateY(8px); }
  to   { opacity: 1; transform: scale(1) translateY(0); }
}
.animate-modalIn {
  animation: modalIn 0.2s cubic-bezier(0.16, 1, 0.3, 1) both;
}

/* 모달 배경 등장 */
@keyframes backdropIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}
.animate-backdropIn {
  animation: backdropIn 0.15s ease-out both;
}

/* 드래그 오버레이 글로우 */
@keyframes dragGlow {
  0%, 100% { box-shadow: 0 0 15px rgba(139,92,246,0.15); }
  50%       { box-shadow: 0 0 30px rgba(139,92,246,0.25); }
}
.animate-dragGlow {
  animation: dragGlow 1.5s ease-in-out infinite;
}

/* 슬라이더 트랙 커스텀 */
input[type="range"]::-webkit-slider-runnable-track {
  height: 6px;
  border-radius: 3px;
  background: rgba(255,255,255,0.05);
}

/* line-clamp 유틸리티 */
.line-clamp-6 {
  display: -webkit-box;
  -webkit-line-clamp: 6;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* ══════════════════════════════════════════
   Phase 4 / 명령 4 CSS 추가 항목
   ══════════════════════════════════════════ */

/* ── 커스텀 스크롤바 ── */
.custom-scrollbar::-webkit-scrollbar {
  width: 4px;
  height: 4px;
}
.custom-scrollbar::-webkit-scrollbar-track {
  background: transparent;
}
.custom-scrollbar::-webkit-scrollbar-thumb {
  background: rgba(139, 92, 246, 0.25);
  border-radius: 2px;
}
.custom-scrollbar::-webkit-scrollbar-thumb:hover {
  background: rgba(139, 92, 246, 0.45);
}

/* ── Slow spin (로딩 인디케이터) ── */
@keyframes spin-slow {
  to { transform: rotate(360deg); }
}
.animate-spin-slow {
  animation: spin-slow 2s linear infinite;
}

/* ── line-clamp-2 / line-clamp-4 (line-clamp-6은 이미 존재) ── */
.line-clamp-2 {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.line-clamp-4 {
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* ── StepBar 연결선 (Tailwind bg-white/8 보완) ── */
.step-connector {
  background: rgba(255,255,255,0.08);
}

/* ════════════════════════════════════════════════════
   SCENARIO ORGANIZER PAGE (sop-*)
   ════════════════════════════════════════════════════ */

/* ── 루트 ── */
.sop-root {
  display: flex;
  flex-direction: column;
  height: 100vh;
  background: #0a0a0f;
  color: #e2e8f0;
  overflow: hidden;
  font-family: 'Manrope', -apple-system, sans-serif;
}

/* ── 헤더 ── */
.sop-header {
  flex-shrink: 0;
  background: #12121a;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  padding: 10px 16px 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.sop-header-row {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 36px;
}

/* 뒤로 버튼 */
.sop-back-btn {
  flex-shrink: 0;
  width: 30px;
  height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 8px;
  color: #94a3b8;
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
}
.sop-back-btn:hover { background: rgba(255,255,255,0.1); color: #fff; }

/* 제목 영역 */
.sop-title-area {
  flex: 1;
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.sop-step-badge {
  flex-shrink: 0;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: #818cf8;
  background: rgba(129,140,248,0.12);
  border: 1px solid rgba(129,140,248,0.25);
  border-radius: 5px;
  padding: 2px 7px;
}
.sop-title {
  font-size: 15px;
  font-weight: 700;
  color: #fff;
  margin: 0;
  white-space: nowrap;
}
.sop-meta {
  font-size: 11px;
  color: #475569;
}

/* 모바일 탭 */
.sop-mobile-tabs {
  display: none;
  gap: 2px;
  background: rgba(255,255,255,0.05);
  border-radius: 8px;
  padding: 3px;
}
@media (max-width: 1023px) {
  .sop-mobile-tabs { display: flex; }
}
.sop-tab-btn {
  padding: 4px 10px;
  border-radius: 6px;
  font-size: 11px;
  color: #64748b;
  background: none;
  border: none;
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
}
.sop-tab-btn.active { background: rgba(255,255,255,0.1); color: #fff; }

/* 다음 단계 버튼 */
.sop-proceed-btn {
  flex-shrink: 0;
  padding: 7px 14px;
  background: linear-gradient(135deg, #6d28d9, #2563eb);
  color: #fff;
  font-size: 12px;
  font-weight: 600;
  border: none;
  border-radius: 8px;
  cursor: pointer;
  white-space: nowrap;
  transition: opacity 0.15s;
  box-shadow: 0 4px 12px rgba(109,40,217,0.3);
}
.sop-proceed-btn:hover { opacity: 0.88; }

/* ── 워크플로 스텝바 ── */
.sop-stepbar {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  padding: 8px 0 10px;
  overflow-x: auto;
}
.sop-step-item {
  display: flex;
  align-items: center;
  gap: 5px;
  background: none;
  border: none;
  padding: 2px 4px;
  color: #475569;
  font-size: 11px;
}
.sop-step-item.current { color: #818cf8; }
.sop-step-item.done { color: #22c55e; }
.sop-step-circle {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: rgba(255,255,255,0.05);
  border: 1.5px solid rgba(255,255,255,0.1);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  font-weight: 700;
  flex-shrink: 0;
}
.sop-step-item.current .sop-step-circle {
  background: rgba(129,140,248,0.2);
  border-color: #818cf8;
  color: #818cf8;
}
.sop-step-item.done .sop-step-circle {
  background: rgba(34,197,94,0.15);
  border-color: #22c55e;
  color: #22c55e;
}
.sop-step-label {
  white-space: nowrap;
  font-weight: 500;
}
.sop-step-line {
  width: 28px;
  height: 1px;
  background: rgba(255,255,255,0.08);
  flex-shrink: 0;
}
.sop-step-line.done { background: rgba(34,197,94,0.3); }
@media (max-width: 600px) {
  .sop-step-label { display: none; }
  .sop-step-line { width: 14px; }
}

/* ── 메인 바디 ── */
.sop-body {
  flex: 1;
  display: flex;
  overflow: hidden;
}

/* ── 패널 공통 ── */
.sop-panel {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border-right: 1px solid rgba(255,255,255,0.05);
}
.sop-panel:last-child { border-right: none; }
.sop-panel-left {
  width: 300px;
  flex-shrink: 0;
  background: #0d0d15;
}
.sop-panel-center {
  flex: 1;
  min-width: 0;
  background: #0a0a0f;
}
.sop-panel-right {
  width: 280px;
  flex-shrink: 0;
  background: #0d0d15;
  border-right: none;
  border-left: 1px solid rgba(255,255,255,0.05);
}

/* 모바일: 패널 숨김/표시 */
@media (max-width: 1023px) {
  .sop-panel-left,
  .sop-panel-right {
    display: none;
    width: 100%;
    border: none;
  }
  .sop-panel-center {
    display: none;
  }
  .sop-panel-left.mobile-show,
  .sop-panel-center.mobile-show,
  .sop-panel-right.mobile-show {
    display: flex;
    flex: 1;
  }
  /* 기본 탭은 center(list) */
  .sop-panel-center { display: none; }
}
@media (max-width: 1023px) {
  /* 모바일에서 list가 기본 */
  .sop-panel-center:not(.mobile-show) { display: none; }
  .sop-panel-center.mobile-show { display: flex; flex: 1; }
}

/* 데스크탑: 항상 표시 */
@media (min-width: 1024px) {
  .sop-panel-left,
  .sop-panel-center,
  .sop-panel-right { display: flex !important; }
}

.sop-panel-header {
  flex-shrink: 0;
  padding: 8px 14px;
  border-bottom: 1px solid rgba(255,255,255,0.05);
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: rgba(255,255,255,0.01);
}
.sop-panel-title {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: #475569;
}
.sop-panel-meta {
  font-size: 10px;
  color: #334155;
}
.sop-add-btn {
  font-size: 11px;
  color: #818cf8;
  background: none;
  border: none;
  cursor: pointer;
  font-weight: 600;
  padding: 2px 6px;
  border-radius: 5px;
  transition: background 0.15s;
}
.sop-add-btn:hover { background: rgba(129,140,248,0.1); }

.sop-panel-content {
  flex: 1;
  overflow: hidden;
  padding: 12px;
}
.sop-scroll {
  overflow-y: auto;
}

/* ── 씬 카드 (sc-*) ── */
.sc-card {
  position: relative;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.06);
  background: rgba(255,255,255,0.02);
  padding: 14px;
  margin-bottom: 8px;
  cursor: pointer;
  user-select: none;
  transition: border-color 0.2s, background 0.2s, box-shadow 0.2s;
}
.sc-card:hover {
  border-color: rgba(255,255,255,0.1);
  background: rgba(255,255,255,0.035);
}
.sc-card.selected {
  border-color: rgba(129,140,248,0.45);
  background: rgba(129,140,248,0.05);
  box-shadow: 0 4px 16px rgba(109,40,217,0.07);
}
.sc-card.dragging {
  border-color: rgba(129,140,248,0.3);
  background: rgba(129,140,248,0.04);
  opacity: 0.45;
  transform: scale(0.97);
}

/* 카드 헤더 */
.sc-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 10px;
}
.sc-left {
  display: flex;
  align-items: center;
  gap: 6px;
  min-width: 0;
  flex: 1;
}

/* 드래그 핸들 */
.sc-drag-handle {
  flex-shrink: 0;
  cursor: grab;
  color: #334155;
  opacity: 0;
  transition: opacity 0.15s, color 0.15s;
  padding: 2px;
}
.sc-card:hover .sc-drag-handle { opacity: 1; }
.sc-card.dragging .sc-drag-handle { opacity: 1; color: #818cf8; cursor: grabbing; }
.sc-drag-handle:active { cursor: grabbing; }

/* 씬 번호 */
.sc-num {
  flex-shrink: 0;
  width: 22px;
  height: 22px;
  font-size: 11px;
  font-weight: 700;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,0.05);
  color: #64748b;
}
.sc-num.selected { background: rgba(129,140,248,0.2); color: #a5b4fc; }

/* 구조 태그 */
.sc-struct-tag {
  flex-shrink: 0;
  font-size: 10px;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 5px;
  border: 1px solid transparent;
}

/* 씬 제목 */
.sc-title {
  font-size: 13px;
  font-weight: 600;
  color: #cbd5e1;
  margin: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.sc-card.selected .sc-title { color: #fff; }

/* 액션 메뉴 */
.sc-menu-wrap { position: relative; flex-shrink: 0; }
.sc-menu-btn {
  width: 26px;
  height: 26px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: none;
  border: none;
  border-radius: 6px;
  color: #64748b;
  cursor: pointer;
  font-size: 16px;
  opacity: 0;
  transition: opacity 0.15s, background 0.15s, color 0.15s;
}
.sc-card:hover .sc-menu-btn { opacity: 1; }
.sc-menu-btn:hover { background: rgba(255,255,255,0.08); color: #cbd5e1; }

.sc-dropdown {
  position: absolute;
  right: 0;
  top: 32px;
  background: #1a1a2e;
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 10px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.5);
  z-index: 30;
  min-width: 140px;
  padding: 4px;
}
.sc-dd-item {
  display: block;
  width: 100%;
  text-align: left;
  padding: 7px 12px;
  font-size: 12px;
  color: #cbd5e1;
  background: none;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  transition: background 0.12s;
}
.sc-dd-item:hover { background: rgba(255,255,255,0.06); }
.sc-dd-item.danger { color: #f87171; }
.sc-dd-item.danger:hover { background: rgba(239,68,68,0.1); }
.sc-dd-sep { border: none; border-top: 1px solid rgba(255,255,255,0.06); margin: 3px 0; }

/* 콘텐츠 미리보기 */
.sc-content {
  font-size: 11px;
  color: #64748b;
  line-height: 1.5;
  margin: 0 0 10px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* 메타 행 */
.sc-meta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  align-items: center;
}
.sc-emotion-tag {
  font-size: 10px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 20px;
}
.sc-char-tag {
  font-size: 10px;
  padding: 2px 8px;
  border-radius: 20px;
  background: rgba(255,255,255,0.05);
  color: #94a3b8;
}
.sc-char-tag.muted { color: #64748b; }
.sc-cuts-tag {
  margin-left: auto;
  font-size: 10px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 20px;
  background: rgba(255,255,255,0.05);
  color: #94a3b8;
}
.sc-cuts-tag.selected { background: rgba(129,140,248,0.2); color: #a5b4fc; }

/* 선택 체크 뱃지 */
.sc-check-badge {
  position: absolute;
  right: -6px;
  top: -6px;
  width: 18px;
  height: 18px;
  background: #6d28d9;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  color: #fff;
  font-weight: 700;
  box-shadow: 0 2px 8px rgba(109,40,217,0.4);
}

/* ── 씬 편집 오버레이 (sop-edit-*) ── */
.sop-edit-overlay {
  position: fixed;
  inset: 0;
  z-index: 40;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  background: rgba(0,0,0,0.5);
  backdrop-filter: blur(4px);
}
.sop-edit-panel {
  width: 100%;
  max-width: 600px;
  background: #12121a;
  border-top-left-radius: 20px;
  border-top-right-radius: 20px;
  border: 1px solid rgba(255,255,255,0.1);
  border-bottom: none;
  padding: 20px;
  box-shadow: 0 -8px 40px rgba(0,0,0,0.5);
}
.sop-edit-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
}
.sop-edit-title {
  font-size: 15px;
  font-weight: 700;
  color: #fff;
  margin: 0;
}
.sop-edit-close {
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 8px;
  color: #94a3b8;
  font-size: 14px;
  cursor: pointer;
}
.sop-edit-close:hover { background: rgba(255,255,255,0.1); color: #fff; }

.sop-edit-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.sop-edit-field { display: flex; flex-direction: column; gap: 5px; }
.sop-edit-field.full { grid-column: 1 / -1; }
.sop-edit-label {
  font-size: 11px;
  color: #64748b;
  font-weight: 500;
}
.sop-edit-input,
.sop-edit-select,
.sop-edit-textarea {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 8px;
  padding: 8px 10px;
  font-size: 13px;
  color: #e2e8f0;
  outline: none;
  transition: border-color 0.15s;
  font-family: inherit;
}
.sop-edit-input:focus,
.sop-edit-select:focus,
.sop-edit-textarea:focus {
  border-color: rgba(129,140,248,0.5);
  background: rgba(255,255,255,0.06);
}
.sop-edit-select { cursor: pointer; }
.sop-edit-textarea { resize: none; }
.sop-edit-range {
  accent-color: #6d28d9;
  width: 100%;
}

.sop-edit-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 16px;
}
.sop-edit-cancel {
  padding: 8px 16px;
  font-size: 13px;
  color: #94a3b8;
  background: none;
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 8px;
  cursor: pointer;
  transition: background 0.15s;
}
.sop-edit-cancel:hover { background: rgba(255,255,255,0.05); }
.sop-edit-save {
  padding: 8px 18px;
  font-size: 13px;
  font-weight: 600;
  color: #fff;
  background: linear-gradient(135deg, #6d28d9, #2563eb);
  border: none;
  border-radius: 8px;
  cursor: pointer;
  transition: opacity 0.15s;
  box-shadow: 0 3px 10px rgba(109,40,217,0.25);
}
.sop-edit-save:hover { opacity: 0.88; }

/* ── EditorHome 씬정리 버튼 강제 표시 ── */
.gbtn-scene-organize {
  flex: 0 0 auto !important;
  width: auto !important;
  background: linear-gradient(135deg, #6366f1, #8b5cf6) !important;
  font-size: 13px !important;
  padding: 0 16px !important;
  white-space: nowrap !important;
  min-width: 80px !important;
  height: 48px !important;
  border-radius: 8px !important;
  letter-spacing: 1px !important;
}
.gbtn-scene-organize:disabled {
  background: linear-gradient(135deg, #4338ca, #6d28d9) !important;
  opacity: 0.45 !important;
  color: #fff !important;
  cursor: not-allowed !important;
}

/* p1-body 안에서도 씬정리 버튼 강제 표시 */
.p1-body .gbtn-scene-organize {
  background: linear-gradient(135deg, #6366f1, #8b5cf6) !important;
  color: #fff !important;
  width: auto !important;
  flex: 0 0 auto !important;
  white-space: nowrap !important;
  min-width: 80px !important;
  height: 48px !important;
  padding: 0 16px !important;
  font-size: 13px !important;
  letter-spacing: 1px !important;
  border-radius: 8px !important;
}
.p1-body .gbtn-scene-organize:disabled {
  background: linear-gradient(135deg, #4338ca80, #6d28d980) !important;
  opacity: 0.5 !important;
  color: #c4b5fd !important;
  cursor: not-allowed !important;
}

/* ══════════════════════════════════════════════════════
   EditorHome — eh-* 클래스 시스템
   (심플 시나리오 입력 화면)
══════════════════════════════════════════════════════ */

/* 전체 카드 래퍼 */
.eh-card {
  background: var(--surface, #1A2432);
  border: 1.5px solid var(--border, #2A3A4A);
  border-radius: 14px;
  padding: 32px 36px;
  width: 100%;
  max-width: 640px;
  display: flex;
  flex-direction: column;
  gap: 24px;
  box-shadow: 0 8px 40px rgba(0,0,0,0.35);
}

/* 헤더 */
.eh-header { display: flex; flex-direction: column; gap: 6px; }
.eh-title {
  font-family: 'Manrope', sans-serif;
  font-size: 20px;
  font-weight: 700;
  color: var(--on-surface, #E8F0F8);
  letter-spacing: 0.4px;
  margin: 0;
}
.eh-title em { color: var(--accent, #4A9EE0); font-style: normal; }
.eh-desc {
  font-size: 12px;
  color: var(--muted, #6A8AAA);
  margin: 0;
}

/* 섹션 */
.eh-section { display: flex; flex-direction: column; gap: 8px; }
.eh-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--muted, #6A8AAA);
  text-transform: uppercase;
  letter-spacing: 1.2px;
}

/* 모드 선택 */
.eh-mode-row { display: flex; gap: 10px; }
.eh-mode-btn {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: 14px 10px;
  background: var(--surface-container-low, #111B27);
  border: 1.5px solid var(--border, #2A3A4A);
  border-radius: 10px;
  cursor: pointer;
  transition: all 0.18s;
  color: var(--muted, #6A8AAA);
}
.eh-mode-btn:hover {
  border-color: var(--accent, #4A9EE0);
  color: var(--on-surface, #E8F0F8);
}
.eh-mode-btn.active {
  border-color: var(--accent, #4A9EE0);
  background: rgba(74,158,224,0.1);
  color: var(--on-surface, #E8F0F8);
}
.eh-mode-icon { font-size: 26px; }
.eh-mode-name {
  font-size: 13px;
  font-weight: 700;
  font-family: 'Manrope', sans-serif;
}
.eh-mode-sub {
  font-size: 10px;
  color: var(--muted, #6A8AAA);
}
.eh-mode-btn.active .eh-mode-sub { color: var(--accent, #4A9EE0); opacity: 0.8; }

/* 파일 업로드 */
.eh-upload {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 16px;
  background: var(--surface-container-low, #111B27);
  border: 1.5px dashed var(--border, #2A3A4A);
  border-radius: 10px;
  cursor: pointer;
  transition: all 0.18s;
  color: var(--muted, #6A8AAA);
}
.eh-upload:hover, .eh-upload.drag {
  border-color: var(--accent, #4A9EE0);
  background: rgba(74,158,224,0.07);
  color: var(--on-surface, #E8F0F8);
}
.eh-upload-icon { font-size: 20px; flex-shrink: 0; }
.eh-upload-text { font-size: 12px; flex: 1; }
.eh-upload-hint { display: flex; gap: 5px; flex-shrink: 0; }
.eh-badge {
  font-size: 9px;
  font-weight: 700;
  padding: 2px 6px;
  border: 1px solid var(--border, #2A3A4A);
  border-radius: 3px;
  letter-spacing: 0.8px;
  color: var(--muted, #6A8AAA);
}

/* 텍스트에어리어 */
.eh-textarea {
  width: 100%;
  min-height: 200px;
  max-height: 340px;
  padding: 14px 16px;
  background: var(--surface-container-low, #111B27);
  border: 1.5px solid var(--border, #2A3A4A);
  border-radius: 10px;
  color: var(--on-surface, #E8F0F8);
  font-size: 13px;
  line-height: 1.75;
  font-family: 'DM Mono', 'Fira Code', monospace;
  resize: vertical;
  transition: border-color 0.18s;
  box-sizing: border-box;
}
.eh-textarea:focus {
  outline: none;
  border-color: var(--accent, #4A9EE0);
  background: rgba(74,158,224,0.04);
}
.eh-textarea::placeholder { color: var(--muted, #6A8AAA); opacity: 0.7; }

/* 샘플 버튼 행 */
.eh-sample-row {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.eh-sample-btn {
  font-size: 11px;
  padding: 4px 10px;
  background: none;
  border: 1px solid var(--border, #2A3A4A);
  border-radius: 4px;
  color: var(--muted, #6A8AAA);
  cursor: pointer;
  transition: all 0.15s;
}
.eh-sample-btn:hover {
  border-color: var(--accent, #4A9EE0);
  color: var(--on-surface, #E8F0F8);
}

/* 버튼 행 */
.eh-btn-row {
  display: flex;
  gap: 10px;
}
.eh-btn {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 20px;
  border: none;
  border-radius: 10px;
  cursor: pointer;
  transition: all 0.18s;
  text-align: left;
}
.eh-btn:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}
.eh-btn-analyze {
  background: linear-gradient(135deg, #6366f1, #8b5cf6);
  color: #fff;
}
.eh-btn-analyze:hover:not(:disabled) {
  background: linear-gradient(135deg, #4f46e5, #7c3aed);
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(99,102,241,0.35);
}
.eh-btn-cut {
  background: linear-gradient(135deg, #2563eb, #1d4ed8);
  color: #fff;
}
.eh-btn-cut:hover:not(:disabled) {
  background: linear-gradient(135deg, #1d4ed8, #1e3a8a);
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(37,99,235,0.35);
}
.eh-btn-icon { font-size: 22px; flex-shrink: 0; }
.eh-btn-text { display: flex; flex-direction: column; gap: 2px; }
.eh-btn-text strong { font-size: 14px; font-weight: 700; font-family: 'Manrope', sans-serif; }
.eh-btn-text small { font-size: 10px; opacity: 0.75; }

/* 하단 각주 */
.eh-footnote {
  font-size: 10px;
  color: var(--muted, #6A8AAA);
  text-align: center;
  opacity: 0.6;
}

/* 반응형 */
@media (max-width: 600px) {
  .eh-card { padding: 20px 18px; gap: 18px; }
  .eh-btn-row { flex-direction: column; }
  .eh-mode-row { gap: 8px; }
  .eh-btn { padding: 14px 16px; }
}
