/* The Porch — theme styles. Brand colors (teal/navy/rattan/paper + derived
   deeps) are injected inline from the Customizer; the rest live here. */

:root{
  --teal:#00A8A2;
  --teal-deep:#0B7B76;
  --teal-soft:#E4F3F1;
  --navy:#1E2D44;
  --navy-deep:#16223A;
  --paper:#FCFBF6;
  --cream:#F6F1E6;
  --sand:#EFE7D6;
  --rattan:#C49A68;
  --brass:#AC8438;
  --ink:#1B2433;
  --ink-soft:#54627A;
  --line:rgba(27,36,51,.14);
  --maxw:1180px;
  --display:"Cormorant Garamond",Georgia,serif;
  --script:"Allura",cursive;
  --body:"Hanken Grotesk",system-ui,-apple-system,sans-serif;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--body);
  font-size:18px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;}
a{color:inherit;}
img{max-width:100%;height:auto;display:block;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;}

.screen-reader-text{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0;}
.skip-link{position:fixed;left:8px;top:-60px;z-index:200;background:var(--teal);color:#fff;
  padding:10px 16px;border-radius:8px;transition:top .2s;text-decoration:none;font-weight:600;}
.skip-link:focus{top:8px;}

.drule{border:0;height:6px;border-top:2px solid var(--teal);border-bottom:2px solid var(--teal);background:transparent;margin:0;}
.eyebrow{font-family:var(--display);font-weight:600;font-size:.92rem;letter-spacing:.34em;
  text-transform:uppercase;color:var(--teal-deep);display:inline-block;}

/* NAV */
.site-header{position:sticky;top:0;z-index:60;background:color-mix(in srgb,var(--paper) 88%,transparent);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line);}
.bar{display:flex;align-items:center;justify-content:space-between;height:78px;gap:18px;}
.brand img,.custom-logo{height:46px!important;width:auto!important;}
.brand-link{display:inline-block;}
nav.links{display:flex;align-items:center;gap:28px;}
nav.links ul{display:flex;align-items:center;gap:28px;list-style:none;margin:0;padding:0;}
nav.links a{text-decoration:none;font-weight:500;font-size:.83rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--ink-soft);transition:color .2s;}
nav.links a:hover,nav.links a.active,nav.links .current-menu-item>a{color:var(--teal-deep);}
.cta{text-decoration:none;font-weight:600;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;
  background:var(--teal);color:#fff!important;padding:12px 20px;border-radius:999px;transition:.2s;white-space:nowrap;}
.cta:hover{background:var(--teal-deep);transform:translateY(-1px);}
.header-right{display:flex;align-items:center;gap:14px;}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;}
.burger span{width:25px;height:2px;background:var(--ink);display:block;transition:.2s;}

/* Open badge */
.open-badge{display:inline-flex;align-items:center;gap:8px;font-size:.72rem;letter-spacing:.08em;
  text-transform:uppercase;font-weight:600;color:var(--ink-soft);white-space:nowrap;}
