/* ================= MODUM ================= */
:root{
  --ink:#0c0f11;
  --ink2:#14181c;
  --paper:#f6f2ea;
  --paper2:#ede7da;
  --txt:#e9e5dd;
  --txt-dark:#22251f;
  --muted:#a7aaa6;
  --muted-dark:#6f7268;
  --coral:#e4593a;
  --coral-d:#c04328;
  --gold:#c9a86b;
  --line:rgba(255,255,255,.09);
  --line-dark:rgba(0,0,0,.12);
  --serif:"Noto Serif KR", serif;
  --sans:"Noto Sans KR", sans-serif;
  --max:1180px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--ink);color:var(--txt);line-height:1.7;font-weight:300;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul{list-style:none}

.wrap{max-width:var(--max);margin:0 auto;padding:0 24px}
.center{text-align:center}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}

h1,h2,h3{font-family:var(--serif);font-weight:700;line-height:1.3;letter-spacing:-.01em}
h2{font-size:clamp(1.7rem,3.4vw,2.6rem);margin-bottom:18px}
.kicker{font-size:.82rem;letter-spacing:.32em;text-transform:uppercase;color:var(--coral);font-weight:500;margin-bottom:16px}
.lead{font-size:1.06rem;color:var(--muted);margin-bottom:14px}
.section-paper .lead{color:var(--muted-dark)}
.fineprint{font-size:.82rem;color:var(--muted);margin-top:26px}
.section-paper .fineprint{color:var(--muted-dark)}

section{padding:110px 0}
.section-dark{background:var(--ink)}
.section-dark2{background:var(--ink2)}
.section-paper{background:var(--paper);color:var(--txt-dark)}

