/* Cinema Diary Mobile — 레이아웃 */
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html{height:100%;}
body{
  min-height:100dvh;
  font-family:var(--font);
  background:var(--bg);
  color:var(--text);
  touch-action:manipulation;
  -webkit-font-smoothing:antialiased;
  padding-top:calc(52px + env(safe-area-inset-top));
  padding-bottom:calc(58px + env(safe-area-inset-bottom));
}

/* ── Header ── */
.header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  height:calc(52px + env(safe-area-inset-top));
  padding:env(safe-area-inset-top) 16px 0;
  background:var(--bg);
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:10px;
}
.header h1{
  font-family:var(--font-display);
  font-size:22px;letter-spacing:3px;font-weight:400;
  color:var(--accent);white-space:nowrap;
}
.header-right{margin-left:auto;display:flex;gap:6px;align-items:center;}
.icon-btn{
  width:38px;height:38px;border:none;border-radius:10px;
  background:transparent;color:var(--text2);
  display:flex;align-items:center;justify-content:center;
  font-size:17px;cursor:pointer;
}
.icon-btn:active{background:var(--card);}
.icon-btn svg{width:19px;height:19px;stroke:currentColor;fill:none;stroke-width:1.6;}
.icon-btn.spin svg{animation:spin 1s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}

/* ── Views ── */
.view{display:none;padding:14px 14px 24px;}
.view.active{display:block;}

.empty-state{
  text-align:center;padding:80px 24px;color:var(--text3);
}
.empty-state .icon{font-size:40px;margin-bottom:14px;}
.empty-state p{font-size:14px;line-height:1.6;}
.empty-state .link-btn{
  margin-top:18px;display:inline-block;
  padding:10px 20px;border-radius:10px;border:1px solid var(--accent2);
  color:var(--accent);font-size:13px;background:transparent;cursor:pointer;
}

/* ── Bottom tab bar ── */
.tabbar{
  position:fixed;bottom:0;left:0;right:0;z-index:100;
  height:calc(58px + env(safe-area-inset-bottom));
  padding-bottom:env(safe-area-inset-bottom);
  background:var(--bg);
  border-top:1px solid var(--border);
  display:flex;
}
.tabbar button{
  flex:1;border:none;background:transparent;cursor:pointer;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
  color:var(--text3);font-size:10.5px;letter-spacing:1.5px;
  font-family:var(--font-display);
}
.tabbar button svg{width:21px;height:21px;stroke:currentColor;fill:none;stroke-width:1.5;}
.tabbar button.active{color:var(--accent);}

/* ── Sheet (설정 등 하단 시트) ── */
.sheet-overlay{
  position:fixed;inset:0;z-index:200;background:var(--overlay);
  opacity:0;pointer-events:none;transition:opacity .22s;
}
.sheet-overlay.show{opacity:1;pointer-events:auto;}
.sheet{
  position:fixed;left:0;right:0;bottom:0;z-index:201;
  max-height:88dvh;overflow-y:auto;-webkit-overflow-scrolling:touch;
  background:var(--bg2);border-radius:18px 18px 0 0;
  padding:10px 16px calc(20px + env(safe-area-inset-bottom));
  transform:translateY(102%);transition:transform .26s cubic-bezier(.32,.72,.29,1);
}
.sheet.show{transform:translateY(0);}
.sheet-grip{width:38px;height:4px;border-radius:2px;background:var(--border);margin:2px auto 14px;}
.sheet h2{
  font-family:var(--font-display);font-weight:400;
  font-size:17px;letter-spacing:2px;color:var(--accent);margin-bottom:14px;
}

/* ── Year chips ── */
.year-chips{
  position:sticky;top:calc(52px + env(safe-area-inset-top));z-index:50;
  display:flex;gap:7px;overflow-x:auto;-webkit-overflow-scrolling:touch;
  background:var(--bg);
  margin:-14px -14px 12px;padding:11px 14px;
  scrollbar-width:none;
}
.year-chips::-webkit-scrollbar{display:none;}
.year-chips:empty{display:none;}
.year-chip{
  flex-shrink:0;display:flex;align-items:center;gap:6px;
  border:1px solid var(--border);border-radius:18px;background:var(--card);
  color:var(--text2);padding:7px 13px;cursor:pointer;
  font-family:var(--font-display);font-size:12.5px;letter-spacing:1.5px;
}
.year-chip-count{font-family:var(--font-mono);font-size:11px;letter-spacing:0;}
.year-chip.active{background:var(--bg2);}

