/* ==========================================================================
   LUMEN STUDIO. CUSTOM STYLES
   Shared across all pages. Premium interactions + visual details.
   ========================================================================== */

:root {
  --cream: #F3EEE5;
  --paper: #EBE4D6;
  --ink: #1A1815;
  --smoke: #3A3530;
  --mist: #6B6560;
  --copper: #B4623A;
  --copper-dark: #0E7490;
  --copper-light: #22D3EE;
}

* { cursor: none; }
@media (hover: none) and (pointer: coarse) { * { cursor: auto; } }

html { scroll-behavior: auto; }
body {
  background: var(--cream);
  color: var(--ink);
  font-family: 'Geist', ui-sans-serif, system-ui, sans-serif;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

/* Grain overlay */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  opacity: 0.35;
  mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.1 0 0 0 0 0.09 0 0 0 0 0.08 0 0 0 0 0.08 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* Font helpers */
.font-display { font-family: 'Instrument Serif', serif; font-weight: 400; letter-spacing: -0.015em; }
.font-display-italic { font-family: 'Instrument Serif', serif; font-weight: 400; font-style: italic; letter-spacing: -0.015em; }
.font-mono { font-family: 'Geist Mono', ui-monospace, monospace; }

/* ==========================================================================
   CUSTOM CURSOR
   ========================================================================== */
.cursor-dot, .cursor-ring {
  position: fixed;
  top: 0; left: 0;
  pointer-events: none;
  z-index: 9999;
  transform: translate(-50%, -50%);
  transition: opacity 0.3s;
  mix-blend-mode: difference;
}
.cursor-dot {
  width: 6px; height: 6px;
  background: var(--cream);
  border-radius: 50%;
  transition: transform 0.15s ease-out, opacity 0.3s;
}
.cursor-ring {
  width: 36px; height: 36px;
  border: 1px solid rgba(243, 238, 229, 0.6);
  border-radius: 50%;
  transition: transform 0.3s cubic-bezier(0.22, 1, 0.36, 1), width 0.3s, height 0.3s, border-color 0.3s, opacity 0.3s;
}
.cursor-ring.hover {
  width: 64px; height: 64px;
  border-color: var(--cream);
  background: rgba(243, 238, 229, 0.08);
}
.cursor-ring.click { transform: translate(-50%, -50%) scale(0.8); }
@media (hover: none) and (pointer: coarse) {
  .cursor-dot, .cursor-ring { display: none; }
}

/* ==========================================================================
   LOADING SCREEN
   ========================================================================== */
#loader {
  position: fixed;
  inset: 0;
  background: var(--ink);
  color: var(--cream);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10000;
  transition: opacity 0.8s ease, transform 1s cubic-bezier(0.77, 0, 0.175, 1);
}
#loader.done {
  opacity: 0;
  transform: translateY(-100%);
  pointer-events: none;
}
#loader .loader-content {
  text-align: center;
}
#loader .loader-mark {
  font-family: 'Instrument Serif', serif;
  font-size: clamp(3rem, 8vw, 6rem);
  letter-spacing: -0.02em;
  margin-bottom: 1rem;
  overflow: hidden;
}
#loader .loader-mark span {
  display: inline-block;
  transform: translateY(100%);
  animation: loader-reveal 0.8s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}
#loader .loader-mark span:nth-child(1) { animation-delay: 0.1s; }
#loader .loader-mark span:nth-child(2) { animation-delay: 0.2s; }
#loader .loader-progress {
  font-family: 'Geist Mono', monospace;
  font-size: 0.75rem;
  letter-spacing: 0.2em;
  color: rgba(243, 238, 229, 0.5);
  margin-top: 2rem;
}
@keyframes loader-reveal {
  to { transform: translateY(0); }
}
#loader .loader-bar {
  width: 240px;
  height: 1px;
  background: rgba(243, 238, 229, 0.15);
  margin: 1.5rem auto 0;
  position: relative;
  overflow: hidden;
}
#loader .loader-bar::after {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--copper);
  transform-origin: left;
  animation: loader-bar 1.6s cubic-bezier(0.77, 0, 0.175, 1) forwards;
  animation-delay: 0.3s;
  transform: scaleX(0);
}
@keyframes loader-bar {
  0% { transform: scaleX(0); }
  100% { transform: scaleX(1); }
}

/* ==========================================================================
   NAVIGATION
   ========================================================================== */
