/* ============================================================
   PALAZZO WATCHES & GEMS — LAPIS THEME
   Single source of truth. Do not drift.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Italiana&family=Marcellus&family=Cormorant+Garamond:wght@400;500;600&family=IBM+Plex+Mono:wght@400;500;600&display=swap');

:root {
  /* ---- Color tokens (LAPIS) ---- */
  --navy:    #0F2A52;  /* primary */
  --gold:    #C4A05E;  /* accent  */
  --vellum:  #EFE7D2;  /* canvas  */
  --ink:     #0B1626;  /* body    */
  --mist:    #D9D2BE;  /* muted/borders */
  --success: #2E7D5B;
  --warn:    #C08A2E;
  --error:   #9B2C2C;

  /* derived */
  --gold-hair: rgba(196,160,94,0.60);   /* hairline rules */
  --gold-faint: rgba(196,160,94,0.22);
  --navy-90: rgba(15,42,82,0.90);
  --ink-70:  rgba(11,22,38,0.70);
  --ink-55:  rgba(11,22,38,0.55);
  --cream-on-navy: #EFE7D2;

  /* ---- Type families ---- */
  --display: 'Italiana', 'Times New Roman', serif;     /* hero, titles, model names */
  --editorial: 'Marcellus', Georgia, serif;            /* sub-display, small caps */
  --body: 'Cormorant Garamond', Georgia, serif;        /* long-form */
  --mono: 'IBM Plex Mono', 'Courier New', monospace;   /* prices, refs, badges */

  /* ---- Spacing rhythm ---- */
  --sp-section-desktop: 96px;
  --sp-section-mobile: 48px;
}

/* ============================================================
   BASE
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  background: var(--vellum);
  color: var(--ink);
  font-family: var(--body);
  font-size: 19px;
  line-height: 1.5;
  font-weight: 500;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

p { text-wrap: pretty; }
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }

/* ============================================================
   TYPE UTILITIES
   ============================================================ */
.display { font-family: var(--display); font-weight: 400; line-height: 1.04; letter-spacing: 0.01em; }
.editorial { font-family: var(--editorial); font-weight: 400; }
.mono { font-family: var(--mono); font-variant-numeric: tabular-nums; }

.eyebrow {
  font-family: var(--mono);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--gold);
}
.smallcaps {
  font-family: var(--editorial);
  font-variant: small-caps;
  letter-spacing: 0.12em;
}
.micro-caps {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.26em;
  text-transform: uppercase;
}

/* ============================================================
   MOTIFS
   ============================================================ */

/* Gold hairline rule */
.hairline {
  height: 0;
  border: 0;
  border-top: 1px solid var(--gold-hair);
  margin: 0;
}

/* Gold mitered specimen frame — for hero imagery */
.mitered {
  position: relative;
  padding: 14px;
}
.mitered::before {
  content: "";
  position: absolute;
  inset: 0;
  border: 1px solid var(--gold);
  pointer-events: none;
}
.mitered::after {
  content: "";
  position: absolute;
  inset: 7px;
  border: 1px solid var(--gold-hair);
  pointer-events: none;
}
/* corner miters */
.mitered .miter { position: absolute; width: 14px; height: 14px; pointer-events: none; }
.mitered .miter::before, .mitered .miter::after { content:""; position:absolute; background: var(--gold); }
.mitered .miter.tl { top: 0; left: 0; }
.mitered .miter.tr { top: 0; right: 0; }
.mitered .miter.bl { bottom: 0; left: 0; }
.mitered .miter.br { bottom: 0; right: 0; }

/* Star ribbon: EST · MMXXVI */
.star-ribbon {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.34em;
  text-transform: uppercase;
  color: var(--gold);
  white-space: nowrap;
}
.star-ribbon .rule { width: 34px; height: 1px; background: var(--gold-hair); }
.star-ribbon .star { font-size: 9px; }

