/* =====================================================================
   Regiany Cristina — tema "premium escuro" (estilo app)
   Azul vibrante = cor da Regiany · Laranja Focus Fit = ação/menção à marca
   ===================================================================== */

:root {
    --bg:        #0b0f17;
    --bg-2:      #0e1422;
    --surface:   #121a2b;
    --surface-2: #16203a;
    --linha:     rgba(255,255,255,.09);
    --linha-2:   rgba(255,255,255,.14);

    --ink:    #eaf0fb;
    --muted:  #9aa8bf;
    --muted-2:#71809a;

    --azul:   #2e9bf0;
    --azul-2: #38d6e6;
    --azul-soft: rgba(46,155,240,.16);

    --laranja:   #ff8a1e;   /* laranja vibrante para CTAs no escuro */
    --laranja-2: #da8201;   /* laranja da marca Focus Fit (referência) */
    --laranja-ink:#ffd9ad;

    --raio:   18px;
    --raio-sm:12px;
    --raio-pill:999px;
    --container:1180px;

    --sombra:   0 18px 50px rgba(0,0,0,.45);
    --sombra-sm:0 8px 24px rgba(0,0,0,.35);
    --glow-laranja: 0 12px 34px rgba(255,138,30,.35);
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; scroll-padding-top: 92px; overflow-x: clip; }

body {
    margin: 0;
    background: var(--bg);
    color: var(--ink);
    font-family: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
    font-size: 17px;
    line-height: 1.65;
    -webkit-font-smoothing: antialiased;
    overflow-x: clip;
}

h1, h2, h3, h4 { font-family: "Sora", "Inter", sans-serif; line-height: 1.12; margin: 0; letter-spacing: -.02em; }
p { margin: 0 0 1rem; }
a { color: var(--azul); text-decoration: none; }
img { max-width: 100%; display: block; }

.rc-container { width: 100%; max-width: var(--container); margin: 0 auto; padding: 0 22px; }

.rc-sr {
    position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px;
    overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}
.rc-skip-link {
    position: absolute; left: -999px; top: 0; z-index: 999;
    background: var(--laranja); color: #1a1205; padding: 10px 16px; border-radius: 0 0 10px 0; font-weight: 700;
}
.rc-skip-link:focus { left: 0; }

/* gradiente de texto (destaque azul→ciano) */
.rc-grad {
    background: linear-gradient(100deg, var(--azul), var(--azul-2));
    -webkit-background-clip: text; background-clip: text; color: transparent;
}

.rc-kicker {
    display: inline-block; font-family: "Sora", sans-serif; font-weight: 700;
    font-size: .8rem; letter-spacing: .16em; text-transform: uppercase;
    color: var(--azul-2); margin-bottom: .85rem;
}
.rc-kicker--claro { color: var(--laranja-ink); }

/* ============================= BOTÕES ============================= */
.rc-btn {
    --b: var(--ink);
    display: inline-flex; align-items: center; justify-content: center; gap: .55em;
    font-family: "Sora", sans-serif; font-weight: 700; font-size: .98rem;
    padding: .8rem 1.4rem; border-radius: var(--raio-pill); border: 1px solid transparent;
    cursor: pointer; transition: transform .15s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease;
    white-space: nowrap; line-height: 1;
}
.rc-btn svg { width: 1.15em; height: 1.15em; }
.rc-btn--sm { padding: .58rem 1rem; font-size: .9rem; }
.rc-btn--lg { padding: 1rem 1.7rem; font-size: 1.06rem; }
.rc-btn--bloco { display: flex; width: 100%; }

.rc-btn--primario {
    background: linear-gradient(180deg, var(--laranja), var(--laranja-2));
    color: #1c1204; box-shadow: var(--glow-laranja);
}
.rc-btn--primario:hover { transform: translateY(-2px); box-shadow: 0 16px 40px rgba(255,138,30,.45); }