#nav {
  transition: background 0.5s ease, backdrop-filter 0.5s ease, border-color 0.5s ease;
}
.nav-scrolled {
  background: rgba(243, 238, 229, 0.85) !important;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(26, 24, 21, 0.08);
}

/* Nav link with active underline */
.nav-link {
  position: relative;
  padding: 0.25rem 0;
  transition: color 0.3s ease;
}
.nav-link::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 100%;
  height: 1px;
  background: var(--copper);
  transform-origin: right;
  transform: scaleX(0);
  transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}
.nav-link:hover::after { transform-origin: left; transform: scaleX(1); }
.nav-link.active::after { transform-origin: left; transform: scaleX(1); }

/* ==========================================================================
   BUTTONS. Magnetic
   ========================================================================== */
.btn-magnetic {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 1rem 2rem;
  font-size: 0.85rem;
  letter-spacing: 0.02em;
  background: var(--ink);
  color: var(--cream);
  border-radius: 999px;
  transition: background 0.4s ease, transform 0.3s cubic-bezier(0.22, 1, 0.36, 1);
  will-change: transform;
  overflow: hidden;
}
.btn-magnetic::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--copper);
  border-radius: 999px;
  transform: translateY(100%);
  transition: transform 0.5s cubic-bezier(0.77, 0, 0.175, 1);
}
.btn-magnetic span { position: relative; z-index: 1; display: inline-flex; align-items: center; gap: 0.5rem; }
.btn-magnetic:hover::before { transform: translateY(0); }

.btn-ghost-magnetic {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 1rem 2rem;
  font-size: 0.85rem;
  letter-spacing: 0.02em;
  border: 1px solid var(--ink);
  color: var(--ink);
  border-radius: 999px;
  background: transparent;
  transition: all 0.4s cubic-bezier(0.22, 1, 0.36, 1);
  will-change: transform;
  overflow: hidden;
}
.btn-ghost-magnetic::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--ink);
  border-radius: 999px;
  transform: translateY(100%);
  transition: transform 0.5s cubic-bezier(0.77, 0, 0.175, 1);
}
.btn-ghost-magnetic span { position: relative; z-index: 1; display: inline-flex; align-items: center; gap: 0.5rem; transition: color 0.3s ease; }
.btn-ghost-magnetic:hover::before { transform: translateY(0); }
.btn-ghost-magnetic:hover span { color: var(--cream); }

/* ==========================================================================
   LINKS
   ========================================================================== */
.link-underline {
  background-image: linear-gradient(var(--ink), var(--ink));
  background-position: 0% 100%;
  background-repeat: no-repeat;
  background-size: 0% 1px;
  transition: background-size 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}
.link-underline:hover { background-size: 100% 1px; }

.link-copper {
  background-image: linear-gradient(var(--copper), var(--copper));
  background-position: 0% 100%;
  background-repeat: no-repeat;
  background-size: 100% 1px;
  transition: background-size 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}
.link-copper:hover { background-size: 0% 1px; }

/* ==========================================================================
   REVEAL ANIMATIONS
   ========================================================================== */
.reveal {
  opacity: 0;
  transform: translateY(32px);
  transition: opacity 1s cubic-bezier(0.22, 1, 0.36, 1), transform 1s cubic-bezier(0.22, 1, 0.36, 1);
}
.reveal.visible { opacity: 1; transform: translateY(0); }

.reveal-delay-1 { transition-delay: 0.1s; }
.reveal-delay-2 { transition-delay: 0.2s; }
.reveal-delay-3 { transition-delay: 0.3s; }
.reveal-delay-4 { transition-delay: 0.4s; }
.reveal-delay-5 { transition-delay: 0.5s; }

/* Character-by-character text reveal */
.text-reveal { overflow: hidden; display: inline-block; }
.text-reveal .char, .text-reveal .word {
  display: inline-block;
  transform: translateY(110%);
  transition: transform 1.2s cubic-bezier(0.22, 1, 0.36, 1);
}
.text-reveal.visible .char,
.text-reveal.visible .word { transform: translateY(0); }

/* Line reveal (for multi-line headings) */
.line-reveal-wrap { overflow: hidden; }
.line-reveal {
  display: inline-block;
  transform: translateY(110%);
  transition: transform 1.2s cubic-bezier(0.22, 1, 0.36, 1);
}
.line-reveal.visible { transform: translateY(0); }

/* ==========================================================================
   MARQUEE / TICKER
   ========================================================================== */
