/* File: /public_html/assets/css/app.css
   Ritremis Theme System (Clean + Stable)
   - HTML gets class: theme-mono OR theme-navy
   - HTML may also get class: sb-collapsed (sidebar collapsed)
*/

/* =========================
   TOKENS
========================= */
:root{
  --radius: 18px;
  --ease: cubic-bezier(.2,.8,.2,1);
  --lift: translateY(-1px);

  /* Mono defaults */
  --bg:#f4f5f7;
  --panel: rgba(255,255,255,.75);
  --border: rgba(0,0,0,.08);
  --text:#0e0f12;
  --muted:#6b7280;
  --shadow: 0 10px 30px rgba(0,0,0,.08);

  --btn-bg:#0e0f12;
  --btn-text:#ffffff;

  --input-bg: rgba(255,255,255,.85);
  --input-border: rgba(0,0,0,.10);

  --nav-active: rgba(0,0,0,.06);

  --accent: rgba(0,0,0,.65);
  --ring: rgba(0,0,0,.10);

  /* gold system */
  --gold: rgba(212,175,55,.92);
  --gold-line: rgba(212,175,55,.28);
  --gold-soft: rgba(212,175,55,.14);

  /* navy extras */
  --grid: rgba(0,0,0,0);
  --glow-a: rgba(0,0,0,0);
  --glow-b: rgba(0,0,0,0);
}

/* =========================
   THEME: MONO
========================= */
html.theme-mono{
  --bg:#f4f5f7;
  --panel: rgba(255,255,255,.75);
  --border: rgba(0,0,0,.08);
  --text:#0e0f12;
  --muted:#6b7280;
  --shadow: 0 10px 30px rgba(0,0,0,.08);

  --btn-bg:#0e0f12;
  --btn-text:#ffffff;

  --input-bg: rgba(255,255,255,.85);
  --input-border: rgba(0,0,0,.10);

  --nav-active: rgba(0,0,0,.06);

  --accent: rgba(0,0,0,.65);
  --ring: rgba(0,0,0,.10);

  --grid: rgba(0,0,0,0);
  --glow-a: rgba(255,255,255,.75);
  --glow-b: rgba(244,245,247,.9);
}

/* =========================
   THEME: NAVY GOLD TECH
========================= */
html.theme-navy{
  --bg:#050816;
  --panel: rgba(8, 14, 30, .64);
  --border: rgba(255,255,255,.10);
  --text:#eef2ff;
  --muted: rgba(231, 237, 255, .68);
  --shadow: 0 24px 70px rgba(0,0,0,.55);

  --input-bg: rgba(255,255,255,.06);
  --input-border: rgba(255,255,255,.14);

  --nav-active: rgba(255,255,255,.08);

  --accent: var(--gold);
  --ring: rgba(212,175,55,.18);

  --glow-a: rgba(212,175,55,.20);
  --glow-b: rgba(25, 190, 220, .12);

  --grid: rgba(255,255,255,.035);

  --btn-bg: linear-gradient(135deg, rgba(212,175,55,.98), rgba(168,126,32,.92));
  --btn-text:#0b0f1f;
}

/* =========================
   BASE
========================= */
*{ box-sizing:border-box; }

html, body{ height:100%; }
body{
  margin:0;
  min-height:100%;
  overflow-y:auto;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  color:var(--text);
  background:
    radial-gradient(circle at 18% 22%, var(--glow-a), transparent 45%),
    radial-gradient(circle at 78% 18%, var(--glow-b), transparent 48%),
    var(--bg);
}

a{ color:inherit; text-decoration:none; }
a:hover{ opacity:.94; }

.container{ max-width:1200px; margin:0 auto; padding:24px; }

/* Navy grid overlay (only once, clean) */
html.theme-navy body{
  background:
    radial-gradient(circle at 18% 22%, var(--glow-a), transparent 45%),
    radial-gradient(circle at 78% 18%, var(--glow-b), transparent 48%),
    linear-gradient(to bottom, rgba(255,255,255,.03), rgba(255,255,255,0)),
    repeating-linear-gradient(to right, var(--grid) 0px, var(--grid) 1px, transparent 1px, transparent 64px),
    repeating-linear-gradient(to bottom, var(--grid) 0px, var(--grid) 1px, transparent 1px, transparent 64px),
    var(--bg);
}

