/* ===========================================================================
   Curta São Roque — folha de estilo
   Direção: editorial enoturismo · vinho & uva · elegante e acolhedor
   =========================================================================== */

:root {
    /* --- Cor: roxo vinho (primária) --- */
    --wine-900: #2a0b37;
    --wine-800: #341043;
    --wine-700: #480e5a;   /* primária */
    --wine-600: #5e1873;
    --wine-500: #7a2e94;   /* hover/realce */

    /* --- Verde folha da uva (acento) --- */
    --leaf-700: #5a9419;
    --leaf-500: #72bb21;
    --leaf-300: #8fd83c;

    /* --- Dourado de uva (terciário, fios finos) --- */
    --gold: #c9a24b;
    --gold-soft: #e3c987;

    /* --- Neutros quentes --- */
    --cream: #faf6f0;
    --cream-200: #f1e9dd;
    --ink: #241726;        /* texto sobre claro */
    --ink-soft: #5b4d5e;
    --dark: #170a1e;       /* quase-preto arroxeado (fundos escuros) */

    /* --- Papéis semânticos (tema claro acolhedor por padrão) --- */
    --bg: var(--cream);
    --surface: #ffffff;
    --text: var(--ink);
    --muted: var(--ink-soft);
    --accent: var(--leaf-700);
    --accent-bright: var(--leaf-500);
    --border: rgba(72, 14, 90, 0.12);

    /* --- Tipografia --- */
    --font-display: "Fraunces", Georgia, "Times New Roman", serif;
    --font-body: "Hanken Grotesk", system-ui, sans-serif;
    --step--1: clamp(0.82rem, 0.78rem + 0.2vw, 0.92rem);
    --step-0:  clamp(1rem, 0.96rem + 0.25vw, 1.12rem);
    --step-1:  clamp(1.2rem, 1.1rem + 0.5vw, 1.45rem);
    --step-2:  clamp(1.5rem, 1.3rem + 1vw, 2.1rem);
    --step-3:  clamp(2rem, 1.6rem + 2vw, 3.25rem);
    --step-4:  clamp(2.6rem, 1.9rem + 3.4vw, 5rem);

    /* --- Espaço (escala 8px) --- */
    --sp-1: 0.5rem;  --sp-2: 1rem;   --sp-3: 1.5rem;  --sp-4: 2rem;
    --sp-5: 2.5rem;  --sp-6: 3rem;   --sp-8: 4rem;    --sp-10: 6rem;

    /* --- Profundidade --- */
    --radius: 16px;
    --radius-sm: 10px;
    --shadow-sm: 0 1px 2px rgba(36, 10, 48, .08), 0 2px 8px rgba(36, 10, 48, .06);
    --shadow-md: 0 4px 12px rgba(36, 10, 48, .10), 0 18px 40px rgba(36, 10, 48, .12);
    --shadow-wine: 0 18px 50px rgba(52, 16, 67, .35);

    --wrap: 1180px;
    --ease: cubic-bezier(0.22, 1, 0.36, 1);
}

/* ---------- Reset enxuto ---------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
    font-family: var(--font-body);
    font-size: var(--step-0);
    line-height: 1.65;
    color: var(--text);
    background: var(--bg);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    overflow-x: hidden;
}
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; }
h1, h2, h3, h4 { font-family: var(--font-display); line-height: 1.1; font-weight: 600; letter-spacing: -0.01em; }
em { font-style: italic; }

.wrap { width: min(var(--wrap), 100% - 2.5rem); margin-inline: auto; }
.visually-hidden {
    position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
    overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}

/* ---------- Acessibilidade: foco e skip-link ---------- */
:focus-visible {
    outline: 3px solid var(--accent-bright);
    outline-offset: 2px;
    border-radius: 4px;
}
.skip-link {
    position: absolute; left: 50%; transform: translateX(-50%) translateY(-150%);
    top: 8px; z-index: 999; background: var(--wine-700); color: #fff;
    padding: .6rem 1rem; border-radius: 8px; transition: transform .2s var(--ease);
}
.skip-link:focus { transform: translateX(-50%) translateY(0); }

