/* ═══════════════════════════════════════════════════════════
   NOVISTA ONE — 디자인 시스템 v2.0
   Vrew 스타일 + 골드 테마 + 다크/라이트
   사용법: <link rel="stylesheet" href="/theme/novista.css">
═══════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&family=Noto+Sans+KR:wght@300;400;500;700&family=Playfair+Display:ital,wght@0,400;0,700;1,400&display=swap');

:root {
  --gold-1: #c9a96e;
  --gold-2: #8b6914;
  --gold-3: #e8c88a;
  --gold-4: rgba(201,169,110,0.12);
  --gold-5: rgba(201,169,110,0.06);
  --green:  #22c55e;
  --red:    #ef4444;
  --blue:   #3b82f6;
  --purple: #a855f7;
  --amber:  #f59e0b;
  --font-body: 'Noto Sans KR', sans-serif;
  --font-sans: 'Outfit', sans-serif;
  --font-disp: 'Playfair Display', serif;
  --nav-h:     60px;
  --sidebar-w: 240px;
  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 14px;
  --radius-xl: 20px;
  --trans:     all 0.2s ease;
  --max-w:     1200px;
}

[data-theme="dark"] {
  --bg:#0a0806; --bg-2:#120f0a; --card:#1a1510; --card-2:#221c15; --card-3:#2a2218;
  --border:#2a2218; --border-2:#352a18; --text:#d4c4a0; --text-2:#a09070; --muted:#7a6a50;
  --white:#fff; --a1:#c9a96e; --a2:#8b6914; --a3:#e8c88a;
  --overlay:rgba(10,8,6,0.97); --glass:rgba(10,8,6,0.90);
  --shadow:0 4px 24px rgba(0,0,0,0.5); --shadow-lg:0 8px 40px rgba(0,0,0,0.6);
}
[data-theme="light"] {
  --bg:#ffffff; --bg-2:#f8f7f5; --card:#ffffff; --card-2:#f3f1ed; --card-3:#ebe8e2;
  --border:#e5e0d8; --border-2:#d4cdc2; --text:#1a1510; --text-2:#5a5245; --muted:#8a7d68;
  --white:#fff; --a1:#8b6914; --a2:#6b5010; --a3:#a07820;
  --overlay:rgba(255,255,255,0.97); --glass:rgba(255,255,255,0.92);
  --shadow:0 4px 24px rgba(0,0,0,0.08); --shadow-lg:0 8px 40px rgba(0,0,0,0.12);
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;word-break:keep-all}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);background:var(--bg);color:var(--text);overflow-x:hidden;line-height:1.6;transition:background 0.25s,color 0.25s}
a{text-decoration:none;color:inherit}
button{cursor:pointer;font-family:inherit}
img{max-width:100%;display:block}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:2px}
::-webkit-scrollbar-track{background:transparent}

/* ── NAV ── */
#nv-nav{position:sticky;top:0;z-index:500;height:var(--nav-h);background:var(--overlay);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);padding:0 24px;display:flex;align-items:center;gap:8px}
.nv-logo{font-family:var(--font-sans);font-size:1.05rem;font-weight:800;letter-spacing:0.04em;color:var(--text);white-space:nowrap;margin-right:8px;flex-shrink:0;text-decoration:none}
.nv-logo em{color:var(--a1);font-style:normal}

/* 메뉴 */
.nv-menu{display:flex;align-items:center;gap:2px;flex:1}
.nv-menu-item{position:relative}
.nv-menu-btn{display:flex;align-items:center;gap:4px;padding:7px 12px;border-radius:var(--radius-sm);font-size:0.82rem;font-weight:500;color:var(--text-2);background:none;border:none;cursor:pointer;font-family:var(--font-body);transition:var(--trans);white-space:nowrap}
.nv-menu-btn:hover{background:var(--card-2);color:var(--text)}
.nv-chevron{width:14px;height:14px;transition:transform 0.2s;opacity:0.5;flex-shrink:0}
.nv-menu-item.open .nv-chevron{transform:rotate(180deg)}

/* 메가 드롭다운 */
.nv-mega{position:absolute;top:calc(100% + 8px);left:0;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:20px;min-width:500px;display:none;z-index:600;gap:20px}
.nv-menu-item.open .nv-mega{display:flex}
.nv-mega-col{flex:1;min-width:0}
.nv-mega-label{font-family:var(--font-sans);font-size:0.62rem;font-weight:700;letter-spacing:0.15em;text-transform:uppercase;color:var(--muted);margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid var(--border);display:block}
.nv-mega-item{display:flex;align-items:flex-start;gap:10px;padding:8px;border-radius:var(--radius-sm);cursor:pointer;transition:var(--trans);text-decoration:none;color:var(--text)}
.nv-mega-item:hover{background:var(--card-2)}
.nv-mega-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:5px}
.nv-mega-item-name{font-size:0.82rem;font-weight:600;color:var(--text);line-height:1.3}
.nv-mega-item-desc{font-size:0.7rem;color:var(--muted);margin-top:1px}
.nv-soon{font-family:var(--font-sans);font-size:0.56rem;font-weight:700;padding:1px 5px;border-radius:3px;background:var(--card-3);color:var(--muted);margin-left:4px;vertical-align:middle}

