/* 인스타툰 — 따뜻한 종이 + 잉크 + 형광펜 노랑. 모바일 1순위. */
:root{
  --paper:#FBF6EA; --paper-2:#F4ECD8; --surface:#FFFFFF; --ink:#1A1510; --ink-2:#5C5246;
  --line:#E8DDC4; --line-2:#D8CBAB;
  --hl:#FFD23F;            /* 형광펜 노랑 (시그니처) */
  --coral:#FF5A3C;         /* 주요 CTA */
  --coral-d:#E8432A;
  --mint:#37B86F; --sky:#5AA9E6; --pink:#FF8FB1;
  --shadow:0 2px 0 var(--line-2);
  --pop:0 4px 0 #211b12;   /* 스티커 버튼 입체 */
  --radius:22px; --radius-s:14px;
  --maxw:480px;
  --safe-b:env(safe-area-inset-bottom,0px);
  --font-disp:'Black Han Sans',sans-serif;
  --font-hand:'Gaegu',cursive;
  --font-round:'Jua',sans-serif;
  --font-body:'Pretendard','Pretendard Variable',-apple-system,sans-serif;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0}
body{
  font-family:var(--font-body); color:var(--ink); background:var(--paper);
  background-image:radial-gradient(rgba(120,100,60,.04) 1px,transparent 1px);
  background-size:4px 4px;
  line-height:1.5; -webkit-font-smoothing:antialiased; overscroll-behavior-y:none;
}
button{font-family:inherit; cursor:pointer; border:none; background:none; color:inherit}
input,textarea,select{font-family:inherit}
a{color:inherit}
.boot{min-height:100dvh;display:grid;place-items:center;font-family:var(--font-hand);font-size:22px;color:var(--ink-2)}

/* 앱 프레임 — 폰 모양 */
#app{max-width:var(--maxw);margin:0 auto;min-height:100dvh;position:relative;
  background:var(--paper);box-shadow:0 0 60px rgba(80,60,20,.08)}
.screen{padding:0 16px calc(120px + var(--safe-b));animation:fade .35s ease}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* 상단바 */
.topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:10px;
  padding:14px 16px;background:rgba(251,246,234,.92);backdrop-filter:blur(8px);
  border-bottom:1.5px solid var(--line)}
.topbar .back{font-size:24px;width:34px;height:34px;display:grid;place-items:center;
  border-radius:10px;background:var(--surface);border:1.5px solid var(--line)}
.topbar h1{font-family:var(--font-disp);font-size:19px;margin:0;flex:1;letter-spacing:-.5px}
.brand{font-family:var(--font-disp);font-size:22px;letter-spacing:-1px}
.brand b{background:linear-gradient(transparent 55%,var(--hl) 55%);padding:0 2px}

/* 크레딧 칩 */
.credit-chip{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-round);
  font-size:14px;padding:7px 12px;border-radius:999px;background:var(--ink);color:#fff;border:none}
.credit-chip.lite{background:var(--surface);color:var(--ink);border:1.5px solid var(--line-2)}
.credit-chip.kakao{background:#FEE500;color:#191600;border:1.5px solid #191600;font-weight:700}
.credit-chip .coin{filter:saturate(1.2)}

/* 히어로 */
.hero{padding:30px 4px 18px;text-align:left}
.hero .kicker{font-family:var(--font-hand);font-size:20px;color:var(--coral);font-weight:700;transform:rotate(-2deg);display:inline-block}
.hero h2{font-family:var(--font-disp);font-size:clamp(34px,9vw,44px);line-height:1.08;margin:6px 0 0;letter-spacing:-1.5px}
.hero h2 .mark{background:linear-gradient(transparent 58%,var(--hl) 58%);padding:0 4px;box-decoration-break:clone;-webkit-box-decoration-break:clone}
.hero p{color:var(--ink-2);margin:14px 2px 0;font-size:15px}

/* 스티커 버튼 */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--font-round);font-size:17px;padding:15px 20px;border-radius:16px;
  background:var(--coral);color:#fff;border:2.5px solid var(--ink);box-shadow:var(--pop);
  transition:transform .08s ease,box-shadow .08s ease;width:100%}
