/* ===========================================================
   향촌흑염소 공주동학사점 — styles.css
   Concept: 산수화(sansuhwa) + 청자(celadon) — Donghaksa / Gyeryongsan mood.
   Distinct from govgoat (dark gold luxury) and goatduck (hanji wine).
   =========================================================== */

:root{
  --paper:#f7f3e9;
  --paper-deep:#efe7d4;
  --ink:#1a1f1c;
  --charcoal:#2a2520;
  --celadon:#6e9b8a;
  --celadon-d:#4f7263;
  --celadon-x:#3a5448;
  --bronze:#a17c3c;
  --bronze-l:#c8a25a;
  --bronze-x:#7a5b25;
  --cream:#f0e8d2;
  --moss:#5b7553;
  --shadow:rgba(36,42,38,.18);

  --serif:"Noto Serif KR","Nanum Myeongjo","Source Han Serif K",ui-serif,serif;
  --sans:"Pretendard","Apple SD Gothic Neo","Noto Sans KR",system-ui,-apple-system,"Segoe UI",sans-serif;
  --latin:"Cormorant Garamond","EB Garamond",Georgia,serif;

  --rule-w:1px;
  --rule:rgba(161,124,60,.32);
  --rule-soft:rgba(42,37,32,.10);

  --container:1240px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  line-height:1.7;
  font-weight:400;
  letter-spacing:-.005em;
  overflow-x:hidden;
  position:relative;
}

/* ---------- Sansuhwa paper texture (very subtle) ---------- */
body::before{
  content:"";
  position:fixed;inset:0;
  background:
    radial-gradient(900px 600px at 12% -8%, rgba(110,155,138,.08), transparent 60%),
    radial-gradient(700px 500px at 110% 10%, rgba(161,124,60,.07), transparent 65%),
    radial-gradient(1200px 800px at 50% 110%, rgba(42,37,32,.05), transparent 70%);
  pointer-events:none;z-index:0;
}
body::after{
  content:"";
  position:fixed;inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence baseFrequency='0.85' numOctaves='1' seed='3'/><feColorMatrix values='0 0 0 0 0.16  0 0 0 0 0.13  0 0 0 0 0.10  0 0 0 0.05 0'/></filter><rect width='240' height='240' filter='url(%23n)' opacity='0.55'/></svg>");
  pointer-events:none;mix-blend-mode:multiply;opacity:.45;z-index:0;
}

/* Anti-gravity ink-mist canvas */
#ag-canvas{
  position:fixed;inset:0;width:100%;height:100%;
  pointer-events:none;z-index:1;opacity:.55;
}

/* ---------- Layout primitives ---------- */
.wrap{max-width:var(--container);margin:0 auto;padding:0 28px;position:relative;z-index:2}
section{position:relative;z-index:2}
.eyebrow{
  font-family:var(--latin);font-style:italic;
  letter-spacing:.18em;font-size:13px;color:var(--celadon-d);
  text-transform:uppercase;margin-bottom:14px;
}
.eyebrow::before{
  content:"";display:inline-block;width:32px;height:1px;
  background:var(--bronze);vertical-align:middle;margin-right:12px;
}
h1,h2,h3,h4{font-family:var(--serif);color:var(--charcoal);font-weight:700;letter-spacing:-.01em}
h1{font-size:clamp(38px,6vw,76px);line-height:1.08}
h2{font-size:clamp(28px,3.4vw,46px);line-height:1.18;margin-bottom:18px}
h3{font-size:clamp(20px,2vw,26px);line-height:1.3}
p{font-size:16.5px;color:#34302b}

a{color:inherit;text-decoration:none;transition:color .25s}
a:hover{color:var(--bronze-x)}
img{max-width:100%;display:block}

/* ---------- Top bar ---------- */
.topbar{
  position:fixed;top:0;left:0;right:0;z-index:30;
  background:rgba(247,243,233,.0);
  backdrop-filter:blur(0);-webkit-backdrop-filter:blur(0);
  transition:background .35s,backdrop-filter .35s,border-color .35s;
  border-bottom:1px solid transparent;
}
.topbar.scrolled{
  background:rgba(247,243,233,.92);
  backdrop-filter:saturate(140%) blur(10px);
  -webkit-backdrop-filter:saturate(140%) blur(10px);
  border-bottom-color:var(--rule);
}
.topbar-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:74px;
}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--serif);font-weight:700}
.brand-mark{
  width:38px;height:38px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,var(--bronze-l),var(--bronze) 60%,var(--bronze-x));
  display:grid;place-items:center;color:var(--cream);
  font-size:18px;box-shadow:0 4px 14px rgba(161,124,60,.35);
  position:relative;
}
.brand-mark::before{
  content:"";position:absolute;inset:5px;border-radius:50%;
  background:var(--celadon-d);
}
.brand-mark span{position:relative;z-index:2}
.brand-name{font-size:16.5px;color:var(--charcoal);letter-spacing:.02em}
.brand-sub{font-family:var(--latin);font-style:italic;color:var(--celadon-d);font-size:12px;margin-left:6px;letter-spacing:.14em}
.nav{display:flex;gap:30px;align-items:center;font-size:14.5px}
.nav a{color:var(--charcoal);position:relative}
.nav a::after{
  content:"";position:absolute;left:0;right:100%;bottom:-6px;
  height:1px;background:var(--bronze);transition:right .35s ease;
}
.nav a:hover::after{right:0}
.nav-cta{
  padding:9px 18px;border:1px solid var(--bronze);color:var(--bronze-x);
  border-radius:999px;font-weight:600;letter-spacing:.04em;
  transition:background .25s,color .25s;
}
.nav-cta:hover{background:var(--bronze);color:var(--cream)}
.nav-toggle{display:none;background:none;border:0;color:var(--charcoal);font-size:22px;cursor:pointer}

