:root{
  --bg:#fff9fc;
  --card:#ffffff;
  --line:#f1dce7;
  --line-strong:#e8a6c6;
  --text:#2b2430;
  --sub:#7b7077;
  --pink:#ef6fab;
  --pink-soft:#fff1f8;
  --purple:#9181ff;
  --blue:#eff6ff;
  --green:#eefbf7;
  --peach:#fff7ee;
  --shadow:0 16px 40px rgba(126,87,110,.10);
}
*{box-sizing:border-box}
body{font-family:Pretendard,Inter,"Noto Sans KR",sans-serif;background:var(--bg);margin:0;color:var(--text)}
button,input,select,textarea{font:inherit}
button{cursor:pointer}
.app{max-width:1280px;margin:0 auto;padding:18px 14px 80px}

/* 상단 */
.top{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;
  background:#fff;border:1px solid var(--line);border-radius:24px;padding:14px 16px;
  box-shadow:0 8px 20px rgba(126,87,110,.07);margin-bottom:14px}
.brand{display:flex;align-items:center;gap:14px}
.logo{width:50px;height:50px;border-radius:16px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(145deg,#ffc0de,#ef6fab 52%,#9181ff);color:#fff;font-weight:900;font-size:21px}
.brand h1{margin:0;font-size:24px}
.brand p{margin:4px 0 0;color:var(--sub);font-size:13px}

/* 탭 */
.toptabs{display:flex;gap:6px;flex-wrap:wrap}
.toptab{border:1px solid var(--line);background:#fff;border-radius:999px;padding:10px 16px;
  font-size:13px;font-weight:900;color:#7b7077;cursor:pointer;transition:.14s}
.toptab:hover{border-color:var(--line-strong)}
.toptab.on{background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff;border-color:transparent}
.lang-sep{display:inline-block;width:1px;height:22px;background:var(--line);margin:0 4px;vertical-align:middle}
.toptab.lang{font-size:12px;padding:8px 12px}
.toptab.lang.on{background:linear-gradient(135deg,#4a90e2,#9181ff);color:#fff;border-color:transparent}
.toptab.lang.soon{position:relative;opacity:.75}
.toptab.lang.soon::after{content:'🚧';position:absolute;top:-6px;right:-4px;font-size:11px;
  background:#fff;border-radius:999px;padding:0 3px;border:1px solid var(--line)}
.toptab.lang.soon:hover{opacity:.92;border-color:var(--line-strong)}

/* 레이아웃 */
.layout{display:grid;grid-template-columns:260px 1fr;gap:16px}
.card{background:#fff;border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow)}
.cardhead{padding:18px 18px 10px}
.cardhead h3{margin:0;font-size:18px}
.cardhead p{margin:8px 0 0;color:var(--sub);font-size:12px;line-height:1.7}
.cardbody{padding:12px 14px 18px}

/* 사이드바 */
.stack{display:grid;gap:8px}
.sidebtn{border:1px solid var(--line);background:#fff;border-radius:18px;padding:14px 14px;
  text-align:left;cursor:pointer;transition:.15s ease;display:flex;align-items:center;gap:10px}
.sidebtn:hover{transform:translateY(-1px);border-color:var(--line-strong)}
.sidebtn.on{background:linear-gradient(135deg,#fff5fa,#f7f4ff);border-color:var(--line-strong);
  box-shadow:0 8px 18px rgba(232,166,198,.18)}
.sidebtn .ico{font-size:22px}
.sidebtn .tx strong{display:block;font-size:14px;margin-bottom:2px}
.sidebtn .tx span{display:block;color:var(--sub);font-size:11px;line-height:1.5}

/* 메인 */
.main{padding:16px}
.hero{padding:22px;border-radius:24px;background:linear-gradient(180deg,#fdf2fa,#fff);
  border:1px solid #f2cfe0;margin-bottom:14px}
.hero h2{margin:0;font-size:28px}
.hero p{margin:8px 0 0;font-size:14px;color:var(--sub);line-height:1.78}
.hero .mode{display:inline-block;margin-top:10px;padding:5px 12px;border-radius:999px;
  background:#fff;border:1px solid var(--line-strong);font-size:12px;font-weight:900;color:#b14d82}

/* 카드 그리드 */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.q{border:none;border-radius:22px;padding:22px 18px;min-height:150px;cursor:pointer;text-align:left;
  box-shadow:0 8px 20px rgba(126,87,110,.07);transition:.15s ease;display:flex;flex-direction:column;gap:8px}
.q:hover{transform:translateY(-2px);box-shadow:0 14px 28px rgba(126,87,110,.13)}
.bg-pink{background:#fff5fa}.bg-purple{background:#f7f4ff}.bg-green{background:#effbf7}
.bg-blue{background:#eff6ff}.bg-peach{background:#fff7ee}.bg-mint{background:#eefbf7}
.q .i{font-size:32px}
.q strong{display:block;font-size:16px}
.q span{display:block;font-size:12px;color:#6f6670;line-height:1.65}
.q .tag{align-self:flex-start;padding:3px 10px;border-radius:999px;background:#fff;
  font-size:10px;font-weight:900;color:#b14d82;border:1px solid var(--line)}

.empty{padding:40px 20px;text-align:center;color:var(--sub);font-size:14px;line-height:1.8}

/* 🛡️ 전역 hide 규칙 — 모든 상세 뷰·스테이지의 기본 숨김 처리 */
.hide{display:none !important}
/* 개별 스테이지에도 명시적 hide 강제 (.hide 클래스 유실 대비) */
.kids-stage.hide, .kids-detail.hide, .gd-stage.hide, .set-stage.hide,
.mz-detail.hide, #monetizeDetail.hide, #publicDetail.hide, #eduDetail.hide,
#transDetail.hide, #smbDetail.hide, #psyDetail.hide, #shortsDetail.hide,
#kidsStage.hide, #kidsDetail.hide, #guideStage.hide, #settingStage.hide,
#libraryDetail.hide{
  display:none !important
}

/* 📁 내 보관함 */
.lib-wrap{padding:4px 0 20px}
.lib-head{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;
  padding:16px 20px;border-radius:20px;margin-bottom:12px;
  background:linear-gradient(135deg,#fff0f8,#f4eaff);border:1px solid #f0c8de}
.lib-head h2{margin:0;font-size:22px;color:#b14d82}
.lib-head p{margin:4px 0 0;color:#7b7077;font-size:12px}
.lib-head .hd-actions{display:flex;gap:6px;flex-wrap:wrap}
.lib-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:10px}
.lib-stat{background:#fff;border:1px solid var(--line);border-radius:16px;padding:14px;text-align:center}
.lib-stat .icon{font-size:22px}
.lib-stat .num{font-size:20px;font-weight:900;color:var(--pink);margin-top:4px}
.lib-stat .lbl{font-size:11px;color:var(--sub);margin-top:2px}
.lib-usage{background:#fff;border:1px solid var(--line);border-radius:16px;padding:12px 14px;margin-bottom:12px}
.lib-usage .bar{height:10px;border-radius:999px;background:#f5e5ee;overflow:hidden;margin-top:6px}
.lib-usage .bar i{display:block;height:100%;background:linear-gradient(90deg,var(--pink),var(--purple))}
.lib-usage .meta{display:flex;justify-content:space-between;font-size:11px;color:var(--sub);margin-top:6px}
.lib-tabs{display:flex;gap:6px;flex-wrap:wrap;background:#fff;border:1px solid var(--line);
  border-radius:16px;padding:6px;margin-bottom:10px}
.lib-tab{flex:1;min-width:120px;padding:10px;border:none;border-radius:12px;background:transparent;
  color:#7b7077;font-weight:800;font-size:12px;cursor:pointer}
.lib-tab.on{background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff}
.lib-toolbar{display:flex;gap:6px;flex-wrap:wrap;align-items:center;margin-bottom:10px}
.lib-search{flex:1 1 240px;padding:10px 14px;border:1px solid var(--line);border-radius:999px;
  font-size:13px;background:#fff}
.lib-search:focus{outline:none;border-color:var(--line-strong)}
.lib-fil{padding:7px 12px;border:1px solid var(--line);background:#fff;border-radius:999px;
  font-size:11px;font-weight:800;color:#7b7077;cursor:pointer}
.lib-fil.on{background:linear-gradient(135deg,#fff0f8,#f4eaff);border-color:var(--line-strong);color:#b14d82}
.lib-sort{display:flex;gap:4px;align-items:center;margin-left:auto;font-size:11px;color:var(--sub)}
.lib-sort select{padding:6px 10px;border:1px solid var(--line);border-radius:999px;font-size:11px;background:#fff}
.lib-cards{display:grid;gap:10px}
.lib-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:14px 16px;
  box-shadow:0 4px 14px rgba(126,87,110,.06)}
.lib-card .row1{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:8px}
.lib-card .chip{padding:3px 9px;border-radius:999px;background:var(--pink-soft);
  border:1px solid #f4d2e4;font-size:10px;font-weight:800;color:#b14d82}
.lib-card .chip.cat{background:#eef4ff;border-color:#d0dcff;color:#4a5abf}
.lib-card .chip.proj{background:#f0fbf5;border-color:#c8eddc;color:#2f7a54}
.lib-card .chip.star{background:#fff8dd;border-color:#f0d070;color:#8b6a10}
.lib-card h4{margin:0 0 6px;font-size:15px;color:#2b2430}
.lib-card .meta{font-size:11px;color:var(--sub);margin-bottom:8px}
.lib-card .prev{font-size:12px;color:#4a4450;background:#fafafc;border:1px dashed #eadce4;
  border-radius:10px;padding:8px 10px;max-height:64px;overflow:hidden;line-height:1.6}
.lib-card .acts{display:flex;gap:5px;flex-wrap:wrap;margin-top:10px}
.lib-btn{border:1px solid var(--line);background:#fff;border-radius:999px;padding:7px 12px;
  font-size:11px;font-weight:800;color:#5a4a56;cursor:pointer}
.lib-btn:hover{border-color:var(--line-strong)}
.lib-btn.pri{background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff;border:none}
.lib-btn.warn{background:#fff5f5;border-color:#f0b8b8;color:#b04040}
.lib-btn.ok{background:var(--green);border-color:#c2e8d8;color:#2f7a54}
.lib-btn.gold{background:#fff8dd;border-color:#f0d070;color:#8b6a10}
.lib-empty{padding:50px 20px;text-align:center;color:var(--sub);font-size:13px;line-height:1.9;
  background:#fff;border:1px dashed var(--line);border-radius:16px}
.lib-proj-card{display:flex;align-items:center;gap:12px;padding:14px 16px;background:#fff;
  border:1px solid var(--line);border-radius:18px;margin-bottom:8px}
.lib-proj-card .emo{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;
  justify-content:center;font-size:26px;background:#fff5fa}
.lib-proj-card.c-pink .emo{background:#ffe0ee}
.lib-proj-card.c-purple .emo{background:#ece4ff}
.lib-proj-card.c-blue .emo{background:#dcecff}
.lib-proj-card.c-green .emo{background:#d5f2e4}
.lib-proj-card.c-orange .emo{background:#ffe6cc}
.lib-proj-card .info{flex:1;min-width:0}
.lib-proj-card .info strong{display:block;font-size:14px;margin-bottom:3px}
.lib-proj-card .info span{font-size:11px;color:var(--sub)}
.lib-proj-card .ops{display:flex;gap:4px;flex-wrap:wrap}
.lib-newproj{margin-top:10px;padding:12px;background:#fff;border:1px dashed var(--line-strong);
  border-radius:14px}
.lib-newproj input, .lib-newproj textarea, .lib-newproj select{width:100%;padding:8px 10px;
  border:1px solid var(--line);border-radius:10px;font-size:12px;background:#fff;margin-bottom:6px}
.lib-emo-pick,.lib-color-pick{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:6px}
.lib-emo-pick button,.lib-color-pick button{width:34px;height:34px;border-radius:10px;
  border:2px solid transparent;background:#fff5fa;cursor:pointer;font-size:18px}
.lib-emo-pick button.on{border-color:var(--pink);background:#ffe0ee}
.lib-color-pick button{font-size:0}
.lib-color-pick button.c-pink{background:#ffa2c5}
.lib-color-pick button.c-purple{background:#b9a6ff}
.lib-color-pick button.c-blue{background:#a6c7ff}
.lib-color-pick button.c-green{background:#92d8b5}
.lib-color-pick button.c-orange{background:#ffb07a}
.lib-color-pick button.on{border-color:#2b2430}
#libToast{position:fixed;right:20px;bottom:20px;padding:12px 18px;border-radius:14px;
  background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff;font-weight:800;
  font-size:13px;box-shadow:0 10px 26px rgba(126,87,110,.3);opacity:0;transform:translateY(10px);
  transition:.25s;pointer-events:none;z-index:9999}
#libToast.on{opacity:1;transform:translateY(0)}
@media(max-width:640px){
  .lib-stats{grid-template-columns:1fr 1fr}
  .lib-sort{margin-left:0;width:100%}
}

/* 🔥 트렌드 분석 센터 */
.tr-wrap{padding:4px 0 20px}
.tr-hero{padding:18px 22px;border-radius:22px;margin-bottom:12px;
  background:linear-gradient(135deg,#fff0f8 0%,#ffd9ec 45%,#e4d5ff 100%);
  border:1px solid #f0c8de}
.tr-hero h2{margin:0;font-size:23px;color:#b14d82}
.tr-hero p{margin:6px 0 0;color:#7b4060;font-size:13px}
.tr-section{background:#fff;border:1px solid var(--line);border-radius:20px;
  padding:16px 18px;margin-bottom:12px;box-shadow:0 4px 14px rgba(126,87,110,.05)}
.tr-section .sec-title{font-size:15px;font-weight:900;color:#2b2430;margin:0 0 4px;
  display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.tr-section .sec-sub{font-size:12px;color:var(--sub);margin:0 0 12px}
.tr-section .sec-badge{font-size:10px;font-weight:800;padding:3px 8px;border-radius:999px;
  background:#ffe4ef;color:#b14d82;border:1px solid #f0c8de}
.tr-tabs{display:flex;gap:5px;flex-wrap:wrap;background:var(--pink-soft);
  border:1px solid #f4d2e4;border-radius:14px;padding:4px;margin-bottom:10px}
.tr-tab{flex:1;min-width:120px;padding:9px;border:none;border-radius:10px;background:transparent;
  color:#7b7077;font-weight:800;font-size:11px;cursor:pointer}
.tr-tab.on{background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff}
.tr-cat-fils{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:10px}
.tr-cat-fil{padding:6px 12px;border:1px solid var(--line);background:#fff;
  border-radius:999px;font-size:11px;font-weight:800;color:#7b7077;cursor:pointer}
.tr-cat-fil.on{background:linear-gradient(135deg,#fff0f8,#f4eaff);border-color:var(--line-strong);color:#b14d82}
.tr-kw-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.tr-kw{background:#fff;border:1px solid var(--line);border-radius:16px;padding:12px 14px;
  display:flex;flex-direction:column;gap:6px}
.tr-kw .rank{font-size:22px;font-weight:900;color:var(--pink)}
.tr-kw .kw{font-size:15px;font-weight:900;color:#2b2430}
.tr-kw .trend{font-size:11px;color:#2f7a54;font-weight:800}
.tr-kw .trend.hot{color:#d92e2e}
.tr-kw .meta{font-size:11px;color:var(--sub)}
.tr-kw .acts{display:flex;gap:4px;flex-wrap:wrap;margin-top:4px}
.tr-kw .acts button{font-size:10px;padding:6px 9px;border:1px solid var(--line);background:#fff;
  border-radius:999px;font-weight:800;cursor:pointer;color:#5a4a56}
.tr-kw .acts button.pri{background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff;border:none}
.tr-kw .acts button.ok{background:var(--green);border-color:#c2e8d8;color:#2f7a54}
.tr-input{display:flex;gap:6px;flex-wrap:wrap;align-items:stretch;margin-bottom:10px}
.tr-input input, .tr-input select, .tr-input textarea{flex:1;min-width:200px;padding:10px 13px;
  border:1px solid var(--line);border-radius:12px;font-size:13px;background:#fff}
.tr-input button{padding:10px 16px;border:none;border-radius:12px;
  background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff;font-weight:800;font-size:12px;cursor:pointer}
.tr-result{background:#fff9fc;border:1px solid #f1dce7;border-radius:14px;
  padding:14px 16px;font-size:13px;line-height:1.85;white-space:pre-wrap}
.tr-result:empty{display:none}
.tr-result .kw-chip{display:inline-block;margin:2px 3px;padding:3px 10px;border-radius:999px;
  background:var(--pink-soft);border:1px solid #f4d2e4;color:#b14d82;font-size:11px;font-weight:800}
.tr-fav-list{display:grid;gap:8px;margin-top:8px}
.tr-fav{display:flex;align-items:center;gap:10px;padding:10px 12px;background:#fff;
  border:1px solid var(--line);border-radius:14px}
.tr-fav .info{flex:1;min-width:0}
.tr-fav .info strong{display:block;font-size:13px}
.tr-fav .info span{font-size:11px;color:var(--sub);word-break:break-all}
.tr-fav .ops button{font-size:10px;padding:6px 10px;border:1px solid var(--line);background:#fff;
  border-radius:999px;font-weight:800;cursor:pointer;color:#5a4a56}
.tr-ch-fields{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:8px}
.tr-ch-fields label{display:block;font-size:11px;font-weight:800;color:#5a4a56;margin-bottom:3px}
.tr-ch-fields .btns{display:flex;gap:4px;flex-wrap:wrap}
.tr-ch-fields .btns button{padding:7px 11px;border:1px solid var(--line);background:#fff;
  border-radius:999px;font-size:11px;font-weight:800;color:#7b7077;cursor:pointer}
.tr-ch-fields .btns button.on{background:linear-gradient(135deg,#fff0f8,#f4eaff);
  border-color:var(--line-strong);color:#b14d82}
.tr-cal{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.tr-cal-cell{background:#fff;border:1px solid var(--line);border-radius:14px;padding:10px 12px}
.tr-cal-cell.now{background:linear-gradient(135deg,#fff0f8,#f4eaff);border-color:var(--line-strong);
  box-shadow:0 6px 14px rgba(232,166,198,.18)}
.tr-cal-cell h5{margin:0 0 6px;font-size:13px;color:#b14d82}
.tr-cal-cell .ko, .tr-cal-cell .jp{font-size:11px;line-height:1.6;color:#5a4a56}
.tr-cal-cell .jp{color:#8B5020;margin-top:2px}
.tr-cal-highlight{margin-top:10px;padding:12px 14px;border-radius:14px;
  background:linear-gradient(135deg,#fff7ee,#ffe9cb);border:1px solid #f0d6a0}
.tr-cal-highlight h5{margin:0;font-size:14px;color:#8B5020}
.tr-cal-highlight p{margin:4px 0 0;font-size:12px;color:#6a4a20}
@media(max-width:720px){
  .tr-kw-grid{grid-template-columns:1fr}
  .tr-ch-fields{grid-template-columns:1fr}
  .tr-cal{grid-template-columns:1fr 1fr}
}
@media(max-width:480px){ .tr-cal{grid-template-columns:1fr} }

/* 🎉 온보딩 마법사 */
#obOverlay{position:fixed;inset:0;z-index:10000;background:rgba(30,18,30,.72);
  backdrop-filter:blur(6px);display:none;align-items:center;justify-content:center;padding:20px}
#obOverlay.on{display:flex;animation:obFade .3s ease}
@keyframes obFade{from{opacity:0}to{opacity:1}}
@keyframes obSlide{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}
.ob-modal{background:#fff;border-radius:28px;max-width:620px;width:100%;max-height:92vh;
  overflow:auto;box-shadow:0 24px 60px rgba(30,18,30,.4);display:flex;flex-direction:column}
.ob-head{padding:18px 22px 0;display:flex;justify-content:space-between;align-items:center;gap:10px}
.ob-prog{display:flex;gap:4px;flex:1}
.ob-prog .dot{flex:1;height:6px;border-radius:3px;background:#f1dce7}
.ob-prog .dot.on{background:linear-gradient(135deg,var(--pink),var(--purple))}
.ob-close{border:none;background:transparent;font-size:20px;color:var(--sub);cursor:pointer;padding:4px 8px;border-radius:999px}
.ob-close:hover{background:var(--pink-soft)}
.ob-body{padding:24px 26px;animation:obSlide .28s ease;flex:1}
.ob-body h2{margin:0 0 8px;font-size:26px;color:#2b2430}
.ob-body .sub{color:var(--sub);font-size:14px;line-height:1.7;margin:0 0 18px}
.ob-foot{padding:14px 22px 22px;display:flex;gap:8px;justify-content:space-between;flex-wrap:wrap;border-top:1px solid var(--line)}
.ob-btn{padding:11px 20px;border-radius:12px;border:1px solid var(--line);background:#fff;
  font-weight:800;font-size:13px;cursor:pointer;color:#5a4a56}
.ob-btn:hover{border-color:var(--line-strong)}
.ob-btn.pri{background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff;border:none}
.ob-btn.ghost{background:transparent;border-color:transparent;color:var(--sub)}
.ob-btn.ok{background:var(--green);border-color:#c2e8d8;color:#2f7a54}
.ob-usergrid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.ob-usercard{padding:18px 16px;border:2px solid var(--line);background:#fff;border-radius:18px;
  cursor:pointer;text-align:left;transition:.16s;display:flex;flex-direction:column;gap:6px}
.ob-usercard:hover{transform:translateY(-2px);border-color:var(--line-strong);background:var(--pink-soft)}
.ob-usercard.on{border-color:var(--pink);background:linear-gradient(135deg,#fff0f8,#f4eaff);
  box-shadow:0 10px 22px rgba(232,166,198,.25)}
.ob-usercard .ico{font-size:32px}
.ob-usercard strong{font-size:15px;display:block}
.ob-usercard span{font-size:11px;color:var(--sub);line-height:1.55}
.ob-step-card{padding:18px;background:linear-gradient(135deg,#fff9fc,#f4eaff);
  border:1px solid #e8c8de;border-radius:18px;margin:10px 0}
.ob-step-card h4{margin:0 0 10px;font-size:17px;color:#b14d82}
.ob-step-card ol{margin:0;padding-left:22px;font-size:13px;line-height:2;color:#5a4a56}
.ob-step-card .meta{display:flex;gap:14px;flex-wrap:wrap;margin-top:10px;padding-top:10px;
  border-top:1px dashed #e8c8de;font-size:12px;color:#b14d82;font-weight:700}
.ob-info-card{padding:14px 16px;background:#fff7ee;border:1px solid #f0d6a0;border-radius:14px;margin:10px 0}
.ob-info-card h4{margin:0 0 6px;color:#8B5020;font-size:14px}
.ob-info-card p{margin:0;color:#6a4a20;font-size:12.5px;line-height:1.75}
.ob-key-row{display:flex;gap:8px;flex-wrap:wrap;margin:8px 0}
.ob-key-row .ob-btn{flex:1;min-width:150px}
.ob-finale{text-align:center;padding:20px 10px}
.ob-finale .emo{font-size:48px;margin-bottom:6px}
@media(max-width:560px){
  .ob-usergrid{grid-template-columns:1fr}
  .ob-body h2{font-size:22px}
}

/* ✨ 오늘의 추천 주제 */
.hp-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:12px 14px;
  margin-bottom:12px;box-shadow:0 4px 12px rgba(126,87,110,.05)}
.hp-card h3{margin:0 0 3px;font-size:17px;display:flex;align-items:center;gap:8px}
.hp-card h3 .tag{font-size:10px;padding:3px 9px;border-radius:999px;
  background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff;font-weight:800}
.hp-card .date{font-size:11px;color:var(--sub);margin-bottom:12px}
.hp-topic{padding:12px 14px;border:1px solid var(--line);border-radius:14px;margin-bottom:8px;
  background:linear-gradient(135deg,#fff9fc,#fdf4ff)}
.hp-topic .flag{font-size:15px;font-weight:900;color:#2b2430}
.hp-topic .note{font-size:11px;color:#b14d82;margin:3px 0 8px}
.hp-topic button{padding:7px 13px;border:none;border-radius:999px;
  background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff;
  font-weight:800;font-size:11px;cursor:pointer}
.hp-topic button.ghost{background:#fff;color:#b14d82;border:1px solid var(--line-strong);margin-left:4px}
.hp-card .more{display:block;margin-top:10px;font-size:11px;color:var(--pink);text-align:right;
  text-decoration:none;font-weight:800;cursor:pointer}
.hp-seasonal{padding:10px 14px;background:#fff7ee;border:1px solid #f0d6a0;border-radius:12px;font-size:12px;color:#8B5020;margin-top:8px}

/* 🔧 시작 준비 현황 */
.hp-setup{background:#fff;border:1px solid var(--line);border-radius:22px;padding:14px 18px;margin-bottom:12px}
.hp-setup.done{background:linear-gradient(135deg,#effbf7,#eefbf7);border-color:#c2e8d8}
.hp-setup h3{margin:0 0 10px;font-size:15px}
.hp-setup .step{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px dashed var(--line);font-size:13px}
.hp-setup .step:last-child{border-bottom:none}
.hp-setup .step .s-ico{font-size:18px;width:24px;text-align:center}
.hp-setup .step strong{flex:1}
.hp-setup .step .s-sta{font-size:11px;color:var(--sub);font-weight:700}
.hp-setup .step button{padding:6px 13px;border:1px solid var(--line-strong);background:var(--pink-soft);
  color:#b14d82;border-radius:999px;font-size:11px;font-weight:800;cursor:pointer}
.hp-setup .msg{margin:10px 0 0;padding:10px;background:var(--pink-soft);border-radius:12px;
  font-size:12px;color:#b14d82;text-align:center;font-weight:800}

/* 👀 샘플 결과 미리보기 */
.hp-sample{background:#fff;border:1px solid var(--line);border-radius:22px;padding:18px 20px;margin-top:14px}
.hp-sample h3{margin:0 0 4px;font-size:16px}
.hp-sample .sub{font-size:11px;color:var(--sub);margin-bottom:10px}
.hp-sample .tabs{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:12px;background:var(--pink-soft);
  border-radius:12px;padding:4px}
.hp-sample .tabs button{flex:1;min-width:80px;padding:8px;border:none;border-radius:9px;
  background:transparent;color:#7b7077;font-weight:800;font-size:11px;cursor:pointer}
.hp-sample .tabs button.on{background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff}
.hp-sample .preview{padding:14px 16px;background:#fff9fc;border:1px solid #f1dce7;border-radius:14px;font-size:12.5px;line-height:1.85}
.hp-sample .preview h4{margin:0 0 8px;color:#2b2430;font-size:14px}
.hp-sample .preview .bi{margin:6px 0 2px;font-size:11px;font-weight:800;color:#b14d82}
.hp-sample .preview blockquote{margin:4px 0 10px;padding:10px 12px;background:#fff;border-radius:10px;
  border-left:3px solid var(--pink);color:#3a2a34;font-size:12.5px;line-height:1.9}
.hp-sample .try{margin-top:10px;padding:10px 16px;border:none;border-radius:999px;
  background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff;font-weight:800;font-size:12px;cursor:pointer}
.hp-sample .ok-line{margin-top:8px;color:#2f7a54;font-size:11px;font-weight:800}

/* ❓ 도움말 플로팅 버튼 */
#helpFab{position:fixed;right:18px;bottom:18px;width:54px;height:54px;border-radius:50%;border:none;
  background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff;font-size:24px;
  box-shadow:0 10px 28px rgba(145,129,255,.35);cursor:pointer;z-index:9998;transition:.2s}
#helpFab:hover{transform:scale(1.08)}
#helpPop{position:fixed;right:18px;bottom:82px;width:320px;max-width:calc(100vw - 36px);
  background:#fff;border:1px solid var(--line);border-radius:20px;box-shadow:0 14px 36px rgba(30,18,30,.25);
  padding:16px 18px;z-index:9998;display:none}
#helpPop.on{display:block;animation:obSlide .2s ease}
#helpPop h4{margin:0 0 10px;font-size:15px;display:flex;justify-content:space-between;align-items:center}
#helpPop h4 .x{border:none;background:transparent;cursor:pointer;font-size:18px;color:var(--sub)}
#helpPop .row{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:10px}
#helpPop .row button{padding:8px 10px;border:1px solid var(--line);background:#fff;border-radius:10px;
  font-size:11px;font-weight:800;color:#5a4a56;cursor:pointer;text-align:left}
#helpPop .row button:hover{border-color:var(--line-strong);background:var(--pink-soft)}
#helpPop .faq{font-size:12px;color:#5a4a56;line-height:1.7;background:#fff9fc;padding:10px 12px;
  border-radius:12px;border:1px solid #f1dce7}
#helpPop .faq .q{font-weight:800;color:#b14d82;margin-top:6px}
#helpPop .faq .q:first-child{margin-top:0}
#helpPop .faq a{color:var(--pink);text-decoration:underline}
@media(max-width:640px){ #helpPop{right:10px;left:10px;width:auto} }

/* ⚖️ A/B 비교 센터 */
.ab-wrap{padding:4px 0 20px}
.ab-hero{padding:18px 22px;border-radius:22px;margin-bottom:12px;
  background:linear-gradient(135deg,#fff0f8,#ffe0ec 45%,#e8d5ff);border:1px solid #f0c8de}
.ab-hero h2{margin:0;font-size:22px;color:#b14d82}
.ab-hero p{margin:5px 0 0;color:#7b4060;font-size:13px}
.ab-section{background:#fff;border:1px solid var(--line);border-radius:20px;padding:16px 18px;
  margin-bottom:12px;box-shadow:0 4px 14px rgba(126,87,110,.05)}
.ab-section h3{margin:0 0 4px;font-size:15px;font-weight:900}
.ab-section .sub{margin:0 0 12px;font-size:12px;color:var(--sub)}
.ab-tabs{display:flex;gap:5px;flex-wrap:wrap;background:var(--pink-soft);border:1px solid #f4d2e4;
  border-radius:14px;padding:4px;margin-bottom:12px}
.ab-tabs button{flex:1;min-width:100px;padding:9px;border:none;border-radius:10px;background:transparent;
  color:#7b7077;font-weight:800;font-size:11px;cursor:pointer}
.ab-tabs button.on{background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff}
.ab-type-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.ab-type{padding:16px;background:#fff;border:2px solid var(--line);border-radius:16px;cursor:pointer;
  transition:.16s;display:flex;flex-direction:column;gap:6px;text-align:left}
.ab-type:hover{transform:translateY(-2px);border-color:var(--line-strong);background:var(--pink-soft)}
.ab-type.on{border-color:var(--pink);background:linear-gradient(135deg,#fff0f8,#f4eaff);
  box-shadow:0 8px 22px rgba(232,166,198,.2)}
.ab-type .ico{font-size:24px}
.ab-type strong{font-size:14px}
.ab-type span{font-size:11px;color:var(--sub);line-height:1.5}
.ab-type button{margin-top:6px;padding:6px 12px;border:none;border-radius:999px;
  background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff;font-size:11px;font-weight:800;cursor:pointer}
.ab-field{display:grid;gap:8px;margin-bottom:10px}
.ab-field label{font-size:11px;font-weight:800;color:#5a4a56}
.ab-field input, .ab-field textarea, .ab-field select{padding:10px 13px;border:1px solid var(--line);
  border-radius:12px;font-size:13px;background:#fff;width:100%;font-family:inherit}
.ab-field textarea{resize:vertical;min-height:80px;line-height:1.7}
.ab-opt-row{display:flex;gap:5px;flex-wrap:wrap}
.ab-opt-row button{padding:7px 12px;border:1px solid var(--line);background:#fff;border-radius:999px;
  font-size:11px;font-weight:800;color:#7b7077;cursor:pointer}
.ab-opt-row button.on{background:linear-gradient(135deg,#fff0f8,#f4eaff);border-color:var(--line-strong);color:#b14d82}
.ab-go{width:100%;padding:14px;border:none;border-radius:14px;margin-top:6px;
  background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff;font-size:14px;font-weight:900;cursor:pointer}
.ab-go:disabled{opacity:.5;cursor:not-allowed}
.ab-split{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px}
.ab-col{background:#fff9fc;border:2px solid var(--line);border-radius:16px;padding:14px;display:flex;flex-direction:column;gap:8px}
.ab-col.A{border-color:#e8a6c6;background:linear-gradient(180deg,#fff0f8,#fff)}
.ab-col.B{border-color:#c8b5ff;background:linear-gradient(180deg,#f4eaff,#fff)}
.ab-col.sel{box-shadow:0 10px 26px rgba(232,166,198,.3)}
.ab-col h4{margin:0;display:flex;align-items:center;gap:6px;font-size:14px}
.ab-col h4 .ver{padding:2px 9px;border-radius:999px;background:var(--pink);color:#fff;font-size:10px;font-weight:800}
.ab-col.B h4 .ver{background:var(--purple)}
.ab-col .style-chip{font-size:10px;font-weight:800;padding:3px 8px;border-radius:999px;
  background:#fff;border:1px solid var(--line);color:#5a4a56;align-self:flex-start}
.ab-col pre.out{margin:0;padding:10px 12px;background:#fff;border:1px solid var(--line);border-radius:12px;
  font-size:12px;line-height:1.75;white-space:pre-wrap;max-height:280px;overflow:auto;font-family:inherit}
.ab-col .meta-row{display:flex;gap:10px;flex-wrap:wrap;font-size:11px;color:#5a4a56}
.ab-col .score{font-size:12px;font-weight:800;color:#b14d82}
.ab-col .acts{display:flex;gap:4px;flex-wrap:wrap;margin-top:4px}
.ab-col .acts button{padding:6px 11px;border:1px solid var(--line);background:#fff;border-radius:999px;
  font-size:11px;font-weight:800;color:#5a4a56;cursor:pointer}
.ab-col .acts button.pick{background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff;border:none}
.ab-col .acts button.ok{background:var(--green);border-color:#c2e8d8;color:#2f7a54}
.ab-reco{padding:14px 16px;background:linear-gradient(135deg,#fff7ee,#ffefd5);border:1px solid #f0d6a0;
  border-radius:16px;margin-top:12px;font-size:13px;line-height:1.9;color:#6a4a20;white-space:pre-wrap}
.ab-reco .title{font-size:14px;font-weight:900;color:#8B5020;margin-bottom:6px}
.ab-titles{display:grid;gap:8px}
.ab-title-card{padding:12px 14px;background:#fff;border:1px solid var(--line);border-radius:14px;display:flex;flex-direction:column;gap:6px}
.ab-title-card .num{display:inline-block;width:22px;height:22px;line-height:22px;border-radius:50%;
  background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff;text-align:center;font-size:11px;font-weight:800}
.ab-title-card .tit{font-size:14px;font-weight:800;color:#2b2430}
.ab-title-card .stars{color:#f0b000;font-size:13px;letter-spacing:1px}
.ab-title-card .reason{font-size:11px;color:var(--sub);line-height:1.6}
.ab-title-card .acts button{padding:6px 11px;border:1px solid var(--line);background:#fff;border-radius:999px;
  font-size:11px;font-weight:800;color:#5a4a56;cursor:pointer;margin-right:4px}
.ab-title-card .acts button.pri{background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff;border:none}
.ab-log-card{padding:12px 14px;background:#fff;border:1px solid var(--line);border-radius:14px;margin-bottom:8px}
.ab-log-card h5{margin:0 0 4px;font-size:13px}
.ab-log-card .row{display:flex;justify-content:space-between;font-size:11px;color:#5a4a56;margin:2px 0}
.ab-log-card .win{display:inline-block;margin-top:6px;padding:4px 10px;border-radius:999px;
  background:linear-gradient(135deg,#fff7dd,#ffe9a9);color:#8B6A10;font-weight:800;font-size:11px}
.ab-stats{padding:14px 16px;background:linear-gradient(135deg,#effbf7,#eefbf7);
  border:1px solid #c2e8d8;border-radius:16px;margin-top:10px}
.ab-stats h4{margin:0 0 8px;font-size:14px;color:#2f7a54}
.ab-stats .line{display:flex;justify-content:space-between;font-size:12px;margin:4px 0;color:#2b2430}
.ab-stats .ai-hint{margin-top:8px;padding:10px;background:#fff;border-radius:10px;font-size:12px;color:#2f7a54;font-weight:700}
.ab-tone-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.ab-trans-issue{padding:10px 12px;background:#fff7ee;border:1px solid #f0d6a0;border-radius:12px;margin-top:10px;font-size:12px;color:#6a4a20;line-height:1.7}
@media(max-width:720px){
  .ab-type-grid{grid-template-columns:1fr}
  .ab-split{grid-template-columns:1fr}
  .ab-tone-grid{grid-template-columns:1fr}
  .ab-col pre.out{max-height:200px}
}

/* 📤 공유 센터 */
.sh-wrap{padding:4px 0 20px}
.sh-hero{padding:18px 22px;border-radius:22px;margin-bottom:12px;
  background:linear-gradient(135deg,#fff0f8,#e8d5ff);border:1px solid #f0c8de}
.sh-hero h2{margin:0;font-size:22px;color:#b14d82}
.sh-hero p{margin:5px 0 0;color:#7b4060;font-size:13px}
.sh-section{background:#fff;border:1px solid var(--line);border-radius:20px;padding:16px 18px;
  margin-bottom:12px;box-shadow:0 4px 14px rgba(126,87,110,.05)}
.sh-section h3{margin:0 0 4px;font-size:15px;font-weight:900;display:flex;align-items:center;gap:6px}
.sh-section .sub{margin:0 0 12px;font-size:12px;color:var(--sub)}
.sh-pick{padding:10px 12px;border:1px solid var(--line);border-radius:12px;background:#fff;
  font-size:13px;width:100%;margin-bottom:10px}
.sh-methods{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.sh-method{padding:14px 16px;background:#fff;border:1px solid var(--line);border-radius:16px;
  display:flex;flex-direction:column;gap:6px}
.sh-method h4{margin:0;font-size:14px}
.sh-method p{margin:0;font-size:11px;color:var(--sub);line-height:1.6}
.sh-method button{margin-top:6px;padding:9px 14px;border:none;border-radius:999px;
  background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff;
  font-size:12px;font-weight:800;cursor:pointer;align-self:flex-start}
.sh-method.ka button{background:linear-gradient(135deg,#ffe500,#fdd835);color:#3c1e1e}
.sh-method.li button{background:linear-gradient(135deg,#00c300,#05a705);color:#fff}
.sh-method.x button{background:#111;color:#fff}
.sh-method.pdf button{background:linear-gradient(135deg,#e8a6c6,#9181ff);color:#fff}
.sh-method.txt button{background:var(--green);color:#2f7a54;border:1px solid #c2e8d8}
.sh-bulk-list{max-height:220px;overflow:auto;border:1px solid var(--line);border-radius:12px;padding:8px}
.sh-bulk-item{display:flex;align-items:center;gap:8px;padding:6px 8px;border-bottom:1px dashed var(--line);font-size:12px}
.sh-bulk-item:last-child{border-bottom:none}
.sh-bulk-item input{accent-color:var(--pink)}
.sh-bulk-item strong{flex:1}
.sh-bulk-item span{font-size:10px;color:var(--sub)}
.sh-fmt{display:flex;gap:6px;flex-wrap:wrap;margin:10px 0}
.sh-fmt label{padding:8px 14px;border:1px solid var(--line);background:#fff;border-radius:999px;
  font-size:12px;font-weight:800;color:#7b7077;cursor:pointer}
.sh-fmt label.on{background:linear-gradient(135deg,#fff0f8,#f4eaff);border-color:var(--line-strong);color:#b14d82}
.sh-fmt input{display:none}
.sh-pdf-opts{display:grid;gap:6px;margin-bottom:10px}
.sh-pdf-opts label{display:flex;align-items:center;gap:6px;font-size:12px;color:#5a4a56;cursor:pointer}
.sh-tmpl{padding:12px;background:#fff9fc;border:1px solid var(--line);border-radius:12px;margin-top:8px}
.sh-tmpl textarea{width:100%;min-height:120px;padding:10px 12px;border:1px solid var(--line);border-radius:10px;
  font-size:12px;line-height:1.75;font-family:inherit;background:#fff;resize:vertical}
.sh-tmpl .acts{display:flex;gap:6px;margin-top:8px}
.sh-tmpl button{padding:8px 14px;border:none;border-radius:999px;font-size:11px;font-weight:800;cursor:pointer}
.sh-tmpl button.pri{background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff}
.sh-tmpl button.gh{background:#fff;color:#5a4a56;border:1px solid var(--line)}

/* 공유 버튼 그룹 (카드에 부착) */
.share-bar{margin-top:10px;padding:10px 12px;background:#fff9fc;border:1px solid var(--line);
  border-radius:14px}
.share-bar .title{font-size:11px;font-weight:800;color:#b14d82;margin-bottom:6px}
.share-bar .row{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:5px}
.share-bar .row:last-child{margin-bottom:0}
.share-bar button{padding:6px 11px;border:1px solid var(--line);background:#fff;border-radius:999px;
  font-size:10px;font-weight:800;color:#5a4a56;cursor:pointer}
.share-bar button.ka{background:#fff8cc;border-color:#f0dc60;color:#6a5010}
.share-bar button.li{background:#dff8df;border-color:#9ae39a;color:#2f7a2f}
.share-bar button.x{background:#222;border-color:#222;color:#fff}
.share-bar button.pdf{background:linear-gradient(135deg,#f4eaff,#fff0f8);border-color:#e0c8ea;color:#8b5bc0}

/* 플로팅 공유 FAB (우측 하단, ? 위쪽) */
#shareFab{position:fixed;right:18px;bottom:80px;width:52px;height:52px;border-radius:50%;border:none;
  background:linear-gradient(135deg,#b9a6ff,#ef6fab);color:#fff;font-size:22px;
  box-shadow:0 10px 26px rgba(145,129,255,.28);cursor:pointer;z-index:9997;transition:.2s;display:none}
#shareFab.on{display:block}
#shareFab:hover{transform:scale(1.08)}

/* 프린트용 — 일반 모드에서 숨기는 요소들은 화면에 영향 주지 않아야 함 */
.print-only{display:none}
@media print{
  body{background:#fff !important}
  .top, aside.card, .toptabs, #helpFab, #helpPop, #shareFab, #libToast,
  .mz-back, .sh-section.no-print, .ob-modal, #obOverlay, .share-bar,
  .hp-setup, .hp-card, .hp-sample, .sidebar, #sidebar, .mode, .toptab,
  .cardhead, .grid, .stack,
  #monetizeDetail, #publicDetail, #eduDetail, #transDetail, #smbDetail,
  #psyDetail, #shortsDetail, #kidsDetail, #kidsStage, #guideStage,
  #settingStage, #libraryDetail, #trendDetail, #abDetail, #shareDetail{
    display:none !important
  }
  .layout{grid-template-columns:1fr !important;gap:0 !important}
  .app{max-width:none !important;padding:0 !important}
  main.card{border:none !important;box-shadow:none !important;padding:0 !important}
  .main{padding:0 !important}
  .print-only{display:block !important}
  .print-page{padding:24px 28px;color:#111;font-family:Pretendard,Inter,"Noto Sans KR",sans-serif}
  .print-page h1{font-size:22px;margin:0 0 6px;border-bottom:2px solid #ef6fab;padding-bottom:6px}
  .print-page .meta{font-size:11px;color:#666;margin-bottom:18px}
  .print-page pre{white-space:pre-wrap;font-size:13px;line-height:1.85;font-family:inherit;margin:0}
  .print-page .sect{margin-top:22px;padding-top:14px;border-top:1px dashed #ccc;page-break-before:auto}
  .print-page footer{margin-top:24px;padding-top:8px;border-top:1px solid #ddd;font-size:10px;color:#999;text-align:right}
  @page{margin:14mm 10mm}
}
@media(max-width:720px){
  .sh-methods{grid-template-columns:1fr}
}

/* ☕ MOCA 소개 탭 */
#aboutStage, #qnaStage{animation:obFade .25s ease}
.mo-hero{padding:56px 32px;border-radius:32px;text-align:center;
  background:linear-gradient(135deg,#fff0f8 0%,#ffe0ec 45%,#e8d5ff 100%);border:1px solid #f0c8de;
  margin-bottom:20px;position:relative;overflow:hidden}
.mo-hero::before{content:'☕';position:absolute;top:-30px;right:-10px;font-size:280px;opacity:.08;transform:rotate(15deg)}
.mo-hero .logo{display:inline-block;padding:10px 26px;border-radius:999px;
  background:linear-gradient(135deg,#2b2430,#5a4a56);color:#fff;font-weight:900;font-size:28px;
  letter-spacing:2px;margin-bottom:18px}
.mo-hero h1{margin:0 0 8px;font-size:54px;font-weight:900;color:#2b2430;line-height:1.15}
.mo-hero h2{margin:0 0 16px;font-size:30px;font-weight:800;color:#b14d82}
.mo-hero p.mo-desc{margin:0 auto 22px;max-width:620px;font-size:16px;line-height:1.9;color:#4a3a42}
.mo-hero .eng{display:block;font-size:14px;color:#b14d82;margin-top:6px;font-weight:700;letter-spacing:1.5px}
.mo-cta{display:inline-flex;gap:10px;flex-wrap:wrap;justify-content:center}
.mo-cta button{padding:15px 28px;border-radius:999px;border:none;cursor:pointer;
  font-size:15px;font-weight:900;transition:.2s}
.mo-cta button.pri{background:linear-gradient(135deg,#ef6fab,#9181ff);color:#fff;
  box-shadow:0 10px 26px rgba(145,129,255,.3)}
.mo-cta button.pri:hover{transform:translateY(-2px);box-shadow:0 14px 30px rgba(145,129,255,.4)}
.mo-cta button.gh{background:#fff;color:#b14d82;border:2px solid #e8a6c6}
.mo-cta button.gh:hover{background:var(--pink-soft)}

.mo-sec{background:#fff;border:1px solid var(--line);border-radius:24px;padding:32px 30px;
  margin-bottom:18px;box-shadow:0 4px 16px rgba(126,87,110,.05)}
.mo-sec h2{margin:0 0 8px;font-size:26px;font-weight:900;color:#2b2430;text-align:center}
.mo-sec .subh{margin:0 0 20px;font-size:14px;color:var(--sub);text-align:center;line-height:1.7}

.mo-situation-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.mo-situation{padding:18px 20px;background:linear-gradient(135deg,#fff9fc,#fff5fa);
  border:1px solid #f1dce7;border-radius:18px}
.mo-situation .ico{font-size:28px;margin-bottom:8px}
.mo-situation strong{display:block;font-size:14px;font-weight:800;color:#b14d82;margin-bottom:6px}
.mo-situation p{margin:0;font-size:13px;line-height:1.8;color:#4a3a42;white-space:pre-line}

.mo-vs{display:grid;grid-template-columns:1fr auto 1fr;gap:16px;align-items:center;margin:20px 0}
.mo-vs .side{padding:22px 20px;border-radius:18px;text-align:center}
.mo-vs .side.before{background:#fff2f2;border:1px solid #ffb8b8;color:#9a3030}
.mo-vs .side.after{background:linear-gradient(135deg,#effbf7,#eefbf7);border:1px solid #9ae3c2;color:#1e6a3e}
.mo-vs .side h4{margin:0 0 8px;font-size:14px;font-weight:800}
.mo-vs .side p{margin:0;font-size:13px;line-height:1.8}
.mo-vs .arrow{font-size:28px;color:#b14d82;font-weight:900}

.mo-cats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.mo-cat{padding:18px 20px;background:#fff;border:1px solid var(--line);border-radius:16px}
.mo-cat h4{margin:0 0 10px;font-size:15px;color:#b14d82;font-weight:900;display:flex;align-items:center;gap:6px}
.mo-cat ul{margin:0;padding:0;list-style:none;font-size:12.5px;line-height:2;color:#4a3a42}
.mo-cat ul li::before{content:'✓ ';color:#9181ff;font-weight:900}

.mo-allbanner{margin-top:20px;padding:28px 22px;border-radius:20px;text-align:center;
  background:linear-gradient(135deg,#2b2430,#5a4a56);color:#fff}
.mo-allbanner h3{margin:0;font-size:22px;font-weight:900}
.mo-allbanner h3 span{color:#ffd9e8}

.mo-story{padding:26px 26px;background:linear-gradient(135deg,#fff7ee,#ffefd5);
  border:1px solid #f0d6a0;border-radius:20px}
.mo-story p{margin:0 0 12px;font-size:14px;line-height:2;color:#4a3a1a}
.mo-story .quote{padding:14px 18px;background:#fff;border-left:4px solid #ef6fab;border-radius:8px;
  font-style:italic;color:#6a3a5e;font-weight:700;margin:14px 0}
.mo-story .sign{text-align:right;color:#8B5020;font-weight:800;font-size:13px;margin-top:14px}

.mo-table{width:100%;border-collapse:collapse;margin-top:10px}
.mo-table th, .mo-table td{padding:11px 14px;text-align:left;border-bottom:1px solid var(--line);font-size:13px}
.mo-table th{background:var(--pink-soft);color:#b14d82;font-weight:900}
.mo-table td:nth-child(2){color:#b04040;text-decoration:line-through;opacity:.8}
.mo-table td:nth-child(3){color:#1e6a3e;font-weight:800}
.mo-highlight{margin-top:14px;padding:14px;background:linear-gradient(135deg,#fff0f8,#f4eaff);
  border:1px solid var(--line-strong);border-radius:14px;text-align:center;font-size:14px;font-weight:900;color:#b14d82}

.mo-reco-list{display:grid;gap:6px;margin:10px 0}
.mo-reco-list div{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--pink-soft);
  border-radius:10px;font-size:13px;color:#4a3a42}
.mo-reco-list div::before{content:'☑ ';color:#1e6a3e;font-weight:900}
.mo-finale{text-align:center;font-size:32px;font-weight:900;color:#b14d82;margin-top:16px;line-height:1.4}
.mo-finale span{font-size:40px}

.mo-review-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:12px}
.mo-review{padding:18px 20px;background:#fff;border:1px solid var(--line);border-radius:16px}
.mo-review .stars{color:#f0b000;letter-spacing:2px;font-size:14px;margin-bottom:8px}
.mo-review blockquote{margin:0 0 10px;padding:0;font-size:13px;line-height:1.85;color:#3a2a34;font-style:italic}
.mo-review cite{font-style:normal;font-size:11px;font-weight:800;color:var(--sub)}

.mo-pkg-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:12px}
.mo-pkg{padding:20px 22px;background:#fff;border:2px solid var(--line);border-radius:18px;display:flex;flex-direction:column;gap:6px}
.mo-pkg.hi{border-color:var(--pink);background:linear-gradient(135deg,#fff0f8,#fff)}
.mo-pkg h4{margin:0;font-size:15px;font-weight:900}
.mo-pkg .price{font-size:22px;font-weight:900;color:#b14d82}
.mo-pkg p{margin:0;font-size:12px;color:#5a4a56;line-height:1.7}
.mo-pkg button{margin-top:8px;padding:10px 16px;border-radius:999px;border:none;cursor:pointer;
  font-size:12px;font-weight:900;background:linear-gradient(135deg,#ef6fab,#9181ff);color:#fff;align-self:flex-start}

.mo-finalcta{padding:46px 24px;border-radius:28px;text-align:center;
  background:linear-gradient(135deg,#2b2430,#5a4a56);color:#fff;margin-top:20px}
.mo-finalcta h2{margin:0;font-size:36px;font-weight:900}
.mo-finalcta .big{display:block;font-size:62px;margin:8px 0 20px;letter-spacing:3px}
.mo-finalcta button{padding:16px 38px;border-radius:999px;border:none;cursor:pointer;
  font-size:16px;font-weight:900;background:linear-gradient(135deg,#ef6fab,#ffd9ec);color:#2b2430;
  box-shadow:0 10px 28px rgba(255,217,236,.35)}
.mo-finalcta .tail{display:block;font-size:12px;color:#ffc8dc;margin-top:14px}

/* 💬 Q&A 탭 */
.qa-hero{padding:36px 28px;border-radius:28px;text-align:center;
  background:linear-gradient(135deg,#e8d5ff,#fff0f8);border:1px solid #d5b8f0;margin-bottom:16px}
.qa-hero h1{margin:0 0 6px;font-size:34px;color:#5A2A8A}
.qa-hero p{margin:0;font-size:14px;color:#6a4a80}

.qa-toolbar{background:#fff;border:1px solid var(--line);border-radius:20px;padding:14px 16px;margin-bottom:12px}
.qa-search{width:100%;padding:12px 18px;border:2px solid var(--line);border-radius:999px;font-size:14px;background:#fff}
.qa-search:focus{outline:none;border-color:var(--line-strong);box-shadow:0 0 0 3px rgba(232,166,198,.15)}
.qa-fils{display:flex;gap:5px;flex-wrap:wrap;margin-top:10px}
.qa-fil{padding:7px 14px;border:1px solid var(--line);background:#fff;border-radius:999px;
  font-size:11px;font-weight:800;color:#7b7077;cursor:pointer}
.qa-fil.on{background:linear-gradient(135deg,#ef6fab,#9181ff);color:#fff;border-color:transparent}

.qa-list{display:grid;gap:8px}
.qa-item{background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;transition:.2s}
.qa-item.open{border-color:var(--line-strong);box-shadow:0 8px 22px rgba(232,166,198,.18)}
.qa-q{padding:14px 18px;cursor:pointer;display:flex;align-items:center;gap:10px;background:#fff;
  font-size:14px;font-weight:800;color:#2b2430;transition:.15s;user-select:none}
.qa-q:hover{background:var(--pink-soft)}
.qa-q .cat{font-size:10px;font-weight:800;padding:3px 9px;border-radius:999px;
  background:#f4eaff;color:#7055a5}
.qa-q .txt{flex:1}
.qa-q .chev{font-size:14px;color:var(--sub);transition:.2s}
.qa-item.open .qa-q .chev{transform:rotate(180deg)}
.qa-a{max-height:0;overflow:hidden;transition:max-height .3s ease;background:#fff9fc}
.qa-item.open .qa-a{max-height:600px}
.qa-a-inner{padding:14px 20px 18px 40px;font-size:13px;line-height:1.95;color:#4a3a42;white-space:pre-wrap}
.qa-a-inner a{color:var(--pink);font-weight:800}

.qa-nomatch{padding:40px 20px;text-align:center;color:var(--sub);font-size:13px;
  background:#fff;border:1px dashed var(--line);border-radius:16px}

.qa-contact{margin-top:18px;padding:22px 24px;border-radius:20px;text-align:center;
  background:linear-gradient(135deg,#fff7ee,#ffe9cb);border:1px solid #f0d6a0}
.qa-contact h3{margin:0 0 6px;color:#8B5020;font-size:17px}
.qa-contact p{margin:0 0 12px;font-size:12px;color:#6a4a20}
.qa-contact .acts{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}
.qa-contact button{padding:11px 20px;border-radius:999px;border:none;cursor:pointer;
  font-size:12px;font-weight:900}
.qa-contact button.email{background:linear-gradient(135deg,#ef6fab,#9181ff);color:#fff}
.qa-contact button.kakao{background:linear-gradient(135deg,#ffe500,#fdd835);color:#3c1e1e}

@media(max-width:900px){
  .mo-situation-grid{grid-template-columns:1fr 1fr}
  .mo-cats-grid, .mo-review-grid, .mo-pkg-grid{grid-template-columns:1fr}
  .mo-vs{grid-template-columns:1fr}
  .mo-vs .arrow{transform:rotate(90deg);justify-self:center}
}
@media(max-width:560px){
  .mo-hero{padding:36px 20px}
  .mo-hero h1{font-size:36px}
  .mo-hero h2{font-size:20px}
  .mo-sec{padding:22px 18px}
  .mo-situation-grid{grid-template-columns:1fr}
  .mo-finalcta h2{font-size:26px}
  .mo-finalcta .big{font-size:44px}
}

/* 수익형 상세 뷰 */
.mz-detail{margin-top:6px}
.mz-detail.hide{display:none}
.mz-back{border:1px solid var(--line);background:#fff;border-radius:999px;padding:8px 14px;
  font-size:12px;font-weight:800;cursor:pointer;margin-bottom:12px}
.mz-back:hover{border-color:var(--line-strong);background:var(--pink-soft)}
.mz-head{display:flex;align-items:center;gap:14px;padding:18px 20px;border-radius:22px;
  background:linear-gradient(135deg,#fff5fa,#f7f4ff);border:1px solid var(--line-strong);margin-bottom:14px}
.mz-ico{font-size:36px}
.mz-head h3{margin:0;font-size:20px;color:#b14d82}
.mz-head .mz-sub{margin:4px 0 0;color:var(--sub);font-size:12px}
.mz-subs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}
.mz-sub-btn{border:1.5px solid var(--line);background:#fff;border-radius:14px;
  padding:10px 14px;font-size:12px;font-weight:800;cursor:pointer;color:#7a6d73;
  font-family:inherit;text-align:left;min-width:170px}
.mz-sub-btn:hover{border-color:var(--line-strong);background:var(--pink-soft)}
.mz-sub-btn.on{background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff;border-color:transparent}
.mz-sub-btn small{display:block;font-size:10px;opacity:.75;margin-top:3px;font-weight:500}
.mz-sub-btn.soon{opacity:.7;position:relative}
.mz-sub-btn.soon::after{content:'🚧';position:absolute;top:-6px;right:-4px;font-size:11px;
  background:#fff;border-radius:999px;padding:0 3px;border:1px solid var(--line)}
.mz-form{background:#fff;border:1px solid var(--line);border-radius:20px;padding:18px}
.mz-form label{display:block;font-size:11px;font-weight:800;margin-bottom:4px;color:#6b5d65}
.mz-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:10px}
.mz-row:has(> div:nth-child(2):last-child){grid-template-columns:1fr 1fr}
.mz-in{width:100%;padding:11px 13px;border:1px solid #ead9e1;border-radius:12px;
  font-size:13px;font-family:inherit;background:#fff;outline:none}
.mz-in:focus{border-color:var(--line-strong);box-shadow:0 0 0 3px rgba(239,111,171,.12)}
.mz-actions{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px}
.mz-btn{padding:11px 16px;border-radius:12px;border:1px solid var(--line);background:#fff;
  font-weight:800;font-size:12px;cursor:pointer;font-family:inherit}
.mz-btn:hover{border-color:var(--line-strong)}
.mz-btn.pri{background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff;border-color:transparent}
.mz-btn.snd{background:#eefbf7;border-color:#a8dcc9;color:#1A7A5A}
.mz-status{font-size:11px;color:var(--sub);margin:8px 0 0;min-height:14px}
.mz-out{width:100%;min-height:240px;padding:14px;margin-top:10px;border:1px solid #ead9e1;
  border-radius:12px;background:#fff9fc;font-size:13px;line-height:1.8;resize:vertical;font-family:inherit}

@media (max-width:820px){.mz-row{grid-template-columns:1fr}.mz-sub-btn{min-width:0;flex:1 1 45%}}

/* 자동숏츠 8단계 파이프라인 */
.sh-stepper{display:flex;gap:4px;overflow-x:auto;padding:10px;background:#fff;border:1px solid var(--line);border-radius:18px;margin-bottom:12px;box-shadow:0 4px 14px rgba(126,87,110,.06)}
.sh-stepper::-webkit-scrollbar{height:4px}
.sh-step{flex:0 0 auto;padding:8px 12px;border-radius:10px;font-size:11px;font-weight:800;cursor:pointer;white-space:nowrap;color:#7a6d73;border:1.5px solid transparent;transition:.14s;font-family:inherit;background:#fff}
.sh-step:hover{background:var(--pink-soft);border-color:var(--line-strong)}
.sh-step.done{color:#1a7a5a;background:#effbf7;border-color:#c8ebd9}
.sh-step.active{background:linear-gradient(135deg,#ef6fab,#9181ff);color:#fff;border-color:transparent;box-shadow:0 4px 12px rgba(232,166,198,.3)}
.sh-panel{background:#fff;border:1px solid var(--line);border-radius:18px;padding:18px;margin-bottom:12px}
.sh-panel h4{margin:0 0 8px;font-size:15px;color:#b14d82}
.sh-panel .muted{font-size:12px;color:var(--sub);margin-bottom:10px}
.sh-stat{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:10px}
.sh-stat-box{padding:12px;background:linear-gradient(135deg,var(--pink-soft),var(--purple-soft));border:1px solid var(--line-strong);border-radius:12px;text-align:center}
.sh-stat-box .v{font-size:18px;font-weight:900;color:#b14d82}
.sh-stat-box .l{font-size:10px;color:var(--sub);margin-top:2px}
.sh-checklist{display:grid;gap:6px}
.sh-check{display:flex;align-items:center;gap:8px;padding:8px 10px;background:#fff9fc;border:1px solid var(--line);border-radius:8px;font-size:12px}
.sh-check.ok{background:#effbf7;border-color:#c8ebd9;color:#1a7a5a}
.sh-nav{display:flex;gap:8px;justify-content:space-between;margin-top:12px}
.sh-card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:10px 0}
.sh-card-grid button{padding:10px;border:1.5px solid var(--line);border-radius:10px;background:#fff;font-size:11px;font-weight:800;cursor:pointer;font-family:inherit;text-align:left}
.sh-card-grid button:hover{border-color:var(--line-strong)}
.sh-card-grid button.on{background:linear-gradient(135deg,var(--pink-soft),var(--purple-soft));border-color:var(--line-strong);color:#b14d82}
@media (max-width:820px){.sh-stat{grid-template-columns:repeat(2,1fr)}.sh-card-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.sh-stat{grid-template-columns:1fr 1fr}.sh-card-grid{grid-template-columns:1fr}}

/* ═══ 🌈 어린이 모드 전용 스타일 ═══ */
body.kids-mode{background:linear-gradient(135deg,#fff5fa 0%,#fff7ee 25%,#effbf7 50%,#eff6ff 75%,#f7f4ff 100%)}
.kids-stage{padding:8px}
.kids-top{text-align:center;padding:20px 16px;margin-bottom:16px;border-radius:24px;
  background:linear-gradient(135deg,#FF6EC7,#FFB347,#FFD700,#77DD77,#87CEEB,#9A8AE3);
  box-shadow:0 10px 30px rgba(126,87,110,.2);animation:kids-shine 4s ease-in-out infinite}
.kids-top h2{margin:0;font-size:30px;color:#fff;text-shadow:0 3px 8px rgba(0,0,0,.2);font-weight:900}
.kids-top p{margin:6px 0 0;font-size:16px;color:#fff;font-weight:800}
@keyframes kids-shine{0%,100%{filter:brightness(1)}50%{filter:brightness(1.1)}}

.kids-stats{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-bottom:14px}
.kids-stat{padding:12px 20px;border-radius:999px;background:#fff;border:3px solid #FFD700;font-weight:900;font-size:15px;color:#b14d82;box-shadow:0 4px 12px rgba(255,215,0,.2)}
.kids-stat.badges{border-color:#9A8AE3;color:#5d4aad}
.kids-stat.family{border-color:#FF6EC7;color:#b14d82}

.kids-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.kids-card{border:none;border-radius:26px;padding:28px 22px;min-height:180px;
  cursor:pointer;text-align:left;transition:.2s;position:relative;overflow:hidden;
  box-shadow:0 8px 24px rgba(126,87,110,.12);font-family:inherit}
.kids-card:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 14px 32px rgba(126,87,110,.2)}
.kids-card:active{transform:scale(.98)}
.kids-card .ico{font-size:56px;display:block;margin-bottom:10px;animation:kids-bounce 2s ease-in-out infinite}
.kids-card strong{display:block;font-size:22px;margin-bottom:6px;color:#2b2430;font-weight:900}
.kids-card span{display:block;font-size:14px;color:#555;line-height:1.6;font-weight:600}
.kids-card .star{position:absolute;top:10px;right:14px;font-size:22px;animation:kids-sparkle 1.5s ease-in-out infinite}
@keyframes kids-bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@keyframes kids-sparkle{0%,100%{transform:rotate(0) scale(1);opacity:1}50%{transform:rotate(20deg) scale(1.2);opacity:.7}}

.kids-card.c1{background:linear-gradient(135deg,#FF6EC7,#FFB347)}
.kids-card.c2{background:linear-gradient(135deg,#FFD700,#FF8E8E)}
.kids-card.c3{background:linear-gradient(135deg,#77DD77,#87CEEB)}
.kids-card.c4{background:linear-gradient(135deg,#87CEEB,#9A8AE3)}
.kids-card.c5{background:linear-gradient(135deg,#9A8AE3,#FF6EC7)}
.kids-card.c6{background:linear-gradient(135deg,#FFB347,#FFD700)}
.kids-card.c7{background:linear-gradient(135deg,#87CEEB,#77DD77)}
.kids-card.c8{background:linear-gradient(135deg,#FF8E8E,#9A8AE3)}
.kids-card.c9{background:linear-gradient(135deg,#77DD77,#FFD700)}
.kids-card.c10{background:linear-gradient(135deg,#FF6EC7,#9A8AE3)}

/* 어린이 상세 뷰 */
.kids-detail{background:#fff;border:4px solid #FFD700;border-radius:26px;padding:22px;margin-top:10px;
  box-shadow:0 12px 32px rgba(255,215,0,.25)}
.kids-head{display:flex;align-items:center;gap:14px;padding:14px 18px;border-radius:20px;
  background:linear-gradient(135deg,#FF6EC7,#9A8AE3);margin-bottom:14px}
.kids-head .bigico{font-size:48px;animation:kids-bounce 1.5s ease-in-out infinite}
.kids-head h3{margin:0;font-size:24px;color:#fff;font-weight:900}
.kids-head p{margin:4px 0 0;font-size:14px;color:#fff;opacity:.95;font-weight:700}
.kids-back{border:3px solid #FF6EC7;background:#fff;border-radius:999px;padding:12px 22px;
  font-size:16px;font-weight:900;cursor:pointer;color:#FF6EC7;margin-bottom:10px;font-family:inherit}
.kids-back:hover{background:#fff5fa;transform:scale(1.05)}

.kids-subs{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:16px}
.kids-sub-btn{border:3px solid #FFD700;background:#fff;border-radius:18px;padding:16px 14px;
  font-size:16px;font-weight:900;cursor:pointer;color:#333;font-family:inherit;text-align:left;
  display:flex;align-items:center;gap:10px;transition:.15s}
.kids-sub-btn:hover{background:linear-gradient(135deg,#fff5fa,#fff7ee);transform:translateX(4px)}
.kids-sub-btn.on{background:linear-gradient(135deg,#FFD700,#FFB347);border-color:#FF6EC7;color:#fff;box-shadow:0 6px 14px rgba(255,215,0,.3)}
.kids-sub-btn .emoji{font-size:26px}

.kids-form label{display:block;font-size:16px;font-weight:900;margin-bottom:6px;color:#b14d82}
.kids-form .kinp{width:100%;padding:14px 18px;border:3px solid #87CEEB;border-radius:14px;
  font-size:16px;font-family:inherit;outline:none;background:#fff9fc;font-weight:700}
.kids-form .kinp:focus{border-color:#FF6EC7;box-shadow:0 0 0 4px rgba(255,110,199,.2)}
.kids-form .ktxt{min-height:110px;resize:vertical;line-height:1.7}

.kids-toggle-row{display:flex;gap:10px;flex-wrap:wrap;margin:10px 0}
.kids-toggle{padding:10px 18px;border:3px solid #87CEEB;border-radius:999px;background:#fff;
  font-size:14px;font-weight:900;cursor:pointer;color:#333;font-family:inherit}
.kids-toggle.on{background:linear-gradient(135deg,#77DD77,#87CEEB);border-color:#77DD77;color:#fff}

.kids-big-btn{width:100%;padding:20px;border:none;border-radius:20px;
  background:linear-gradient(135deg,#FF6EC7,#FFD700,#77DD77);
  font-size:22px;font-weight:900;color:#fff;cursor:pointer;font-family:inherit;
  box-shadow:0 8px 20px rgba(255,110,199,.35);transition:.15s;margin-top:14px}
.kids-big-btn:hover{transform:translateY(-2px) scale(1.02)}
.kids-big-btn:active{transform:scale(.96)}
.kids-big-btn:disabled{opacity:.6;cursor:not-allowed}

.kids-result{margin-top:14px;padding:18px;background:linear-gradient(135deg,#fff5fa,#fff7ee);
  border:3px dashed #FF6EC7;border-radius:18px;font-size:16px;line-height:1.9;font-weight:600;color:#333;
  white-space:pre-wrap;min-height:160px}
.kids-result:empty::before{content:'✨ 여기에 AI가 만들어준 멋진 결과가 나타나요! ✨';color:#b14d82;font-style:italic;font-weight:700}

.kids-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px;justify-content:center}
.kids-action-btn{padding:14px 22px;border:3px solid #FFD700;background:#fff;border-radius:999px;
  font-size:15px;font-weight:900;cursor:pointer;color:#b14d82;font-family:inherit}
.kids-action-btn:hover{background:#fff7ee;transform:scale(1.05)}

.kids-points-pop{position:fixed;top:30%;left:50%;transform:translate(-50%,-50%);
  background:linear-gradient(135deg,#FFD700,#FF6EC7);color:#fff;font-size:42px;font-weight:900;
  padding:30px 50px;border-radius:30px;box-shadow:0 15px 40px rgba(0,0,0,.3);z-index:9999;
  animation:kids-pop 2.2s ease-out forwards;pointer-events:none}
@keyframes kids-pop{0%{opacity:0;transform:translate(-50%,-50%) scale(.3)}20%{opacity:1;transform:translate(-50%,-50%) scale(1.2)}80%{opacity:1;transform:translate(-50%,-70%) scale(1)}100%{opacity:0;transform:translate(-50%,-90%) scale(.9)}}

.kids-warning{padding:14px 18px;background:#fff7ee;border:3px solid #FFB347;border-radius:16px;
  margin:10px 0;font-size:14px;font-weight:800;color:#b05010;text-align:center}
.kids-parent-btn{padding:8px 16px;border:2px solid var(--line);background:#fff;border-radius:999px;font-size:11px;font-weight:800;cursor:pointer;font-family:inherit;color:#7a6d73}

@media (max-width:820px){.kids-grid,.kids-subs{grid-template-columns:1fr}}
@media (max-width:520px){.kids-card{min-height:150px;padding:20px 16px}.kids-card .ico{font-size:44px}.kids-card strong{font-size:18px}.kids-card span{font-size:12px}}

/* ═══ 📖 가이드 모드 전용 스타일 ═══ */
.gd-stage{padding:8px}
.gd-top{padding:20px 22px;margin-bottom:12px;border-radius:22px;
  background:linear-gradient(135deg,#fff5fa,#eff6ff,#effbf7);border:1px solid var(--line-strong);
  box-shadow:0 8px 24px rgba(126,87,110,.1)}
.gd-top h2{margin:0;font-size:24px;color:#b14d82}
.gd-top p{margin:6px 0 0;font-size:14px;color:var(--sub);line-height:1.7}
.gd-search{margin-top:12px;padding:10px 14px;border:2px solid var(--line-strong);border-radius:999px;
  font-size:14px;width:100%;font-family:inherit;outline:none}
.gd-search:focus{box-shadow:0 0 0 3px rgba(239,111,171,.15)}
.gd-actions{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px}
.gd-tb{padding:8px 14px;border:1px solid var(--line);background:#fff;border-radius:999px;font-size:12px;font-weight:800;cursor:pointer;font-family:inherit}
.gd-tb:hover{border-color:var(--line-strong)}

.gd-tabs{display:flex;gap:5px;overflow-x:auto;padding:8px;background:#fff;
  border:1px solid var(--line);border-radius:18px;margin-bottom:12px;box-shadow:0 4px 14px rgba(126,87,110,.06)}
.gd-tabs::-webkit-scrollbar{height:4px}
.gd-tab{flex:0 0 auto;padding:10px 14px;border-radius:12px;font-size:12px;font-weight:800;cursor:pointer;
  white-space:nowrap;color:#7a6d73;border:1.5px solid transparent;background:#fff;font-family:inherit;transition:.14s}
.gd-tab:hover{background:var(--pink-soft);border-color:var(--line-strong)}
.gd-tab.on{background:linear-gradient(135deg,#ef6fab,#9181ff);color:#fff;border-color:transparent;box-shadow:0 4px 12px rgba(232,166,198,.25)}

.gd-panel{background:#fff;border:1px solid var(--line);border-radius:20px;padding:22px;margin-bottom:12px;box-shadow:0 6px 18px rgba(126,87,110,.06)}
.gd-panel h3{margin:0 0 12px;font-size:20px;color:#b14d82}
.gd-panel h4{margin:16px 0 8px;font-size:16px;color:#5d4aad}
.gd-panel p{margin:0 0 10px;font-size:14px;line-height:1.8;color:#2b2430}
.gd-panel ul{margin:0 0 10px;padding-left:20px}
.gd-panel li{font-size:14px;line-height:1.9;color:#2b2430;margin-bottom:4px}

.gd-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:10px 0}
.gd-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:10px 0}
.gd-card{padding:18px;background:linear-gradient(135deg,var(--pink-soft),var(--purple-soft));
  border:2px solid var(--line-strong);border-radius:18px}
.gd-card.blue{background:linear-gradient(135deg,#eff6ff,#effbf7);border-color:#bcd7f0}
.gd-card.green{background:linear-gradient(135deg,#effbf7,#fff7ee);border-color:#c8ebd9}
.gd-card.peach{background:linear-gradient(135deg,#fff7ee,#fff5fa);border-color:#f1e0c4}
.gd-card h5{margin:0 0 8px;font-size:16px;color:#2b2430}
.gd-card .big-emoji{font-size:40px;margin-bottom:6px;display:block}

.gd-step-card{padding:18px;background:#fff;border:2px solid var(--line);border-radius:18px;display:flex;gap:14px;align-items:flex-start;margin-bottom:10px;cursor:pointer;transition:.14s}
.gd-step-card:hover{border-color:var(--line-strong);transform:translateX(4px)}
.gd-step-card.on{background:linear-gradient(135deg,var(--pink-soft),var(--purple-soft));border-color:var(--line-strong);box-shadow:0 8px 18px rgba(232,166,198,.2)}
.gd-step-num{flex:0 0 50px;height:50px;border-radius:14px;background:linear-gradient(135deg,#ef6fab,#9181ff);color:#fff;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:900}
.gd-step-body strong{display:block;font-size:16px;margin-bottom:4px;color:#b14d82}
.gd-step-body span{font-size:13px;color:var(--sub);line-height:1.7}

.gd-bigbtn{padding:14px 24px;border:none;border-radius:14px;background:linear-gradient(135deg,#ef6fab,#9181ff);color:#fff;font-size:15px;font-weight:900;cursor:pointer;font-family:inherit}
.gd-bigbtn:hover{transform:translateY(-1px)}

.gd-before-after{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:8px 0}
.gd-before-after > div{padding:14px;border-radius:14px;font-size:13px;line-height:1.8}
.gd-before{background:#fff2f2;border:2px solid #ffb0b0;color:#9a1a1a}
.gd-after{background:#eefbf7;border:2px solid #77DD77;color:#1a5a3a}

.gd-calc-row{display:flex;gap:10px;align-items:center;margin:10px 0}
.gd-calc-row label{flex:0 0 160px;font-size:13px;font-weight:800;color:#6b5d65}
.gd-calc-row input[type=range]{flex:1}
.gd-calc-row .val{font-size:15px;font-weight:900;color:#b14d82;min-width:80px;text-align:right}
.gd-result-box{padding:16px;background:linear-gradient(135deg,var(--pink-soft),var(--purple-soft));border:2px dashed var(--line-strong);border-radius:14px;margin:10px 0;font-size:14px;line-height:1.9;font-weight:700;color:#b14d82}

.gd-tree-btns{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.gd-tree-btn{padding:16px;border:2px solid var(--line);background:#fff;border-radius:14px;text-align:left;cursor:pointer;font-family:inherit;font-size:14px;font-weight:800;transition:.14s}
.gd-tree-btn:hover{transform:translateX(4px)}
.gd-tree-btn.red{border-color:#ffb0b0;background:#fff9f9}
.gd-tree-btn.yellow{border-color:#f1e0c4;background:#fffef5}
.gd-tree-btn.orange{border-color:#ffd4a8;background:#fff7ee}
.gd-tree-btn.purple{border-color:#d8d2f4;background:#f7f4ff}
.gd-tree-btn.blue{border-color:#bcd7f0;background:#eff6ff}

.gd-day-card{padding:16px;background:#fff;border:2px solid var(--line);border-radius:16px;margin-bottom:8px;display:grid;grid-template-columns:60px 1fr auto;gap:14px;align-items:center}
.gd-day-num{width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,#ef6fab,#9181ff);color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:900}
.gd-day-num.done{background:linear-gradient(135deg,#77DD77,#87CEEB)}
.gd-day-body strong{display:block;font-size:15px;color:#b14d82}
.gd-day-body span{font-size:12px;color:var(--sub)}
.gd-prog{height:10px;background:#f1dce7;border-radius:999px;overflow:hidden;margin:10px 0}
.gd-prog > div{height:100%;background:linear-gradient(90deg,#ef6fab,#9181ff);transition:width .4s}

details.gd-fold{border:1px solid var(--line);border-radius:14px;padding:10px 14px;margin-bottom:8px;background:#fff}
details.gd-fold[open]{background:var(--pink-soft);border-color:var(--line-strong)}
details.gd-fold summary{cursor:pointer;font-weight:800;font-size:14px;color:#b14d82;padding:4px 0}

.gd-pkg{padding:18px;border:2px solid var(--line-strong);border-radius:18px;background:#fff;margin-bottom:10px}
.gd-pkg.primary{background:linear-gradient(135deg,var(--pink-soft),var(--purple-soft))}
.gd-pkg h4{margin:0 0 8px;font-size:18px;color:#b14d82}
.gd-pkg .pkg-list{font-size:13px;line-height:1.9;color:#2b2430}

@media (max-width:820px){.gd-grid-2,.gd-grid-3,.gd-before-after,.gd-tree-btns{grid-template-columns:1fr}.gd-calc-row{flex-direction:column;align-items:stretch}.gd-calc-row label{flex:none}.gd-day-card{grid-template-columns:1fr}}
@media print{.tab-nav,.gd-tabs,.gd-actions,.tb-btn,.toptabs,.gd-search,.costbar{display:none!important}.gd-panel{box-shadow:none;border:1px solid #ccc}}

/* ═══ 💰 실시간 비용 바 ═══ */
.costbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  background:linear-gradient(135deg,#fff5fa,#f7f4ff);
  border:1px solid var(--line-strong);border-radius:999px;
  padding:8px 18px;margin-bottom:10px;font-size:12px;font-weight:800;
  box-shadow:0 4px 14px rgba(126,87,110,.08)}
.costbar .cb-sep{color:#d8c2ce}
.costbar .cb-ai{color:#b14d82}
.costbar b{color:#5d4aad;font-weight:900}
.costbar.warn{background:linear-gradient(135deg,#fff7ee,#fff5fa);border-color:#f1a860}
.costbar.warn b{color:#b05010}
.costbar.block{background:linear-gradient(135deg,#fff2f2,#fff5fa);border-color:#ff8888;animation:costPulse 1.5s ease-in-out infinite}
.costbar.block b{color:#c01818}
@keyframes costPulse{0%,100%{opacity:1}50%{opacity:.7}}
.cb-pct{padding:2px 8px;border-radius:999px;background:#fff;font-size:10px;margin-left:4px}
.cb-btn{padding:5px 12px;border:1px solid var(--line-strong);background:#fff;border-radius:999px;
  font-size:11px;font-weight:800;cursor:pointer;color:#b14d82;font-family:inherit;margin-left:auto}
.cb-btn:hover{background:var(--pink-soft)}
@media (max-width:560px){.costbar{font-size:11px;padding:6px 12px}.costbar .cb-sep{display:none}}

/* ═══ ⚙️ 설정 모드 전용 스타일 ═══ */
.set-stage{padding:8px}
.set-top{padding:20px 22px;margin-bottom:12px;border-radius:22px;
  background:linear-gradient(135deg,#fff5fa,#f7f4ff,#eff6ff);border:1px solid var(--line-strong)}
.set-top h2{margin:0;font-size:24px;color:#b14d82}
.set-top p{margin:6px 0 0;font-size:14px;color:var(--sub);line-height:1.7}
.set-hub{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:14px}
.set-hub-card{padding:22px 16px;border:2px solid var(--line);border-radius:20px;cursor:pointer;
  text-align:center;transition:.15s;background:#fff;font-family:inherit}
.set-hub-card:hover{border-color:var(--line-strong);transform:translateY(-2px);box-shadow:0 10px 24px rgba(126,87,110,.12)}
.set-hub-card.on{background:linear-gradient(135deg,var(--pink-soft),var(--purple-soft));border-color:var(--line-strong)}
.set-hub-card .ico{font-size:44px;display:block;margin-bottom:8px}
.set-hub-card strong{display:block;font-size:17px;color:#b14d82;margin-bottom:4px}
.set-hub-card span{display:block;font-size:12px;color:var(--sub);line-height:1.6}

.set-panel{background:#fff;border:1px solid var(--line);border-radius:20px;padding:22px;margin-bottom:12px;box-shadow:0 6px 18px rgba(126,87,110,.06)}
.set-panel h3{margin:0 0 8px;font-size:20px;color:#b14d82}
.set-panel .hint{margin:0 0 14px;font-size:13px;color:var(--sub);line-height:1.75;font-style:italic}
.set-panel h4{margin:16px 0 8px;font-size:15px;color:#5d4aad}

.set-key-card{padding:16px;border:2px solid var(--line);border-radius:16px;margin-bottom:10px;background:#fff}
.set-key-card.claude{border-color:#d8d2f4;background:linear-gradient(135deg,#f7f4ff,#fff)}
.set-key-card.openai{border-color:#c8ebd9;background:linear-gradient(135deg,#effbf7,#fff)}
.set-key-card.gemini{border-color:#bcd7f0;background:linear-gradient(135deg,#eff6ff,#fff)}
.set-key-card .khead{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px;flex-wrap:wrap}
.set-key-card .khead strong{font-size:15px}
.set-status{padding:4px 10px;border-radius:999px;font-size:11px;font-weight:800}
.set-status.on{background:#effbf7;color:#1a7a5a;border:1px solid #a8dcc9}
.set-status.off{background:#fff2f2;color:#9a1a1a;border:1px solid #ffb0b0}

.set-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:10px}
.set-row label{display:block;font-size:12px;font-weight:800;color:#6b5d65;margin-bottom:4px}
.set-in{width:100%;padding:11px 14px;border:1px solid #ead9e1;border-radius:12px;font-size:13px;font-family:inherit;background:#fff;outline:none}
.set-in:focus{border-color:var(--line-strong);box-shadow:0 0 0 3px rgba(239,111,171,.12)}

.set-pill-row{display:flex;gap:6px;flex-wrap:wrap;margin:6px 0}
.set-pill{padding:8px 14px;border:2px solid var(--line);background:#fff;border-radius:999px;
  font-size:12px;font-weight:800;cursor:pointer;color:#7a6d73;font-family:inherit}
.set-pill:hover{border-color:var(--line-strong)}
.set-pill.on{background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff;border-color:transparent}
.set-check{display:flex;align-items:center;gap:8px;padding:10px 14px;border:1px solid var(--line);
  border-radius:10px;background:#fff;font-size:13px;font-weight:800;cursor:pointer;margin-bottom:6px}
.set-check input{width:18px;height:18px}
.set-btn{padding:11px 18px;border:none;border-radius:12px;background:linear-gradient(135deg,#ef6fab,#9181ff);
  color:#fff;font-size:13px;font-weight:800;cursor:pointer;font-family:inherit}
.set-btn.ghost{background:#fff;color:#b14d82;border:2px solid var(--line-strong)}
.set-btn.danger{background:#fff2f2;color:#9a1a1a;border:2px solid #ffb0b0}

.set-budget-box{padding:16px;background:linear-gradient(135deg,var(--pink-soft),var(--purple-soft));border:2px dashed var(--line-strong);border-radius:16px;margin-bottom:10px}
.set-budget-box .pill{display:inline-block;padding:3px 10px;border-radius:999px;background:#fff;font-size:11px;font-weight:800;color:#b14d82;margin-left:4px}
.set-progress{height:14px;background:#f1dce7;border-radius:999px;overflow:hidden;margin:8px 0}
.set-progress > div{height:100%;background:linear-gradient(90deg,#77DD77,#FFD700,#FF6EC7);transition:width .4s}
.set-progress.warn > div{background:linear-gradient(90deg,#FFB347,#FFD700)}
.set-progress.block > div{background:linear-gradient(90deg,#FF6EC7,#ff8888)}

table.set-table{width:100%;border-collapse:collapse;font-size:13px;margin:8px 0}
table.set-table th,table.set-table td{padding:10px 12px;border:1px solid var(--line);text-align:left}
table.set-table th{background:var(--pink-soft);color:#b14d82;font-weight:900}
table.set-table tr:hover{background:#fff9fc}

.set-linkbtn{display:flex;align-items:center;gap:8px;padding:10px 14px;border:1px solid var(--line);
  border-radius:12px;background:#fff;font-size:13px;font-weight:800;cursor:pointer;font-family:inherit;color:#2b2430;text-decoration:none;margin-bottom:6px}
.set-linkbtn:hover{border-color:var(--line-strong);background:var(--pink-soft)}

@media (max-width:820px){.set-hub{grid-template-columns:repeat(2,1fr)}.set-row{grid-template-columns:1fr}}
@media (max-width:520px){.set-hub{grid-template-columns:1fr}}

@media (max-width:1180px){.layout{grid-template-columns:1fr}}
@media (max-width:980px){.grid{grid-template-columns:1fr 1fr}.brand p{display:none}}
@media (max-width:560px){.grid{grid-template-columns:1fr}.brand h1{font-size:20px}.hero h2{font-size:22px}}

/* ═══════════ 📱 숏츠 스튜디오 ═══════════ */
.studio-dash{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin:10px 0}
.studio-mode-card{background:#fff;border:2px solid var(--line);border-radius:18px;padding:20px;
  cursor:pointer;transition:.2s;display:flex;flex-direction:column;gap:8px;position:relative}
.studio-mode-card:hover{border-color:var(--line-strong);transform:translateY(-2px);box-shadow:var(--shadow-hover)}
.studio-mode-card.recommend::before{content:'🏆 추천';position:absolute;top:10px;right:12px;
  background:var(--pink-soft);border:1px solid var(--pink);color:var(--pink-deep);
  padding:3px 10px;border-radius:999px;font-size:11px;font-weight:900}
.studio-mode-card .ico{font-size:36px}
.studio-mode-card h4{margin:0;font-size:16px;font-weight:900}
.studio-mode-card p{margin:0;color:var(--sub);font-size:12.5px;line-height:1.6}

.studio-ch-bar{display:flex;gap:6px;flex-wrap:wrap;margin:10px 0}
.studio-ch{padding:10px 16px;border:2px solid var(--line);background:#fff;border-radius:999px;
  font-weight:900;font-size:13px;cursor:pointer;min-height:44px;transition:.15s}
.studio-ch.on{background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff;border-color:transparent}

/* 진행 바 */
.studio-progress{position:sticky;top:0;z-index:5;background:#fff;border:1px solid var(--line);
  border-radius:16px;padding:10px 12px;margin:10px 0;box-shadow:var(--shadow-soft)}
.studio-steps{display:flex;gap:4px;overflow-x:auto;padding:4px 2px}
.studio-step-pill{flex-shrink:0;padding:8px 12px;border:1px solid var(--line);background:#fff;
  border-radius:999px;font-size:12px;font-weight:900;white-space:nowrap;cursor:pointer}
.studio-step-pill.done{background:#eafbe8;border-color:#9ed99c;color:#326a31}
.studio-step-pill.current{background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff;border-color:transparent}
.studio-step-pill.locked{opacity:.5;cursor:not-allowed}

/* 단계 패널 */
.studio-panel{background:#fff;border:1px solid var(--line);border-radius:18px;padding:18px;margin:10px 0;box-shadow:var(--shadow-soft)}
.studio-panel h4{margin:0 0 6px;font-size:15px;color:var(--pink-deep)}
.studio-panel .sub{color:var(--sub);font-size:12.5px;margin:0 0 12px}
.studio-label{display:block;margin:10px 0 6px;font-size:13px;font-weight:900}
.studio-chips{display:flex;flex-wrap:wrap;gap:6px;margin:4px 0}
.studio-chip{padding:8px 13px;border:1.5px solid var(--line);background:#fff;border-radius:999px;
  font-size:12.5px;font-weight:800;cursor:pointer;transition:.12s;min-height:40px}
.studio-chip:hover{border-color:var(--line-strong)}
.studio-chip.on{background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff;border-color:transparent}
.studio-in{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:12px;font-size:14px;outline:none;background:#fff}
.studio-in:focus{border-color:var(--line-strong)}
.studio-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}
.studio-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.studio-btn{padding:12px 20px;border:none;border-radius:999px;font-weight:900;font-size:13px;cursor:pointer;min-height:44px}
.studio-btn.pri{background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff}
.studio-btn.ghost{background:#fff;border:1px solid var(--line)}
.studio-btn.ok{background:#eafbe8;color:#2f7a30;border:1px solid #9ed99c}

/* 프로젝트 목록 */
.studio-proj-list{display:grid;gap:8px;margin:10px 0}
.studio-proj-row{background:#fff;border:1px solid var(--line);border-radius:12px;padding:10px 14px;
  display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.studio-proj-row .name{font-weight:900;font-size:13.5px;flex:1}
.studio-proj-row .meta{font-size:11px;color:var(--sub)}
.studio-proj-row .stepbadge{background:var(--pink-soft);color:var(--pink-deep);
  padding:3px 10px;border-radius:999px;font-size:11px;font-weight:900}

/* 점수 표시 */
.studio-score{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;
  background:var(--pink-soft);color:var(--pink-deep);border-radius:999px;font-weight:900;font-size:12px}
.studio-score.ok{background:#eafbe8;color:#2f7a30}

/* iframe (Step 2 script engine) */
.studio-iframe-wrap{border:1px solid var(--line);border-radius:14px;overflow:hidden;margin-top:10px;background:#fff}
.studio-iframe-wrap iframe{width:100%;height:700px;border:0;display:block}
.studio-iframe-tabs{display:flex;gap:4px;flex-wrap:wrap;padding:8px;background:#fff5fa;border-bottom:1px solid var(--line)}
.studio-iframe-tabs button{padding:6px 12px;border:1px solid var(--line);background:#fff;border-radius:8px;font-size:11.5px;font-weight:800;cursor:pointer}
.studio-iframe-tabs button.on{background:var(--grad-main);color:#fff;border-color:transparent}

/* Step 2 이중 iframe (한·일) */
.studio-iframe-dual{display:grid;grid-template-columns:1fr 1fr;gap:10px}

/* 씬/이미지 카드 */
.studio-scene-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}
.studio-scene{background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden}
.studio-scene .img-box{aspect-ratio:9/16;background:#f3e4ee;display:flex;align-items:center;justify-content:center;color:var(--sub);font-size:11px}
.studio-scene .img-box img{width:100%;height:100%;object-fit:cover}
.studio-scene .meta{padding:8px;font-size:11.5px}
.studio-scene .acts{display:flex;gap:4px;padding:6px 8px;border-top:1px solid var(--line)}
.studio-scene .acts button{flex:1;padding:5px;border:1px solid var(--line);background:#fff;border-radius:6px;font-size:11px;cursor:pointer}

@media (max-width:820px){
  .studio-iframe-dual{grid-template-columns:1fr}
  .studio-iframe-wrap iframe{height:520px}
}
@media (max-width:480px){
  .studio-panel{padding:14px;border-radius:14px}
  .studio-step-pill{padding:6px 10px;font-size:11px}
  .studio-btn{padding:10px 14px;font-size:12px}
  .studio-iframe-wrap iframe{height:440px}
}

/* ═══════════ 🔍 유튜브 벤치마킹 ═══════════ */
.bench-root{padding:0}
.bench-tabs{display:flex;gap:6px;margin-bottom:14px;flex-wrap:wrap}
.bench-tab{padding:10px 16px;border:1.5px solid var(--line);background:#fff;border-radius:999px;
  font-weight:900;font-size:13px;cursor:pointer;transition:.15s}
.bench-tab:hover{border-color:var(--line-strong)}
.bench-tab.on{background:linear-gradient(135deg,#ef6fab,#9181ff);color:#fff;border-color:transparent}
.bench-panel{background:#fff;border:1px solid var(--line);border-radius:18px;padding:18px;margin-bottom:14px}
.bench-panel h4{margin:0 0 8px;font-size:15px;font-weight:900;color:var(--pink-deep)}
.bench-panel h5{margin:12px 0 6px;font-size:13px;font-weight:900;color:var(--text)}
.bench-section{background:linear-gradient(135deg,#fff5fa,#f7f4ff);border:1px solid var(--line-strong);
  border-radius:14px;padding:14px;margin:10px 0}
.bench-section h5{margin:0 0 8px;font-size:13px;color:var(--pink-deep)}
.bench-input{width:100%;min-height:120px;padding:12px 14px;border:1.5px solid var(--line);
  border-radius:12px;font-size:13.5px;line-height:1.7;outline:none;background:#fff;resize:vertical}
.bench-input:focus{border-color:var(--line-strong)}
.bench-small{padding:10px 12px;border:1.5px solid var(--line);border-radius:10px;font-size:13px;width:100%}
.bench-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px}
.bench-method{border:2px solid var(--line);border-radius:14px;padding:14px;cursor:pointer;transition:.15s;background:#fff}
.bench-method:hover{border-color:var(--line-strong)}
.bench-method.on{border-color:var(--pink);background:linear-gradient(135deg,#fff5fa,#f7f4ff);box-shadow:0 0 0 3px rgba(239,111,171,.15)}
.bench-method b{font-size:13px}
.bench-method small{display:block;color:var(--sub);font-size:11.5px;margin-top:4px}
.bench-score{display:inline-block;padding:3px 10px;border-radius:999px;font-weight:900;font-size:12px;
  background:var(--pink-soft);color:var(--pink-deep)}
.bench-score.ok{background:#eafbe8;color:#2f7a30}
.bench-score.warn{background:#fff7ee;color:#a26b2a}
.bench-score.err{background:#fee2e4;color:#a83245}
.bench-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:6px 0}
.bench-bar{display:flex;align-items:center;gap:8px;margin:4px 0;font-size:12.5px}
.bench-bar .lbl{min-width:70px;font-weight:900;color:var(--sub)}
.bench-bar .bar{flex:1;height:8px;background:#f3e4ee;border-radius:999px;overflow:hidden}
.bench-bar .bar b{display:block;height:100%;background:linear-gradient(90deg,#ef6fab,#9181ff);transition:.3s}
.bench-bar .val{font-weight:900;width:40px;text-align:right}
.bench-topic-card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:10px 12px;
  margin:6px 0;display:flex;justify-content:space-between;align-items:center;gap:10px}
.bench-topic-card.red{border-left:4px solid #d95574}
.bench-topic-card.green{border-left:4px solid #2fa98a}
.bench-lib-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px;margin:10px 0}
.bench-lib-card .hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.bench-checklist{background:linear-gradient(135deg,#fff5fa,#eff6ff);border:1px solid var(--line-strong);
  border-radius:14px;padding:14px;margin:10px 0}
.bench-checklist label{display:flex;gap:8px;align-items:flex-start;padding:5px 0;font-size:13px;cursor:pointer}
.bench-checklist input[type=checkbox]{width:16px;height:16px;margin-top:3px}

@media (max-width:640px){
  .bench-row{grid-template-columns:1fr}
  .bench-tab{padding:8px 12px;font-size:12px}
}

/* ═══════════ 🔥 오늘의 추천 주제 (접이식) ═══════════ */
.today-topic{background:linear-gradient(135deg,#fff5fa,#eff6ff);border:1px dashed var(--pink);
  border-radius:14px;padding:10px 14px;margin:0 0 12px}
.today-topic-head{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:13px;font-weight:900}
.today-topic-head .tp-ico{font-size:16px}
.today-topic-head .tp-date{margin-left:auto;color:var(--sub);font-size:11.5px;font-weight:600}
.today-topic-head .tp-toggle{font-size:13px;color:var(--sub);margin-left:6px;transition:.2s}
.today-topic-body{margin-top:8px;overflow:hidden;transition:max-height .25s ease, opacity .2s ease;max-height:400px;opacity:1}
.today-topic-body.tp-closed{max-height:0;opacity:0;margin-top:0}
.tp-season{font-size:12.5px;color:var(--pink-deep);font-weight:800;margin-bottom:6px}
.tp-chips{display:flex;flex-wrap:wrap;gap:5px}
.tp-chip{padding:6px 11px;border:1px solid var(--line);background:#fff;border-radius:999px;
  font-size:11.5px;font-weight:800;cursor:pointer;transition:.12s}
.tp-chip:hover{border-color:var(--pink);background:var(--pink-soft);color:var(--pink-deep)}

/* ═══════════ 채널 선택 (원스톱 허브 상단) ═══════════ */
.one-channel{display:flex;gap:6px;justify-content:center;margin-bottom:14px;flex-wrap:wrap}
.one-ch{padding:8px 16px;border:2px solid var(--line);background:#fff;border-radius:999px;
  font-weight:900;font-size:12.5px;cursor:pointer;transition:.15s;min-height:40px}
.one-ch:hover{border-color:var(--line-strong)}
.one-ch.on{background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff;border-color:transparent}

/* ═══════════ ☕ 원스톱 허브 (메인 히어로) ═══════════ */
.one-hub{background:linear-gradient(135deg,#fff5fa,#f7f4ff);border:1px solid var(--line-strong);
  border-radius:26px;padding:22px;margin:0 0 16px;box-shadow:var(--shadow-soft)}
.one-q{margin:0 0 14px;font-size:24px;font-weight:900;text-align:center;
  background:var(--grad-main);-webkit-background-clip:text;background-clip:text;color:transparent}
.one-in{width:100%;min-height:120px;padding:16px 18px;border:2px solid var(--line-strong);
  border-radius:18px;font-size:15px;font-weight:600;line-height:1.7;outline:none;background:#fff;resize:vertical;
  font-family:inherit;transition:.15s}
.one-in:focus{border-color:var(--pink);box-shadow:0 0 0 4px rgba(239,111,171,.15)}
.one-formats{display:flex;gap:8px;flex-wrap:wrap;margin:14px 0 12px;justify-content:center}
.one-fmt{padding:12px 18px;border:2px solid var(--line);background:#fff;border-radius:999px;
  font-size:14px;font-weight:900;cursor:pointer;transition:.15s;position:relative}
.one-fmt:hover{border-color:var(--line-strong);transform:translateY(-1px)}
.one-fmt.on{background:linear-gradient(135deg,#fff,#fff5fa);border-color:var(--pink);
  box-shadow:0 0 0 3px rgba(239,111,171,.15)}
.one-fmt .pill{background:var(--grad-main);color:#fff;border-radius:999px;
  font-size:10px;padding:2px 8px;margin-left:4px;font-weight:900}
.one-make{display:block;margin:18px auto 8px;padding:16px 42px;border:none;
  background:var(--grad-main);color:#fff;border-radius:999px;font-size:17px;font-weight:900;
  cursor:pointer;transition:.2s;box-shadow:0 10px 26px rgba(239,111,171,.30);letter-spacing:.5px}
.one-make:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(239,111,171,.40)}
.one-make:disabled{opacity:.6;cursor:not-allowed;transform:none}
.one-hint{text-align:center;font-size:12px;color:var(--sub);margin:6px 0 14px}
.one-quick{margin-top:16px;padding-top:14px;border-top:1px dashed var(--line)}
.one-quick-title{font-size:11.5px;color:var(--sub);font-weight:900;margin-bottom:8px;text-align:center}
.one-quick-row{display:flex;gap:6px;flex-wrap:wrap;justify-content:center}
.one-qchip{padding:8px 13px;border:1px solid var(--line);background:#fff;border-radius:999px;
  font-size:12px;font-weight:800;cursor:pointer;transition:.1s}
.one-qchip:hover{border-color:var(--pink);background:var(--pink-soft)}

/* 진행상황 */
.one-progress{margin-top:14px;padding:14px;background:#fff;border:1px solid var(--line);
  border-radius:14px;font-size:13px}
.one-progress .step{padding:4px 0;display:flex;align-items:center;gap:8px}
.one-progress .step .ico{width:18px;text-align:center}

/* 통합 결과 */
.one-result{margin-top:14px}
.uni-result{background:#fff;border:1px solid var(--line);border-radius:18px;padding:16px;
  box-shadow:var(--shadow-soft)}
.uni-result h3{margin:0 0 6px;font-size:17px;font-weight:900}
.uni-result .meta{font-size:11.5px;color:var(--sub);margin-bottom:12px}
.uni-body{background:#fdf6fa;border:1px solid var(--line);border-radius:14px;padding:16px;
  max-height:560px;overflow-y:auto;line-height:1.9}
.uni-body img{max-width:100%;border-radius:10px;display:block;margin:12px 0}
.uni-body h1{font-size:20px;color:var(--pink-deep);margin:18px 0 8px}
.uni-body h2{font-size:17px;color:var(--pink-deep);margin:16px 0 6px}
.uni-body h3{font-size:15px;color:var(--pink-deep);margin:12px 0 4px}
.uni-body blockquote{border-left:4px solid var(--pink);padding:10px 14px;
  background:#fff5fa;margin:10px 0;border-radius:8px}
.uni-body hr{border:none;border-top:2px solid var(--line);margin:16px 0}
.uni-actions{margin-top:14px;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}
.uni-actions>div>b{display:block;font-size:12px;color:var(--pink-deep);margin-bottom:6px}
.uni-actions button,.uni-actions a{padding:8px 12px;border:1px solid var(--line);background:#fff;
  border-radius:10px;font-size:12px;font-weight:800;cursor:pointer;text-decoration:none;color:var(--text);display:inline-block;margin:2px 4px 2px 0}
.uni-actions button:hover,.uni-actions a:hover{border-color:var(--pink)}

/* 카테고리 접힘 */
.cat-fold{margin-top:8px}
.cat-fold summary{list-style:none;cursor:pointer;padding:10px 16px;background:#fff;
  border:1px solid var(--line);border-radius:14px;font-weight:900;font-size:13px;
  display:flex;align-items:center;gap:6px}
.cat-fold summary::-webkit-details-marker{display:none}
.cat-fold summary::before{content:'▸';transition:.2s;display:inline-block}
.cat-fold[open] summary::before{transform:rotate(90deg)}

@media (max-width:640px){
  .one-hub{padding:16px;border-radius:20px}
  .one-q{font-size:19px}
  .one-in{min-height:100px;font-size:14px}
  .one-fmt{padding:10px 14px;font-size:12.5px}
  .one-make{padding:14px 32px;font-size:15px}
}

/* ═══════════ 🎨 콘텐츠 빌더 ═══════════ */
.bld-brandkit{background:linear-gradient(135deg,#fff5fa,#f7f4ff);border:1px solid var(--line-strong);
  border-radius:14px;padding:10px 14px;margin:6px 0 0}
.bld-brandkit summary{cursor:pointer;font-weight:900;font-size:13px;list-style:none}
.bld-brandkit summary::-webkit-details-marker{display:none}
.bld-brandkit summary::before{content:'▸ ';margin-right:4px;transition:.2s;display:inline-block}
.bld-brandkit[open] summary::before{transform:rotate(90deg)}
.bld-brandkit .bk-sum{margin-left:8px;color:var(--sub);font-weight:700;font-size:12px}
.bld-brandkit-body{padding:8px 0 2px}

.bld-flow-banner{background:linear-gradient(135deg,var(--pink-soft),var(--purple-soft));
  border:1px dashed var(--pink);border-radius:14px;padding:12px 14px;margin:10px 0;font-size:13px}
.bld-flow-banner b{display:block;margin-bottom:6px;color:var(--pink-deep)}
.bld-flow{font-size:12px;color:var(--sub);display:flex;flex-wrap:wrap;gap:4px;align-items:center}
.bld-flow span{background:#fff;padding:3px 9px;border-radius:999px;border:1px solid var(--line)}

.bld-panel{margin-top:12px}

/* 3단 레이아웃 — 기본 2단 (왼쪽 설정 + 가운데 캔버스) */
.bld-3col{display:grid;grid-template-columns:280px 1fr;gap:12px;align-items:flex-start}
.bld-3col.advanced{grid-template-columns:260px 1fr 280px}
.bld-col-right{display:none}
.bld-3col.advanced .bld-col-right{display:block}
.bld-col{background:#fff;border:1px solid var(--line);border-radius:16px;padding:14px;min-width:0}
.bld-col h4{margin:0 0 8px;font-size:13px;font-weight:900;color:var(--pink-deep)}
.bld-col label{margin-top:4px;font-size:12px}

/* 템플릿 그리드 */
.bld-tpl-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.bld-tpl{background:#fff;border:2px solid var(--line);border-radius:12px;padding:8px 6px;
  cursor:pointer;transition:.15s;text-align:center}
.bld-tpl:hover{border-color:var(--line-strong)}
.bld-tpl.on{border-color:var(--pink);background:linear-gradient(135deg,#fff5fa,#f7f4ff)}
.bld-tpl .ico{font-size:22px}
.bld-tpl .t{font-weight:900;font-size:11.5px;margin:2px 0}
.bld-tpl .s{font-size:10px;color:var(--sub)}

/* pill / chip */
.bld-pill-row{display:flex;gap:4px;flex-wrap:wrap;margin:4px 0}
.bld-pill{padding:6px 11px;border:1.5px solid var(--line);background:#fff;border-radius:999px;
  font-size:11.5px;font-weight:800;cursor:pointer;transition:.12s}
.bld-pill:hover{border-color:var(--line-strong)}
.bld-pill.on{background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff;border-color:transparent}
.bld-chip{padding:6px 11px;border:1px solid var(--line);background:#fff;border-radius:10px;
  font-size:12px;font-weight:800;cursor:pointer}
.bld-chip.on{background:var(--grad-main);color:#fff;border-color:transparent}

/* 편집기 툴바 */
.bld-editor-toolbar{display:flex;gap:4px;padding:8px;background:#fff;border:1px solid var(--line);
  border-radius:10px;margin-bottom:8px;flex-wrap:wrap}
.bld-editor-toolbar button{padding:6px 10px;border:1px solid var(--line);background:#fff;
  border-radius:8px;font-weight:900;font-size:13px;cursor:pointer;transition:.1s}
.bld-editor-toolbar button:hover{border-color:var(--line-strong);background:var(--pink-soft)}
.bld-editor-toolbar button.on{background:var(--grad-main);color:#fff;border-color:transparent}
.bld-size-row{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:8px}

/* 캔버스 */
.bld-canvas-wrap{background:#f6edf3;border-radius:14px;padding:14px;min-height:420px}
.bld-canvas{background:#fff;border:1px solid var(--line);border-radius:12px;padding:20px;
  max-width:700px;margin:0 auto;min-height:360px;transition:max-width .3s}
.bld-canvas.size-insta{max-width:500px;aspect-ratio:1}
.bld-canvas.size-story{max-width:340px;aspect-ratio:9/16}
.bld-canvas.size-kakao{max-width:560px}
.bld-canvas.mobile{max-width:390px !important}
.bld-empty{text-align:center;padding:60px 20px;color:var(--muted);font-size:13px}

/* 블록 */
.bld-block{position:relative;padding:10px 12px;margin:6px 0;border:2px solid transparent;
  border-radius:10px;transition:.12s}
.bld-block:hover{border-color:var(--line)}
.bld-block.sel{border-color:var(--pink);background:#fff5fa}
.bld-block .bld-acts{position:absolute;right:4px;top:4px;display:none;gap:2px;z-index:2}
.bld-block.sel .bld-acts{display:flex}
.bld-block .bld-acts button{padding:3px 7px;background:#fff;border:1px solid var(--line);
  border-radius:6px;font-size:11px;cursor:pointer}
.bld-block .bld-acts button:hover{border-color:var(--pink)}
.bld-block[contenteditable="true"]{outline:none}
.bld-block-img img{max-width:100%;border-radius:8px;display:block}
.bld-block-divider{height:2px;background:var(--line);margin:14px 0}
.bld-block-button a{display:inline-block;padding:10px 18px;background:var(--grad-main);color:#fff;
  border-radius:999px;font-weight:900;text-decoration:none}
.bld-block-quote{padding:12px 14px;border-left:4px solid var(--pink);background:var(--pink-soft);
  border-radius:8px;font-style:italic}
.bld-block-table table{width:100%;border-collapse:collapse;font-size:13px}
.bld-block-table th,.bld-block-table td{padding:8px;border:1px solid var(--line);text-align:left}
.bld-block-table th{background:var(--pink-soft);font-weight:900}
.bld-block-checklist ul{list-style:none;padding:0;margin:0}
.bld-block-checklist li::before{content:'☐ ';color:var(--pink)}
.bld-block-checklist li.done::before{content:'☑ ';color:var(--ok)}

/* 읽기 진행바 */
.bld-read-progress{position:sticky;top:0;height:4px;background:#f3e4ee;border-radius:999px;margin:-12px -12px 12px;overflow:hidden}
.bld-read-progress b{display:block;height:100%;width:0;background:var(--grad-main);transition:.2s}

/* 목차 사이드바 */
.bld-toc{background:#fff5fa;border:1px solid var(--line);border-radius:12px;padding:10px 14px;margin:8px 0}
.bld-toc h5{margin:0 0 6px;font-size:12px;color:var(--pink-deep);font-weight:900}
.bld-toc ul{list-style:none;padding:0;margin:0;font-size:12px}
.bld-toc li{padding:3px 0;cursor:pointer}
.bld-toc li:hover{color:var(--pink-deep)}

/* 형광펜 / 카운트업 애니 */
.bld-hl{background:linear-gradient(180deg,transparent 60%,rgba(255,225,100,.75) 60%);padding:0 2px;border-radius:2px}

/* 오른쪽 탭 */
.bld-right-tabs{display:flex;gap:3px;margin-bottom:10px}
.bld-right-tabs button{flex:1;padding:7px 4px;border:1px solid var(--line);background:#fff;
  border-radius:8px;font-weight:900;font-size:12px;cursor:pointer}
.bld-right-tabs button.on{background:var(--grad-main);color:#fff;border-color:transparent}
.bld-tab{display:none}
.bld-tab.on{display:block}

/* SEO */
.seo-list{list-style:none;padding:0;margin:0;font-size:12px;line-height:1.9}
.seo-list li{padding:3px 0}
.seo-list li.ok::before{content:'✅ ';color:var(--ok)}
.seo-list li.warn::before{content:'⚠️ ';color:var(--warn)}
.seo-list li.fail::before{content:'❌ ';color:var(--err)}

/* Export */
.bld-export{background:linear-gradient(135deg,#fff5fa,#f7f4ff);border:1px solid var(--line-strong);
  border-radius:16px;padding:16px;margin:14px 0}
.bld-export h4{margin:0 0 10px;font-size:15px}
.bld-export-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px}
.bld-export-grid>div>b{display:block;margin-bottom:6px;font-size:13px}
.bld-btnrow{display:flex;gap:6px;flex-wrap:wrap}
.bld-btnrow .mz-btn{flex:1 1 auto;font-size:12px;padding:8px 10px}

/* 성과 */
.bld-perf{background:#fff;border:1px solid var(--line);border-radius:16px;padding:14px;margin-top:14px}
.bld-perf h4{margin:0 0 8px;font-size:14px;color:var(--pink-deep)}

/* 모바일 */
@media (max-width:1080px){
  .bld-3col{grid-template-columns:1fr}
}
@media (max-width:480px){
  .bld-editor-toolbar button{padding:5px 8px;font-size:12px}
  .bld-canvas{padding:14px}
}

/* ═══════════ 📱 모바일 하단 네비게이션 ═══════════ */
.mobile-nav{display:none;position:fixed;left:0;right:0;bottom:0;z-index:9997;
  background:#fff;border-top:1px solid var(--line);box-shadow:0 -6px 20px rgba(126,87,110,.10);
  padding:6px 8px calc(6px + env(safe-area-inset-bottom,0));
  grid-template-columns:repeat(4,1fr);gap:4px}
.mobile-nav button{min-height:56px;background:#fff;border:none;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:2px;font-weight:900;color:var(--sub);
  border-radius:14px;transition:.15s;cursor:pointer}
.mobile-nav button .ico{font-size:20px}
.mobile-nav button .lbl{font-size:11px}
.mobile-nav button.on{color:var(--pink-deep);background:var(--pink-soft)}
.mobile-nav button:active{transform:scale(.95)}
body.kb-open .mobile-nav{display:none !important}
body.kb-open .brand h1{font-size:16px}
body.kb-open .brand p{display:none}

/* ═══════════ 👤 프로필 배지 & 전환 모달 ═══════════ */
.profile-badge{position:fixed;right:14px;top:14px;z-index:998;
  background:#fff;border:1px solid var(--line-strong);border-radius:999px;
  padding:6px 12px 6px 8px;display:flex;align-items:center;gap:6px;cursor:pointer;
  box-shadow:var(--shadow-soft);font-weight:800;font-size:13px;transition:.15s}
.profile-badge:hover{border-color:var(--pink);transform:translateY(-1px)}
.profile-badge .emoji{font-size:18px}
.profile-badge .name{max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

.profile-modal{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:9998;
  display:none;align-items:center;justify-content:center;padding:20px}
.profile-modal.on{display:flex;animation:profileFade .25s ease}
@keyframes profileFade{from{opacity:0}to{opacity:1}}
.profile-modal-body{background:#fff;border-radius:20px;max-width:520px;width:100%;
  padding:22px;box-shadow:var(--shadow);max-height:86vh;overflow-y:auto}
.profile-modal-body h3{margin:0 0 6px;font-size:18px}
.profile-modal-body .sub{color:var(--sub);font-size:13px;margin:0 0 14px}
.profile-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:10px;margin-bottom:12px}
.profile-card{background:#fff;border:2px solid var(--line);border-radius:16px;padding:16px 10px;
  text-align:center;cursor:pointer;transition:.2s;min-height:130px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px}
.profile-card:hover{border-color:var(--line-strong);transform:translateY(-2px)}
.profile-card.on{border-color:var(--pink);background:linear-gradient(135deg,#fff5fa,#f7f4ff);
  box-shadow:0 0 0 3px rgba(239,111,171,.15)}
.profile-card .emoji{font-size:36px}
.profile-card .name{font-weight:900;font-size:14px}
.profile-card .chk{font-size:10px;color:var(--pink-deep);font-weight:900;margin-top:2px}
.profile-card.add{border-style:dashed;color:var(--sub)}

/* ═══════════ 📱 768px 이하 통합 모바일 세트 ═══════════ */
@media (max-width:768px){
  .mobile-nav{display:grid}
  .main-content,.app,main.card{padding-bottom:92px}
  button,.btn,.mz-btn,.set-btn,.vs-btn{min-height:44px}
  input[type=text],input[type=password],input[type=number],input[type=email],input[type=search],textarea,select{font-size:16px}
  body{font-size:14.5px}
  /* 모바일에서 결과/3단 레이아웃 세로로 */
  .bld-3col{grid-template-columns:1fr}
  /* 프로필 배지는 상단 브랜드 영역과 겹칠 수 있어 약간 축소 */
  .profile-badge{top:10px;right:10px;padding:5px 10px 5px 6px;font-size:12px}
}

/* ─── 390px 전용 모바일 대응 ─── */
@media (max-width:480px){
  .app{padding:8px 6px 48px}
  .layout{grid-template-columns:1fr !important;gap:8px}
  /* 사이드바는 햄버거로만 열도록 기본 숨김 (모바일메뉴 토글로 표시) */
  body:not(.sidebar-open) .stack#sidebar{display:none}
  body.sidebar-open .stack#sidebar{
    position:fixed;left:0;top:0;z-index:9998;width:80vw;max-width:300px;height:100vh;
    background:#fff;padding:16px 12px;overflow-y:auto;box-shadow:8px 0 24px rgba(0,0,0,.18);
    border-right:1px solid var(--line);
  }
  /* 햄버거 버튼 (JS 가 .mobile-sidebar-toggle 로 생성) */
  .mobile-sidebar-toggle{
    position:fixed;left:10px;top:10px;z-index:9999;
    width:42px;height:42px;border-radius:12px;border:1px solid var(--line);
    background:#fff;font-size:20px;font-weight:900;box-shadow:var(--shadow-soft);
  }
  body.sidebar-open::before{
    content:'';position:fixed;inset:0;background:rgba(0,0,0,.35);z-index:9997;
  }
  /* 모든 multi-column grid → 1열 */
  .grid,.grid-2,.grid-3,.grid-4{grid-template-columns:1fr !important}
  .set-hub{grid-template-columns:1fr !important}
  .set-row{grid-template-columns:1fr !important}
  .set-table{font-size:11.5px}
  .set-table th,.set-table td{padding:6px 4px}
  .brand h1{font-size:18px}
  .brand p{display:none}
  .hero h2{font-size:20px}
  .toptab{padding:8px 10px;font-size:12px}
  .cardhead{padding:14px 14px 8px}
  .cardbody{padding:10px 10px 14px}
  /* 상단 비용바 간격 축소 */
  #costBar{padding:8px 10px;font-size:12px}
  /* 좌우 가로 스크롤 방지 */
  html,body{overflow-x:hidden;max-width:100vw}
}
@media (min-width:481px){ .mobile-sidebar-toggle{display:none} }

/* ═══ 미디어 조합 바 ═══ */
.media-bar{
  margin-top:14px;
  padding:14px;
  background:linear-gradient(135deg,#fff5fa,#f4eaff);
  border:1px solid #f0c8de;
  border-radius:16px;
  animation:fadeInUp .3s ease;
}
@keyframes fadeInUp{
  from{opacity:0;transform:translateY(8px)}
  to{opacity:1;transform:translateY(0)}
}
.mb-style-btn:hover{background:var(--pink-soft)!important;border-color:var(--pink)!important}

/* ═══════════════════════════════════════════════════════════
   📝 숏츠 Step3 장르 카드 + iframe 슬라이드
   ═══════════════════════════════════════════════════════════ */
.sh-genre-card{padding:14px 10px;background:#fff;border:2px solid var(--line);border-radius:14px;
  cursor:pointer;transition:.15s;text-align:center;min-height:96px;display:flex;flex-direction:column;justify-content:center}
.sh-genre-card:hover{border-color:var(--line-strong);transform:translateY(-1px)}
.sh-genre-card.on{background:linear-gradient(135deg,var(--pink-soft),var(--purple-soft));
  border-color:var(--pink);box-shadow:0 0 0 3px rgba(239,111,171,.15);color:var(--pink-deep)}

.sh-iframe-wrap{max-height:0;overflow:hidden;opacity:0;transition:max-height .3s ease, opacity .25s ease;
  margin-top:10px;border-radius:14px;background:#fff}
.sh-iframe-wrap.open{max-height:760px;opacity:1;border:1px solid var(--line);box-shadow:var(--shadow-soft)}
.sh-iframe-wrap iframe{width:100%;height:700px;border:0;display:block;background:#fff}

/* ═══════════════════════════════════════════════════════════
   🌟 ucHeader — 새 상단 헤더 (기존 costbar/top/newHeader 전부 대체)
   ═══════════════════════════════════════════════════════════ */
/* 기존 UI + 이전 헤더 버전들 전부 숨김 */
.costbar,
#costBar,
.top,
.top .brand,
.top .toptabs,
#toptabs,
#oneHub,
#navCtrl,
#breadcrumb,
#newHeader,
.new-header,
.uc-header,
#helpFab{ display:none !important }

#ucHeader{position:sticky;top:0;z-index:200;background:rgba(255,249,252,.92);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);box-shadow:0 2px 10px rgba(126,87,110,.08)}

/* 줄1: 정보바 */
.uch-info{display:flex;align-items:center;gap:14px;padding:10px 18px;min-height:50px}

/* 왼쪽: 날짜·날씨 */
.uch-date{display:flex;align-items:center;gap:10px;flex:1 1 33%;font-size:12.5px;min-width:0}
.uch-date #uchDateStr{font-weight:900;color:var(--text);white-space:nowrap}
.uch-weather{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;
  background:var(--pink-soft);color:var(--pink-deep);border-radius:999px;font-weight:800;font-size:11.5px;white-space:nowrap}
.uch-weather.err{background:#f3e4ee;color:var(--sub)}
.uch-weather #uchWTemp{font-weight:900}
.uch-weather #uchWDesc{opacity:.85}

/* 가운데: 로고·제목 */
.uch-center{display:flex;align-items:center;gap:10px;flex:1 1 34%;justify-content:center;min-width:0}
.uch-logo{width:36px;height:36px;border-radius:12px;background:var(--grad-logo);color:#fff;
  font-weight:900;font-size:17px;display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 10px rgba(239,111,171,.25)}
.uch-title{margin:0;font-size:16px;font-weight:900;letter-spacing:-.3px;
  background:var(--grad-main);-webkit-background-clip:text;background-clip:text;color:transparent;white-space:nowrap}

/* 오른쪽: AI·비용·잔액 */
.uch-status{display:flex;align-items:center;gap:6px;flex:1 1 33%;justify-content:flex-end;font-size:12px;flex-wrap:wrap}
.uch-ai{display:inline-flex;align-items:center;gap:4px;padding:5px 11px;background:#fff;
  border:1px solid var(--line);border-radius:999px;font-weight:800}
.uch-cost{display:inline-flex;align-items:center;gap:3px;padding:5px 11px;background:#fff;
  border:1px solid var(--line);border-radius:999px;font-weight:700;white-space:nowrap}
.uch-cost b{color:var(--pink-deep)}
.uch-balance{padding:6px 13px;border:1px solid var(--line);background:#fff;border-radius:999px;
  font-weight:900;font-size:11.5px;cursor:pointer;min-height:32px;transition:.12s}
.uch-balance:hover{border-color:var(--pink);background:var(--pink-soft)}

/* 줄2: 컨트롤바 (탭/검색/언어/아이콘) */
.uch-ctrl{display:flex;align-items:center;gap:10px;padding:8px 18px;border-top:1px solid var(--line);
  background:rgba(253,246,250,.72)}
.uch-tabs{display:flex;gap:4px;flex-wrap:wrap}
.uch-tabs button{padding:7px 13px;background:#fff;border:1px solid var(--line);border-radius:999px;
  font-weight:900;font-size:12.5px;cursor:pointer;min-height:36px;transition:.12s}
.uch-tabs button:hover{border-color:var(--line-strong)}
.uch-tabs button.on{background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff;border-color:transparent;
  box-shadow:0 4px 10px rgba(239,111,171,.25)}

.uch-search{flex:1;max-width:400px;position:relative}
.uch-search input{width:100%;padding:8px 14px 8px 36px;border:1px solid var(--line);border-radius:999px;
  background:#fff;font-size:13px;outline:none;min-height:36px;transition:.15s}
.uch-search input:focus{border-color:var(--line-strong);box-shadow:0 0 0 3px rgba(239,111,171,.12)}
.uch-search::before{content:'🔍';position:absolute;left:13px;top:50%;transform:translateY(-50%);font-size:14px;pointer-events:none}
.uch-search-dd{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid var(--line);
  border-radius:14px;box-shadow:var(--shadow);padding:6px;max-height:400px;overflow-y:auto;display:none;z-index:250}
.uch-search-dd.open{display:block;animation:uchFadeIn .18s ease}
.uch-search-dd .sd-group{padding:6px 10px;font-size:10.5px;color:var(--sub);font-weight:900;text-transform:uppercase;letter-spacing:.5px}
.uch-search-dd .sd-item{padding:9px 12px;border-radius:8px;cursor:pointer;font-size:13px;font-weight:700;
  display:flex;align-items:center;gap:8px}
.uch-search-dd .sd-item:hover{background:var(--pink-soft);color:var(--pink-deep)}
.uch-search-dd .sd-desc{color:var(--sub);font-size:11px;margin-left:auto;font-weight:400}

.uch-icons{display:flex;align-items:center;gap:6px}
.uch-lang-dd{position:relative}
.uch-lang-btn{padding:7px 12px;background:#fff;border:1px solid var(--line);border-radius:999px;
  font-weight:800;font-size:13px;cursor:pointer;min-height:36px;display:flex;align-items:center;gap:4px}
.uch-lang-btn:hover{border-color:var(--pink)}
.uch-lang-menu{position:absolute;top:calc(100% + 6px);right:0;background:#fff;border:1px solid var(--line);
  border-radius:14px;box-shadow:var(--shadow);padding:6px;min-width:150px;display:none;z-index:250}
.uch-lang-dd.open .uch-lang-menu{display:block;animation:uchFadeIn .18s ease}
.uch-lang-menu button{display:block;width:100%;padding:9px 12px;background:transparent;border:none;border-radius:8px;
  text-align:left;font-weight:800;font-size:13px;cursor:pointer}
.uch-lang-menu button:hover{background:var(--pink-soft);color:var(--pink-deep)}
.uch-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#fff;
  border:1px solid var(--line);border-radius:12px;cursor:pointer;font-size:14px;transition:.12s}
.uch-icon:hover{border-color:var(--pink);background:var(--pink-soft);transform:translateY(-1px)}

/* 줄3: 브레드크럼 */
.uch-breadcrumb{display:none;align-items:center;gap:8px;padding:7px 18px;background:#fff;
  border-top:1px solid var(--line);font-size:12px}
.uch-breadcrumb.on{display:flex}
.uch-breadcrumb .bc-home{color:var(--sub);cursor:pointer;font-weight:700;display:inline-flex;align-items:center;gap:3px}
.uch-breadcrumb .bc-home:hover{color:var(--pink-deep)}
.uch-breadcrumb .bc-sep{color:var(--muted)}
.uch-breadcrumb .bc-current{font-weight:900;color:var(--text)}
.uch-breadcrumb .bc-save{margin-left:auto;font-size:11px;color:var(--ok);font-weight:800}
.uch-breadcrumb .bc-save.saving{color:var(--warn)}

@keyframes uchFadeIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}

/* 모바일 */
@media (max-width:820px){
  .uch-info{flex-wrap:wrap;padding:8px 12px;gap:6px}
  .uch-date,.uch-center,.uch-status{flex-basis:100%;justify-content:flex-start}
  .uch-center{order:-1;justify-content:center}
  .uch-title{font-size:14px}
  .uch-status{flex-wrap:wrap}
}
@media (max-width:600px){
  .uch-ctrl{flex-wrap:wrap;padding:6px 10px;gap:6px}
  .uch-search{flex-basis:100%;max-width:none;order:2}
  .uch-tabs{order:1;flex:1}
  .uch-icons{order:1}
  .uch-cost{font-size:11px;padding:4px 9px}
  .uch-balance{padding:5px 10px;font-size:11px}
}

/* ═══════════════════════════════════════════════════════════
   🎨 콘텐츠 포장 스튜디오 CSS
   ═══════════════════════════════════════════════════════════ */
.pkg-studio{position:fixed;inset:0;z-index:9990;background:rgba(0,0,0,.45);
  display:none;align-items:flex-end;justify-content:center}
.pkg-studio.on{display:flex}
.pkg-studio .pkg-shell{background:#fff;width:100%;max-width:1180px;height:calc(100vh - 30px);
  border-radius:22px 22px 0 0;overflow:hidden;display:flex;flex-direction:column;
  animation:pkgSlideIn .28s ease;box-shadow:0 -10px 40px rgba(0,0,0,.25)}
@keyframes pkgSlideIn{from{transform:translateY(100%)}to{transform:none}}
.pkg-head{display:flex;align-items:center;gap:10px;padding:14px 18px;border-bottom:1px solid var(--line);
  background:linear-gradient(135deg,var(--pink-soft),var(--purple-soft))}
.pkg-head h3{margin:0;font-size:17px;font-weight:900;flex:1}
.pkg-close{background:#fff;border:1px solid var(--line);border-radius:12px;width:38px;height:38px;
  font-size:16px;cursor:pointer}
.pkg-steps{display:flex;gap:4px;padding:10px 14px;overflow-x:auto;background:#fdf6fa;border-bottom:1px solid var(--line)}
.pkg-step-pill{padding:7px 13px;border:1px solid var(--line);background:#fff;border-radius:999px;
  font-size:11.5px;font-weight:900;white-space:nowrap;cursor:pointer;min-height:36px}
.pkg-step-pill.done{background:#eafbe8;border-color:#9ed99c;color:#326a31}
.pkg-step-pill.current{background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff;border-color:transparent}
.pkg-body{flex:1;overflow-y:auto;padding:18px}

/* 채널/용도 카드 */
.pkg-ch-row{display:flex;gap:8px;flex-wrap:wrap;margin:8px 0 18px}
.pkg-ch-row button{flex:1;min-width:140px;padding:18px;border:2px solid var(--line);background:#fff;
  border-radius:16px;font-size:16px;font-weight:900;cursor:pointer;transition:.15s}
.pkg-ch-row button.on{background:linear-gradient(135deg,var(--pink-soft),var(--purple-soft));
  border-color:var(--pink);color:var(--pink-deep);box-shadow:0 0 0 3px rgba(239,111,171,.15)}

.pkg-cat-group{margin-bottom:20px}
.pkg-cat-group h4{margin:0 0 8px;font-size:14px;font-weight:900;color:var(--pink-deep)}
.pkg-use-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:8px}
.pkg-use{background:#fff;border:2px solid var(--line);border-radius:12px;padding:12px;cursor:pointer;transition:.15s;
  display:flex;flex-direction:column;gap:4px;position:relative;min-height:70px}
.pkg-use:hover{border-color:var(--line-strong)}
.pkg-use.on{border-color:var(--pink);background:var(--pink-soft);box-shadow:0 0 0 3px rgba(239,111,171,.15)}
.pkg-use b{font-size:13px;font-weight:900}
.pkg-use span{font-size:11px;color:var(--sub)}
.pkg-use .chk{position:absolute;top:6px;right:8px;font-size:14px;color:var(--pink-deep);display:none}
.pkg-use.on .chk{display:block}

/* 분석 타임라인 */
.pkg-analyze{background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px;margin:10px 0}
.pkg-analyze .step-line{padding:6px 0;font-size:13.5px;font-weight:700;opacity:0;animation:pkgFadeLine .3s ease forwards}
@keyframes pkgFadeLine{to{opacity:1}}

/* 편집·미리보기 2분할 */
.pkg-edit{display:grid;grid-template-columns:380px 1fr;gap:14px;align-items:flex-start}
.pkg-edit .pkg-left{background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px;max-height:70vh;overflow-y:auto}
.pkg-edit .pkg-right{background:#fdf6fa;border:1px solid var(--line);border-radius:14px;padding:14px;min-height:400px;position:relative}
.pkg-edit h4{margin:0 0 8px;font-size:13.5px;color:var(--pink-deep)}
.pkg-edit details{margin-bottom:8px;border-bottom:1px dashed var(--line);padding-bottom:8px}
.pkg-edit details summary{cursor:pointer;font-weight:900;font-size:13px;padding:6px 0}
.pkg-edit details[open] summary{color:var(--pink-deep)}

.pkg-chips{display:flex;flex-wrap:wrap;gap:4px;margin:4px 0}
.pkg-chip{padding:5px 10px;border:1px solid var(--line);background:#fff;border-radius:999px;font-size:11.5px;font-weight:700;cursor:pointer;min-height:32px}
.pkg-chip.on{background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff;border-color:transparent}

.pkg-preview{background:#fff;border:2px dashed var(--line);border-radius:10px;padding:20px;min-height:380px;
  display:flex;flex-direction:column;gap:12px;overflow:hidden;word-break:break-word}
.pkg-preview.aspect-1-1{aspect-ratio:1}
.pkg-preview.aspect-4-5{aspect-ratio:4/5}
.pkg-preview.aspect-9-16{aspect-ratio:9/16;max-width:320px;margin:0 auto}
.pkg-preview.aspect-16-9{aspect-ratio:16/9}
.pkg-preview.aspect-a4{aspect-ratio:210/297;max-width:520px;margin:0 auto}

.pkg-pv-tabs{display:flex;gap:4px;margin-bottom:8px}
.pkg-pv-tabs button{padding:6px 12px;border:1px solid var(--line);background:#fff;border-radius:8px;font-size:11.5px;font-weight:800;cursor:pointer}
.pkg-pv-tabs button.on{background:var(--pink);color:#fff;border-color:transparent}

/* 품질 체크 */
.pkg-qc{margin-top:10px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px}
.pkg-qc h5{margin:0 0 6px;font-size:13px;color:var(--pink-deep)}
.pkg-qc .qc-item{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:12.5px;cursor:pointer}
.pkg-qc .qc-item.ok{color:var(--ok)}
.pkg-qc .qc-item.warn{color:var(--warn)}
.pkg-qc .qc-item.err{color:var(--err)}
.pkg-qc .qc-fix{margin-left:auto;padding:2px 8px;font-size:10px;background:var(--pink-soft);color:var(--pink-deep);
  border:1px solid var(--pink);border-radius:999px;cursor:pointer;font-weight:900}

/* 출력 바 */
.pkg-output{display:flex;flex-wrap:wrap;gap:6px;padding:14px 18px;border-top:1px solid var(--line);background:#fff}
.pkg-output button{padding:10px 16px;border-radius:999px;font-weight:900;font-size:12.5px;cursor:pointer;border:1px solid var(--line);background:#fff;min-height:42px}
.pkg-output button.pri{background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff;border-color:transparent}
.pkg-output .spacer{flex:1}

/* 포장하기 플로팅 버튼 */
.pkg-trigger{margin-top:10px;padding:10px 14px;background:linear-gradient(135deg,#fff5fa,#f7f4ff);
  border:1.5px dashed var(--pink);border-radius:14px;text-align:center;animation:mediaFadeIn .35s ease}
.pkg-trigger button{padding:11px 22px;background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff;
  border:none;border-radius:999px;font-weight:900;font-size:14px;cursor:pointer;min-height:44px}
.pkg-trigger button:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(239,111,171,.3)}

/* 브랜드 프리셋 섹션 CSS (설정 탭) */
.brand-logo-preview{width:80px;height:80px;border:2px dashed var(--line);border-radius:12px;
  background:#fff;display:flex;align-items:center;justify-content:center;font-size:30px;overflow:hidden}
.brand-logo-preview img{max-width:100%;max-height:100%;display:block}

@media (max-width:860px){
  .pkg-edit{grid-template-columns:1fr}
  .pkg-edit .pkg-left{max-height:none}
}
@media (max-width:600px){
  .pkg-studio .pkg-shell{height:calc(100vh - 10px);border-radius:18px 18px 0 0}
  .pkg-head h3{font-size:15px}
  .pkg-body{padding:12px}
  .pkg-use-grid{grid-template-columns:1fr 1fr}
}

/* ═══════════════════════════════════════════════════════════
   🎨 UI Polish — 10가지 개선안 CSS
   ═══════════════════════════════════════════════════════════ */

/* ─── 1. 상단 컨트롤바 (검색·아이콘·언어 드롭다운·AI상태) ─── */
.nav-ctrl{position:sticky;top:0;z-index:40;display:flex;align-items:center;gap:8px;
  padding:8px 14px;background:rgba(255,249,252,.95);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line)}
.nav-ctrl .nav-search{flex:1;max-width:420px;position:relative}
.nav-ctrl .nav-search input{width:100%;padding:8px 12px 8px 34px;border:1px solid var(--line);
  border-radius:999px;background:#fff;font-size:13px;outline:none;min-height:38px}
.nav-ctrl .nav-search input:focus{border-color:var(--line-strong);box-shadow:0 0 0 3px rgba(239,111,171,.12)}
.nav-ctrl .nav-search::before{content:'🔍';position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:14px}
.nav-ctrl .nav-icon{width:38px;height:38px;display:flex;align-items:center;justify-content:center;
  background:#fff;border:1px solid var(--line);border-radius:12px;cursor:pointer;font-size:16px;transition:.15s}
.nav-ctrl .nav-icon:hover{border-color:var(--pink);background:var(--pink-soft)}
.nav-ctrl .nav-lang-dd{position:relative}
.nav-ctrl .nav-lang-btn{padding:7px 12px;background:#fff;border:1px solid var(--line);border-radius:999px;
  font-weight:800;font-size:12.5px;cursor:pointer;min-height:38px;display:flex;align-items:center;gap:4px}
.nav-ctrl .nav-lang-btn:hover{border-color:var(--pink)}
.nav-ctrl .nav-lang-menu{position:absolute;right:0;top:calc(100% + 6px);background:#fff;border:1px solid var(--line);
  border-radius:12px;box-shadow:var(--shadow);padding:6px;display:none;min-width:140px;z-index:50}
.nav-ctrl .nav-lang-dd.open .nav-lang-menu{display:block}
.nav-ctrl .nav-lang-menu button{display:block;width:100%;padding:8px 12px;background:transparent;border:none;
  border-radius:8px;text-align:left;font-weight:800;font-size:13px;cursor:pointer}
.nav-ctrl .nav-lang-menu button:hover{background:var(--pink-soft)}
.nav-ctrl .nav-ai-status{display:flex;align-items:center;gap:4px;padding:6px 10px;
  background:#fff;border:1px solid var(--line);border-radius:999px;font-size:11.5px;font-weight:700}

/* 검색 드롭다운 */
.search-dd{position:absolute;left:0;right:0;top:calc(100% + 4px);background:#fff;border:1px solid var(--line);
  border-radius:12px;box-shadow:var(--shadow);max-height:360px;overflow-y:auto;z-index:60;display:none;padding:6px}
.search-dd.open{display:block}
.search-dd .sd-group{padding:6px 10px;font-size:10.5px;color:var(--sub);font-weight:900;text-transform:uppercase}
.search-dd .sd-item{padding:9px 12px;border-radius:8px;cursor:pointer;font-size:13px;font-weight:700;display:flex;align-items:center;gap:8px}
.search-dd .sd-item:hover, .search-dd .sd-item.active{background:var(--pink-soft);color:var(--pink-deep)}
.search-dd .sd-item .sd-desc{color:var(--sub);font-weight:400;font-size:11px;margin-left:auto}

/* ─── 2. 브레드크럼 고정바 ─── */
.breadcrumb{position:sticky;top:55px;z-index:35;display:flex;align-items:center;gap:10px;
  padding:8px 14px;background:#fff;border-bottom:1px solid var(--line);font-size:12.5px}
.breadcrumb .bc-back{padding:5px 10px;background:var(--pink-soft);color:var(--pink-deep);
  border:1px solid var(--pink);border-radius:8px;font-weight:800;cursor:pointer;font-size:11.5px;min-height:32px}
.breadcrumb .bc-back:hover{background:var(--pink);color:#fff}
.breadcrumb .bc-path{flex:1;display:flex;align-items:center;gap:6px;color:var(--sub);flex-wrap:wrap}
.breadcrumb .bc-path .bc-crumb{cursor:pointer;font-weight:700}
.breadcrumb .bc-path .bc-crumb:hover{color:var(--pink-deep)}
.breadcrumb .bc-path .bc-crumb.current{color:var(--text);font-weight:900}
.breadcrumb .bc-path .bc-sep{color:var(--muted)}
.breadcrumb .bc-save{font-size:11px;color:var(--sub);font-weight:700;white-space:nowrap}
.breadcrumb .bc-save.saving{color:var(--warn)}
.breadcrumb .bc-save.saved{color:var(--ok)}

/* ─── 3. 사이드바 sticky + 하이라이트 + 뱃지 ─── */
@media (min-width:981px){
  .layout > aside.stack, .layout > .stack:first-child{position:sticky;top:100px;align-self:start;max-height:calc(100vh - 120px);overflow-y:auto}
}
.sidebtn.active-cat{background:linear-gradient(135deg,var(--pink-soft),var(--purple-soft)) !important;
  border-color:var(--pink) !important;color:var(--pink-deep) !important;font-weight:900}
.sidebtn .progress-badge{display:inline-block;margin-left:6px;padding:2px 7px;background:#fff7ee;
  color:#a26b2a;border-radius:999px;font-size:10px;font-weight:900}
.sidebtn .complete-badge{display:inline-block;margin-left:6px;font-size:11px}

/* ─── 5. 화면 전환 애니메이션 ─── */
@keyframes slideInRight{from{opacity:0;transform:translateX(30px)}to{opacity:1;transform:none}}
@keyframes slideInLeft {from{opacity:0;transform:translateX(-30px)}to{opacity:1;transform:none}}
@keyframes slideInUp   {from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
@keyframes uiFadeIn    {from{opacity:0}to{opacity:1}}
.anim-slide-r{animation:slideInRight .22s ease}
.anim-slide-l{animation:slideInLeft .22s ease}
.anim-slide-u{animation:slideInUp .22s ease}
.anim-fade   {animation:uiFadeIn .22s ease}

/* ─── 6. 플로팅 빠른메뉴 (우측 하단) ─── */
.fab-menu{position:fixed;right:16px;bottom:96px;z-index:9996;display:flex;flex-direction:column;gap:8px}
.fab-btn{width:52px;height:52px;border-radius:50%;border:1px solid var(--line);background:#fff;
  color:var(--text);font-size:18px;cursor:pointer;box-shadow:0 6px 18px rgba(126,87,110,.18);
  transition:.15s;display:flex;align-items:center;justify-content:center;position:relative}
.fab-btn:hover{transform:translateY(-2px);border-color:var(--pink);box-shadow:0 10px 24px rgba(239,111,171,.25)}
.fab-btn.primary{background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff;border-color:transparent}
.fab-btn .fab-tip{position:absolute;right:calc(100% + 10px);top:50%;transform:translateY(-50%);
  background:#2b2430;color:#fff;padding:5px 10px;border-radius:8px;font-size:11px;white-space:nowrap;
  opacity:0;pointer-events:none;transition:.15s;font-weight:800}
.fab-btn:hover .fab-tip{opacity:1}

/* ─── 9. 통합 토스트 시스템 ─── */
.moca-toast-host{position:fixed;right:16px;top:80px;z-index:9998;display:flex;flex-direction:column;gap:8px;max-width:340px;pointer-events:none}
.moca-toast{background:#fff;border:1px solid var(--line);border-left:4px solid var(--pink);
  border-radius:12px;padding:10px 14px;box-shadow:var(--shadow-soft);font-size:13px;font-weight:700;
  animation:slideInRight .22s ease;pointer-events:auto;display:flex;align-items:center;gap:8px;min-width:200px}
.moca-toast.ok   {border-left-color:var(--ok);background:#f0fbf5}
.moca-toast.warn {border-left-color:var(--warn);background:#fff7ee}
.moca-toast.err  {border-left-color:var(--err);background:#fff0f3}
.moca-toast.info {border-left-color:var(--purple);background:#f7f4ff}
.moca-toast .mt-close{margin-left:auto;cursor:pointer;color:var(--sub);font-size:14px;border:none;background:none}
.moca-toast .mt-act{background:var(--pink-soft);color:var(--pink-deep);border:1px solid var(--pink);
  padding:4px 10px;border-radius:999px;font-size:11px;font-weight:900;cursor:pointer;margin-left:6px}
.moca-toast.fadeout{animation:uiFadeOut .2s ease forwards}
@keyframes uiFadeOut{to{opacity:0;transform:translateX(30px)}}

/* ─── 10. 자동복귀 모달 ─── */
.resume-modal{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:9997;
  display:none;align-items:center;justify-content:center;padding:20px;animation:uiFadeIn .2s ease}
.resume-modal.on{display:flex}
.resume-modal .rm-body{background:#fff;border-radius:18px;padding:24px;max-width:420px;width:100%;
  box-shadow:var(--shadow);text-align:center}
.resume-modal h3{margin:0 0 6px;font-size:18px}
.resume-modal p{color:var(--sub);font-size:13px;margin:0 0 16px;line-height:1.7}
.resume-modal .rm-info{background:var(--pink-soft);padding:10px 14px;border-radius:10px;margin:10px 0 16px;
  font-size:12.5px;color:var(--pink-deep);font-weight:800}
.resume-modal .rm-btns{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}
.resume-modal .rm-btns button{padding:12px 20px;border-radius:999px;font-weight:900;font-size:13px;cursor:pointer;min-height:46px}
.resume-modal .rm-btns .pri{background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff;border:none}
.resume-modal .rm-btns .ghost{background:#fff;border:1px solid var(--line)}

/* ─── 모바일 최적화 ─── */
@media (max-width:600px){
  .nav-ctrl .nav-search{min-width:0}
  .nav-ctrl .nav-ai-status{display:none}
  .breadcrumb{top:50px;font-size:11.5px;padding:6px 10px}
  .breadcrumb .bc-save{display:none}
  .fab-menu{right:10px;bottom:80px}
  .fab-btn{width:46px;height:46px;font-size:16px}
}

/* ─── 작업 중 경고 모달 ─── */
.leave-modal{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:9998;
  display:none;align-items:center;justify-content:center;padding:20px;animation:uiFadeIn .2s ease}
.leave-modal.on{display:flex}
.leave-modal .lm-body{background:#fff;border-radius:18px;padding:24px;max-width:380px;width:100%;
  box-shadow:var(--shadow);text-align:center}
.leave-modal h3{margin:0 0 6px;font-size:17px}
.leave-modal p{color:var(--sub);font-size:13px;margin:0 0 14px}
.leave-modal .lm-btns{display:flex;gap:6px;flex-wrap:wrap;justify-content:center}
.leave-modal button{padding:10px 16px;border-radius:999px;font-weight:900;font-size:12.5px;cursor:pointer;min-height:42px}
.leave-modal .lm-save{background:linear-gradient(135deg,var(--pink),var(--purple));color:#fff;border:none}
.leave-modal .lm-drop{background:var(--warn);color:#fff;border:none}
.leave-modal .lm-cancel{background:#fff;border:1px solid var(--line)}