/* =========================
   GLASS SURFACES
========================= */
.glass{
  position:relative;
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  backdrop-filter: blur(12px);
  overflow:hidden;
  transition: transform .18s var(--ease), box-shadow .18s var(--ease), border-color .18s var(--ease), background .18s var(--ease);
}

html.theme-navy .glass{
  box-shadow:
    0 24px 70px rgba(0,0,0,.55),
    inset 0 1px 0 rgba(255,255,255,.06);
}

/* Diagonal sheen (navy only, subtle) */
html.theme-navy .glass::after{
  content:"";
  position:absolute;
  inset:-40px;
  pointer-events:none;
  background:
    linear-gradient(120deg, transparent 0%, rgba(212,175,55,.10) 18%, transparent 38%),
    linear-gradient(135deg, transparent 0%, rgba(255,255,255,.05) 35%, transparent 65%);
  opacity:.28;
}

/* =========================
   TOPBAR
========================= */
.topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:16px 18px;
  margin-bottom:16px;
}

.brand{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:800;
  letter-spacing:.3px;
  position:relative;
  z-index:1;
}

.brand-dot{
  display:inline-block;
  width:10px; height:10px;
  border-radius:999px;
  background:#0e0f12;
}
html.theme-navy .brand-dot{
  background: var(--gold);
  box-shadow: 0 0 22px rgba(212,175,55,.50);
}

.badge{
  font-size:12px;
  padding:4px 10px;
  border:1px solid var(--border);
  border-radius:999px;
  color:var(--muted);
}
html.theme-navy .badge{
  border-color: rgba(212,175,55,.20);
  color: rgba(212,175,55,.92);
}

.top-actions{
  display:flex;
  align-items:center;
  gap:10px;
}

/* Hamburger toggle button */
.iconbtn{
  width:42px; height:42px;
  border-radius:14px;
  border:1px solid var(--border);
  background: rgba(255,255,255,.06);
  color: var(--text);
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  transition: transform .18s var(--ease), box-shadow .18s var(--ease), background .18s var(--ease), border-color .18s var(--ease);
}
.iconbtn:hover{
  transform: var(--lift);
  box-shadow: 0 10px 22px rgba(0,0,0,.18);
  background: rgba(255,255,255,.09);
}
.iconbtn:active{ transform: translateY(0px) scale(.98); }

.hamburger{
  width:18px;
  height:2px;
  background: currentColor;
  position:relative;
  border-radius:99px;
  opacity:.9;
}
.hamburger:before,
.hamburger:after{
  content:"";
  position:absolute;
  left:0;
  width:18px;
  height:2px;
  background: currentColor;
  border-radius:99px;
  opacity:.85;
}
.hamburger:before{ top:-6px; }
.hamburger:after { top: 6px; }

/* =========================
   LAYOUT
========================= */
.layout{
  display:grid;
  grid-template-columns: 260px 1fr;
  gap:16px;
  transition: grid-template-columns .22s var(--ease);
}

html.sb-collapsed .layout{
  grid-template-columns: 92px 1fr;
}

/* =========================
   SIDEBAR
========================= */
.sidebar{
  padding:16px;
  position:sticky;
  top: 0;
  align-self:start;
  max-height: calc(100vh - 48px);
  overflow:auto;
  scrollbar-width: thin;
  transition: padding .22s var(--ease);
  overflow-x: hidden !important;
  overflow-y: auto;
}

html.sb-collapsed .sidebar{
  padding: 12px 10px;
}

/* gold edge light on navy sidebar */
html.theme-navy .sidebar::before{
  content:"";
  position:absolute;
  top:0; bottom:0; left:0;
  width:4px;
  background: linear-gradient(to bottom, rgba(212,175,55,.05), rgba(212,175,55,.65), rgba(212,175,55,.08));
  box-shadow:
    0 0 18px rgba(212,175,55,.35),
    0 0 42px rgba(212,175,55,.18);
  border-top-left-radius: var(--radius);
  border-bottom-left-radius: var(--radius);
  pointer-events:none;
}