.btn:active{transform:translate(0,4px);box-shadow:0 0 0 var(--ink)}
.btn.ghost{background:var(--surface);color:var(--ink)}
.btn.dark{background:var(--ink);color:#fff}
.btn.hl{background:var(--hl);color:var(--ink)}
.btn.sm{font-size:14px;padding:10px 14px;border-radius:12px;box-shadow:0 3px 0 var(--ink);border-width:2px}
.btn:disabled{opacity:.5;filter:grayscale(.3)}
.btn-row{display:flex;gap:10px}

/* 카드 */
.card{background:var(--surface);border:2px solid var(--line-2);border-radius:var(--radius);
  padding:16px;box-shadow:var(--shadow)}
.section-t{font-family:var(--font-disp);font-size:20px;margin:26px 2px 12px;letter-spacing:-.5px}
.section-t .hl{background:linear-gradient(transparent 55%,var(--hl) 55%);padding:0 3px}

/* 내 작업 리스트 */
.toon-list{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.toon-cell{position:relative;border:2px solid var(--line-2);border-radius:var(--radius-s);overflow:hidden;
  background:var(--paper-2);aspect-ratio:4/5;box-shadow:var(--shadow)}
.toon-cell img{width:100%;height:100%;object-fit:cover;display:block}
.toon-cell .ph{width:100%;height:100%;display:grid;place-items:center;font-family:var(--font-hand);color:var(--ink-2);font-size:16px;text-align:center;padding:10px}
.toon-cell .cap{position:absolute;left:0;right:0;bottom:0;background:linear-gradient(transparent,rgba(0,0,0,.7));
  color:#fff;font-family:var(--font-round);font-size:13px;padding:18px 8px 8px;line-height:1.25}
.toon-cell .badge{position:absolute;top:6px;right:6px;font-size:11px;background:var(--ink);color:#fff;border-radius:8px;padding:3px 7px;font-family:var(--font-round)}
.new-cell{display:grid;place-items:center;background:var(--surface);border-style:dashed;cursor:pointer}
.new-cell .plus{font-family:var(--font-disp);font-size:40px;color:var(--coral);line-height:1}
.new-cell span{font-family:var(--font-round);font-size:14px;margin-top:4px}

/* 모드 선택 */
.mode-card{display:flex;align-items:center;gap:14px;width:100%;text-align:left;margin-bottom:12px;
  border:2.5px solid var(--line-2);border-radius:var(--radius);padding:16px;background:var(--surface);
  box-shadow:var(--shadow);transition:transform .08s}
.mode-card:active{transform:scale(.99)}
.mode-card.on{border-color:var(--ink);box-shadow:var(--pop)}
.mode-card .emo{font-size:34px;width:52px;height:52px;display:grid;place-items:center;
  background:var(--paper-2);border-radius:14px;flex-shrink:0}
.mode-card .t{font-family:var(--font-round);font-size:17px}
.mode-card .d{font-size:13px;color:var(--ink-2);margin-top:2px}

/* 그림체 카테고리 탭 */
.cat-tabs{display:flex;gap:8px;overflow-x:auto;padding:2px 2px 12px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.cat-tabs::-webkit-scrollbar{display:none}
.cat-tab{flex:0 0 auto;border:2px solid var(--line-2);background:var(--surface);border-radius:999px;
  padding:8px 15px;font-family:var(--font-round);font-size:14px;white-space:nowrap;box-shadow:var(--shadow)}
.cat-tab.on{background:var(--ink);color:#fff;border-color:var(--ink);box-shadow:none}

/* 그림체 갤러리 */
.style-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.style-cell .thumb.noimg{display:grid;place-items:center}
.style-cell .thumb.noimg::after{content:'🎨';font-size:38px;opacity:.5}
.style-cell{border:2.5px solid var(--line-2);border-radius:var(--radius-s);overflow:hidden;background:var(--surface);
  text-align:left;box-shadow:var(--shadow);transition:transform .08s;padding:0}
.style-cell:active{transform:scale(.98)}
.style-cell.on{border-color:var(--ink);box-shadow:var(--pop)}
.style-cell .thumb{aspect-ratio:1;background:var(--paper-2);position:relative;overflow:hidden}
.style-cell .thumb img{width:100%;height:100%;object-fit:cover;display:block}
.style-cell .thumb .emo{position:absolute;inset:0;display:grid;place-items:center;font-size:42px}
.style-cell .meta{padding:9px 11px}
.style-cell .nm{font-family:var(--font-round);font-size:15px}
.style-cell .ds{font-size:11.5px;color:var(--ink-2);margin-top:1px;line-height:1.3}
.style-cell .check{position:absolute;top:7px;right:7px;width:24px;height:24px;border-radius:50%;
  background:var(--ink);color:#fff;display:none;place-items:center;font-size:14px}
.style-cell.on .check{display:grid}

/* 폼 */
.field{margin:16px 0}
.field label{font-family:var(--font-round);font-size:15px;display:block;margin-bottom:7px}
.field .hint{font-size:12.5px;color:var(--ink-2);font-weight:400;margin-left:6px}
textarea,input[type=text]{width:100%;border:2px solid var(--line-2);border-radius:14px;padding:13px;
  font-size:15px;background:var(--surface);resize:vertical;color:var(--ink)}
textarea:focus,input:focus{outline:none;border-color:var(--ink)}
textarea{min-height:120px;line-height:1.6}
.seg{display:flex;gap:8px;flex-wrap:wrap}
.seg button{flex:1;min-width:70px;border:2px solid var(--line-2);border-radius:12px;padding:11px 8px;
  background:var(--surface);font-family:var(--font-round);font-size:14px}
.seg button.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.stepper{display:flex;align-items:center;gap:14px}
.stepper button{width:44px;height:44px;border-radius:12px;border:2px solid var(--line-2);background:var(--surface);
  font-family:var(--font-disp);font-size:22px;line-height:1}
.stepper .val{font-family:var(--font-disp);font-size:30px;min-width:54px;text-align:center}
.stepper .val small{font-family:var(--font-body);font-size:13px;color:var(--ink-2);font-weight:600}

/* 캐릭터 업로드 */
.char-row{display:flex;gap:12px;align-items:center}
.char-thumb{width:74px;height:74px;border-radius:16px;border:2px dashed var(--line-2);background:var(--paper-2);
  display:grid;place-items:center;font-size:26px;overflow:hidden;flex-shrink:0}
.char-thumb img{width:100%;height:100%;object-fit:cover}

/* 하단 고정 액션바 */
.actionbar{position:fixed;left:0;right:0;bottom:0;z-index:40;max-width:var(--maxw);margin:0 auto;
  padding:12px 16px calc(12px + var(--safe-b));background:linear-gradient(transparent,var(--paper) 22%);
  display:flex;gap:10px;align-items:center}
.actionbar .cost{font-family:var(--font-round);font-size:12.5px;color:var(--ink-2);text-align:center;line-height:1.2}

/* 에디터 — 패널 뷰어 */
.editor-head{padding:6px 2px 2px}
.editor-head .ttl{font-family:var(--font-disp);font-size:24px;line-height:1.15;letter-spacing:-1px}
.editor-head .sub{font-family:var(--font-hand);font-size:16px;color:var(--coral);font-weight:700}
.panel-wrap{margin:16px 0}
.panel{position:relative;border:2.5px solid var(--ink);border-radius:18px;overflow:hidden;background:var(--paper-2);
  box-shadow:var(--pop)}
.panel .idxtag{position:absolute;top:10px;left:10px;z-index:3;font-family:var(--font-round);font-size:12px;
  background:rgba(0,0,0,.6);color:#fff;border-radius:999px;padding:4px 10px}
.panel img{width:100%;display:block}
.panel .empty{display:grid;place-items:center;text-align:center;padding:20px;gap:8px;min-height:120px}
.panel .empty .scene{font-family:var(--font-hand);font-size:18px;color:var(--ink-2);max-width:85%}
/* 콘티(장면 계획) — 읽기 쉽게 큰 글씨 + 구분 */
.panel .conti{padding:18px 16px;display:flex;flex-direction:column;gap:14px}
.conti .cline{display:flex;flex-direction:column;gap:6px}
.conti .clbl{font-family:var(--font-round);font-size:11.5px;color:#fff;background:var(--ink);border-radius:7px;padding:2px 9px;align-self:flex-start}
.conti .ctext{font-size:17px;line-height:1.5;font-weight:700}
.conti .cdlg{display:flex;flex-direction:column;gap:7px}
.conti .cbub{font-size:16px;line-height:1.5;background:var(--paper-2);border:1.5px solid var(--line);border-radius:14px;padding:9px 13px}
.conti .cbub b{font-family:var(--font-round);font-size:13px;color:var(--coral);margin-right:7px}
.conti .cscene{font-family:var(--font-hand);font-size:18.5px;color:var(--ink);line-height:1.55}
/* 콘티 대사 편집 행 */
.dlgrow{display:flex;gap:6px;margin-bottom:7px;align-items:center}
.dlgrow input[data-f="speaker"]{flex:0 0 76px}
.dlgrow input[data-f="text"]{flex:1}
.dlgrow input{border:2px solid var(--line-2);border-radius:11px;padding:10px;font-size:14.5px;background:var(--surface)}
.dlgx{flex:0 0 34px;height:38px;border:2px solid var(--line-2);border-radius:10px;background:var(--surface);font-size:14px;color:var(--ink-2)}
.panel .gening{position:absolute;inset:0;display:grid;place-items:center;background:rgba(251,246,234,.82);
  font-family:var(--font-hand);font-size:18px;color:var(--ink);gap:10px;z-index:4}
.panel .gening .spin{width:34px;height:34px;border:4px solid var(--line-2);border-top-color:var(--coral);
  border-radius:50%;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.panel-tools{display:flex;gap:8px;margin-top:10px}
.panel-tools .btn{flex:1}
.beat{font-family:var(--font-hand);font-size:15px;color:var(--ink-2);margin:8px 4px 0}

/* 채팅 */
.chat-scroll{padding:10px 2px 8px;display:flex;flex-direction:column;gap:10px}
.bubble{max-width:82%;padding:11px 14px;border-radius:18px;font-size:15px;line-height:1.5}
.bubble.user{align-self:flex-end;background:var(--ink);color:#fff;border-bottom-right-radius:5px}
.bubble.ai{align-self:flex-start;background:var(--surface);border:2px solid var(--line-2);border-bottom-left-radius:5px}
.chat-input{position:fixed;bottom:0;left:0;right:0;max-width:var(--maxw);margin:0 auto;display:flex;gap:8px;
  padding:10px 12px calc(10px + var(--safe-b));background:var(--paper);border-top:1.5px solid var(--line)}
.chat-input textarea{min-height:46px;max-height:120px;border-radius:23px;padding:11px 16px}
.chat-input .send{width:48px;height:48px;border-radius:50%;background:var(--coral);color:#fff;border:2px solid var(--ink);
  font-size:20px;flex-shrink:0;box-shadow:0 3px 0 var(--ink)}

/* 바텀시트 */
.sheet-bg{position:fixed;inset:0;z-index:90;background:rgba(26,21,16,.45);display:flex;align-items:flex-end;
  animation:fade .2s}
.sheet{background:var(--paper);width:100%;max-width:var(--maxw);margin:0 auto;border-radius:26px 26px 0 0;
  padding:10px 18px calc(20px + var(--safe-b));max-height:88dvh;overflow-y:auto;animation:up .28s cubic-bezier(.2,.9,.3,1)}
@keyframes up{from{transform:translateY(100%)}to{transform:none}}
.sheet .grip{width:42px;height:5px;border-radius:3px;background:var(--line-2);margin:4px auto 14px}
.sheet h3{font-family:var(--font-disp);font-size:22px;margin:0 0 4px;letter-spacing:-.5px}
.sheet .desc{color:var(--ink-2);font-size:14px;margin:0 0 14px}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin:10px 0}
.chip{border:2px solid var(--line-2);border-radius:999px;padding:8px 14px;font-family:var(--font-round);font-size:14px;background:var(--surface)}
.chip:active{background:var(--hl);border-color:var(--ink)}

/* 결제 팩 */
.pack{display:flex;align-items:center;gap:12px;border:2.5px solid var(--line-2);border-radius:18px;padding:14px;
  margin-bottom:10px;background:var(--surface);box-shadow:var(--shadow);position:relative;width:100%;text-align:left}
.pack.hot{border-color:var(--coral)}
.pack .ribbon{position:absolute;top:-11px;right:14px;background:var(--coral);color:#fff;font-family:var(--font-round);
  font-size:11px;padding:3px 10px;border-radius:999px;border:2px solid var(--ink)}
.pack .pc{font-family:var(--font-disp);font-size:26px;line-height:1}
.pack .pc small{font-family:var(--font-body);font-size:13px;color:var(--ink-2);font-weight:600}
.pack .pn{font-family:var(--font-round);font-size:15px}
.pack .pp{margin-left:auto;font-family:var(--font-round);font-size:17px}

/* 토스트 */
.toast{position:fixed;left:50%;bottom:calc(96px + var(--safe-b));transform:translateX(-50%);z-index:120;
  background:var(--ink);color:#fff;padding:11px 18px;border-radius:14px;font-size:14px;font-family:var(--font-round);
  max-width:88vw;text-align:center;box-shadow:0 6px 24px rgba(0,0,0,.25);animation:fade .2s}

/* 스피너/스켈레톤 */
.center-load{min-height:50dvh;display:grid;place-items:center;font-family:var(--font-hand);font-size:18px;color:var(--ink-2);gap:14px}
.center-load .spin{width:40px;height:40px;border:4px solid var(--line-2);border-top-color:var(--coral);border-radius:50%;animation:spin 1s linear infinite}

.muted{color:var(--ink-2)}
.tc{text-align:center}
.mt{margin-top:14px}
hr.soft{border:none;border-top:1.5px dashed var(--line-2);margin:20px 0}
.note{font-family:var(--font-hand);font-size:14px;color:var(--ink-2);background:var(--paper-2);
  border-radius:12px;padding:10px 12px;border:1.5px solid var(--line)}
