/* 오늘 뭐 먹지 — 디자인 시스템 v2 */
:root{
  --cream:#fbf6ee; --paper:#ffffff; --ink:#2a2520; --soft:#6f665b; --faint:#9b9286;
  --line:#ece3d6; --primary:#e2542b; --primary-d:#c4421e; --accent:#1f8a5b; --gold:#e8a32c;
  --shadow:0 10px 30px rgba(80,50,20,.10); --shadow-lg:0 24px 60px rgba(80,50,20,.16);
  --radius:20px; --radius-sm:14px; --max:1080px; --gap:clamp(14px,2.4vw,24px);
  --serif:"Pretendard Variable",Pretendard,system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{font-family:var(--serif);color:var(--ink);background:var(--cream);
  line-height:1.75;letter-spacing:-.01em;word-break:keep-all;overflow-wrap:break-word;
  -webkit-font-smoothing:antialiased}
img,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--max);margin:0 auto;padding:0 clamp(16px,4vw,28px)}
.skip{position:absolute;left:-999px}
.skip:focus{left:8px;top:8px;background:#fff;padding:8px 14px;border-radius:8px;z-index:99}
h1,h2,h3{line-height:1.32;letter-spacing:-.02em;font-weight:800}
section.sec{margin:clamp(34px,6vw,60px) 0}
.sec-head{margin-bottom:clamp(16px,3vw,26px)}
.sec-head.center{text-align:center}
.sec-head h2{font-size:clamp(20px,3.4vw,28px)}
.sec-sub{color:var(--soft);margin-top:6px;font-size:clamp(14px,2.2vw,16px)}

/* ---------- header ---------- */
.site-head{position:sticky;top:0;z-index:50;background:rgba(251,246,238,.86);
  backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--line)}
.head-in{display:flex;align-items:center;justify-content:space-between;height:62px}
.brand{display:flex;align-items:center;gap:9px;font-weight:800;font-size:19px}
.brand-mark{display:grid;place-items:center}
.brand-name{letter-spacing:-.03em}
.site-nav{display:flex;gap:6px}
.site-nav a{padding:8px 13px;border-radius:999px;font-weight:600;font-size:15px;color:var(--soft);transition:.15s}
.site-nav a:hover{background:#fff;color:var(--ink);box-shadow:var(--shadow)}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;padding:8px;cursor:pointer}
.nav-toggle span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.2s}