.marquee {
  display: flex;
  overflow: hidden;
  user-select: none;
  gap: 2rem;
  mask-image: linear-gradient(90deg, transparent, black 8%, black 92%, transparent);
  -webkit-mask-image: linear-gradient(90deg, transparent, black 8%, black 92%, transparent);
}
.marquee-track {
  display: flex;
  gap: 3rem;
  flex-shrink: 0;
  animation: marquee 40s linear infinite;
  padding-right: 3rem;
}
.marquee:hover .marquee-track { animation-play-state: paused; }
@keyframes marquee {
  from { transform: translateX(0); }
  to { transform: translateX(-100%); }
}

.marquee-fast .marquee-track { animation-duration: 25s; }
.marquee-reverse .marquee-track { animation-direction: reverse; }

/* ==========================================================================
   SECTIONS
   ========================================================================== */
.divider-label {
  display: flex;
  align-items: center;
  gap: 1rem;
  font-family: 'Geist Mono', monospace;
  font-size: 0.7rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--mist);
}
.divider-label::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--ink);
  opacity: 0.15;
}

.divider-label.dark { color: rgba(243, 238, 229, 0.5); }
.divider-label.dark::after { background: var(--cream); opacity: 0.15; }

/* ==========================================================================
   WORK CARDS
   ========================================================================== */
.work-card {
  transition: transform 0.6s cubic-bezier(0.22, 1, 0.36, 1);
  will-change: transform;
}
.work-card:hover { transform: translateY(-6px); }
.work-card .work-image {
  overflow: hidden;
  position: relative;
}
.work-card .work-image > * {
  transition: transform 1.2s cubic-bezier(0.22, 1, 0.36, 1), filter 0.6s ease;
}
.work-card:hover .work-image > * {
  transform: scale(1.04);
}

/* ==========================================================================
   SERVICE ROWS
   ========================================================================== */
.service-row {
  border-top: 1px solid rgba(26, 24, 21, 0.12);
  transition: background 0.4s ease, padding 0.4s ease;
  position: relative;
  overflow: hidden;
}
.service-row:last-child { border-bottom: 1px solid rgba(26, 24, 21, 0.12); }
.service-row::before {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(8, 145, 178, 0.05);
  transform: translateX(-101%);
  transition: transform 0.6s cubic-bezier(0.22, 1, 0.36, 1);
}
.service-row:hover::before { transform: translateX(0); }
.service-row > * { position: relative; z-index: 1; }

/* ==========================================================================
   FORM INPUTS
   ========================================================================== */
.form-input {
  background: transparent;
  border: none;
  border-bottom: 1px solid rgba(26, 24, 21, 0.2);
  padding: 0.9rem 0;
  font-family: 'Geist', sans-serif;
  font-size: 1.05rem;
  color: var(--ink);
  transition: border-color 0.3s ease;
  width: 100%;
}
.form-input:focus { outline: none; border-bottom-color: var(--copper); }
.form-input::placeholder { color: var(--mist); }
.form-input.resize-none { resize: none; }

/* ==========================================================================
   FAQ
   ========================================================================== */
.faq-item {
  border-top: 1px solid rgba(26, 24, 21, 0.15);
  padding: 1.75rem 0;
  cursor: pointer;
}
.faq-item:last-child { border-bottom: 1px solid rgba(26, 24, 21, 0.15); }
.faq-question {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 2rem;
}
.faq-icon {
  flex-shrink: 0;
  width: 24px;
  height: 24px;
  position: relative;
}
.faq-icon::before, .faq-icon::after {
  content: '';
  position: absolute;
  background: var(--ink);
  transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}
.faq-icon::before { top: 50%; left: 0; right: 0; height: 1px; transform: translateY(-50%); }
.faq-icon::after { top: 0; bottom: 0; left: 50%; width: 1px; transform: translateX(-50%); }
.faq-item.open .faq-icon::after { transform: translateX(-50%) rotate(90deg); }
.faq-answer {
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transition: max-height 0.6s cubic-bezier(0.22, 1, 0.36, 1), opacity 0.4s ease, margin 0.4s ease;
}
.faq-item.open .faq-answer {
  max-height: 400px;
  opacity: 1;
  margin-top: 1.5rem;
}

/* ==========================================================================
   HERO CANVAS CONTAINER
   ========================================================================== */