/* ---------- Hero ---------- */
.hero{
  min-height:100vh;
  display:grid;grid-template-columns:1.1fr .9fr;gap:64px;
  align-items:center;
  padding:140px 28px 80px;
  max-width:var(--container);margin:0 auto;
  position:relative;
}
.hero::before{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(135deg, transparent 60%, rgba(110,155,138,.08));
  pointer-events:none;
}
.hero-meta{
  display:flex;gap:14px;align-items:center;
  font-family:var(--latin);font-style:italic;letter-spacing:.18em;
  color:var(--celadon-d);font-size:13px;text-transform:uppercase;
}
.hero-meta .dot{width:5px;height:5px;border-radius:50%;background:var(--bronze)}
.hero h1{margin:22px 0 8px;color:var(--charcoal)}
.hero h1 .accent{color:var(--bronze-x);font-style:normal}
.hero-deck{
  font-family:var(--serif);font-size:clamp(17px,1.6vw,21px);
  line-height:1.7;color:#3b3a36;margin:18px 0 30px;max-width:560px;
}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 26px;border-radius:999px;
  font-weight:600;letter-spacing:.03em;font-size:15px;
  transition:transform .35s,box-shadow .35s,background .25s,color .25s,border-color .25s;
  will-change:transform;
}
.btn-primary{
  background:var(--charcoal);color:var(--cream);
  box-shadow:0 8px 26px rgba(36,42,38,.28);
}
.btn-primary:hover{background:var(--celadon-x);transform:translateY(-2px);box-shadow:0 14px 34px rgba(58,84,72,.32);color:var(--cream)}
.btn-ghost{
  background:transparent;color:var(--charcoal);border:1px solid var(--bronze);
}
.btn-ghost:hover{background:var(--bronze);color:var(--cream);border-color:var(--bronze);transform:translateY(-2px)}
.btn .arrow{display:inline-block;transition:transform .25s}
.btn:hover .arrow{transform:translateX(4px)}