/* 일반 드롭다운 */
.nv-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow);padding:6px;min-width:180px;display:none;z-index:600}
.nv-menu-item.open .nv-dropdown{display:block}
.nv-dropdown-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--radius-sm);font-size:0.8rem;color:var(--text-2);cursor:pointer;transition:var(--trans);text-decoration:none;border:none;background:none;width:100%;text-align:left;font-family:var(--font-body)}
.nv-dropdown-item:hover{background:var(--card-2);color:var(--text)}
.nv-dropdown-item.danger{color:var(--red)}
.nv-dropdown-item.danger:hover{background:rgba(239,68,68,0.08)}
.nv-dropdown-divider{border:none;border-top:1px solid var(--border);margin:4px 0}

/* NAV 우측 */
.nv-nav-r{display:flex;align-items:center;gap:8px;margin-left:auto;flex-shrink:0}

/* 포인트 */
.nv-points{display:flex;align-items:center;gap:5px;padding:5px 10px;border-radius:20px;background:var(--gold-4);border:1px solid rgba(201,169,110,0.2);font-family:var(--font-sans);font-size:0.72rem;font-weight:700;color:var(--a1);cursor:pointer;transition:var(--trans);white-space:nowrap}
.nv-points:hover{background:rgba(201,169,110,0.2)}

/* 유저 버튼 */
.nv-user-btn{display:flex;align-items:center;gap:6px;padding:5px 10px;border-radius:var(--radius-sm);background:var(--card-2);border:1px solid var(--border);font-size:0.78rem;font-weight:600;color:var(--text);cursor:pointer;transition:var(--trans);font-family:var(--font-body);white-space:nowrap}
.nv-user-btn:hover{border-color:var(--a1)}
.nv-user-type{font-size:0.62rem;font-weight:500;color:var(--muted);padding:1px 5px;background:var(--card-3);border-radius:3px}

/* 언어 버튼 */
.nv-lang-btn{display:flex;align-items:center;gap:4px;padding:5px 8px;border-radius:var(--radius-sm);background:none;border:1px solid var(--border);font-size:0.75rem;font-weight:600;color:var(--muted);cursor:pointer;transition:var(--trans);font-family:var(--font-sans)}
.nv-lang-btn:hover{border-color:var(--a1);color:var(--a1)}

/* 테마 토글 */
.nv-theme-btn{width:32px;height:32px;border-radius:50%;background:var(--card-2);border:1px solid var(--border);color:var(--muted);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:0.9rem;transition:var(--trans);flex-shrink:0}
.nv-theme-btn:hover{border-color:var(--a1);color:var(--a1)}

/* CTA / 로그인 */
.nv-btn-cta{padding:7px 16px;border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--a1),var(--a2));color:#000;font-family:var(--font-sans);font-size:0.8rem;font-weight:700;border:none;cursor:pointer;transition:var(--trans);white-space:nowrap}
.nv-btn-cta:hover{opacity:0.9;transform:translateY(-1px)}
.nv-btn-login{padding:7px 14px;border-radius:var(--radius-sm);background:none;border:1px solid var(--border);color:var(--text-2);font-family:var(--font-sans);font-size:0.8rem;font-weight:600;cursor:pointer;transition:var(--trans);white-space:nowrap}
.nv-btn-login:hover{border-color:var(--a1);color:var(--a1)}

/* 햄버거 */
.nv-hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;border:none;background:none}
.nv-hamburger span{display:block;width:20px;height:2px;background:var(--text);border-radius:1px;transition:var(--trans)}

