/* ════════════════════════════════════════════
   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:var(--primary);
  --accent2:var(--primary-dark);
  --accent-hover:var(--primary-dark);

  /* ── 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;   /* 8px  tight */
  --space-3:1rem;     /* 16px standard */
  --space-6:2rem;     /* 32px sectional */
  --space-12:4rem;    /* 64px editorial */
  --space-16:5.5rem;  /* 88px larger */

  /* ── Radius ── */
  --radius-sm:4px;
  --radius-md:8px;
  --radius-lg:12px;
}
*{box-sizing:border-box;margin:0;padding:0;}
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) ── */
.pages{display:flex;width:600%;height:100%;transition:transform 0.45s cubic-bezier(0.4,0,0.2,1);overflow:hidden;}
.pages.p0{transform:translateX(0);}
.pages.p1{transform:translateX(-16.6667%);}
.pages.p2{transform:translateX(-33.3333%);}
.pages.p3{transform:translateX(-50%);}
.pages.p4{transform:translateX(-66.6667%);}
.pages.p5{transform:translateX(-83.3333%);}
/* .page \uae30\ubcf8: \ud3ec\uc9d0 \ud654\uc2a4 - overflow:hidden\uc73c\ub85c \ub0b4\ubd80 \uc2a4\ud06c\ub864 \uc601\uc5ed\ub9cc \uc2a4\ud06c\ub864 */
.page{width:16.6667%;height:100%;display:flex;flex-direction:column;flex-shrink:0;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 */
.pages > .page:first-child{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:#c0392b;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;}

/* 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;}

/* 푸터 */
.landing-footer{background:var(--surface);border-top:1px solid var(--border);padding:28px 48px;}
.landing-footer-inner{max-width:960px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;}
.landing-footer-logo{font-family:serif;font-size:15px;font-weight:800;color:var(--text-bright);letter-spacing:2px;}
.landing-footer-logo em{color:var(--editor-accent);font-style:normal;}
.landing-footer-text{font-family:'DM Mono',monospace;font-size:10px;color:var(--muted);letter-spacing:1px;}

/* ── 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:#c0392b;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:#a93226;}
.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:#a93226;}
.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);}
.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);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:14px 18px 14px 64px;}
.ep-info-title{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:3px;color:var(--accent);text-transform:uppercase;margin-bottom:8px;font-weight:600;}
.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;min-width:56px;flex-shrink:0;}
.ep-val{font-size:11px;color:var(--ink2);line-height:1.55;flex:1;}
.ep-val.editable{background:var(--paper);border:1px solid var(--rule);padding:3px 7px;outline:none;font-family:'Noto Sans KR',sans-serif;font-size:11px;font-weight:300;cursor:text;min-height:22px;}
.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);}

/* ── 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:#a93226;}

/* ── 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);}
.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);}
/* 하단 푸터 */
.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;}
  .pages{display:block!important;width:100%!important;height:auto!important;transform:none!important;overflow:visible!important;}
  .page{display:none!important;width:100%!important;height:auto!important;}
  /* React uses p0-p4 class on .pages for print page detection */
  .pages.p5 .page:nth-child(6){display:block!important;}
  .pages.p4 .page:nth-child(5){display:block!important;}
  .pages.p3 .page:nth-child(4){display:block!important;}
  .pages.p2 .page:nth-child(3){display:block!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:#c0392b;color:#c0392b;}

/* 이름 편집 */
.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:#c0392b;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,#c0392b,#a93226);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,#a93226,#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:#c0392b;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);}
.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:#a93226;}
.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; }
