/* ===========================================================
   Athelstone Take Away — local chippy, navy + sea-green brand
   Display: Anton  ·  Body: Hanken Grotesk
   =========================================================== */

:root{
  --navy:#222163;
  --navy-900:#191747;
  --navy-700:#2e2d86;
  --green:#2e9078;
  --green-deep:#237a64;
  --green-bright:#46c695;
  --cream:#f7f3e9;
  --cream-2:#efe7d4;
  --gold:#e9a33c;
  --ink:#1b1b2b;
  --muted:#5d5d72;
  --white:#fff;
  --line:rgba(34,33,99,.12);

  --wrap:1200px;
  --r:12px;
  --r-sm:8px;
  --shadow:0 18px 50px -22px rgba(25,23,71,.45);
  --shadow-sm:0 8px 24px -14px rgba(25,23,71,.4);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;
  font-family:"Hanken Grotesk",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink);
  background:var(--white);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{margin:0;font-weight:700;line-height:1.1}
p{margin:0}
.wrap{width:min(var(--wrap),100% - 48px);margin-inline:auto}

/* ---------- display type ---------- */
.hero__title,.sec-title,.feed-card h3,.menu-block__title,.pack__price,.brand__name,
.price-ticket__num,.strip span,.foot-name{
  font-family:"Anton",Impact,sans-serif;font-weight:400;
  text-transform:uppercase;letter-spacing:.01em;line-height:.95;
}

/* ---------- buttons ---------- */
.btn{
  --bg:var(--green);--fg:#fff;
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  background:var(--bg);color:var(--fg);
  font-weight:800;font-size:1rem;line-height:1;
  padding:.85em 1.25em;border-radius:var(--r-sm);border:2px solid transparent;
  cursor:pointer;transition:transform .15s ease,background .2s ease,box-shadow .2s ease;
  white-space:nowrap;
}
.btn .ico{width:1.15em;height:1.15em;fill:currentColor;flex:none}
.btn:hover{transform:translateY(-2px)}
.btn--call{--bg:var(--green);box-shadow:0 10px 22px -12px rgba(35,122,100,.9)}
.btn--call:hover{--bg:var(--green-deep)}
.btn--solid{--bg:var(--navy)}
.btn--solid:hover{--bg:var(--navy-700)}
.btn--ghost{--bg:transparent;--fg:var(--cream);border-color:rgba(247,243,233,.45)}
.btn--ghost:hover{--bg:rgba(247,243,233,.12);border-color:var(--cream)}
.btn--lg{font-size:1.06rem;padding:1.05em 1.6em}

/* ---------- utility bar ---------- */
.utilbar{background:var(--navy-900);color:var(--cream);font-size:.82rem;font-weight:600}
.utilbar__inner{display:flex;justify-content:space-between;align-items:center;gap:16px;min-height:38px}
.utilbar__loc,.utilbar__phone{display:inline-flex;align-items:center;gap:.5em;letter-spacing:.01em}
.utilbar .ico{width:15px;height:15px;fill:var(--green-bright)}
.utilbar__phone{color:#fff}
.utilbar__phone:hover{color:var(--green-bright)}

/* ---------- header ---------- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.96);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.site-header__inner{display:flex;align-items:center;gap:20px;min-height:74px}
.brand{display:flex;align-items:center;gap:12px;margin-right:auto}
.brand__mark{width:46px;height:46px;object-fit:contain}
.brand__name{font-size:1.42rem;color:var(--navy);display:flex;flex-direction:column;line-height:.82}
.brand__name span{color:var(--green);font-size:.66em}
.nav{display:flex;gap:30px}
.nav a{font-weight:700;font-size:.97rem;color:var(--navy);position:relative;padding:4px 0}
.nav a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:3px;background:var(--green);transition:right .25s ease}
.nav a:hover::after{right:0}
.nav__cta{display:inline-flex}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;padding:8px;cursor:pointer}
.nav-toggle span{width:26px;height:3px;background:var(--navy);border-radius:2px;transition:.25s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* mobile menu — BASE hidden on all widths, shown only when open on mobile */
.mobile-menu{display:none}
.mobile-menu[hidden]{display:none}

/* ---------- hero ---------- */
.hero{position:relative;background:var(--navy);color:var(--cream);overflow:hidden;isolation:isolate}
.hero::before{content:"";position:absolute;inset:0;background:
  radial-gradient(120% 80% at 100% 0%,rgba(46,144,120,.28),transparent 60%),
  linear-gradient(180deg,var(--navy-900),var(--navy));z-index:-2}
.hero__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center;padding:74px 0 86px}
.hero__kick{font-weight:800;text-transform:uppercase;letter-spacing:.22em;font-size:.8rem;color:var(--green-bright);margin-bottom:18px}
.hero__title{font-size:clamp(3rem,6.5vw,5.4rem);color:var(--white)}
.hero__title .hl{color:var(--gold)}
.hero__lead{margin:24px 0 32px;font-size:1.16rem;line-height:1.55;color:rgba(247,243,233,.86);max-width:34ch}
.hero__actions{display:flex;flex-wrap:wrap;gap:14px}
.hero__hours{margin-top:26px;font-weight:600;font-size:.95rem;color:rgba(247,243,233,.72)}

