/* Base Reset */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg: #F8F5F0;
  --bg2: #F0EDE6;
  --fg: #1A1614;
  --fg-mid: #5C5651;
  --fg-light: #9B9590;
  --accent: #C96C3A;
  --accent-light: #E8A878;
  --sage: #8B8C7A;
  --sage-light: #B8B9A8;
  --border: #E0DDD8;
  --card: #FFFFFF;
}

html { font-size: 16px; scroll-behavior: smooth; }
body { background: var(--bg); color: var(--fg); font-family: 'DM Sans', sans-serif; font-weight: 400; line-height: 1.6; -webkit-font-smoothing: antialiased; }

/* Navigation */
.nav { display: flex; align-items: center; justify-content: space-between; padding: 24px 48px; border-bottom: 1px solid var(--border); background: var(--bg); position: sticky; top: 0; z-index: 100; }
.nav-brand { display: flex; align-items: center; gap: 10px; }
.nav-logo { display: flex; align-items: center; }
.nav-name { font-family: 'Playfair Display', serif; font-size: 1.2rem; font-weight: 600; letter-spacing: -0.01em; }
.nav-tagline { font-size: 0.8rem; color: var(--fg-light); font-weight: 400; letter-spacing: 0.05em; text-transform: uppercase; }

/* Hero */
.hero { padding: 80px 48px 100px; position: relative; overflow: hidden; }
.hero::before { content: ''; position: absolute; top: 0; right: 0; width: 45%; height: 100%; background: var(--fg); clip-path: polygon(8% 0, 100% 0, 100% 100%, 0% 100%); z-index: 0; }
.hero-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; max-width: 1320px; margin: 0 auto; position: relative; z-index: 1; }
.hero-eyebrow { font-size: 0.75rem; font-weight: 500; letter-spacing: 0.12em; text-transform: uppercase; color: var(--accent); margin-bottom: 20px; }
.hero-headline { font-family: 'Playfair Display', serif; font-size: clamp(2.4rem, 4vw, 3.8rem); font-weight: 600; line-height: 1.1; letter-spacing: -0.02em; color: var(--fg); margin-bottom: 24px; }
.hero-sub { font-size: 1.1rem; color: var(--fg-mid); max-width: 460px; line-height: 1.7; margin-bottom: 48px; }
.hero-stats { display: flex; align-items: center; gap: 32px; }
.stat { display: flex; flex-direction: column; }
.stat-num { font-family: 'Playfair Display', serif; font-size: 2rem; font-weight: 700; color: var(--fg); line-height: 1; }
.stat-label { font-size: 0.75rem; color: var(--fg-light); text-transform: uppercase; letter-spacing: 0.06em; margin-top: 4px; }
.stat-divider { width: 1px; height: 36px; background: var(--border); }
.hero-scroll-hint { display: flex; align-items: center; gap: 12px; margin-top: 64px; color: var(--fg-light); font-size: 0.8rem; letter-spacing: 0.05em; text-transform: uppercase; max-width: 1320px; margin-left: auto; margin-right: auto; }
.scroll-line { width: 40px; height: 1px; background: var(--fg-light); }