/* ── 월별 가로 바 차트 (데스크톱 hbar 이식) ── */
.mchart{display:flex;flex-direction:column;gap:5px;margin:2px 0 14px;}
.mbar-row{
  display:flex;align-items:center;gap:9px;padding:2px 4px;border-radius:6px;
  cursor:pointer;outline:1.5px solid transparent;outline-offset:0;
  transition:opacity .18s;
}
.mbar-row.is-disabled{opacity:.3;cursor:default;}
.mchart.has-sel .mbar-row:not(.is-sel){opacity:.35;}
.mbar-row.is-sel{background:var(--card);}
.mbar-label{
  min-width:30px;font-size:11.5px;color:var(--text2);text-align:right;
  white-space:nowrap;flex-shrink:0;font-weight:600;
}
.mbar-track{
  flex:1;height:21px;background:var(--bg2);border-radius:4px;
  position:relative;display:flex;align-items:center;overflow:visible;
}
.mbar-track .grid-line{
  position:absolute;top:0;bottom:0;width:1px;background:var(--border);opacity:.6;
}
.mbar-track .avg-line{
  position:absolute;top:-2px;bottom:-2px;width:1.5px;background:var(--accent);
  opacity:.55;
}
.mbar-fill{
  height:100%;border-radius:4px;display:flex;align-items:center;
  justify-content:flex-end;padding-right:7px;min-width:0;overflow:hidden;
  position:relative;z-index:1;
}
.mbar-val{
  font-family:var(--font-mono);font-size:11.5px;color:#fff;letter-spacing:0.5px;
  text-shadow:0 1px 3px rgba(0,0,0,0.4);white-space:nowrap;
}
.mbar-val-out{
  font-family:var(--font-mono);font-size:11.5px;letter-spacing:0.5px;
  white-space:nowrap;margin-left:6px;font-weight:600;position:relative;z-index:1;
}
.mchart-avg{
  text-align:right;font-family:var(--font-mono);font-size:10px;
  color:var(--text3);padding:2px 4px 0;
}
.month-head{
  display:flex;justify-content:space-between;align-items:center;margin:0 2px 10px;
}
.month-head-title{
  font-family:var(--font-mono);font-size:12.5px;font-weight:700;color:var(--accent);
  letter-spacing:0.5px;
}
.month-clear{
  border:1px solid var(--border);border-radius:12px;background:transparent;
  color:var(--text2);font-size:11.5px;padding:5px 11px;cursor:pointer;
}
.month-clear:active{background:var(--card);}

/* ── Pace 카드 (ALL-TIME) ── */
.pace-card{
  background:var(--card);border:1px solid var(--border);border-radius:13px;
  padding:13px 15px 11px;margin:2px 0 14px;cursor:pointer;
  box-shadow:0 1px 6px rgba(0,0,0,0.08);
}
.pace-card:active{border-color:var(--accent2);}
.pace-head{display:flex;justify-content:space-between;align-items:baseline;}
.pace-title{font-family:var(--font-display);font-size:12px;letter-spacing:2.5px;color:var(--text3);}
.pace-date{font-family:var(--font-mono);font-size:11px;color:var(--text2);}
.pace-nums{display:flex;align-items:baseline;gap:8px;margin:6px 0 2px;}
.pace-now{font-family:var(--font-mono);font-size:30px;font-weight:700;color:var(--text);line-height:1;}
.pace-arrow{font-size:14px;color:var(--text3);}
.pace-proj{font-family:var(--font-mono);font-size:21px;font-weight:700;line-height:1;}
.pace-est{font-size:11px;opacity:.75;}
.pace-spark{display:block;width:100%;margin:4px 0 7px;}
.pace-chips{display:flex;gap:8px;}
.pace-chip{
  flex:1;background:var(--bg2);border-radius:8px;padding:6px 9px;
  font-family:var(--font-mono);font-size:12px;color:var(--text2);
}
.pace-chip b{font-weight:700;}
.pace-chip .pace-up{color:var(--green);}
.pace-chip .pace-down{color:var(--red);}