/* Divider uses theme border */
.sidebar-hr{
  border: 0;
  border-top: 1px solid var(--border);
  margin: 14px 0;
  opacity: .9;
}
html.theme-navy .sidebar-hr{
  border-top-color: rgba(255,255,255,.10);
  opacity: .7;
}

/* Meta block styling */
.sidebar-meta{
  color: var(--muted);
  font-size: 12px;
  line-height: 1.55;
  max-width: 100%;
}
.sidebar-meta *{
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
}
.sidebar-meta-label{ opacity: .75; margin-bottom: 6px; }
.sidebar-meta-name{ font-weight: 800; color: var(--text); }
.sidebar-meta-email{ opacity: .9; margin-top: 2px; }
.sidebar-meta-role{ margin-top: 10px; }

/* When collapsed: hide divider + meta completely */
.sb-collapsed .sidebar-hr,
.sb-collapsed .sidebar-meta{
  display: none !important;
}

/* =========================
   NAV (STABLE GRID + ICON PILL)
   - Requires your <a> to have data-ico="D" etc
========================= */
.nav{ position:relative; z-index:1; }

/* Expanded = icon | text */
.nav a{
  position:relative;
  display:grid;
  grid-template-columns: 34px 1fr;
  align-items:center;
  gap:12px;

  padding:12px 12px;
  border-radius:14px;
  margin-bottom:8px;
  min-height:46px;

  border:1px solid transparent;
  transition: transform .14s var(--ease), box-shadow .18s var(--ease), background .18s var(--ease), border-color .18s var(--ease);
}

/* icon pill */
.nav a::before{
  content: attr(data-ico);
  width:30px; height:30px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-weight:800;
  font-size:12px;
  letter-spacing:.4px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.12);
  color: var(--text);
}

html.theme-navy .nav a::before{
  border-color: rgba(212,175,55,.35);
  color: rgba(212,175,55,.95);
  box-shadow: 0 0 0 1px rgba(212,175,55,.10) inset;
}

.nav a > span{
  font-weight:700;
  line-height:1.1;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.nav a > small{
  justify-self:end;
  color:var(--muted);
  font-size:12px;
  line-height:1.1;
  white-space:nowrap;
  padding-right: 18px;
}

.nav a:hover{
  transform: var(--lift);
  background: rgba(0,0,0,.03);
}
html.theme-navy .nav a:hover{
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.10);
  box-shadow: 0 10px 24px rgba(0,0,0,.20);
}

/* active */
.nav a.active{
  background: var(--nav-active);
  border-color: var(--border);
}
html.theme-navy .nav a.active{
  border-color: rgba(212,175,55,.30);
  box-shadow: 0 0 0 3px rgba(212,175,55,.10);
}

/* tiny gold chevron (expanded only) */
html.theme-navy .nav a.active::after{
  content:"";
  position:absolute;
  right:12px;
  top:50%;
  width:7px; height:7px;
  border-right:2px solid rgba(212,175,55,.95);
  border-bottom:2px solid rgba(212,175,55,.95);
  transform: translateY(-50%) rotate(-45deg);
  filter: drop-shadow(0 0 6px rgba(212,175,55,.35));
  pointer-events:none;
}

/* Collapsed mode: ONLY icon, no text, no chevron */
html.sb-collapsed .nav a{
  grid-template-columns: 1fr;
  justify-items:center;
  padding:12px 8px;
  min-height:44px;
}
html.sb-collapsed .nav a > span,
html.sb-collapsed .nav a > small{
  display:none !important;
}
html.sb-collapsed .nav a::after{
  display:none !important;
}

/* =========================
   MAIN CARD + KPI
========================= */
.card{
  padding:16px;
  position:relative;
}

html.theme-navy .card{
  border-top: 1px solid rgba(212,175,55,.38);
}

/* KPI grid */
.grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:12px;
}