/* Content Canvas (right side hero) */
.hero-right { position: relative; height: 520px; }
.content-canvas { position: absolute; inset: 0; }
.canvas-card { position: absolute; background: var(--card); border: 1px solid var(--border); border-radius: 10px; padding: 20px; box-shadow: 0 4px 24px rgba(0,0,0,0.08); }
.canvas-label { font-size: 0.68rem; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--fg-mid); margin-bottom: 12px; }
.canvas-card-1 { top: 0; left: 0; right: 80px; z-index: 4; }
.canvas-card-2 { bottom: 40px; left: 0; width: 180px; z-index: 3; }
.canvas-card-3 { top: 20px; right: 0; width: 200px; z-index: 2; }
.canvas-card-4 { bottom: 0; right: 40px; width: 200px; z-index: 1; }
.canvas-lines { display: flex; flex-direction: column; gap: 8px; }
.cl { height: 8px; border-radius: 4px; background: var(--fg); opacity: 0.08; }
.cl-long { width: 100%; }
.cl-med { width: 70%; }
.cl-short { width: 45%; }
.canvas-tag { font-size: 0.6rem; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; padding: 4px 8px; border-radius: 4px; display: inline-block; margin-top: 12px; }
.terracotta { background: #FDF0E8; color: var(--accent); }
.sage { background: #F4F4F0; color: var(--sage); }
.social-row { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.social-icon { width: 16px; height: 16px; border-radius: 50%; border: 1.5px solid var(--accent); opacity: 0.5; flex-shrink: 0; }
.social-lines { flex: 1; }
.sl { height: 5px; background: var(--fg); opacity: 0.08; border-radius: 3px; margin-bottom: 5px; }
.sl-short { width: 60%; }
.seo-lines { display: flex; flex-direction: column; gap: 6px; margin-bottom: 10px; }
.sl-headline { height: 10px; width: 75%; background: var(--fg); opacity: 0.15; border-radius: 4px; }
.seo-bar { height: 4px; background: var(--border); border-radius: 2px; overflow: hidden; }
.seo-fill { height: 100%; width: 72%; background: var(--accent); border-radius: 2px; }
.script-row { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
.script-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--fg); opacity: 0.15; flex-shrink: 0; }
.canvas-orb { position: absolute; border-radius: 50%; }
.orb-1 { width: 200px; height: 200px; background: var(--accent); opacity: 0.05; top: 40%; right: -60px; z-index: 0; }
.orb-2 { width: 140px; height: 140px; background: var(--sage); opacity: 0.07; bottom: 10%; left: 30%; z-index: 0; }

/* Manifesto */
.manifesto { background: var(--fg); padding: 100px 48px; }
.manifesto-inner { max-width: 800px; margin: 0 auto; text-align: center; }
.manifesto-ornament { font-size: 2rem; color: var(--accent); margin-bottom: 40px; font-family: 'Playfair Display', serif; }
.manifesto-text { font-family: 'Playfair Display', serif; font-size: clamp(1.4rem, 2.5vw, 2rem); font-weight: 400; font-style: italic; line-height: 1.5; color: #F8F5F0; margin-bottom: 48px; letter-spacing: -0.01em; }
.manifesto-rule { width: 60px; height: 2px; background: var(--accent); margin: 0 auto 40px; }
.manifesto-cta { font-size: 1.05rem; color: var(--fg-light); line-height: 1.7; }

/* Features */
.features { padding: 100px 48px; background: var(--bg); }
.features-header { text-align: center; max-width: 580px; margin: 0 auto 64px; }
.section-title { font-family: 'Playfair Display', serif; font-size: clamp(1.8rem, 3vw, 2.6rem); font-weight: 600; line-height: 1.2; letter-spacing: -0.02em; margin-bottom: 16px; color: var(--fg); }
.section-sub { font-size: 1.05rem; color: var(--fg-mid); line-height: 1.6; }
.features-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--border); border: 1px solid var(--border); border-radius: 12px; overflow: hidden; max-width: 1320px; margin: 0 auto; }
.feature-card { background: var(--card); padding: 36px 28px; }
.feature-card-main { grid-column: span 2; }
.feature-icon { margin-bottom: 20px; }
.feature-name { font-family: 'Playfair Display', serif; font-size: 1.15rem; font-weight: 600; margin-bottom: 10px; color: var(--fg); }
.feature-desc { font-size: 0.9rem; color: var(--fg-mid); line-height: 1.6; margin-bottom: 16px; }
.feature-detail { font-size: 0.75rem; color: var(--accent); font-weight: 500; }

/* Pricing */
.pricing { padding: 100px 48px; background: var(--bg2); }
.pricing-header { text-align: center; max-width: 580px; margin: 0 auto 64px; }
.pricing-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; max-width: 1100px; margin: 0 auto; }
.price-card { background: var(--card); border: 1px solid var(--border); border-radius: 12px; padding: 40px 32px; position: relative; }
.price-card-featured { border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent), 0 8px 32px rgba(201,108,58,0.1); }
.price-badge { position: absolute; top: -12px; left: 50%; transform: translateX(-50%); background: var(--accent); color: #fff; font-size: 0.7rem; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; padding: 4px 14px; border-radius: 20px; white-space: nowrap; }
.price-tier { font-size: 0.8rem; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-mid); margin-bottom: 16px; }
.price-range { font-family: 'Playfair Display', serif; font-size: 2.8rem; font-weight: 700; color: var(--fg); line-height: 1; margin-bottom: 8px; }
.price-sub { font-size: 1.4rem; font-weight: 400; }
.per-mo { font-size: 1rem; font-weight: 400; color: var(--fg-mid); }
.price-note { font-size: 0.85rem; color: var(--fg-light); margin-bottom: 28px; line-height: 1.5; }
.price-includes { display: flex; flex-direction: column; gap: 12px; }
.pi-item { display: flex; align-items: flex-start; gap: 10px; font-size: 0.9rem; color: var(--fg-mid); }
.pi-check { color: var(--accent); font-weight: 600; flex-shrink: 0; }

/* Closing */
.closing { background: var(--bg); padding: 100px 48px; border-top: 1px solid var(--border); }
.closing-inner { max-width: 900px; margin: 0 auto; text-align: center; }
.closing-rule { display: block; width: 60px; height: 2px; background: var(--accent); margin: 0 auto 48px; }
.closing-text { font-family: 'Playfair Display', serif; font-size: clamp(1.3rem, 2vw, 1.8rem); font-style: italic; line-height: 1.5; color: var(--fg); margin-bottom: 56px; }
.closing-statement { display: flex; align-items: center; justify-content: center; gap: 16px; flex-wrap: wrap; }
.closing-num { font-family: 'Playfair Display', serif; font-size: 3rem; font-weight: 700; color: var(--accent); line-height: 1; }
.closing-label { font-size: 1rem; color: var(--fg-mid); max-width: 480px; line-height: 1.5; }

/* Footer */
.footer { background: var(--fg); padding: 48px; text-align: center; }
.footer-brand { display: flex; align-items: center; justify-content: center; gap: 10px; margin-bottom: 12px; font-family: 'Playfair Display', serif; font-size: 1.1rem; font-weight: 600; color: #F8F5F0; }
.footer-tagline { color: var(--fg-light); font-size: 0.9rem; margin-bottom: 8px; }
.footer-note { color: var(--fg-light); font-size: 0.8rem; opacity: 0.6; }

/* Responsive */
@media (max-width: 1024px) {
  .features-grid { grid-template-columns: repeat(2, 1fr); }
  .feature-card-main { grid-column: span 2; }
  .pricing-grid { grid-template-columns: 1fr; max-width: 480px; }
}

@media (max-width: 768px) {
  .nav { padding: 20px 24px; }
  .hero { padding: 60px 24px 80px; }
  .hero::before { display: none; }
  .hero-inner { grid-template-columns: 1fr; gap: 48px; }
  .hero-right { height: 320px; }
  .features-grid { grid-template-columns: 1fr; }
  .feature-card-main { grid-column: span 1; }
  .manifesto, .pricing, .closing, .features, .footer { padding-left: 24px; padding-right: 24px; }
  .hero-stats { flex-wrap: wrap; gap: 24px; }
}