.hero-stats{
  margin-top:54px;display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border-top:1px solid var(--rule);padding-top:22px;max-width:560px;
}
.hero-stats > div + div{border-left:1px solid var(--rule-soft);padding-left:18px}
.hero-stats > div{padding-right:18px}
.stat-num{font-family:var(--latin);font-size:34px;color:var(--bronze-x);font-weight:600;line-height:1}
.stat-lbl{font-size:12.5px;color:#5e5a52;letter-spacing:.04em;margin-top:6px}

/* hero visual */
.hero-visual{position:relative;height:560px;}
.hv-frame{
  position:absolute;inset:auto;
  border:1px solid var(--bronze);border-radius:2px;
  overflow:hidden;box-shadow:0 28px 70px -20px rgba(36,42,38,.4);
}
.hv-1{top:0;left:8%;width:62%;height:62%;}
.hv-2{bottom:0;right:0;width:54%;height:48%;}
.hv-3{top:38%;right:18%;width:30%;height:30%;border-radius:50%;border:2px solid var(--bronze)}
.hv-frame img{width:100%;height:100%;object-fit:cover;transform:scale(1.04);transition:transform 1.2s}
.hv-frame:hover img{transform:scale(1.08)}
.hv-tag{
  position:absolute;left:-10px;top:18px;
  background:var(--celadon-x);color:var(--cream);
  font-size:11px;letter-spacing:.18em;padding:6px 14px;
  font-family:var(--latin);font-style:italic;
}

.hv-seal{
  position:absolute;left:-30px;bottom:30px;width:120px;height:120px;
  border-radius:50%;background:var(--paper);
  border:1px solid var(--bronze);
  display:grid;place-items:center;text-align:center;
  box-shadow:0 14px 30px -10px rgba(36,42,38,.25);
}
.hv-seal .ko{font-family:var(--serif);font-size:13px;color:var(--charcoal);line-height:1.5;letter-spacing:.06em}
.hv-seal .en{font-family:var(--latin);font-style:italic;font-size:11px;letter-spacing:.16em;color:var(--celadon-d);margin-top:6px}

/* hero brush mountains backdrop */
.hero-mountain{
  position:absolute;left:0;right:0;bottom:0;height:46%;z-index:0;pointer-events:none;
  opacity:.5;
}

/* ---------- Quote band ---------- */
.quote-band{
  background:var(--paper-deep);
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
  padding:64px 0;
  text-align:center;
}
.quote-band blockquote{
  font-family:var(--serif);font-size:clamp(22px,2.4vw,32px);
  line-height:1.65;max-width:880px;margin:0 auto;color:var(--charcoal);
  font-weight:500;letter-spacing:-.005em;
}
.quote-band .cite{
  margin-top:22px;font-family:var(--latin);font-style:italic;
  letter-spacing:.18em;color:var(--celadon-d);font-size:13px;text-transform:uppercase;
}
.quote-band .cite::before,.quote-band .cite::after{
  content:"";display:inline-block;width:42px;height:1px;background:var(--bronze);
  vertical-align:middle;margin:0 14px;
}

/* ---------- Section base ---------- */
.section{padding:120px 0;position:relative}
.section-head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;margin-bottom:60px;flex-wrap:wrap}
.section-head .lead{max-width:520px;color:#3b3a36;font-size:16.5px}

/* ---------- Pillars (3 고집) ---------- */
.pillars{background:var(--paper)}
.pillar-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.pillar{
  background:#fcfaf2;border:1px solid var(--rule-soft);
  border-radius:2px;padding:38px 32px;position:relative;
  transition:transform .5s ease,box-shadow .5s ease,border-color .5s ease;
}
.pillar:hover{transform:translateY(-6px);box-shadow:0 28px 60px -22px rgba(36,42,38,.25);border-color:var(--bronze)}
.pillar-num{
  font-family:var(--latin);font-size:48px;color:var(--bronze);
  line-height:1;display:block;margin-bottom:18px;font-weight:500;
}
.pillar-num::after{content:"";display:block;width:36px;height:1px;background:var(--bronze);margin-top:14px}
.pillar h3{margin:6px 0 14px}
.pillar p{font-size:15.5px;color:#3d3a35;line-height:1.7}
.pillar .tag{
  display:inline-block;font-family:var(--latin);font-style:italic;
  font-size:12px;letter-spacing:.18em;color:var(--celadon-d);
  margin-top:18px;text-transform:uppercase;
}

/* ---------- Story (방송 검증 / 잡내) ---------- */
.story{
  background:linear-gradient(180deg,var(--paper) 0%,var(--paper-deep) 100%);
  position:relative;overflow:hidden;
}
.story-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.story-art{position:relative;aspect-ratio:4/5;overflow:hidden;border:1px solid var(--rule)}
.story-art img{width:100%;height:100%;object-fit:cover;transform:scale(1.06)}
.story-art::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(170deg,transparent 50%,rgba(58,84,72,.2));
  pointer-events:none;
}
.story-art .seal-tl{
  position:absolute;left:-22px;top:24px;
  background:var(--cream);color:var(--charcoal);
  font-family:var(--serif);font-size:13.5px;
  padding:14px 22px;letter-spacing:.04em;
  border:1px solid var(--bronze);
  box-shadow:0 8px 22px rgba(36,42,38,.16);
}
.story-art .seal-br{
  position:absolute;right:24px;bottom:24px;
  background:var(--charcoal);color:var(--cream);
  font-family:var(--latin);font-style:italic;font-size:12px;letter-spacing:.18em;
  padding:8px 16px;text-transform:uppercase;
}
.story-body p{margin-bottom:18px}
.story-body p strong{color:var(--charcoal)}
.broadcast{
  margin-top:34px;padding:22px 24px;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);
  display:flex;gap:36px;align-items:center;flex-wrap:wrap;
}
.broadcast .label{font-family:var(--latin);font-style:italic;letter-spacing:.18em;font-size:11.5px;color:var(--celadon-d);text-transform:uppercase}
.broadcast .item{font-family:var(--serif);font-size:15px;color:var(--charcoal)}
.broadcast .item span{color:var(--bronze);margin:0 6px}