.rc-btn--fantasma {
    background: rgba(255,255,255,.04); color: var(--ink); border-color: var(--linha-2);
    backdrop-filter: blur(4px);
}
.rc-btn--fantasma:hover { border-color: var(--azul); color: #fff; transform: translateY(-2px); }

.rc-btn--secundario {
    background: var(--surface-2); color: var(--ink); border-color: var(--linha-2);
}
.rc-btn--secundario:hover { border-color: var(--azul); color: #fff; }

/* ============================= HEADER ============================= */
.rc-header {
    position: sticky; top: 0; z-index: 100;
    background: rgba(11,15,23,.72); backdrop-filter: blur(14px) saturate(140%);
    border-bottom: 1px solid transparent; transition: border-color .2s ease, background .2s ease;
}
.rc-header.is-scrolled { border-bottom-color: var(--linha); background: rgba(11,15,23,.9); }
.rc-header__inner { display: flex; align-items: center; gap: 1.2rem; min-height: 74px; }

.rc-marca { display: inline-flex; align-items: center; gap: .65rem; margin-right: auto; }
.rc-marca__avatar {
    width: 42px; height: 42px; border-radius: 50%; overflow: hidden; flex: 0 0 auto;
    border: 2px solid transparent; background:
        linear-gradient(var(--bg),var(--bg)) padding-box,
        linear-gradient(135deg, var(--azul), var(--azul-2)) border-box;
}
.rc-marca__avatar img { width: 100%; height: 100%; object-fit: cover; object-position: 50% 22%; }
.rc-marca__txt { display: flex; flex-direction: column; line-height: 1.05; }
.rc-marca__nome { font-family: "Sora", sans-serif; font-weight: 800; color: var(--ink); font-size: 1.06rem; }
.rc-marca__papel { font-size: .74rem; letter-spacing: .04em; color: var(--muted); }

.rc-nav { display: flex; align-items: center; gap: 1.4rem; }
.rc-nav__lista { display: flex; align-items: center; gap: 1.4rem; list-style: none; margin: 0; padding: 0; }
.rc-nav__link {
    color: var(--muted); font-weight: 600; font-size: .96rem; position: relative; padding: .3rem 0;
    transition: color .15s ease;
}
.rc-nav__link:hover, .rc-nav__link[aria-current="page"] { color: var(--ink); }
.rc-nav__link[aria-current="page"]::after {
    content: ""; position: absolute; left: 0; right: 0; bottom: -4px; height: 2px; border-radius: 2px;
    background: linear-gradient(90deg, var(--azul), var(--azul-2));
}

.rc-header__focusfit {
    display: inline-flex; align-items: center; gap: .45rem; color: var(--muted);
    font-size: .82rem; font-weight: 600; padding: .4rem .7rem; border-radius: var(--raio-pill);
    border: 1px solid var(--linha); transition: border-color .2s, color .2s;
}
.rc-header__focusfit img { width: 22px; height: 22px; }
.rc-header__focusfit:hover { color: var(--ink); border-color: var(--laranja-2); }

.rc-hamburger {
    display: none; background: transparent; border: 1px solid var(--linha-2); color: var(--ink);
    width: 44px; height: 44px; border-radius: 12px; cursor: pointer; padding: 9px;
}
.rc-hamburger svg { width: 100%; height: 100%; }
.rc-icone-fechar { display: none; }
.rc-nav-overlay { display: none; }

/* ============================= HERO ============================= */
.rc-hero { position: relative; padding: clamp(3rem, 8vw, 6rem) 0 clamp(2.5rem, 6vw, 4.5rem); overflow: hidden; }
.rc-hero__glow {
    position: absolute; inset: -30% -10% auto -10%; height: 80%; pointer-events: none;
    background:
        radial-gradient(50% 60% at 22% 30%, rgba(46,155,240,.30), transparent 70%),
        radial-gradient(45% 55% at 80% 20%, rgba(255,138,30,.18), transparent 70%);
    filter: blur(10px);
}
.rc-hero__inner { position: relative; display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(1.5rem, 4vw, 3.5rem); align-items: center; }

.rc-pill {
    display: inline-flex; align-items: center; gap: .55rem; font-size: .82rem; font-weight: 600;
    color: var(--azul-ink); background: var(--azul-soft); border: 1px solid rgba(46,155,240,.3);
    padding: .42rem .9rem; border-radius: var(--raio-pill); margin-bottom: 1.3rem;
}
.rc-pill__dot { width: 8px; height: 8px; border-radius: 50%; background: var(--azul-2); box-shadow: 0 0 0 4px rgba(56,214,230,.2); }

.rc-hero__titulo { font-size: clamp(2.3rem, 5.4vw, 3.9rem); font-weight: 800; }
.rc-hero__lead { color: var(--muted); font-size: clamp(1.02rem, 2vw, 1.18rem); max-width: 33ch; margin: 1.3rem 0 1.9rem; }

.rc-hero__acoes { display: flex; flex-wrap: wrap; gap: .8rem; margin-bottom: 2rem; }

.rc-hero__provas { display: flex; flex-wrap: wrap; gap: 1.8rem; list-style: none; margin: 0; padding: 1.3rem 0 0; border-top: 1px solid var(--linha); }
.rc-hero__provas li { display: flex; flex-direction: column; }
.rc-hero__provas strong { font-family: "Sora", sans-serif; font-size: 1.5rem; color: #fff; }
.rc-hero__provas span { font-size: .82rem; color: var(--muted); }

.rc-hero__midia { position: relative; justify-self: center; }
.rc-hero__foto {
    position: relative; width: min(420px, 80vw); aspect-ratio: 5 / 6; border-radius: 26px; overflow: hidden;
    border: 1px solid var(--linha-2);
    background: linear-gradient(160deg, rgba(46,155,240,.25), rgba(255,138,30,.12));
    box-shadow: var(--sombra);
}
.rc-hero__foto img { width: 100%; height: 100%; object-fit: cover; }
.rc-hero__foto::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 55%, rgba(8,11,18,.55)); }

.rc-badge {
    position: absolute; display: flex; align-items: center; gap: .7rem; z-index: 2;
    background: rgba(18,26,43,.92); border: 1px solid var(--linha-2); border-radius: 14px;
    padding: .7rem .9rem; box-shadow: var(--sombra-sm); backdrop-filter: blur(8px); max-width: 230px;
}
.rc-badge span:not(.rc-badge__icone) { display: flex; flex-direction: column; font-size: .8rem; color: var(--muted); line-height: 1.25; }
.rc-badge strong { color: #fff; font-size: .9rem; font-weight: 700; }
.rc-badge__icone { width: 36px; height: 36px; flex: 0 0 auto; display: grid; place-items: center; border-radius: 10px; background: var(--azul-soft); color: var(--azul-2); }
.rc-badge__icone svg { width: 20px; height: 20px; }
.rc-badge__icone--laranja { background: rgba(255,138,30,.16); color: var(--laranja); }
.rc-badge--um { left: -26px; top: 18%; }
.rc-badge--dois { right: -22px; bottom: 14%; }

/* ============================= STATS ============================= */
.rc-stats { border-top: 1px solid var(--linha); border-bottom: 1px solid var(--linha); background: var(--bg-2); }
.rc-stats__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; padding: 2rem 22px; }
.rc-stat { text-align: center; }
.rc-stat__num { display: block; font-family: "Sora", sans-serif; font-weight: 800; font-size: clamp(1.6rem, 3.5vw, 2.4rem);
    background: linear-gradient(120deg, var(--azul), var(--azul-2)); -webkit-background-clip: text; background-clip: text; color: transparent; }
.rc-stat__rot { font-size: .85rem; color: var(--muted); }

/* ============================= SEÇÕES (base) ============================= */
.rc-secao { padding: clamp(3.2rem, 7vw, 5.5rem) 0; position: relative; }
.rc-secao__cab { max-width: 720px; margin: 0 auto clamp(2rem, 4vw, 3rem); text-align: center; }
.rc-secao__titulo { font-size: clamp(1.8rem, 4vw, 2.7rem); font-weight: 800; }
.rc-secao__lead { color: var(--muted); font-size: 1.08rem; margin-top: 1rem; }

/* lista com check */
.rc-lista-check { list-style: none; margin: 0 0 1.6rem; padding: 0; display: grid; gap: .7rem; }
.rc-lista-check li { position: relative; padding-left: 2rem; color: var(--ink); }
.rc-lista-check li::before {
    content: ""; position: absolute; left: 0; top: .15em; width: 1.3rem; height: 1.3rem; border-radius: 50%;
    background:
        var(--azul-soft) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2338d6e6' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/.85rem no-repeat;
    border: 1px solid rgba(56,214,230,.3);
}
.rc-lista-check--mini li { font-size: .92rem; color: var(--muted); }

/* ============================= MÉTODO ============================= */
.rc-metodo { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.2rem; }
.rc-passo {
    background: var(--surface); border: 1px solid var(--linha); border-radius: var(--raio); padding: 1.6rem 1.4rem;
    position: relative; overflow: hidden; transition: transform .18s ease, border-color .2s ease;
}
.rc-passo:hover { transform: translateY(-4px); border-color: rgba(46,155,240,.4); }
.rc-passo::before { content: ""; position: absolute; left: 0; top: 0; width: 100%; height: 3px; background: linear-gradient(90deg, var(--azul), var(--azul-2)); opacity: .8; }
.rc-passo__n { font-family: "Sora", sans-serif; font-weight: 800; font-size: 1.1rem; color: var(--azul-2); letter-spacing: .1em; }
.rc-passo h3 { font-size: 1.18rem; margin: .5rem 0 .55rem; color: #fff; }
.rc-passo p { color: var(--muted); font-size: .95rem; margin: 0; }

/* ============================= TREINE COM A REGIANY ============================= */
.rc-secao--treine { background: var(--bg-2); border-top: 1px solid var(--linha); border-bottom: 1px solid var(--linha); }
.rc-treine { display: grid; grid-template-columns: 1.2fr .8fr; gap: clamp(1.5rem, 4vw, 3rem); align-items: center; }
.rc-treine__acoes { display: flex; flex-direction: column; gap: .6rem; align-items: flex-start; }
.rc-treine__nota { font-size: .85rem; color: var(--muted-2); }

.rc-treine__card { display: flex; }
.rc-precinho {
    width: 100%; background: linear-gradient(180deg, var(--surface-2), var(--surface)); border: 1px solid var(--linha-2);
    border-radius: var(--raio); padding: 1.8rem; box-shadow: var(--sombra); position: relative;
}
.rc-precinho::before { content: ""; position: absolute; inset: 0; border-radius: var(--raio); padding: 1px;
    background: linear-gradient(160deg, rgba(46,155,240,.5), transparent 40%); -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0); -webkit-mask-composite: xor; mask-composite: exclude; pointer-events: none; }
.rc-precinho__rot { font-weight: 600; color: var(--muted); font-size: .9rem; }
.rc-precinho__valor { display: block; font-family: "Sora", sans-serif; font-weight: 800; font-size: 2.1rem; color: #fff; margin: .3rem 0 1.1rem; }
.rc-precinho__valor small { display: block; font-size: .8rem; font-weight: 600; color: var(--muted); letter-spacing: .04em; }
.rc-precinho__valor span { font-size: 1rem; color: var(--muted); font-weight: 600; }
.rc-precinho__obs { font-size: .8rem; color: var(--muted-2); margin: .9rem 0 0; text-align: center; }

/* ============================= CURSO ============================= */
.rc-curso { display: grid; grid-template-columns: .85fr 1.15fr; gap: clamp(1.5rem, 4vw, 3rem); align-items: center; }
.rc-curso__capa {
    aspect-ratio: 4 / 3; border-radius: var(--raio); display: flex; flex-direction: column; justify-content: flex-end; gap: .3rem;
    padding: 1.8rem; color: #fff; position: relative; overflow: hidden;
    background: linear-gradient(150deg, #103a63, #0c2440 60%); border: 1px solid var(--linha-2); box-shadow: var(--sombra);
}
.rc-curso__capa::before { content: ""; position: absolute; inset: 0; background: radial-gradient(60% 60% at 80% 10%, rgba(56,214,230,.35), transparent 70%); }
.rc-curso__tag { position: relative; align-self: flex-start; font-size: .75rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
    background: rgba(255,138,30,.18); color: var(--laranja-ink); border: 1px solid rgba(255,138,30,.4); padding: .35rem .7rem; border-radius: var(--raio-pill); margin-bottom: auto; }
.rc-curso__nome { position: relative; font-family: "Sora", sans-serif; font-weight: 800; font-size: clamp(1.6rem, 3vw, 2.2rem); line-height: 1.1; }
.rc-curso__sub { position: relative; color: rgba(255,255,255,.78); font-size: .98rem; }
.rc-curso__acoes { display: flex; flex-direction: column; gap: .6rem; align-items: flex-start; }

/* ============================= APP ============================= */
.rc-secao--app { background: var(--bg-2); border-top: 1px solid var(--linha); border-bottom: 1px solid var(--linha); overflow: hidden; }
.rc-app__glow { position: absolute; inset: 0; pointer-events: none; background: radial-gradient(40% 60% at 85% 30%, rgba(46,155,240,.18), transparent 70%); }
.rc-app { position: relative; display: grid; grid-template-columns: 1.1fr .9fr; gap: clamp(1.5rem, 4vw, 3rem); align-items: center; }
.rc-app__mock { display: flex; justify-content: center; }

.rc-form-inline { display: flex; gap: .6rem; flex-wrap: wrap; margin: 0 0 .7rem; }
.rc-form-inline input {
    flex: 1 1 240px; min-width: 0; background: var(--surface); border: 1px solid var(--linha-2); color: var(--ink);
    border-radius: var(--raio-pill); padding: .85rem 1.2rem; font: inherit; font-size: .98rem;
}
.rc-form-inline input::placeholder { color: var(--muted-2); }
.rc-form-inline input:focus { outline: none; border-color: var(--azul); box-shadow: 0 0 0 4px var(--azul-soft); }

/* mockup de celular (CSS puro) */
.rc-phone {
    width: 270px; max-width: 78vw; aspect-ratio: 9 / 18.5; border-radius: 38px; padding: 12px;
    background: linear-gradient(160deg, #1c2740, #0d1422); border: 1px solid var(--linha-2);
    box-shadow: var(--sombra); position: relative;
}
.rc-phone__notch { position: absolute; top: 14px; left: 50%; transform: translateX(-50%); width: 44%; height: 22px; background: #0a0e16; border-radius: 0 0 14px 14px; z-index: 3; }
.rc-phone__tela { height: 100%; border-radius: 28px; background: linear-gradient(180deg, #0f1626, #0b1019); border: 1px solid var(--linha); padding: 2.2rem 1rem 1rem; display: flex; flex-direction: column; gap: .8rem; overflow: hidden; }
.rc-phone__top { display: flex; flex-direction: column; gap: .45rem; }
.rc-phone__hi { font-family: "Sora", sans-serif; font-weight: 700; color: #fff; font-size: 1rem; }
.rc-phone__chip { align-self: flex-start; font-size: .72rem; font-weight: 600; color: var(--azul-ink); background: var(--azul-soft); border: 1px solid rgba(46,155,240,.3); padding: .25rem .6rem; border-radius: var(--raio-pill); }
.rc-phone__card { background: var(--surface); border: 1px solid var(--linha); border-radius: 14px; padding: .85rem; }
.rc-phone__barra { display: block; height: 8px; border-radius: 6px; background: rgba(255,255,255,.1); position: relative; overflow: hidden; }
.rc-phone__barra::before { content: ""; position: absolute; inset: 0; width: var(--p, 60%); border-radius: 6px; background: linear-gradient(90deg, var(--azul), var(--azul-2)); }
.rc-phone__legenda { display: block; margin-top: .5rem; font-size: .72rem; color: var(--muted); }
.rc-phone__exs { list-style: none; margin: 0; padding: 0; display: grid; gap: .5rem; }
.rc-phone__exs li { display: flex; align-items: center; gap: .5rem; font-size: .82rem; color: var(--ink); background: var(--surface); border: 1px solid var(--linha); border-radius: 10px; padding: .5rem .6rem; }
.rc-phone__exs li span { width: 10px; height: 10px; border-radius: 50%; background: var(--azul-2); flex: 0 0 auto; }
.rc-phone__exs li em { margin-left: auto; font-style: normal; color: var(--muted); font-size: .78rem; }
.rc-phone__cta { margin-top: auto; text-align: center; font-family: "Sora", sans-serif; font-weight: 700; font-size: .85rem; color: #1c1204;
    background: linear-gradient(180deg, var(--laranja), var(--laranja-2)); border-radius: var(--raio-pill); padding: .65rem; }

/* ============================= DEPOIMENTOS ============================= */
.rc-depos { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem; }
.rc-depo { background: var(--surface); border: 1px solid var(--linha); border-radius: var(--raio); padding: 1.6rem; margin: 0; }
.rc-depo__estrelas { color: #ffc24a; letter-spacing: .12em; margin-bottom: .7rem; }
.rc-depo blockquote { margin: 0 0 1.1rem; color: var(--ink); font-size: 1.02rem; }
.rc-depo figcaption { display: flex; align-items: center; gap: .65rem; font-weight: 600; color: var(--muted); font-size: .92rem; }
.rc-depo__avatar { width: 38px; height: 38px; border-radius: 50%; display: grid; place-items: center; font-family: "Sora", sans-serif; font-weight: 800; color: #06121f;
    background: linear-gradient(135deg, var(--azul), var(--azul-2)); }

/* ============================= LEAD / E-BOOK ============================= */
.rc-secao--lead { }
.rc-lead {
    background: linear-gradient(135deg, rgba(46,155,240,.16), rgba(255,138,30,.1)); border: 1px solid var(--linha-2);
    border-radius: 24px; padding: clamp(1.8rem, 4vw, 3rem); text-align: center; position: relative; overflow: hidden;
}
.rc-lead .rc-secao__titulo, .rc-lead .rc-secao__lead { margin-left: auto; margin-right: auto; }
.rc-lead .rc-secao__lead { max-width: 56ch; }
.rc-form-inline--lead { max-width: 520px; margin: 1.6rem auto .4rem; }
.rc-lead__obs { font-size: .82rem; color: var(--muted); margin: 0; }

/* ============================= CTA FINAL ============================= */
.rc-cta-final { position: relative; padding: clamp(3.5rem, 8vw, 6rem) 0; text-align: center; overflow: hidden; border-top: 1px solid var(--linha); }
.rc-cta-final__glow { position: absolute; inset: 0; pointer-events: none; background: radial-gradient(50% 70% at 50% 0%, rgba(46,155,240,.22), transparent 70%); }
.rc-cta-final__inner { position: relative; max-width: 720px; margin: 0 auto; }
.rc-cta-final h2 { font-size: clamp(2rem, 5vw, 3rem); font-weight: 800; }
.rc-cta-final p { color: var(--muted); font-size: 1.1rem; margin: 1rem 0 2rem; }
.rc-cta-final__acoes { display: flex; flex-wrap: wrap; gap: .8rem; justify-content: center; margin-bottom: 1rem; }

/* ============================= FOOTER ============================= */
.rc-footer { background: #070a11; border-top: 1px solid var(--linha); padding: 3.2rem 0 2rem; }
.rc-footer__grid { display: grid; grid-template-columns: 1.6fr 1fr 1.2fr; gap: 2.4rem; }
.rc-footer h3 { font-size: 1rem; color: #fff; margin-bottom: 1rem; }
.rc-footer__marca-nome { font-family: "Sora", sans-serif; font-weight: 800; font-size: 1.3rem; color: #fff; margin: 0; }
.rc-footer__papel { color: var(--azul-2); font-size: .85rem; font-weight: 600; margin: .2rem 0 1rem; }
.rc-footer__texto { color: var(--muted); font-size: .95rem; max-width: 42ch; }
.rc-footer__sobre .rc-btn { margin-top: .4rem; }
.rc-footer__lista { list-style: none; margin: 0; padding: 0; display: grid; gap: .55rem; }
.rc-footer__lista a { color: var(--muted); font-weight: 500; }
.rc-footer__lista a:hover { color: var(--ink); }
.rc-footer__focusfit { display: inline-block; margin-top: 1rem; opacity: .9; }
.rc-footer__focusfit:hover { opacity: 1; }
.rc-footer__base { margin-top: 2.4rem; padding-top: 1.4rem; border-top: 1px solid var(--linha); color: var(--muted-2); font-size: .85rem; text-align: center; }
.rc-footer__base a { color: var(--laranja); }

/* =====================================================================
   BLOG (listagem)
   ===================================================================== */
.rc-blog-topo { position: relative; padding: clamp(2.8rem, 6vw, 4.5rem) 0 clamp(1.8rem, 3vw, 2.5rem); text-align: center; overflow: hidden; }
.rc-blog-topo::before { content: ""; position: absolute; inset: 0; pointer-events: none; background: radial-gradient(50% 80% at 50% 0%, rgba(46,155,240,.2), transparent 70%); }
.rc-blog-topo h1 { position: relative; font-size: clamp(1.9rem, 4.5vw, 3rem); font-weight: 800; max-width: 720px; margin: 0 auto; }
.rc-blog-topo p { position: relative; color: var(--muted); max-width: 620px; margin: 1rem auto 0; }

.rc-blog-layout { display: grid; grid-template-columns: 1fr 320px; gap: 2.4rem; padding-bottom: clamp(3rem, 6vw, 5rem); align-items: start; }

.rc-busca { display: flex; gap: .6rem; margin-bottom: 1.6rem; }
.rc-busca input { flex: 1; background: var(--surface); border: 1px solid var(--linha-2); color: var(--ink); border-radius: var(--raio-pill); padding: .8rem 1.2rem; font: inherit; }
.rc-busca input::placeholder { color: var(--muted-2); }
.rc-busca input:focus { outline: none; border-color: var(--azul); box-shadow: 0 0 0 4px var(--azul-soft); }
.rc-busca .rc-btn { padding: .8rem 1.1rem; }
.rc-busca-info { color: var(--muted); font-size: .92rem; margin-bottom: 1.4rem; }
.rc-busca-info a { margin-left: .4rem; }

.rc-cards { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.4rem; }
.rc-card { display: flex; flex-direction: column; background: var(--surface); border: 1px solid var(--linha); border-radius: var(--raio); overflow: hidden; transition: transform .18s ease, border-color .2s ease, box-shadow .2s ease; }
.rc-card:hover { transform: translateY(-4px); border-color: rgba(46,155,240,.4); box-shadow: var(--sombra-sm); }
.rc-card__thumb { display: block; aspect-ratio: 16 / 10; overflow: hidden; background: var(--surface-2); }
.rc-card__thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform .3s ease; }
.rc-card:hover .rc-card__thumb img { transform: scale(1.05); }
.rc-card__corpo { padding: 1.2rem 1.3rem 1.4rem; display: flex; flex-direction: column; flex: 1; }
.rc-card__categoria { align-self: flex-start; font-size: .72rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--azul-2); background: var(--azul-soft); border: 1px solid rgba(46,155,240,.25); padding: .25rem .6rem; border-radius: var(--raio-pill); margin-bottom: .7rem; }
.rc-card__titulo { font-size: 1.18rem; line-height: 1.3; margin: 0 0 .6rem; }
.rc-card__titulo a { color: #fff; }
.rc-card__titulo a:hover { color: var(--azul-2); }
.rc-card__resumo { color: var(--muted); font-size: .92rem; margin: 0 0 1.1rem; }
.rc-card__meta { display: flex; align-items: center; justify-content: space-between; margin-top: auto; padding-top: 1rem; border-top: 1px solid var(--linha); font-size: .82rem; color: var(--muted); }
.rc-card__meta svg { width: 1em; height: 1em; vertical-align: -.15em; margin-right: .3em; }
.rc-card__meta > span { display: inline-flex; align-items: center; }
.rc-card__ler { display: inline-flex; align-items: center; gap: .35rem; font-weight: 700; color: var(--azul-2); }
.rc-card__ler svg { width: 1em; height: 1em; transition: transform .15s ease; }
.rc-card__ler:hover svg { transform: translateX(3px); }

/* estado vazio */
.rc-vazio { text-align: center; padding: 3.5rem 1rem; background: var(--surface); border: 1px dashed var(--linha-2); border-radius: var(--raio); }
.rc-vazio__icone { width: 64px; height: 64px; margin: 0 auto 1.2rem; display: grid; place-items: center; border-radius: 50%; background: var(--azul-soft); color: var(--azul-2); }
.rc-vazio__icone svg { width: 30px; height: 30px; }
.rc-vazio h2 { font-size: 1.4rem; color: #fff; margin-bottom: .6rem; }
.rc-vazio p { color: var(--muted); max-width: 42ch; margin: 0 auto 1.6rem; }

/* paginação (estiliza o paginador padrão do Laravel de forma defensiva) */
.rc-paginacao { margin-top: 2.4rem; }
.rc-paginacao nav { display: flex; justify-content: center; }
.rc-paginacao [role="navigation"] svg { width: 1.1rem; height: 1.1rem; }
.rc-paginacao a, .rc-paginacao span { color: var(--ink); }
.rc-paginacao .hidden { display: none; }
.rc-paginacao ul, .rc-paginacao .pagination { display: inline-flex; flex-wrap: wrap; gap: .35rem; list-style: none; margin: 0 auto; padding: 0; }
.rc-paginacao li > *, .rc-paginacao li.page-item { display: inline-grid; place-items: center; min-width: 42px; height: 42px; padding: 0 .7rem; border-radius: 12px; background: var(--surface); border: 1px solid var(--linha); color: var(--ink); font-weight: 600; }
.rc-paginacao a:hover { border-color: var(--azul); color: #fff; }
.rc-paginacao [aria-current] > *, .rc-paginacao .active > * { background: linear-gradient(180deg, var(--laranja), var(--laranja-2)); color: #1c1204; border-color: transparent; }

/* sidebar */
.rc-sidebar { display: grid; gap: 1.4rem; position: sticky; top: 92px; }
.rc-widget { background: var(--surface); border: 1px solid var(--linha); border-radius: var(--raio); padding: 1.4rem; }
.rc-widget--destaque { background: linear-gradient(150deg, var(--azul-soft), rgba(255,138,30,.08)); border-color: rgba(46,155,240,.3); }
.rc-widget__titulo { font-size: 1.05rem; color: #fff; margin: 0 0 1rem; }
.rc-widget--destaque p { color: var(--muted); font-size: .9rem; margin: 0; }
.rc-selo { display: inline-flex; align-items: center; gap: .45rem; font-weight: 700; font-size: .82rem; color: var(--azul-2); }
.rc-selo svg { width: 1.1em; height: 1.1em; }
.rc-recente { display: flex; gap: .8rem; padding: .7rem 0; border-top: 1px solid var(--linha); }
.rc-recente:first-of-type { border-top: 0; padding-top: 0; }
.rc-recente__thumb { width: 60px; height: 60px; border-radius: 10px; overflow: hidden; flex: 0 0 auto; background: var(--surface-2); }
.rc-recente__thumb img { width: 100%; height: 100%; object-fit: cover; }
.rc-recente__titulo { display: block; font-weight: 600; color: var(--ink); font-size: .9rem; line-height: 1.3; }
.rc-recente__titulo:hover { color: var(--azul-2); }
.rc-recente__data { font-size: .78rem; color: var(--muted-2); }
.rc-tags { display: flex; flex-wrap: wrap; gap: .5rem; }
.rc-tag { font-size: .8rem; font-weight: 600; color: var(--muted); background: var(--surface-2); border: 1px solid var(--linha); padding: .35rem .7rem; border-radius: var(--raio-pill); }
a.rc-tag { text-decoration: none; cursor: pointer; transition: color .15s ease, background .15s ease, border-color .15s ease; }
a.rc-tag:hover { color: var(--ink); border-color: var(--azul); background: var(--azul-soft); }
.rc-tag--ativa, .rc-tag--ativa:hover { color: #04121f; background: var(--azul-2); border-color: var(--azul-2); }

/* =====================================================================
   POSTAGEM (artigo)
   ===================================================================== */
.rc-artigo { padding-bottom: clamp(3rem, 6vw, 5rem); }
.rc-artigo__cabecalho { position: relative; padding: clamp(2.4rem, 5vw, 3.6rem) 0 1.6rem; text-align: center; overflow: hidden; }
.rc-artigo__cabecalho::before { content: ""; position: absolute; inset: 0; pointer-events: none; background: radial-gradient(50% 90% at 50% 0%, rgba(46,155,240,.18), transparent 70%); }
.rc-breadcrumb { position: relative; display: flex; flex-wrap: wrap; gap: .5rem; justify-content: center; font-size: .85rem; color: var(--muted-2); margin-bottom: 1.2rem; }
.rc-breadcrumb a { color: var(--muted); }
.rc-breadcrumb a:hover { color: var(--ink); }
.rc-artigo__categoria { position: relative; display: inline-block; font-size: .74rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--azul-2); background: var(--azul-soft); border: 1px solid rgba(46,155,240,.25); padding: .3rem .7rem; border-radius: var(--raio-pill); margin-bottom: 1rem; }
.rc-artigo__cabecalho h1 { position: relative; font-size: clamp(1.9rem, 4.5vw, 3rem); font-weight: 800; max-width: 800px; margin: 0 auto; }
.rc-artigo__meta { position: relative; display: flex; flex-wrap: wrap; gap: 1.2rem; justify-content: center; margin-top: 1.4rem; color: var(--muted); font-size: .9rem; }
.rc-artigo__meta > span { display: inline-flex; align-items: center; gap: .4rem; }
.rc-artigo__meta svg { width: 1.05em; height: 1.05em; }

.rc-artigo__capa { margin: 0 0 2.4rem; border-radius: var(--raio); overflow: hidden; border: 1px solid var(--linha); max-width: 960px; margin-inline: auto; }
.rc-artigo__capa img { width: 100%; }
.rc-artigo__credito { font-size: .78rem; color: var(--muted-2); padding: .6rem .9rem; background: var(--surface); }

/* prosa (leitura confortável no escuro) */
.rc-prosa { max-width: 760px; margin: 0 auto; font-size: 1.12rem; line-height: 1.8; color: #d7e0ef; }
.rc-prosa > * { margin-bottom: 1.3rem; }
.rc-prosa h2 { font-size: 1.7rem; color: #fff; margin: 2.4rem 0 1rem; }
.rc-prosa h3 { font-size: 1.35rem; color: #fff; margin: 2rem 0 .8rem; }
.rc-prosa a { color: var(--azul-2); text-decoration: underline; text-underline-offset: 3px; }
.rc-prosa ul, .rc-prosa ol { padding-left: 1.4rem; }
.rc-prosa li { margin-bottom: .5rem; }
.rc-prosa img { border-radius: var(--raio-sm); margin: 1.8rem auto; }
.rc-prosa blockquote { margin: 1.8rem 0; padding: 1rem 1.4rem; border-left: 4px solid var(--azul); background: var(--surface); border-radius: 0 12px 12px 0; color: var(--ink); }
.rc-prosa strong { color: #fff; }

.rc-artigo__rodape, .rc-autor-box, .rc-navpost, .rc-voltar { max-width: 760px; margin-inline: auto; }
.rc-artigo__tags { display: flex; flex-wrap: wrap; gap: .5rem; align-items: center; margin-top: 2.4rem; }
.rc-artigo__tags-rotulo { font-weight: 700; color: var(--muted); font-size: .85rem; margin-right: .3rem; }

.rc-autor-box { display: flex; gap: 1.2rem; margin-top: 2.4rem; padding: 1.6rem; background: var(--surface); border: 1px solid var(--linha); border-radius: var(--raio); }
.rc-autor-box__foto { width: 76px; height: 76px; border-radius: 50%; overflow: hidden; flex: 0 0 auto; border: 2px solid transparent;
    background: linear-gradient(var(--surface),var(--surface)) padding-box, linear-gradient(135deg, var(--azul), var(--azul-2)) border-box; }
.rc-autor-box__foto img { width: 100%; height: 100%; object-fit: cover; }
.rc-autor-box__nome { font-family: "Sora", sans-serif; font-weight: 800; color: #fff; margin: 0; }
.rc-autor-box__papel { color: var(--azul-2); font-size: .85rem; font-weight: 600; margin: .1rem 0 .6rem; }
.rc-autor-box__bio { color: var(--muted); font-size: .92rem; margin: 0; }

.rc-navpost { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-top: 2.4rem; }
.rc-navpost__item { display: flex; align-items: center; gap: .8rem; padding: 1.1rem 1.3rem; background: var(--surface); border: 1px solid var(--linha); border-radius: var(--raio); transition: border-color .2s, transform .18s; }
.rc-navpost__item:hover { border-color: var(--azul); transform: translateY(-2px); }
.rc-navpost__item--prox { grid-column: 2; text-align: right; flex-direction: row-reverse; }
.rc-navpost__seta { width: 38px; height: 38px; flex: 0 0 auto; display: grid; place-items: center; border-radius: 10px; background: var(--azul-soft); color: var(--azul-2); }
.rc-navpost__seta svg { width: 18px; height: 18px; }
.rc-navpost__rotulo { display: block; font-size: .76rem; color: var(--muted-2); text-transform: uppercase; letter-spacing: .08em; }
.rc-navpost__titulo { display: block; font-weight: 600; color: var(--ink); font-size: .95rem; }
.rc-voltar { margin-top: 2.4rem; text-align: center; }

/* ============================= HISTÓRIA ============================= */
.rc-secao--historia { background: var(--bg-2); border-top: 1px solid var(--linha); border-bottom: 1px solid var(--linha); }
.rc-historia { display: grid; grid-template-columns: .82fr 1.18fr; gap: clamp(1.6rem, 4vw, 3.4rem); align-items: start; }
.rc-historia__midia { position: relative; }
.rc-historia__foto { position: relative; border-radius: 22px; overflow: hidden; border: 1px solid var(--linha-2); aspect-ratio: 4 / 5;
    background: linear-gradient(160deg, rgba(46,155,240,.25), rgba(255,138,30,.1)); box-shadow: var(--sombra); }
.rc-historia__foto img { width: 100%; height: 100%; object-fit: cover; }
.rc-historia__foto::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 55%, rgba(8,11,18,.55)); }
.rc-historia__selo { position: absolute; right: -16px; bottom: 22px; display: flex; flex-direction: column; z-index: 2;
    background: rgba(18,26,43,.92); border: 1px solid var(--linha-2); border-radius: 14px; padding: .7rem .95rem;
    box-shadow: var(--sombra-sm); backdrop-filter: blur(8px); }
.rc-historia__selo strong { font-family: "Sora", sans-serif; color: #fff; font-size: 1.05rem; }
.rc-historia__selo span { font-size: .78rem; color: var(--muted); }
.rc-historia__conteudo .rc-secao__titulo { text-align: left; }
.rc-historia__texto { margin-top: 1.2rem; }
.rc-historia__texto p { color: var(--muted); }
.rc-historia__texto strong { color: #fff; }
.rc-timeline { list-style: none; margin: 1.9rem 0 0; padding: 0 0 0 1.6rem; position: relative; border-left: 2px solid var(--linha-2); display: grid; gap: 1.2rem; }
.rc-marco { position: relative; }
.rc-marco::before { content: ""; position: absolute; left: -1.6rem; top: .35em; width: 12px; height: 12px; border-radius: 50%; transform: translateX(-50%);
    background: var(--azul-2); box-shadow: 0 0 0 4px rgba(56,214,230,.18); }
.rc-marco__quando { display: block; font-family: "Sora", sans-serif; font-weight: 700; font-size: .78rem; letter-spacing: .12em; text-transform: uppercase; color: var(--azul-2); }
.rc-marco__oque { display: block; color: var(--ink); font-size: .98rem; margin-top: .15rem; }
.rc-marco--destaque::before { background: var(--laranja); box-shadow: 0 0 0 4px rgba(255,138,30,.22); }
.rc-marco--destaque .rc-marco__quando { color: var(--laranja); }
.rc-marco--destaque .rc-marco__oque { color: #fff; font-weight: 600; }

/* =====================================================================
   RESPONSIVO
   ===================================================================== */
@media (max-width: 980px) {
    .rc-hero__inner { grid-template-columns: 1fr; }
    .rc-hero__midia { order: -1; }
    .rc-hero__lead { max-width: none; }
    .rc-metodo { grid-template-columns: repeat(2, 1fr); }
    .rc-treine, .rc-curso, .rc-app, .rc-historia { grid-template-columns: 1fr; }
    .rc-curso__capa { order: -1; }
    .rc-historia__midia { max-width: 420px; }
    .rc-historia__selo { right: 10px; }
    .rc-depos { grid-template-columns: 1fr; }
    .rc-blog-layout { grid-template-columns: 1fr; }
    .rc-sidebar { position: static; }
    .rc-stats__grid { grid-template-columns: repeat(2, 1fr); gap: 1.5rem; }
    .rc-footer__grid { grid-template-columns: 1fr 1fr; }
    .rc-footer__sobre { grid-column: 1 / -1; }
}

@media (max-width: 920px) {
    .rc-hamburger { display: block; }
    body.rc-menu-aberto .rc-icone-abrir { display: none; }
    body.rc-menu-aberto .rc-icone-fechar { display: block; }
    .rc-nav {
        position: fixed; inset: 0 0 0 auto; width: min(320px, 86vw); z-index: 120;
        background: var(--bg-2); border-left: 1px solid var(--linha); flex-direction: column;
        align-items: stretch; gap: 1rem; padding: 5.5rem 1.6rem 2rem;
        transform: translateX(100%); transition: transform .25s ease; overflow-y: auto;
    }
    body.rc-menu-aberto .rc-nav { transform: translateX(0); }
    .rc-nav__lista { flex-direction: column; align-items: stretch; gap: .3rem; }
    .rc-nav__link { padding: .7rem 0; border-bottom: 1px solid var(--linha); }
    .rc-nav__link[aria-current="page"]::after { display: none; }
    .rc-header__cta { width: 100%; margin-top: .5rem; }
    .rc-header__focusfit { align-self: flex-start; }
    .rc-nav-overlay { display: block; position: fixed; inset: 0; z-index: 110; background: rgba(4,7,12,.6);
        opacity: 0; visibility: hidden; transition: opacity .25s ease, visibility .25s ease; }
    body.rc-menu-aberto .rc-nav-overlay { opacity: 1; visibility: visible; }
    body.rc-menu-aberto { overflow: hidden; }
}

@media (max-width: 600px) {
    body { font-size: 16px; }
    .rc-cards { grid-template-columns: 1fr; }
    .rc-metodo { grid-template-columns: 1fr; }
    .rc-footer__grid { grid-template-columns: 1fr; }
    .rc-badge--um { left: 4px; top: 8px; }
    .rc-badge--dois { right: 4px; bottom: 8px; }
    .rc-navpost { grid-template-columns: 1fr; }
    .rc-navpost__item--prox { grid-column: 1; text-align: left; flex-direction: row; }
    .rc-hero__provas { gap: 1.2rem; }
    .rc-form-inline input { flex-basis: 100%; }
}

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