/* Mortaro Authority — base v4 (rizkad-style: cream, bold grotesque, urgency, light-led) */

*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; scroll-padding-top: calc(var(--header-h) + var(--urgency-h) + 12px); overflow-x: hidden; max-width: 100%; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

body {
  font-family: var(--font-body);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  color: var(--text);
  background: var(--cream);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

img, svg, video { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; color: inherit; background: none; border: 0; }
ul, ol { list-style: none; padding: 0; }

h1, h2, h3, h4 { font-family: var(--font-display); font-weight: 760; line-height: var(--lh-heading); letter-spacing: -0.03em; color: var(--heading); }
h1 { font-size: var(--fs-h1); line-height: var(--lh-display); letter-spacing: -0.045em; }
h2 { font-size: var(--fs-h2); letter-spacing: -0.04em; }
h3 { font-size: var(--fs-h3); letter-spacing: -0.02em; }
p { max-width: 62ch; }
strong { font-weight: 700; }
em { font-style: italic; }
::selection { background: var(--brass); color: var(--cream); }

/* ---- Layout ---- */
.wrap { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--gutter); position: relative; }
.wrap--wide { max-width: var(--maxw-wide); }
.wrap--narrow { max-width: var(--maxw-narrow); }
.section { padding-block: var(--space-section); position: relative; }
.section--tight { padding-block: clamp(56px, 8vw, 110px); }

/* Surfaces */
.surface-cream { background: var(--cream); color: var(--text); }
.surface-paper { background: var(--cream-2); color: var(--text); }
.surface-dark { background: var(--night); color: var(--on-dark); --text:var(--on-dark); --text-muted:var(--on-dark-muted); --heading:var(--cream); --line:var(--line-dark); }
.surface-dark h1, .surface-dark h2, .surface-dark h3 { color: var(--cream); }
.muted { color: var(--text-muted); }

/* Eyebrow — condensed, brass, // prefix */
.eyebrow { font-family: var(--font-cond); font-weight: 600; font-size: clamp(.85rem,.78rem+.3vw,1.05rem); letter-spacing: .14em; text-transform: uppercase; color: var(--brass); display: inline-flex; align-items: center; gap: .5em; }
.eyebrow::before { content: "//"; opacity: .85; }
.eyebrow--plain::before { content: none; }

.section-head { max-width: 20ch; }
.section-head--wide { max-width: 28ch; }
.section-head--center { max-width: 760px; margin-inline: auto; text-align: center; }
.section-head--center .eyebrow { justify-content: center; }
.section-head .eyebrow { margin-bottom: var(--s5); }
.section-head h2 { margin-bottom: var(--s5); }
.section-head .lead { font-family: var(--font-body); font-size: var(--fs-lead); color: var(--text-muted); max-width: 52ch; letter-spacing: 0; line-height: 1.5; }

.lead { font-size: var(--fs-lead); line-height: 1.5; }

/* Accent treatments */
.hl { color: var(--brass); }
.hl-i { color: var(--brass); font-style: italic; }                 /* rizkad's orange-italic word */
.hand { font-family: var(--font-hand); font-weight: 600; color: var(--brass); font-size: 1.25em; letter-spacing: 0; }  /* handwritten annotation */