/* ── 모바일 메뉴 (Vrew 스타일) ── */
#nv-mob-menu{position:fixed;inset:0;z-index:900;background:var(--bg);display:none;flex-direction:column;overflow-y:auto}
#nv-mob-menu.open{display:flex}
.nv-mob-header{height:var(--nav-h);padding:0 20px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);flex-shrink:0}
.nv-mob-close{width:36px;height:36px;border-radius:50%;background:var(--card-2);border:none;color:var(--text);font-size:1.1rem;display:flex;align-items:center;justify-content:center;cursor:pointer}
.nv-mob-body{flex:1;padding:8px 0}
.nv-mob-item{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;font-size:1rem;font-weight:500;color:var(--text);cursor:pointer;border:none;background:none;width:100%;text-align:left;font-family:var(--font-body);transition:var(--trans)}
.nv-mob-item:hover{background:var(--card-2)}
.nv-mob-sub{display:none;background:var(--card-2)}
.nv-mob-sub.open{display:block}
.nv-mob-sub-label{font-family:var(--font-sans);font-size:0.62rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);padding:12px 20px 4px;display:block}
.nv-mob-sub-item{display:flex;align-items:center;gap:10px;padding:10px 20px;font-size:0.88rem;color:var(--text-2);cursor:pointer;text-decoration:none;transition:var(--trans)}
.nv-mob-sub-item:hover{color:var(--text);background:var(--card-3)}
.nv-mob-footer{padding:16px 20px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:8px}

/* ── 사이드바 ── */
#nv-sidebar{position:fixed;top:var(--nav-h);left:0;bottom:0;width:var(--sidebar-w);background:var(--card);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;z-index:100;transition:transform 0.3s}
.nv-sb-body{flex:1;overflow-y:auto;padding:12px 8px;scrollbar-width:thin}
.nv-sb-label{font-family:var(--font-sans);font-size:0.6rem;font-weight:700;letter-spacing:0.15em;text-transform:uppercase;color:var(--muted);padding:12px 10px 4px;display:block}
.nv-sb-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);font-size:0.8rem;font-weight:500;color:var(--text-2);cursor:pointer;transition:var(--trans);text-decoration:none;border:none;background:none;width:100%;text-align:left;font-family:var(--font-body)}
.nv-sb-item:hover{background:var(--card-2);color:var(--text)}
.nv-sb-item.active{background:var(--gold-4);color:var(--a1)}
.nv-sb-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.nv-sb-footer{border-top:1px solid var(--border);padding:8px;flex-shrink:0}
.nv-sb-user{display:flex;align-items:center;gap:8px;padding:10px;border-radius:var(--radius-sm);cursor:pointer;transition:var(--trans)}
.nv-sb-user:hover{background:var(--card-2)}
.nv-sb-avatar{width:30px;height:30px;border-radius:50%;background:var(--gold-4);border:1px solid rgba(201,169,110,0.3);display:flex;align-items:center;justify-content:center;font-family:var(--font-sans);font-size:0.75rem;font-weight:700;color:var(--a1);flex-shrink:0}
.nv-sb-user-name{font-size:0.78rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nv-sb-user-plan{font-size:0.62rem;color:var(--muted);font-family:var(--font-sans)}

/* ── 버튼 ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;border-radius:var(--radius-md);font-size:0.84rem;font-weight:700;font-family:var(--font-sans);cursor:pointer;transition:var(--trans);border:none;white-space:nowrap;text-decoration:none}
.btn:disabled{opacity:0.5;cursor:not-allowed;transform:none!important}
.btn-primary{background:linear-gradient(135deg,var(--a1),var(--a2));color:#000}
.btn-primary:hover:not(:disabled){opacity:0.9;transform:translateY(-1px)}
.btn-secondary{background:var(--card-2);color:var(--text);border:1px solid var(--border)}
.btn-secondary:hover:not(:disabled){border-color:var(--a1);color:var(--a1)}
.btn-ghost{background:transparent;color:var(--muted);border:1px solid var(--border)}
.btn-ghost:hover:not(:disabled){border-color:var(--a1);color:var(--a1)}
.btn-sm{padding:6px 14px;font-size:0.74rem;border-radius:var(--radius-sm)}
.btn-lg{padding:14px 32px;font-size:0.96rem}
.btn-full{width:100%}
.btn-spinner{display:inline-block;width:13px;height:13px;border:2px solid rgba(0,0,0,0.2);border-top-color:#000;border-radius:50%;animation:spin 0.6s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── 입력 ── */
.nv-input{width:100%;background:var(--bg-2);border:1px solid var(--border);color:var(--text);padding:10px 14px;border-radius:var(--radius-md);font-size:0.84rem;font-family:var(--font-body);outline:none;transition:border-color 0.2s}
.nv-input:focus{border-color:var(--a1)}
.nv-input::placeholder{color:var(--muted)}
.nv-label{display:block;font-size:0.71rem;font-weight:600;color:var(--muted);margin-bottom:5px;font-family:var(--font-sans)}
.nv-select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%237a6a50'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}
.nv-form-group{margin-bottom:14px}
.nv-err{background:rgba(239,68,68,0.08);border:1px solid rgba(239,68,68,0.2);color:var(--red);font-size:0.72rem;padding:8px 12px;border-radius:var(--radius-sm);margin-bottom:12px;display:none}
.nv-err.show{display:block}

/* ── 카드 ── */
.nv-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;transition:var(--trans)}
.nv-card:hover{border-color:var(--border-2)}
.nv-card-active{border-color:var(--a1)!important;background:var(--gold-5)}

