:root{
  /* ✅ iPhone 13에서 확실히 크게 보이게(체감 2배급) */
  --fs: 20px;            /* 기본 글자 */
  --fs-sm: 0.95rem;      /* 설명/보조 */
  --fs-md: 1.05rem;
  --fs-lg: 1.25rem;
  --fs-xl: 1.9rem;

  --radius: 18px;
  --shadow: 0 10px 30px rgba(0,0,0,.35);

  /* 기본(다크) */
  --bg:#0b1220;
  --card: rgba(255,255,255,.05);
  --card2: rgba(255,255,255,.04);
  --text:#e8eefc;
  --muted:#a9b6d3;
  --line:rgba(255,255,255,.10);

  /* 몽픽 포인트(보라+핑크) */
  --accent:#c084fc;
  --accent2:#fb7185;

  /* 버튼 */
  --btnText:#081024;
}

/* ✅ 라이트 테마 */
html[data-theme="light"]{
  --bg:#f6f7ff;
  --card: rgba(255,255,255,.92);
  --card2: rgba(255,255,255,.80);
  --text:#111827;
  --muted:#4b5563;
  --line: rgba(17,24,39,.10);

  --accent:#a855f7;
  --accent2:#fb7185;

  --shadow: 0 14px 30px rgba(17,24,39,.08);
  --btnText:#ffffff;
}

*{ box-sizing:border-box; }
html,body{ height:100%; }

body{
  margin:0;
  font-size: var(--fs);
  font-family: ui-sans-serif, system-ui, -apple-system, "Apple SD Gothic Neo", "Noto Sans KR", Segoe UI, Roboto, Arial;
  background:
    radial-gradient(900px 500px at 20% 0%, color-mix(in oklab, var(--accent) 24%, transparent), transparent 55%),
    radial-gradient(800px 500px at 90% 10%, color-mix(in oklab, var(--accent2) 18%, transparent), transparent 55%),
    var(--bg);
  color:var(--text);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Layout */
.app{
  max-width: 520px;
  margin:0 auto;
  min-height:100%;
  padding-bottom: 96px;
}

/* Top Header */
.topbar{
  position: sticky;
  top:0;
  z-index:50;
  backdrop-filter: blur(10px);
  background: color-mix(in oklab, var(--bg) 72%, transparent);
  border-bottom: 1px solid var(--line);
}
.topbar-inner{ padding: 16px 16px 12px; }

.brand{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.logo{
  display:flex;
  align-items:center;
  gap:12px;
  min-width: 0;
}
.brand-character{
  width:56px;
  height:56px;
  object-fit:contain;
  border-radius: 16px;
  background: color-mix(in oklab, var(--card) 85%, transparent);
  border: 1px solid var(--line);
  box-shadow: 0 12px 22px rgba(0,0,0,.12);
  padding: 6px;
}
.brand-text{ min-width:0; }
.brand-title{
  margin:0;
  font-size: 1.15rem;
  line-height: 1.15;
  font-weight: 900;
  letter-spacing: -0.4px;
  white-space: nowrap;
  overflow:hidden;
  text-overflow: ellipsis;
}
.brand-sub{
  margin:4px 0 0;
  font-size: var(--fs-sm);
  color: var(--muted);
  white-space: nowrap;
  overflow:hidden;
  text-overflow: ellipsis;
}

/* Theme Chip */
.chip{
  border:1px solid var(--line);
  background: var(--card2);
  color: var(--text);
  padding: 10px 12px;
  border-radius: 999px;
  font-size: var(--fs-sm);
  display:flex;
  align-items:center;
  gap:8px;
  cursor:pointer;
  user-select:none;
}
.chip:active{ transform: translateY(1px); }
.chip-emoji{ font-size: 1.1rem; }
.chip-text{ font-weight: 800; }

/* Search */
.search{
  margin-top: 12px;
  display:flex;
  gap:10px;
  align-items:center;
}
.searchbox{ flex:1; position:relative; }
.searchbox input{
  width:100%;
  padding: 14px 14px 14px 44px;
  border-radius: 16px;
  border:1px solid var(--line);
  outline:none;
  background: var(--card2);
  color: var(--text);
  font-size: 1rem;
}
.searchbox input::placeholder{ color: color-mix(in oklab, var(--muted) 70%, transparent); }
.icon{
  position:absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  opacity:.9;
}
.btn{
  border:1px solid var(--line);
  background: var(--card2);
  color: var(--text);
  padding: 12px 14px;
  border-radius: 16px;
  font-size: 1rem;
  cursor:pointer;
}
.btn:active{ transform: translateY(1px); }

/* Content */
.content{ padding: 14px 16px 0; }

/* Hero */
.hero{
  margin-top: 10px;
  padding: 14px;
  border-radius: 22px;
  background: var(--card);
  border:1px solid var(--line);
  box-shadow: var(--shadow);
  overflow:hidden;
  position:relative;
}

.hero-image{
  width:100%;
  height: 170px;
  border-radius: 18px;
  overflow:hidden;
  margin-bottom: 14px;
  position:relative;
  background:
    radial-gradient(220px 160px at 20% 25%, color-mix(in oklab, var(--accent) 28%, transparent), transparent 60%),
    radial-gradient(220px 160px at 80% 30%, color-mix(in oklab, var(--accent2) 24%, transparent), transparent 60%),
    color-mix(in oklab, var(--bg) 75%, white 25%);
}
.hero-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  filter: saturate(1.05) contrast(1.02);
}
.hero-bubble{
  position:absolute;
  left:12px;
  bottom:12px;
  padding: 10px 12px;
  border-radius: 999px;
  background: color-mix(in oklab, var(--card) 75%, transparent);
  border:1px solid var(--line);
  font-size: var(--fs-sm);
  font-weight: 900;
  backdrop-filter: blur(8px);
}

.hero-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}
.hero h2{
  margin:0;
  font-size: var(--fs-xl);
  letter-spacing:-0.6px;
  line-height: 1.15;
}
.hero p{
  margin: 8px 0 0;
  font-size: var(--fs-md);
  color: var(--muted);
  line-height: 1.35;
}