.kpi{
  padding:14px;
  border-radius:16px;
  border:1px solid var(--border);
  background: rgba(255,255,255,.60);
  position:relative;
  overflow:hidden;
  transition: transform .16s var(--ease), box-shadow .16s var(--ease), border-color .16s var(--ease);
}
.kpi:hover{
  transform: var(--lift);
  box-shadow: 0 14px 34px rgba(0,0,0,.10);
}

html.theme-navy .kpi{
  background: rgba(255,255,255,.05);
  border-color: rgba(255,255,255,.10);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
}
html.theme-navy .kpi:hover{
  border-color: rgba(212,175,55,.22);
  box-shadow:
    0 18px 46px rgba(0,0,0,.42),
    0 0 0 3px rgba(212,175,55,.10),
    inset 0 1px 0 rgba(255,255,255,.06);
}

/* thin gold top line in KPI (navy) */
html.theme-navy .kpi::before{
  content:"";
  position:absolute;
  left:12px; right:12px; top:10px;
  height:1px;
  background: rgba(212,175,55,.22);
  border-radius:999px;
  pointer-events:none;
}

.kpi .n{ font-size:22px; font-weight:800; letter-spacing:.2px; }
.kpi .l{ font-size:12px; color:var(--muted); }

/* =========================
   TYPO
========================= */
.h1{ font-size:22px; margin:0 0 10px; }
.muted{ color:var(--muted); }

/* =========================
   TABLE
========================= */
.table{
  width:100%;
  border-collapse:collapse;
}
.table th,.table td{
  text-align:left;
  padding:12px 10px;
  border-bottom:1px solid var(--border);
  font-size:14px;
}
.table th{ color:var(--muted); font-weight:700; }

html.theme-navy .table th,
html.theme-navy .table td{
  border-bottom:1px solid rgba(255,255,255,.08);
}

.table tr:hover td{ background: rgba(0,0,0,.02); }
html.theme-navy .table tr:hover td{ background: rgba(255,255,255,.04); }

/* =========================
   BUTTONS + FORMS
========================= */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid var(--border);
  background:var(--btn-bg);
  color:var(--btn-text);
  cursor:pointer;
  font-weight:900;
  letter-spacing:.2px;
  transition: transform .14s var(--ease), box-shadow .18s var(--ease), opacity .18s var(--ease), border-color .18s var(--ease);
}
.btn:hover{ transform: var(--lift); box-shadow: 0 12px 28px rgba(0,0,0,.12); }
.btn:active{ transform: translateY(0px); opacity:.96; }

.btn.secondary{
  background:transparent;
  color:var(--text);
}
html.theme-navy .btn.secondary{
  border-color: rgba(212,175,55,.18);
  background: rgba(255,255,255,.05);
}

.btn:disabled{ opacity:.6; cursor:not-allowed; }

.input, select{
  width:100%;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid var(--input-border);
  background: var(--input-bg);
  outline:none;
  color: var(--text);
  transition: box-shadow .16s var(--ease), border-color .16s var(--ease), transform .12s var(--ease);
}
.input:hover, select:hover{
  transform: translateY(-.5px);
}
.input:focus, select:focus{
  border-color: rgba(212,175,55,.55);
  box-shadow: 0 0 0 4px var(--ring);
  transform: translateY(-.5px);
}

