/* ============================================================
   Broke'n Dessertz — main.css
   ============================================================ */

/* ── Design Tokens ─────────────────────────────────────────── */
:root {
  --color-bg:         #1a0a00;
  --color-bg-light:   #2b1200;
  --color-surface:    #3a1a05;
  --color-surface-2:  #4e2408;

  --color-primary:    #d4843c;
  --color-primary-dk: #b56626;
  --color-gold:       #e8b86d;
  --color-cream:      #f5e6ce;
  --color-text:       #f0dfc0;
  --color-muted:      #a0876a;
  --color-white:      #fff8f0;

  --font-heading: 'Playfair Display', Georgia, serif;
  --font-body:    'Lato', 'Helvetica Neue', Arial, sans-serif;

  --radius-sm: 6px;
  --radius-md: 12px;
  --radius-lg: 24px;
  --radius-xl: 48px;

  --shadow-card: 0 4px 24px rgba(0,0,0,0.45);
  --shadow-glow: 0 0 32px rgba(212,132,60,0.18);
  --transition:  0.25s ease;
  --max-width:   1160px;
  --nav-height:  72px;
}

/* ── Reset ───────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{background:var(--color-bg);color:var(--color-text);font-family:var(--font-body);line-height:1.7;min-height:100vh}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul{list-style:none}

/* ── Typography ──────────────────────────────────────────────── */
h1,h2,h3,h4{font-family:var(--font-heading);color:var(--color-cream);line-height:1.2}
h1{font-size:clamp(2.2rem,6vw,4rem)}
h2{font-size:clamp(1.6rem,4vw,2.6rem)}
h3{font-size:clamp(1.2rem,3vw,1.6rem)}
p{color:var(--color-text);max-width:68ch}

.section-label{display:inline-block;font-size:0.75rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--color-primary);margin-bottom:.75rem}

/* ── Layout ──────────────────────────────────────────────────── */
.container{width:100%;max-width:var(--max-width);margin-inline:auto;padding-inline:1.5rem}
.section{padding-block:5rem}
.section--dark{background:var(--color-bg-light)}
.section--surface{background:var(--color-surface)}
.text-center{text-align:center}

/* ── Buttons ─────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 2rem;border-radius:var(--radius-xl);font-family:var(--font-body);font-size:.95rem;font-weight:700;letter-spacing:.04em;cursor:pointer;border:2px solid transparent;transition:background var(--transition),color var(--transition),border-color var(--transition),transform var(--transition)}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn--primary{background:var(--color-primary);color:var(--color-bg);border-color:var(--color-primary)}
.btn--primary:hover{background:var(--color-primary-dk);border-color:var(--color-primary-dk)}
.btn--outline{background:transparent;color:var(--color-cream);border-color:var(--color-cream)}
.btn--outline:hover{background:var(--color-cream);color:var(--color-bg)}
.btn--gold{background:var(--color-gold);color:var(--color-bg);border-color:var(--color-gold)}
.btn--gold:hover{background:var(--color-primary);border-color:var(--color-primary)}
.btn--lg{padding:1rem 2.6rem;font-size:1.05rem}

/* ── Divider ─────────────────────────────────────────────────── */
.divider{width:60px;height:3px;background:var(--color-primary);border-radius:2px;margin-block:1.25rem}
.divider--center{margin-inline:auto}

