
:root { --bg:#FFF1E4; --ink:#3F2A1E; --ink2:#A88D7A; --accent:#FF7A59; --maxw:1040px; }
* { box-sizing:border-box; margin:0; padding:0; }
body {
  font-family:-apple-system,BlinkMacSystemFont,"Pretendard Variable",Pretendard,"Apple SD Gothic Neo","Hiragino Sans","Segoe UI",Roboto,sans-serif;
  background:var(--bg); color:var(--ink); line-height:1.55; -webkit-font-smoothing:antialiased;
}
a { color:inherit; text-decoration:none; }
.wrap { max-width:var(--maxw); margin:0 auto; padding:0 24px; }
header { position:fixed; top:0; left:0; right:0; z-index:50;
  background:color-mix(in srgb, var(--bg) 75%, transparent);
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px); }
header .bar { max-width:var(--maxw); margin:0 auto; display:flex; align-items:center; justify-content:space-between; padding:14px 24px; }
.wordmark { display:flex; align-items:center; gap:10px; font-weight:650; font-size:15px; }
.wordmark img { width:26px; height:26px; border-radius:7px; }
.nav-right { display:flex; align-items:center; gap:14px; font-size:13px; color:var(--ink2); }
.lang-select { background:transparent; border:none; color:var(--ink2); font-size:13px; font-family:inherit; cursor:pointer; outline:none; }
.lang-select option { color:#1A1A1A; }
.nav-cta { color:var(--bg); background:var(--ink); padding:7px 14px; border-radius:99px; font-weight:600; font-size:13px; }
.nav-cta:hover { opacity:.85; }
.hero { min-height:92svh; display:grid; grid-template-columns:1.05fr .95fr; align-items:center; gap:44px;
  max-width:var(--maxw); margin:0 auto; padding:120px 24px 60px; }
.kicker { font-size:12px; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--ink2); margin-bottom:20px; }
.hero h1 { font-size:clamp(32px,4.8vw,52px); font-weight:700; letter-spacing:-.02em; line-height:1.18; }
.hero h1 em { font-style:normal; color:var(--accent); }
.hero-sub { margin-top:18px; font-size:clamp(15px,1.6vw,17.5px); color:var(--ink2); max-width:30em; }
.hero-cta-row { margin-top:32px; display:flex; align-items:center; gap:18px; flex-wrap:wrap; }
.appstore-btn { display:inline-flex; align-items:center; gap:10px; background:var(--ink); color:var(--bg);
  padding:14px 24px; border-radius:14px; font-size:16px; font-weight:600; transition:transform .15s, opacity .2s; }
.appstore-btn:hover { transform:translateY(-1px); opacity:.9; }
.appstore-btn svg { width:18px; height:22px; fill:currentColor; }
.rating { font-size:13px; color:var(--ink2); }
.rating .stars { color:var(--accent); letter-spacing:1px; margin-right:6px; }
.hero-foot { margin-top:16px; font-size:12.5px; color:var(--ink2); opacity:.85; }
.hero-visual { display:flex; justify-content:center; align-items:center; }
.shot { display:block; border-radius:26px; border:1px solid color-mix(in srgb, var(--ink) 10%, transparent);
  box-shadow:0 30px 70px -22px color-mix(in srgb, var(--ink) 45%, transparent); }
