/* ================================================================
   RR WEB SERVICES — rr-tools.css
   ================================================================ */

:root {
  --ink:     #0E1520;
  --ghost:   rgba(14,21,32,0.45);
  --muted:   rgba(14,21,32,0.62);
  --rule:    rgba(30,40,60,0.13);
  --mint:    #22C55E;
  --green:   #1A6B3A;
  --gold:    #D4820A;
  --amber:   #D97706;
  --orange:  #EA580C;
  --red:     #DC2626;
  --rust:    #B91C1C;
  --blue:    #1A3A6B;
  --cyan:    #0EA5E9;
  --teal:    #0D9488;
  --violet2: #7C3AED;
  --border2: rgba(30,40,60,0.08);
  --grade-a: #22C55E; --grade-b: #84CC16; --grade-c: #EAB308;
  --grade-d: #F97316; --grade-f: #EF4444;
  --h1c:#1A3A6B;--h2c:#2563EB;--h3c:#7C3AED;--h4c:#DB2777;--h5c:#D97706;--h6c:#16A34A;
  --e-exp:#1A3A6B;--e-exp2:#3B82F6;--e-auth:#7C3AED;
  --violet3:rgba(124,58,237,0.12);--green3:rgba(26,107,58,0.12);
  --gold3:rgba(212,130,10,0.12);--blue3:rgba(26,58,107,0.10);
}

/* ── Hub Hero ── */
.rr-tool-page .hero {
  background: linear-gradient(155deg,#0C1B36 0%,#0A1628 50%,#071020 100%);
  padding: calc(var(--nav-h,68px) + 48px) var(--gutter,60px) 64px;
  position: relative; overflow: hidden; text-align: center;
}
.rr-tool-page .hero::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 70% 60% at 50% 0%,rgba(212,130,10,0.10) 0%,transparent 60%);
  pointer-events:none;
}
.rr-tool-page .hero-inner { position:relative; z-index:1; max-width:720px; margin:0 auto; }
.rr-tool-page .hero-badge {
  display:inline-flex; align-items:center; gap:8px;
  font-size:10px; letter-spacing:.18em; text-transform:uppercase;
  font-weight:700; color:var(--gold); margin-bottom:20px;
}
.rr-tool-page .hero-badge-dot {
  width:6px; height:6px; border-radius:50%; background:var(--gold);
  animation:toolpulse 2.5s ease-in-out infinite;
}
@keyframes toolpulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.85)}}
.rr-tool-page .hero h1 {
  font-family:var(--font-display,'Fraunces',Georgia,serif);
  font-size:clamp(40px,5vw,64px); font-weight:900; line-height:1.05;
  letter-spacing:-.04em; color:#fff; margin-bottom:20px;
}
.rr-tool-page .hero h1 em { font-style:italic; font-weight:300; color:rgba(212,184,130,0.90); }
.rr-tool-page .hero-sub {
  font-size:17px; line-height:1.75; color:rgba(240,244,250,0.65);
  max-width:580px; margin:0 auto 36px;
}
.rr-tool-page .hero-stats { display:flex; gap:32px; justify-content:center; flex-wrap:wrap; }
.rr-tool-page .hero-stat { text-align:center; }
.rr-tool-page .hero-stat-num {
  font-family:var(--font-display,'Fraunces',Georgia,serif);
  font-size:32px; font-weight:900; letter-spacing:-.04em; color:var(--gold); line-height:1;
}
.rr-tool-page .hero-stat-lbl {
  font-size:10px; letter-spacing:.14em; text-transform:uppercase;
  color:rgba(255,255,255,0.40); margin-top:4px; font-weight:600;
}

/* ── Page wrap ── */
.rr-tool-page .page-wrap {
  max-width:1200px; margin:0 auto; padding:48px var(--gutter,60px) 80px;
}

