/* ============================================================
   BOOK PAGE — multi-step intake form, premium styling
   Matches the home page design system (Geist + Instrument Serif).
   ============================================================ */

/* ── BACKGROUND VIDEO ── */
.book-bg {
    position: fixed;
    inset: 0;
    z-index: 0;
    overflow: hidden;
    pointer-events: none;
}
.book-bg video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}
.book-bg::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(
        135deg,
        rgba(4, 3, 10, 0.88) 0%,
        rgba(6, 4, 14, 0.82) 50%,
        rgba(4, 3, 10, 0.88) 100%
    );
}

/* Everything above the bg */
.nav, .page-header, .book-section, .footer {
    position: relative;
    z-index: 1;
}

/* Page-level layout */
.book-section {padding:40px 0 120px;position:relative}
.book-section .container {max-width:1240px}

/* Page header above the form */
@keyframes book-header-in {
    from { opacity: 0; transform: translateY(24px); }
    to   { opacity: 1; transform: translateY(0); }
}
.page-header .tag        { animation: book-header-in 0.6s ease both; animation-delay: 0.1s; }
.page-header .page-title { animation: book-header-in 0.7s ease both; animation-delay: 0.2s; }
.page-header .page-subtitle { animation: book-header-in 0.7s ease both; animation-delay: 0.35s; }
.page-header {padding:120px 0 20px;text-align:center;position:relative}
.page-header .container {max-width:780px}
.page-header .tag {display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:.72rem;font-weight:600;letter-spacing:.22em;color:rgba(255,255,255,.92);text-transform:uppercase;padding:0;border:none;background:none;margin-bottom:18px}
.page-header .tag::before {content:'';display:inline-block;width:6px;height:6px;border-radius:999px;background:var(--accent);box-shadow:0 0 0 2px rgba(255,107,40,.16)}
.page-title {font-family:var(--display);font-size:clamp(2.4rem,5.5vw,4.4rem);font-weight:800;letter-spacing:-.04em;line-height:1.02;color:#fff;margin:0 0 18px}
.page-title .gradient-text {font-family:var(--editorial);font-style:italic;font-weight:400;color:var(--accent2);background:none;-webkit-text-fill-color:initial;letter-spacing:-.02em}
.page-subtitle {font-size:clamp(1rem,1.2vw,1.15rem);color:rgba(255,255,255,.9);line-height:1.65;max-width:620px;margin:0 auto}

/* Two-column layout: text left, form right */
.contact-wrap {display:grid;grid-template-columns:1fr;gap:48px;margin-top:48px}
@media (min-width:960px) {
    .contact-wrap {grid-template-columns:5fr 7fr;gap:56px;align-items:start}
    .contact-left {position:sticky;top:96px}
}

/* LEFT pane */
.contact-left .tag {display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:.7rem;font-weight:600;letter-spacing:.22em;color:rgba(255,255,255,.92);text-transform:uppercase;padding:0;border:none;background:none;margin-bottom:20px}
.contact-left .tag::before {content:'';display:inline-block;width:6px;height:6px;border-radius:999px;background:var(--accent);box-shadow:0 0 0 2px rgba(255,107,40,.16)}
.contact-left h2 {font-family:var(--display);font-size:clamp(2rem,3.4vw,2.8rem);font-weight:800;letter-spacing:-.04em;line-height:1.04;color:#fff;margin:0 0 16px}
.contact-left > p {font-size:1rem;color:rgba(255,255,255,.9);line-height:1.65;margin:0 0 32px;max-width:480px}

.contact-info-list {display:flex;flex-direction:column;gap:12px}
.ci {display:flex;align-items:center;gap:14px;padding:14px 16px;border:1px solid rgba(255,107,40,.18);border-radius:14px;background:linear-gradient(155deg,rgba(255,107,40,.06),rgba(255,107,40,.01));transition:transform .35s var(--ease),border-color .35s ease,background .35s ease}
.ci:hover {transform:translateY(-2px);border-color:rgba(255,107,40,.4);background:linear-gradient(155deg,rgba(255,107,40,.12),rgba(255,107,40,.02))}
.ci-icon {width:38px;height:38px;border-radius:10px;background:rgba(255,107,40,.14);border:1px solid rgba(255,107,40,.28);display:grid;place-items:center;color:var(--accent2);flex-shrink:0}
.ci a {font-family:var(--display);font-size:.92rem;font-weight:600;color:#fff !important;letter-spacing:-.01em}

/* =====================================================
   INTAKE FORM
   ===================================================== */
.intake-form {position:relative;padding:32px 32px 36px;border:1px solid rgba(255,255,255,.08);border-radius:24px;background:linear-gradient(155deg,#0c0810 0%,#08060c 100%);box-shadow:0 30px 80px rgba(0,0,0,.5),0 0 0 1px rgba(255,107,40,.06)}
.intake-form::before {content:'';position:absolute;left:0;right:0;top:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,107,40,.45),transparent);opacity:.7}

/* Progress bar */
.intake-progress {margin-bottom:32px}
.ip-bar {position:relative;height:4px;background:rgba(255,255,255,.06);border-radius:2px;overflow:hidden;margin-bottom:14px}
.ip-fill {height:100%;background:linear-gradient(90deg,#ff5722 0%,#ff8c42 100%);box-shadow:0 0 12px rgba(255,107,40,.55);border-radius:2px;transition:width .55s cubic-bezier(.22,.85,.28,1)}
.ip-steps {display:flex;justify-content:space-between;gap:8px}
.ip-step {font-family:var(--mono);font-size:.62rem;font-weight:600;letter-spacing:.08em;color:rgba(255,255,255,.85);text-transform:uppercase;text-align:center;flex:1;transition:color .3s ease}
.ip-step.active {color:var(--accent2)}
.ip-step.done {color:rgba(255,255,255,.88)}

/* Step containers — only the active one shows */
.intake-step {display:none}
.intake-step.active {display:block;animation:intake-fade-in .5s cubic-bezier(.22,.85,.28,1)}
@keyframes intake-fade-in {from {opacity:0;transform:translateY(12px)} to {opacity:1;transform:translateY(0)}}

/* Step header */
.intake-head {margin-bottom:24px}
.intake-eyebrow {display:inline-block;font-family:var(--mono);font-size:.62rem;font-weight:600;letter-spacing:.2em;color:var(--accent2);text-transform:uppercase;margin-bottom:12px;padding:5px 12px;border:1px solid rgba(255,107,40,.28);border-radius:999px;background:rgba(255,107,40,.06)}
.intake-head h3 {font-family:var(--display);font-size:clamp(1.5rem,2.6vw,1.9rem);font-weight:800;letter-spacing:-.035em;line-height:1.1;color:#fff;margin:0 0 8px}
.intake-head p {font-size:.92rem;color:rgba(255,255,255,.88);line-height:1.55;margin:0;max-width:520px}

/* CHOICE GRID — step 1's radio cards */
.choice-grid {display:grid;grid-template-columns:1fr;gap:10px;margin-bottom:28px}
.choice {position:relative;cursor:pointer;display:block}
.choice input[type="radio"] {position:absolute;opacity:0;pointer-events:none;width:0;height:0}
.choice-inner {display:grid;grid-template-columns:44px 1fr;gap:14px;align-items:center;padding:14px 16px;border:1px solid rgba(255,255,255,.08);border-radius:14px;background:linear-gradient(155deg,rgba(20,18,22,.5),rgba(8,8,12,.5));transition:transform .3s var(--ease),border-color .3s ease,background .3s ease,box-shadow .3s ease}
.choice:hover .choice-inner {border-color:rgba(255,107,40,.32);background:linear-gradient(155deg,rgba(255,107,40,.08),rgba(255,107,40,.01));transform:translateY(-1px)}
.choice input:checked ~ .choice-inner {border-color:rgba(255,107,40,.55);background:linear-gradient(155deg,rgba(255,107,40,.14),rgba(255,107,40,.02));box-shadow:0 0 0 1px rgba(255,107,40,.25),0 12px 28px rgba(255,107,40,.18)}
.choice input:focus-visible ~ .choice-inner {outline:2px solid var(--accent);outline-offset:2px}
.choice-icon {width:42px;height:42px;display:grid;place-items:center;border-radius:10px;border:1px solid rgba(255,107,40,.25);background:linear-gradient(155deg,rgba(255,107,40,.12),rgba(255,107,40,.02));color:var(--accent2);flex-shrink:0;transition:color .3s ease,border-color .3s ease,background .3s ease}
.choice input:checked ~ .choice-inner .choice-icon {color:#ffb066;border-color:rgba(255,107,40,.55);background:linear-gradient(155deg,rgba(255,107,40,.22),rgba(255,107,40,.06))}
.choice-icon svg {width:20px;height:20px}
.choice strong {display:block;font-family:var(--display);font-size:.98rem;font-weight:700;color:#fff;letter-spacing:-.015em;margin-bottom:3px;line-height:1.25}
.choice em {display:block;font-style:normal;font-size:.82rem;color:rgba(255,255,255,.88);line-height:1.45}

/* Pill-style radio for budget/timeline */
.choice-row {display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.choice-pill {position:relative;cursor:pointer}
.choice-pill input[type="radio"] {position:absolute;opacity:0;pointer-events:none;width:0;height:0}
.choice-pill span {display:inline-block;padding:10px 16px;border:1px solid rgba(255,255,255,.1);border-radius:999px;background:rgba(255,255,255,.02);font-family:var(--display);font-size:.84rem;font-weight:600;color:rgba(255,255,255,.75);letter-spacing:-.005em;transition:transform .25s var(--ease),border-color .25s ease,background .25s ease,color .25s ease}
.choice-pill:hover span {border-color:rgba(255,107,40,.4);color:#fff;transform:translateY(-1px)}
.choice-pill input:checked ~ span {border-color:rgba(255,107,40,.55);background:linear-gradient(135deg,rgba(255,107,40,.2),rgba(255,107,40,.05));color:var(--accent2);box-shadow:0 6px 16px rgba(255,107,40,.18)}
.choice-pill input:focus-visible ~ span {outline:2px solid var(--accent);outline-offset:2px}

/* Form fields (text/email/url/textarea/select) */
.field {margin-bottom:18px}
.field label, .field .label {display:block;font-family:var(--display);font-size:.84rem;font-weight:600;color:#fff;letter-spacing:-.005em;margin-bottom:8px}
.field-optional {font-family:var(--mono);font-size:.7rem;font-weight:500;color:rgba(255,255,255,.85);letter-spacing:.04em;margin-left:6px}
.field input, .field textarea, .field select {
    width:100%;
    padding:13px 16px;
    border:1px solid rgba(255,255,255,.1);
    border-radius:12px;
    background:rgba(255,255,255,.025);
    color:#fff;
    font-family:var(--font);
    font-size:.95rem;
    line-height:1.4;
    transition:border-color .3s ease,background .3s ease,box-shadow .3s ease;
    -webkit-appearance:none;
    appearance:none;
}
.field textarea {resize:vertical;min-height:80px;line-height:1.5}
.field input::placeholder, .field textarea::placeholder {color:rgba(255,255,255,.82)}
.field input:focus, .field textarea:focus, .field select:focus {outline:none;border-color:rgba(255,107,40,.5);background:rgba(255,107,40,.04);box-shadow:0 0 0 3px rgba(255,107,40,.12)}
.field select {background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23ff8c42' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;padding-right:42px;cursor:pointer}
.field select option {background:#0c0810;color:#fff}

/* 2-col form rows (step 4) */
.form-2col {display:grid;grid-template-columns:1fr;gap:18px}
@media (min-width:520px) {.form-2col {grid-template-columns:1fr 1fr}}

/* Navigation row */
.intake-nav {display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:28px;padding-top:24px;border-top:1px dashed rgba(255,255,255,.08)}
.intake-nav .btn {min-width:140px}
.intake-nav .intake-back {min-width:auto}
.intake-nav span:empty {display:block;width:1px}

/* Summary block on step 4 */
.intake-summary {padding:16px 18px;border:1px dashed rgba(255,107,40,.3);border-radius:12px;background:rgba(255,107,40,.04);margin-top:18px;font-family:var(--mono);font-size:.78rem;color:rgba(255,255,255,.75);line-height:1.6}
.intake-summary:empty {display:none}
.intake-summary strong {font-family:var(--display);color:var(--accent2);font-weight:700}

/* Form note at bottom */
.form-note {display:flex;align-items:center;gap:8px;margin:18px 0 0;padding:12px 14px;background:rgba(74,222,128,.05);border:1px solid rgba(74,222,128,.18);border-radius:10px;font-family:var(--mono);font-size:.72rem;color:rgba(74,222,128,.9);letter-spacing:.03em;line-height:1.5}
.form-note strong {color:#fff;font-weight:700}
.form-dot {width:7px;height:7px;border-radius:999px;background:#4ade80;box-shadow:0 0 0 2px rgba(74,222,128,.18);animation:status-core 2.4s ease-in-out infinite;flex-shrink:0}

/* Success state (after submit) */
.intake-success {text-align:center;padding:40px 20px}
.intake-success h3 {font-family:var(--display);font-size:1.8rem;color:#fff;margin:0 0 12px}
.intake-success p {color:rgba(255,255,255,.9);max-width:480px;margin:0 auto}

/* ── TRUST STATS ── */
.book-stats {
    display: flex;
    gap: 0;
    margin: 28px 0 32px;
    border: 1px solid rgba(255,255,255,0.07);
    border-radius: 14px;
    overflow: hidden;
}
.book-stat {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 16px 12px;
    border-right: 1px solid rgba(255,255,255,0.07);
    background: rgba(255,255,255,0.02);
}
.book-stat:last-child { border-right: none; }
.book-stat-num {
    font-family: var(--display);
    font-size: 1.5rem;
    font-weight: 800;
    color: #ff6b28;
    letter-spacing: -0.03em;
    line-height: 1;
    text-shadow: 0 0 20px rgba(255,107,40,0.35);
}
.book-stat-label {
    font-size: 0.6rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: rgba(255,255,255,0.45);
    margin-top: 5px;
    text-align: center;
}

/* ── TERMINAL ── */
.book-terminal {
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 14px;
    overflow: hidden;
    background: rgba(5,5,12,0.85);
    margin-bottom: 32px;
}
.bt-bar {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 10px 14px;
    background: rgba(255,255,255,0.03);
    border-bottom: 1px solid rgba(255,255,255,0.06);
}
.bt-dot { width: 10px; height: 10px; border-radius: 50%; }
.bt-r { background: #ff5f57; }
.bt-y { background: #febc2e; }
.bt-g { background: #28c840; }
.bt-title {
    font-family: var(--mono);
    font-size: 0.65rem;
    color: rgba(255,255,255,0.3);
    margin-left: 6px;
    letter-spacing: 0.05em;
}
.bt-body {
    padding: 14px 16px;
    min-height: 130px;
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.bt-line {
    font-family: var(--mono);
    font-size: 0.72rem;
    letter-spacing: 0.02em;
    line-height: 1.5;
}
.bt-line::after {
    content: '▋';
    animation: cursor-blink 0.8s step-end infinite;
    opacity: 0;
}
.bt-line:last-child::after { opacity: 1; }
@keyframes cursor-blink {
    0%, 100% { opacity: 1; }
    50% { opacity: 0; }
}

/* ── WHAT HAPPENS NEXT ── */
.book-next {
    margin-bottom: 28px;
}
.bn-label {
    font-family: var(--mono);
    font-size: 0.6rem;
    font-weight: 700;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.3);
    margin-bottom: 14px;
}
.bn-steps {
    display: flex;
    flex-direction: column;
    gap: 0;
}
.bn-step {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    padding: 14px 0;
    border-bottom: 1px solid rgba(255,255,255,0.05);
    position: relative;
}
.bn-step:last-child { border-bottom: none; }
.bn-num {
    font-family: var(--mono);
    font-size: 0.62rem;
    font-weight: 700;
    color: #ff6b28;
    letter-spacing: 0.1em;
    flex-shrink: 0;
    margin-top: 2px;
    width: 22px;
}
.bn-text {
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.bn-text strong {
    font-family: var(--display);
    font-size: 0.88rem;
    font-weight: 700;
    color: #fff;
    letter-spacing: -0.01em;
}
.bn-text span {
    font-size: 0.78rem;
    color: rgba(255,255,255,0.45);
    line-height: 1.45;
}

/* Mobile tightening */
@media (max-width:880px) {
    .book-section {padding:20px 0 80px}
    .page-header {padding:96px 0 16px}
    .intake-form {padding:24px 20px 28px;border-radius:18px}
    .contact-left {position:relative;top:auto}
    .contact-wrap {gap:32px;margin-top:32px}
    .intake-head h3 {font-size:1.45rem}
    .intake-head p {font-size:.86rem}
    .choice-inner {padding:13px 14px;grid-template-columns:38px 1fr;gap:12px}
    .choice-icon {width:38px;height:38px}
    .choice-icon svg {width:18px;height:18px}
    .choice strong {font-size:.92rem}
    .choice em {font-size:.78rem}
    .intake-nav .btn {min-width:auto;flex:1;padding:14px 18px;font-size:.84rem}
    .intake-nav .intake-back {flex:0 0 auto;padding:14px 18px}
}
@media (max-width:480px) {
    .ip-steps {gap:4px}
    .ip-step {font-size:.55rem;letter-spacing:.06em}
    .intake-form {padding:20px 16px 24px}
    .intake-eyebrow {font-size:.56rem;padding:4px 10px}
    .intake-head h3 {font-size:1.3rem}
    .choice-row {gap:6px}
    .choice-pill span {padding:8px 12px;font-size:.78rem}
    .field input, .field textarea, .field select {padding:12px 14px;font-size:.9rem}
}
