/* =========================================================================
   DOLCE AND BAKE CAFÉ — GLOBAL STYLES
   ========================================================================= */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=DM+Sans:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');
@import url('./tokens.css');

/* ---------- RESET ---------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--font-body);
  font-size: var(--fs-16);
  line-height: var(--lh-normal);
  color: var(--color-ink);
  background: var(--color-cream);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}
img, svg, video { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; border: none; background: none; cursor: pointer; color: inherit; }
ul, ol { list-style: none; }

/* ---------- UTILITIES ---------- */
.container {
  max-width: var(--container-max);
  margin: 0 auto;
  padding-left: var(--container-pad);
  padding-right: var(--container-pad);
}
.eyebrow {
  font-family: var(--font-body);
  font-size: var(--fs-12);
  font-weight: var(--weight-medium);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  color: var(--color-burgundy);
}
.display {
  font-family: var(--font-display);
  font-weight: var(--weight-regular);
  letter-spacing: var(--tracking-tight);
  line-height: var(--lh-tight);
  color: var(--color-ink);
}
.display i, .display em { font-style: italic; font-weight: var(--weight-regular); }

/* ---------- TOP STRIP ---------- */
.topstrip {
  background: var(--color-ink);
  color: var(--color-cream);
  font-size: var(--fs-12);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  padding: var(--s-3) var(--container-pad);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--s-8);
  flex-wrap: wrap;
}
.topstrip__dot { width: 4px; height: 4px; background: var(--color-butter); border-radius: 50%; }
.topstrip a { color: var(--color-butter); }

/* ---------- HEADER / NAV ---------- */
.header {
  background: var(--color-cream);
  border-bottom: 1px solid var(--color-line);
  position: sticky;
  top: 0;
  z-index: 50;
}
.header__inner {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  padding: var(--s-5) 0;
  gap: var(--s-6);
}
.header__nav { display: flex; gap: var(--s-8); align-items: center; }
.header__nav a {
  font-size: var(--fs-14);
  font-weight: var(--weight-medium);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  position: relative;
  transition: color var(--dur-fast) var(--ease-out);
}
.header__nav a::after {
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: -6px;
  height: 1px;
  background: var(--color-burgundy);
  transform: scaleX(0);
  transition: transform var(--dur-base) var(--ease-out);
}
.header__nav a:hover { color: var(--color-burgundy); }
.header__nav a:hover::after, .header__nav a.is-active::after { transform: scaleX(1); }

.brand {
  text-align: center;
  font-family: var(--font-display);
}
.brand__name {
  font-size: var(--fs-32);
  font-style: italic;
  font-weight: var(--weight-medium);
  line-height: 1;
  color: var(--color-ink);
}
.brand__tag {
  font-family: var(--font-body);
  font-size: 9px;
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  color: var(--color-ink-soft);
  margin-top: 4px;
}
.brand__name .amp { font-size: 0.7em; vertical-align: 0.1em; margin: 0 0.05em; }

.header__actions { display: flex; gap: var(--s-5); align-items: center; justify-content: flex-end; }
.icon-btn {
  width: 40px; height: 40px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: var(--radius-full);
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
  position: relative;
}
.icon-btn:hover { background: var(--color-cream-deep); color: var(--color-burgundy); }
.icon-btn__count {
  position: absolute;
  top: 4px; right: 4px;
  background: var(--color-burgundy);
  color: var(--color-cream);
  font-size: 10px;
  font-weight: var(--weight-semibold);
  min-width: 16px; height: 16px;
  border-radius: var(--radius-full);
  display: inline-flex; align-items: center; justify-content: center;
  padding: 0 4px;
}

/* ---------- BUTTONS ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--s-2);
  padding: var(--s-4) var(--s-8);
  font-size: var(--fs-14);
  font-weight: var(--weight-medium);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  border-radius: var(--radius-full);
  cursor: pointer;
  transition: all var(--dur-base) var(--ease-out);
  white-space: nowrap;
  border: 1px solid transparent;
}
.btn--primary {
  background: var(--color-burgundy);
  color: var(--color-cream-soft);
}
.btn--primary:hover { background: var(--color-burgundy-dark); transform: translateY(-1px); box-shadow: var(--shadow-md); }
.btn--ghost {
  background: transparent;
  color: var(--color-ink);
  border: 1px solid var(--color-ink);
}
.btn--ghost:hover { background: var(--color-ink); color: var(--color-cream); }
.btn--cream {
  background: var(--color-cream-soft);
  color: var(--color-ink);
}
.btn--cream:hover { background: white; }
.btn--sm { padding: var(--s-2) var(--s-5); font-size: var(--fs-12); }
.btn--lg { padding: var(--s-5) var(--s-10); font-size: var(--fs-14); }

/* ---------- FOOTER ---------- */
.footer {
  background: var(--color-ink);
  color: var(--color-cream-soft);
  padding: var(--s-20) 0 var(--s-8);
  margin-top: var(--s-24);
}
.footer__grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1.2fr;
  gap: var(--s-12);
  margin-bottom: var(--s-16);
}
.footer__brand .brand__name { color: var(--color-cream-soft); font-size: var(--fs-40); }
.footer__brand p { color: var(--color-ink-mute); margin-top: var(--s-5); max-width: 28ch; font-size: var(--fs-14); line-height: var(--lh-loose); }
.footer__col h4 {
  font-family: var(--font-body);
  font-size: var(--fs-12);
  font-weight: var(--weight-semibold);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--color-butter);
  margin-bottom: var(--s-6);
}
.footer__col ul { display: flex; flex-direction: column; gap: var(--s-3); }
.footer__col a { font-size: var(--fs-14); color: var(--color-cream-soft); transition: color var(--dur-fast); }
.footer__col a:hover { color: var(--color-butter); }
.footer__col .meta { font-size: var(--fs-12); color: var(--color-ink-mute); letter-spacing: var(--tracking-wide); text-transform: uppercase; margin-top: var(--s-4); }

