/* ============================================================
   THE TAVERN & INN COMPANY — "Refined" style set
   Aesthetic: St. John austerity × The Cow boldness. Monochrome,
   warm paper, one restrained clay accent. Editorial restraint.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;0,9..144,600;1,9..144,400&family=Spectral:ital,wght@0,300;0,400;0,500;1,400&display=swap');

:root{
  /* tokens — master copy: Websites/ti-theme.css */
  --paper:#F3F0E8;          /* warm off-white, St John gallery wall */
  --paper-2:#ECE7DA;        /* slightly deeper panel */
  --ink:#171513;            /* near-black, warm */
  --ink-soft:#3A3631;
  --grey:#6E675C;           /* warm mid grey for meta text */
  --line:#CFC7B6;           /* hairline rules */
  --line-soft:#DED7C6;
  --clay:#9C3B2A;           /* the single accent — muted oxblood/clay */
  --clay-deep:#7E2E20;
  --white:#FBF9F3;

  --display:'Fraunces', Georgia, serif;
  --body:'Spectral', Georgia, serif;

  --maxw:1280px;
  --gutter:clamp(20px,5vw,72px);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--body);
  font-weight:400;
  font-size:18px;
  line-height:1.65;
  letter-spacing:.005em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}

/* paper grain overlay for atmosphere */
body::before{
  content:"";position:fixed;inset:0;z-index:1;pointer-events:none;
  opacity:.035;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- type scale ---------- */
.display{
  font-family:var(--display);
  font-weight:500;
  line-height:.96;
  letter-spacing:-.01em;
  text-transform:uppercase;
}
h1,h2,h3{font-family:var(--display);font-weight:500;line-height:1.02}
.eyebrow{
  font-family:var(--body);
  text-transform:uppercase;
  letter-spacing:.28em;
  font-size:.72rem;
  font-weight:500;
  color:var(--grey);
}
.lede{font-size:clamp(1.15rem,2vw,1.5rem);line-height:1.5;font-weight:300}
.measure{max-width:62ch}

/* ---------- layout primitives ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter)}
.section{padding-block:clamp(56px,9vw,140px);position:relative;z-index:2}
.rule{height:1px;background:var(--line);border:0}
.center{text-align:center}

/* ---------- NAV ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--gutter);
  background:color-mix(in srgb, var(--paper) 96%, transparent);
  border-bottom:1px solid transparent;
  transition:border-color .4s, background .4s, padding .4s;
}
.nav.scrolled{border-bottom-color:var(--line);padding-top:13px;padding-bottom:13px}
.nav-logo{font-family:var(--display);text-transform:uppercase;font-weight:600;
  letter-spacing:.04em;font-size:1.04rem;line-height:1}
.nav-logo .amp{font-style:italic;font-weight:400;text-transform:none}
.nav-links{display:flex;gap:clamp(18px,2.4vw,40px);align-items:center}
.nav-links a{
  font-size:.78rem;text-transform:uppercase;letter-spacing:.18em;color:var(--ink-soft);
  position:relative;padding-block:6px;
}
.nav-links a::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:1px;
  background:var(--clay);transition:right .35s ease}
.nav-links a:hover::after{right:0}
.nav-book{
  border:1px solid var(--ink);padding:9px 18px !important;border-radius:0;
  transition:background .3s,color .3s;
}
.nav-book::after{display:none}
.nav-book:hover{background:var(--ink);color:var(--paper)}
.nav-burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.nav-burger span{width:26px;height:2px;background:var(--ink);transition:.3s}

/* ---------- HERO ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;
  overflow:hidden;z-index:2}
.hero-media{position:absolute;inset:0;z-index:0}
.hero-media::after{content:"";position:absolute;inset:0;
  background:linear-gradient(to top, rgba(15,13,11,.72) 0%, rgba(15,13,11,.15) 45%, rgba(15,13,11,.35) 100%)}
.hero-media img,.hero-media .ph{width:100%;height:100%;object-fit:cover}
.hero-inner{position:relative;z-index:2;width:100%;
  padding:0 var(--gutter) clamp(48px,8vh,96px);color:var(--white)}
.hero .eyebrow{color:rgba(251,249,243,.8)}
.hero h1{
  font-size:clamp(2.6rem,7.2vw,6.6rem);
  text-transform:uppercase;font-weight:500;color:var(--white);
  letter-spacing:-.015em;margin:.18em 0 .32em;
  text-shadow:0 2px 40px rgba(0,0,0,.25);
}
.hero h1 em{font-style:italic;font-weight:400;text-transform:none}
.hero-sub{max-width:46ch;font-size:clamp(1.05rem,1.8vw,1.4rem);
  font-weight:300;color:rgba(251,249,243,.92);margin-bottom:2em}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap}

/* placeholder image fields (no real photos) */
.ph{position:relative;background:var(--paper-2);overflow:hidden;
  display:flex;align-items:center;justify-content:center}
.ph::before{content:"";position:absolute;inset:0;
  background:
    repeating-linear-gradient(135deg, rgba(0,0,0,.025) 0 2px, transparent 2px 22px),
    radial-gradient(120% 120% at 30% 20%, #2A2622 0%, #15110E 60%, #0C0A08 100%);
}
.ph[data-tone="light"]::before{
  background:
    repeating-linear-gradient(135deg, rgba(0,0,0,.03) 0 2px, transparent 2px 22px),
    radial-gradient(120% 120% at 30% 20%, #E7E0D0 0%, #D6CDB8 70%);
}
.ph-label{position:absolute;z-index:2;bottom:14px;right:16px;font-family:var(--display);text-transform:uppercase;
  letter-spacing:.14em;font-size:.68rem;color:rgba(255,255,255,.34)}
.ph[data-tone="light"] .ph-label{color:rgba(0,0,0,.3)}

/* ---------- BUTTONS ---------- */
.btn{display:inline-flex;align-items:center;gap:.7em;font-family:var(--body);
  text-transform:uppercase;letter-spacing:.16em;font-size:.78rem;font-weight:500;
  padding:14px 26px;border:1px solid currentColor;border-radius:0;cursor:pointer;
  transition:background .3s,color .3s,transform .3s;background:none}
.btn .arr{transition:transform .3s}
.btn:hover .arr{transform:translateX(4px)}
.btn-light{color:var(--white)}
.btn-light:hover{background:var(--white);color:var(--ink)}
.btn-dark{color:var(--ink)}
.btn-dark:hover{background:var(--ink);color:var(--paper)}
.btn-clay{color:var(--paper);background:var(--clay);border-color:var(--clay)}
.btn-clay:hover{background:var(--clay-deep);border-color:var(--clay-deep)}
.link-underline{position:relative;text-transform:uppercase;letter-spacing:.16em;
  font-size:.78rem;font-weight:500;padding-bottom:4px;display:inline-flex;gap:.6em;align-items:center}
.link-underline::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;
  background:currentColor;transform:scaleX(1);transform-origin:left;transition:transform .35s}
.link-underline:hover::after{transform:scaleX(.4)}
.link-underline:hover .arr{transform:translateX(4px)}

/* ---------- SECTION HEADERS ---------- */
.sec-head{display:flex;flex-direction:column;gap:18px;margin-bottom:clamp(36px,6vw,72px)}
.sec-head .eyebrow{display:flex;align-items:center;gap:14px}
.sec-head .eyebrow::before{content:"";width:34px;height:1px;background:var(--clay)}
.sec-title{font-size:clamp(2rem,5.5vw,4.4rem);text-transform:uppercase;letter-spacing:-.01em}
.sec-title em{font-style:italic;text-transform:none;font-weight:400}

/* ---------- STORY / EDITORIAL ---------- */
.story{display:grid;grid-template-columns:1fr;gap:clamp(28px,4vw,60px)}
@media(min-width:880px){.story{grid-template-columns:1.1fr .9fr;align-items:center}}
.story-body p{margin-bottom:1.1em;font-size:1.06rem}
.story-body p:first-of-type{font-size:clamp(1.2rem,2vw,1.55rem);line-height:1.45;font-weight:300}
.story-media{aspect-ratio:4/5;min-height:340px}

/* pull quote */
.pquote{border-block:1px solid var(--line);padding-block:clamp(40px,7vw,84px);text-align:center}
.pquote blockquote{font-family:var(--display);font-weight:400;font-style:italic;
  font-size:clamp(1.5rem,4vw,3rem);line-height:1.18;max-width:20ch;margin:0 auto;text-transform:none}
.pquote cite{display:block;margin-top:1.4em;font-family:var(--body);font-style:normal;
  text-transform:uppercase;letter-spacing:.22em;font-size:.72rem;color:var(--grey)}

/* ---------- VALUES / 3-COL ---------- */
.cols3{display:grid;grid-template-columns:1fr;gap:1px;background:var(--line);
  border:1px solid var(--line)}
@media(min-width:780px){.cols3{grid-template-columns:repeat(3,1fr)}}
.cols3 .cell{background:var(--paper);padding:clamp(28px,3.5vw,48px)}
.cell .num{font-family:var(--display);font-size:.8rem;letter-spacing:.1em;color:var(--clay);
  display:block;margin-bottom:18px}
.cell h3{font-size:1.5rem;text-transform:uppercase;margin-bottom:.5em;letter-spacing:-.005em}
.cell p{color:var(--ink-soft);font-size:1rem}

/* ---------- PUB CARDS ---------- */
.pubs-grid{display:grid;grid-template-columns:1fr;gap:clamp(36px,5vw,72px)}
.pub-card{display:grid;grid-template-columns:1fr;gap:24px;align-items:center}
@media(min-width:820px){
  .pub-card{grid-template-columns:1fr 1fr;gap:clamp(32px,4vw,64px)}
  .pub-card:nth-child(even) .pub-card-media{order:2}
}
.pub-card-media{aspect-ratio:3/2;overflow:hidden;position:relative}
.pub-card-media .ph,.pub-card-media img{width:100%;height:100%;transition:transform .9s cubic-bezier(.2,.7,.2,1)}
.pub-card:hover .pub-card-media .ph,.pub-card:hover .pub-card-media img{transform:scale(1.04)}
.pub-status{position:absolute;top:16px;left:16px;z-index:3;background:var(--paper);
  font-family:var(--body);text-transform:uppercase;letter-spacing:.14em;font-size:.64rem;
  font-weight:500;padding:6px 12px;color:var(--ink)}
.pub-status.soon{background:var(--clay);color:var(--paper)}
.pub-card-meta .loc{font-family:var(--body);text-transform:uppercase;letter-spacing:.2em;
  font-size:.72rem;color:var(--grey);margin-bottom:12px;display:flex;gap:12px;align-items:center}
.pub-card-meta .loc::before{content:"";width:24px;height:1px;background:var(--clay)}
.pub-card-meta h3{font-size:clamp(1.8rem,3.4vw,2.8rem);text-transform:uppercase;
  letter-spacing:-.01em;margin-bottom:.5em}
.pub-tagline{font-style:italic;color:var(--clay);font-size:1.1rem;margin-bottom:1em;font-family:var(--display);font-weight:400}
.pub-card-meta p{color:var(--ink-soft);font-size:1rem;margin-bottom:1.4em;max-width:46ch}
.pub-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:1.8em}
.pub-tags span{font-family:var(--body);text-transform:uppercase;letter-spacing:.1em;
  font-size:.64rem;color:var(--grey);border:1px solid var(--line);padding:5px 11px}

/* ---------- FILTER BAR ---------- */
.filters{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:clamp(40px,5vw,68px)}
.filters button{font-family:var(--body);text-transform:uppercase;letter-spacing:.14em;
  font-size:.72rem;font-weight:500;padding:9px 18px;border:1px solid var(--line);
  background:none;color:var(--ink-soft);cursor:pointer;transition:.3s}
.filters button:hover{border-color:var(--ink)}
.filters button.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}