#hero-canvas-container {
  position: relative;
  width: 100%;
  height: 600px;
}
#hero-canvas { width: 100%; height: 100%; display: block; }
@media (max-width: 768px) {
  #hero-canvas-container { height: 340px; margin-top: 2rem; }
}

/* ==========================================================================
   TESTIMONIAL CARD
   ========================================================================== */
.testimonial {
  padding: 3rem;
  border: 1px solid rgba(26, 24, 21, 0.1);
  background: var(--paper);
  position: relative;
  transition: transform 0.5s cubic-bezier(0.22, 1, 0.36, 1), border-color 0.3s ease;
}
.testimonial:hover {
  transform: translateY(-4px);
  border-color: var(--copper);
}
.testimonial::before {
  content: '"';
  font-family: 'Instrument Serif', serif;
  position: absolute;
  top: -0.5rem;
  left: 1.5rem;
  font-size: 6rem;
  color: var(--copper);
  opacity: 0.5;
  line-height: 1;
}

/* ==========================================================================
   NUMBER COUNTER
   ========================================================================== */
.counter {
  font-variant-numeric: tabular-nums;
}

/* ==========================================================================
   PAGE TRANSITION
   ========================================================================== */
.page-transition {
  position: fixed;
  inset: 0;
  background: var(--ink);
  z-index: 9998;
  transform: translateY(100%);
  transition: transform 0.8s cubic-bezier(0.77, 0, 0.175, 1);
  pointer-events: none;
}
.page-transition.active {
  transform: translateY(0);
}
.page-transition.exiting {
  transform: translateY(-100%);
}

/* ==========================================================================
   UTILITY
   ========================================================================== */
.no-scrollbar::-webkit-scrollbar { display: none; }
.no-scrollbar { -ms-overflow-style: none; scrollbar-width: none; }

.text-balance { text-wrap: balance; }
.text-pretty { text-wrap: pretty; }