.hero__media{position:relative}
.photo-card{margin:0;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);border:5px solid var(--white);rotate:1.4deg}
.photo-card img{width:100%;height:430px;object-fit:cover}
.photo-card figcaption{background:var(--white);color:var(--muted);font-size:.84rem;font-weight:600;padding:10px 14px;text-align:center}
.price-ticket{position:absolute;left:-22px;bottom:38px;background:var(--gold);color:var(--navy);
  padding:12px 18px;border-radius:var(--r-sm);box-shadow:var(--shadow-sm);rotate:-5deg;text-align:center}
.price-ticket__label{display:block;font-weight:800;font-size:.72rem;text-transform:uppercase;letter-spacing:.05em}
.price-ticket__num{display:block;font-size:1.9rem;line-height:.9;margin-top:2px}

/* ---------- marquee strip ---------- */
.strip{background:var(--green);color:var(--navy);overflow:hidden;border-block:4px solid var(--navy-900)}
.strip__track{display:flex;align-items:center;gap:0;white-space:nowrap;width:max-content;
  animation:marquee 26s linear infinite;padding:13px 0}
.strip span:not(.dot){font-size:1.18rem;padding:0 22px;letter-spacing:.03em}
.strip .dot{width:9px;height:9px;background:var(--navy);rotate:45deg;flex:none}
@keyframes marquee{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.strip__track{animation:none}}

/* ---------- section heads ---------- */
.sec-head{max-width:760px;margin-bottom:46px}
.sec-title{font-size:clamp(2.1rem,4.3vw,3.2rem);color:var(--navy)}
.sec-sub{margin-top:16px;font-size:1.1rem;color:var(--muted)}
.sec-head--light .sec-title{color:var(--white)}
.sec-head--light .sec-sub{color:rgba(247,243,233,.8)}

/* ---------- what we do ---------- */
.feeds{padding:88px 0;background:var(--cream)}
.feed-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.feed-card{padding:34px 30px 30px;border-radius:var(--r);display:flex;flex-direction:column;gap:14px;min-height:236px}
.feed-card h3{font-size:1.9rem}
.feed-card p{font-size:1rem;line-height:1.5}
.feed-card__from{margin-top:auto;font-weight:600;font-size:.95rem;opacity:.9}
.feed-card__from strong{font-weight:800}
.feed-card--navy{background:var(--navy);color:var(--cream)}
.feed-card--navy h3{color:var(--white)}
.feed-card--green{background:var(--green);color:#fff}
.feed-card--cream{background:var(--white);color:var(--ink);border:1px solid var(--line)}
.feed-card--cream h3{color:var(--navy)}

.feed-photos{display:grid;grid-template-columns:1fr 1fr 1.4fr;gap:20px;margin-top:26px}
.feed-photos figure{margin:0;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm)}
.feed-photos img{width:100%;height:300px;object-fit:cover}
.feed-quote{background:var(--navy);color:var(--cream);border-radius:var(--r);padding:32px;display:flex;flex-direction:column;justify-content:center;gap:20px}
.feed-quote p{font-family:"Anton",sans-serif;text-transform:uppercase;font-size:1.5rem;line-height:1.04;color:var(--white)}

