:root{
  --ink:#1c1a17;
  --ink-soft:#4a463f;
  --paper:#f7f3ec;
  --paper-warm:#efe7d9;
  --gold:#b78f52;
  --gold-dark:#9a7639;
  --green:#2f4438;
  --line:rgba(28,26,23,.14);
  --display:"Cormorant Garamond", Georgia, serif;
  --body:"Jost", sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.7;
  font-weight:300;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4{font-family:var(--display);font-weight:500;line-height:1.1;letter-spacing:.01em}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:1180px;margin:0 auto;padding:0 28px}

/* small caps label */
.eyebrow{
  font-family:var(--body);font-weight:500;font-size:.72rem;
  letter-spacing:.32em;text-transform:uppercase;color:var(--gold-dark);
  display:inline-block;
}
.section-head{text-align:center;margin-bottom:54px}
.section-head h2{font-size:clamp(2.2rem,5vw,3.4rem);margin-top:.2em}
.rule{width:46px;height:2px;background:var(--gold);margin:18px auto 0}

/* ---------- top bar ---------- */
.topbar{
  background:var(--ink);color:#e7ddcb;
  font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;
}
.topbar .wrap{display:flex;justify-content:center;gap:28px;padding-top:9px;padding-bottom:9px}
.topbar a{display:flex;align-items:center;gap:7px;transition:color .25s}
.topbar a:hover{color:var(--gold)}

/* ---------- nav ---------- */
header.nav{
  position:sticky;top:0;z-index:60;
  background:rgba(26,22,15,.95);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:78px}