/* ---------- WHAT'S ON ---------- */
.whatson{background:var(--ink);color:var(--paper);position:relative;z-index:2}
.whatson .eyebrow{color:rgba(243,240,232,.6)}
.whatson .eyebrow::before{background:var(--clay)}
.whatson .sec-title{color:var(--paper)}
.whatson-grid{display:grid;grid-template-columns:1fr;gap:1px;background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.12)}
@media(min-width:760px){.whatson-grid{grid-template-columns:repeat(2,1fr)}}
.event{background:var(--ink);padding:clamp(26px,3vw,40px);transition:background .4s}
.event:hover{background:#211D19}
.event .date{font-family:var(--body);text-transform:uppercase;letter-spacing:.18em;
  font-size:.7rem;color:var(--clay);font-weight:500;margin-bottom:14px}
.event h3{font-size:1.5rem;text-transform:uppercase;color:var(--paper);margin-bottom:.5em}
.event p{color:rgba(243,240,232,.7);font-size:.98rem;margin-bottom:1.2em}

/* ---------- CTA BANNER ---------- */
.cta-banner{position:relative;overflow:hidden;text-align:center;z-index:2}
.cta-banner .ph{position:absolute;inset:0;z-index:0}
.cta-banner .ph::after{content:"";position:absolute;inset:0;background:rgba(15,13,11,.6)}
.cta-inner{position:relative;z-index:2;padding-block:clamp(70px,11vw,170px);color:var(--white)}
.cta-inner h2{font-size:clamp(2rem,6vw,5rem);text-transform:uppercase;color:var(--white);margin-bottom:.4em}
.cta-inner p{max-width:48ch;margin:0 auto 2em;color:rgba(251,249,243,.9);font-weight:300;font-size:1.15rem}

/* ---------- FOOTER ---------- */
.footer{background:var(--paper-2);border-top:1px solid var(--line);position:relative;z-index:2}
.footer-top{display:grid;grid-template-columns:1fr;gap:48px;padding-block:clamp(50px,7vw,90px)}
@media(min-width:780px){.footer-top{grid-template-columns:1.4fr 1fr 1fr}}
.footer-logo{font-family:var(--display);text-transform:uppercase;font-weight:600;
  font-size:1.6rem;letter-spacing:.02em;margin-bottom:18px}
.footer-logo .amp{font-style:italic;font-weight:400;text-transform:none}
.footer-tag{color:var(--ink-soft);max-width:34ch;font-size:1rem}
.footer h4{font-family:var(--body);text-transform:uppercase;letter-spacing:.2em;font-size:.72rem;
  color:var(--grey);font-weight:500;margin-bottom:18px}
.footer-col a,.footer-col p{display:block;color:var(--ink-soft);font-size:.96rem;margin-bottom:10px;
  transition:color .25s}
.footer-col a:hover{color:var(--clay)}
.footer-bottom{border-top:1px solid var(--line);padding-block:22px;display:flex;
  flex-wrap:wrap;gap:14px;justify-content:space-between;align-items:center}
.footer-bottom p,.footer-bottom a{font-size:.74rem;text-transform:uppercase;letter-spacing:.12em;color:var(--grey)}
.footer-bottom .fb-links{display:flex;gap:22px;flex-wrap:wrap}
.footer-bottom a:hover{color:var(--ink)}

/* ---------- NEWSLETTER ---------- */
.news{display:flex;gap:12px;flex-wrap:wrap;max-width:420px}
.news input{flex:1;min-width:180px;background:none;border:0;border-bottom:1px solid var(--line);
  padding:10px 2px;font-family:var(--body);font-size:1rem;color:var(--ink)}
.news input:focus{outline:none;border-color:var(--clay)}
.news button{background:none;border:0;border-bottom:1px solid var(--ink);cursor:pointer;
  font-family:var(--body);text-transform:uppercase;letter-spacing:.16em;font-size:.74rem;
  padding:10px 2px;color:var(--ink)}

/* ---------- reveal animation ---------- */
[data-reveal]{opacity:0;transform:translateY(26px);
  transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
[data-reveal].in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  [data-reveal]{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}

/* ---------- generic page hero (interior pages) ---------- */
.page-hero{padding-top:clamp(140px,16vh,200px);padding-bottom:clamp(40px,6vw,80px)}
.page-hero h1{font-size:clamp(2.6rem,8vw,6.5rem);text-transform:uppercase;letter-spacing:-.015em;margin:.2em 0 .3em}
.page-hero h1 em{font-style:italic;text-transform:none;font-weight:400}
.page-hero .lede{max-width:54ch;color:var(--ink-soft)}

/* ---------- mobile nav ---------- */
@media(max-width:860px){
  .nav-burger{display:flex}
  .nav-links{position:fixed;top:0;left:0;width:100vw;height:100vh;height:100svh;
    background:var(--paper);flex-direction:column;
    justify-content:center;align-items:center;gap:30px;transform:translateY(-100%);
    transition:transform .5s cubic-bezier(.7,0,.2,1),visibility .5s;visibility:hidden;z-index:49}
  .nav-links.open{transform:none;visibility:visible}
  .nav-links a{font-size:1.1rem;letter-spacing:.2em}
  .nav-book{padding:14px 28px !important}
}

/* ---- real images dropped into placeholder fields ---- */
.ph.has-img::before{content:none}
.ph.has-img .ph-label{display:none}
.ph.has-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}

/* ---- TTIC Charter ---- */
.charter{list-style:none;margin:0;padding:0;max-width:720px}
.charter li{display:flex;gap:18px;align-items:baseline;padding:14px 0;border-bottom:1px solid var(--line,#DED7C6);font-family:'Spectral',Georgia,serif;font-size:1.08rem;color:var(--ink)}
.charter li:last-child{border-bottom:0}
.charter li span{font-family:'Fraunces',Georgia,serif;font-weight:600;color:var(--brass,#9C3B2A);font-size:.85rem;letter-spacing:.06em;flex:none}
@media (max-width:560px){.charter li{font-size:1rem;gap:14px}}