/* ---------- family packs ---------- */
.packs{position:relative;padding:88px 0;background:var(--navy);overflow:hidden;isolation:isolate}
.packs::before{content:"";position:absolute;inset:0;background:radial-gradient(90% 70% at 0% 0%,rgba(46,144,120,.22),transparent 55%);z-index:-1}
.pack-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.pack{background:rgba(255,255,255,.05);border:1px solid rgba(247,243,233,.16);border-radius:var(--r);padding:26px;color:var(--cream);display:flex;flex-direction:column;gap:12px}
.pack__top{display:flex;align-items:baseline;justify-content:space-between;gap:12px}
.pack h3{font-size:1.32rem;font-weight:800;color:var(--white)}
.pack__price{font-size:2.05rem;color:var(--gold)}
.pack p{font-size:.98rem;color:rgba(247,243,233,.8);line-height:1.45}
.pack__tag{margin-top:auto;align-self:flex-start;background:var(--green);color:#fff;font-weight:700;font-size:.78rem;padding:5px 12px;border-radius:999px;text-transform:uppercase;letter-spacing:.04em}
.pack--hero{background:var(--green);border-color:transparent}
.pack--hero p{color:rgba(255,255,255,.92)}
.pack--hero .pack__price{color:#fff}
.pack--hero .pack__tag{background:var(--navy-900)}
.pack--cta{background:transparent;border-style:dashed;align-items:flex-start;justify-content:center;gap:18px}
.pack--cta p{font-size:1.1rem;color:var(--cream)}

/* ---------- menu ---------- */
.menu{padding:88px 0;background:var(--cream-2)}
.menu-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px 56px}
.menu-col{display:flex;flex-direction:column;gap:36px}
.menu-block{background:var(--white);border-radius:var(--r);padding:28px 30px;box-shadow:var(--shadow-sm)}
.menu-block__title{font-size:1.6rem;color:var(--navy);padding-bottom:12px;margin-bottom:14px;border-bottom:4px solid var(--green);display:inline-block}
.menu-note{font-size:.9rem;color:var(--muted);margin:-6px 0 14px}
.menu-list{list-style:none;margin:0;padding:0}
.menu-list li{display:flex;align-items:baseline;gap:8px;padding:9px 0;border-bottom:1px dotted rgba(34,33,99,.18)}
.menu-list li:last-child{border-bottom:0}
.menu-list .mi{font-weight:600;color:var(--ink)}
.menu-list .mi em{font-style:normal;color:var(--muted);font-weight:500;font-size:.9em}
.menu-list .md{flex:1;border-bottom:1px dotted rgba(34,33,99,.28);translate:0 -4px}
.menu-list .mp{font-weight:800;color:var(--green-deep)}
.menu-foot{text-align:center;margin-top:34px;color:var(--muted);font-size:.95rem}

/* ---------- find us ---------- */
.find{padding:88px 0;background:var(--white)}
.find__grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.find__lead{margin:18px 0 28px;font-size:1.1rem;color:var(--muted)}
.find__rows{display:flex;flex-direction:column;gap:22px;margin-bottom:30px}
.find-row{display:flex;gap:16px;align-items:flex-start}
.find-row .ico{width:26px;height:26px;fill:var(--green);flex:none;margin-top:3px}
.find-row strong{color:var(--navy)}
.find-row a:hover{color:var(--green)}
.hours{border-collapse:collapse;margin-top:8px;font-size:.97rem}
.hours th{text-align:left;font-weight:700;color:var(--navy);padding:3px 22px 3px 0;white-space:nowrap}
.hours td{color:var(--muted);padding:3px 0}
.hours .closed{color:var(--gold);font-weight:700}
.find__map{border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);border:5px solid var(--white);height:430px}
.find__map iframe{width:100%;height:100%;border:0;filter:saturate(1.05)}