.brand-link{display:flex;align-items:center}
.nav-logo{height:46px;width:auto;display:block;filter:invert(1) sepia(1) saturate(0.4) brightness(1.1);}
.nav-links{display:flex;gap:34px;align-items:center}
.nav-links a{
  font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;font-weight:400;
  position:relative;padding:4px 0;color:rgba(231,221,203,.75);transition:color .25s;
}
.nav-links a::after{
  content:"";position:absolute;left:0;bottom:-2px;height:1.5px;width:0;background:var(--gold);transition:width .3s;
}
.nav-links a:hover{color:#fff}
.nav-links a:hover::after{width:100%}
.nav-links a.current{color:#fff}
.nav-links a.current::after{width:100%}
.btn{
  display:inline-block;font-family:var(--body);font-weight:500;
  font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;
  padding:13px 26px;border:1.5px solid var(--gold);color:#e7ddcb;
  background:transparent;cursor:pointer;transition:all .3s;
}
.btn:hover{background:var(--gold);color:#fff}
.btn-solid{background:var(--gold);color:#fff;border-color:var(--gold)}
.btn-solid:hover{background:var(--gold-dark);border-color:var(--gold-dark)}
.btn-light{border-color:rgba(255,255,255,.7);color:#fff}
.btn-light:hover{background:#fff;color:var(--ink);border-color:#fff}
.btn-dark{border-color:var(--ink);color:var(--ink)}
.btn-dark:hover{background:var(--ink);color:#fff}
.nav-cta{display:flex;align-items:center;gap:18px}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.burger span{width:26px;height:2px;background:#e7ddcb;transition:.3s}

/* ---------- hero ---------- */
.hero{
  position:relative;min-height:88vh;display:flex;align-items:center;
  color:#fff;text-align:center;
  background:
    linear-gradient(to bottom, rgba(20,17,13,.55) 0%, rgba(20,17,13,.35) 50%, rgba(20,17,13,.6) 100%),
    var(--hero-img, url("../img/WarwickPics-50-2.webp")) center/cover fixed;
}
.hero--sub{min-height:60vh}
.hero-inner{max-width:600px;margin:0 auto;animation:rise 1.1s ease both}
.hero .eyebrow{color:#fff;letter-spacing:.36em}
.hero h1{font-size:clamp(3rem,7vw,5.4rem);margin:.18em 0 .35em;font-weight:500}
.hero h1 em{font-style:italic;color:#fff}
.hero-logo{width:min(420px,80%);height:auto;margin:.3em auto .55em}
.footer-logo{width:120px;height:auto;margin:0 auto 14px}
.hero p{font-size:1.12rem;font-weight:300;max-width:480px;margin:0 auto 34px;color:#f1e9da}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;justify-content:center}
@keyframes rise{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}

/* ---------- intro ---------- */
.intro{padding:90px 0 70px;text-align:center}
.crest{font-size:2rem;color:var(--gold);margin-bottom:10px}
.intro p{font-family:var(--display);font-size:clamp(1.5rem,3vw,2.1rem);
  font-weight:400;font-style:italic;color:var(--ink-soft);max-width:760px;margin:0 auto;line-height:1.45}

/* ---------- explore cards ---------- */
.explore{padding:30px 0 90px}
.feature-row{display:grid;grid-template-columns:1fr 1fr;gap:28px;margin-bottom:28px}
.feature{
  display:grid;grid-template-columns:1fr 1fr;background:#fff;
  box-shadow:0 18px 40px -28px rgba(28,26,23,.5);overflow:hidden;
}
.feature img{height:100%;width:100%;object-fit:cover;min-height:230px}
.feature .txt{padding:34px 32px;display:flex;flex-direction:column;justify-content:center}
.feature h3{font-size:1.7rem;margin-bottom:10px}
.feature p{font-size:.95rem;color:var(--ink-soft);margin-bottom:20px}

.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.card{background:#fff;box-shadow:0 18px 40px -30px rgba(28,26,23,.5);overflow:hidden;
  display:flex;flex-direction:column;transition:transform .35s, box-shadow .35s}
.card:hover{transform:translateY(-6px);box-shadow:0 28px 50px -28px rgba(28,26,23,.55)}
.card .ph{height:200px;overflow:hidden}
.card .ph img{height:100%;width:100%;object-fit:cover;transition:transform .6s}
.card:hover .ph img{transform:scale(1.06)}
.card .body{padding:26px 26px 30px;display:flex;flex-direction:column;flex:1}
.card h3{font-size:1.45rem;margin-bottom:8px}
.card p{font-size:.9rem;color:var(--ink-soft);margin-bottom:20px;flex:1}
.link-arrow{font-size:.76rem;letter-spacing:.18em;text-transform:uppercase;font-weight:500;
  color:var(--gold-dark);display:inline-flex;gap:8px;align-items:center;transition:gap .25s}
.card:hover .link-arrow{gap:14px}

/* ---------- menus ---------- */
.menus{background:var(--green);color:#f1e9da;padding:90px 0}
.menus .section-head h2,.menus .crest{color:#fff}
.menus .eyebrow{color:var(--gold)}
.menu-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;max-width:840px;margin:0 auto}
.menu-tile{
  border:1px solid rgba(241,233,218,.22);padding:34px 22px;text-align:center;
  transition:background .3s,border-color .3s;
}
.menu-tile:hover{background:rgba(183,143,82,.16);border-color:var(--gold)}
.menu-tile .ico{font-size:1.5rem;color:var(--gold);margin-bottom:12px}
.menu-tile h4{font-family:var(--display);font-size:1.4rem;color:#fff;margin-bottom:6px}
.menu-tile span{font-size:.8rem;letter-spacing:.04em;color:#cdbfa4}

/* ---------- amenities band ---------- */
.band{background:var(--paper-warm);padding:64px 0}
.band-inner{display:grid;grid-template-columns:1fr 1.2fr;gap:50px;align-items:center}
.band-inner img{box-shadow:0 24px 50px -30px rgba(28,26,23,.6);height:100%;object-fit:cover;width:100%}
.band h3{font-size:2.2rem;margin-bottom:6px}
.amen{display:grid;grid-template-columns:1fr 1fr;gap:14px 30px;margin-top:24px}
.amen div{display:flex;align-items:center;gap:11px;font-size:.92rem;color:var(--ink-soft)}
.amen .dot{width:7px;height:7px;background:var(--gold);border-radius:50%;flex:none}

/* ---------- hours ---------- */
.hours{padding:90px 0}
.hours-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;max-width:880px;margin:0 auto}
.hours-col h3{font-size:1.6rem;text-align:center;margin-bottom:8px}
.hours-col .rule{margin:10px auto 24px}
.hrow{display:flex;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--line);font-size:.94rem}
.hrow span:first-child{color:var(--ink);font-weight:400}
.hrow span:last-child{color:var(--ink-soft);letter-spacing:.03em}

/* ---------- reservation ---------- */
.reserve{
  background:var(--paper-warm);padding:60px 0;text-align:center;
  border-top:1px solid var(--line);
}
.reserve .section-head{margin-bottom:32px}
.reserve .eyebrow{color:var(--gold-dark)}
.ot-wrap{
  display:flex;justify-content:center;
  min-height:0;
}
.ot-wrap iframe{max-width:100%}

/* ---------- find us ---------- */
.find{background:var(--ink);color:#e7ddcb;padding:0;display:grid;grid-template-columns:1fr 1fr}
.find .info{padding:80px clamp(28px,6vw,90px)}
.find .eyebrow{color:var(--gold)}
.find h2{color:#fff;font-size:clamp(2rem,4vw,3rem);margin:.2em 0 .6em}
.find .blk{margin-bottom:30px}
.find .blk h4{font-family:var(--body);font-weight:500;font-size:.78rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--gold);margin-bottom:8px}
.find .blk p,.find .blk a{font-size:1rem;color:#d8cdba;font-weight:300}
.find .blk a:hover{color:#fff}
.find .map iframe{width:100%;height:100%;min-height:420px;border:0;filter:grayscale(.3) contrast(1.05)}
.socials{display:flex;gap:14px;margin-top:8px}
.socials a{width:40px;height:40px;border:1px solid rgba(231,221,203,.35);border-radius:50%;
  display:grid;place-items:center;transition:all .3s}
.socials a:hover{background:var(--gold);border-color:var(--gold);color:#fff}
.socials svg{width:17px;height:17px}

/* ---------- footer ---------- */
footer{background:#141109;color:#9a907d;text-align:center;padding:46px 0;font-size:.82rem;letter-spacing:.04em}
footer .brand{color:#fff;font-size:1.6rem;margin-bottom:10px}
footer .fnav{display:flex;justify-content:center;gap:26px;flex-wrap:wrap;margin:18px 0 22px;
  text-transform:uppercase;font-size:.74rem;letter-spacing:.16em}
footer .fnav a:hover{color:var(--gold)}
footer .fine{font-size:.74rem;color:#6d6556;margin-top:14px}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s ease, transform .8s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- gallery carousel ---------- */
.gallery{position:relative;width:100%;background:var(--ink)}
.gallery-track{position:relative;width:100%;height:clamp(360px,68vh,720px);overflow:hidden}
.gslide{
  position:absolute;inset:0;opacity:0;visibility:hidden;
  transition:opacity .9s ease;
}
.gslide.active{opacity:1;visibility:visible}
.gslide img{width:100%;height:100%;object-fit:cover}
.gslide::after{content:"";position:absolute;inset:0;
  background:linear-gradient(to top, rgba(20,17,13,.55) 0%, rgba(20,17,13,0) 45%)}
.gcaption{
  position:absolute;left:0;right:0;bottom:64px;z-index:3;text-align:center;color:#fff;
  font-family:var(--display);font-size:clamp(.9rem,1.6vw,1.2rem);font-style:italic;
  text-shadow:0 2px 14px rgba(0,0,0,.5);padding:0 24px;
  opacity:0;transform:translateY(14px);transition:opacity .7s ease .2s, transform .7s ease .2s;
}
.gslide.active .gcaption{opacity:1;transform:none}
.garrow{
  position:absolute;top:50%;transform:translateY(-50%);z-index:4;
  width:54px;height:54px;border-radius:50%;border:0;cursor:pointer;
  background:rgba(20,17,13,.4);color:#fff;display:grid;place-items:center;
  backdrop-filter:blur(4px);transition:background .3s;
}
.garrow:hover{background:var(--gold)}
.garrow svg{width:22px;height:22px}
.garrow.prev{left:clamp(14px,3vw,38px)}
.garrow.next{right:clamp(14px,3vw,38px)}
.gdots{
  position:absolute;left:0;right:0;bottom:26px;z-index:4;
  display:flex;gap:11px;justify-content:center;
}
.gdots button{
  width:11px;height:11px;border-radius:50%;border:1.5px solid rgba(255,255,255,.75);
  background:transparent;cursor:pointer;padding:0;transition:all .3s;
}
.gdots button:hover{transform:scale(1.2)}
.gdots button.active{background:var(--gold);border-color:var(--gold);transform:scale(1.15)}

/* ====================================================================
   Sub-page components (Sunday Roast, Private Hire)
   ==================================================================== */

/* section helpers */
.sec{padding:90px 0}
.sec-tight{padding:64px 0}
.bg-warm{background:var(--paper-warm)}
.bg-green{background:var(--green);color:#f1e9da}
.bg-green .section-head h2{color:#fff}
.bg-green .eyebrow{color:var(--gold)}

/* breadcrumb */
.crumbs{background:var(--paper-warm);font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;border-bottom:1px solid var(--line)}
.crumbs .wrap{padding:13px 28px}
.crumbs a{color:var(--gold-dark)}
.crumbs a:hover{color:var(--ink)}
.crumbs span{color:var(--ink-soft)}
.crumbs .sep{margin:0 9px;color:var(--gold)}

/* prose */
.prose{max-width:760px;margin:0 auto;text-align:center}
.prose p{font-size:1.05rem;color:var(--ink-soft);margin-bottom:18px}
.prose p:last-child{margin-bottom:0}
.lead{font-family:var(--display);font-size:clamp(1.4rem,3vw,2rem);font-style:italic;color:var(--ink-soft);line-height:1.45;margin-bottom:24px}

/* content split (image + text) */
.split{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.split + .split{margin-top:56px}
.split.rev .split-media{order:2}
.split-media img{width:100%;height:100%;object-fit:cover;min-height:300px;box-shadow:0 24px 50px -30px rgba(28,26,23,.6)}
.split h3{font-size:2rem;margin-bottom:12px}
.split .eyebrow{margin-bottom:6px}
.split p{color:var(--ink-soft);margin-bottom:16px}

/* occasions / tick list */
.ticks{display:grid;grid-template-columns:repeat(3,1fr);gap:14px 30px;max-width:840px;margin:0 auto}
.ticks div{display:flex;align-items:center;gap:11px;font-size:.96rem;color:var(--ink-soft)}
.ticks .dot{width:7px;height:7px;background:var(--gold);border-radius:50%;flex:none}

/* faq */
.faq{max-width:820px;margin:0 auto}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{cursor:pointer;list-style:none;padding:20px 0;font-family:var(--display);font-size:1.3rem;
  color:var(--ink);display:flex;justify-content:space-between;align-items:center;gap:20px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--gold-dark);font-size:1.5rem;line-height:1;transition:transform .3s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{color:var(--ink-soft);padding:0 0 20px;font-size:.98rem;max-width:680px}

/* enquiry form */
.form{max-width:660px;margin:0 auto;text-align:left;display:grid;gap:18px}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form label{display:block;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--gold-dark);margin-bottom:7px;font-weight:500}
.form input,.form select,.form textarea{
  width:100%;padding:13px 15px;border:1px solid var(--line);background:#fff;
  font-family:var(--body);font-size:.95rem;color:var(--ink);font-weight:300;border-radius:0;
}
.form textarea{min-height:120px;resize:vertical}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--gold)}
.form button.btn{justify-self:start;color:#fff}

/* ====================================================================
   Menu pages (Pub, Sunday, Bar Snacks, Wine, Christmas)
   ==================================================================== */
.menu-doc{padding:80px 0 90px}
.menu-doc .wrap{max-width:980px}

/* feature line e.g. "Nocellara Olives  5.5" */
.menu-feature{
  text-align:center;font-family:var(--display);font-style:italic;
  font-size:1.3rem;color:var(--ink-soft);margin:0 auto 6px;
  display:flex;align-items:center;justify-content:center;gap:14px;
}
.menu-feature::before,.menu-feature::after{content:"❧";color:var(--gold);font-style:normal;font-size:.9rem;opacity:.8}
.menu-feature .pr{color:var(--gold-dark);font-style:normal}
.menu-feature.plain::before,.menu-feature.plain::after{content:""}

/* section */
.menu-section{margin-top:56px}
.menu-section:first-of-type{margin-top:0}
.menu-section > h2{
  text-align:center;font-size:clamp(1.8rem,4vw,2.6rem);
  text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px;
}
.menu-section > h2 + .rule{margin-bottom:34px}

/* sub-region heading (wine) */
.menu-region{font-family:var(--display);font-style:italic;font-size:1.35rem;
  color:var(--gold-dark);margin:30px 0 14px;text-align:left}
.menu-region:first-child{margin-top:0}

/* two-column item grid */
.menu-cols{display:grid;grid-template-columns:1fr 1fr;gap:6px 56px}
.menu-cols.one{grid-template-columns:1fr;max-width:620px;margin:0 auto}

/* single item */
.mitem{padding:13px 0;border-bottom:1px solid var(--line)}
.mitem-head{display:flex;align-items:baseline;gap:8px}
.mitem-head h3{font-family:var(--body);font-weight:500;font-size:1rem;letter-spacing:.01em;white-space:nowrap;flex:0 1 auto}
.mitem-head .lead-dots{flex:1 1 auto;border-bottom:1px dotted var(--line);transform:translateY(-4px);min-width:14px}
.mitem-head .pr{font-weight:500;color:var(--gold-dark);flex:none;letter-spacing:.02em}
.mitem .mdesc{font-size:.85rem;color:var(--ink-soft);margin-top:4px;max-width:90%}
.mitem .tag{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-dark);font-weight:500}

/* by-the-glass / multi-price rows (wine) */
.glass-head,.glassrow{display:grid;grid-template-columns:1fr repeat(3,58px);gap:10px;align-items:baseline}
.glass-head{font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-dark);
  padding-bottom:8px;border-bottom:1px solid var(--line);margin-bottom:4px}
.glass-head span:not(:first-child),.glassrow .g{text-align:right}
.glassrow{padding:11px 0;border-bottom:1px solid var(--line)}
.glassrow .nm{font-size:.95rem}
.glassrow .g{font-weight:500;color:var(--gold-dark);font-size:.92rem}

/* framed callout (e.g. signature burger / special roasts) */
.menu-callout{
  border:2px solid var(--ink);padding:30px 34px;text-align:center;margin:46px auto;max-width:560px;
  position:relative;background:#fff;
}
.menu-callout h3{font-family:var(--display);font-size:1.6rem;margin-bottom:10px}
.menu-callout p{font-size:.9rem;color:var(--ink-soft)}
.menu-callout .pr{color:var(--gold-dark);font-weight:500}

/* small centred note line between sections */
.menu-aside{text-align:center;font-family:var(--display);font-style:italic;font-size:1.15rem;
  color:var(--ink-soft);margin:30px 0}

/* allergen / service footer */
.menu-foot{text-align:center;font-size:.82rem;color:var(--ink-soft);margin-top:56px;
  padding-top:26px;border-top:1px solid var(--line);line-height:1.8}
.menu-foot strong{color:var(--ink);font-weight:500}

/* download / actions row */
.menu-dl{text-align:center;margin-top:40px}

/* responsive */
@media(max-width:760px){
  .menu-cols{grid-template-columns:1fr;gap:0}
  .glass-head,.glassrow{grid-template-columns:1fr 46px 46px 46px;gap:6px}
  .mitem .mdesc{max-width:100%}
}

/* ---------- responsive ---------- */
@media(max-width:900px){
  .feature-row{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr 1fr}
  .band-inner{grid-template-columns:1fr}
  .band-inner img{max-height:320px}
  .find{grid-template-columns:1fr}
  .find .map iframe{min-height:340px}
  .split{grid-template-columns:1fr;gap:28px}
  .split.rev .split-media{order:0}
  .ticks{grid-template-columns:1fr 1fr}
  .form .row{grid-template-columns:1fr}
}
@media(max-width:720px){
  .nav-links,.topbar .wrap{display:none}
  .burger{display:flex}
  .nav-cta .btn:not(.btn-solid){display:none}
  .mobile-menu{
    position:fixed;inset:78px 0 auto 0;background:var(--paper);
    border-bottom:1px solid var(--line);transform:translateY(-120%);
    transition:transform .4s ease;z-index:55;padding:18px 28px 26px;
    display:flex;flex-direction:column;gap:4px;box-shadow:0 20px 40px -20px rgba(0,0,0,.3);
  }
  .mobile-menu.open{transform:translateY(0)}
  .mobile-menu a{padding:13px 0;border-bottom:1px solid var(--line);
    font-size:.85rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft)}
  .hero{min-height:78vh;background-attachment:scroll}
  .hero--sub{min-height:56vh}
  .menu-grid,.cards{grid-template-columns:1fr;max-width:420px}
  .hours-grid{grid-template-columns:1fr;gap:42px}
  .amen{grid-template-columns:1fr}
  .feature{grid-template-columns:1fr}
  /* iOS/WebKit resolves img height:100% against the whole grid container when
     stacked, stretching the image over the text. Pin an explicit height. */
  .feature img{height:240px;min-height:0}
  .garrow{width:42px;height:42px}
  .garrow svg{width:18px;height:18px}
  .gcaption{bottom:54px}
  .ticks{grid-template-columns:1fr}
}
@media(min-width:721px){.mobile-menu{display:none}}

/* compact hero — menu pages (just enough space above/below the content) */
.hero--compact{min-height:0;padding:64px 0}
@media(max-width:720px){
  .hero--compact{min-height:0;padding:48px 0;background-attachment:scroll}
}
