/* ==========================================================================
   Insights Reporter — landing page
   Concept: "The Morning Watch" — watched through the night, one clear move by
   first light. Teal-night hero → warm first-light briefing card (the signature)
   → daylight sections that sell advisor-not-reporter.
   Vanilla CSS, no build step. Mobile-first.
   ========================================================================== */

:root {
    /* Night + first light */
    --ink:        #0a262c;   /* teal-night — hero / dark bands */
    --ink-deep:   #06181c;   /* darker — footer */
    --ink-soft:   #123741;   /* raised panel on dark */
    --paper:      #f6f0e4;   /* warm "first light" — the brief card */
    --cloud:      #ffffff;   /* light surface / cards */
    --fog:        #eef3f2;   /* light section background */

    /* Accent + status */
    --dawn:       #eaa53e;   /* gold — sunrise, primary action */
    --dawn-deep:  #c9831d;   /* gold pressed */
    --up:         #2fa46a;   /* good / rising */
    --down:       #d05a48;   /* needs attention */

    /* Text */
    --on-ink:       #eef4f3;
    --on-ink-mute:  #9bb3b2;
    --on-paper:     #16282a;
    --on-paper-mute:#5c6f6e;

    /* Lines */
    --line:      #dde6e4;
    --line-ink:  rgba(255, 255, 255, 0.12);

    --container: 1140px;
    --radius:    14px;
    --radius-sm: 9px;

    --display: "Fraunces", Georgia, "Times New Roman", serif;
    --body:    "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
    --mono:    "IBM Plex Mono", ui-monospace, "SFMono-Regular", Menlo, monospace;
}

* { box-sizing: border-box; }

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

body {
    margin: 0;
    font-family: var(--body);
    color: var(--on-paper);
    background: var(--cloud);
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}

h1, h2, h3 { font-family: var(--display); font-weight: 600; line-height: 1.08; margin: 0; letter-spacing: -0.015em; }
p { margin: 0; }
a { color: inherit; text-decoration: none; }

.container { width: 100%; max-width: var(--container); margin: 0 auto; padding: 0 1.4rem; }

.eyebrow {
    font-family: var(--mono);
    font-size: 0.72rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--dawn);
    margin: 0 0 1.1rem;
}
.section-eyebrow { color: var(--on-paper-mute); }

/* ---- Buttons -------------------------------------------------------------- */
.btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-family: var(--body);
    font-weight: 600;
    font-size: 0.98rem;
    line-height: 1;
    padding: 0.92rem 1.4rem;
    border-radius: var(--radius-sm);
    border: 1.5px solid transparent;
    cursor: pointer;
    transition: transform 0.15s ease, background-color 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}