/* ── Search bar ── */
.rr-tool-page .search-bar {
  display:flex; align-items:center; gap:12px; background:#fff;
  border:1.5px solid var(--rule); border-radius:12px; padding:14px 20px;
  margin-bottom:32px; box-shadow:0 2px 12px rgba(14,21,32,0.06);
}
.rr-tool-page .search-input {
  flex:1; border:none; outline:none;
  font-family:var(--font-body,'DM Sans',system-ui,sans-serif);
  font-size:15px; color:var(--ink); background:transparent;
}
.rr-tool-page .search-input::placeholder { color:var(--ghost); }
.rr-tool-page .search-icon { font-size:16px; flex-shrink:0; }
.rr-tool-page .search-count { font-size:12px; color:var(--ghost); white-space:nowrap; font-weight:600; }

/* ── Category tabs ── */
.rr-tool-page .cat-tabs { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:36px; }
.rr-tool-page .cat-tab {
  padding:8px 18px; border-radius:100px; border:1.5px solid var(--rule);
  background:#fff; font-family:var(--font-body,'DM Sans',system-ui,sans-serif);
  font-size:13px; font-weight:600; color:var(--muted); cursor:pointer; transition:all .2s;
}
.rr-tool-page .cat-tab:hover { border-color:var(--blue); color:var(--blue); background:rgba(26,58,107,0.04); }
.rr-tool-page .cat-tab.active { background:var(--blue); border-color:var(--blue); color:#fff; }

/* ── Featured banner ── */
.rr-tool-page .featured-banner {
  display:flex; align-items:center; justify-content:space-between; gap:24px;
  background:linear-gradient(135deg,#0C1B36 0%,#0E2248 100%);
  border-radius:16px; padding:32px 36px; margin-bottom:40px; flex-wrap:wrap;
}
.rr-tool-page .fb-eyebrow {
  font-size:10px; letter-spacing:.18em; text-transform:uppercase;
  font-weight:700; color:var(--gold); margin-bottom:8px;
}
.rr-tool-page .fb-title {
  font-family:var(--font-display,'Fraunces',Georgia,serif);
  font-size:clamp(20px,2.5vw,28px); font-weight:700; color:#fff;
  letter-spacing:-.025em; margin-bottom:8px;
}
.rr-tool-page .fb-desc { font-size:14px; color:rgba(240,244,250,0.65); line-height:1.65; margin-bottom:14px; }
.rr-tool-page .fb-pills { display:flex; gap:8px; flex-wrap:wrap; }
.rr-tool-page .fb-pill {
  font-size:11px; font-weight:600; padding:4px 12px; border-radius:100px;
  background:rgba(255,255,255,0.10); color:rgba(255,255,255,0.75);
  border:1px solid rgba(255,255,255,0.15);
}
.rr-tool-page .btn-featured {
  display:inline-flex; align-items:center; gap:8px;
  padding:13px 28px; background:var(--gold); color:#fff;
  border:none; border-radius:8px; font-size:14px; font-weight:700;
  text-decoration:none; cursor:pointer; white-space:nowrap;
  box-shadow:0 3px 14px rgba(212,130,10,0.30); transition:all .25s; flex-shrink:0;
}
.rr-tool-page .btn-featured:hover { background:#C4780A; transform:translateY(-1px); }

/* ── Category sections ── */
.rr-tool-page .cat-section { margin-bottom:48px; }
.rr-tool-page .cat-section.hidden { display:none; }
.rr-tool-page .cat-header {
  display:flex; align-items:center; gap:14px; margin-bottom:20px;
  padding-bottom:14px; border-bottom:1.5px solid var(--rule);
}
.rr-tool-page .cat-icon-wrap {
  width:42px; height:42px; border-radius:10px;
  display:flex; align-items:center; justify-content:center; font-size:20px; flex-shrink:0;
}
.rr-tool-page .cat-title {
  font-family:var(--font-display,'Fraunces',Georgia,serif);
  font-size:18px; font-weight:700; letter-spacing:-.02em; color:var(--ink);
}
.rr-tool-page .cat-subtitle { font-size:13px; color:var(--ghost); margin-top:2px; }
.rr-tool-page .cat-count {
  margin-left:auto; font-size:12px; font-weight:600; color:var(--ghost);
  background:var(--canvas-mid,#E8EBF1); padding:4px 12px; border-radius:100px;
  flex-shrink:0;
}

/* ── Tool grid ── */
.rr-tool-page .tool-grid {
  display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:16px;
}

/* ── Tool cards ── */
.rr-tool-page .tool-card {
  background:#fff; border:1.5px solid var(--rule); border-radius:14px;
  padding:22px; text-decoration:none; display:flex; flex-direction:column; gap:12px;
  transition:border-color .25s,box-shadow .25s,transform .25s;
  position:relative; overflow:hidden;
}
.rr-tool-page .tool-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--blue,#1A3A6B),var(--gold,#D4820A));
  opacity:0; transition:opacity .25s;
}
.rr-tool-page .tool-card:hover {
  border-color:rgba(26,58,107,0.25); box-shadow:0 8px 32px rgba(14,21,32,0.12);
  transform:translateY(-3px);
}
.rr-tool-page .tool-card:hover::before { opacity:1; }
.rr-tool-page .tool-card.hidden { display:none; }
.rr-tool-page .tool-card-top { display:flex; align-items:flex-start; gap:12px; }
.rr-tool-page .tool-emoji { font-size:26px; flex-shrink:0; }
.rr-tool-page .tool-name {
  font-family:var(--font-display,'Fraunces',Georgia,serif);
  font-size:16px; font-weight:700; letter-spacing:-.02em; color:var(--ink);
  line-height:1.25; margin-bottom:4px;
}
.rr-tool-page .tool-tag {
  display:inline-block; font-size:10px; font-weight:700; letter-spacing:.06em;
  padding:2px 9px; border-radius:100px;
}
.rr-tool-page .tag-seo   { background:rgba(26,107,58,0.10); color:#0e5c30; }
.rr-tool-page .tag-aeo   { background:rgba(124,58,237,0.10); color:#4a1a8a; }
.rr-tool-page .tag-ai    { background:rgba(14,165,233,0.10); color:#0369a1; }
.rr-tool-page .tag-content { background:rgba(212,130,10,0.10); color:var(--gold); }
.rr-tool-page .tag-technical { background:rgba(26,58,107,0.10); color:var(--blue); }
.rr-tool-page .tool-desc { font-size:13px; color:var(--muted); line-height:1.65; flex:1; }
.rr-tool-page .tool-footer {
  display:flex; align-items:center; justify-content:space-between;
  padding-top:12px; border-top:1px solid var(--rule); margin-top:auto;
}
.rr-tool-page .tool-checks { font-size:11px; color:var(--ghost); font-weight:500; }
.rr-tool-page .tool-cta { font-size:13px; font-weight:700; color:var(--blue); transition:color .2s; }
.rr-tool-page .tool-card:hover .tool-cta { color:var(--gold); }

/* ── How it works section ── */
.rr-tool-page .how-section {
  background:var(--canvas-mid,#E8EBF1); border-radius:16px;
  padding:40px; margin:48px 0;
}
.rr-tool-page .how-title {
  font-family:var(--font-display,'Fraunces',Georgia,serif);
  font-size:22px; font-weight:700; letter-spacing:-.025em; color:var(--ink);
  margin-bottom:28px; text-align:center;
}
.rr-tool-page .how-steps { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:20px; }
.rr-tool-page .how-step { text-align:center; }
.rr-tool-page .how-num {
  font-family:var(--font-display,'Fraunces',Georgia,serif);
  font-size:36px; font-weight:900; color:var(--gold); line-height:1; margin-bottom:8px;
}

/* ── Bottom CTA section ── */
.rr-tool-page .cta-section {
  background:linear-gradient(135deg,#0C1B36 0%,#0E2248 100%);
  border-radius:16px; padding:48px 40px; text-align:center; margin:48px 0;
}
.rr-tool-page .cta-section h2 {
  font-family:var(--font-display,'Fraunces',Georgia,serif);
  font-size:clamp(22px,2.5vw,32px); font-weight:700; color:#fff;
  letter-spacing:-.03em; margin-bottom:12px;
}
.rr-tool-page .cta-section p { font-size:15px; color:rgba(240,244,250,0.65); margin-bottom:24px; }
.rr-tool-page .cta-form { display:flex; gap:10px; justify-content:center; flex-wrap:wrap; margin-bottom:12px; }
.rr-tool-page .cta-input {
  padding:13px 18px; border-radius:8px; border:1.5px solid rgba(255,255,255,0.20);
  background:rgba(255,255,255,0.10); color:#fff; font-size:14px;
  font-family:var(--font-body,'DM Sans',system-ui,sans-serif);
  outline:none; min-width:240px; flex:1; max-width:320px;
}
.rr-tool-page .cta-input::placeholder { color:rgba(255,255,255,0.40); }
.rr-tool-page .btn-cta {
  padding:13px 28px; background:var(--gold); color:#fff; border:none;
  border-radius:8px; font-size:14px; font-weight:700; cursor:pointer;
  font-family:var(--font-body,'DM Sans',system-ui,sans-serif);
  transition:all .25s; box-shadow:0 3px 14px rgba(212,130,10,0.28);
}
.rr-tool-page .btn-cta:hover { background:#C4780A; transform:translateY(-1px); }
.rr-tool-page .cta-success { color:var(--mint); font-weight:600; display:none; }
.rr-tool-page .cta-privacy { font-size:11px; color:rgba(255,255,255,0.30); margin-top:10px; }

/* ── Hub footer ── */
.rr-tool-page .hub-footer {
  text-align:center; padding:40px 0; border-top:1px solid var(--rule);
  font-size:13px; color:var(--ghost);
}

/* ── Individual tool pages ── */
.rr-tool-wrapper {
  width:100%; background:var(--canvas,#F4F5F7);
  min-height:calc(100vh - 68px);
}
.rr-tool-wrapper .wrap {
  max-width:960px; margin:0 auto;
  padding:calc(var(--nav-h,68px) + 32px) var(--gutter,60px) 80px;
}
.rr-tool-wrapper .header {
  margin-bottom:32px; padding-bottom:24px; border-bottom:1.5px solid var(--rule);
}
.rr-tool-wrapper .header h1,
.rr-tool-wrapper .header-meta h1 {
  font-family:var(--font-display,'Fraunces',Georgia,serif);
  font-size:clamp(24px,3vw,36px); font-weight:900; letter-spacing:-.035em;
  color:var(--ink); margin-bottom:8px;
}
.rr-tool-wrapper .subtitle { font-size:15px; color:var(--muted); line-height:1.65; }
.rr-tool-wrapper .brand-pill {
  display:inline-flex; align-items:center; gap:7px;
  font-size:10px; letter-spacing:.16em; text-transform:uppercase;
  font-weight:700; color:var(--ghost); margin-bottom:10px;
}
.rr-tool-wrapper .brand-dot { width:6px; height:6px; border-radius:50%; background:var(--gold); }
.rr-tool-wrapper .version-tag { font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--ghost); font-weight:600; }
.rr-tool-wrapper .input-card {
  background:#fff; border:1.5px solid var(--rule); border-radius:14px;
  padding:28px; margin-bottom:24px;
}
.rr-tool-wrapper .field-label {
  display:block; font-size:10px; letter-spacing:.14em; text-transform:uppercase;
  font-weight:700; color:var(--ghost); margin-bottom:8px;
}
.rr-tool-wrapper .url-input,
.rr-tool-wrapper .html-input,
.rr-tool-wrapper input[type="text"],
.rr-tool-wrapper input[type="url"],
.rr-tool-wrapper textarea {
  width:100%; padding:13px 16px; background:var(--canvas,#F4F5F7);
  border:1.5px solid var(--rule); border-radius:10px;
  font-family:var(--font-body,'DM Sans',system-ui,sans-serif);
  font-size:14px; color:var(--ink); outline:none; transition:border-color .2s;
  box-sizing:border-box; margin-bottom:16px;
}
.rr-tool-wrapper input:focus,
.rr-tool-wrapper textarea:focus {
  border-color:var(--blue); box-shadow:0 0 0 3px rgba(26,58,107,0.08); background:#fff;
}
.rr-tool-wrapper .html-input { min-height:160px; resize:vertical; font-family:monospace; font-size:13px; }
.rr-tool-wrapper .field-hint { font-size:12px; color:var(--ghost); margin-bottom:8px; line-height:1.5; }
.rr-tool-wrapper .btn-run {
  display:inline-flex; align-items:center; gap:8px; padding:13px 28px;
  background:var(--gold); color:#fff; border:none; border-radius:8px;
  font-family:var(--font-body,'DM Sans',system-ui,sans-serif);
  font-size:14px; font-weight:700; cursor:pointer; transition:all .25s;
  box-shadow:0 3px 14px rgba(212,130,10,0.28);
}
.rr-tool-wrapper .btn-run:hover { background:#C4780A; box-shadow:0 8px 24px rgba(212,130,10,0.36); transform:translateY(-1px); }
.rr-tool-wrapper .btn-clear {
  display:inline-flex; align-items:center; gap:6px; padding:13px 20px;
  background:transparent; border:1.5px solid var(--rule); border-radius:8px;
  font-family:var(--font-body,'DM Sans',system-ui,sans-serif);
  font-size:13px; font-weight:500; color:var(--muted); cursor:pointer; transition:all .2s;
}
.rr-tool-wrapper .btn-clear:hover { border-color:var(--red); color:var(--red); }
.rr-tool-wrapper .input-actions { display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.rr-tool-wrapper .char-hint { font-size:12px; color:var(--ghost); margin-left:auto; }
.rr-tool-wrapper .err { color:var(--red); font-size:13px; margin-top:8px; min-height:20px; }
.rr-tool-wrapper .load-ring {
  display:none; width:28px; height:28px; border:3px solid var(--rule);
  border-top-color:var(--gold); border-radius:50%;
  animation:toolspin 0.7s linear infinite; margin:20px auto;
}
.rr-tool-wrapper .load-ring.active { display:block; }
@keyframes toolspin { to { transform:rotate(360deg); } }
.rr-tool-wrapper .how-to {
  background:rgba(26,58,107,0.04); border:1px solid rgba(26,58,107,0.12);
  border-radius:10px; padding:16px 20px; margin-bottom:24px;
  font-size:13.5px; color:var(--muted); line-height:1.65;
}
.rr-tool-wrapper .results-area { margin-top:24px; }
.rr-tool-wrapper .score-card,
.rr-tool-wrapper .result-card {
  background:#fff; border:1.5px solid var(--rule); border-radius:14px;
  padding:28px; margin-bottom:16px;
}

/* ── Related tools ── */
.rr-related-strip {
  background:var(--canvas-mid,#E8EBF1) !important;
  border-top:1.5px solid var(--rule) !important;
  font-family:var(--font-body,'DM Sans',system-ui,sans-serif) !important;
}
.rr-related-inner { max-width:960px; margin:0 auto; }

/* ── Responsive ── */
@media(max-width:900px) {
  .rr-tool-page .page-wrap { padding:36px 24px 60px; }
  .rr-tool-page .hero { padding:calc(var(--nav-h,68px) + 32px) 24px 48px; }
  .rr-tool-page .tool-grid { grid-template-columns:1fr 1fr; }
  .rr-tool-wrapper .wrap { padding:calc(var(--nav-h,68px) + 24px) 24px 60px; }
  .rr-tool-page .featured-banner { flex-direction:column; }
}
@media(max-width:600px) {
  .rr-tool-page .tool-grid { grid-template-columns:1fr; }
  .rr-tool-page .hero h1 { font-size:36px; }
  .rr-tool-page .hero-stats { gap:20px; }
  .rr-tool-wrapper .wrap { padding:calc(var(--nav-h,68px) + 16px) 18px 48px; }
  .rr-tool-page .cta-form { flex-direction:column; align-items:stretch; }
}