/* ── NAV ─────────────────────────────────────────────────────── */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--nav-height);display:flex;align-items:center;transition:background var(--transition),box-shadow var(--transition)}
.nav.scrolled{background:rgba(26,10,0,.97);box-shadow:0 2px 24px rgba(0,0,0,.5);backdrop-filter:blur(10px)}
.nav__inner{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:var(--max-width);margin-inline:auto;padding-inline:1.5rem}
.nav__logo{display:flex;align-items:center;gap:.75rem}
.nav__logo-img{width:44px;height:44px;border-radius:50%;object-fit:cover;border:2px solid var(--color-primary)}
.nav__logo-text{font-family:var(--font-heading);font-size:1.25rem;color:var(--color-cream);font-weight:700}
.nav__logo-text span{color:var(--color-primary)}
.nav__links{display:flex;align-items:center;gap:2.5rem}
.nav__link{font-size:.9rem;font-weight:600;letter-spacing:.06em;color:var(--color-muted);text-transform:uppercase;transition:color var(--transition);position:relative}
.nav__link::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--color-primary);transition:width var(--transition);border-radius:1px}
.nav__link:hover,.nav__link.active{color:var(--color-cream)}
.nav__link:hover::after,.nav__link.active::after{width:100%}
.nav__hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;background:none;border:none}
.nav__hamburger span{display:block;width:26px;height:2px;background:var(--color-cream);border-radius:2px;transition:transform var(--transition),opacity var(--transition)}
.nav__hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.nav__hamburger.open span:nth-child(2){opacity:0}
.nav__hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

@media(max-width:768px){
  .nav__hamburger{display:flex}
  .nav__links{position:fixed;top:var(--nav-height);left:0;right:0;flex-direction:column;background:rgba(26,10,0,.98);backdrop-filter:blur(12px);padding:2rem 1.5rem 3rem;gap:2rem;transform:translateY(-110%);transition:transform .35s ease;z-index:-1;pointer-events:none}
  .nav__links.open{transform:translateY(0);z-index:999;pointer-events:auto}
  .nav__link{font-size:1.1rem}
}

/* ── FOOTER ──────────────────────────────────────────────────── */
.footer{background:var(--color-bg);border-top:1px solid var(--color-surface-2);padding-block:3rem 2rem}
.footer__inner{display:grid;grid-template-columns:1fr auto;align-items:center;gap:2rem}
.footer__brand{display:flex;align-items:center;gap:.75rem}
.footer__logo-img{width:38px;height:38px;border-radius:50%;object-fit:cover;border:2px solid var(--color-primary)}
.footer__brand-name{font-family:var(--font-heading);font-size:1.1rem;color:var(--color-cream)}
.footer__brand-name span{color:var(--color-primary)}
.footer__tagline{font-size:.82rem;color:var(--color-muted);margin-top:.25rem}
.footer__social{display:flex;gap:1rem;align-items:center}
.footer__social-link{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:var(--color-surface);color:var(--color-muted);font-size:1.1rem;transition:background var(--transition),color var(--transition)}
.footer__social-link:hover{background:var(--color-primary);color:var(--color-bg)}
.footer__copy{grid-column:1/-1;text-align:center;font-size:.78rem;color:var(--color-muted);margin-top:1.5rem;border-top:1px solid var(--color-surface-2);padding-top:1.5rem}
@media(max-width:580px){.footer__inner{grid-template-columns:1fr;text-align:center;justify-items:center}}

/* ── HERO ────────────────────────────────────────────────────── */
.hero{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;background:linear-gradient(160deg,rgba(26,10,0,.92) 40%,rgba(78,36,8,.7) 100%)}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 70% 50%,rgba(212,132,60,.08) 0%,transparent 70%)}
.hero__content{position:relative;z-index:1;max-width:680px}
.hero__eyebrow{display:inline-flex;align-items:center;gap:.75rem;font-size:.8rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--color-primary);margin-bottom:1.5rem}
.hero__eyebrow::before,.hero__eyebrow::after{content:'';display:inline-block;width:28px;height:1px;background:var(--color-primary)}
.hero__title{margin-bottom:1.25rem}
.hero__title .break{color:var(--color-primary)}
.hero__subtitle{font-size:1.1rem;color:var(--color-muted);margin-bottom:2.5rem;max-width:50ch}
.hero__cta{display:flex;gap:1rem;flex-wrap:wrap}
.hero__scroll{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem;color:var(--color-muted);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;animation:bounce 2s infinite}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}