/* Keep dropdown options readable */
select option{ color:#0e0f12; }

.form-row{ display:grid; grid-template-columns: 1fr 1fr; gap:12px; }
.form-row3{ display:grid; grid-template-columns: 1fr 1fr 1fr; gap:12px; }
label{ font-size:12px; color:var(--muted); display:block; margin-bottom:6px; }

/* =========================
   ALERTS
========================= */
.alert{
  padding:12px 14px;
  border-radius:14px;
  border:1px solid var(--border);
  margin-bottom:12px;
}
.alert.ok{ background: rgba(0,0,0,.06); }
.alert.err{ background: rgba(255,0,0,.06); }
html.theme-navy .alert.ok{ background: rgba(255,255,255,.06); }
html.theme-navy .alert.err{ background: rgba(255,0,0,.12); }

.footer-actions{ display:flex; gap:10px; margin-top:14px; }

/* =========================
   RESPONSIVE
========================= */
@media (max-width: 980px){
  .layout{ grid-template-columns:1fr; }
  .grid{ grid-template-columns: repeat(2, 1fr); }
  .sidebar{ position:relative; max-height:none; }
}

/* =========================
   Ritremis Public Funnel (Premium)
========================= */

.rr-public{
  color: var(--text, #eef2ff);
  background: var(--bg, #050816);
}
.rr-wrap{ width:min(1120px, calc(100% - 44px)); margin:0 auto; }

/* HERO */
.rr-hero{
  position:relative;
  overflow:hidden;
  padding: 34px 0 26px;
}
.rr-hero--premium{
  background: radial-gradient(1100px 700px at 70% 20%, rgba(212,175,55,.08), rgba(0,0,0,0) 60%),
              linear-gradient(135deg, #020125 0%, #03194A 55%, #020125 100%);
}

/* CSS “photo-like” depth layer (no images) */
.rr-hero--premium::before{
  content:"";
  position:absolute;
  inset:-120px;
  z-index:0;
  pointer-events:none;

  background:
    radial-gradient(1000px 700px at 18% 35%, rgba(0,0,0,.55), rgba(0,0,0,0) 58%),
    radial-gradient(800px 600px at 85% 30%, rgba(0,0,0,.40), rgba(0,0,0,0) 62%),
    repeating-linear-gradient(90deg,
      rgba(255,255,255,.04) 0 1px,
      rgba(255,255,255,0) 1px 26px),
    repeating-linear-gradient(0deg,
      rgba(255,255,255,.02) 0 1px,
      rgba(255,255,255,0) 1px 36px),
    linear-gradient(90deg, rgba(0,0,0,.55), rgba(0,0,0,.12) 55%, rgba(0,0,0,.50));

  opacity:.28;
  transform: translate3d(var(--rr-bg-x,0px), var(--rr-bg-y,0px), 0);
}

/* Geometric navy panels + gold edges + wire lines */
.rr-hero--premium::after{
  content:"";
  position:absolute;
  inset:-120px;
  z-index:0;
  pointer-events:none;

  background:
    conic-gradient(from 210deg at 16% 22%,
      rgba(2,11,45,0) 0 18deg,
      rgba(2,11,45,.78) 18deg 52deg,
      rgba(1,40,90,.92) 52deg 86deg,
      rgba(2,11,45,.74) 86deg 124deg,
      rgba(2,11,45,0) 124deg 360deg),

    conic-gradient(from 235deg at 23% 48%,
      rgba(2,11,45,0) 0 20deg,
      rgba(2,11,45,.80) 20deg 62deg,
      rgba(1,35,95,.95) 62deg 94deg,
      rgba(2,11,45,.72) 94deg 134deg,
      rgba(2,11,45,0) 134deg 360deg),

    conic-gradient(from 230deg at 13% 74%,
      rgba(2,11,45,0) 0 22deg,
      rgba(2,11,45,.80) 22deg 66deg,
      rgba(1,26,80,.96) 66deg 98deg,
      rgba(2,11,45,.72) 98deg 140deg,
      rgba(2,11,45,0) 140deg 360deg),

    linear-gradient(128deg,
      rgba(212,175,55,0) 0 31%,
      rgba(212,175,55,.22) 31% 31.6%,
      rgba(212,175,55,0) 31.6% 100%),
    linear-gradient(128deg,
      rgba(212,175,55,0) 0 45%,
      rgba(212,175,55,.16) 45% 45.5%,
      rgba(212,175,55,0) 45.5% 100%),
    linear-gradient(128deg,
      rgba(212,175,55,0) 0 63%,
      rgba(212,175,55,.14) 63% 63.4%,
      rgba(212,175,55,0) 63.4% 100%),

    repeating-linear-gradient(-18deg,
      rgba(212,175,55,0) 0 10px,
      rgba(212,175,55,.14) 10px 12px,
      rgba(212,175,55,0) 12px 22px),

    radial-gradient(1200px 850px at 70% 30%, rgba(0,0,0,0), rgba(0,0,0,.46));

  opacity: .92;
  mix-blend-mode: screen;
  transform: translate3d(var(--rr-bg-x,0px), var(--rr-bg-y,0px), 0);
}

/* keep content above layers */
.rr-hero > .rr-wrap{ position:relative; z-index:1; }

.rr-topline{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin-bottom: 26px;
}

.rr-logo{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight: 900;
  letter-spacing: .2px;
}
.rr-mark{
  width:36px; height:36px;
  border-radius: 14px;
  display:grid;
  place-items:center;
  background: rgba(212,175,55,.92);
  color: #0b0f1f;
  box-shadow: 0 10px 28px rgba(212,175,55,.18), 0 0 0 4px rgba(212,175,55,.08);
}
.rr-word{ font-size: 15px; }
.rr-pill{
  font-size: 12px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(212,175,55,.22);
  background: rgba(255,255,255,.06);
  color: rgba(212,175,55,.92);
}

.rr-nav{ display:flex; gap:10px; align-items:center; flex-wrap:wrap; }
.rr-nav a{
  opacity:.82;
  padding: 8px 10px;
  border-radius: 12px;
  border: 1px solid transparent;
}
.rr-nav a:hover{
  opacity: 1;
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.10);
}

.rr-heroGrid{
  display:grid;
  grid-template-columns: 1.08fr .92fr;
  gap: 22px;
  align-items: start;
}
@media (max-width: 980px){
  .rr-heroGrid{ grid-template-columns:1fr; }
}

.rr-kicker{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  width: fit-content;
  color: rgba(231,237,255,.90);
}
.rr-kickerDot{
  width:10px; height:10px;
  border-radius:999px;
  background: rgba(212,175,55,.92);
  box-shadow: 0 0 20px rgba(212,175,55,.45);
}

.rr-hero h1{
  font-size: clamp(34px, 4.4vw, 56px);
  line-height: 1.02;
  margin: 12px 0 12px;
  letter-spacing: -.6px;
}
.rr-sub{
  font-size: 16px;
  opacity: .85;
  margin: 0 0 16px;
  max-width: 56ch;
}

.rr-ctaRow{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  align-items:center;
  margin: 16px 0 12px;
}
.rr-ctaRow--center{ justify-content:center; }

.rr-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding: 11px 16px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
  color: #0b0f1f;
  background: linear-gradient(135deg, rgba(212,175,55,.98), rgba(168,126,32,.92));
  box-shadow: 0 18px 44px rgba(0,0,0,.35);
  font-weight: 900;
  letter-spacing:.2px;
  transition: transform .16s var(--ease), box-shadow .16s var(--ease), filter .16s var(--ease);
}
.rr-btn:hover{ transform: translateY(-1px); filter: brightness(1.02); }
.rr-btn:active{ transform: translateY(0px) scale(.99); }

.rr-btn--ghost{
  background: rgba(255,255,255,.06);
  color: rgba(231,237,255,.92);
  border-color: rgba(212,175,55,.18);
  box-shadow: none;
}
.rr-btn--ghost:hover{
  background: rgba(255,255,255,.10);
  border-color: rgba(212,175,55,.26);
}

.rr-btn--xl{ padding: 12px 18px; border-radius: 16px; }
.rr-btn--block{ width:100%; }

.rr-btn--shine{
  position:relative;
  overflow:hidden;
}
.rr-btn--shine::after{
  content:"";
  position:absolute;
  inset:-40px;
  background: linear-gradient(120deg, transparent 0%, rgba(255,255,255,.35) 22%, transparent 45%);
  transform: translateX(-35%);
  opacity:.35;
  transition: transform .65s var(--ease), opacity .65s var(--ease);
}
.rr-btn--shine:hover::after{
  transform: translateX(35%);
  opacity:.45;
}

.rr-miniCtas{
  display:flex;
  gap:10px;
  align-items:center;
  opacity:.88;
  margin-top: 6px;
}
.rr-link{ text-decoration:none; color: rgba(231,237,255,.92); }
.rr-link:hover{ color: rgba(212,175,55,.92); }
.rr-sep{ opacity:.5; }

.rr-bullets{ display:flex; flex-direction:column; gap:10px; margin-top: 14px; }
.rr-bullet{ display:flex; gap:10px; align-items:flex-start; opacity:.86; }
.rr-dot{
  width:10px; height:10px;
  border-radius:999px;
  margin-top: 6px;
  background: rgba(212,175,55,.78);
  box-shadow: 0 0 16px rgba(212,175,55,.18);
}

/* Premium stat tiles */
.rr-stats{
  margin-top: 18px;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
@media (max-width: 980px){
  .rr-stats{ grid-template-columns: 1fr; }
}
.glassy{
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 18px;
  box-shadow: 0 18px 54px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.05);
  backdrop-filter: blur(12px);
}
.rr-stat{
  padding: 14px 14px;
  display:flex;
  gap: 12px;
  align-items:center;
}
.rr-statIco{
  width:38px; height:38px;
  border-radius: 16px;
  display:grid;
  place-items:center;
  color: rgba(212,175,55,.95);
  border: 1px solid rgba(212,175,55,.28);
  background: rgba(212,175,55,.08);
  box-shadow: 0 0 0 4px rgba(212,175,55,.06);
  font-weight: 900;
}
.rr-statN{ font-weight: 900; letter-spacing:.2px; }
.rr-statL{ font-size: 12px; color: rgba(231,237,255,.72); margin-top:2px; }

/* Cards */
.rr-card{
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 20px;
  padding: 16px;
  box-shadow: 0 24px 70px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.05);
  backdrop-filter: blur(14px);
}
.rr-card--big{ padding: 18px; }

.rr-card--wide{
  margin-top: 16px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  flex-wrap:wrap;
}

.rr-card--highlight{
  border-color: rgba(212,175,55,.20);
  box-shadow: 0 30px 90px rgba(0,0,0,.55), 0 0 0 3px rgba(212,175,55,.10), inset 0 1px 0 rgba(255,255,255,.06);
  transform: translateY(-2px);
}

.rr-cardTitle{ font-weight: 900; margin:0 0 8px; }
.rr-cardSub{ opacity:.72; margin:0 0 12px; font-size: 13px; }
.rr-cardBody{ opacity:.86; }

.rr-form{ display:flex; flex-direction:column; gap: 10px; margin-top: 10px; }
.rr-field label{ font-size:12px; opacity:.75; display:block; margin-bottom:6px; }
.rr-field input,
.rr-field select,
.rr-field textarea{
  width:100%;
  padding: 11px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.20);
  color: rgba(231,237,255,.92);
  outline:none;
  transition: transform .12s var(--ease), box-shadow .16s var(--ease), border-color .16s var(--ease);
}
.rr-field input::placeholder{ color: rgba(231,237,255,.50); }
.rr-field input:focus,
.rr-field select:focus,
.rr-field textarea:focus{
  border-color: rgba(212,175,55,.45);
  box-shadow: 0 0 0 4px rgba(212,175,55,.12);
  transform: translateY(-.5px);
}
select option{ color:#0e0f12; }

.rr-mini{ font-size: 12px; opacity: .70; margin-top: 8px; }

.rr-alert{
  padding: 10px 12px;
  border-radius: 14px;
  margin-bottom: 10px;
  border: 1px solid rgba(255,255,255,.12);
}
.rr-alert--ok{ background: rgba(255,255,255,.06); }
.rr-alert--bad{ background: rgba(255,0,0,.10); border-color: rgba(255,0,0,.18); }

.rr-heroBottom{ margin-top: 16px; padding-top: 10px; }
.rr-metrics{
  display:flex;
  gap: 22px;
  flex-wrap:wrap;
  align-items:flex-end;
}
.rr-metricN{
  font-size: 28px;
  font-weight: 900;
  letter-spacing: -.3px;
  color: rgba(212,175,55,.95);
}
.rr-metricL{
  font-size: 12px;
  opacity:.72;
  margin-top: 2px;
}

/* MAIN */
.rr-main{ padding: 18px 0 48px; }
.rr-section{ padding: 28px 0; }
.rr-section--soft{
  background: rgba(255,255,255,.03);
  border-top: 1px solid rgba(255,255,255,.06);
  border-bottom: 1px solid rgba(255,255,255,.06);
}

.rr-grid2{ display:grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.rr-grid3{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
@media (max-width: 920px){
  .rr-grid2{ grid-template-columns:1fr; }
  .rr-grid3{ grid-template-columns:1fr; }
}

.rr-muted{ opacity:.78; margin-top:6px; color: rgba(231,237,255,.72); }

/* Horizontal modules scroller */
.rr-hscrollHead{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap: 12px;
  margin-bottom: 10px;
}
.rr-hscrollActions{ display:flex; gap: 8px; }

.rr-iconBtn{
  width: 40px; height: 40px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  color: rgba(231,237,255,.92);
  display:grid;
  place-items:center;
  cursor:pointer;
  transition: transform .16s var(--ease), background .16s var(--ease), border-color .16s var(--ease);
}
.rr-iconBtn:hover{
  transform: translateY(-1px);
  background: rgba(255,255,255,.10);
  border-color: rgba(212,175,55,.18);
}

.rr-hscrollWrap{ position:relative; }
.rr-hscroll{
  display:flex;
  gap: 12px;
  overflow-x: auto;
  padding: 6px 4px 12px;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
}
.rr-hscroll::-webkit-scrollbar{ height: 10px; }
.rr-hscroll::-webkit-scrollbar-thumb{
  background: rgba(212,175,55,.20);
  border-radius: 999px;
}
.rr-hscroll::-webkit-scrollbar-track{ background: transparent; }

.rr-hcard{
  min-width: 270px;
  max-width: 330px;
  flex: 0 0 auto;
  scroll-snap-align: start;
  transition: transform .18s var(--ease), border-color .18s var(--ease), background .18s var(--ease);
}
.rr-hcard:hover{
  transform: translateY(-2px);
  border-color: rgba(212,175,55,.18);
  background: rgba(255,255,255,.10);
}

.rr-chipRow{ display:flex; gap: 8px; flex-wrap:wrap; margin-top: 10px; }
.rr-chip{
  font-size: 12px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(212,175,55,.18);
  background: rgba(212,175,55,.08);
  color: rgba(212,175,55,.92);
  opacity: .95;
}

/* Center CTA row */
.rr-ctaRow--center{ justify-content:center; }

/* Final section */
.rr-final{ text-align:center; padding-top: 18px; }

/* FOOTER */
.rr-footer{
  padding: 28px 0;
  border-top: 1px solid rgba(255,255,255,.08);
  opacity: .92;
}
.rr-footerGrid{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 16px;
  flex-wrap:wrap;
}
.rr-footLinks{ display:flex; gap: 12px; flex-wrap:wrap; }
.rr-footLinks a{ opacity:.78; }
.rr-footLinks a:hover{ opacity:1; color: rgba(212,175,55,.92); }
.rr-logo--foot .rr-mark{ width: 30px; height: 30px; border-radius: 12px; }

/* =========================
   Scroll Reveal Animations
========================= */
.reveal{
  opacity: 0;
  transform: translateY(14px);
  transition: opacity .7s ease, transform .7s ease;
  will-change: opacity, transform;
}
.reveal.is-in{ opacity: 1; transform: translateY(0); }
.reveal[data-reveal="fade"]{ transform: none; }
.reveal[data-reveal="up"]{ transform: translateY(16px); }
.reveal[data-reveal="down"]{ transform: translateY(-16px); }
.reveal[data-reveal="left"]{ transform: translateX(18px); }
.reveal[data-reveal="right"]{ transform: translateX(-18px); }
.reveal.is-in[data-reveal="left"],
.reveal.is-in[data-reveal="right"]{ transform: translateX(0); }
@media (prefers-reduced-motion: reduce){
  .reveal,.reveal.is-in{ transition:none; transform:none; opacity:1; }
}