.open-badge i{width:8px;height:8px;border-radius:50%;background:#bbb;display:inline-block;}
.open-badge.open i{background:#1db981;box-shadow:0 0 0 0 rgba(29,185,129,.5);animation:pulse 2.4s infinite;}
.open-badge.open .ob-text{color:var(--teal-deep);}
.open-badge.closed i{background:#c2553f;}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(29,185,129,.5);}70%{box-shadow:0 0 0 7px rgba(29,185,129,0);}100%{box-shadow:0 0 0 0 rgba(29,185,129,0);}}

/* HERO */
.hero{position:relative;min-height:84vh;display:flex;align-items:flex-end;
  background:#0d2030 center 42%/cover no-repeat;background-image:var(--hero-img);}
.hero::after{content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(13,28,40,.82) 0%,rgba(13,28,40,.5) 42%,rgba(13,28,40,.12) 100%),
             linear-gradient(0deg,rgba(13,28,40,.6) 0%,rgba(13,28,40,0) 40%);}
.hero-inner{position:relative;z-index:2;padding:0 28px 9vh;max-width:708px;margin:0 auto;width:100%;}
.hero img.logo{width:min(420px,72vw);margin-bottom:26px;filter:drop-shadow(0 4px 18px rgba(0,0,0,.35));}
.hero .kicker{color:#CFE9E6;font-family:var(--display);letter-spacing:.32em;text-transform:uppercase;
  font-weight:600;font-size:.9rem;margin-bottom:16px;}
.hero h1{font-family:var(--display);font-weight:500;color:#fff;line-height:1.04;
  font-size:clamp(2.1rem,5vw,3.5rem);margin:0 0 22px;max-width:18ch;}
.hero h1 em{font-style:italic;color:#7FE3DC;}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;}
.btn{text-decoration:none;font-weight:600;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;
  padding:15px 26px;border-radius:999px;transition:.2s;display:inline-block;}
.btn-fill{background:var(--teal);color:#fff;}
.btn-fill:hover{background:#fff;color:var(--navy);transform:translateY(-2px);}
.btn-ghost{border:1.5px solid rgba(255,255,255,.6);color:#fff;}
.btn-ghost:hover{background:rgba(255,255,255,.14);}

.scallop{height:26px;background:var(--teal);
  -webkit-mask:radial-gradient(13px at 50% 0,#0000 96%,#000) 0 0/27px 100% repeat-x;
          mask:radial-gradient(13px at 50% 0,#0000 96%,#000) 0 0/27px 100% repeat-x;}

/* DAY ARC */
.arc{padding:64px 0 18px;}
.arc-track{position:relative;height:2px;margin:46px 8px 14px;
  background:linear-gradient(90deg,var(--teal) 0%,var(--rattan) 52%,var(--navy) 100%);}
.arc-track i{position:absolute;top:50%;transform:translate(-50%,-50%);width:11px;height:11px;border-radius:50%;
  background:var(--paper);border:2px solid var(--teal);}
.arc-track i:nth-child(2){left:50%;border-color:var(--rattan);}
.arc-track i:nth-child(3){left:100%;border-color:var(--navy);}
.arc-labels{display:flex;justify-content:space-between;font-family:var(--display);
  text-transform:uppercase;letter-spacing:.2em;font-weight:600;font-size:.82rem;color:var(--ink-soft);}

/* SECTIONS */
section{padding:92px 0;}
.sec-head{max-width:56ch;}
.sec-head h2{font-family:var(--display);font-weight:500;line-height:1.05;letter-spacing:-.01em;
  font-size:clamp(2.1rem,4.6vw,3.3rem);margin:.45em 0 .35em;}
.sec-head h2 em{font-style:italic;color:var(--teal-deep);}
.sec-head p{color:var(--ink-soft);margin:0;max-width:52ch;}

#moments{background:var(--cream);}
.twoup{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin-top:50px;}
.moment{background:var(--paper);border:1px solid var(--line);border-radius:14px;overflow:hidden;
  display:flex;flex-direction:column;transition:transform .25s,box-shadow .25s;}
.moment:hover{transform:translateY(-4px);box-shadow:0 20px 44px -26px rgba(27,36,51,.5);}
.moment .ph{height:240px;background-size:cover;background-position:center;}
.moment .mb{padding:30px 30px 34px;display:flex;flex-direction:column;flex:1;}
.moment .tag{font-family:var(--display);font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  font-size:.82rem;color:var(--teal-deep);}
.moment h3{font-family:var(--display);font-weight:600;font-size:2rem;margin:.3em 0 .35em;}
.moment p{color:var(--ink-soft);margin:0 0 22px;}
.moment .hrs{margin-top:auto;border-top:1px solid var(--line);padding-top:16px;font-size:.94rem;
  display:flex;flex-direction:column;gap:6px;}
.moment .hrs .r{display:flex;justify-content:space-between;gap:14px;}
.moment .hrs .r span:last-child{font-weight:600;font-variant-numeric:tabular-nums;}

/* MENU */
#menu{background:var(--paper);}
.menu-wrap{margin-top:48px;background:var(--cream);border:1px solid var(--line);border-radius:16px;
  padding:46px clamp(22px,4vw,56px);}
.menu-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:42px 48px;}
.mcol{min-width:0;}
.mblock{margin-bottom:34px;}
.mhead{font-family:var(--display);font-weight:600;text-transform:uppercase;letter-spacing:.14em;
  color:var(--teal-deep);font-size:1.5rem;line-height:1;display:flex;align-items:baseline;
  justify-content:space-between;gap:12px;}
.mhead small{font-family:var(--body);font-weight:600;letter-spacing:.04em;font-size:.66rem;
  color:var(--ink-soft);text-transform:none;white-space:nowrap;}
.mblock .drule{margin:12px 0 16px;}
.m-row{display:grid;grid-template-columns:1fr auto;gap:4px 14px;padding:5px 0;align-items:baseline;}
.m-row.two{grid-template-columns:1fr auto auto;}
.m-name{font-weight:600;letter-spacing:.08em;text-transform:uppercase;font-size:.82rem;color:var(--navy);}
.m-desc{grid-column:1/-1;font-size:.8rem;color:var(--ink-soft);margin-top:-2px;}
.m-price{font-weight:600;font-size:.84rem;color:var(--teal-deep);font-variant-numeric:tabular-nums;
  min-width:42px;text-align:right;}
.syrups{columns:2;column-gap:18px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  font-size:.8rem;color:var(--navy);}
.syrups span{display:block;padding:3px 0;}
.menu-note{margin-top:30px;text-align:center;color:var(--ink-soft);font-size:.86rem;}
.menu-note a{color:var(--teal-deep);}

/* ABOUT */
#space{background:var(--navy);color:#EAF1F2;}
#space .eyebrow{color:#7FD8D2;}
.space-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center;}
#space h2{font-family:var(--display);font-weight:500;color:#fff;line-height:1.06;
  font-size:clamp(2rem,4.4vw,3.1rem);margin:.4em 0 .5em;}
#space h2 em{font-style:italic;color:#7FE3DC;}
#space p{color:#C4D2D6;margin:0 0 18px;}
.space-photo{border-radius:14px;overflow:hidden;aspect-ratio:4/3;background:#0e1f2e center/cover no-repeat;background-size:cover;}
.facts{display:flex;gap:34px;margin-top:26px;flex-wrap:wrap;}
.facts .f .n{font-family:var(--display);font-size:2.1rem;font-weight:600;color:#7FE3DC;line-height:1;}
.facts .f .l{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:#9DB0B5;margin-top:6px;}

/* GALLERY */
#gallery{background:var(--paper);padding-top:92px;}
.gal{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px;margin-top:46px;}
.gal figure{margin:0;overflow:hidden;border-radius:12px;background:var(--sand) center/cover no-repeat;
  background-size:cover;transition:transform .6s ease;}
.gal figure:hover{transform:scale(1.02);}
.gal .tall{grid-row:span 2;}
.gal .wide{grid-column:span 2;}

/* VISIT */
#visit{background:var(--cream);}
.visit-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;margin-top:48px;}
.vb{margin-bottom:30px;}
.vb h4{font-family:var(--display);font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  color:var(--teal-deep);font-size:.9rem;margin:0 0 10px;}
.vb .big{font-family:var(--display);font-size:1.5rem;font-weight:600;margin:0;line-height:1.3;}
.vb .phone-block{font-family:var(--body);font-size:1.1rem;font-weight:600;}
.vb a{color:var(--teal-deep);text-decoration:none;border-bottom:1px solid var(--line);}
.vb a:hover{border-color:var(--teal);}
.inline-soc{display:flex;gap:24px;margin-top:14px;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;}
.inline-soc a{border-bottom:0;color:var(--teal-deep);}
.vhours .vr{display:flex;justify-content:space-between;gap:18px;padding:11px 0;border-bottom:1px solid var(--line);font-size:.96rem;}
.vhours .vr span:last-child{font-weight:600;font-variant-numeric:tabular-nums;}
.vhours .vr.am span:last-child{color:var(--teal-deep);}
.mapbtn{display:inline-flex;align-items:center;gap:.5em;margin-top:20px;text-decoration:none;font-weight:600;
  font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;background:var(--teal);color:#fff!important;
  padding:13px 22px;border-radius:999px;transition:.2s;border:0;}
.mapbtn:hover{background:var(--teal-deep);transform:translateY(-2px);}

/* FOOTER */
.site-footer{background:var(--navy-deep);color:#9DB0B5;padding:60px 0 38px;}
.foot{display:flex;justify-content:space-between;gap:36px;flex-wrap:wrap;align-items:center;}
.foot img{height:54px;}
.fsoc{display:flex;gap:24px;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;}
.fsoc a{color:#B9C7CC;text-decoration:none;border-bottom:1px solid transparent;transition:.2s;}
.fsoc a:hover{color:#fff;border-color:var(--teal);}
.fbase{margin-top:36px;padding-top:22px;border-top:1px solid rgba(255,255,255,.1);
  display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:.78rem;color:#74878D;}
.fbase a{color:#9fb1b6;}

/* Simple post/page content */
.post-card{padding:22px 0;border-bottom:1px solid var(--line);}
.entry-content h2,.entry-content h3{font-family:var(--display);}
.page-title,.entry-title-list{font-family:var(--display);font-weight:600;}

/* REVEAL */
.reveal{opacity:1;transform:none;}
.js .reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease;}
.reveal.in{opacity:1;transform:none;}

/* RESPONSIVE */
@media (max-width:900px){
  .twoup,.space-grid,.visit-grid{grid-template-columns:1fr;gap:34px;}
  .menu-grid{grid-template-columns:1fr 1fr;gap:32px;}
  .space-photo{aspect-ratio:16/10;}
}
@media (max-width:760px){
  nav.links{position:fixed;inset:78px 0 auto 0;flex-direction:column;gap:0;background:var(--paper);
    border-bottom:1px solid var(--line);transform:translateY(-130%);transition:transform .3s ease;padding:6px 0;}
  nav.links.open{transform:none;}
  nav.links ul{flex-direction:column;gap:0;width:100%;}
  nav.links a{padding:15px 28px;width:100%;display:block;}
  nav.links .cta{margin:10px 28px;text-align:center;}
  .burger{display:flex;}
  .open-badge{display:none;}
  .menu-grid{grid-template-columns:1fr;}
  .gal{grid-template-columns:repeat(2,1fr);}
  .gal .wide{grid-column:span 2;}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto;}
  .js .reveal{opacity:1;transform:none;transition:none;}
}
:focus-visible{outline:3px solid var(--brass);outline-offset:3px;border-radius:4px;}

/* Back to top */
.to-top{position:fixed;right:20px;bottom:20px;z-index:70;width:46px;height:46px;border:0;cursor:pointer;
  border-radius:50%;background:var(--teal);color:#fff;font-size:1.2rem;line-height:1;
  box-shadow:0 10px 26px -10px rgba(0,0,0,.5);opacity:0;transform:translateY(12px);
  transition:opacity .25s,transform .25s,background .2s;}
.to-top.show{opacity:1;transform:none;}
.to-top:hover{background:var(--teal-deep);}
@media (prefers-reduced-motion:reduce){.to-top{transition:none;}}


/* ---- Refinements: gallery balance, hero legibility, overflow guard ---- */

/* Prevent any accidental horizontal scroll on small screens */
html, body { overflow-x: hidden; }

/* Balance the gallery: let the 4th tile fill the empty row so there is
   no awkward gap under the wide image on desktop. */
.gal figure:nth-child(4) { grid-column: span 3; }

/* Improve contrast/legibility of the pale hero kicker over lighter
   areas of the background photo. */
.hero .kicker { text-shadow: 0 1px 6px rgba(0,0,0,.45); }

@media (max-width: 760px) {
  /* On mobile the gallery collapses to a single column, so reset spans
     to keep every photo full-width and evenly sized. */
  .gal { grid-template-columns: 1fr; }
  .gal figure,
  .gal .tall,
  .gal .wide,
  .gal figure:nth-child(4) { grid-column: auto; grid-row: auto; }
}