/* ===========================================================================
   Botões
   =========================================================================== */
.btn {
    display: inline-flex; align-items: center; gap: .5rem;
    padding: .7rem 1.2rem; border-radius: 999px; border: 1px solid transparent;
    font-weight: 600; font-size: var(--step--1); letter-spacing: .01em;
    transition: transform .2s var(--ease), box-shadow .2s var(--ease), background .2s var(--ease), color .2s var(--ease);
    will-change: transform;
}
.btn svg { width: 1.1em; height: 1.1em; }
.btn-lg { padding: .95rem 1.6rem; font-size: var(--step-0); }
.btn-accent {
    background: var(--accent); color: #fff;
    box-shadow: 0 6px 18px rgba(90, 148, 25, .35);
}
.btn-accent:hover { background: var(--accent-bright); transform: translateY(-2px); box-shadow: 0 10px 26px rgba(90,148,25,.42); }
.btn-ghost { background: transparent; color: #fff; border-color: rgba(255,255,255,.4); }
.btn-ghost:hover { background: rgba(255,255,255,.12); transform: translateY(-2px); }
.btn-nav { background: var(--wine-700); color: #fff; }
.btn-nav:hover { background: var(--wine-500); transform: translateY(-1px); }

/* ===========================================================================
   Cabeçalho
   =========================================================================== */
.brand-logo{
        width: 126px;
}

   .site-header {
    position: sticky; top: 0; z-index: 100;
    background: rgba(250, 246, 240, .82);
    backdrop-filter: saturate(180%) blur(14px);
    border-bottom: 1px solid var(--border);
}
.header-inner { display: flex; align-items: center; gap: var(--sp-3); height: 68px; }
.brand { display: inline-flex; align-items: center; gap: .55rem; font-size: 1.15rem; }
.brand-mark {
    display: grid; place-items: center; width: 38px; height: 38px;
    border-radius: 11px; color: #fff;
    background: linear-gradient(140deg, var(--wine-600), var(--wine-800));
    box-shadow: var(--shadow-sm);
}
.brand-mark svg { width: 22px; height: 22px; }
.brand-text { font-family: var(--font-display); }
.brand-text strong { color: var(--wine-700); font-weight: 700; }
.site-nav { display: none; margin-left: auto; gap: 1.4rem; font-weight: 500; font-size: var(--step--1); }
.site-nav a { color: var(--muted); position: relative; padding: .25rem 0; }
.site-nav a::after {
    content: ""; position: absolute; left: 0; bottom: -2px; height: 2px; width: 0;
    background: var(--accent); transition: width .25s var(--ease);
}
.site-nav a:hover { color: var(--text); }
.site-nav a:hover::after { width: 100%; }
.btn-nav { margin-left: auto; }
@media (min-width: 880px) {
    .site-nav { display: flex; }
    .btn-nav { margin-left: 0; }
}

/* ===========================================================================
   Hero
   =========================================================================== */
.hero { position: relative; color: #fff; overflow: hidden; isolation: isolate; }
.hero-bg {
    position: absolute; inset: 0; z-index: -2;
    /* Foto de fundo (pergolado de parreiras) sob um véu roxo-vinho para
       garantir o contraste do texto. Troque o arquivo em assets/img/. */
    background:
        radial-gradient(1100px 560px at 82% -10%, rgba(122,46,148,.40), transparent 60%),
        radial-gradient(900px 500px at 0% 115%, rgba(90,148,25,.24), transparent 55%),
        linear-gradient(160deg, rgba(52,16,67,.80) 0%, rgba(42,11,55,.84) 55%, rgba(23,10,30,.92) 100%),
        url("/assets/img/background.jpg") center / cover no-repeat;
}
.grain {
    position: absolute; inset: 0; z-index: -1; pointer-events: none; opacity: .06;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.hero-inner { padding: clamp(3.5rem, 9vw, 7rem) 0 clamp(3rem, 7vw, 5.5rem); }
.hero-copy { max-width: 60ch; }
.hero-eyebrow {
    text-transform: uppercase; letter-spacing: .22em; font-size: .72rem; font-weight: 600;
    color: var(--gold-soft); margin-bottom: var(--sp-3);
}
.hero-title { font-size: var(--step-4); font-weight: 600; }
.hero-title em { color: var(--gold-soft); font-weight: 500; }
.hero-lead { margin-top: var(--sp-3); font-size: var(--step-1); color: rgba(255,255,255,.86); max-width: 52ch; }
.hero-cta { display: flex; flex-wrap: wrap; gap: var(--sp-2); margin-top: var(--sp-5); }
.hero-stats {
    list-style: none; padding: 0; display: flex; flex-wrap: wrap; gap: var(--sp-5);
    margin-top: var(--sp-8); border-top: 1px solid rgba(255,255,255,.18); padding-top: var(--sp-4);
}
.hero-stats strong { display: block; font-family: var(--font-display); font-size: var(--step-2); color: var(--gold-soft); }
.hero-stats span { font-size: var(--step--1); color: rgba(255,255,255,.72); }

/* ===========================================================================
   Seções genéricas
   =========================================================================== */
.section { padding: clamp(3.5rem, 8vw, 6.5rem) 0; position: relative; }
.section-cream { background: var(--cream-200); }
.section-vinho { background:
        linear-gradient(180deg, var(--cream) 0%, #fff 100%); }
.section-head { max-width: 60ch; margin-bottom: var(--sp-6); }
.section-head.center { margin-inline: auto; text-align: center; }
.section-tag {
    display: inline-flex; align-items: center; gap: .45rem;
    font-size: var(--step--1); font-weight: 600; letter-spacing: .04em;
    text-transform: uppercase; color: var(--wine-700);
    background: rgba(72,14,90,.07); padding: .35rem .75rem; border-radius: 999px;
}
.section-tag svg { width: 1.05em; height: 1.05em; }
.section-title { font-size: var(--step-3); margin-top: var(--sp-2); color: var(--wine-800); }
.section-sub { margin-top: var(--sp-2); color: var(--muted); font-size: var(--step-1); }
.section-head.center .section-sub { margin-inline: auto; }
.subgroup-title {
    font-size: var(--step-2); color: var(--wine-700); margin: var(--sp-8) 0 var(--sp-4);
    display: flex; align-items: center; gap: .6rem;
}
.subgroup-title::before { content:""; width: 28px; height: 2px; background: var(--gold); }

.badge { display: inline-block; font-size: .68rem; font-weight: 700; letter-spacing: .05em;
    text-transform: uppercase; padding: .2rem .55rem; border-radius: 999px; vertical-align: middle; }
.badge-ia { background: var(--leaf-500); color: #11300a; }
.badge-demo { background: var(--gold-soft); color: #4a3608; }

/* ===========================================================================
   Cards
   =========================================================================== */
.card-grid {
    display: grid; gap: var(--sp-3);
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
}
.card {
    background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius);
    overflow: hidden; box-shadow: var(--shadow-sm);
    transition: transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s var(--ease);
    display: flex; flex-direction: column;
}
.card:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); border-color: rgba(72,14,90,.22); }
/* Mídia: placeholder com gradiente do tema (troque por <img> quando tiver fotos) */
.card-media {
    aspect-ratio: 16 / 10; position: relative; display: grid; place-items: center;
    background:
        radial-gradient(120% 120% at 20% 10%, rgba(143,216,60,.22), transparent 55%),
        linear-gradient(150deg, var(--wine-600), var(--wine-800));
}
.card-media::after {
    content:""; position:absolute; inset:0; opacity:.5;
    background-image: repeating-linear-gradient(45deg, rgba(255,255,255,.05) 0 12px, transparent 12px 24px);
}
.card-seal {
    width: 56px; height: 56px; display: grid; place-items: center; border-radius: 14px;
    color: #fff; background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.28);
    backdrop-filter: blur(4px); z-index: 1;
}
.card-seal svg { width: 28px; height: 28px; }
.card-img { width: 100%; height: 100%; object-fit: cover; aspect-ratio: 16/10; }
.card-body { padding: var(--sp-3); display: flex; flex-direction: column; gap: .4rem; flex: 1; }
.card-kicker { font-size: .72rem; text-transform: uppercase; letter-spacing: .08em; color: var(--accent); font-weight: 700; }
.card-title { font-size: var(--step-1); color: var(--wine-800); }
.card-desc { color: var(--muted); font-size: .96rem; }
.card-dica {
    margin-top: auto; padding-top: .75rem; border-top: 1px dashed var(--border);
    font-size: .86rem; color: var(--ink); display: flex; gap: .5rem; align-items: flex-start;
}
.card-dica span { color: var(--gold); flex-shrink: 0; margin-top: .15rem; }
.card-dica svg { width: 1em; height: 1em; }

/* Religioso: fundo escuro elegante */
.section-religioso { background: linear-gradient(165deg, var(--wine-800), var(--wine-900)); color: #fff; }
.section-religioso .section-title { color: #fff; }
.section-religioso .section-sub { color: rgba(255,255,255,.8); }
.section-religioso .section-tag { background: rgba(255,255,255,.1); color: var(--gold-soft); }
.section-religioso .card { background: rgba(255,255,255,.04); border-color: rgba(255,255,255,.12); }
.section-religioso .card-title { color: #fff; }
.section-religioso .card-desc { color: rgba(255,255,255,.74); }
.section-religioso .card-dica { color: rgba(255,255,255,.9); border-color: rgba(255,255,255,.14); }

/* ===========================================================================
   Gerador de roteiro — formulário
   =========================================================================== */
.gerador { padding: clamp(3.5rem, 8vw, 6rem) 0; background:
        radial-gradient(900px 500px at 90% 0%, rgba(143,216,60,.10), transparent 60%), var(--cream); }
.roteiro-form {
    background: var(--surface); border: 1px solid var(--border); border-radius: 22px;
    padding: clamp(1.5rem, 4vw, 2.75rem); box-shadow: var(--shadow-md);
    max-width: 860px; margin: var(--sp-6) auto 0; display: grid; gap: var(--sp-4);
    position: relative; overflow: hidden;
}
.roteiro-form::before {
    content:""; position:absolute; inset:0 0 auto 0; height:4px;
    background: linear-gradient(90deg, var(--wine-700), var(--leaf-500), var(--gold));
}
.field { border: 0; padding: 0; min-width: 0; }
.field legend { font-family: var(--font-display); font-size: var(--step-1); color: var(--wine-800); margin-bottom: var(--sp-2); padding: 0; }
.field legend small { font-family: var(--font-body); font-weight: 400; color: var(--muted); font-size: .8rem; }
.field-row { display: grid; gap: var(--sp-4); }
@media (min-width: 720px) { .field-row { grid-template-columns: 1fr 1fr; } }

/* Choice (rádio em cartão) */
.choice-row { display: grid; gap: .6rem; grid-template-columns: repeat(auto-fit, minmax(110px, 1fr)); }
.choice-row.sm { grid-template-columns: repeat(3, 1fr); }
.choice input { position: absolute; opacity: 0; pointer-events: none; }
.choice span {
    display: flex; flex-direction: column; align-items: center; gap: .15rem; text-align: center;
    padding: .8rem .5rem; border: 1.5px solid var(--border); border-radius: var(--radius-sm);
    font-weight: 600; color: var(--ink); transition: all .2s var(--ease); background: var(--cream);
}
.choice span small { font-weight: 400; color: var(--muted); font-size: .76rem; }
.choice:hover span { border-color: var(--wine-500); }
.choice input:checked + span {
    border-color: var(--wine-700); background: rgba(72,14,90,.06);
    box-shadow: inset 0 0 0 1px var(--wine-700); color: var(--wine-800);
}
.choice input:focus-visible + span { outline: 3px solid var(--accent-bright); outline-offset: 2px; }

/* Chips (checkbox com ícone) */
.chip-grid { display: grid; gap: .6rem; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); }
.chip input { position: absolute; opacity: 0; pointer-events: none; }
.chip span {
    display: flex; align-items: center; gap: .55rem; padding: .75rem .9rem;
    border: 1.5px solid var(--border); border-radius: 999px; font-weight: 600; color: var(--ink);
    background: var(--cream); transition: all .2s var(--ease);
}
.chip span svg { width: 1.2em; height: 1.2em; color: var(--wine-600); transition: color .2s var(--ease); }
.chip:hover span { border-color: var(--leaf-500); }
.chip input:checked + span {
    border-color: var(--leaf-700); background: rgba(114,187,33,.12); color: var(--leaf-700);
}
.chip input:checked + span svg { color: var(--leaf-700); }
.chip input:focus-visible + span { outline: 3px solid var(--accent-bright); outline-offset: 2px; }

/* Select e input de texto */
.select-wrap { position: relative; }
.select-wrap::after {
    content: "▾"; position: absolute; right: 1rem; top: 50%; transform: translateY(-50%);
    pointer-events: none; color: var(--wine-600);
}
select, .text-input {
    width: 100%; padding: .85rem 1rem; border: 1.5px solid var(--border); border-radius: var(--radius-sm);
    background: var(--cream); color: var(--ink); font: inherit; appearance: none;
    transition: border-color .2s var(--ease), box-shadow .2s var(--ease);
}
select { padding-right: 2.4rem; }
select:focus, .text-input:focus { border-color: var(--wine-700); box-shadow: 0 0 0 3px rgba(72,14,90,.12); outline: none; }

/* Campo "mais dias" + ajuda de campo */
.dias-extra { display: flex; align-items: center; flex-wrap: wrap; gap: .6rem; margin-top: var(--sp-2); font-weight: 600; color: var(--wine-800); }
.dias-extra input[type="number"] { width: 6.5rem; padding: .55rem .7rem; }
.dias-extra small { font-weight: 400; color: var(--muted); }
.field-help { margin-top: .5rem; font-size: var(--step--1); color: var(--muted); line-height: 1.5; }
textarea.text-input { resize: vertical; font: inherit; line-height: 1.5; }

/* Switch (crianças) */
.field-toggle { align-self: end; }
.switch { display: inline-flex; align-items: center; gap: .7rem; cursor: pointer; }
.switch input { position: absolute; opacity: 0; }
.switch-track {
    width: 50px; height: 28px; border-radius: 999px; background: var(--cream-200);
    border: 1.5px solid var(--border); position: relative; transition: background .2s var(--ease), border-color .2s var(--ease); flex-shrink: 0;
}
.switch-track::after {
    content:""; position:absolute; top: 2px; left: 2px; width: 22px; height: 22px; border-radius: 50%;
    background: #fff; box-shadow: var(--shadow-sm); transition: transform .25s var(--ease);
}
.switch input:checked + .switch-track { background: var(--leaf-500); border-color: var(--leaf-700); }
.switch input:checked + .switch-track::after { transform: translateX(22px); }
.switch input:focus-visible + .switch-track { outline: 3px solid var(--accent-bright); outline-offset: 2px; }
.switch-label { font-weight: 500; color: var(--ink); }

.form-actions { display: flex; flex-wrap: wrap; align-items: center; gap: var(--sp-3); }
.form-hint { color: var(--muted); font-size: .9rem; }
#btn-gerar[aria-busy="true"] { opacity: .75; pointer-events: none; }
#btn-gerar.is-loading span.spin {
    width: 1.1em; height: 1.1em; border: 2px solid rgba(255,255,255,.4); border-top-color:#fff;
    border-radius: 50%; animation: spin .7s linear infinite; display: inline-block;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ===========================================================================
   Resultado do roteiro — timeline
   =========================================================================== */
.roteiro-resultado { max-width: 860px; margin: var(--sp-6) auto 0; }
.roteiro-card {
    background: var(--surface); border: 1px solid var(--border); border-radius: 22px;
    box-shadow: var(--shadow-md); overflow: hidden;
}
.roteiro-top {
    padding: clamp(1.4rem, 4vw, 2.2rem); color: #fff; position: relative;
    background: linear-gradient(150deg, var(--wine-700), var(--wine-900));
}
.roteiro-top .grain { opacity: .07; }
.roteiro-origem {
    display: inline-block; font-size: .68rem; font-weight: 700; letter-spacing: .08em;
    text-transform: uppercase; padding: .25rem .6rem; border-radius: 999px;
    background: rgba(255,255,255,.16); margin-bottom: .6rem;
}
.roteiro-top h3 { font-size: var(--step-3); }
.roteiro-top p { color: rgba(255,255,255,.85); margin-top: .4rem; max-width: 60ch; }
.roteiro-acoes { display: flex; flex-wrap: wrap; gap: .7rem; margin-top: var(--sp-3); }
.roteiro-acoes .btn { background: rgba(255,255,255,.14); color: #fff; border: 1px solid rgba(255,255,255,.3); }
.roteiro-acoes .btn:hover { background: rgba(255,255,255,.24); transform: translateY(-2px); }
.roteiro-body { padding: clamp(1.4rem, 4vw, 2.2rem); }

.dia-bloco + .dia-bloco { margin-top: var(--sp-6); }
.dia-head { display: flex; align-items: center; gap: .8rem; margin-bottom: var(--sp-3); }
.dia-titulo {
    font-size: var(--step-2); color: var(--wine-800);
    display: inline-flex; align-items: center; gap: .7rem;
}
.dia-titulo::before {
    content: attr(data-num); display: grid; place-items: center; width: 2.1rem; height: 2.1rem;
    font-size: 1rem; font-family: var(--font-body); font-weight: 700; color: #fff; border-radius: 50%;
    background: linear-gradient(140deg, var(--leaf-500), var(--leaf-700));
}

.timeline { list-style: none; padding: 0; position: relative; margin-left: .6rem; }
.timeline::before {
    content:""; position: absolute; left: 7px; top: .4rem; bottom: .4rem; width: 2px;
    background: linear-gradient(var(--leaf-500), var(--gold)); opacity: .5;
}
.timeline-item { position: relative; padding: 0 0 var(--sp-3) var(--sp-5); }
.timeline-dot {
    position: absolute; left: 0; top: .5rem; width: 16px; height: 16px; border-radius: 50%;
    background: var(--surface); border: 3px solid var(--leaf-500); z-index: 1;
}
.timeline-card {
    background: var(--cream); border: 1px solid var(--border); border-radius: var(--radius-sm);
    padding: var(--sp-3); transition: box-shadow .2s var(--ease);
}
.timeline-card:hover { box-shadow: var(--shadow-sm); }
.parada-periodo {
    display: inline-flex; align-items: center; gap: .4rem; font-size: .72rem; font-weight: 700;
    letter-spacing: .06em; text-transform: uppercase; color: var(--wine-700);
    background: rgba(72,14,90,.08); padding: .22rem .6rem; border-radius: 999px;
}
.parada-nome { font-size: var(--step-1); color: var(--wine-800); margin-top: .5rem; }
.parada-tipo { font-size: .76rem; text-transform: uppercase; letter-spacing: .06em; color: var(--accent); font-weight: 700; }
.parada-desc { color: var(--muted); margin-top: .4rem; }
.parada-dica { font-size: .86rem; color: var(--ink); margin-top: .5rem; padding-left: .8rem; border-left: 2px solid var(--gold); }
.parada-dica::before { content: "Dica: "; font-weight: 700; color: var(--gold); }
.parada-dica:empty { display: none; }

.roteiro-obs { margin-top: var(--sp-6); padding: var(--sp-3); background: rgba(72,14,90,.05); border-radius: var(--radius-sm); }
.roteiro-obs h4 { color: var(--wine-700); font-size: var(--step-1); margin-bottom: .5rem; }
.roteiro-obs ul { margin: 0; padding-left: 1.2rem; color: var(--muted); }
.roteiro-obs li + li { margin-top: .35rem; }

.roteiro-erro { text-align: center; padding: var(--sp-5); color: var(--wine-700); }

/* ===========================================================================
   Sobre
   =========================================================================== */
.section-sobre {
    position: relative; color: #fff; overflow: hidden; isolation: isolate;
    background: linear-gradient(150deg, var(--wine-700), var(--wine-900));
    padding: clamp(3.5rem, 8vw, 6.5rem) 0;
}
.sobre-grid { display: grid; gap: var(--sp-6); align-items: start; }
@media (min-width: 860px) { .sobre-grid { grid-template-columns: 1.5fr 1fr; gap: var(--sp-8); } }
.sobre-text .section-tag { background: rgba(255,255,255,.12); color: var(--gold-soft); }
.sobre-text .section-title { color: #fff; }
.sobre-text p { color: rgba(255,255,255,.85); margin-top: var(--sp-3); }
.sobre-text strong { color: #fff; }
.sobre-text em { color: var(--gold-soft); }
.sobre-card {
    background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.16);
    border-radius: var(--radius); padding: var(--sp-4); backdrop-filter: blur(6px);
}
.sobre-card h3 { display: flex; align-items: center; gap: .55rem; color: var(--gold-soft); font-size: var(--step-1); margin-bottom: .4rem; }
.sobre-card h3 svg { width: 1.1em; height: 1.1em; }
.sobre-card h3:not(:first-child) { margin-top: var(--sp-4); }
.sobre-card p { color: rgba(255,255,255,.8); font-size: .95rem; }

/* ===========================================================================
   Rodapé
   =========================================================================== */
.site-footer { background: var(--dark); color: rgba(255,255,255,.78); padding: var(--sp-8) 0 var(--sp-4); }
.footer-grid { display: grid; gap: var(--sp-5); }
@media (min-width: 760px) { .footer-grid { grid-template-columns: 1.6fr 1fr 1fr; } }
.footer-brand .brand-text { color: #fff; font-size: 1.3rem; font-family: var(--font-display); }
.footer-brand .brand-text strong { color: var(--gold-soft); }
.footer-brand p { margin-top: var(--sp-2); max-width: 38ch; }
.footer-col h3 { color: #fff; font-size: var(--step-0); margin-bottom: var(--sp-2); font-family: var(--font-body); text-transform: uppercase; letter-spacing: .08em; font-size: .8rem; }
.footer-col address { font-style: normal; line-height: 1.9; }
.footer-col a:hover { color: var(--gold-soft); }
.footer-links { list-style: none; padding: 0; line-height: 2; }
.footer-bottom {
    margin-top: var(--sp-6); padding-top: var(--sp-4); border-top: 1px solid rgba(255,255,255,.12);
    display: flex; flex-wrap: wrap; justify-content: space-between; gap: .5rem;
    font-size: .82rem; color: rgba(255,255,255,.5);
}

/* ===========================================================================
   Reveal on scroll
   =========================================================================== */
.reveal { opacity: 0; transform: translateY(22px); transition: opacity .7s var(--ease), transform .7s var(--ease); transition-delay: var(--d, 0ms); }
.reveal.is-visible { opacity: 1; transform: none; }

/* ===========================================================================
   Movimento reduzido & impressão
   =========================================================================== */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; scroll-behavior: auto !important; }
    .reveal { opacity: 1; transform: none; }
}

/* Overlay de geração da apresentação (Download) */
.apresentacao-overlay {
    position: fixed; inset: 0; z-index: 1000;
    display: grid; place-items: center; padding: 1.5rem;
    background: rgba(36, 10, 48, .72); backdrop-filter: blur(3px);
    animation: fadeIn .2s var(--ease);
}
.apresentacao-box {
    width: min(440px, 100%); background: var(--surface); color: var(--text);
    border-radius: 18px; padding: 2rem 1.8rem; text-align: center;
    box-shadow: var(--shadow-wine); border: 1px solid var(--border);
}
.apresentacao-box h3 { font-family: var(--font-display); color: var(--wine-800); font-size: var(--step-1); margin: .4rem 0 .5rem; }
.apresentacao-box p { color: var(--muted); font-size: var(--step--1); line-height: 1.6; }
.apresentacao-box .ampulheta { font-size: 2.6rem; display: inline-block; animation: ampulheta 1.6s ease-in-out infinite; }
.apresentacao-barra { margin-top: 1.2rem; height: 6px; border-radius: 999px; background: var(--cream-200); overflow: hidden; }
.apresentacao-barra span { display: block; height: 100%; width: 40%; border-radius: 999px; background: linear-gradient(90deg, var(--wine-600), var(--leaf-500)); animation: barra 1.4s var(--ease) infinite; }
@keyframes ampulheta { 0%, 100% { transform: rotate(0); } 50% { transform: rotate(180deg); } }
@keyframes barra { 0% { transform: translateX(-120%); } 100% { transform: translateX(320%); } }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
@media (prefers-reduced-motion: reduce) {
    .apresentacao-box .ampulheta, .apresentacao-barra span { animation: none; }
}

/* Marca e galeria do roteiro: só na impressão / PDF */
.print-marca, .print-galeria { display: none; }

@media print {
    .site-header, .site-footer, .hero, .gerador .roteiro-form,
    .gerador .section-head, .section, .skip-link, .roteiro-acoes { display: none !important; }
    .roteiro-resultado { margin: 0; }
    .roteiro-card, .timeline-card { box-shadow: none; border-color: #ccc; }
    .roteiro-top { background: #480e5a !important; -webkit-print-color-adjust: exact; print-color-adjust: exact; }
    body { background: #fff; }

    /* Identidade visual no topo da folha (fundo branco + borda roxa, logo grande) */
    .print-marca {
        display: flex; flex-direction: column; align-items: center; gap: .5rem;
        text-align: center; margin: 0 0 1.2rem; padding: 1.4rem 1rem;
        background: #fff; color: var(--wine-800);
        border: 2px solid var(--wine-700); border-radius: 12px;
        -webkit-print-color-adjust: exact; print-color-adjust: exact;
    }
    .print-marca-logo { max-height: 120px; width: auto; }
    .print-marca-nome { font-family: var(--font-display); font-size: 1.8rem; color: var(--wine-800); font-weight: 700; }
    .print-marca-sub { font-size: .8rem; color: #555; letter-spacing: .02em; }

    /* Galeria de imagens no fim do roteiro */
    .print-galeria { display: block; margin-top: 1.4rem; break-inside: avoid; }
    .print-galeria-tit {
        font-family: var(--font-display); font-size: 1.3rem; color: var(--wine-800);
        margin: 0 0 .7rem; padding-bottom: .4rem; border-bottom: 2px solid var(--wine-700);
    }
    .print-galeria-grid { display: grid; grid-template-columns: 1fr 1fr; gap: .5rem; }
    .print-galeria-grid img {
        width: 100%; height: 5.5cm; object-fit: cover;
        border-radius: 8px; border: 1px solid #ccc; break-inside: avoid;
        -webkit-print-color-adjust: exact; print-color-adjust: exact;
    }
}