.btn-primary { background: var(--dawn); color: #2a1c05; }
.btn-primary:hover { background: var(--dawn-deep); transform: translateY(-1px); }
.btn-ghost { background: transparent; color: var(--on-ink); border-color: var(--line-ink); }
.btn-ghost:hover { border-color: var(--on-ink-mute); transform: translateY(-1px); }
.btn-dark { background: var(--ink); color: var(--on-ink); }
.btn-dark:hover { background: var(--ink-soft); transform: translateY(-1px); }
.btn-lg { padding: 1.05rem 1.7rem; font-size: 1.04rem; }

.btn:focus-visible,
a:focus-visible { outline: 3px solid var(--dawn); outline-offset: 3px; border-radius: 4px; }

/* ---- Header --------------------------------------------------------------- */
.site-header {
    position: absolute;
    inset: 0 0 auto 0;
    z-index: 10;
    padding: 1.25rem 0;
}
.site-header .container { display: flex; align-items: center; justify-content: space-between; }
.wordmark {
    font-family: var(--display);
    font-weight: 600;
    font-size: 1.2rem;
    letter-spacing: -0.02em;
    color: var(--on-ink);
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
}
.wordmark .mark {
    width: 1.55rem; height: 1.55rem; flex: none;
    display: grid; place-items: center;
    border-radius: 6px;
    background: var(--dawn);
    color: #2a1c05;
    font-family: var(--mono);
    font-weight: 600;
    font-size: 0.82rem;
}
.site-nav { display: flex; align-items: center; gap: 1.6rem; }
.site-nav a.nav-link { color: var(--on-ink-mute); font-size: 0.92rem; font-weight: 500; transition: color 0.15s ease; }
.site-nav a.nav-link:hover { color: var(--on-ink); }
.nav-link.hide-sm { display: none; }

/* ---- Hero ----------------------------------------------------------------- */
.hero {
    position: relative;
    background:
        radial-gradient(120% 90% at 88% -10%, rgba(234, 165, 62, 0.16), transparent 55%),
        radial-gradient(90% 70% at 0% 110%, rgba(47, 164, 106, 0.10), transparent 60%),
        var(--ink);
    color: var(--on-ink);
    padding: 7.5rem 0 4.5rem;
    overflow: hidden;
}
.hero-grid { display: grid; gap: 3rem; align-items: center; }
.hero-copy { max-width: 36rem; }
.hero h1 {
    color: var(--on-ink);
    font-size: clamp(2.5rem, 7.5vw, 3.9rem);
    font-weight: 600;
}
.hero h1 em { font-style: italic; color: var(--dawn); }
.hero-sub {
    margin: 1.5rem 0 2.2rem;
    font-size: 1.12rem;
    color: var(--on-ink-mute);
    max-width: 33rem;
}
.hero-actions { display: flex; flex-wrap: wrap; gap: 0.8rem; align-items: center; }

.badge {
    display: inline-flex; align-items: center; gap: 0.5rem;
    font-family: var(--mono); font-size: 0.72rem; letter-spacing: 0.1em; text-transform: uppercase;
    color: var(--on-ink-mute);
    border: 1px solid var(--line-ink); border-radius: 999px;
    padding: 0.4rem 0.8rem;
    margin-bottom: 1.6rem;
}
.badge .dot { width: 0.5rem; height: 0.5rem; border-radius: 50%; background: var(--up); box-shadow: 0 0 0 0 rgba(47,164,106,0.5); animation: pulse 2.6s infinite; }

/* ---- The signature: morning brief card ------------------------------------ */
.brief {
    background: var(--paper);
    color: var(--on-paper);
    border-radius: var(--radius);
    padding: 1.5rem 1.5rem 1.65rem;
    box-shadow: 0 30px 60px -22px rgba(0, 0, 0, 0.55), 0 0 0 1px rgba(255,255,255,0.04);
    max-width: 27rem;
    width: 100%;
    justify-self: center;
}
.brief-top { display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.brief-title { font-family: var(--mono); font-size: 0.72rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--on-paper-mute); }
.brief-tag { font-family: var(--mono); font-size: 0.62rem; letter-spacing: 0.1em; text-transform: uppercase; color: #8a6d2e; background: rgba(234,165,62,0.18); border-radius: 999px; padding: 0.18rem 0.5rem; }
.brief-score { display: flex; align-items: baseline; gap: 0.7rem; margin: 1.1rem 0 0.2rem; }
.brief-score .num { font-family: var(--display); font-weight: 600; font-size: 3.2rem; line-height: 0.9; letter-spacing: -0.02em; }
.brief-score .delta { font-family: var(--mono); font-size: 0.92rem; font-weight: 500; color: var(--up); }
.brief-score .label { font-size: 0.82rem; color: var(--on-paper-mute); }
.brief-divider { height: 1px; background: rgba(22,40,42,0.12); margin: 1.15rem 0; }
.brief-section-label { font-family: var(--mono); font-size: 0.68rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--on-paper-mute); margin-bottom: 0.7rem; }
.brief-line { display: flex; align-items: flex-start; gap: 0.6rem; font-size: 0.92rem; margin-bottom: 0.5rem; }
.brief-line .glyph { font-family: var(--mono); font-weight: 600; line-height: 1.5; }
.brief-line.good .glyph { color: var(--up); }
.brief-line.flag .glyph { color: var(--down); }
.brief-move {
    margin-top: 1.15rem;
    border: 1.5px solid rgba(234,165,62,0.5);
    background: rgba(234,165,62,0.10);
    border-radius: var(--radius-sm);
    padding: 0.9rem 1rem;
}
.brief-move .move-label { font-family: var(--mono); font-size: 0.68rem; letter-spacing: 0.14em; text-transform: uppercase; color: #95701f; display: flex; align-items: center; gap: 0.45rem; margin-bottom: 0.4rem; }
.brief-move .move-text { font-size: 0.95rem; font-weight: 500; }

/* ---- Difference strip ----------------------------------------------------- */
.difference { background: var(--fog); padding: 4.5rem 0; }
.difference .container { max-width: 50rem; text-align: center; }
.difference h2 { font-size: clamp(1.9rem, 5vw, 2.9rem); }
.difference h2 .said { color: var(--on-paper-mute); }
.difference h2 .do { color: var(--ink); }
.difference p { margin-top: 1.2rem; color: var(--on-paper-mute); font-size: 1.08rem; }

/* ---- Section scaffolding -------------------------------------------------- */
.section { padding: 5rem 0; }
.section-head { max-width: 40rem; margin-bottom: 2.8rem; }
.section-head h2 { font-size: clamp(1.8rem, 4.5vw, 2.5rem); margin-top: 0.6rem; }
.section-head p { margin-top: 0.9rem; color: var(--on-paper-mute); font-size: 1.05rem; }

/* ---- Features (signal -> move) -------------------------------------------- */
.feature-grid { display: grid; gap: 1.1rem; grid-template-columns: 1fr; }
.feature {
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: 1.5rem;
    background: var(--cloud);
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}
.feature:hover { transform: translateY(-3px); box-shadow: 0 18px 36px -24px rgba(10,38,44,0.4); border-color: #cdd9d7; }
.feature .f-kicker { font-family: var(--mono); font-size: 0.7rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--dawn-deep); display: inline-flex; align-items: center; gap: 0.45rem; margin-bottom: 0.85rem; }
.feature h3 { font-size: 1.28rem; margin-bottom: 0.55rem; }
.feature p { color: var(--on-paper-mute); font-size: 0.96rem; }

/* ---- Audience chips ------------------------------------------------------- */
.audience { background: var(--ink); color: var(--on-ink); }
.audience .section-head h2 { color: var(--on-ink); }
.audience .section-head p { color: var(--on-ink-mute); }
.chips { display: flex; flex-wrap: wrap; gap: 0.7rem; }
.chip {
    font-size: 0.95rem; font-weight: 500;
    border: 1px solid var(--line-ink); border-radius: 999px;
    padding: 0.6rem 1.1rem; color: var(--on-ink);
    transition: border-color 0.15s ease, background-color 0.15s ease;
}
.chip:hover { border-color: var(--dawn); background: rgba(234,165,62,0.08); }

/* ---- Steps (a real sequence, so numbered) --------------------------------- */
.steps { display: grid; gap: 2rem; grid-template-columns: 1fr; counter-reset: step; }
.step { position: relative; padding-left: 3.6rem; }
.step::before {
    counter-increment: step; content: counter(step);
    position: absolute; left: 0; top: -0.2rem;
    width: 2.6rem; height: 2.6rem; border-radius: 50%;
    display: grid; place-items: center;
    font-family: var(--mono); font-weight: 600; font-size: 1rem;
    color: var(--ink); background: var(--paper); border: 1.5px solid var(--dawn);
}
.step h3 { font-size: 1.28rem; margin-bottom: 0.4rem; }
.step p { color: var(--on-paper-mute); font-size: 0.98rem; }

/* ---- Pricing -------------------------------------------------------------- */
.pricing { background: var(--fog); }
.price-grid { display: grid; gap: 1.1rem; grid-template-columns: 1fr; }
.price {
    background: var(--cloud); border: 1px solid var(--line);
    border-radius: var(--radius); padding: 1.7rem;
    display: flex; flex-direction: column;
}
.price.featured { border-color: var(--dawn); box-shadow: 0 18px 40px -26px rgba(234,165,62,0.7); }
.price .tier { font-family: var(--mono); font-size: 0.72rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--on-paper-mute); }
.price .featured-tag { color: var(--dawn-deep); }
.price .amount { font-family: var(--display); font-size: 2.6rem; font-weight: 600; margin: 0.6rem 0 0.1rem; letter-spacing: -0.02em; }
.price .amount span { font-family: var(--body); font-size: 0.95rem; font-weight: 500; color: var(--on-paper-mute); }
.price .desc { color: var(--on-paper-mute); font-size: 0.95rem; margin-top: 0.7rem; }

/* ---- Final CTA ------------------------------------------------------------ */
.cta-band {
    background:
        radial-gradient(90% 120% at 100% 0%, rgba(234,165,62,0.18), transparent 55%),
        var(--ink);
    color: var(--on-ink);
    text-align: center;
    padding: 5.5rem 0;
}
.cta-band h2 { color: var(--on-ink); font-size: clamp(2rem, 5vw, 3rem); max-width: 30rem; margin: 0 auto 1.6rem; }
.cta-actions { display: flex; flex-wrap: wrap; gap: 0.8rem; justify-content: center; }

/* ---- Footer --------------------------------------------------------------- */
.site-footer { background: var(--ink-deep); color: var(--on-ink-mute); padding: 3rem 0; }
.site-footer .container { display: flex; flex-wrap: wrap; gap: 1.2rem; align-items: center; justify-content: space-between; }
.site-footer .wordmark { color: var(--on-ink); font-size: 1.05rem; }
.footer-nav { display: flex; flex-wrap: wrap; gap: 1.4rem; }
.footer-nav a { color: var(--on-ink-mute); font-size: 0.9rem; transition: color 0.15s ease; }
.footer-nav a:hover { color: var(--on-ink); }
.footer-fine { width: 100%; font-family: var(--mono); font-size: 0.72rem; letter-spacing: 0.04em; color: #5f7574; border-top: 1px solid var(--line-ink); padding-top: 1.2rem; margin-top: 0.4rem; }

/* ---- Motion --------------------------------------------------------------- */
@keyframes pulse { 0% { box-shadow: 0 0 0 0 rgba(47,164,106,0.45); } 70% { box-shadow: 0 0 0 7px rgba(47,164,106,0); } 100% { box-shadow: 0 0 0 0 rgba(47,164,106,0); } }
@keyframes rise { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: translateY(0); } }
.reveal { animation: rise 0.7s cubic-bezier(0.2, 0.7, 0.2, 1) both; }
.reveal.d1 { animation-delay: 0.08s; }
.reveal.d2 { animation-delay: 0.16s; }
.reveal.d3 { animation-delay: 0.26s; }

@media (prefers-reduced-motion: reduce) {
    * { animation: none !important; transition: none !important; scroll-behavior: auto !important; }
}

/* ---- Responsive ----------------------------------------------------------- */
@media (min-width: 600px) {
    .nav-link.hide-sm { display: inline; }
    .price-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (min-width: 760px) {
    .feature-grid { grid-template-columns: repeat(2, 1fr); }
    .steps { grid-template-columns: repeat(3, 1fr); }
    .step { padding-left: 0; padding-top: 3.4rem; }
    .step::before { top: 0; }
}
@media (min-width: 960px) {
    .hero { padding: 9rem 0 5.5rem; }
    .hero-grid { grid-template-columns: 1.05fr 0.95fr; gap: 4rem; }
    .brief { justify-self: end; }
    .feature-grid { grid-template-columns: repeat(3, 1fr); }
}