.footer__newsletter {
  display: flex;
  border-bottom: 1px solid var(--color-ink-soft);
  padding-bottom: var(--s-3);
  margin-top: var(--s-5);
}
.footer__newsletter input {
  flex: 1;
  background: transparent;
  border: none;
  outline: none;
  color: var(--color-cream-soft);
  font: inherit;
  font-size: var(--fs-14);
  padding: var(--s-2) 0;
}
.footer__newsletter input::placeholder { color: var(--color-ink-mute); }
.footer__newsletter button {
  color: var(--color-butter);
  font-size: var(--fs-12);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  font-weight: var(--weight-semibold);
}

.footer__bottom {
  border-top: 1px solid var(--color-ink-soft);
  padding-top: var(--s-6);
  display: flex;
  justify-content: space-between;
  gap: var(--s-6);
  font-size: var(--fs-12);
  color: var(--color-ink-mute);
  letter-spacing: var(--tracking-wide);
}
.footer__bottom .social { display: flex; gap: var(--s-5); }

/* ---------- PLACEHOLDER IMAGES ---------- */
/* Replace these with real photography. Patterns telegraph "image goes here"
   to the dev so they can't confuse a placeholder with the final art. */
.ph {
  position: relative;
  background: repeating-linear-gradient(
    45deg,
    var(--ph-base, var(--color-cream-deep)) 0 12px,
    var(--ph-stripe, var(--color-line)) 12px 13px
  );
  overflow: hidden;
  color: var(--color-ink-soft);
}
.ph__label {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: var(--fs-12);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  text-align: center;
  padding: var(--s-4);
  background: rgba(246, 239, 227, 0.4);
  backdrop-filter: blur(2px);
}
.ph--dark { --ph-base: #3D2E22; --ph-stripe: #5A4533; color: var(--color-cream); }
.ph--dark .ph__label { background: rgba(42, 31, 24, 0.45); color: var(--color-cream-soft); }
.ph--burgundy { --ph-base: #6E1B26; --ph-stripe: #8B2A36; color: var(--color-cream); }
.ph--burgundy .ph__label { background: rgba(122, 31, 43, 0.4); color: var(--color-cream-soft); }
.ph--olive { --ph-base: #5C6A3E; --ph-stripe: #7A8758; color: var(--color-cream); }
.ph--olive .ph__label { background: rgba(107, 122, 74, 0.4); color: var(--color-cream-soft); }
.ph--rose { --ph-base: #B57361; --ph-stripe: #C8856F; color: var(--color-cream); }
.ph--rose .ph__label { background: rgba(200, 133, 111, 0.4); color: var(--color-cream-soft); }

/* ---------- SECTION HEADER ---------- */
.section { padding: var(--s-24) 0; }
.section--tight { padding: var(--s-16) 0; }
.section__head { text-align: center; margin-bottom: var(--s-16); max-width: 64ch; margin-left: auto; margin-right: auto; }
.section__head .eyebrow { margin-bottom: var(--s-4); display: inline-block; }
.section__head h2 { font-size: clamp(2rem, 4vw, var(--fs-56)); }
.section__head p { margin-top: var(--s-5); color: var(--color-ink-soft); font-size: var(--fs-18); }

/* ---------- ORNAMENT ---------- */
.ornament {
  display: inline-flex;
  align-items: center;
  gap: var(--s-3);
  color: var(--color-burgundy);
  margin-bottom: var(--s-4);
}
.ornament__line { width: 32px; height: 1px; background: currentColor; opacity: 0.5; }
.ornament__star { font-size: 14px; }

/* ---------- RESPONSIVE ---------- */
@media (max-width: 900px) {
  .header__inner { grid-template-columns: auto 1fr auto; }
  .header__nav { display: none; }
  .footer__grid { grid-template-columns: 1fr 1fr; }
  .section { padding: var(--s-16) 0; }
}
@media (max-width: 600px) {
  .footer__grid { grid-template-columns: 1fr; }
  .footer__bottom { flex-direction: column; }
}