/* ── CARDS ───────────────────────────────────────────────────── */
.featured-grid,.menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:1.75rem;margin-top:2.5rem}
.card{background:var(--color-surface);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-card);transition:transform var(--transition),box-shadow var(--transition);border:1px solid var(--color-surface-2)}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-card),var(--shadow-glow)}
.card__img-wrap{width:100%;aspect-ratio:4/3;overflow:hidden;background:var(--color-surface-2);position:relative;display:flex;align-items:center;justify-content:center}
.card__img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.card:hover .card__img-wrap img{transform:scale(1.05)}
.card__emoji{font-size:4rem}
.card__badge{position:absolute;top:.75rem;right:.75rem;background:var(--color-primary);color:var(--color-bg);font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:.25rem .65rem;border-radius:var(--radius-xl)}
.card__body{padding:1.4rem}
.card__title{font-family:var(--font-heading);font-size:1.2rem;color:var(--color-cream);margin-bottom:.4rem}
.card__desc{font-size:.88rem;color:var(--color-muted);line-height:1.6;margin-bottom:1rem}
.card__footer{display:flex;align-items:center;justify-content:space-between}
.card__price{font-family:var(--font-heading);font-size:1.3rem;color:var(--color-gold);font-weight:700}
.card__tag{font-size:.72rem;background:var(--color-surface-2);color:var(--color-muted);padding:.2rem .6rem;border-radius:var(--radius-xl);text-transform:uppercase;letter-spacing:.08em}

/* ── WHY US ──────────────────────────────────────────────────── */
.why-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;margin-top:3rem;text-align:center}
.why-item__icon{font-size:2.4rem;margin-bottom:1rem}
.why-item__title{font-family:var(--font-heading);font-size:1.1rem;color:var(--color-cream);margin-bottom:.4rem}
.why-item__desc{font-size:.88rem;color:var(--color-muted);max-width:24ch;margin-inline:auto}

/* ── MENU FILTER ─────────────────────────────────────────────── */
.filter-bar{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:2rem}
.filter-btn{padding:.45rem 1.25rem;border-radius:var(--radius-xl);font-size:.85rem;font-weight:600;letter-spacing:.04em;cursor:pointer;border:2px solid var(--color-surface-2);background:var(--color-surface);color:var(--color-muted);transition:all var(--transition)}
.filter-btn:hover,.filter-btn.active{border-color:var(--color-primary);color:var(--color-cream)}
.filter-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-bg)}

/* ── ABOUT ───────────────────────────────────────────────────── */
.page-hero{padding-top:calc(var(--nav-height) + 4rem);padding-bottom:4rem}
.about-story{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.about-story__img{border-radius:var(--radius-md);overflow:hidden;aspect-ratio:4/5;background:var(--color-surface);display:flex;align-items:center;justify-content:center;font-size:8rem}
.about-story__img img{width:100%;height:100%;object-fit:cover}
.about-story__text p+p{margin-top:1.25rem}
.values-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;margin-top:3rem}
.value-card{background:var(--color-surface);border:1px solid var(--color-surface-2);border-radius:var(--radius-md);padding:2rem 1.5rem;text-align:center;transition:border-color var(--transition),box-shadow var(--transition)}
.value-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-glow)}
.value-card__icon{font-size:2.2rem;margin-bottom:1rem}
.value-card__title{font-family:var(--font-heading);color:var(--color-cream);margin-bottom:.5rem}
.value-card__desc{font-size:.88rem;color:var(--color-muted)}
@media(max-width:768px){.about-story{grid-template-columns:1fr}}