/* Subtle background patterns */
.bg-grid {
  background-image:
    linear-gradient(rgba(26, 24, 21, 0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(26, 24, 21, 0.04) 1px, transparent 1px);
  background-size: 40px 40px;
}

/* ==========================================================================
   SCROLL PROGRESS INDICATOR
   ========================================================================== */
.scroll-progress {
  position: fixed;
  top: 0; left: 0;
  height: 2px;
  background: var(--copper);
  z-index: 9997;
  transform-origin: left;
  transition: transform 0.1s ease-out;
  will-change: transform;
}

/* ==========================================================================
   BACK TO TOP
   ========================================================================== */
.back-to-top {
  position: fixed;
  bottom: 2rem;
  right: 2rem;
  width: 48px;
  height: 48px;
  background: var(--ink);
  color: var(--cream);
  border-radius: 999px;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 50;
  opacity: 0;
  transform: translateY(20px);
  pointer-events: none;
  transition: opacity 0.4s ease, transform 0.4s ease, background 0.3s ease;
}
.back-to-top.visible { opacity: 1; transform: translateY(0); pointer-events: auto; }
.back-to-top:hover { background: var(--copper); }

/* ==========================================================================
   COOKIE CONSENT
   ========================================================================== */
.cookie-banner {
  position: fixed;
  bottom: 2rem;
  left: 2rem;
  right: 2rem;
  max-width: 420px;
  background: var(--ink);
  color: var(--cream);
  padding: 1.5rem;
  border-radius: 4px;
  z-index: 60;
  transform: translateY(calc(100% + 3rem));
  transition: transform 0.5s cubic-bezier(0.22, 1, 0.36, 1);
  box-shadow: 0 20px 60px rgba(0,0,0,0.3);
}
.cookie-banner.visible { transform: translateY(0); }
.cookie-banner h4 {
  font-family: 'Instrument Serif', serif;
  font-size: 1.5rem;
  margin-bottom: 0.5rem;
}
.cookie-banner p { font-size: 0.85rem; line-height: 1.5; color: rgba(243, 238, 229, 0.7); margin-bottom: 1rem; }
.cookie-banner .cookie-actions { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.cookie-banner button {
  padding: 0.5rem 1rem;
  font-size: 0.75rem;
  font-family: 'Geist Mono', monospace;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  border-radius: 999px;
  transition: all 0.3s ease;
}
.cookie-banner .btn-accept { background: var(--copper); color: var(--cream); border: none; }
.cookie-banner .btn-accept:hover { background: var(--copper-light); }
.cookie-banner .btn-decline { background: transparent; color: var(--cream); border: 1px solid rgba(243,238,229,0.3); }
.cookie-banner .btn-decline:hover { border-color: var(--cream); }

/* ==========================================================================
   DARK MODE
   ========================================================================== */
html.dark {
  --cream: #14120F;
  --paper: #1F1C18;
  --ink: #E8E3D8;
  --smoke: #C4BEB1;
  --mist: #88837A;
  --copper: #22D3EE;
  --copper-dark: #B4623A;
  --copper-light: #E8A37A;
}
html.dark body::before {
  opacity: 0.15;
  mix-blend-mode: screen;
}
html.dark .bg-cream { background: var(--cream) !important; }
html.dark .bg-paper { background: var(--paper) !important; }
html.dark .bg-ink { background: var(--paper) !important; color: var(--ink) !important; }
html.dark .text-cream { color: var(--cream) !important; }
html.dark .text-ink { color: var(--ink) !important; }
html.dark .text-smoke { color: var(--smoke) !important; }
html.dark .text-mist { color: var(--mist) !important; }
html.dark .text-copper { color: var(--copper) !important; }
html.dark .border-ink\/10 { border-color: rgba(232, 227, 216, 0.1) !important; }
html.dark .border-ink\/15 { border-color: rgba(232, 227, 216, 0.15) !important; }
html.dark .border-ink\/20 { border-color: rgba(232, 227, 216, 0.2) !important; }
html.dark .bg-grid {
  background-image:
    linear-gradient(rgba(232, 227, 216, 0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(232, 227, 216, 0.04) 1px, transparent 1px);
}

.theme-toggle {
  background: transparent;
  border: 1px solid rgba(26, 24, 21, 0.15);
  padding: 0.4rem;
  border-radius: 999px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
}
.theme-toggle:hover { border-color: var(--copper); color: var(--copper); }
.theme-toggle .sun { display: none; }
.theme-toggle .moon { display: block; }
html.dark .theme-toggle .sun { display: block; }
html.dark .theme-toggle .moon { display: none; }

/* ==========================================================================
   FOUNDER PRICING STRIP
   ========================================================================== */
.founder-strip {
  position: relative;
  background: var(--copper);
  color: var(--cream);
  padding: 0.75rem 1rem;
  overflow: hidden;
}
.founder-strip-track {
  display: flex;
  gap: 3rem;
  animation: marquee 30s linear infinite;
  white-space: nowrap;
  font-family: 'Geist Mono', monospace;
  font-size: 0.75rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
}

/* ==========================================================================
   CALL LOSS CALCULATOR
   ========================================================================== */
.calculator {
  background: var(--paper);
  border: 1px solid rgba(26, 24, 21, 0.1);
  padding: 2.5rem;
  border-radius: 4px;
}
.calculator-slider {
  appearance: none;
  -webkit-appearance: none;
  width: 100%;
  height: 2px;
  background: rgba(26, 24, 21, 0.15);
  outline: none;
  cursor: pointer;
}
.calculator-slider::-webkit-slider-thumb {
  appearance: none;
  -webkit-appearance: none;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--copper);
  cursor: pointer;
  border: 3px solid var(--cream);
  box-shadow: 0 2px 8px rgba(0,0,0,0.15);
  transition: transform 0.2s ease;
}
.calculator-slider::-webkit-slider-thumb:hover { transform: scale(1.2); }
.calculator-slider::-moz-range-thumb {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--copper);
  cursor: pointer;
  border: 3px solid var(--cream);
}
.calc-output {
  font-family: 'Instrument Serif', serif;
  font-size: clamp(3.5rem, 8vw, 6rem);
  line-height: 0.95;
  color: var(--copper);
  font-variant-numeric: tabular-nums;
  transition: transform 0.3s ease;
}

/* ==========================================================================
   FORM VALIDATION
   ========================================================================== */
.form-input.has-error { border-bottom-color: #B44242; }
.form-input.has-success { border-bottom-color: var(--copper); }
.form-error-msg {
  font-family: 'Geist Mono', monospace;
  font-size: 0.7rem;
  color: #B44242;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-top: 0.5rem;
  display: none;
}
.form-input.has-error ~ .form-error-msg { display: block; }

/* ==========================================================================
   BLOG / ARTICLE STYLES
   ========================================================================== */
.prose {
  font-size: 1.125rem;
  line-height: 1.75;
  color: var(--smoke);
  max-width: 68ch;
}
.prose p { margin-bottom: 1.5rem; }
.prose h2 {
  font-family: 'Instrument Serif', serif;
  font-size: 2.5rem;
  line-height: 1.1;
  color: var(--ink);
  margin-top: 3.5rem;
  margin-bottom: 1.25rem;
  letter-spacing: -0.01em;
}
.prose h3 {
  font-family: 'Instrument Serif', serif;
  font-size: 1.75rem;
  color: var(--ink);
  margin-top: 2.5rem;
  margin-bottom: 1rem;
}
.prose strong { color: var(--ink); font-weight: 500; }
.prose em { font-family: 'Instrument Serif', serif; font-style: italic; color: var(--ink); }
.prose ul, .prose ol { margin: 1.5rem 0; padding-left: 1.5rem; }
.prose li { margin-bottom: 0.5rem; }
.prose ul li { list-style: none; position: relative; }
.prose ul li::before {
  content: '';
  position: absolute;
  left: -1.25rem;
  top: 0.75em;
  width: 8px;
  height: 1px;
  background: var(--copper);
}
.prose blockquote {
  border-left: 2px solid var(--copper);
  padding-left: 1.5rem;
  margin: 2rem 0;
  font-family: 'Instrument Serif', serif;
  font-style: italic;
  font-size: 1.5rem;
  color: var(--ink);
}
.prose a { color: var(--copper); text-decoration: underline; text-underline-offset: 3px; text-decoration-thickness: 1px; }
.prose a:hover { text-decoration-thickness: 2px; }
.prose code {
  font-family: 'Geist Mono', monospace;
  font-size: 0.9em;
  background: var(--paper);
  padding: 0.15rem 0.4rem;
  border-radius: 3px;
}

/* ==========================================================================
   KEYBOARD SHORTCUTS MODAL
   ========================================================================== */
.kbd-modal {
  position: fixed;
  inset: 0;
  background: rgba(26, 24, 21, 0.7);
  backdrop-filter: blur(8px);
  z-index: 9996;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 2rem;
}
.kbd-modal.visible { display: flex; }
.kbd-modal-content {
  background: var(--cream);
  border: 1px solid rgba(26,24,21,0.1);
  padding: 3rem;
  max-width: 520px;
  width: 100%;
  border-radius: 4px;
}
.kbd-modal h3 {
  font-family: 'Instrument Serif', serif;
  font-size: 2rem;
  margin-bottom: 1.5rem;
}
.kbd-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.75rem 0;
  border-bottom: 1px solid rgba(26,24,21,0.08);
  font-size: 0.9rem;
}
.kbd-row:last-child { border-bottom: 0; }
kbd {
  font-family: 'Geist Mono', monospace;
  font-size: 0.75rem;
  background: var(--paper);
  border: 1px solid rgba(26,24,21,0.15);
  padding: 0.2rem 0.5rem;
  border-radius: 3px;
  color: var(--ink);
}

/* ==========================================================================
   GOOGLE BUSINESS PROFILE MOCKUP (hero right column)
   Shows the deliverable: what customers see in the map pack after we optimize.
   ========================================================================== */
.gbp-card {
  background: var(--cream);
  border-radius: 12px;
  box-shadow: 0 24px 60px -12px rgba(26, 24, 21, 0.22), 0 4px 12px -4px rgba(26, 24, 21, 0.1);
  overflow: hidden;
  position: relative;
  max-width: 460px;
  margin-left: auto;
  font-family: 'Geist', ui-sans-serif, system-ui, sans-serif;
  border: 1px solid rgba(26, 24, 21, 0.08);
}
html.dark .gbp-card {
  background: var(--paper);
  box-shadow: 0 24px 60px -12px rgba(0,0,0,0.4);
}

/* Photo row at top */
.gbp-photos {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: 2px;
  height: 160px;
  background: rgba(26, 24, 21, 0.08);
}
.gbp-photos > div {
  background: linear-gradient(135deg, var(--smoke), var(--ink));
  position: relative;
  overflow: hidden;
}
.gbp-photos > div:nth-child(1) {
  background: linear-gradient(135deg, #4a3f37, #1a1815);
}
.gbp-photos > div:nth-child(2) {
  background: linear-gradient(135deg, #B4623A, #8F4A2A);
}
.gbp-photos > div:nth-child(3) {
  background: linear-gradient(135deg, #6B6560, #3A3530);
}
.gbp-photos > div::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 30% 40%, rgba(243, 238, 229, 0.15) 0%, transparent 50%),
    radial-gradient(circle at 70% 60%, rgba(180, 98, 58, 0.2) 0%, transparent 50%);
}

.gbp-photos-count {
  position: absolute;
  bottom: 10px;
  right: 10px;
  background: rgba(26, 24, 21, 0.85);
  color: var(--cream);
  padding: 4px 10px;
  border-radius: 999px;
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.5px;
}

/* Top-1 badge */
.gbp-badge {
  position: absolute;
  top: 14px;
  left: 14px;
  background: var(--copper);
  color: var(--cream);
  padding: 6px 12px;
  border-radius: 999px;
  font-family: 'Geist Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: 6px;
  z-index: 2;
  box-shadow: 0 4px 12px rgba(180, 98, 58, 0.4);
}
.gbp-badge::before {
  content: '';
  width: 6px;
  height: 6px;
  background: var(--cream);
  border-radius: 50%;
  animation: gbp-pulse 2s ease-in-out infinite;
}
@keyframes gbp-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.5; transform: scale(0.8); }
}

