
:root { --bg:#F8F3E9; --ink:#2B231A; --ink2:#9C8C77; --accent:#E07A33; --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; } }

.tmhero { position:relative; width:370px; height:520px; }
.tmhero > .shot { position:absolute; width:250px; right:0; top:0; }
.watch { position:absolute; left:0; bottom:48px; width:132px; height:162px; border-radius:40px;
  background:#221C15; border:6px solid #3C3327;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 26px 60px -18px rgba(43,35,26,.5); animation:watchfloat 4.5s ease-in-out infinite; }
.watch .crown { position:absolute; right:-12px; top:42px; width:7px; height:24px; border-radius:4px; background:#3C3327; }
.rec { position:absolute; top:18px; width:12px; height:12px; border-radius:50%; background:#E0452F;
  animation:blink 1.6s ease-in-out infinite; }
.wave { display:flex; align-items:center; gap:5px; height:50px; }
.wave i { width:6px; border-radius:4px; background:var(--accent); animation:wv 1.05s ease-in-out infinite; }
.wave i:nth-child(1) { height:16px; } .wave i:nth-child(2) { height:34px; animation-delay:.12s; }
.wave i:nth-child(3) { height:48px; animation-delay:.24s; } .wave i:nth-child(4) { height:30px; animation-delay:.36s; }
.wave i:nth-child(5) { height:18px; animation-delay:.48s; }
@keyframes wv { 0%,100% { transform:scaleY(.55); } 50% { transform:scaleY(1); } }
@keyframes blink { 0%,100% { opacity:1; } 50% { opacity:.35; } }
@keyframes watchfloat { 0%,100% { transform:translateY(0); } 50% { transform:translateY(-8px); } }
@media (max-width:520px) { .tmhero { transform:scale(.84); margin:-36px 0; } }