/* ---------- hero ---------- */
.hero{position:relative;background:
  radial-gradient(120% 90% at 85% -10%, #ffe6d3 0%, rgba(255,230,211,0) 55%),
  radial-gradient(90% 80% at 0% 0%, #fdeccf 0%, rgba(253,236,207,0) 50%);
  padding:clamp(28px,6vw,64px) 0 clamp(60px,9vw,96px);overflow:hidden}
.hero-in{display:grid;grid-template-columns:1.05fr .95fr;gap:var(--gap);align-items:center}
.hero-title{font-size:clamp(34px,7vw,60px);letter-spacing:-.04em;line-height:1.08}
.hero-sub{margin-top:14px;color:var(--soft);font-size:clamp(15px,2.6vw,19px);line-height:1.7}
.hero-wave{position:absolute;left:0;right:0;bottom:-1px;height:40px;
  background:radial-gradient(60% 100% at 50% 100%, var(--cream) 70%, transparent 71%) repeat-x;
  background-size:48px 40px}

/* picker */
.picker{margin-top:26px;background:var(--paper);border:1px solid var(--line);
  border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:clamp(16px,3vw,22px)}
.picker-stage{min-height:140px;display:grid;place-items:center;text-align:center}
.picker-idle{color:var(--faint)}
.picker-illust{display:block;width:84px;height:84px;margin:0 auto 6px;animation:float 4s ease-in-out infinite}
.picker-result .pr-ill{width:88px;height:88px;margin:0 auto}
.pr-name{font-size:clamp(26px,5vw,36px);font-weight:800;letter-spacing:-.03em;margin-top:4px}
.pr-cat{display:inline-block;margin-top:8px;font-size:13px;font-weight:700;color:#fff;
  background:var(--primary);padding:4px 13px;border-radius:999px}
.pr-one{color:var(--soft);font-size:14px;margin-top:8px}
.pr-go{display:inline-block;margin-top:12px;font-weight:700;color:var(--primary)}
.picker-cats{display:flex;flex-wrap:wrap;gap:7px;justify-content:center;margin:16px 0 4px}
.picker-cats button{border:1.5px solid var(--line);background:#fff;color:var(--soft);
  font-weight:700;font-size:13px;padding:7px 13px;border-radius:999px;cursor:pointer;transition:.15s}
.picker-cats button.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn-pick{display:block;width:100%;margin-top:12px;border:0;cursor:pointer;font-family:inherit;
  font-weight:800;font-size:17px;color:#fff;padding:16px;border-radius:var(--radius-sm);
  background:linear-gradient(135deg,var(--primary),#ef7a4a);
  box-shadow:0 12px 26px rgba(226,84,43,.34);transition:transform .08s,box-shadow .2s}
.btn-pick:hover{box-shadow:0 16px 34px rgba(226,84,43,.42)}
.btn-pick:active{transform:scale(.98)}
.btn-ghost{display:inline-block;font-weight:700;color:var(--ink);background:#fff;
  border:1.5px solid var(--line);padding:13px 20px;border-radius:var(--radius-sm);cursor:pointer;text-align:center}
.btn-ghost:hover{border-color:var(--primary);color:var(--primary)}

/* hero floating art */
.hero-art{position:relative;height:320px;display:none}
.hero-art .float{position:absolute;width:128px;height:128px;background:#fff;border-radius:28px;
  box-shadow:var(--shadow-lg);display:grid;place-items:center;padding:18px}
.float.f1{top:8%;left:6%;animation:float 5s ease-in-out infinite}
.float.f2{top:2%;right:10%;width:104px;height:104px;animation:float 6s ease-in-out .4s infinite}
.float.f3{bottom:6%;left:22%;width:112px;height:112px;animation:float 5.5s ease-in-out .8s infinite}
.float.f4{bottom:14%;right:6%;width:96px;height:96px;animation:float 6.5s ease-in-out .2s infinite}
@keyframes float{0%,100%{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-16px) rotate(1.5deg)}}
.float-hover{transition:transform .25s cubic-bezier(.2,.8,.2,1),box-shadow .25s}
.float-hover:hover{transform:translateY(-7px)}

/* ---------- category grid ---------- */
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gap)}
.cat-tile{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px 16px;text-align:center;box-shadow:var(--shadow);position:relative;overflow:hidden}
.cat-tile::before{content:"";position:absolute;inset:0 0 auto 0;height:5px;background:var(--c)}
.cat-ill{display:block;width:64px;height:64px;margin:6px auto 10px}
.cat-name{display:block;font-weight:800;font-size:17px}
.cat-desc{display:block;color:var(--soft);font-size:13px;margin-top:3px}

/* chips (situations) */
.chip-row{display:flex;flex-wrap:wrap;gap:10px}
.chip{display:flex;flex-direction:column;background:var(--paper);border:1px solid var(--line);
  border-radius:var(--radius-sm);padding:12px 16px;min-width:130px;flex:1 1 130px;box-shadow:var(--shadow);transition:.18s}
.chip:hover{transform:translateY(-4px);border-color:var(--primary)}
.chip b{font-size:16px;font-weight:800}
.chip span{color:var(--soft);font-size:12.5px;margin-top:2px}

/* ---------- menu cards ---------- */
.mcard-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gap)}
.mcard{display:flex;flex-direction:column;background:var(--paper);border:1px solid var(--line);
  border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:transform .22s,box-shadow .22s}