/* ---------- Menu paper-frame ---------- */
.menu{background:var(--paper-deep)}
.menu-wrap{
  background:var(--paper);
  border:1px solid var(--rule);
  padding:60px 60px 48px;position:relative;
  box-shadow:0 30px 80px -30px rgba(36,42,38,.2);
}
.menu-wrap::before,.menu-wrap::after{
  content:"";position:absolute;width:18px;height:18px;border:1px solid var(--bronze);
}
.menu-wrap::before{left:14px;top:14px;border-right:0;border-bottom:0}
.menu-wrap::after{right:14px;bottom:14px;border-left:0;border-top:0}
.menu-head{text-align:center;border-bottom:1px solid var(--rule);padding-bottom:28px;margin-bottom:36px}
.menu-head .ko{font-family:var(--serif);font-size:32px;color:var(--charcoal);margin-bottom:6px;letter-spacing:.08em}
.menu-head .en{font-family:var(--latin);font-style:italic;letter-spacing:.22em;color:var(--celadon-d);font-size:13px;text-transform:uppercase}
.menu-grid{display:grid;grid-template-columns:1fr 1fr;gap:38px 60px}
.menu-row{
  display:grid;grid-template-columns:64px 1fr;gap:22px;align-items:flex-start;
  padding-bottom:18px;border-bottom:1px dotted var(--rule-soft);
}
.menu-row .thumb{
  width:64px;height:64px;border-radius:50%;
  background:var(--paper-deep) center/cover no-repeat;
  border:1px solid var(--bronze);
}
.menu-row .name{font-family:var(--serif);font-size:18px;color:var(--charcoal);font-weight:600;margin-bottom:4px}
.menu-row .desc{font-size:13.8px;color:#5e5a52;line-height:1.55}
.menu-foot{
  text-align:center;margin-top:30px;font-size:13px;color:#5e5a52;
  font-family:var(--latin);font-style:italic;letter-spacing:.16em;
}

/* ---------- Audience (이런 분들께 추천) ---------- */
.audience{
  background:var(--celadon-x);color:var(--cream);
  padding:120px 0;position:relative;overflow:hidden;
}
.audience::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(800px 500px at 90% -10%, rgba(161,124,60,.18), transparent 60%),
    radial-gradient(700px 600px at -10% 110%, rgba(247,243,233,.06), transparent 60%);
  pointer-events:none;
}
.audience .eyebrow{color:var(--bronze-l)}
.audience .eyebrow::before{background:var(--bronze-l)}
.audience h2{color:var(--cream)}
.aud-list{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:46px}
.aud-card{
  border:1px solid rgba(247,243,233,.18);
  background:rgba(0,0,0,.12);
  padding:32px 28px;
  transition:transform .5s ease,background .35s,border-color .35s;
}
.aud-card:hover{transform:translateY(-6px);background:rgba(0,0,0,.22);border-color:var(--bronze-l)}
.aud-card .num{font-family:var(--latin);font-style:italic;color:var(--bronze-l);font-size:14px;letter-spacing:.22em;margin-bottom:14px;text-transform:uppercase}
.aud-card h3{color:var(--cream);font-size:21px;margin-bottom:12px;line-height:1.4}
.aud-card p{color:rgba(247,243,233,.78);font-size:15px;line-height:1.7}

/* ---------- Gallery masonry ---------- */
.gallery{background:var(--paper)}
.masonry{column-count:4;column-gap:18px}
.masonry .cell{
  break-inside:avoid;margin:0 0 18px;overflow:hidden;
  position:relative;border:1px solid var(--rule-soft);
  background:var(--paper-deep);
}
.masonry .cell img{width:100%;height:auto;display:block;transition:transform 1s ease}
.masonry .cell:hover img{transform:scale(1.06)}
.masonry .cell::after{
  content:"";position:absolute;inset:auto 0 0 0;height:34%;
  background:linear-gradient(180deg,transparent,rgba(36,42,38,.3));
  opacity:0;transition:opacity .35s;
}
.masonry .cell:hover::after{opacity:1}
@media (max-width:1100px){.masonry{column-count:3}}
@media (max-width:780px){.masonry{column-count:2}}
@media (max-width:520px){.masonry{column-count:1}}

/* ---------- Info & map ---------- */
.info{background:var(--paper-deep)}
.info-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:flex-start}
.info-list{display:grid;gap:0;border-top:1px solid var(--rule)}
.info-item{
  display:grid;grid-template-columns:160px 1fr;gap:24px;align-items:flex-start;
  padding:22px 0;border-bottom:1px solid var(--rule-soft);
}
.info-item .k{
  font-family:var(--latin);font-style:italic;letter-spacing:.18em;
  color:var(--celadon-d);font-size:12.5px;text-transform:uppercase;padding-top:4px;
}
.info-item .k em{
  display:block;font-style:normal;font-family:var(--serif);
  font-size:15px;color:var(--charcoal);letter-spacing:0;margin-top:4px;
}
.info-item .v{font-size:15.5px;line-height:1.7;color:#34302b}
.info-item .v strong{color:var(--charcoal)}
.hours{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;margin-top:8px;font-size:13px}
.hours .day{padding:10px 6px;background:#fcfaf2;border:1px solid var(--rule-soft);text-align:center;border-radius:2px}
.hours .day .d{font-family:var(--serif);color:var(--charcoal);font-weight:600;display:block;margin-bottom:4px}
.hours .day .t{color:#5e5a52;font-size:12.5px}
.hours .day.off{background:var(--celadon);color:var(--cream)}
.hours .day.off .d,.hours .day.off .t{color:var(--cream)}

.map-card{position:sticky;top:96px}
.map-card .map-frame{
  width:100%;aspect-ratio:4/5;background:#dad3bf url("assets/img/web/p10.jpg") center/cover;
  border:1px solid var(--rule);position:relative;overflow:hidden;
}
.map-card .map-frame::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(14,26,20,0) 30%,rgba(14,26,20,.6));
  pointer-events:none;
}
.map-card .map-info{
  position:absolute;left:24px;right:24px;bottom:24px;color:var(--cream);
}
.map-card .map-info h3{color:var(--cream);font-size:22px;margin-bottom:10px}
.map-card .map-info p{color:rgba(247,243,233,.85);font-size:14.5px;margin-bottom:14px;line-height:1.55}
.map-card .map-info .btn{padding:10px 18px;font-size:13.5px}

/* ---------- CTA ---------- */
.cta{
  background:var(--charcoal);color:var(--cream);text-align:center;
  padding:120px 0;position:relative;overflow:hidden;
}
.cta::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(700px 360px at 50% -10%, rgba(161,124,60,.22), transparent 60%),
    radial-gradient(500px 360px at 50% 110%, rgba(110,155,138,.16), transparent 60%);
}
.cta .wrap{position:relative;z-index:2}
.cta h2{color:var(--cream);font-size:clamp(30px,3.4vw,46px)}
.cta .lede{color:rgba(247,243,233,.78);font-size:17px;max-width:640px;margin:18px auto 36px}
.cta .phone{
  font-family:var(--latin);font-size:clamp(40px,5vw,68px);font-weight:600;
  letter-spacing:.04em;color:var(--bronze-l);display:inline-block;margin-bottom:18px;
}
.cta .phone:hover{color:var(--cream)}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.cta .btn-primary{background:var(--bronze);color:var(--charcoal)}
.cta .btn-primary:hover{background:var(--bronze-l);color:var(--charcoal)}