/* ---------- footer ---------- */
.site-footer{background:var(--navy-900);color:rgba(247,243,233,.78)}
.site-footer__inner{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:34px;padding:64px 0 40px}
.foot-brand{display:flex;gap:16px;align-items:flex-start}
.foot-mark{width:54px;height:54px;object-fit:contain;flex:none}
.foot-name{display:block;font-size:1.5rem;color:var(--white)}
.foot-tag{display:block;margin-top:8px;font-size:.95rem;max-width:30ch}
.foot-col h4{color:var(--green-bright);text-transform:uppercase;letter-spacing:.08em;font-size:.82rem;margin-bottom:14px}
.foot-col p{font-size:.95rem;line-height:1.7}
.foot-col a{color:rgba(247,243,233,.78)}
.foot-col a:hover{color:#fff}
.foot-col .btn{margin-top:14px}
.foot-phone{display:block;font-family:"Anton",sans-serif;font-size:1.45rem;color:var(--white);margin-bottom:14px}
.site-footer__base{display:flex;justify-content:space-between;align-items:center;gap:12px;
  padding:20px 0 28px;border-top:1px solid rgba(247,243,233,.14);font-size:.85rem}
.jtn-credit{color:rgba(247,243,233,.6)}
.jtn-credit a{color:rgba(247,243,233,.78);font-weight:700}
.jtn-credit a:hover{color:var(--green-bright)}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ===========================================================
   RESPONSIVE
   =========================================================== */
@media (max-width:980px){
  .nav,.nav__cta{display:none}
  .nav-toggle{display:flex}
  .hero__grid{grid-template-columns:1fr;gap:40px;padding:54px 0 64px}
  .hero__media{max-width:520px}
  .feed-photos{grid-template-columns:1fr 1fr}
  .feed-quote{grid-column:1 / -1}
  .find__grid{grid-template-columns:1fr;gap:36px}
  .find__map{height:340px}
  .site-footer__inner{grid-template-columns:1fr 1fr;gap:30px}
  .foot-brand{grid-column:1 / -1}

  .mobile-menu{display:none}
  .mobile-menu.open{display:flex;flex-direction:column;gap:4px;
    position:fixed;inset:74px 0 auto 0;background:var(--navy);
    padding:18px 24px 26px;box-shadow:var(--shadow);z-index:49}
  .mobile-menu.open a{color:var(--cream);font-weight:700;font-size:1.15rem;padding:14px 4px;border-bottom:1px solid rgba(247,243,233,.12)}
  .mobile-menu.open a:last-child{border-bottom:0;margin-top:10px;justify-content:center}
}

@media (max-width:640px){
  body{font-size:16px}
  .wrap{width:min(var(--wrap),100% - 32px)}
  .utilbar__loc{display:none}
  .utilbar__inner{justify-content:center}
  .feeds,.packs,.menu,.find{padding:60px 0}
  .feed-cards{grid-template-columns:1fr}
  .feed-photos{grid-template-columns:1fr}
  .feed-photos img{height:240px}
  .pack-grid{grid-template-columns:1fr}
  .menu-grid{grid-template-columns:1fr;gap:36px}
  .hero__actions .btn{width:100%}
  .photo-card{rotate:0deg}
  .price-ticket{left:auto;right:14px;bottom:-18px}
  .site-footer__inner{grid-template-columns:1fr;gap:28px}
  .site-footer__base{flex-direction:column;text-align:center}
}