/* ── 배지 ── */
.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:4px;font-family:var(--font-sans);font-size:0.6rem;font-weight:700}
.badge-free{background:rgba(148,163,184,0.1);color:#94a3b8;border:1px solid rgba(148,163,184,0.2)}
.badge-pro{background:var(--gold-4);color:var(--a1);border:1px solid rgba(201,169,110,0.2)}
.badge-live{background:rgba(34,197,94,0.1);color:var(--green);border:1px solid rgba(34,197,94,0.2)}
.badge-soon{background:var(--card-3);color:var(--muted);border:1px solid var(--border)}

/* ── 진행바 ── */
.nv-progress{width:100%;height:4px;background:var(--border);border-radius:2px;overflow:hidden}
.nv-progress-fill{height:100%;background:linear-gradient(90deg,var(--a2),var(--a1));border-radius:2px;transition:width 0.4s ease}

/* ── 토스트 ── */
#nv-toasts{position:fixed;bottom:80px;left:50%;transform:translateX(-50%);z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.nv-toast{padding:10px 18px;border-radius:var(--radius-md);font-family:var(--font-sans);font-size:0.78rem;font-weight:600;white-space:nowrap;animation:toastIn 0.3s ease;pointer-events:none}
.nv-toast-ok{background:var(--green);color:#000}
.nv-toast-err{background:var(--red);color:#fff}
.nv-toast-info{background:var(--card-2);color:var(--text);border:1px solid var(--border)}
@keyframes toastIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ── 모달 ── */
.nv-modal-ov{position:fixed;inset:0;z-index:800;background:rgba(0,0,0,0.6);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;padding:20px}
.nv-modal-ov.show{display:flex}
.nv-modal{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:28px;width:100%;max-width:440px;animation:modalIn 0.25s ease}
@keyframes modalIn{from{opacity:0;transform:translateY(16px) scale(0.97)}to{opacity:1;transform:translateY(0) scale(1)}}

/* ── 하단 탭바 ── */
#nv-btm-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:400;background:var(--overlay);border-top:1px solid var(--border);padding:6px 0 calc(6px + env(safe-area-inset-bottom))}
.nv-btm-tabs{display:flex;justify-content:space-around}
.nv-btm-tab{display:flex;flex-direction:column;align-items:center;gap:2px;padding:4px 8px;text-decoration:none;min-width:52px;background:none;border:none;cursor:pointer}
.nv-btm-icon{font-size:1.1rem;line-height:1;color:var(--muted);transition:color 0.15s}
.nv-btm-label{font-size:0.52rem;font-weight:600;color:var(--muted);font-family:var(--font-sans);transition:color 0.15s}
.nv-btm-tab.active .nv-btm-icon,.nv-btm-tab.active .nv-btm-label{color:var(--a1)}

/* ── 기부/매출 ── */
.nv-impact{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px;text-align:center}
.nv-impact-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:20px}
.nv-impact-val{font-family:var(--font-sans);font-size:1.8rem;font-weight:800;color:var(--a1);line-height:1}
.nv-impact-label{font-size:0.72rem;color:var(--muted);margin-top:4px;font-family:var(--font-sans)}
.nv-impact-note{font-size:0.66rem;color:var(--muted);margin-top:4px;font-style:italic}

/* ── 유틸 ── */
.container{max-width:var(--max-w);margin:0 auto;padding:0 24px}
.flex{display:flex}.flex-col{flex-direction:column}.flex-1{flex:1}
.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}
.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-20{gap:20px}
.w-full{width:100%}.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.divider{border:none;border-top:1px solid var(--border);margin:24px 0}
.fade-in{animation:fadeIn 0.3s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ── 반응형 ── */
@media(max-width:768px){
  :root{--nav-h:54px}
  .nv-menu{display:none}
  .nv-hamburger{display:flex}
  .nv-btn-login{display:none}
  #nv-sidebar{transform:translateX(-100%)}
  #nv-sidebar.open{transform:translateX(0);box-shadow:var(--shadow-lg)}
  #nv-btm-bar{display:block}
  .container{padding:0 16px}
  body.has-btm-bar{padding-bottom:calc(60px + env(safe-area-inset-bottom))}
  body.has-player{padding-bottom:calc(120px + env(safe-area-inset-bottom))}
  .hide-mobile{display:none!important}
}
@media(min-width:769px){
  .hide-desktop{display:none!important}
  body.has-sidebar{margin-left:var(--sidebar-w)}@media(max-width:768px){body.has-sidebar{margin-left:0}}
}
@media(max-width:480px){
  .nv-points .nv-points-label{display:none}
}
