/* ===== SHARED STYLES ===== */
:root {
  --bg: #f7f6f3;
  --surface: #ffffff;
  --border: rgba(0,0,0,0.08);
  --border-md: rgba(0,0,0,0.14);
  --text: #1a1a1a;
  --text-2: #5a5a5a;
  --text-3: #999;
  --purple: #534AB7;
  --purple-light: #EEEDFE;
  --purple-mid: #AFA9EC;
  --purple-dark: #3C3489;
  --teal: #1D9E75;
  --teal-light: #E1F5EE;
  --teal-mid: #9FE1CB;
  --amber: #854F0B;
  --amber-light: #FAEEDA;
  --red: #A32D2D;
  --red-light: #FCEBEB;
  --r-sm: 9px;
  --r-md: 14px;
  --r-lg: 16px;
  --shadow-md: 0 4px 16px rgba(0,0,0,0.08);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Noto Sans KR',sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.6;min-height:100vh}

/* NAV */
.nav{position:sticky;top:0;z-index:200;background:var(--surface);border-bottom:0.5px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 32px;height:60px}
.nav-logo{font-size:18px;font-weight:700;cursor:pointer;text-decoration:none;color:var(--text)}
.nav-logo span{color:var(--purple)}
.nav-links{display:flex;gap:2px;align-items:center}
.nav-link{padding:8px 14px;font-size:13px;color:var(--text-2);cursor:pointer;border-radius:var(--r-sm);border:none;background:transparent;font-family:inherit;text-decoration:none;display:inline-block;transition:all .15s}
.nav-link:hover{background:var(--bg);color:var(--text)}
.nav-cta{display:flex;gap:8px}
.btn{padding:9px 18px;border-radius:var(--r-sm);font-size:13px;font-weight:500;cursor:pointer;border:0.5px solid var(--border-md);background:var(--surface);color:var(--text);font-family:inherit;text-decoration:none;display:inline-block;transition:all .15s}
.btn:hover{background:var(--bg)}
.btn-primary{background:var(--purple);color:#fff;border-color:var(--purple)}
.btn-primary:hover{background:var(--purple-dark)}
.btn-lg{padding:12px 28px;font-size:15px}
.btn-sm{padding:6px 12px;font-size:12px}
.btn-danger{color:var(--red);border-color:#F09595;background:transparent}
.btn-danger:hover{background:var(--red-light)}
.btn-outline-purple{color:var(--purple);border-color:var(--purple);background:transparent}
.btn-outline-purple:hover{background:var(--purple-light)}

/* CARD */
.card{background:var(--surface);border:0.5px solid var(--border);border-radius:var(--r-lg);padding:20px 24px}

/* PILL */
.pill{display:inline-flex;align-items:center;font-size:11px;padding:2px 9px;border-radius:20px;background:var(--bg);color:var(--text-2);border:0.5px solid var(--border)}
.pill.purple{background:var(--purple-light);color:var(--purple-dark);border-color:var(--purple-mid)}
.pill.teal{background:var(--teal-light);color:#085041;border-color:var(--teal-mid)}
.pill.done{background:var(--teal-light);color:#085041;border-color:var(--teal-mid)}
.pill.review{background:var(--amber-light);color:var(--amber);border-color:#FAC775}

/* FORM */
.field-label{display:block;font-size:12px;font-weight:500;color:var(--text-2);margin-bottom:6px}
input[type=text],input[type=email],input[type=password],input[type=date],select,textarea{width:100%;padding:10px 13px;border:0.5px solid var(--border-md);border-radius:var(--r-sm);font-size:14px;font-family:inherit;color:var(--text);background:var(--surface);outline:none;transition:border-color .15s}
input:focus,select:focus{border-color:var(--purple)}
input:disabled{background:var(--bg);color:var(--text-3)}

/* SIDEBAR */
.dash-layout{display:flex;min-height:calc(100vh - 60px)}
.sidebar{width:220px;flex-shrink:0;border-right:0.5px solid var(--border);background:var(--surface);padding:20px 0;display:flex;flex-direction:column}
.sb-credit{margin:0 12px 16px;background:var(--purple-light);border-radius:var(--r-sm);padding:12px}
.sb-credit-label{font-size:11px;color:var(--purple);margin-bottom:3px}
.sb-credit-amount{font-size:17px;font-weight:700;color:var(--purple-dark)}
.sb-charge-btn{width:100%;margin-top:8px;padding:7px;border-radius:var(--r-sm);background:var(--purple);color:#fff;font-size:12px;font-weight:500;border:none;cursor:pointer;font-family:inherit}
.sb-section{padding:0 12px;margin-bottom:6px}
.sb-section-label{font-size:11px;color:var(--text-3);font-weight:500;padding:0 8px;margin-bottom:4px}
.sb-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:var(--r-sm);cursor:pointer;font-size:13px;color:var(--text-2);border:none;background:transparent;width:100%;text-align:left;font-family:inherit;text-decoration:none;transition:all .15s}
.sb-item:hover{background:var(--bg);color:var(--text)}
.sb-item.active{background:var(--purple-light);color:var(--purple);font-weight:500}
.sb-bottom{margin-top:auto;padding:12px;border-top:0.5px solid var(--border)}
.sb-user{display:flex;align-items:center;gap:10px;padding:8px;border-radius:var(--r-sm)}
.sb-avatar{width:32px;height:32px;border-radius:50%;background:var(--purple-light);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:var(--purple);flex-shrink:0}
.main-area{flex:1;min-width:0;background:var(--bg)}
.main-hd{background:var(--surface);padding:16px 24px;border-bottom:0.5px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.main-hd-title{font-size:16px;font-weight:500}
.main-hd-sub{font-size:12px;color:var(--text-3);margin-top:2px}
.main-body{padding:24px}

/* STEP BAR */
.step-bar{display:flex;align-items:center;gap:0;margin-bottom:28px}
.step-item{display:flex;align-items:center;gap:8px;font-size:13px}
.step-num{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:500;flex-shrink:0}
.step-num.done{background:var(--teal);color:#fff}
.step-num.active{background:var(--purple);color:#fff}
.step-num.todo{background:var(--bg);color:var(--text-3);border:0.5px solid var(--border-md)}
.step-label{color:var(--text-3)}
.step-label.active{color:var(--text);font-weight:500}
.step-label.done-lbl{color:var(--text-2)}
.step-line{flex:1;height:1px;background:var(--border);margin:0 8px}
.step-line.done{background:var(--teal);opacity:.4}

/* STATS */
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}
.stat-card{background:var(--surface);border:0.5px solid var(--border);border-radius:var(--r-md);padding:16px}
.stat-label{font-size:12px;color:var(--text-3);margin-bottom:6px}
.stat-val{font-size:22px;font-weight:700;color:var(--text)}
.stat-val.purple{color:var(--purple)}
.stat-note{font-size:11px;color:var(--text-3);margin-top:3px}
.stat-note.up{color:var(--teal)}

/* HISTORY */
.history-card{background:var(--surface);border:0.5px solid var(--border);border-radius:var(--r-md);padding:14px 16px;display:flex;align-items:center;gap:14px;cursor:pointer;text-decoration:none;color:inherit;transition:border-color .15s;margin-bottom:8px;display:flex}
.history-card:hover{border-color:var(--purple)}
.h-type-icon{width:36px;height:36px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:18px}
.h-type-icon.sub{background:var(--teal-light)}
.h-type-icon.doc{background:var(--purple-light)}
.h-name{font-size:13px;font-weight:500;margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.h-right{text-align:right;flex-shrink:0}
.h-date{font-size:11px;color:var(--text-3);margin-bottom:4px}

/* PERIOD CHIPS */
.period-chips{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.p-chip{padding:5px 12px;border-radius:20px;font-size:12px;font-weight:500;cursor:pointer;border:0.5px solid var(--border-md);background:var(--surface);color:var(--text-2);font-family:inherit;transition:all .15s}
.p-chip:hover{border-color:var(--purple);color:var(--purple)}
.p-chip.on{background:var(--purple);color:#fff;border-color:var(--purple)}
.date-panel{display:none;align-items:center;gap:8px;margin-top:10px;padding:12px 14px;background:var(--bg);border-radius:var(--r-sm);border:0.5px solid var(--border);flex-wrap:wrap}
.date-panel.show{display:flex}
.date-apply{padding:6px 14px;border-radius:var(--r-sm);background:var(--purple);color:#fff;font-size:12px;font-weight:500;border:none;cursor:pointer;font-family:inherit}
.date-reset{padding:6px 10px;border-radius:var(--r-sm);background:transparent;color:var(--text-3);font-size:12px;border:0.5px solid var(--border);cursor:pointer;font-family:inherit}

/* TM */
.tm-group{background:var(--surface);border:0.5px solid var(--border);border-radius:var(--r-md);overflow:hidden;margin-bottom:10px}
.tm-group-hd{display:flex;align-items:center;gap:12px;padding:14px 16px;cursor:pointer;border-bottom:0.5px solid var(--border);transition:background .1s}
.tm-group-hd:hover{background:var(--bg)}
.tm-group-icon{width:36px;height:36px;border-radius:var(--r-sm);background:var(--purple-light);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.tm-group-name{font-size:14px;font-weight:500;margin-bottom:2px}
.tm-group-meta{font-size:12px;color:var(--text-3)}
.tm-count-badge{font-size:12px;padding:3px 10px;border-radius:20px;background:var(--purple-light);color:var(--purple);font-weight:500}
.tm-chev{color:var(--text-3);font-size:12px;transition:transform .2s;margin-left:8px}
.tm-chev.open{transform:rotate(180deg)}
.tm-items{display:none}
.tm-items.open{display:block}
.tm-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:0.5px solid var(--border);transition:background .1s}
.tm-item:last-child{border-bottom:none}
.tm-item:hover{background:var(--bg)}
.tm-item-name{font-size:13px;font-weight:500;margin-bottom:3px}
.tm-item-meta{font-size:12px;color:var(--text-3);display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.tm-style-tag{font-size:11px;padding:1px 7px;border-radius:20px;background:var(--bg);color:var(--text-2);border:0.5px solid var(--border)}
.tm-sim{font-size:11px;padding:2px 8px;border-radius:20px;background:var(--teal-light);color:#085041;font-weight:500}
.tm-del{font-size:11px;padding:4px 10px;border-radius:var(--r-sm);color:var(--red);border:0.5px solid #F09595;background:transparent;cursor:pointer;font-family:inherit}
.tm-del:hover{background:var(--red-light)}

/* TOGGLE */
.toggle{width:40px;height:22px;border-radius:11px;background:var(--border-md);cursor:pointer;position:relative;transition:background .2s;flex-shrink:0;border:none}
.toggle.on{background:var(--purple)}
.toggle-thumb{width:18px;height:18px;border-radius:50%;background:#fff;position:absolute;top:2px;left:2px;transition:left .2s;pointer-events:none}
.toggle.on .toggle-thumb{left:20px}

/* PREVIEW */
.preview-wrap{border:0.5px solid var(--border);border-radius:var(--r-md);overflow:hidden}
.preview-hd{background:var(--bg);padding:10px 16px;display:flex;justify-content:space-between;border-bottom:0.5px solid var(--border);font-size:13px;font-weight:500}
.preview-grid{display:grid;grid-template-columns:1fr 1fr}
.preview-col{padding:14px 16px}
.preview-col:first-child{border-right:0.5px solid var(--border)}
.preview-col-label{font-size:11px;color:var(--text-3);font-weight:500;margin-bottom:10px}
.preview-seg{padding:8px 0;border-bottom:0.5px solid var(--border)}
.preview-seg:last-child{border-bottom:none}
.preview-ts{font-size:10px;color:var(--text-3);font-family:monospace;margin-bottom:3px}
.preview-text{font-size:13px}
.preview-text.translated{color:var(--purple-dark)}

/* FOOTER */
.footer-bar{padding:20px 40px;border-top:0.5px solid var(--border);display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--text-3);background:var(--surface)}
