/* ==========================================================================
   Ritoo — Institutional page (institucional.html)
   Premium marketing presentation. Builds on themed Bootstrap.
   ========================================================================== */

/* --------------------------------------------------------------------------
   Navbar
   -------------------------------------------------------------------------- */
.rit-navbar {
  background: rgba(246,243,238,0.0);
  transition: background-color .35s var(--rit-ease), box-shadow .35s var(--rit-ease),
              border-color .35s var(--rit-ease), backdrop-filter .35s var(--rit-ease);
  border-bottom: 1px solid transparent;
}
.rit-navbar.is-scrolled {
  background: rgba(250,249,246,0.82);
  backdrop-filter: saturate(140%) blur(14px);
  -webkit-backdrop-filter: saturate(140%) blur(14px);
  border-bottom-color: var(--rit-line);
  box-shadow: 0 1px 0 rgba(15,34,51,.02);
}
.rit-brand {
  font-family: var(--rit-font-serif);
  font-weight: 600;
  font-size: 1.5rem;
  letter-spacing: .01em;
  color: var(--rit-navy);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: .6rem;
}
.rit-brand:hover { color: var(--rit-navy); }
.rit-brand .mark {
  width: 30px; height: 30px;
  border: 1.5px solid var(--rit-navy);
  border-radius: 7px;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: .9rem; font-weight: 700; letter-spacing: 0;
  position: relative;
}
.rit-brand .mark::after {
  content: ""; position: absolute; right: -3px; bottom: -3px;
  width: 9px; height: 9px; border-radius: 3px;
  background: var(--rit-gold);
}
.rit-brand .dotcorp { font-size: .7rem; color: var(--rit-gold-ink); font-weight: 700; align-self: flex-start; }

.rit-nav .nav-link {
  font-family: var(--rit-font-sans);
  font-weight: 500;
  font-size: .92rem;
  color: var(--rit-ink-soft);
  padding: .4rem .9rem;
  position: relative;
}
.rit-nav .nav-link::after {
  content:""; position:absolute; left:.9rem; right:.9rem; bottom:.15rem;
  height:1px; background: var(--rit-gold); transform: scaleX(0);
  transform-origin: left; transition: transform .3s var(--rit-ease);
}
.rit-nav .nav-link:hover { color: var(--rit-navy); }
.rit-nav .nav-link:hover::after { transform: scaleX(1); }

/* --------------------------------------------------------------------------
   Hero
   -------------------------------------------------------------------------- */
.hero {
  position: relative;
  padding-top: 9.5rem;
  padding-bottom: 6rem;
  overflow: hidden;
  background:
    radial-gradient(120% 90% at 85% 0%, rgba(191,162,105,0.10), transparent 55%),
    radial-gradient(90% 80% at 0% 100%, rgba(15,34,51,0.05), transparent 60%),
    var(--rit-bg);
}
.hero-title { font-size: clamp(2.5rem, 4.6vw, 3.85rem); }
.hero-title .accent { color: var(--rit-gold-ink); font-style: italic; font-weight: 400; }
.hero-highlight {
  display: inline-flex; align-items: center; gap: .65rem;
  font-family: var(--rit-font-sans); font-weight: 600; font-size: .92rem;
  color: var(--rit-navy);
  background: var(--rit-surface);
  border: 1px solid var(--rit-line-strong);
  padding: .55rem 1rem; border-radius: 50rem;
  box-shadow: var(--rit-shadow-sm);
}
.hero-highlight .bi { color: var(--rit-gold-ink); }

.hero-stats { display: flex; gap: 2.4rem; flex-wrap: wrap; }
.hero-stat .n { font-family: var(--rit-font-serif); font-size: 1.9rem; font-weight: 600; color: var(--rit-navy); line-height: 1; }
.hero-stat .l { font-size: .82rem; color: var(--rit-muted); margin-top: .3rem; }

/* --------------------------------------------------------------------------
   Device / browser mockups
   -------------------------------------------------------------------------- */
.rit-window {
  background: var(--rit-surface);
  border: 1px solid var(--rit-line);
  border-radius: 14px;
  box-shadow: var(--rit-shadow-lg);
  overflow: hidden;
}
.rit-window-bar {
  display: flex; align-items: center; gap: .5rem;
  padding: .7rem .9rem;
  border-bottom: 1px solid var(--rit-line);
  background: var(--rit-bg-2);
}
.rit-window-bar .dot { width: 10px; height: 10px; border-radius: 50%; background: rgba(15,34,51,.16); }
.rit-window-url {
  margin-left: .6rem; flex: 1;
  background: var(--rit-surface);
  border: 1px solid var(--rit-line);
  border-radius: 50rem;
  font-size: .72rem; color: var(--rit-muted);
  padding: .28rem .8rem;
  display: flex; align-items: center; gap: .4rem;
  font-family: var(--rit-font-sans);
}
.rit-window-url .bi { font-size: .8em; color: var(--rit-green); }