.mcard:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.mcard-thumb{display:grid;place-items:center;aspect-ratio:16/10;padding:14px;
  background:color-mix(in srgb, var(--c) 12%, #fff)}
.mcard-thumb svg{width:78px;height:78px}
.mcard-body{padding:14px 15px 16px;display:flex;flex-direction:column;gap:3px;flex:1}
.mcard-cat{font-size:11.5px;font-weight:800;color:var(--c);letter-spacing:.02em}
.mcard-name{font-size:18px;font-weight:800;letter-spacing:-.02em}
.mcard-desc{color:var(--soft);font-size:13px;line-height:1.55;flex:1}
.mcard-meta{font-size:12.5px;color:var(--faint);margin-top:6px}
.mcard-lg .mcard-name{font-size:19px}

/* ---------- detail ---------- */
.crumb{display:flex;align-items:center;gap:7px;flex-wrap:wrap;font-size:13.5px;color:var(--soft);margin:18px 0}
.crumb a:hover{color:var(--primary)}
.crumb span{color:var(--faint)}
.detail{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:clamp(18px,4vw,34px);position:relative;overflow:hidden}
.detail::before{content:"";position:absolute;top:0;left:0;right:0;height:6px;background:var(--c)}
.detail-head{display:grid;grid-template-columns:auto 1fr;gap:clamp(16px,3vw,28px);align-items:center}
.detail-ill{width:clamp(96px,18vw,150px);height:clamp(96px,18vw,150px);border-radius:24px;
  background:color-mix(in srgb,var(--c) 14%,#fff);display:grid;place-items:center;padding:18px}
.detail-cat a{font-weight:800;color:var(--c);font-size:14px}
.detail-title{font-size:clamp(26px,5vw,40px);margin:4px 0 6px}
.detail-one{color:var(--soft);font-size:clamp(15px,2.6vw,18px)}
.detail-badges{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.bdg{font-size:13px;font-weight:700;color:#fff;padding:6px 13px;border-radius:999px}
.bdg.ghost{background:#fff;color:var(--soft);border:1.5px solid var(--line)}
.bdg.ghost.link:hover{border-color:var(--primary);color:var(--primary)}
.detail-body{margin-top:22px;font-size:clamp(15px,2.5vw,17px);line-height:1.95}
.detail-body p{margin:0 0 16px}
.detail-body p:last-child{margin-bottom:0;color:var(--accent);font-weight:600;
  background:#f1f9f4;border-left:3px solid var(--accent);padding:12px 16px;border-radius:0 10px 10px 0;line-height:1.7}
.tagline{display:flex;flex-wrap:wrap;gap:7px;margin-top:20px;padding-top:18px;border-top:1px dashed var(--line)}
.tag{font-size:12.5px;color:var(--soft);background:var(--cream);padding:5px 11px;border-radius:999px}
.more-row{margin-top:14px}
.more-link{font-weight:700;color:var(--primary)}
.next-cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin:34px 0 10px}
.next-cta .btn-pick{width:auto;padding:14px 26px}

/* ---------- page hero (category/situation/calc) ---------- */
.page-hero{display:grid;grid-template-columns:auto 1fr;gap:clamp(14px,3vw,24px);align-items:center;
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:clamp(18px,3.5vw,30px);margin:8px 0 18px;position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;top:0;left:0;right:0;height:6px;background:var(--c)}
.page-hero-ill{width:clamp(80px,15vw,120px);height:clamp(80px,15vw,120px);border-radius:22px;
  background:color-mix(in srgb,var(--c) 14%,#fff);display:grid;place-items:center;padding:16px}
.page-hero h1{font-size:clamp(24px,4.5vw,34px)}
.page-hero p{color:var(--soft);margin-top:6px}
.pill-row{display:flex;flex-wrap:wrap;gap:8px;margin:6px 0 8px}
.pill{border:1.5px solid var(--line);background:#fff;color:var(--soft);font-weight:700;
  font-size:14px;padding:9px 16px;border-radius:999px;cursor:pointer;font-family:inherit;transition:.15s}
.pill:hover{border-color:var(--primary);color:var(--primary)}
.pill.on{background:var(--primary);color:#fff;border-color:var(--primary)}
.empty,.calc-note{color:var(--soft);text-align:center;padding:24px;font-size:14.5px}
.notfound{text-align:center;padding:80px 20px}
.notfound h1{font-size:28px;margin-bottom:10px}
.notfound p{color:var(--soft);margin-bottom:20px}

/* ---------- calculator ---------- */
.calc-panel{margin-top:6px}
.calc-panel[hidden]{display:none}
.calc-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:clamp(18px,4vw,30px)}
.calc-card h2{font-size:clamp(19px,3.4vw,24px)}
.calc-help{color:var(--soft);margin:6px 0 18px;font-size:14.5px}
.calc-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:18px}
.calc-grid .full{grid-column:1/-1}
.calc-grid label{display:flex;flex-direction:column;gap:6px;font-weight:700;font-size:14px;color:var(--soft)}
.calc-grid input,.calc-grid select{font-family:inherit;font-size:16px;color:var(--ink);
  border:1.5px solid var(--line);border-radius:12px;padding:12px 14px;background:#fff;width:100%}
.calc-grid input:focus,.calc-grid select:focus{outline:none;border-color:var(--primary)}
.calc-result{margin-top:18px;background:linear-gradient(135deg,#fff6f0,#fdf0e4);
  border:1px solid #f3d9c4;border-radius:var(--radius-sm);padding:20px;text-align:center}
.calc-result .big{font-size:clamp(30px,6vw,42px);font-weight:800;color:var(--primary);letter-spacing:-.02em}
.calc-result .sub{color:var(--soft);font-size:14px;margin-top:6px;line-height:1.7}
.calc-list{list-style:none;margin:0 0 6px;display:flex;flex-direction:column;gap:8px}
.calc-list li{display:flex;justify-content:space-between;align-items:center;background:var(--cream);
  border-radius:10px;padding:10px 14px;font-weight:600}
.calc-list button{border:0;background:none;color:var(--primary-d);cursor:pointer;font-weight:800;font-size:18px}

/* ---------- ad ---------- */
.ad-slot{margin:26px 0;min-height:100px;display:grid;place-items:center}
.ad-empty{background:repeating-linear-gradient(135deg,#f4eddf,#f4eddf 12px,#f0e7d6 12px,#f0e7d6 24px);
  border:1px dashed #ddd0bb;border-radius:14px;color:#b3a892;font-size:13px;font-weight:700;letter-spacing:.05em}

/* ---------- roulette ---------- */
.roulette{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:clamp(24px,5vw,44px)}
.rou-box{max-width:380px;margin:0 auto;text-align:center}
.rou-display{font-size:clamp(28px,6vw,40px);font-weight:800;letter-spacing:-.02em;
  min-height:80px;display:grid;place-items:center;background:var(--cream);border-radius:var(--radius-sm);
  margin-bottom:14px;color:var(--ink)}
.rou-display.spin{color:var(--faint)}
.btn-rou{max-width:200px;margin:0 auto}
.rou-go{display:inline-block;margin-top:14px;font-weight:800;color:var(--primary)}

/* ---------- footer ---------- */
.site-foot{background:#2a2520;color:#e9e1d4;margin-top:60px;padding:40px 0 30px}
.foot-top{display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-bottom:22px}
.foot-brand strong{font-size:19px}
.foot-brand p{color:#b7ad9c;font-size:14px;margin-top:6px;max-width:300px}
.foot-links{display:flex;flex-wrap:wrap;gap:8px 16px;align-content:flex-start}
.foot-links a{color:#cfc6b6;font-size:14px;font-weight:600}
.foot-links a:hover{color:#fff}
.copy{color:#8d8473;font-size:12.5px;border-top:1px solid #3a352d;padding-top:18px}

/* ---------- responsive ---------- */
@media (min-width:861px){.hero-art{display:block}}
@media (max-width:860px){
  .hero-in{grid-template-columns:1fr}
  .cat-grid{grid-template-columns:repeat(2,1fr)}
  .mcard-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:680px){
  .nav-toggle{display:flex}
  .site-nav{position:fixed;inset:62px 0 auto 0;flex-direction:column;background:var(--paper);
    border-bottom:1px solid var(--line);padding:10px 16px;gap:2px;
    transform:translateY(-130%);transition:transform .25s;box-shadow:var(--shadow-lg)}
  body.nav-open .site-nav{transform:translateY(0)}
  .site-nav a{padding:13px 8px;font-size:16px;border-radius:10px}
  .detail-head{grid-template-columns:1fr;text-align:center}
  .detail-ill{margin:0 auto}
  .detail-badges{justify-content:center}
  .page-hero{grid-template-columns:1fr;text-align:center}
  .page-hero-ill{margin:0 auto}
  .calc-grid{grid-template-columns:1fr}
  .foot-top{flex-direction:column}
}
@media (max-width:430px){
  .cat-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .mcard-grid{grid-template-columns:1fr 1fr;gap:10px}
  .mcard-thumb svg{width:64px;height:64px}
}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