/* ---------- Footer ---------- */
.footer{background:var(--ink);color:rgba(247,243,233,.7);padding:64px 0 44px;font-size:13.5px}
.footer-top{
  display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:48px;
  padding-bottom:32px;border-bottom:1px solid rgba(247,243,233,.08);
}
.footer .brand{color:var(--cream);font-size:18px;margin-bottom:14px}
.footer .brand-name{color:var(--cream)}
.footer p{color:rgba(247,243,233,.66);font-size:13.5px;line-height:1.8}
.footer h4{color:var(--cream);font-size:14px;letter-spacing:.16em;text-transform:uppercase;
  font-family:var(--latin);font-style:italic;margin-bottom:14px;font-weight:500;
}
.footer a{color:rgba(247,243,233,.78)}
.footer a:hover{color:var(--bronze-l)}
.footer ul{list-style:none}
.footer li{margin-bottom:8px}
.footer-bot{padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;color:rgba(247,243,233,.45);font-size:12.5px}
.footer-bot .biz{display:flex;gap:18px;flex-wrap:wrap}

/* ---------- Anti-gravity reveal ---------- */
.ag-rise{
  opacity:0;transform:translateY(28px) rotate(.4deg);
  transition:opacity 1s ease,transform 1.1s cubic-bezier(.2,.7,.2,1);
  will-change:opacity,transform;
}
.ag-rise.in{opacity:1;transform:translateY(0) rotate(0)}
.ag-rise.delay-1{transition-delay:.12s}
.ag-rise.delay-2{transition-delay:.24s}
.ag-rise.delay-3{transition-delay:.36s}
.ag-rise.delay-4{transition-delay:.48s}

/* float bobbing for floating elements */
.float-card{animation:agBob 7s ease-in-out infinite}
.float-card.alt{animation-duration:9s;animation-delay:-3s}
@keyframes agBob{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-10px)}
}

/* parallax-ish slow drift on hero seal */
.hv-seal{animation:agDrift 11s ease-in-out infinite}
@keyframes agDrift{
  0%,100%{transform:translateY(0) rotate(0)}
  50%{transform:translateY(-6px) rotate(-1.5deg)}
}

/* ---------- Responsive ---------- */
@media (max-width:1080px){
  .hero{grid-template-columns:1fr;gap:40px;padding-top:120px}
  .hero-visual{height:480px;max-width:560px}
  .pillar-grid{grid-template-columns:1fr 1fr}
  .menu-grid{grid-template-columns:1fr}
  .story-grid{grid-template-columns:1fr;gap:50px}
  .info-grid{grid-template-columns:1fr;gap:40px}
  .map-card{position:static}
  .aud-list{grid-template-columns:1fr 1fr}
  .footer-top{grid-template-columns:1fr 1fr}
}
@media (max-width:720px){
  h1{font-size:42px}
  .nav{display:none}
  .nav-toggle{display:block}
  .nav.open{
    display:flex;flex-direction:column;gap:18px;
    position:absolute;top:74px;left:0;right:0;background:var(--paper);
    padding:24px 28px;border-bottom:1px solid var(--rule);
  }
  .pillar-grid{grid-template-columns:1fr}
  .aud-list{grid-template-columns:1fr}
  .menu-wrap{padding:36px 24px}
  .hero-visual{height:420px}
  .hv-1{width:74%}
  .hv-2{width:62%}
  .hours{grid-template-columns:repeat(7,minmax(60px,1fr));overflow-x:auto;font-size:11.5px}
  .info-item{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr}
  .section{padding:80px 0}
  .menu-head .ko{font-size:24px}
  .quote-band{padding:48px 0}
  .quote-band blockquote{font-size:20px}
}

/* a11y */
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);margin:-1px;padding:0;border:0;white-space:nowrap}
.skip{position:absolute;left:-9999px}
.skip:focus{left:14px;top:14px;background:var(--charcoal);color:var(--cream);padding:10px 14px;z-index:99}