/* Striped image placeholder */
.ph {
  position: relative;
  background-color: #e7ddc4;
  background-image: repeating-linear-gradient(
    -45deg,
    rgba(15,42,82,0.05) 0 10px,
    rgba(15,42,82,0.09) 10px 20px
  );
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.ph--navy {
  background-color: #16356a;
  background-image: repeating-linear-gradient(
    -45deg,
    rgba(196,160,94,0.07) 0 10px,
    rgba(196,160,94,0.13) 10px 20px
  );
}
.ph__label {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-55);
  text-align: center;
  padding: 8px 14px;
  border: 1px solid rgba(15,42,82,0.18);
  background: rgba(239,231,210,0.72);
}
.ph--navy .ph__label { color: rgba(239,231,210,0.7); border-color: rgba(196,160,94,0.3); background: rgba(15,42,82,0.5); }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 52px;
  padding: 0 30px;
  font-family: var(--mono);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  border: 1px solid transparent;
  cursor: pointer;
  transition: background .18s ease, color .18s ease, border-color .18s ease;
  background: transparent;
}
.btn--gold { background: var(--gold); color: var(--navy); border-color: var(--gold); }
.btn--gold:hover { background: #b8924d; border-color: #b8924d; }
.btn--navy-outline { background: transparent; color: var(--navy); border-color: var(--navy); }
.btn--navy-outline:hover { background: var(--navy); color: var(--vellum); }
.btn--cream-outline { background: transparent; color: var(--vellum); border-color: rgba(239,231,210,0.5); }
.btn--cream-outline:hover { border-color: var(--gold); color: var(--gold); }
.btn--text {
  min-height: 0; padding: 0; background: none; border: 0;
  color: var(--ink); letter-spacing: 0.14em;
  border-bottom: 1px solid var(--gold);
  padding-bottom: 3px;
}
.btn--text:hover { color: var(--gold); }
.btn:focus-visible { outline: 2px solid var(--gold); outline-offset: 3px; }

/* ============================================================
   PRODUCT CARD
   ============================================================ */
.card {
  display: flex;
  flex-direction: column;
  background: transparent;
  text-align: left;
}
.card__img { aspect-ratio: 4/5; }
.card__brand { margin-top: 18px; color: var(--ink-55); }
.card__model { font-family: var(--editorial); font-size: 23px; margin: 6px 0 0; line-height: 1.15; }
.card__meta { font-family: var(--mono); font-size: 12px; color: var(--ink-55); margin-top: 8px; letter-spacing: 0.06em; }
.card__rule { border-top: 1px solid var(--gold-hair); margin: 16px 0 0; }
.card__price { font-family: var(--mono); font-size: 17px; margin-top: 14px; letter-spacing: 0.02em; }
.card__affirm { font-family: var(--mono); font-size: 11.5px; color: var(--ink-55); margin-top: 6px; letter-spacing: 0.04em; }
.card a, .card { transition: opacity .18s ease; }
.card:hover .card__img { opacity: 0.92; }
.card:hover .card__model { color: var(--navy); }

/* ============================================================
   LAYOUT HELPERS
   ============================================================ */
.wrap { width: 100%; max-width: 1240px; margin: 0 auto; padding: 0 40px; }
.flow > * + * { margin-top: 1em; }

/* ============================================================
   SHARED SITE CHROME (header / nav / footer) — opt-in classes
   ============================================================ */
.pwg-head { position: sticky; top: 0; z-index: 50; background: var(--vellum); border-bottom: 1px solid var(--gold-hair); }
.pwg-nav { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; height: 78px; padding: 0 40px; max-width: 1440px; margin: 0 auto; }
.pwg-nav__links { display: flex; gap: 30px; font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; }
.pwg-nav__links a { color: var(--ink-70); transition: color .15s; }
.pwg-nav__links a:hover, .pwg-nav__links a.active { color: var(--gold); }
.pwg-nav__util { justify-self: end; display: flex; gap: 24px; font-family: var(--mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-70); }
.pwg-nav__util a:hover { color: var(--gold); }
.pwg-burger { display: none; background: none; border: 0; cursor: pointer; flex-direction: column; gap: 5px; padding: 8px; }
.pwg-burger span { width: 22px; height: 1.5px; background: var(--navy); display: block; }
.pwg-crumb { max-width: 1440px; margin: 0 auto; padding: 22px 40px 0; font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-55); }
.pwg-crumb a:hover { color: var(--gold); }
.pwg-crumb span { color: var(--gold); }
.foot-mini { background: var(--navy); color: rgba(239,231,210,0.7); text-align: center; padding: 44px 22px; font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; }

