/* ── Portfolio Navigation Bar ───────────────── */
.pflio-bar {
  position: fixed;
  top: 0; left: 0;
  width: 100%;
  height: 40px;
  z-index: 99999;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 20px;
  background: rgba(10, 10, 20, 0.92);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  font-family: system-ui, -apple-system, sans-serif;
  font-size: 13px;
  box-sizing: border-box;
}
.pflio-bar a {
  color: rgba(255, 255, 255, 0.75);
  text-decoration: none;
  transition: color 0.2s ease;
  white-space: nowrap;
}
.pflio-bar a:hover { color: #ffffff; }
.pflio-bar a:focus-visible {
  outline: 2px solid rgba(255,255,255,0.5);
  outline-offset: 3px;
  border-radius: 3px;
}
.pflio-bar__back:hover .pflio-bar__arrow { margin-right: 4px; }
.pflio-bar__arrow { display: inline-block; transition: margin 0.2s ease; }
.pflio-bar__label {
  color: rgba(255, 255, 255, 0.45);
  font-size: 12px;
  letter-spacing: 0.02em;
  pointer-events: none;
}
.pflio-bar__diamond {
  color: rgba(255, 255, 255, 0.25);
  margin-right: 6px;
  font-size: 10px;
}
.pflio-bar__arrow-right {
  display: inline-block;
  transition: transform 0.2s ease;
  margin-left: 4px;
}
.pflio-bar__all:hover .pflio-bar__arrow-right { transform: translateX(3px); }
.pflio-bar__all-short { display: none; }

@media (max-width: 600px) {
  .pflio-bar { height: 44px; padding: 0 16px; }
  .pflio-bar__all-text { display: none; }
  .pflio-bar__all-short { display: inline; }
}
@media (max-width: 480px) {
  .pflio-bar__label { display: none; }
}
body { padding-top: 40px; }
@media (max-width: 600px) { body { padding-top: 44px; } }
/* ── End Portfolio Navigation Bar ───────────── */

/* CRUST REPUBLIC — Bold Street Food | Black · Yellow · White | Anton + DM Sans */
:root{
  --clr-bg:#111111;--clr-bg2:#1A1A1A;--clr-yellow:#FFDE21;--clr-yellow-dk:#E0C200;
  --clr-red:#E83A2A;--clr-white:#FFFFFF;--clr-cream:#F5F0E8;
  --clr-text:#F0EDED;--clr-text-lt:#888888;
  --font-display:'Anton',Impact,sans-serif;--font-body:'DM Sans',system-ui,sans-serif;
  --sp-xs:.5rem;--sp-sm:1rem;--sp-md:1.5rem;--sp-lg:2.5rem;--sp-xl:4rem;--sp-2xl:6rem;
  --transition:200ms ease;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);font-size:clamp(1rem,1.1vw,1.05rem);line-height:1.65;color:var(--clr-text);background:var(--clr-bg);-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
ul{list-style:none}
address{font-style:normal}
.skip-link{position:absolute;top:-100%;left:1rem;background:var(--clr-yellow);color:#111;padding:.5em 1em;z-index:9999;font-weight:700}
.skip-link:focus{top:1rem}
.container{width:min(92%,1240px);margin-inline:auto}
.btn{display:inline-flex;align-items:center;padding:.7em 1.8em;border:3px solid transparent;font-family:var(--font-display);font-size:1.1rem;letter-spacing:.08em;cursor:pointer;transition:all var(--transition)}
.btn--primary{background:var(--clr-yellow);color:#111;border-color:var(--clr-yellow)}
.btn--primary:hover,.btn--primary:focus-visible{background:var(--clr-yellow-dk);border-color:var(--clr-yellow-dk);transform:translateY(-2px)}
.btn--outline{background:transparent;color:var(--clr-text);border-color:var(--clr-text)}
.btn--outline:hover{background:var(--clr-text);color:#111}
.btn--dark{background:#111;color:var(--clr-yellow);border-color:#111}
.btn--dark:hover{background:#222}
.btn--full{width:100%;justify-content:center}
:focus-visible{outline:3px solid var(--clr-yellow);outline-offset:3px}
.section{padding-block:var(--sp-2xl);background:var(--clr-bg)}
.section--dark{background:var(--clr-bg2)}
.section--yellow{background:var(--clr-yellow);color:#111}
.section--yellow .section__eyebrow{color:var(--clr-bg)}
.section--yellow .section__title{color:#111}
.section__eyebrow{font-size:.7rem;font-weight:700;letter-spacing:.25em;text-transform:uppercase;color:var(--clr-yellow);margin-bottom:.5rem}
.section__title{font-family:var(--font-display);font-size:clamp(2.5rem,6vw,4.5rem);letter-spacing:.04em;line-height:1;margin-bottom:var(--sp-md);color:var(--clr-text)}
/* HEADER */
.site-header{position:fixed;top:0;left:0;right:0;z-index:100;transition:background var(--transition),border-color var(--transition);border-bottom:3px solid transparent}
.site-header.scrolled{background:rgba(17,17,17,.98);border-color:var(--clr-yellow)}
.header__inner{display:flex;align-items:center;justify-content:space-between;height:62px}
.logo{display:flex;flex-direction:column;line-height:1}
.logo__crust{font-family:var(--font-display);font-size:1.4rem;letter-spacing:.1em;color:var(--clr-yellow)}
.logo__republic{font-family:var(--font-display);font-size:.7rem;letter-spacing:.3em;color:var(--clr-text-lt)}
.nav__list{display:none;gap:var(--sp-lg);list-style:none}
.nav__link{font-family:var(--font-display);font-size:1rem;letter-spacing:.08em;color:var(--clr-text-lt);transition:color var(--transition)}
.nav__link:hover{color:var(--clr-yellow)}
.nav__link--cta{background:var(--clr-yellow);color:#111;padding:.3em .9em}
.nav__link--cta:hover{background:var(--clr-yellow-dk)}
.nav-toggle{display:flex;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.nav-toggle span{display:block;width:24px;height:2.5px;background:var(--clr-text);transition:transform var(--transition),opacity var(--transition)}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}
.mobile-nav{background:#111;border-top:3px solid var(--clr-yellow);padding:var(--sp-md) 5%}
.mobile-nav[hidden]{display:none}
.mobile-nav ul{display:flex;flex-direction:column;gap:var(--sp-sm)}
.mobile-nav a{font-family:var(--font-display);font-size:1.3rem;letter-spacing:.1em;color:var(--clr-text-lt);padding:.5rem 0;display:block;border-bottom:1px solid rgba(255,222,33,.15)}
.mobile-nav a:hover{color:var(--clr-yellow)}
/* HERO */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;background:#111;overflow:hidden}
.hero__bg{position:absolute;inset:0;background:url('https://images.unsplash.com/photo-1574071318508-1cdbab80d002?w=1800&q=80') center/cover no-repeat;opacity:.2}
.hero__content{position:relative;z-index:1;padding-top:5rem}
.hero__badge{display:inline-block;background:var(--clr-yellow);color:#111;font-family:var(--font-display);font-size:.75rem;letter-spacing:.2em;padding:.3em 1em;margin-bottom:var(--sp-md)}
.hero__title{font-family:var(--font-display);font-size:clamp(4.5rem,14vw,11rem);letter-spacing:.02em;line-height:.92;color:var(--clr-text);margin-bottom:var(--sp-md)}
.hero__sub{color:var(--clr-text-lt);font-size:1rem;max-width:500px;margin-bottom:var(--sp-lg);font-weight:300}
.hero__ctas{display:flex;flex-wrap:wrap;gap:var(--sp-sm)}
/* TICKER */
.ticker{background:var(--clr-yellow);overflow:hidden;padding:.6rem 0;border-top:2px solid #111;border-bottom:2px solid #111}
.ticker__track{display:flex;gap:var(--sp-lg);white-space:nowrap;animation:ticker 30s linear infinite;color:#111;font-family:var(--font-display);font-size:1rem;letter-spacing:.1em}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.ticker__track{animation:none}}
/* MENU */
.menu__tabs{display:flex;gap:4px;margin-top:var(--sp-lg);margin-bottom:var(--sp-lg)}
.tab{background:var(--clr-bg2);color:var(--clr-text-lt);border:2px solid transparent;font-family:var(--font-display);font-size:1.2rem;letter-spacing:.08em;padding:.4em 1.4em;cursor:pointer;transition:all var(--transition)}
.tab--active,.tab:hover{background:var(--clr-yellow);color:#111;border-color:var(--clr-yellow)}
.menu__panel--hidden{display:none}
.menu__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,280px),1fr));gap:var(--sp-md)}
.pizza-card{background:var(--clr-bg2);overflow:hidden;transition:transform var(--transition)}
.pizza-card:hover{transform:translateY(-4px)}
.pizza-card img{width:100%;aspect-ratio:4/3;object-fit:cover}
.pizza-card__info{padding:var(--sp-md)}
.pizza-card__info h3{font-family:var(--font-display);font-size:1.3rem;letter-spacing:.06em;color:var(--clr-text);margin-bottom:.4rem}
.pizza-card__info p{font-size:.875rem;color:var(--clr-text-lt);margin-bottom:.75rem;line-height:1.55}
.pizza-card__info strong{font-family:var(--font-display);font-size:1.2rem;color:var(--clr-yellow);margin-right:.5rem}
.pizza-card__info .tag{font-size:.7rem;background:var(--clr-red);color:#fff;padding:.2em .6em;font-weight:700;letter-spacing:.08em}
.slice-list{display:flex;flex-direction:column;gap:var(--sp-sm)}
.menu__item{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--sp-md);padding:var(--sp-sm) 0;border-bottom:2px solid rgba(255,222,33,.1)}
.menu__item-info strong{font-family:var(--font-display);font-size:1.15rem;letter-spacing:.06em;color:var(--clr-text);display:block;margin-bottom:.2rem}
.menu__item-info p{font-size:.875rem;color:var(--clr-text-lt)}
.menu__price{font-family:var(--font-display);font-size:1.1rem;color:var(--clr-yellow);white-space:nowrap;flex-shrink:0}
/* ABOUT */
.about__inner{display:grid;grid-template-columns:1fr;gap:var(--sp-xl);align-items:center}
.about__text p{color:var(--clr-text-lt);margin-bottom:var(--sp-sm)}
.about__text strong{color:var(--clr-text);font-weight:500}
.about__image img{width:100%;aspect-ratio:4/3;object-fit:cover}
/* GALLERY */
.gallery__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-top:var(--sp-lg)}
.gallery__item{overflow:hidden;aspect-ratio:4/3;margin:0}
.gallery__item img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.gallery__item:hover img{transform:scale(1.06)}
/* ORDER / BOOKING */
.order__inner{display:grid;grid-template-columns:1fr;gap:var(--sp-xl)}
.order__info p{color:#333;margin-bottom:var(--sp-sm)}
.contact-block{margin:var(--sp-md) 0;padding:var(--sp-md);background:#fff;border-left:4px solid #111}
.contact-block p{font-size:.875rem;margin-bottom:.4rem;color:#333}
.contact-block a{color:#111;font-weight:700}
.hours h3{font-family:var(--font-display);font-size:1.3rem;letter-spacing:.08em;color:#111;margin-bottom:.5rem}
.hours ul li{display:flex;justify-content:space-between;font-size:.875rem;color:#555;padding:.3rem 0;border-bottom:2px solid rgba(0,0,0,.1)}
.delivery-badges{margin-top:var(--sp-md);display:flex;align-items:center;gap:var(--sp-sm);flex-wrap:wrap}
.delivery-label{font-size:.8rem;font-weight:700;color:#333;text-transform:uppercase;letter-spacing:.1em}
.badge{background:#111;color:var(--clr-yellow);font-family:var(--font-display);font-size:.8rem;letter-spacing:.1em;padding:.35em 1em}
.form-title{font-family:var(--font-display);font-size:1.8rem;letter-spacing:.06em;color:#111;margin-bottom:var(--sp-md)}
.form-group{display:flex;flex-direction:column;gap:.4rem;margin-bottom:var(--sp-sm)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-sm)}
.form-group label{font-family:var(--font-display);font-size:.9rem;letter-spacing:.1em;color:#111}
.form-group input,.form-group select,.form-group textarea{padding:.75rem 1rem;border:2px solid rgba(0,0,0,.2);background:#fff;font-family:var(--font-body);font-size:.95rem;color:#111;transition:border-color var(--transition)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#111}
.form-error{font-size:.8rem;color:var(--clr-red);min-height:1.1em}
.form-success{color:#111;font-family:var(--font-display);font-size:1.1rem;letter-spacing:.06em;text-align:center;margin-top:var(--sp-sm)}
/* FOOTER */
.site-footer{background:#000;border-top:3px solid var(--clr-yellow)}
.footer__inner{display:grid;grid-template-columns:1fr;gap:var(--sp-xl);padding:var(--sp-2xl) 0 var(--sp-xl);border-bottom:1px solid rgba(255,222,33,.1)}
.footer__logo{font-family:var(--font-display);font-size:1.6rem;letter-spacing:.1em;color:var(--clr-yellow);margin-bottom:.5rem;display:flex;flex-direction:column;line-height:1}
.footer__logo span{font-size:.7rem;letter-spacing:.3em;color:var(--clr-text-lt)}
.footer__col p{font-size:.875rem;line-height:1.7;color:var(--clr-text-lt)}
.footer__col h3{font-family:var(--font-display);font-size:1rem;letter-spacing:.15em;color:var(--clr-yellow);margin-bottom:.75rem}
.footer__col a{color:var(--clr-text-lt);transition:color var(--transition)}
.footer__col a:hover{color:var(--clr-yellow)}
.footer__hours li{display:flex;justify-content:space-between;font-size:.85rem;color:var(--clr-text-lt);border-bottom:1px solid rgba(255,222,33,.08);padding-bottom:.35rem;margin-bottom:.35rem}
.footer__social{display:flex;gap:var(--sp-sm);margin-top:var(--sp-sm)}
.footer__social a{color:rgba(255,222,33,.35);transition:color var(--transition)}
.footer__social a:hover{color:var(--clr-yellow)}
.footer__bottom{padding:var(--sp-md) 0;text-align:center;font-size:.75rem;color:rgba(255,222,33,.2)}
@media(min-width:768px){.nav__list{display:flex}.nav-toggle{display:none}.mobile-nav{display:none!important}.about__inner{grid-template-columns:1fr 1fr}.order__inner{grid-template-columns:1fr 1fr}.footer__inner{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.footer__inner{grid-template-columns:repeat(4,1fr)}}
@media(max-width:767px){.gallery__grid{grid-template-columns:repeat(2,1fr)}.form-row{grid-template-columns:1fr}}
@media(prefers-reduced-motion:reduce){*{transition-duration:.01ms!important}html{scroll-behavior:auto}}