.pill{
  padding: 8px 10px;
  border-radius: 999px;
  border:1px solid var(--line);
  background: var(--card2);
  color: color-mix(in oklab, var(--text) 90%, transparent);
  font-size: var(--fs-sm);
  white-space: nowrap;
  font-weight: 900;
}

.hero .cta{
  margin-top: 14px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.cta .primary{
  background: linear-gradient(135deg, var(--accent), color-mix(in oklab, var(--accent) 70%, white 30%));
  border: none;
  color: var(--btnText);
  font-weight: 1000;
  padding: 12px 14px;
  border-radius: 16px;
  cursor:pointer;
  font-size: 1rem;
}
html[data-theme="dark"] .cta .primary{ color:#0b1220; }
.cta .secondary{
  background: var(--card2);
  border: 1px solid var(--line);
  color: var(--text);
  padding: 12px 14px;
  border-radius: 16px;
  cursor:pointer;
  font-size: 1rem;
}

/* Sections */
.section{ margin-top: 20px; }
.section-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom: 12px;
}
.section-title{
  margin:0;
  font-size: var(--fs-lg);
  letter-spacing:-0.3px;
  font-weight: 1000;
}
.link{
  color: color-mix(in oklab, var(--text) 82%, transparent);
  font-size: var(--fs-sm);
  text-decoration:none;
  opacity:.95;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: var(--card2);
}

/* Tags */
.tags{
  display:flex;
  gap:10px;
  overflow:auto;
  padding-bottom: 2px;
  scrollbar-width: none;
}
.tags::-webkit-scrollbar{ display:none; }
.tag{
  white-space:nowrap;
  border:1px solid var(--line);
  background: var(--card2);
  color: color-mix(in oklab, var(--text) 92%, transparent);
  font-size: var(--fs-sm);
  padding: 10px 12px;
  border-radius: 999px;
  cursor:pointer;
  user-select:none;
  font-weight: 900;
}
.tag.active{
  border-color: color-mix(in oklab, var(--accent) 65%, transparent);
  background: color-mix(in oklab, var(--accent) 18%, transparent);
}

/* Grid cards */
.grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.card{
  border:1px solid var(--line);
  border-radius: 22px;
  background: var(--card);
  overflow:hidden;
  box-shadow: 0 10px 24px rgba(0,0,0,.16);
  cursor:pointer;
  transition: transform .12s ease;
}
.card:active{ transform: scale(.99); }

.thumb{
  height: 112px;
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(140px 90px at 25% 25%, color-mix(in oklab, var(--accent) 22%, transparent), transparent 60%),
    radial-gradient(140px 90px at 80% 30%, color-mix(in oklab, var(--accent2) 18%, transparent), transparent 60%),
    color-mix(in oklab, var(--bg) 70%, white 30%);
}
.thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.badge{
  position:absolute;
  left: 12px;
  top: 12px;
  font-size: var(--fs-sm);
  padding: 8px 10px;
  border-radius: 999px;
  background: color-mix(in oklab, #000 25%, transparent);
  border:1px solid color-mix(in oklab, var(--line) 80%, transparent);
  color: color-mix(in oklab, var(--text) 95%, transparent);
  backdrop-filter: blur(8px);
  font-weight: 1000;
}

.card-body{ padding: 12px 12px 14px; }
.card-title{
  margin:0;
  font-size: 1.05rem;
  font-weight: 1000;
  line-height: 1.25;
  letter-spacing:-0.3px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow:hidden;
  min-height: 44px;
}
.card-meta{
  margin-top: 10px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  color: var(--muted);
  font-size: var(--fs-sm);
}
.card-meta .pill{
  font-size: var(--fs-sm);
  padding: 7px 10px;
}

/* List rows */
.list{ display:flex; flex-direction:column; gap: 12px; }
.row{
  display:flex;
  gap:12px;
  padding: 12px;
  border-radius: 22px;
  border:1px solid var(--line);
  background: var(--card);
  cursor:pointer;
}
.mini{
  width: 84px;
  height: 84px;
  border-radius: 18px;
  overflow:hidden;
  flex: 0 0 auto;
  background:
    radial-gradient(90px 70px at 25% 25%, color-mix(in oklab, var(--accent) 22%, transparent), transparent 60%),
    radial-gradient(90px 70px at 75% 30%, color-mix(in oklab, var(--accent2) 18%, transparent), transparent 60%),
    color-mix(in oklab, var(--bg) 70%, white 30%);
  border:1px solid var(--line);
}
.mini img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.row h4{
  margin:0;
  font-size: 1.08rem;
  font-weight: 1000;
  letter-spacing:-0.3px;
  line-height: 1.25;
}
.row p{
  margin: 8px 0 0;
  font-size: 0.98rem;
  color: var(--muted);
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow:hidden;
}
.row .row-meta{
  margin-top: 10px;
  display:flex;
  gap:8px;
  align-items:center;
  flex-wrap:wrap;
}
.row .row-meta .pill{ font-size: var(--fs-sm); }

.more{
  margin: 16px 0 10px;
  width:100%;
  padding: 14px 14px;
  border-radius: 18px;
  border:1px solid var(--line);
  background: var(--card2);
  color: var(--text);
  font-weight: 1000;
  cursor:pointer;
  font-size: 1rem;
}

/* Bottom Nav */
.bottom{
  position: fixed;
  left:50%;
  transform: translateX(-50%);
  bottom: 10px;
  width: min(520px, calc(100% - 18px));
  border-radius: 24px;
  border:1px solid var(--line);
  background: color-mix(in oklab, var(--bg) 72%, transparent);
  backdrop-filter: blur(10px);
  box-shadow: var(--shadow);
  padding: 8px 10px;
  z-index: 60;
}
.tabs{
  display:flex;
  justify-content:space-between;
  gap:10px;
}
.tab{
  flex:1;
  border:none;
  background: transparent;
  color: color-mix(in oklab, var(--text) 70%, transparent);
  padding: 12px 10px;
  border-radius: 18px;
  font-size: var(--fs-sm);
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  user-select:none;
  font-weight: 900;
}
.tab.active{
  background: color-mix(in oklab, var(--accent) 16%, transparent);
  border:1px solid color-mix(in oklab, var(--accent) 26%, transparent);
  color: color-mix(in oklab, var(--text) 95%, transparent);
}
.dot{
  width:8px;height:8px;border-radius:50%;
  background: color-mix(in oklab, var(--text) 55%, transparent);
}
.tab.active .dot{
  background: var(--accent);
  box-shadow: 0 0 0 5px color-mix(in oklab, var(--accent) 14%, transparent);
}

/* Desktop polish */
@media (min-width: 521px){
  .content{ padding-left: 0; padding-right: 0; }
  .topbar-inner{ padding-left: 0; padding-right: 0; }
  .app{ padding-left: 16px; padding-right: 16px; }
}

/* 혹시 더 큰 글자 원하는 경우 iPhone 13 폭에서 추가 상승 */
@media (max-width: 420px){
  :root{ --fs: 21px; }
}
