/* ===== Gold Raccoon — Classic Gold Luxury (custom frame) ===== */
:root{
  --gr-bg:#09090B; --gr-bg2:#121116; --gr-bg3:#17151B; --gr-band:#060608;
  --gr-line:rgba(201,162,75,.28); --gr-line2:rgba(255,255,255,.07);
  --gr-gold:#C9A24B; --gr-gold-b:#E8CD85; --gr-gold-d:#9C7A2E;
  --gr-white:#F4F1E9; --gr-mut:#9A938460; --gr-mut2:#9A9384; --gr-ink:#12100A;
  --gr-kakao:#FAE100; --gr-kakao-ink:#3A1D1D; --gr-tele:#27A7E7;
  --gr-radius:6px; --gr-radius-s:4px;
  --gr-shadow:0 18px 50px rgba(0,0,0,.5); --gr-shadow-h:0 28px 70px rgba(0,0,0,.66);
  --gr-display:'Playfair Display',serif; --gr-serif:'Noto Serif KR',serif; --gr-sans:'Pretendard','Noto Sans KR',system-ui,sans-serif;
}
*{box-sizing:border-box;}
html,body{ margin:0; }
body,.gr-body{ background:var(--gr-bg) !important; color:var(--gr-white); font-family:var(--gr-sans); line-height:1.85; letter-spacing:-.005em; }
/* neutralize any astra leftovers */
#page,.site,.site-content,.ast-container,.entry-content,#content{ background:transparent !important; max-width:none !important; padding:0 !important; margin:0 !important; }
img{max-width:100%;height:auto;}
a{ color:var(--gr-gold-b); text-decoration:none; }
h1,h2,h3{ font-family:var(--gr-serif); font-weight:700; color:var(--gr-white); line-height:1.4; letter-spacing:-.01em; }
.gr-wrap{ max-width:1160px; margin:0 auto; padding:0 24px; }

/* ===== top gold line + header ===== */
.gr-topline{ height:3px; background:linear-gradient(90deg,var(--gr-gold-d),var(--gr-gold-b),var(--gr-gold-d)); }
.gr-header{ position:sticky; top:0; z-index:1000; background:rgba(6,6,8,.92); backdrop-filter:blur(10px); border-bottom:1px solid var(--gr-line); }
.gr-header__inner{ display:flex; align-items:center; justify-content:space-between; height:92px; }
.gr-logo{ display:flex; align-items:center; gap:10px; }
.gr-logo__img{ height:66px; width:auto; display:block; filter:drop-shadow(0 3px 12px rgba(201,162,75,.28)); transition:filter .2s; }
.gr-logo:hover .gr-logo__img{ filter:drop-shadow(0 4px 16px rgba(232,205,133,.45)); }
.gr-logo__mascot{ width:44px; height:44px; object-fit:contain; filter:drop-shadow(0 2px 8px rgba(201,162,75,.35)); }
.gr-logo__wm{ font-family:var(--gr-display); font-size:1.32rem; font-weight:700; letter-spacing:.18em; color:var(--gr-white); }
.gr-logo__wm em{ font-style:normal; color:var(--gr-gold-b); }
.gr-nav{ display:flex; align-items:center; gap:30px; }
.gr-menu{ display:flex; align-items:center; gap:26px; list-style:none; margin:0; padding:0; }
.gr-menu a{ font-family:var(--gr-sans); font-size:.9rem; font-weight:600; letter-spacing:.04em; color:var(--gr-white); padding:6px 0; position:relative; transition:color .2s; }
.gr-menu a::after{ content:""; position:absolute; left:0; right:100%; bottom:-2px; height:1px; background:var(--gr-gold-b); transition:right .25s; }
.gr-menu a:hover{ color:var(--gr-gold-b); } .gr-menu a:hover::after{ right:0; }
.gr-menu .current-menu-item > a{ color:var(--gr-gold-b); }
.gr-header__cta{ font-family:var(--gr-sans); font-size:.84rem; font-weight:700; letter-spacing:.05em; color:var(--gr-ink); background:linear-gradient(135deg,var(--gr-gold-b),var(--gr-gold-d)); padding:9px 20px; border-radius:var(--gr-radius-s); transition:filter .2s, transform .2s; }
.gr-header__cta:hover{ filter:brightness(1.06); transform:translateY(-1px); }
.gr-navtoggle{ display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:6px; }
.gr-navtoggle span{ width:24px; height:2px; background:var(--gr-gold-b); transition:.25s; }
.gr-main{ display:block; }