/* Body */
.gbp-body {
  padding: 20px 22px 18px;
}
.gbp-name {
  font-family: 'Instrument Serif', serif;
  font-size: 28px;
  line-height: 1.1;
  color: var(--ink);
  margin-bottom: 8px;
  letter-spacing: -0.02em;
}
.gbp-rating-row {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 8px;
  font-size: 14px;
  color: var(--smoke);
}
.gbp-rating-row strong {
  color: var(--ink);
  font-weight: 500;
}
.gbp-stars {
  display: inline-flex;
  gap: 1px;
  color: #F6B933;
  font-size: 13px;
  letter-spacing: 1px;
}
.gbp-meta-row {
  font-size: 13px;
  color: var(--mist);
  margin-bottom: 4px;
}
.gbp-meta-row .gbp-dot { padding: 0 6px; opacity: 0.5; }
.gbp-status {
  color: #1B7A3E;
  font-weight: 500;
}
html.dark .gbp-status { color: #4AC97A; }

/* Phone line, prominent */
.gbp-phone-line {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid rgba(26, 24, 21, 0.08);
  display: flex;
  align-items: center;
  gap: 12px;
}
.gbp-phone-icon {
  width: 32px;
  height: 32px;
  background: rgba(180, 98, 58, 0.1);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--copper);
  flex-shrink: 0;
}
.gbp-phone-number {
  font-family: 'Geist Mono', monospace;
  font-size: 16px;
  font-weight: 500;
  color: var(--ink);
  letter-spacing: -0.01em;
}