@media (prefers-reduced-motion:reduce){
  *{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
  .ag-rise{opacity:1;transform:none}
  #ag-canvas{display:none}
}
/* ===========================================================
   Article pages (/info/) — long-form reading layout.
   Appended to assets/styles.css.
   =========================================================== */

/* breadcrumb */
.crumb{padding:96px 0 0;font-size:13px;color:#5e5a52;font-family:var(--latin);font-style:italic;letter-spacing:.14em}
.crumb .wrap{padding-top:18px;padding-bottom:18px}
.crumb a{color:var(--celadon-d)}
.crumb a:hover{color:var(--bronze-x)}
.crumb .sep{margin:0 10px;color:var(--rule)}
.crumb [aria-current]{color:var(--charcoal);font-style:normal}

/* topbar nav active */
.nav a.is-active{color:var(--bronze-x);font-weight:600}
.nav a.is-active::after{right:0}

/* ---------- Article hero ---------- */
.post-hero{
  position:relative;padding:46px 0 64px;
  border-bottom:1px solid var(--rule);
  background:linear-gradient(180deg,var(--paper) 0%, var(--paper-deep) 100%);
}
.post-hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
.post-hero .kicker{
  font-family:var(--latin);font-style:italic;letter-spacing:.18em;
  color:var(--bronze-x);text-transform:uppercase;font-size:13px;margin-bottom:14px;
}
.post-hero .kicker::before{
  content:"";display:inline-block;width:32px;height:1px;background:var(--bronze);
  vertical-align:middle;margin-right:12px;
}
.post-hero h1{
  font-size:clamp(34px,5vw,58px);line-height:1.18;color:var(--charcoal);margin-bottom:18px;
  letter-spacing:-.01em;
}
.post-hero .lead{
  font-family:var(--serif);font-size:clamp(16.5px,1.4vw,19px);
  color:#3b3a36;line-height:1.75;max-width:560px;
}
.post-hero .meta{
  margin-top:26px;padding-top:22px;border-top:1px solid var(--rule);
  display:flex;gap:26px;flex-wrap:wrap;font-size:13.5px;color:#5e5a52;
  font-family:var(--latin);font-style:italic;letter-spacing:.14em;
}
.post-hero .meta strong{color:var(--charcoal);font-style:normal;font-family:var(--sans);font-weight:600;letter-spacing:0;margin-left:8px}
.post-hero .hero-frame{
  position:relative;aspect-ratio:4/5;overflow:hidden;border:1px solid var(--bronze);
  box-shadow:0 30px 70px -20px rgba(36,42,38,.32);
}
.post-hero .hero-frame img{width:100%;height:100%;object-fit:cover;transform:scale(1.05);transition:transform 1.4s ease}
.post-hero .hero-frame:hover img{transform:scale(1.1)}
.post-hero .hero-frame .seal{
  position:absolute;left:-22px;top:24px;
  background:var(--cream);color:var(--charcoal);
  font-family:var(--serif);font-size:13.5px;
  padding:12px 20px;letter-spacing:.04em;border:1px solid var(--bronze);
  box-shadow:0 8px 22px rgba(36,42,38,.16);
}
.post-hero .hero-frame .stamp{
  position:absolute;right:24px;bottom:24px;
  background:var(--charcoal);color:var(--cream);
  font-family:var(--latin);font-style:italic;font-size:11.5px;letter-spacing:.18em;
  padding:8px 14px;text-transform:uppercase;
}

/* ---------- Article body ---------- */
.post{position:relative;z-index:2}
.post-body{
  display:grid;grid-template-columns:240px 1fr;gap:64px;
  padding:80px 0 100px;
}
.post-body .toc{
  position:sticky;top:96px;align-self:start;
  border-top:1px solid var(--rule);padding-top:18px;
  font-family:var(--latin);font-style:italic;letter-spacing:.16em;
  font-size:12.5px;color:var(--celadon-d);text-transform:uppercase;
}
.post-body .toc h4{
  font-family:var(--latin);font-weight:500;
  font-size:12.5px;color:var(--celadon-d);letter-spacing:.18em;
  text-transform:uppercase;margin-bottom:14px;
}
.post-body .toc ol{list-style:none;counter-reset:toc;display:grid;gap:9px}
.post-body .toc li{counter-increment:toc;line-height:1.5}
.post-body .toc li::before{
  content:counter(toc,decimal-leading-zero);
  font-family:var(--latin);color:var(--bronze);margin-right:10px;font-style:normal;
}
.post-body .toc a{
  color:var(--charcoal);font-style:normal;font-family:var(--sans);
  font-size:13.5px;letter-spacing:0;
}
.post-body .toc a:hover{color:var(--bronze-x)}

.post-body .body{max-width:760px}
.post-body .body p{
  font-size:17px;line-height:1.85;color:#2e2b27;margin-bottom:22px;
  word-break:keep-all;
}
.post-body .body p:first-of-type::first-letter{
  font-family:var(--serif);font-weight:700;font-size:64px;line-height:.9;
  float:left;margin:6px 12px 0 0;color:var(--bronze-x);
}
.post-body .body h2{
  font-size:clamp(24px,2.4vw,30px);line-height:1.3;
  margin:54px 0 18px;padding-top:26px;border-top:1px solid var(--rule-soft);
  color:var(--charcoal);
}
.post-body .body h2 .num{
  display:inline-block;font-family:var(--latin);font-style:italic;
  color:var(--bronze);font-size:15px;letter-spacing:.18em;
  vertical-align:middle;margin-right:14px;text-transform:uppercase;
}
.post-body .body h3{
  font-size:20px;line-height:1.4;margin:30px 0 12px;color:var(--charcoal);
}
.post-body .body strong{color:var(--charcoal);font-weight:600}
.post-body .body em{font-style:italic;color:var(--celadon-x)}
.post-body .body ul,.post-body .body ol{
  margin:0 0 26px 18px;padding-left:8px;
}
.post-body .body ul li,.post-body .body ol li{
  font-size:16.5px;line-height:1.85;color:#2e2b27;margin-bottom:8px;word-break:keep-all;
}
.post-body .body ul li{list-style:none;position:relative;padding-left:18px}
.post-body .body ul li::before{
  content:"";position:absolute;left:0;top:13px;width:8px;height:1px;background:var(--bronze);
}
.post-body .body ol{list-style:decimal-leading-zero;counter-reset:lst}
.post-body .body ol li::marker{font-family:var(--latin);color:var(--bronze)}
.post-body .body blockquote{
  margin:32px 0;padding:24px 28px;
  background:var(--paper-deep);border-left:3px solid var(--bronze);
  font-family:var(--serif);font-size:18px;line-height:1.7;color:var(--charcoal);
}
.post-body .body blockquote p:last-child{margin-bottom:0}
.post-body .body blockquote .src{
  display:block;margin-top:10px;font-family:var(--latin);font-style:italic;
  font-size:13px;color:var(--celadon-d);letter-spacing:.14em;
}
.post-body .body .pullquote{
  display:block;margin:36px auto;padding:34px 30px;
  border-top:1px solid var(--bronze);border-bottom:1px solid var(--bronze);
  text-align:center;font-family:var(--serif);font-size:clamp(20px,2.2vw,26px);
  line-height:1.6;color:var(--charcoal);max-width:720px;font-weight:500;
}
.post-body .body .callout{
  margin:32px 0;padding:24px 26px;background:#fcfaf2;
  border:1px solid var(--rule);border-radius:2px;
}
.post-body .body .callout h3{margin:0 0 8px;font-size:17px;color:var(--celadon-x)}
.post-body .body .callout p{font-size:15.5px;color:#3d3a35;margin-bottom:8px}
.post-body .body .callout p:last-child{margin-bottom:0}
.post-body .body figure{margin:30px 0}
.post-body .body figure img{border:1px solid var(--rule);max-width:100%}
.post-body .body figcaption{margin-top:10px;font-size:13.5px;color:#5e5a52;font-family:var(--latin);font-style:italic;letter-spacing:.12em;text-align:center}
.post-body .body table{
  width:100%;border-collapse:collapse;margin:28px 0;font-size:15px;
  border-top:1px solid var(--bronze);border-bottom:1px solid var(--bronze);
}
.post-body .body th,.post-body .body td{
  padding:14px 12px;text-align:left;border-bottom:1px solid var(--rule-soft);vertical-align:top;
}
.post-body .body th{
  background:var(--paper-deep);font-family:var(--serif);font-weight:600;color:var(--charcoal);letter-spacing:.02em;
}
.post-body .body .ref{
  margin-top:46px;padding-top:22px;border-top:1px solid var(--rule);
  font-size:13.5px;color:#5e5a52;
}
.post-body .body .ref strong{display:block;margin-bottom:8px;font-family:var(--latin);font-style:italic;letter-spacing:.16em;color:var(--celadon-d);text-transform:uppercase;font-weight:500}
.post-body .body .tags{margin-top:34px;display:flex;flex-wrap:wrap;gap:8px}
.post-body .body .tags a{
  padding:6px 12px;border:1px solid var(--rule);background:var(--paper);
  font-size:12.5px;color:#5e5a52;letter-spacing:.02em;border-radius:999px;
}
.post-body .body .tags a:hover{border-color:var(--bronze);color:var(--bronze-x)}

/* ---------- Related ---------- */
.related{padding:90px 0;background:var(--paper-deep);border-top:1px solid var(--rule)}
.related h2{margin-bottom:30px;font-size:clamp(24px,2.4vw,32px)}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.related-card{
  background:var(--paper);border:1px solid var(--rule-soft);
  display:flex;flex-direction:column;overflow:hidden;
  transition:transform .5s ease,box-shadow .5s ease,border-color .5s ease;
  color:var(--charcoal);
}
.related-card:hover{transform:translateY(-6px);box-shadow:0 26px 60px -22px rgba(36,42,38,.25);border-color:var(--bronze);color:var(--charcoal)}
.related-card .rc-img{aspect-ratio:5/3;background:#dcd6c4 center/cover}
.related-card .rc-body{padding:24px 24px 26px}
.related-card .rc-kicker{
  font-family:var(--latin);font-style:italic;letter-spacing:.18em;
  color:var(--celadon-d);font-size:12px;text-transform:uppercase;margin-bottom:10px;
}
.related-card h3{font-size:18.5px;line-height:1.4;margin-bottom:14px;color:var(--charcoal)}
.related-card .rc-more{font-size:13px;color:var(--bronze-x);font-weight:600;letter-spacing:.04em}
.related-card .rc-more .arrow{display:inline-block;transition:transform .25s}
.related-card:hover .rc-more .arrow{transform:translateX(4px)}

/* ---------- Article CTA band ---------- */
.post-cta{
  background:var(--charcoal);color:var(--cream);text-align:center;
  padding:90px 0;position:relative;overflow:hidden;
}
.post-cta::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(700px 360px at 50% -10%, rgba(161,124,60,.20), transparent 60%),
    radial-gradient(500px 360px at 50% 110%, rgba(110,155,138,.14), transparent 60%);
}
.post-cta .wrap{position:relative;z-index:2}
.post-cta .eyebrow{color:var(--bronze-l)}
.post-cta .eyebrow::before{background:var(--bronze-l)}
.post-cta h2{color:var(--cream);font-size:clamp(26px,3vw,38px)}
.post-cta p{color:rgba(247,243,233,.78);font-size:16px;max-width:600px;margin:14px auto 26px}
.post-cta .phone{
  font-family:var(--latin);font-size:clamp(34px,4vw,52px);font-weight:600;
  letter-spacing:.04em;color:var(--bronze-l);display:inline-block;margin-bottom:18px;
}
.post-cta .phone:hover{color:var(--cream)}
.post-cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.post-cta .btn-primary{background:var(--bronze);color:var(--charcoal)}
.post-cta .btn-primary:hover{background:var(--bronze-l);color:var(--charcoal)}
.post-cta .btn-ghost{color:var(--cream);border-color:var(--bronze-l)}

/* ---------- Category index ---------- */
.cat-hero{
  padding:140px 0 70px;
  background:linear-gradient(180deg,var(--paper) 0%,var(--paper-deep) 100%);
  border-bottom:1px solid var(--rule);
  text-align:center;
}
.cat-hero .eyebrow{justify-content:center;margin-bottom:18px}
.cat-hero h1{font-size:clamp(34px,5vw,60px);margin-bottom:14px}
.cat-hero p{font-family:var(--serif);font-size:clamp(16px,1.4vw,19px);color:#3b3a36;max-width:680px;margin:0 auto;line-height:1.75}

.cat-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:28px;
  padding:80px 0 100px;
}
.cat-card{
  background:#fcfaf2;border:1px solid var(--rule-soft);overflow:hidden;
  display:flex;flex-direction:column;color:var(--charcoal);
  transition:transform .5s ease,box-shadow .5s ease,border-color .5s ease;
  position:relative;
}
.cat-card::before{
  content:attr(data-num);
  position:absolute;left:18px;top:14px;z-index:3;
  font-family:var(--latin);font-style:italic;color:var(--cream);
  background:var(--bronze);padding:4px 12px;font-size:12.5px;letter-spacing:.18em;
}
.cat-card:hover{transform:translateY(-8px);box-shadow:0 30px 70px -22px rgba(36,42,38,.28);border-color:var(--bronze);color:var(--charcoal)}
.cat-card .img{aspect-ratio:5/3;background:#dcd6c4 center/cover;position:relative}
.cat-card .img::after{
  content:"";position:absolute;inset:auto 0 0 0;height:50%;
  background:linear-gradient(180deg,transparent,rgba(36,42,38,.18));
}
.cat-card .body{padding:28px 26px 30px;display:flex;flex-direction:column;flex:1}
.cat-card .kicker{
  font-family:var(--latin);font-style:italic;letter-spacing:.18em;
  color:var(--celadon-d);font-size:12px;text-transform:uppercase;margin-bottom:12px;
}
.cat-card h2{
  font-size:22px;line-height:1.4;margin-bottom:14px;color:var(--charcoal);
}
.cat-card .desc{font-size:14.5px;line-height:1.7;color:#5e5a52;margin-bottom:22px;flex:1}
.cat-card .more{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:14px;border-top:1px solid var(--rule-soft);
  font-size:13px;color:var(--bronze-x);font-weight:600;letter-spacing:.04em;
}
.cat-card .more .read{color:#7a766f;font-weight:400;font-family:var(--latin);font-style:italic;letter-spacing:.14em}
.cat-card .more .arrow{display:inline-block;transition:transform .25s}
.cat-card:hover .more .arrow{transform:translateX(4px)}

/* ---------- Responsive ---------- */
@media (max-width:1080px){
  .post-hero .wrap{grid-template-columns:1fr;gap:40px}
  .post-hero .hero-frame{max-width:520px}
  .post-body{grid-template-columns:1fr;gap:30px;padding-top:50px}
  .post-body .toc{position:static;display:block;margin-bottom:14px;border-top:0;padding-top:0;border-left:1px solid var(--rule);padding-left:18px}
  .related-grid{grid-template-columns:1fr 1fr}
  .cat-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:720px){
  .post-hero{padding:30px 0 40px}
  .post-hero h1{font-size:30px}
  .post-body{padding:40px 0 60px}
  .post-body .body p{font-size:16px}
  .post-body .body p:first-of-type::first-letter{font-size:48px}
  .related,.post-cta{padding:60px 0}
  .related-grid,.cat-grid{grid-template-columns:1fr}
  .crumb{padding-top:80px;font-size:12px}
}