/* ===== section heading (classic centered ornament) ===== */
.gr-eyebrow{ display:block; font-family:var(--gr-sans); font-size:.72rem; font-weight:700; letter-spacing:.34em; text-transform:uppercase; color:var(--gr-gold-b); }
.gr-h{ text-align:center; font-size:1.85rem; font-weight:700; margin:3.4rem 0 .4rem; }
.gr-h::after{ content:"◆"; display:block; color:var(--gr-gold); font-size:.62rem; letter-spacing:.5em; margin:.8rem auto 0; opacity:.9; }
.gr-sub{ text-align:center; color:var(--gr-mut2); margin:.4rem auto 1.8rem; font-size:.98rem; max-width:680px; }

/* diamond divider */
.gr-rule-c{ display:flex; align-items:center; justify-content:center; gap:14px; margin:1.2rem auto 0; max-width:240px; }
.gr-rule-c::before,.gr-rule-c::after{ content:""; height:1px; flex:1; background:linear-gradient(90deg,transparent,var(--gr-gold)); }
.gr-rule-c::after{ background:linear-gradient(90deg,var(--gr-gold),transparent); }
.gr-rule-c i{ color:var(--gr-gold-b); font-style:normal; font-size:.7rem; }

/* ===== hero band (full-bleed) ===== */
.gr-banner{ width:100%; background:radial-gradient(120% 130% at 50% -10%, #1E1A10 0%, #0B0A0C 60%); border-bottom:1px solid var(--gr-line); padding:88px 24px 78px; position:relative; }
.gr-banner::before{ content:""; position:absolute; top:0; left:50%; transform:translateX(-50%); width:46%; height:1px; background:linear-gradient(90deg,transparent,var(--gr-gold-b),transparent); }
.gr-banner__in{ text-align:center; }
.gr-banner .gr-mascot{ width:248px; max-width:80%; height:auto; display:inline-block; filter:drop-shadow(0 10px 30px rgba(201,162,75,.4)); }
.gr-banner h1{ font-family:var(--gr-serif); font-size:2.7rem; font-weight:700; margin:.6rem 0 0; }
.gr-banner .gr-banner__latin{ font-family:var(--gr-display); font-size:1rem; letter-spacing:.4em; text-transform:uppercase; color:var(--gr-gold-b); margin:0; }
.gr-banner p{ color:#CFC7B5; max-width:680px; margin:1.4rem auto 0; font-size:1.04rem; }
.gr-banner .gr-banner__cta{ margin-top:26px; display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }

/* ===== badges ===== */
.gr-badge{ display:inline-block; font-family:var(--gr-sans); font-size:.66rem; font-weight:700; letter-spacing:.12em; padding:4px 11px; border-radius:2px; text-transform:uppercase; }
.gr-badge--live{ background:linear-gradient(135deg,var(--gr-gold-b),var(--gr-gold-d)); color:var(--gr-ink); }
.gr-badge--elec{ background:transparent; color:var(--gr-gold-b); border:1px solid var(--gr-line); }
.gr-badge--closed{ background:rgba(255,255,255,.05); color:#C98C84; border:1px solid rgba(255,255,255,.08); }

/* ===== photo placeholder ===== */
.gr-photo{ position:relative; width:100%; aspect-ratio:16/9; background:linear-gradient(160deg,#1A1812,#0C0B0D); display:flex; align-items:center; justify-content:center; overflow:hidden; }
.gr-photo::before{ content:""; position:absolute; inset:14px; border:1px solid var(--gr-line); }
.gr-photo::after{ content:""; position:absolute; inset:14px; border:1px solid var(--gr-line2); transform:scale(1.04); opacity:.5; }
.gr-photo__ph{ display:flex; flex-direction:column; align-items:center; gap:7px; z-index:1; }
.gr-photo__ph b{ font-size:1.8rem; }
.gr-photo__logo{ width:160px; max-width:72%; height:auto; opacity:.9; }
.gr-photo__ph small{ font-family:var(--gr-display); font-size:.62rem; letter-spacing:.34em; text-transform:uppercase; color:var(--gr-gold); }

/* ===== cards ===== */
.gr-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(264px,1fr)); gap:24px; margin:1.4rem 0 2rem; }
.gr-card{ position:relative; display:flex; flex-direction:column; background:var(--gr-bg2); border:1px solid var(--gr-line); overflow:hidden; color:var(--gr-white); box-shadow:var(--gr-shadow); transition:transform .26s ease, box-shadow .26s ease, border-color .26s ease; }
.gr-card::before{ content:""; position:absolute; inset:0; border:1px solid transparent; pointer-events:none; transition:border-color .26s; z-index:3; }
.gr-card:hover{ transform:translateY(-7px); box-shadow:var(--gr-shadow-h); border-color:var(--gr-gold); }
.gr-card:hover::before{ border-color:rgba(232,205,133,.35); }
.gr-card__main{ position:absolute; top:0; left:0; z-index:4; background:linear-gradient(135deg,var(--gr-gold-b),var(--gr-gold-d)); color:var(--gr-ink); font-size:.6rem; font-weight:800; letter-spacing:.18em; text-transform:uppercase; padding:5px 13px; }
.gr-card__body{ padding:18px 20px 20px; display:flex; flex-direction:column; gap:8px; flex:1; }
.gr-card__badges{ display:flex; flex-wrap:wrap; gap:6px; }
.gr-card__title{ font-family:var(--gr-serif); font-size:1.16rem; font-weight:700; margin:2px 0 0; line-height:1.4; }
.gr-card__loc{ color:var(--gr-mut2); font-size:.83rem; margin:0; letter-spacing:.02em; }
.gr-card__meta{ color:#C7C0B0; font-size:.82rem; margin:0; }
.gr-card__more{ margin-top:auto; padding-top:8px; color:var(--gr-gold-b); font-weight:700; font-size:.8rem; letter-spacing:.06em; text-transform:uppercase; }

/* ===== hub grid ===== */
.gr-hubgrid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:20px; margin:1.6rem 0; }
.gr-hubcard{ position:relative; display:flex; flex-direction:column; gap:6px; padding:32px 26px; background:linear-gradient(165deg,var(--gr-bg3),var(--gr-bg2)); border:1px solid var(--gr-line); color:var(--gr-white); box-shadow:var(--gr-shadow); transition:transform .26s, box-shadow .26s, border-color .26s; }
.gr-hubcard:hover{ transform:translateY(-7px); box-shadow:var(--gr-shadow-h); border-color:var(--gr-gold-b); }
.gr-hubcard__name{ font-family:var(--gr-serif); font-weight:700; font-size:1.24rem; }
.gr-hubcard__sub{ font-size:.78rem; color:var(--gr-mut2); }
.gr-hubcard__cnt{ margin-top:10px; font-size:.68rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--gr-gold-b); }
.gr-hubcard::after{ content:"→"; position:absolute; right:26px; top:32px; color:var(--gr-line); font-size:1.2rem; transition:.2s; }
.gr-hubcard:hover::after{ color:var(--gr-gold-b); transform:translateX(4px); }

/* ===== chips ===== */
.gr-chips{ display:flex; gap:10px; flex-wrap:wrap; margin:1rem 0 1.3rem; justify-content:center; }
.gr-chip{ cursor:pointer; border:1px solid var(--gr-line); background:transparent; color:var(--gr-mut2); font-weight:600; font-size:.84rem; letter-spacing:.04em; padding:9px 22px; border-radius:2px; transition:.2s; }
.gr-chip.is-on{ background:linear-gradient(135deg,var(--gr-gold-b),var(--gr-gold-d)); color:var(--gr-ink); border-color:transparent; }

/* ===== tables ===== */
.gr-table{ width:100%; border-collapse:collapse; margin:1.2rem 0; background:var(--gr-bg2); border:1px solid var(--gr-line); }
.gr-table th{ width:32%; text-align:left; background:rgba(201,162,75,.08); color:var(--gr-gold-b); font-family:var(--gr-sans); font-weight:700; font-size:.86rem; padding:14px 17px; border-bottom:1px solid var(--gr-line2); }
.gr-table td{ padding:14px 17px; border-bottom:1px solid var(--gr-line2); font-size:.95rem; color:var(--gr-white); }
.gr-table tr:last-child th,.gr-table tr:last-child td{ border-bottom:0; }

/* ===== scale ===== */
.gr-scale{ display:grid; grid-template-columns:repeat(auto-fit,minmax(90px,1fr)); gap:1px; margin:1.2rem 0; background:var(--gr-line2); border:1px solid var(--gr-line); }
.gr-scale__item{ background:var(--gr-bg2); padding:20px 6px; text-align:center; }
.gr-scale__n{ display:block; font-family:var(--gr-serif); font-size:1.7rem; font-weight:700; color:var(--gr-gold-b); }
.gr-scale__l{ display:block; font-size:.74rem; color:var(--gr-mut2); letter-spacing:.05em; margin-top:4px; }

/* ===== CTA ===== */
.gr-cta{ display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:20px; background:linear-gradient(135deg,#15130D,var(--gr-bg2)); border:1px solid var(--gr-gold); padding:30px 34px; margin:2.4rem 0; position:relative; }
.gr-cta::before{ content:""; position:absolute; inset:5px; border:1px solid var(--gr-line2); pointer-events:none; }
.gr-cta__txt{ display:flex; flex-direction:column; gap:5px; z-index:1; }
.gr-cta__txt strong{ font-family:var(--gr-serif); font-size:1.26rem; color:var(--gr-white); font-weight:700; }
.gr-cta__txt span{ color:#C7C0B0; font-size:.9rem; }
.gr-cta__btns{ display:flex; gap:12px; flex-wrap:wrap; z-index:1; }
.gr-btn{ display:inline-flex; align-items:center; gap:7px; padding:13px 27px; border-radius:var(--gr-radius-s); font-family:var(--gr-sans); font-weight:700; font-size:.92rem; letter-spacing:.02em; transition:transform .16s, box-shadow .16s, filter .16s; }
.gr-btn:hover{ transform:translateY(-2px); filter:brightness(1.05); box-shadow:0 12px 28px rgba(0,0,0,.45); }
.gr-btn--kakao{ background:var(--gr-kakao); color:var(--gr-kakao-ink); }
.gr-btn--tele{ background:var(--gr-tele); color:#fff; }
.gr-btn--gold{ background:linear-gradient(135deg,var(--gr-gold-b),var(--gr-gold-d)); color:var(--gr-ink); }
.gr-btn--ghost{ background:transparent; color:var(--gr-gold-b); border:1px solid var(--gr-gold); }

/* ===== single ===== */
.gr-single{ padding-top:2rem; }
.gr-single .gr-hero{ display:grid; grid-template-columns:1.05fr .95fr; gap:34px; align-items:start; margin:1rem 0 1.4rem; }
.gr-single .gr-hero__head h1{ font-size:2.25rem; font-weight:700; margin:.4rem 0 .35rem; }
.gr-single .gr-hero__en{ font-family:var(--gr-display); color:var(--gr-gold-b); font-size:.95rem; letter-spacing:.12em; margin:0 0 1rem; }
.gr-bc{ font-size:.8rem; color:var(--gr-mut2); letter-spacing:.03em; margin:.4rem 0 1rem; }
.gr-bc a{ color:var(--gr-mut2); }
.gr-prose{ font-size:1.05rem; color:#D6D0C3; }
.gr-prose h2{ font-family:var(--gr-serif); font-size:1.45rem; font-weight:700; color:var(--gr-white); margin:2.3rem 0 .7rem; padding-bottom:.55rem; border-bottom:1px solid var(--gr-line); }
.gr-prose h3{ font-size:1.14rem; font-weight:700; margin:1.5rem 0 .5rem; color:var(--gr-gold-b); }
.gr-prose p{ margin:.75rem 0; } .gr-prose ul{ padding-left:1.1rem; } .gr-prose li{ margin:.35rem 0; }
.gr-prose strong{ color:var(--gr-white); }
.gr-faq{ margin:1.6rem 0; }
.gr-faq details{ background:var(--gr-bg2); border:1px solid var(--gr-line2); padding:17px 22px; margin:12px 0; transition:border-color .2s; }
.gr-faq details[open]{ border-color:var(--gr-gold); }
.gr-faq summary{ font-family:var(--gr-serif); font-weight:700; cursor:pointer; list-style:none; color:var(--gr-white); }
.gr-faq summary::after{ content:"+"; float:right; color:var(--gr-gold-b); font-size:1.25rem; line-height:1; }
.gr-faq details[open] summary::after{ content:"–"; }
.gr-faq details>div{ margin-top:.7rem; color:#C7C0B0; }
.gr-related{ margin-top:2.6rem; }

/* ===== nightlife ===== */
.gr-nl{ display:grid; grid-template-columns:1fr 1fr; gap:20px; margin:1.6rem 0; }
.gr-nl__box{ background:var(--gr-bg2); border:1px solid var(--gr-line); padding:40px 28px; text-align:center; }
.gr-nl__box h3{ font-family:var(--gr-serif); font-size:1.26rem; margin:.6rem 0 .4rem; color:var(--gr-white); }
.gr-nl__box p{ color:var(--gr-mut2); font-size:.9rem; }
.gr-soon{ display:inline-block; background:rgba(201,162,75,.1); color:var(--gr-gold-b); font-weight:700; font-size:.64rem; letter-spacing:.2em; text-transform:uppercase; padding:5px 14px; border:1px solid var(--gr-line); }

/* content sections need horizontal padding via wrap */
.gr-section{ padding:0; }

/* ===== footer ===== */
.gr-footer{ background:var(--gr-band); border-top:1px solid var(--gr-line); margin-top:4rem; }
.gr-footer__inner{ display:flex; flex-wrap:wrap; gap:40px; justify-content:space-between; padding:54px 24px 36px; }
.gr-footer__brand{ max-width:380px; }
.gr-foot-emblem{ width:54px; height:auto; display:block; }
.gr-foot-logo{ width:230px; max-width:78%; height:auto; display:block; margin-bottom:.4rem; }
.gr-logo__wm--foot{ font-size:1.4rem; margin:.4rem 0 .6rem; }
.gr-footer__brand p{ color:var(--gr-mut2); font-size:.9rem; margin:0 0 1rem; }
.gr-footer__contact{ display:flex; gap:10px; }
.gr-footer__links{ display:flex; flex-direction:column; gap:9px; }
.gr-footer__links strong{ color:var(--gr-gold-b); font-family:var(--gr-sans); font-size:.74rem; letter-spacing:.2em; text-transform:uppercase; margin-bottom:4px; }
.gr-footer__links a{ color:var(--gr-mut2); font-size:.92rem; } .gr-footer__links a:hover{ color:var(--gr-gold-b); }
.gr-footer__bottom{ border-top:1px solid var(--gr-line2); }
.gr-footer__bottom .gr-wrap{ display:flex; flex-wrap:wrap; gap:10px 24px; justify-content:space-between; padding-top:18px; padding-bottom:18px; }
.gr-footer__bottom span{ color:#6E6A60; font-size:.78rem; } .gr-footer__disc{ max-width:560px; }

/* ===== floating ===== */
.gr-float{ position:fixed; right:22px; bottom:22px; z-index:9999; display:flex; flex-direction:column; align-items:center; gap:12px; }
.gr-float__btn{ width:50px; height:50px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-weight:700; font-size:.74rem; box-shadow:var(--gr-shadow-h); transform:scale(0) translateY(8px); opacity:0; transition:transform .22s, opacity .22s; }
.gr-float.is-open .gr-float__btn{ transform:scale(1) translateY(0); opacity:1; }
.gr-float__kakao{ background:var(--gr-kakao); color:var(--gr-kakao-ink); }
.gr-float__tele{ background:var(--gr-tele); color:#fff; }
.gr-float__main{ width:66px; height:66px; border-radius:50%; border:2px solid var(--gr-gold); cursor:pointer; background:radial-gradient(120% 120% at 30% 25%,#241F16,#0C0A07); color:#fff; font-size:1.85rem; box-shadow:0 0 0 5px rgba(201,162,75,.1), var(--gr-shadow-h); transition:transform .2s; }
.gr-float__main:hover{ transform:scale(1.07) rotate(-5deg); }
.gr-float__main img{ width:40px; height:40px; object-fit:contain; }

/* ===== responsive ===== */
@media(max-width:860px){
  .gr-navtoggle{ display:flex; }
  .gr-header__inner{ height:68px; }
  .gr-logo__img{ height:46px; }
  .gr-nav{ position:absolute; top:68px; left:0; right:0; flex-direction:column; align-items:stretch; gap:0; background:var(--gr-band); border-bottom:1px solid var(--gr-line); padding:8px 0 16px; max-height:0; overflow:hidden; transition:max-height .3s ease; box-shadow:var(--gr-shadow); }
  .gr-header.is-open .gr-nav{ max-height:85vh; }
  .gr-menu{ flex-direction:column; align-items:stretch; gap:0; }
  .gr-menu a{ padding:14px 22px; border-bottom:1px solid var(--gr-line2); }
  .gr-menu a::after{ display:none; }
  .gr-header__cta{ margin:12px 22px 4px; text-align:center; }
  .gr-wrap{ padding:0 18px; }
  .gr-h{ font-size:1.5rem; margin-top:2.6rem; }
  .gr-banner{ padding:48px 18px 40px; }
  .gr-banner h1{ font-size:1.75rem; }
  .gr-banner .gr-mascot{ width:200px; }
  .gr-banner p{ font-size:.96rem; }
  .gr-single{ padding-top:1.2rem; }
  .gr-single .gr-hero{ grid-template-columns:1fr; gap:18px; }
  .gr-single .gr-hero__head h1{ font-size:1.7rem; }
  .gr-nl{ grid-template-columns:1fr; }
  .gr-cta{ flex-direction:column; align-items:stretch; text-align:center; padding:24px 22px; }
  .gr-cta__btns{ justify-content:center; }
  .gr-footer__inner{ gap:26px; padding:40px 22px 28px; }
  .gr-footer__bottom .gr-wrap{ flex-direction:column; }
}
@media(max-width:480px){
  .gr-grid{ grid-template-columns:1fr; gap:16px; }
  .gr-hubgrid{ grid-template-columns:1fr 1fr; gap:12px; }
  .gr-hubcard{ padding:22px 16px; } .gr-hubcard__name{ font-size:1.05rem; } .gr-hubcard::after{ display:none; }
  .gr-scale{ grid-template-columns:repeat(3,1fr); }
  .gr-banner{ padding:40px 16px 34px; }
  .gr-banner .gr-mascot{ width:172px; }
  .gr-banner h1{ font-size:1.5rem; }
  .gr-h{ font-size:1.35rem; }
  .gr-table th{ width:40%; padding:11px 12px; font-size:.82rem; }
  .gr-table td{ padding:11px 12px; font-size:.9rem; }
  .gr-prose{ font-size:1rem; }
  .gr-prose h2{ font-size:1.28rem; }
  .gr-float__main{ width:56px; height:56px; } .gr-float__main img{ width:34px; height:34px; }
  .gr-float__btn{ width:46px; height:46px; }
  .gr-btn{ padding:12px 22px; }
}