/* Actions */
.gbp-actions {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: 8px;
  padding: 14px 18px 20px;
  border-top: 1px solid rgba(26, 24, 21, 0.05);
}
.gbp-btn {
  padding: 10px 8px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.02em;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  transition: all 0.25s ease;
}
.gbp-btn-primary {
  background: var(--copper);
  color: var(--cream);
}
.gbp-btn-primary:hover { background: var(--copper-dark); }
.gbp-btn-secondary {
  background: transparent;
  color: var(--ink);
  border: 1px solid rgba(26, 24, 21, 0.15);
}
.gbp-btn-secondary:hover { border-color: var(--ink); }
html.dark .gbp-btn-secondary { color: var(--ink); border-color: rgba(232, 227, 216, 0.2); }

/* Caption above the card */
.gbp-caption {
  font-family: 'Geist Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--mist);
  margin-bottom: 14px;
  display: flex;
  align-items: center;
  gap: 10px;
  max-width: 460px;
  margin-left: auto;
}
.gbp-caption::before {
  content: '';
  width: 20px;
  height: 1px;
  background: var(--copper);
  flex-shrink: 0;
}

/* Secondary note under the card */
.gbp-note {
  font-family: 'Geist', ui-sans-serif, system-ui, sans-serif;
  font-size: 12px;
  color: var(--mist);
  margin-top: 14px;
  max-width: 460px;
  margin-left: auto;
  text-align: right;
  line-height: 1.5;
}

/* Responsive */
@media (max-width: 1023px) {
  .gbp-card, .gbp-caption, .gbp-note { margin-left: 0; margin-right: 0; max-width: 100%; }
  .gbp-caption { justify-content: flex-start; }
  .gbp-note { text-align: left; }
}