/* ── Diary cards (데스크톱 .card 계열 이식 — hover 제거, 터치 최적화) ── */
.diary-count{
  font-family:var(--font-mono);font-size:12px;color:var(--text3);
  margin:0 2px 10px;
}
.cards-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,340px),1fr));
  gap:12px;
}
@keyframes fadeUp{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:none;}}
.card{
  background:var(--card);border:1px solid var(--border);border-radius:13px;
  overflow:hidden;cursor:pointer;box-shadow:0 1px 6px rgba(0,0,0,0.08);
  animation:fadeUp .22s ease both;display:flex;flex-direction:column;
  contain:layout style paint;content-visibility:auto;contain-intrinsic-size:0 300px;
}
.card:active{border-color:var(--accent2);}
.card-poster{width:100%;aspect-ratio:16/9;overflow:hidden;background:var(--bg2);position:relative;flex-shrink:0;}
.card-poster img{width:100%;height:100%;object-fit:cover;transition:opacity .25s ease;opacity:0;}
.card-poster img.loaded{opacity:1;}
.card-poster .no-img,
.no-img{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text3);font-size:28px;}
.card-body{padding:13px 15px;display:flex;gap:11px;flex:1;}
.card-date{min-width:42px;text-align:center;flex-shrink:0;}
.card-date .mo{font-family:var(--font-display);font-size:12px;letter-spacing:1px;line-height:1;margin-bottom:1px;}
.card-date .day{font-family:var(--font-display);font-size:34px;line-height:1;color:var(--text);}
.card-date .dow{font-family:var(--font-display);font-size:11px;letter-spacing:1.5px;color:var(--text2);margin-top:2px;}
.card-date .stars-mini{margin-top:5px;font-size:10px;line-height:1;letter-spacing:0.5px;}
.stars-5{color:#d4a017}.stars-4-5{color:#b0b0b0}.stars-4{color:#9b59b6}.stars-3-5{color:#5b9bd5}.stars-3{color:#7ec87e}.stars-2{color:#e05555}.stars-1{color:#e05555}.stars-0{color:#555}
.card-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px;}
.card-title{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3;letter-spacing:-0.2px;}
.card-director{font-size:12px;color:var(--text2);display:flex;align-items:center;flex-wrap:wrap;row-gap:1px;}
.card-director .dir-dot{margin:0 5px;color:var(--text3);flex-shrink:0;}
.card-director .dir-year{color:var(--text3);font-size:11px;flex-shrink:0;}
.card-meta{font-size:11px;color:var(--text3);display:flex;flex-wrap:wrap;align-items:center;line-height:1.6;}
.card-meta .dot{margin:0 4px;color:var(--text3);flex-shrink:0;}
.card-tags{display:flex;gap:4px;flex-wrap:wrap;margin-top:2px;}
.tag{background:var(--tag-bg);color:var(--tag-text);padding:1px 7px;border-radius:20px;font-size:10px;white-space:nowrap;border:1px solid var(--border);}
.tag-imax{border-color:#00b4d8;color:#00b4d8;}
.tag-dolby{border-color:#a855f7;color:#a855f7;}
.card-count{min-width:52px;flex-shrink:0;border-left:1px solid var(--border);padding-left:11px;display:flex;flex-direction:column;justify-content:center;gap:3px;text-align:right;}
.card-count .cy{font-family:var(--font-mono);font-size:14px;color:var(--accent);line-height:1.2;}
.card-count .ct{font-family:var(--font-mono);font-size:12px;color:var(--text3);line-height:1.2;}
.diary-more{height:40px;}

/* ── Detail sheet ── */
.detail-poster{margin:2px 0 14px;text-align:center;}
.detail-poster img{
  max-width:100%;max-height:40dvh;border-radius:12px;
  border:1px solid var(--border);box-shadow:var(--shadow);
}
.detail-title{
  font-family:var(--font-serif);font-size:22px;line-height:1.25;
  color:var(--text);margin-bottom:6px;
}
.detail-stars{font-size:15px;letter-spacing:2px;margin-bottom:14px;}
.detail-rows{display:flex;flex-direction:column;}
.detail-row{
  display:flex;align-items:baseline;gap:14px;
  padding:9px 0;border-top:1px solid var(--border);
}
.detail-label{
  flex:0 0 76px;font-family:var(--font-display);font-size:11px;
  letter-spacing:2px;color:var(--text3);
}
.detail-value{font-size:13.5px;color:var(--text);min-width:0;line-height:1.5;}
.detail-num{font-family:var(--font-mono);color:var(--accent);}
.detail-num-total{color:var(--text3);}
.detail-viewings{margin-top:16px;}
.detail-viewings-title{
  font-family:var(--font-display);font-size:11px;letter-spacing:2px;
  color:var(--text3);margin-bottom:8px;
}
.detail-viewing{
  width:100%;display:flex;align-items:center;gap:10px;
  border:1px solid var(--border);border-radius:10px;background:var(--card);
  color:var(--text2);padding:10px 12px;margin-bottom:6px;cursor:pointer;
  font-size:12.5px;text-align:left;
}
.detail-viewing:active{background:var(--card-hover);}
.dv-date{font-family:var(--font-mono);flex-shrink:0;color:var(--text);}
.dv-loc{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.dv-stars{flex-shrink:0;font-size:10px;letter-spacing:0.5px;}

/* ── Settings ── */
.settings-section{margin-bottom:22px;}
.settings-title{
  font-family:var(--font-display);font-size:12px;letter-spacing:2.5px;
  color:var(--text3);margin-bottom:10px;
}
.data-status{font-family:var(--font-mono);font-size:12.5px;color:var(--text2);margin-bottom:10px;}
.btn{
  border:1px solid var(--border);border-radius:10px;background:var(--card);
  color:var(--text);font-size:13px;padding:9px 14px;cursor:pointer;
  font-family:var(--font);
}
.btn:active{background:var(--card-hover);}
.btn:disabled{opacity:.45;}
.btn.btn-accent{border-color:var(--accent2);color:var(--accent);}
.btn.active{border-color:var(--accent);color:var(--accent);}
.sync-actions{display:flex;gap:8px;}
.sync-actions .btn{flex:1;}
.field-row{display:flex;gap:8px;margin:10px 0;}
.field-row input{
  flex:1;min-width:0;padding:10px 12px;border-radius:10px;
  border:1px solid var(--border);background:var(--card);color:var(--text);
  font-size:13px;font-family:var(--font-mono);
}
.field-row input::placeholder{color:var(--text3);}
.field-row input:focus{outline:none;border-color:var(--accent2);}
.db-item{
  display:flex;align-items:center;justify-content:space-between;gap:8px;
  padding:9px 2px;border-bottom:1px solid var(--border);
}
.db-info{display:flex;flex-direction:column;gap:2px;min-width:0;}
.db-label{font-size:13.5px;font-weight:600;}
.db-id{font-family:var(--font-mono);font-size:10.5px;color:var(--text3);}
.db-last-sync{font-size:10.5px;color:var(--text3);}
.db-actions{display:flex;gap:5px;flex-shrink:0;}
.db-actions button{
  border:1px solid var(--border);border-radius:8px;background:transparent;
  color:var(--text2);font-size:11.5px;padding:6px 9px;cursor:pointer;
}
.db-actions .db-del{color:var(--red);border-color:transparent;}
.db-empty{font-size:12px;color:var(--text3);padding:6px 0;}
.sync-progress{margin-top:12px;}
.sync-progress-head{
  display:flex;justify-content:space-between;gap:8px;
  font-family:var(--font-mono);font-size:11px;color:var(--text2);margin-bottom:6px;
  min-height:14px;
}
.sync-progress-head span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.sync-bar-track{height:3px;border-radius:3px;background:var(--border);overflow:hidden;}
.sync-bar{height:100%;width:0%;background:var(--accent);border-radius:3px;transition:width .25s;}
.sync-log{
  margin-top:10px;max-height:180px;overflow-y:auto;-webkit-overflow-scrolling:touch;
  font-family:var(--font-mono);font-size:10.5px;line-height:1.65;color:var(--text2);
  background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:8px 10px;
  white-space:pre-wrap;word-break:break-all;
}
.sync-log:empty{display:none;}
.sync-log .log-ok{color:var(--green);}
.sync-log .log-err{color:var(--red);}
.sync-log .log-info{color:var(--text3);}
.import-details{margin-top:6px;}
.import-details summary{
  font-size:12px;color:var(--text3);cursor:pointer;padding:4px 0;
  -webkit-user-select:none;user-select:none;
}
.import-details textarea{
  width:100%;margin:8px 0;padding:10px 12px;border-radius:10px;
  border:1px solid var(--border);background:var(--card);color:var(--text);
  font-size:11.5px;font-family:var(--font-mono);resize:vertical;
}
.import-details textarea:focus{outline:none;border-color:var(--accent2);}
.theme-btns{display:flex;gap:8px;}
.theme-btns .btn{flex:1;font-family:var(--font-display);letter-spacing:1.5px;font-size:12px;}
.about-line{font-family:var(--font-mono);font-size:11.5px;color:var(--text3);}

/* ── Toast ── */
.toast{
  position:fixed;left:50%;bottom:calc(74px + env(safe-area-inset-bottom));z-index:300;
  transform:translateX(-50%) translateY(16px);
  background:var(--card);color:var(--text);border:1px solid var(--border);
  border-radius:12px;padding:10px 16px;font-size:13px;
  box-shadow:var(--shadow);opacity:0;pointer-events:none;
  transition:opacity .22s,transform .22s;max-width:86vw;text-align:center;
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
.toast.ok{border-color:var(--green);}
.toast.err{border-color:var(--red);}