/* ── CONTACT ─────────────────────────────────────────────────── */
.contact-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-top:3rem}
.contact-card{background:var(--color-surface);border:1px solid var(--color-surface-2);border-radius:var(--radius-md);padding:2rem 1.5rem;display:flex;flex-direction:column;align-items:center;text-align:center;gap:1rem;transition:border-color var(--transition),box-shadow var(--transition),transform var(--transition)}
.contact-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-glow);transform:translateY(-4px)}
.contact-card__icon{width:56px;height:56px;border-radius:50%;background:var(--color-surface-2);display:flex;align-items:center;justify-content:center;font-size:1.5rem}
.contact-card__label{font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--color-muted)}
.contact-card__value{font-family:var(--font-heading);font-size:1.1rem;color:var(--color-cream)}
.contact-card__sub{font-size:.82rem;color:var(--color-muted)}
.social-strip{display:flex;justify-content:center;gap:1.25rem;flex-wrap:wrap;margin-top:3rem}
.social-pill{display:inline-flex;align-items:center;gap:.6rem;padding:.65rem 1.5rem;border-radius:var(--radius-xl);background:var(--color-surface);border:1px solid var(--color-surface-2);color:var(--color-muted);font-size:.9rem;font-weight:600;transition:all var(--transition)}
.social-pill:hover{border-color:var(--color-primary);color:var(--color-cream);background:var(--color-surface-2);transform:translateY(-2px)}
.social-pill__icon{font-size:1.2rem}

/* ── FADE ANIMATIONS ─────────────────────────────────────────── */
.fade-up{opacity:0;transform:translateY(28px);transition:opacity .6s ease,transform .6s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}
.delay-1{transition-delay:.1s}
.delay-2{transition-delay:.2s}
.delay-3{transition-delay:.3s}
.delay-4{transition-delay:.4s}

/* ── Responsive ──────────────────────────────────────────────── */
@media(max-width:580px){
  .hero__cta{flex-direction:column}
  .section{padding-block:3.5rem}
  .filter-bar{justify-content:center}
  .btn--lg{width:100%;justify-content:center}
}

/* ── Mobile Enhancements ─────────────────────────────────────── */
/* Safe area insets for notched devices (iPhone X+) */
.nav{padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}
.container{padding-left:max(1.5rem,env(safe-area-inset-left));padding-right:max(1.5rem,env(safe-area-inset-right))}
.footer{padding-bottom:max(2rem,env(safe-area-inset-bottom))}

/* Tap highlight & touch behavior */
a,button,.btn,.filter-btn,.card{-webkit-tap-highlight-color:rgba(212,132,60,0.15)}
.nav__link,.btn,.filter-btn,.card,.social-pill,.contact-card{touch-action:manipulation}

/* Minimum touch target size (48px per WCAG) */
.nav__hamburger{min-width:48px;min-height:48px;display:none;align-items:center;justify-content:center}
.nav__link{padding-block:.5rem}
.footer__social-link{min-width:48px;min-height:48px}

/* Prevent text size adjust on orientation change */
html{-webkit-text-size-adjust:100%;text-size-adjust:100%}

/* Smooth momentum scrolling for iOS */
body{-webkit-overflow-scrolling:touch}

/* Overscroll background color */
html{background:var(--color-bg)}

@media(max-width:768px){
  .nav__hamburger{display:flex}
  /* Larger tap targets on mobile */
  .nav__link{padding:.75rem 0;font-size:1.1rem;width:100%;text-align:center}
  /* Prevent horizontal scroll */
  body{overflow-x:hidden}
  /* Better card grid on small screens */
  .featured-grid,.menu-grid{grid-template-columns:1fr}
}

@media(max-width:480px){
  .nav__inner{padding-inline:1rem}
  .nav__logo{gap:.5rem}
  .nav__logo-img{width:36px;height:36px}
  .nav__logo-text{font-size:1.05rem}
}
@media(max-width:380px){
  .hero__eyebrow{font-size:.7rem}
  .card__body{padding:1.1rem}
  .nav__logo-img{width:32px;height:32px}
  .nav__logo-text{font-size:.95rem}
}