/* Skip + focus */
.skip-link { position: absolute; left: -999px; top: 0; z-index: 1000; background: var(--ink); color: var(--cream); padding: var(--s3) var(--s5); }
.skip-link:focus { left: 0; }
:focus-visible { outline: 2px solid var(--brass); outline-offset: 3px; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

/* ---- Urgency bar (top, persistent) ---- */
.urgency { min-height: var(--urgency-h); background: var(--ink); color: var(--cream); display: flex; align-items: center; justify-content: center; flex-wrap: wrap; gap: .2em .6em; position: relative; z-index: 101; font-family: var(--font-cond); font-weight: 600; font-size: clamp(.74rem,.68rem+.3vw,.95rem); letter-spacing: .06em; text-transform: uppercase; text-align: center; padding: 7px var(--gutter); line-height: 1.3; }
.urgency__dot { width: 8px; height: 8px; border-radius: 50%; background: var(--brass-bright); flex: none; box-shadow: 0 0 0 0 rgba(208,138,48,.6); }
@media (prefers-reduced-motion: no-preference) { .urgency__dot { animation: pulse 2s infinite; } @keyframes pulse { 0%{box-shadow:0 0 0 0 rgba(208,138,48,.55)} 70%{box-shadow:0 0 0 7px rgba(208,138,48,0)} 100%{box-shadow:0 0 0 0 rgba(208,138,48,0)} } }
.urgency a { color: var(--brass-bright); text-decoration: underline; text-underline-offset: 2px; }

/* ---- Header ---- */
.site-header { position: sticky; top: 0; z-index: 100; height: var(--header-h); display: flex; align-items: center; background: transparent; border-bottom: 1px solid transparent; transition: border-color .3s, background .3s; }
.site-header.is-stuck { background: var(--cream); border-bottom-color: var(--line); }
.site-header__inner { display: flex; align-items: center; justify-content: space-between; gap: var(--s5); width: 100%; }
.site-nav { display: flex; align-items: center; gap: var(--s6); }
.site-nav a { font-family: var(--font-body); font-weight: 500; font-size: .98rem; color: var(--ink); transition: color .2s; }
.site-nav a:hover { color: var(--brass); }
.header-actions { display: flex; align-items: center; gap: var(--s4); }
.header-spots { font-family: var(--font-cond); font-weight: 600; font-size: .82rem; letter-spacing: .08em; text-transform: uppercase; color: var(--text-muted); display: inline-flex; align-items: center; gap: .5em; }
.header-spots .urgency__dot { background: var(--brass); }
@media (max-width: 940px) { .site-nav, .header-spots, .site-header .spotmeter { display: none; } }
@media (max-width: 640px) { .logo__mark, .logo__sub { font-size: 1.08rem; } .header-actions .btn { padding: 12px 18px; min-height: 44px; font-size: .9rem; } }

/* Logo lockup with brass slash */
.logo { display: inline-flex; align-items: baseline; gap: .35em; line-height: 1; }
.logo__mark { font-family: var(--font-display); font-weight: 800; font-size: 1.3rem; letter-spacing: -.02em; color: var(--ink); }
.logo__slash { color: var(--brass); font-weight: 800; font-style: italic; }
.logo__sub { font-family: var(--font-display); font-weight: 800; font-size: 1.3rem; letter-spacing: -.02em; text-transform: none; color: var(--brass); }
.surface-dark .logo__mark { color: var(--cream); }

/* ---- Footer ---- */
.site-footer { background: var(--ink); color: var(--on-dark); padding-block: var(--s9) var(--s7); }
.site-footer .logo__mark { color: var(--cream); }
.site-footer__top { display: flex; flex-wrap: wrap; gap: var(--s7); justify-content: space-between; align-items: start; }
.site-footer__tag { color: var(--on-dark-muted); margin-top: var(--s4); max-width: 34ch; }
.site-footer__links { display: flex; gap: var(--s6); flex-wrap: wrap; }
.site-footer__links a { color: var(--on-dark-muted); font-family: var(--font-cond); font-weight: 600; letter-spacing: .08em; text-transform: uppercase; font-size: .85rem; }
.site-footer__links a:hover { color: var(--brass-bright); }
.site-footer__bottom { margin-top: var(--s8); padding-top: var(--s5); border-top: 1px solid var(--line-dark); display: flex; flex-wrap: wrap; gap: var(--s4); justify-content: space-between; color: var(--on-dark-muted); font-size: var(--fs-small); }

/* ---- Marquee ---- */
.marquee { overflow: hidden; border-block: 1px solid var(--ink); padding-block: var(--s4); background: var(--ink); color: var(--cream); }
.marquee__track { display: flex; gap: var(--s7); width: max-content; white-space: nowrap; }
.marquee__track span { font-family: var(--font-display); font-weight: 740; font-size: clamp(1.5rem,1rem+2.6vw,3rem); display: inline-flex; align-items: center; gap: var(--s7); letter-spacing: -.02em; }
.marquee__track span::after { content: "\2192"; color: var(--brass-bright); }
.marquee__track .is-ghost { color: var(--brass-bright); font-style: italic; }
@media (prefers-reduced-motion: no-preference) { .marquee__track { animation: marquee 34s linear infinite; } @keyframes marquee { to { transform: translateX(-50%); } } }

/* ---- Reveal ---- */
@media (prefers-reduced-motion: no-preference) {
  .js .reveal { opacity: 0; transform: translateY(30px); transition: opacity .8s var(--ease), transform .8s var(--ease); }
  .js .reveal.in-view { opacity: 1; transform: none; }
  .js .reveal[data-delay="1"]{transition-delay:.08s}.js .reveal[data-delay="2"]{transition-delay:.16s}.js .reveal[data-delay="3"]{transition-delay:.24s}.js .reveal[data-delay="4"]{transition-delay:.32s}
  .js .reveal-lines .rl{display:block;overflow:hidden}
  .js .reveal-lines .rl>span{display:block;transform:translateY(108%);transition:transform 1s var(--ease)}
  .js .reveal-lines.in-view .rl>span{transform:none}
  .js .reveal-lines .rl:nth-child(2)>span{transition-delay:.1s}.js .reveal-lines .rl:nth-child(3)>span{transition-delay:.2s}
}

/* External Reviews Matter link */
.rm-link { color: var(--brass); text-decoration: underline; text-underline-offset: 2px; transition: color .2s; }
.rm-link:hover { color: var(--brass-bright); }
.surface-dark .rm-link, .site-footer .rm-link { color: var(--brass-bright); }
.surface-dark .rm-link:hover, .site-footer .rm-link:hover { color: var(--cream); }

.prose { max-width: 68ch; }
.prose p { margin-bottom: var(--s4); }
.prose a { color: var(--brass); text-decoration: underline; }

/* ---- Header niches dropdown ---- */
.nav-drop { position: relative; display: inline-flex; align-items: center; }
.nav-drop__toggle { display: inline-flex; align-items: center; gap: .35em; }
.nav-drop__caret { font-size: .7em; transition: transform .2s var(--ease); }
.nav-drop:hover .nav-drop__caret, .nav-drop:focus-within .nav-drop__caret { transform: rotate(180deg); }
.nav-drop__menu { position: absolute; top: 100%; left: 50%; transform: translateX(-50%) translateY(8px); margin-top: 6px; background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius-lg); padding: var(--s2); min-width: 250px; display: grid; gap: 2px; visibility: hidden; transition: transform .2s var(--ease), visibility 0s linear .2s; box-shadow: var(--shadow-card); z-index: 120; }
.nav-drop__menu::before { content: ""; position: absolute; left: 0; right: 0; top: -12px; height: 12px; }
.nav-drop:hover .nav-drop__menu, .nav-drop:focus-within .nav-drop__menu { visibility: visible; transform: translateX(-50%) translateY(0); transition: transform .2s var(--ease), visibility 0s; }
.nav-drop__menu a { padding: 9px 14px; border-radius: var(--radius); font-family: var(--font-body); font-weight: 500; font-size: .95rem; color: var(--ink); white-space: nowrap; }
.nav-drop__menu a:hover { background: var(--brass-soft); color: var(--brass); }
.nav-drop__all { border-top: 1px solid var(--line); margin-top: 4px; padding-top: 12px; color: var(--brass); font-weight: 600; }

/* ---- Footer columns ---- */
.site-footer__top { display: grid; grid-template-columns: 1.7fr 1fr 1fr; gap: var(--s8) var(--s7); align-items: start; }
.site-footer__brand { max-width: 42ch; }
.site-footer__h { display: block; font-family: var(--font-cond); font-weight: 600; font-size: .8rem; letter-spacing: .12em; text-transform: uppercase; color: var(--brass-bright); margin-bottom: var(--s5); }
.site-footer__links--col { flex-direction: column; align-items: flex-start; gap: var(--s3); }
.site-footer__links a.site-footer__email { text-transform: none; letter-spacing: 0; font-family: var(--font-body); font-size: .95rem; color: var(--cream); }
.site-footer__links a.site-footer__email:hover { color: var(--brass-bright); }
@media (max-width: 820px) { .site-footer__top { grid-template-columns: 1fr 1fr; } .site-footer__brand { grid-column: 1 / -1; } }
@media (max-width: 480px) { .site-footer__top { grid-template-columns: 1fr; } }