/* Mock premium law-firm page inside the window */
.firm-page { background: linear-gradient(180deg, #fff, #FBFAF7); }
.firm-topbar {
  display:flex; align-items:center; justify-content:space-between;
  padding: .85rem 1.2rem; border-bottom: 1px solid var(--rit-line);
}
.firm-logo { font-family: var(--rit-font-serif); font-weight: 600; color: var(--rit-navy); font-size: .95rem; letter-spacing:.01em; }
.firm-nav { display:flex; gap: 1rem; }
.firm-nav span { font-size: .62rem; color: var(--rit-muted); font-weight:600; letter-spacing:.04em; }
.firm-hero { padding: 1.4rem 1.2rem 1.2rem; display:grid; grid-template-columns: 1.4fr .9fr; gap: 1rem; align-items:center; }
.firm-hero h4 { font-size: 1.18rem; line-height:1.15; margin-bottom:.5rem; }
.firm-hero p { font-size: .68rem; color: var(--rit-muted); margin-bottom:.8rem; line-height:1.5; }
.firm-cta { display:inline-flex; align-items:center; gap:.4rem; background: #1f8f4e; color:#fff; font-size:.64rem; font-weight:700; padding:.4rem .7rem; border-radius:50rem; }
.firm-portrait {
  aspect-ratio: 3/3.4; border-radius: 10px;
  background:
    repeating-linear-gradient(135deg, rgba(15,34,51,.05) 0 8px, rgba(15,34,51,.02) 8px 16px),
    var(--rit-bg-2);
  border: 1px solid var(--rit-line);
  display:flex; align-items:flex-end; justify-content:center;
  position: relative;
}
.firm-portrait::after {
  content: "retrato do advogado"; position:absolute; top:50%; left:50%;
  transform: translate(-50%,-50%); font-family: ui-monospace, monospace;
  font-size: .52rem; color: var(--rit-muted); letter-spacing:.02em;
}
.firm-areas { display:flex; gap:.4rem; flex-wrap:wrap; padding: 0 1.2rem 1.3rem; }
.firm-areas span {
  font-size:.58rem; font-weight:600; color: var(--rit-ink-soft);
  border:1px solid var(--rit-line); border-radius:50rem; padding:.28rem .6rem;
  background: var(--rit-surface);
}

/* Floating cards around hero mockup */
.float-card {
  position: absolute;
  background: var(--rit-surface);
  border: 1px solid var(--rit-line);
  border-radius: 12px;
  box-shadow: var(--rit-shadow);
  padding: .85rem 1rem;
  z-index: 3;
}
.float-card .fc-title { font-size: .7rem; color: var(--rit-muted); font-weight:600; letter-spacing:.04em; text-transform:uppercase; }
.float-tenant { top: 7%; left: -4%; width: 210px; }
.float-modules { bottom: 6%; right: -5%; width: 230px; }

.tenant-row { display:flex; align-items:center; gap:.6rem; margin-top:.55rem; }
.tenant-avatar { width: 30px; height:30px; border-radius:8px; background: var(--rit-navy); color: var(--rit-gold-bright);
  display:flex; align-items:center; justify-content:center; font-family: var(--rit-font-serif); font-weight:600; font-size:.8rem; }
.tenant-name { font-size:.8rem; font-weight:700; color: var(--rit-navy); line-height:1.1; }
.tenant-meta { font-size:.66rem; color: var(--rit-muted); }

.mini-mod { display:flex; align-items:center; gap:.5rem; margin-top:.5rem; font-size:.72rem; color: var(--rit-ink-soft); font-weight:600; }
.mini-mod .bi { color: var(--rit-gold-ink); font-size:.9em; }
.mini-mod .on { margin-left:auto; width:8px; height:8px; border-radius:50%; background:#1f8f4e; box-shadow:0 0 0 3px rgba(31,143,78,.14); }

@media (max-width: 991.98px) {
  .float-tenant { left: 0; }
  .float-modules { right: 0; }
}

/* --------------------------------------------------------------------------
   Section heading block
   -------------------------------------------------------------------------- */
.section-head { max-width: 720px; }
.section-title { font-size: clamp(1.9rem, 3vw, 2.6rem); }

/* Trust strip */
.trust-strip {
  border-top: 1px solid var(--rit-line);
  border-bottom: 1px solid var(--rit-line);
  background: var(--rit-bg-2);
}
.trust-item { display:flex; align-items:center; gap:.7rem; color: var(--rit-ink-soft); font-weight:600; font-size:.92rem; }
.trust-item .bi { color: var(--rit-gold-ink); font-size:1.2rem; }

/* --------------------------------------------------------------------------
   Problem — fragmented tools illustration
   -------------------------------------------------------------------------- */
.frag-grid { display:grid; grid-template-columns: repeat(3,1fr); gap:.7rem; }
.frag-tool {
  border:1px dashed var(--rit-line-strong); border-radius:10px;
  padding:.9rem; background: var(--rit-surface);
  display:flex; align-items:center; gap:.6rem; font-size:.85rem; font-weight:600; color: var(--rit-muted);
}
.frag-tool .bi { font-size:1.1rem; color: var(--rit-muted); }
.frag-tool.is-x { position:relative; }
.frag-note { font-family: ui-monospace, monospace; font-size:.72rem; color: var(--rit-muted); }

/* --------------------------------------------------------------------------
   Modules
   -------------------------------------------------------------------------- */
.module-filter { display:flex; gap:.5rem; flex-wrap:wrap; }
.module-card {
  height: 100%;
  cursor: default;
}
.module-card:hover { transform: translateY(-4px); box-shadow: var(--rit-shadow); border-color: var(--rit-line-strong); }
.module-icon {
  width: 52px; height: 52px; border-radius: 13px;
  display:flex; align-items:center; justify-content:center;
  background: var(--rit-navy); color: var(--rit-gold-bright);
  font-size: 1.4rem; margin-bottom: 1.25rem;
  transition: background-color .35s var(--rit-ease);
}
.module-card:hover .module-icon { background: var(--rit-navy-deep); }
.module-name { font-size: 1.25rem; margin-bottom:.55rem; }
.module-desc { font-size: .95rem; color: var(--rit-ink-soft); line-height:1.55; }
.module-feats { list-style:none; padding:0; margin: 1.1rem 0 0; }
.module-feats li {
  font-size: .85rem; color: var(--rit-ink-soft); padding: .32rem 0 .32rem 1.4rem;
  position: relative; border-top: 1px solid var(--rit-line);
}
.module-feats li:first-child { border-top: 0; }
.module-feats li::before {
  content: "\F26E"; font-family: "bootstrap-icons"; position:absolute; left:0; top:.34rem;
  color: var(--rit-gold-ink); font-size:.8rem;
}
.module-card.is-dimmed { opacity: .32; filter: saturate(.4); }

/* --------------------------------------------------------------------------
   Multi-tenant section (dark)
   -------------------------------------------------------------------------- */
.tenant-diagram {
  position: relative;
  border: 1px solid var(--rit-line-on-dark);
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,0));
  padding: 2rem;
}
.platform-node {
  text-align:center; margin: 0 auto 1.6rem; max-width: 320px;
  border: 1px solid rgba(210,186,133,.4);
  background: rgba(191,162,105,.10);
  border-radius: 12px; padding: 1rem 1.2rem;
}
.platform-node .pn-title { font-family: var(--rit-font-serif); font-size:1.15rem; color:#fff; }
.platform-node .pn-sub { font-size:.78rem; color: var(--rit-gold-bright); letter-spacing:.04em; text-transform:uppercase; font-weight:600; }
.tenant-cards { display:grid; grid-template-columns: repeat(3,1fr); gap: 1rem; position: relative; }
.tenant-cards::before {
  content:""; position:absolute; top:-1.6rem; left:16.66%; right:16.66%; height:1.6rem;
  border-top: 1px solid rgba(255,255,255,.14);
}
.tenant-card {
  border: 1px solid var(--rit-line-on-dark);
  background: rgba(255,255,255,.035);
  border-radius: 12px; padding: 1.2rem;
  position: relative;
  transition: transform .3s var(--rit-ease), background-color .3s var(--rit-ease), border-color .3s var(--rit-ease);
}
.tenant-card::before {
  content:""; position:absolute; top:-1.6rem; left:50%; width:1px; height:1.6rem; background: rgba(255,255,255,.14);
}
.tenant-card:hover { transform: translateY(-4px); background: rgba(255,255,255,.06); border-color: rgba(210,186,133,.4); }
.tenant-card .tc-head { display:flex; align-items:center; gap:.6rem; margin-bottom:.9rem; }
.tenant-card .tc-avatar {
  width: 34px; height:34px; border-radius:9px; background: var(--rit-gold);
  color: var(--rit-navy-deep); display:flex; align-items:center; justify-content:center;
  font-family: var(--rit-font-serif); font-weight:700; font-size:.9rem;
}
.tenant-card .tc-name { color:#fff; font-weight:700; font-size:.95rem; line-height:1.1; }
.tenant-card .tc-domain { color: rgba(234,240,246,.55); font-size:.72rem; }
.tc-mods { display:flex; flex-wrap:wrap; gap:.35rem; }
.tc-mod { font-size:.68rem; font-weight:600; color:#EAF0F6; background: rgba(255,255,255,.07);
  border:1px solid var(--rit-line-on-dark); border-radius:50rem; padding:.24rem .55rem; }
.tc-mod.is-gold { background: rgba(191,162,105,.16); border-color: rgba(210,186,133,.4); color: var(--rit-gold-bright); }

.tenant-feature { display:flex; gap:1rem; align-items:flex-start; }
.tenant-feature .tf-ico { color: var(--rit-gold-bright); font-size:1.4rem; flex:0 0 auto; margin-top:.1rem; }
.tenant-feature h5 { color:#fff; font-size:1.05rem; margin-bottom:.3rem; }
.tenant-feature p { color: rgba(234,240,246,.72); font-size:.9rem; margin:0; line-height:1.5; }

@media (max-width: 767.98px){
  .tenant-cards { grid-template-columns: 1fr; }
  .tenant-cards::before, .tenant-card::before { display:none; }
}

/* --------------------------------------------------------------------------
   Benefits
   -------------------------------------------------------------------------- */
.benefit {
  display:flex; gap:1rem; padding: 1.3rem; border-radius: 12px;
  border:1px solid transparent; transition: background-color .3s var(--rit-ease), border-color .3s var(--rit-ease);
}
.benefit:hover { background: var(--rit-surface); border-color: var(--rit-line); box-shadow: var(--rit-shadow-sm); }
.benefit .b-ico {
  flex:0 0 auto; width:44px; height:44px; border-radius:11px;
  border:1px solid var(--rit-line-strong); display:flex; align-items:center; justify-content:center;
  color: var(--rit-navy); font-size:1.2rem;
}
.benefit h5 { font-size:1.05rem; margin-bottom:.3rem; }
.benefit p { font-size:.88rem; color: var(--rit-muted); margin:0; line-height:1.5; }

/* --------------------------------------------------------------------------
   How it works — vertical steps
   -------------------------------------------------------------------------- */
.steps { position: relative; }
.step { display:grid; grid-template-columns: 64px 1fr; gap: 1.4rem; padding-bottom: 2.2rem; position: relative; }
.step:last-child { padding-bottom: 0; }
.step::before {
  content:""; position:absolute; left: 31px; top: 64px; bottom: 0; width:1px; background: var(--rit-line-strong);
}
.step:last-child::before { display:none; }
.step-num {
  width: 64px; height:64px; border-radius:50%;
  border:1px solid var(--rit-line-strong); background: var(--rit-surface);
  display:flex; align-items:center; justify-content:center;
  font-family: var(--rit-font-serif); font-size:1.3rem; font-weight:600; color: var(--rit-navy);
  position: relative; z-index:1;
}
.step.is-visible .step-num { border-color: var(--rit-gold); color: var(--rit-gold-ink); }
.step h5 { font-size:1.15rem; margin-bottom:.4rem; padding-top:.7rem; }
.step p { color: var(--rit-ink-soft); font-size:.95rem; margin:0; }

/* --------------------------------------------------------------------------
   Compositions
   -------------------------------------------------------------------------- */
.compo-card { height:100%; }
.compo-card .badge-profile {
  font-size:.72rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase;
  color: var(--rit-gold-ink);
}
.compo-mods { list-style:none; padding:0; margin: 1.1rem 0 0; }
.compo-mods li { display:flex; align-items:center; gap:.6rem; padding:.5rem 0; font-size:.92rem; font-weight:600; color: var(--rit-navy); border-top:1px solid var(--rit-line); }
.compo-mods li .bi { color: var(--rit-gold-ink); }
.compo-note { font-size:.88rem; color: var(--rit-muted); line-height:1.55; }

/* --------------------------------------------------------------------------
   Dashboard preview (panel section)
   -------------------------------------------------------------------------- */
.dash-mock { background: var(--rit-bg-2); }
.dash-shell { display:grid; grid-template-columns: 200px 1fr; min-height: 420px; }
.dash-side { background: var(--rit-navy-deep); padding: 1.2rem 1rem; }
.dash-side .ds-brand { color:#fff; font-family: var(--rit-font-serif); font-weight:600; font-size:1rem; margin-bottom:1.4rem; display:flex; align-items:center; gap:.5rem; }
.dash-side .ds-brand .b { width:8px;height:8px;border-radius:2px;background:var(--rit-gold); }
.dash-nav { list-style:none; padding:0; margin:0; }
.dash-nav li { display:flex; align-items:center; gap:.6rem; font-size:.8rem; color: rgba(234,240,246,.65); padding:.55rem .65rem; border-radius:8px; margin-bottom:.15rem; font-weight:600; }
.dash-nav li.active { background: rgba(255,255,255,.07); color:#fff; }
.dash-nav li.active .bi { color: var(--rit-gold-bright); }
.dash-main { padding: 1.4rem 1.5rem; }
.dash-kpis { display:grid; grid-template-columns: repeat(3,1fr); gap:.8rem; margin-bottom:1.1rem; }
.dash-kpi { border:1px solid var(--rit-line); border-radius:10px; padding:.9rem 1rem; background:var(--rit-surface); }
.dash-kpi .k { font-family: var(--rit-font-serif); font-size:1.5rem; color: var(--rit-navy); font-weight:600; line-height:1; }
.dash-kpi .l { font-size:.68rem; color: var(--rit-muted); margin-top:.3rem; text-transform:uppercase; letter-spacing:.05em; font-weight:600; }
.dash-kpi .d { font-size:.66rem; color:#1f8f4e; font-weight:700; }
.dash-panel { border:1px solid var(--rit-line); border-radius:10px; background:var(--rit-surface); padding:1rem 1.1rem; }
.dash-panel h6 { font-family:var(--rit-font-sans); font-size:.72rem; text-transform:uppercase; letter-spacing:.06em; color: var(--rit-muted); font-weight:700; }
.lead-row { display:flex; align-items:center; gap:.7rem; padding:.55rem 0; border-top:1px solid var(--rit-line); font-size:.8rem; }
.lead-row .av { width:26px;height:26px;border-radius:50%; background: var(--rit-navy); color: var(--rit-gold-bright); display:flex;align-items:center;justify-content:center; font-size:.66rem; font-weight:700; }
.lead-row .st { margin-left:auto; font-size:.64rem; font-weight:700; padding:.16rem .5rem; border-radius:50rem; }
.st-new { background: rgba(31,143,78,.12); color:#1f8f4e; }
.st-prog { background: var(--rit-gold-soft); color: var(--rit-gold-ink); }
.st-won { background: rgba(15,34,51,.08); color: var(--rit-navy); }
@media (max-width: 575.98px){ .dash-shell{ grid-template-columns:1fr;} .dash-side{ display:none;} .dash-kpis{grid-template-columns:1fr;} }

/* --------------------------------------------------------------------------
   Commercial model
   -------------------------------------------------------------------------- */
.commercial-card { height:100%; position:relative; overflow:hidden; }
.commercial-card.is-featured { border-color: var(--rit-gold); box-shadow: 0 18px 50px rgba(138,110,54,.12); }
.commercial-card .cc-tier { font-family: var(--rit-font-serif); font-size:1.4rem; color: var(--rit-navy); margin-bottom:.5rem; }
.commercial-card .cc-for { font-size:.92rem; color: var(--rit-ink-soft); min-height:3.2em; line-height:1.5; }
.cc-tag { position:absolute; top:1.2rem; right:1.2rem; font-size:.66rem; font-weight:700; letter-spacing:.05em; text-transform:uppercase; color: var(--rit-gold-ink); }
.cc-list { list-style:none; padding:0; margin:1.1rem 0 0; }
.cc-list li { display:flex; align-items:center; gap:.6rem; font-size:.9rem; padding:.45rem 0; color: var(--rit-ink-soft); border-top:1px solid var(--rit-line); font-weight:600; }
.cc-list li .bi { color: var(--rit-gold-ink); }
.commercial-note {
  border:1px solid var(--rit-line); border-left: 3px solid var(--rit-gold);
  background: var(--rit-bg-2); border-radius: 10px; padding: 1.1rem 1.3rem;
  font-size:.9rem; color: var(--rit-ink-soft);
}

/* --------------------------------------------------------------------------
   Differentiators
   -------------------------------------------------------------------------- */
.diff-item { display:flex; gap:.8rem; align-items:flex-start; padding:.7rem 0; }
.diff-item .bi { color: var(--rit-gold-ink); font-size:1.05rem; margin-top:.15rem; }
.diff-item span { font-size:.95rem; font-weight:600; color: var(--rit-ink); }

/* --------------------------------------------------------------------------
   CTA final (dark)
   -------------------------------------------------------------------------- */
.cta-final {
  background:
    radial-gradient(100% 120% at 80% 0%, rgba(191,162,105,0.16), transparent 55%),
    var(--rit-navy-deep);
  position: relative; overflow: hidden;
}
.cta-final h2 { color:#fff; font-size: clamp(2rem, 3.4vw, 3rem); }
.cta-final p { color: rgba(234,240,246,.78); }

/* --------------------------------------------------------------------------
   Footer
   -------------------------------------------------------------------------- */
.rit-footer { background: var(--rit-navy-deep); color: rgba(234,240,246,.65); }
.rit-footer a { color: rgba(234,240,246,.65); text-decoration:none; font-size:.9rem; transition: color .2s var(--rit-ease); }
.rit-footer a:hover { color:#fff; }
.rit-footer .foot-brand { font-family: var(--rit-font-serif); color:#fff; font-size:1.4rem; }
.rit-footer h6 { color:#fff; font-size:.78rem; letter-spacing:.08em; text-transform:uppercase; font-family: var(--rit-font-sans); font-weight:700; }
.foot-bottom { border-top:1px solid var(--rit-line-on-dark); font-size:.82rem; }

/* --------------------------------------------------------------------------
   Contact form
   -------------------------------------------------------------------------- */
.contact-card { background: var(--rit-surface); border:1px solid var(--rit-line); border-radius:18px; box-shadow: var(--rit-shadow); }

/* WhatsApp float */
.wa-float {
  position: fixed; right: 1.4rem; bottom: 1.4rem; z-index: 1040;
  width: 56px; height:56px; border-radius:50%;
  background: #1f8f4e; color:#fff; display:flex; align-items:center; justify-content:center;
  font-size:1.6rem; box-shadow: 0 10px 30px rgba(31,143,78,.4);
  transition: transform .25s var(--rit-ease);
}
.wa-float:hover { transform: translateY(-3px) scale(1.04); color:#fff; }

/* Section dividers */
.deco-quote {
  font-family: var(--rit-font-serif); font-style: italic; font-weight: 400;
  font-size: clamp(1.5rem, 2.6vw, 2.2rem); color: var(--rit-navy); line-height:1.3;
}
.deco-quote .accent { color: var(--rit-gold-ink); }

/* ==========================================================================
   Checkout — module configurator + payment (PIX / Boleto / Cartão)
   ========================================================================== */
.configurator { background: var(--rit-bg-2); }
.config-grid { display:grid; grid-template-columns: 1.55fr .9fr; gap: 1.6rem; align-items:start; }
@media (max-width: 991.98px){ .config-grid{ grid-template-columns:1fr; } }

/* Selectable module tile */
.config-module {
  display:flex; align-items:flex-start; gap:.9rem;
  border:1px solid var(--rit-line); border-radius:12px; background:var(--rit-surface);
  padding: 1rem 1.1rem; cursor:pointer; user-select:none;
  transition: border-color .25s var(--rit-ease), box-shadow .25s var(--rit-ease), background-color .25s var(--rit-ease);
  position: relative;
}
.config-module:hover { border-color: var(--rit-line-strong); box-shadow: var(--rit-shadow-sm); }
.config-module.is-selected { border-color: var(--rit-gold); background: linear-gradient(0deg, var(--rit-gold-soft), var(--rit-gold-soft)), var(--rit-surface); }
.config-module.is-required { cursor:not-allowed; }
.config-check {
  flex:0 0 auto; width:22px; height:22px; border-radius:6px;
  border:1.5px solid var(--rit-line-strong); display:flex; align-items:center; justify-content:center;
  color:#fff; font-size:.75rem; transition: background-color .2s var(--rit-ease), border-color .2s var(--rit-ease);
}
.config-module.is-selected .config-check { background: var(--rit-gold); border-color: var(--rit-gold); color: var(--rit-navy-deep); }
.config-ico { flex:0 0 auto; width:40px; height:40px; border-radius:10px; background: var(--rit-navy); color:var(--rit-gold-bright); display:flex; align-items:center; justify-content:center; font-size:1.1rem; }
.config-body { flex:1; }
.config-body .cm-name { font-family: var(--rit-font-serif); font-size:1.05rem; color: var(--rit-navy); font-weight:600; line-height:1.1; }
.config-body .cm-desc { font-size:.82rem; color: var(--rit-muted); margin:.25rem 0 0; line-height:1.45; }
.config-body .cm-price { font-size:.8rem; font-weight:700; color: var(--rit-ink-soft); margin-top:.45rem; }
.config-body .cm-price .ref { color: var(--rit-muted); font-weight:600; }
.config-req-tag { font-size:.6rem; font-weight:700; letter-spacing:.05em; text-transform:uppercase; color: var(--rit-gold-ink); }

/* Summary panel */
.summary-card { position: sticky; top: 96px; border:1px solid var(--rit-line); border-radius:16px; background:var(--rit-surface); box-shadow: var(--rit-shadow); overflow:hidden; }
.summary-head { background: var(--rit-navy); color:#fff; padding: 1.2rem 1.4rem; }
.summary-head .sh-title { font-family:var(--rit-font-serif); font-size:1.15rem; color:#fff; }
.summary-head .sh-sub { font-size:.76rem; color: var(--rit-gold-bright); letter-spacing:.04em; text-transform:uppercase; font-weight:600; }
.summary-body { padding: 1.2rem 1.4rem; }
.summary-list { list-style:none; padding:0; margin:0; max-height: 230px; overflow:auto; }
.summary-list li { display:flex; align-items:center; gap:.5rem; font-size:.85rem; padding:.5rem 0; border-top:1px solid var(--rit-line); color: var(--rit-ink-soft); }
.summary-list li:first-child{ border-top:0; }
.summary-list li .nm { font-weight:600; color: var(--rit-navy); }
.summary-list li .pr { margin-left:auto; font-weight:700; color: var(--rit-ink-soft); }
.summary-list .empty { color: var(--rit-muted); font-style:italic; border:0; }
.summary-total { display:flex; align-items:baseline; justify-content:space-between; border-top:1px solid var(--rit-line-strong); padding-top:1rem; margin-top:.4rem; }
.summary-total .lbl { font-size:.78rem; text-transform:uppercase; letter-spacing:.05em; color: var(--rit-muted); font-weight:700; }
.summary-total .amt { font-family: var(--rit-font-serif); font-size:1.9rem; color: var(--rit-navy); font-weight:600; }
.summary-total .amt small { font-size:.85rem; color: var(--rit-muted); font-weight:500; }
.summary-disclaimer { font-size:.72rem; color: var(--rit-muted); line-height:1.5; margin-top:.9rem; }

/* Checkout modal */
.checkout-modal .modal-content { border:0; border-radius:18px; overflow:hidden; box-shadow: var(--rit-shadow-lg); }
.checkout-modal .modal-body { padding:0; }
.checkout-layout { display:grid; grid-template-columns: 1fr 340px; min-height: 540px; }
@media (max-width: 767.98px){ .checkout-layout{ grid-template-columns:1fr; } .checkout-aside{ order:-1; } }
.checkout-main { padding: 2rem 2.2rem; }
.checkout-aside { background: var(--rit-navy-deep); color:#EAF0F6; padding: 2rem 1.8rem; }
.checkout-aside .ca-brand { font-family:var(--rit-font-serif); color:#fff; font-size:1.3rem; margin-bottom:.2rem; }
.checkout-aside .ca-sub { font-size:.72rem; color:var(--rit-gold-bright); text-transform:uppercase; letter-spacing:.08em; font-weight:600; margin-bottom:1.6rem; }
.ca-list { list-style:none; padding:0; margin:0; }
.ca-list li { display:flex; gap:.5rem; font-size:.84rem; padding:.5rem 0; border-top:1px solid var(--rit-line-on-dark); color: rgba(234,240,246,.85); }
.ca-list li:first-child{ border-top:0; }
.ca-list li .pr { margin-left:auto; color:#fff; font-weight:700; }
.ca-total { border-top:1px solid var(--rit-line-on-dark); margin-top:.6rem; padding-top:1rem; display:flex; justify-content:space-between; align-items:baseline; }
.ca-total .amt { font-family:var(--rit-font-serif); font-size:1.6rem; color:#fff; }
.ca-secure { font-size:.72rem; color: rgba(234,240,246,.55); display:flex; align-items:center; gap:.45rem; margin-top:1.4rem; }
.ca-secure .bi{ color: var(--rit-gold-bright); }

/* Stepper */
.checkout-steps { display:flex; gap:.4rem; margin-bottom:1.8rem; }
.checkout-steps .cs { flex:1; text-align:center; font-size:.72rem; font-weight:700; color: var(--rit-muted); padding-bottom:.6rem; border-bottom:2px solid var(--rit-line); letter-spacing:.02em; transition: color .25s, border-color .25s; }
.checkout-steps .cs.active { color: var(--rit-navy); border-bottom-color: var(--rit-gold); }
.checkout-steps .cs.done { color: var(--rit-gold-ink); border-bottom-color: var(--rit-gold); }
.checkout-steps .cs .bi { margin-right:.3rem; }

.step-pane { display:none; }
.step-pane.active { display:block; animation: fadeStep .4s var(--rit-ease); }
@keyframes fadeStep { from { opacity:0; transform: translateY(8px);} to{opacity:1; transform:none;} }

/* Payment method selector */
.pay-methods { display:grid; grid-template-columns: repeat(3,1fr); gap:.7rem; margin-bottom:1.5rem; }
.pay-method {
  border:1.5px solid var(--rit-line); border-radius:12px; padding:1rem .8rem; text-align:center; cursor:pointer;
  transition: border-color .2s var(--rit-ease), background-color .2s var(--rit-ease);
  background: var(--rit-surface);
}
.pay-method:hover { border-color: var(--rit-line-strong); }
.pay-method.is-active { border-color: var(--rit-navy); background: var(--rit-bg-2); }
.pay-method .pm-ico { font-size:1.5rem; color: var(--rit-navy); }
.pay-method .pm-name { font-size:.82rem; font-weight:700; color: var(--rit-navy); margin-top:.35rem; }
.pay-method .pm-tag { font-size:.66rem; color: var(--rit-muted); }
.pay-method.is-active .pm-ico { color: var(--rit-gold-ink); }

.pay-pane { display:none; }
.pay-pane.active { display:block; }

/* PIX */
.pix-box { display:flex; gap:1.4rem; align-items:center; flex-wrap:wrap; }
.pix-qr {
  width: 168px; height:168px; flex:0 0 auto; border-radius:12px; padding:10px; background:#fff; border:1px solid var(--rit-line);
}
.pix-qr svg { width:100%; height:100%; display:block; }
.pix-info { flex:1; min-width: 220px; }
.pix-code {
  font-family: ui-monospace, monospace; font-size:.72rem; color: var(--rit-ink-soft);
  background: var(--rit-bg-2); border:1px solid var(--rit-line); border-radius:8px; padding:.7rem .8rem;
  word-break: break-all; line-height:1.4; max-height: 70px; overflow:hidden;
}
.copy-row { display:flex; gap:.5rem; align-items:center; margin-top:.7rem; }
.pix-timer { font-size:.78rem; color: var(--rit-gold-ink); font-weight:700; }

/* Boleto */
.boleto-barcode { height:64px; margin: .4rem 0 .8rem; background:
  repeating-linear-gradient(90deg, var(--rit-ink) 0 2px, transparent 2px 4px, var(--rit-ink) 4px 5px, transparent 5px 9px,
   var(--rit-ink) 9px 12px, transparent 12px 13px); border:1px solid var(--rit-line); border-radius:4px; }
.boleto-line { font-family: ui-monospace, monospace; font-size:.8rem; color: var(--rit-navy); font-weight:600; letter-spacing:.02em; }

/* Card form */
.card-preview {
  background: linear-gradient(135deg, var(--rit-navy), var(--rit-navy-deep));
  border-radius:14px; padding:1.3rem 1.4rem; color:#fff; margin-bottom:1.3rem; position:relative; overflow:hidden; box-shadow: var(--rit-shadow);
}
.card-preview::after{ content:""; position:absolute; right:-30px; top:-30px; width:120px; height:120px; border-radius:50%; background: rgba(191,162,105,.18); }
.card-preview .cp-chip { width:34px; height:24px; border-radius:5px; background: linear-gradient(135deg, var(--rit-gold-bright), var(--rit-gold)); margin-bottom:1.2rem; }
.card-preview .cp-num { font-family: ui-monospace, monospace; font-size:1.1rem; letter-spacing:.1em; }
.card-preview .cp-row { display:flex; justify-content:space-between; margin-top:1rem; font-size:.7rem; color: rgba(255,255,255,.7); text-transform:uppercase; letter-spacing:.05em; }
.card-preview .cp-row b { display:block; color:#fff; font-size:.85rem; letter-spacing:.03em; text-transform:none; margin-top:.15rem; font-family: ui-monospace, monospace; }

/* Success */
.checkout-success { text-align:center; padding: 2rem 1rem; }
.success-ring { width:84px; height:84px; border-radius:50%; background: rgba(31,143,78,.12); color:#1f8f4e; display:flex; align-items:center; justify-content:center; font-size:2.4rem; margin:0 auto 1.4rem; animation: pop .5s var(--rit-ease); }
@keyframes pop { 0%{transform:scale(.6); opacity:0;} 60%{transform:scale(1.08);} 100%{transform:scale(1); opacity:1;} }

.copied-toast { position:fixed; bottom:1.6rem; left:50%; transform:translateX(-50%) translateY(20px); background:var(--rit-navy-deep); color:#fff; padding:.7rem 1.2rem; border-radius:50rem; font-size:.85rem; font-weight:600; z-index:2000; opacity:0; transition:opacity .3s, transform .3s; pointer-events:none; box-shadow:var(--rit-shadow-lg); }
.copied-toast.show { opacity:1; transform:translateX(-50%) translateY(0); }