/* buttons */
.btn{display:inline-block;padding:14px 30px;border-radius:2px;font-size:.95rem;font-weight:500;letter-spacing:.04em;transition:all .25s;border:1px solid transparent}
.btn-primary{background:var(--coral);color:#fff}
.btn-primary:hover{background:var(--coral-d);transform:translateY(-2px)}
.btn-ghost{border-color:rgba(255,255,255,.4);color:#fff}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.08)}
.btn-ghost-dark{border-color:rgba(0,0,0,.35);color:var(--txt-dark)}
.btn-ghost-dark:hover{background:rgba(0,0,0,.06)}

/* ================= NAV ================= */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .3s,box-shadow .3s;padding:18px 0}
.nav.scrolled{background:rgba(12,15,17,.94);backdrop-filter:blur(12px);box-shadow:0 1px 0 var(--line);padding:10px 0}
.nav-inner{max-width:var(--max);margin:0 auto;padding:0 24px;display:flex;align-items:center;gap:32px}
.brand{display:flex;align-items:baseline;gap:10px}
.brand-mark{font-family:var(--serif);font-weight:900;font-size:1.7rem;color:#fff;letter-spacing:.06em}
.brand-sub{font-size:.68rem;letter-spacing:.42em;color:var(--gold);font-weight:500}
.nav-links{display:flex;gap:26px;margin-left:auto}
.nav-links a{font-size:.92rem;color:rgba(255,255,255,.85);position:relative;padding:4px 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--coral);transition:width .25s}
.nav-links a:hover::after{width:100%}
.nav-right{display:flex;align-items:center;gap:14px}
.lang-switch{display:flex;border:1px solid rgba(255,255,255,.3);border-radius:2px;overflow:hidden}
.lang-switch button{background:transparent;border:none;color:rgba(255,255,255,.6);font-size:.78rem;letter-spacing:.08em;padding:6px 12px;cursor:pointer;font-family:var(--sans);transition:all .2s}
.lang-switch button.active{background:var(--coral);color:#fff}
.nav-call{font-size:.88rem;color:#fff;border:1px solid rgba(255,255,255,.35);padding:8px 16px;border-radius:2px;transition:all .25s;white-space:nowrap}
.nav-call:hover{background:var(--coral);border-color:var(--coral)}
.burger{display:none;background:none;border:none;cursor:pointer;padding:6px}
.burger span{display:block;width:22px;height:2px;background:#fff;margin:5px 0;transition:all .3s}

/* ================= HERO ================= */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:center;padding:140px 0 0}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.02)}
.hero-veil{position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(12,15,17,.62) 0%,rgba(12,15,17,.38) 45%,rgba(12,15,17,.88) 100%)}
.hero-content{position:relative;max-width:var(--max);margin:0 auto;padding:0 24px;width:100%}
.hero h1{font-size:clamp(2.6rem,6.4vw,4.6rem);font-weight:900;color:#fff;margin-bottom:24px;text-shadow:0 2px 30px rgba(0,0,0,.45)}
.hero-sub{font-size:clamp(1rem,1.8vw,1.2rem);color:rgba(255,255,255,.88);max-width:560px;margin-bottom:36px;white-space:pre-line}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-stats{position:relative;margin-top:auto;display:grid;grid-template-columns:repeat(4,1fr);max-width:var(--max);margin:72px auto 0;width:calc(100% - 48px);border-top:1px solid rgba(255,255,255,.18);padding:26px 0 34px}
.hero-stats div{text-align:center;padding:0 10px}
.hero-stats strong{display:block;font-family:var(--serif);font-size:1.15rem;color:#fff;font-weight:700;margin-bottom:4px}
.hero-stats span{font-size:.82rem;color:rgba(255,255,255,.66)}

/* ================= PROMISE ================= */
.promise-copy h2{color:#fff}
.promise-list{margin-top:34px;display:flex;flex-direction:column;gap:22px}
.promise-list li{padding-left:22px;border-left:2px solid var(--coral)}
.promise-list strong{display:block;font-family:var(--serif);font-size:1.08rem;color:#fff;font-weight:600;margin-bottom:3px}
.promise-list span{font-size:.94rem;color:var(--muted)}
.promise-imgs{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;gap:16px}
.promise-imgs figure{overflow:hidden;border-radius:3px}
.promise-imgs img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.promise-imgs figure:hover img{transform:scale(1.05)}
.pi-a{grid-column:1/3;aspect-ratio:16/9}
.pi-b{aspect-ratio:4/5}
.pi-c{aspect-ratio:4/5}

/* ================= SETS ================= */
.set-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:48px}
.set-card{background:#fff;border:1px solid var(--line-dark);border-radius:3px;padding:34px 26px 30px;position:relative;display:flex;flex-direction:column;transition:transform .25s,box-shadow .25s}
.set-card:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(0,0,0,.12)}
.set-card.popular{border-color:var(--coral)}
.set-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--coral);color:#fff;font-size:.72rem;letter-spacing:.14em;padding:4px 14px;border-radius:20px;white-space:nowrap}
.set-num{font-family:var(--serif);font-size:.8rem;letter-spacing:.3em;color:var(--gold);margin-bottom:10px}
.set-name{font-family:var(--serif);font-size:1.22rem;font-weight:700;margin-bottom:14px;line-height:1.4}
.set-items{font-size:.9rem;color:var(--muted-dark);flex:1;line-height:2}
.set-items li::before{content:"— ";color:var(--gold)}
.set-price{margin-top:22px;padding-top:18px;border-top:1px solid var(--line-dark);font-family:var(--serif);font-size:1.5rem;font-weight:700;color:var(--coral-d)}
.set-price small{font-size:.85rem;color:var(--muted-dark);font-family:var(--sans);font-weight:400}

/* ================= SPECIAL ================= */
.special{background:
  radial-gradient(1200px 600px at 85% 10%,rgba(228,89,58,.14),transparent 60%),
  var(--ink2)}
.special-img{position:relative;border-radius:4px;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.special-img img{width:100%;aspect-ratio:4/5;object-fit:cover}
.special-copy h2{color:#fff;font-size:clamp(2rem,4vw,3rem)}
.special-price{display:inline-block;background:var(--coral);color:#fff;font-family:var(--serif);font-weight:700;font-size:1.25rem;padding:6px 20px;border-radius:2px;letter-spacing:.04em;margin:6px 0 18px}
.special-copy p{margin-bottom:16px}
.special-copy .lead{color:#d8d4cc}
.special-badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px}
.special-badges span{border:1px solid rgba(228,89,58,.5);color:#f0b4a4;font-size:.82rem;padding:7px 16px;border-radius:30px;letter-spacing:.03em}

/* ================= MENU ================= */
.menu-tabs{display:flex;justify-content:center;flex-wrap:wrap;gap:8px;margin:44px 0 40px}
.menu-tabs button{font-family:var(--sans);font-size:.92rem;letter-spacing:.05em;padding:10px 22px;background:transparent;border:1px solid var(--line-dark);border-radius:30px;cursor:pointer;color:var(--muted-dark);transition:all .2s}
.menu-tabs button:hover{border-color:var(--coral);color:var(--coral-d)}
.menu-tabs button.active{background:var(--txt-dark);border-color:var(--txt-dark);color:var(--paper)}
.menu-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px 56px;max-width:980px;margin:0 auto}
.menu-item{display:flex;align-items:baseline;gap:12px;padding:15px 4px;border-bottom:1px solid var(--line-dark)}
.mi-names{flex-shrink:0}
.mi-name{font-family:var(--serif);font-weight:600;font-size:1.02rem;color:var(--txt-dark)}
.mi-sub{display:block;font-size:.78rem;color:var(--muted-dark);letter-spacing:.02em}
.mi-desc{display:block;font-size:.8rem;color:var(--coral-d);margin-top:2px}
.mi-dots{flex:1;border-bottom:1px dotted rgba(0,0,0,.28);transform:translateY(-4px)}
.mi-price{font-family:var(--serif);font-weight:600;font-size:.98rem;color:var(--txt-dark);white-space:nowrap;text-align:right}
.mi-price small{display:block;font-size:.78rem;font-weight:400;color:var(--muted-dark)}
.menu-item.star .mi-name::after{content:"★";color:var(--coral);font-size:.8rem;margin-left:6px}

/* ================= GALLERY ================= */
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:210px;gap:14px;margin-top:48px}
.g-item{position:relative;overflow:hidden;border-radius:3px;cursor:zoom-in}
.g-item img{width:100%;height:100%;object-fit:cover;transition:transform .55s}
.g-item:hover img{transform:scale(1.06)}
.g-item .g-cap{position:absolute;left:0;right:0;bottom:0;padding:26px 14px 12px;font-size:.8rem;color:#fff;background:linear-gradient(transparent,rgba(0,0,0,.72));opacity:0;transition:opacity .3s}
.g-item:hover .g-cap{opacity:1}
.g-item.tall{grid-row:span 2}
.g-item.wide{grid-column:span 2}

/* ================= REVIEWS ================= */
.review-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin:48px 0 40px}
.review-card{background:rgba(255,255,255,.035);border:1px solid var(--line);border-radius:3px;padding:30px 26px;display:flex;flex-direction:column}
.review-card .stars{color:var(--gold);letter-spacing:.2em;font-size:.85rem;margin-bottom:16px}
.review-card blockquote{font-size:.95rem;color:#d9d5cd;flex:1;line-height:1.85}
.review-card cite{display:block;margin-top:18px;font-style:normal;font-size:.78rem;color:var(--muted);letter-spacing:.06em}

/* ================= VISIT ================= */
.visit .grid-2{align-items:start}
.info-list{margin:30px 0 34px;display:flex;flex-direction:column;gap:18px}
.info-list div{display:grid;grid-template-columns:96px 1fr;gap:14px}
.info-list dt{font-family:var(--serif);font-weight:700;color:var(--coral-d);font-size:.95rem;letter-spacing:.06em}
.info-list dd{font-size:.95rem;color:var(--txt-dark)}
.info-list dd em{color:var(--muted-dark);font-style:normal;font-size:.85rem}
.info-list dd a{border-bottom:1px solid var(--line-dark)}
.visit-btns{display:flex;gap:12px;flex-wrap:wrap}
.visit-map{display:flex;flex-direction:column;gap:16px}
.visit-map iframe{width:100%;height:320px;border:0;border-radius:3px;filter:grayscale(.2)}
.visit-photo{overflow:hidden;border-radius:3px}
.visit-photo img{width:100%;height:240px;object-fit:cover}

/* ================= FOOTER ================= */
.footer{background:#080a0b;padding:56px 0;border-top:1px solid var(--line)}
.footer-inner{text-align:center;display:flex;flex-direction:column;gap:12px;align-items:center}
.footer p{font-size:.88rem;color:var(--muted)}
.footer .dim{font-size:.76rem;color:#5c6063}

/* quickbar (mobile) */
.quickbar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:90;grid-template-columns:1fr 1fr;background:rgba(12,15,17,.97);border-top:1px solid var(--line)}
.quickbar a{text-align:center;padding:15px 0;font-size:.95rem;color:#fff;font-weight:500}
.quickbar a:first-child{background:var(--coral)}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:200;background:rgba(8,10,11,.96);display:none;flex-direction:column;align-items:center;justify-content:center;padding:40px}
.lightbox.open{display:flex}
.lightbox img{max-width:92vw;max-height:80vh;border-radius:3px}
.lightbox p{margin-top:16px;color:var(--muted);font-size:.9rem}
.lb-close{position:absolute;top:18px;right:26px;background:none;border:none;color:#fff;font-size:2.4rem;cursor:pointer;line-height:1}

/* reveal animation */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}
html.no-anim{scroll-behavior:auto}
html.no-anim .nav.scrolled{backdrop-filter:none}
html.no-anim .reveal{opacity:1;transform:none;transition:none}
html.no-anim *{transition:none !important}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none;transition:none}
}

/* ================= RESPONSIVE ================= */
@media(max-width:1024px){
  .set-cards{grid-template-columns:repeat(2,1fr)}
  .review-cards{grid-template-columns:repeat(2,1fr)}
  .gallery-grid{grid-template-columns:repeat(3,1fr)}
  .nav-links{display:none}
}
@media(max-width:760px){
  section{padding:72px 0}
  .grid-2{grid-template-columns:1fr;gap:40px}
  .hero-stats{grid-template-columns:repeat(2,1fr);gap:18px 0}
  .menu-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px}
  .set-cards{grid-template-columns:1fr}
  .review-cards{grid-template-columns:1fr}
  .nav-call{display:none}
  .burger{display:block}
  .quickbar{display:grid}
  body{padding-bottom:52px}
  .info-list div{grid-template-columns:78px 1fr}
}
/* mobile nav overlay */
.nav-links.open{display:flex;position:fixed;inset:0;background:rgba(12,15,17,.98);flex-direction:column;align-items:center;justify-content:center;gap:30px;z-index:99}
.nav-links.open a{font-size:1.3rem;font-family:var(--serif)}