section { padding:80px 0; }
.sec-label { font-size:12px; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--ink2); margin-bottom:14px; }
.sec-title { font-size:clamp(25px,3.4vw,38px); font-weight:700; letter-spacing:-.02em; line-height:1.25; max-width:22em; }
.features { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-top:40px; }
.feature { border-radius:20px; padding:26px; background:color-mix(in srgb, var(--ink) 5%, transparent); border:1px solid color-mix(in srgb, var(--ink) 9%, transparent); }
.feature .dot { width:10px; height:10px; border-radius:50%; background:var(--accent); margin-bottom:14px; }
.feature h3 { font-size:17px; font-weight:650; letter-spacing:-.01em; }
.feature p { font-size:14px; color:var(--ink2); margin-top:7px; }
.x-list { margin-top:36px; display:grid; grid-template-columns:1fr 1fr; gap:10px 24px; max-width:640px; }
.x-item { font-size:15px; color:var(--ink2); display:flex; gap:10px; align-items:baseline; }
.x-item::before { content:"✕"; color:var(--accent); font-weight:700; }
.cta { text-align:center; padding:90px 0 110px; }
.cta-title { font-size:clamp(26px,3.8vw,42px); font-weight:700; letter-spacing:-.02em; line-height:1.25; }
.cta-sub { color:var(--ink2); margin-top:12px; font-size:15.5px; }
.cta .appstore-btn { margin-top:30px; }
footer { border-top:1px solid color-mix(in srgb, var(--ink) 9%, transparent); padding:34px 0 58px; font-size:13px; color:var(--ink2); }
footer .cols { display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap; }
footer a:hover { color:var(--ink); }
footer .links { display:flex; gap:16px; flex-wrap:wrap; }
@media (max-width:860px) {
  .hero { grid-template-columns:1fr; min-height:auto; padding-top:104px; text-align:center; gap:48px; }
  .hero-sub { margin-left:auto; margin-right:auto; }
  .hero-cta-row { justify-content:center; }
  .features { grid-template-columns:1fr; }
  .x-list { grid-template-columns:1fr; }
  section { padding:60px 0; }
}
@media (prefers-reduced-motion:reduce) { * { animation:none !important; } }

.popwrap { display:flex; flex-direction:column; align-items:center; gap:26px; }
.fan { position:relative; width:330px; height:400px; }
.fan img { position:absolute; width:200px; border-radius:26px;
  box-shadow:0 26px 60px -18px rgba(63,42,30,.42); border:1px solid rgba(63,42,30,.08); }
.fan img:nth-child(1) { left:6px; top:26px; transform:rotate(-7deg); }
.fan img:nth-child(2) { left:120px; top:0; transform:rotate(5deg); z-index:2; }
.score { position:absolute; right:0; bottom:38px; z-index:3; background:#FFFDF8;
  border:1px solid rgba(63,42,30,.1); border-radius:18px; padding:12px 18px;
  font-size:22px; font-weight:800; color:#FF7A59; box-shadow:0 16px 36px -12px rgba(63,42,30,.3);
  animation:bob 4s ease-in-out infinite; }
.score span { display:block; font-size:11px; font-weight:600; color:#A88D7A; margin-top:1px; }
.featpill { position:absolute; left:-8px; top:18px; z-index:3; background:#3F2A1E; color:#FFF1E4;
  border-radius:14px; padding:9px 14px; font-size:12px; font-weight:800;
  box-shadow:0 14px 32px -10px rgba(63,42,30,.5); animation:bob 4s ease-in-out infinite; animation-delay:1s; }
.featpill span { display:block; font-size:10px; font-weight:600; opacity:.75; margin-top:1px; }
.merge { display:flex; align-items:flex-end; gap:10px; }
.merge i { border-radius:50%; background:linear-gradient(145deg,#FFC93C,#FF7A59);
  animation:pop 2.6s ease-in-out infinite; }
.merge i:nth-child(1) { width:18px; height:18px; }
.merge i:nth-child(2) { width:28px; height:28px; animation-delay:.2s; }
.merge i:nth-child(3) { width:42px; height:42px; animation-delay:.4s; }
.merge i:nth-child(4) { width:60px; height:60px; animation-delay:.6s; }
.merge b { font-size:30px; color:#FF7A59; animation:pop 2.6s ease-in-out infinite; animation-delay:.8s; }
@keyframes pop { 0%,100% { transform:scale(1); } 50% { transform:scale(1.14); } }
@keyframes bob { 0%,100% { transform:translateY(0); } 50% { transform:translateY(-7px); } }
@media (max-width:520px) { .fan { transform:scale(.84); margin:-26px 0; } }