.pwg-drawer { position: fixed; inset: 0; background: var(--navy); z-index: 100; transform: translateY(-100%); transition: transform .32s cubic-bezier(.5,0,.2,1); display: flex; flex-direction: column; padding: 28px; }
.pwg-drawer.open { transform: translateY(0); }
.pwg-drawer__top { display: flex; justify-content: space-between; align-items: center; }
.pwg-drawer__top .x { background: none; border: 0; color: var(--vellum); font-size: 26px; cursor: pointer; }
.pwg-drawer nav { margin-top: 40px; display: flex; flex-direction: column; }
.pwg-drawer nav a { font-family: var(--display); font-size: 32px; color: var(--vellum); padding: 14px 0; border-bottom: 1px solid rgba(196,160,94,0.2); }

@media (max-width: 760px) {
  .pwg-nav { grid-template-columns: auto 1fr auto; padding: 0 22px; height: 64px; }
  .pwg-nav__links { display: none; }
  .pwg-burger { display: flex; }
  .pwg-nav__util .util-hide { display: none; }
  .pwg-crumb { padding: 18px 22px 0; }
}

/* ============================================================
   FORMS
   ============================================================ */
.field { display: flex; flex-direction: column; gap: 9px; }
.field > label { font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-55); }
.field .req { color: var(--gold); }
.field input, .field select, .field textarea {
  font-family: var(--body); font-size: 18px; font-weight: 500; color: var(--ink);
  background: #fff; border: 1px solid var(--mist); padding: 14px 15px; width: 100%;
  transition: border-color .15s; border-radius: 0;
}
.field input::placeholder, .field textarea::placeholder { color: var(--ink-55); }
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--gold); }
.field textarea { resize: vertical; min-height: 116px; line-height: 1.5; }
.field select { appearance: none; background-image: linear-gradient(45deg, transparent 50%, var(--gold) 50%), linear-gradient(135deg, var(--gold) 50%, transparent 50%); background-position: calc(100% - 19px) center, calc(100% - 13px) center; background-size: 6px 6px, 6px 6px; background-repeat: no-repeat; cursor: pointer; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.form-grid .span-2 { grid-column: 1 / -1; }
.dropzone { border: 1px dashed var(--mist); background: #fff; padding: 30px; text-align: center; cursor: pointer; transition: border-color .15s, background .15s; }
.dropzone:hover { border-color: var(--gold); background: #fffdf7; }
.dropzone .dz-title { font-family: var(--editorial); font-size: 18px; color: var(--navy); }
.dropzone .dz-sub { font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em; color: var(--ink-55); margin-top: 8px; }

/* segmented toggle */
.segmented { display: inline-flex; border: 1px solid var(--mist); background: #fff; }
.segmented button { font-family: var(--mono); font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-70); background: none; border: 0; padding: 14px 26px; cursor: pointer; transition: all .15s; }
.segmented button.active { background: var(--navy); color: var(--vellum); }

@media (max-width: 600px) { .form-grid { grid-template-columns: 1fr; } }

/* ============================================================
   FAQ ACCORDION
   ============================================================ */
.faq { border-top: 1px solid var(--gold-hair); }
.faq__item { border-bottom: 1px solid var(--mist); }
.faq__q { width: 100%; text-align: left; background: none; border: 0; cursor: pointer; padding: 26px 0; display: flex; justify-content: space-between; align-items: center; gap: 24px; font-family: var(--editorial); font-size: 22px; color: var(--navy); }
.faq__q .sign { font-family: var(--mono); font-size: 20px; color: var(--gold); transition: transform .2s; flex: 0 0 auto; }
.faq__item.open .sign { transform: rotate(45deg); }
.faq__a { max-height: 0; overflow: hidden; transition: max-height .3s ease; }
.faq__a p { font-family: var(--body); font-size: 18px; line-height: 1.55; color: var(--ink-70); margin: 0 0 24px; max-width: 720px; }

/* ============================================================
   PROCESS STEPS
   ============================================================ */
.process { display: grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid var(--gold-hair); }
.process__step { padding: 44px 36px 12px 0; border-left: 1px solid var(--gold-hair); padding-left: 36px; }
.process__step:first-child { border-left: 0; padding-left: 0; }
.process__step .pnum { font-family: var(--mono); font-size: 12px; letter-spacing: 0.2em; color: var(--gold); }
.process__step h3 { font-family: var(--editorial); font-size: 25px; color: var(--navy); margin: 20px 0 14px; }
.process__step p { font-family: var(--body); font-size: 18px; line-height: 1.5; color: var(--ink-70); margin: 0; }
.process.on-navy { border-top-color: rgba(196,160,94,0.3); }
.process.on-navy .process__step { border-left-color: rgba(196,160,94,0.3); }
.process.on-navy .process__step h3 { color: var(--vellum); }
.process.on-navy .process__step p { color: rgba(239,231,210,0.76); }
@media (max-width: 760px) {
  .process { grid-template-columns: 1fr; }
  .process__step { border-left: 0; padding: 32px 0 12px; border-top: 1px solid var(--gold-hair); padding-left: 0; }
  .process__step:first-child { border-top: 0; }
  .process.on-navy .process__step { border-top-color: rgba(196,160,94,0.3); }
}

/* ============================================================
   LOGO LOCKUP — real PWG crest + wordmark
   ============================================================ */
.logo-lockup { display: inline-flex; align-items: center; gap: 13px; }
.logo-lockup img { height: 46px; width: auto; display: block; }
.logo-lockup .wm { display: flex; flex-direction: column; line-height: 1; text-align: left; }
.logo-lockup .wm .name { font-family: var(--display); font-size: 23px; letter-spacing: 0.07em; color: var(--navy); }
.logo-lockup .wm .sub { font-family: var(--mono); font-size: 8.5px; letter-spacing: 0.26em; color: var(--gold); margin-top: 6px; text-transform: uppercase; }
.logo-lockup.on-navy .wm .name { color: var(--vellum); }
.logo-lockup.stacked { flex-direction: column; gap: 9px; }
.logo-lockup.stacked .wm { align-items: center; text-align: center; }

/* ============================================================
   LAPIS OVERRIDES — for WatchTrack PHP-injected widgets
   (these widgets ship with .palazzo-burgundy / .palazzo-cream / .palazzo-gold
   classes hardcoded into PHP; we surgically repaint them here.)
   v1.1 — 2026-06-01
   ============================================================ */

/* The PDL utility classes get redefined to LAPIS tokens */
.palazzo-burgundy {
  background-color: var(--navy) !important;
  color: var(--vellum) !important;
}
.palazzo-cream {
  background-color: var(--vellum) !important;
  color: var(--ink) !important;
}
.palazzo-gold {
  background-color: var(--gold) !important;
  color: var(--navy) !important;
}
.palazzo-eyebrow { color: var(--gold) !important; }
.palazzo-border { border-color: var(--gold-hair) !important; }

/* Footer newsletter band "Stay on the Wrist of the Market" */
.palazzo-footer-newsletter {
  background: var(--navy) !important;
  color: var(--vellum) !important;
  padding: 88px 40px !important;
  border-top: 1px solid rgba(196,160,94,0.3) !important;
}
.palazzo-footer-newsletter h3 {
  font-family: var(--display) !important;
  font-weight: 400 !important;
  font-size: clamp(28px, 4vw, 42px) !important;
  color: var(--vellum) !important;
  margin: 0 0 20px !important;
  text-align: center !important;
}
.palazzo-footer-newsletter p {
  color: rgba(239,231,210,0.78) !important;
  font-family: var(--body) !important;
  font-size: 18px !important;
  text-align: center !important;
  max-width: 540px !important;
  margin: 0 auto 36px !important;
  line-height: 1.5 !important;
}

/* Newsletter card (the "Subscribe to Our Newsletter" box) */
.palazzo-newsletter-card,
.palazzo-newsletter-popup {
  background: var(--navy) !important;
  border: 1px solid rgba(196,160,94,0.4) !important;
  color: var(--vellum) !important;
}
.palazzo-newsletter-card h3,
.palazzo-newsletter-card h2 {
  color: var(--vellum) !important;
  font-family: var(--display) !important;
}
.palazzo-newsletter-card label,
.palazzo-newsletter-card p {
  color: rgba(239,231,210,0.78) !important;
  font-family: var(--body) !important;
}

/* WatchTrack-rendered form chrome */
.palazzo-wt-form { color: var(--vellum) !important; }

.palazzo-wt-form input[type="email"],
.palazzo-wt-form input[type="text"],
.palazzo-wt-form input[type="tel"],
.palazzo-wt-form textarea,
.palazzo-wt-form select {
  background: #fff !important;
  border: 1px solid var(--mist) !important;
  border-radius: 0 !important;
  padding: 14px 15px !important;
  font-family: var(--body) !important;
  font-size: 16px !important;
  color: var(--ink) !important;
}
.palazzo-wt-form input:focus,
.palazzo-wt-form textarea:focus,
.palazzo-wt-form select:focus {
  outline: none !important;
  border-color: var(--gold) !important;
}

/* Submit button — LAPIS gold CTA */
.palazzo-wt-form button[type="submit"],
.palazzo-wt-form input[type="submit"],
.palazzo-wt-form .palazzo-submit,
.palazzo-wt-form .submit-btn {
  background: var(--gold) !important;
  color: var(--navy) !important;
  border: 1px solid var(--gold) !important;
  border-radius: 0 !important;
  font-family: var(--mono) !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  letter-spacing: 0.2em !important;
  text-transform: uppercase !important;
  padding: 18px 32px !important;
  min-height: 52px !important;
  cursor: pointer !important;
  transition: background 0.18s ease !important;
}
.palazzo-wt-form button[type="submit"]:hover,
.palazzo-wt-form input[type="submit"]:hover,
.palazzo-wt-form .palazzo-submit:hover {
  background: #b8924d !important;
  border-color: #b8924d !important;
}

/* ============================================================
   ELEMENTOR PRO SECTION OVERRIDES — catch any remaining burgundy
   bands not in our Kit swap (specific section IDs that hold inline
   color overrides).
   ============================================================ */

/* The Subscribe to Our Newsletter inner section */
.elementor-element-ff038ef,
.elementor-element-62e409e,
.elementor-element-1cce70b,
.elementor-element-79ce086 {
  background-color: var(--navy) !important;
}

/* PDL-era named utility classes that survived */
.elementor-section[style*="#5B0004"],
.elementor-section[style*="#5b0004"] { background-color: var(--navy) !important; }

/* Newsletter submit input element styling */
input[type="submit"].newsletter-submit,
button.newsletter-submit {
  background: var(--gold) !important;
  color: var(--navy) !important;
  border-radius: 0 !important;
  font-family: var(--mono) !important;
  letter-spacing: 0.2em !important;
  text-transform: uppercase !important;
}

/* Brand-Lapis legacy class kill — any old PDL burgundy inline */
[style*="background-color: #5B0004"],
[style*="background-color:#5B0004"],
[style*="background: #5B0004"],
[style*="background:#5B0004"] {
  background-color: var(--navy) !important;
}
[style*="color: #5B0004"],
[style*="color:#5B0004"] {
  color: var(--navy) !important;
}

/* Hello Elementor parent footer base background just in case */
footer.site-footer,
footer.elementor-location-footer {
  background: var(--navy) !important;
}

/* PDL Italic gold mark legacy */
.palazzo-italic-gold,
em.gold {
  font-family: var(--body) !important;
  font-style: italic !important;
  color: var(--gold) !important;
}
