/* Risk Review – matches website .modern-card + layout.css rail (see app.css) */

*{box-sizing:border-box}

body{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;line-height:1.55}
a{color:inherit;text-decoration:none}
button,input,select{font:inherit}

/* Content rail uses Tailwind `container mx-auto px-4 ... container-main-content` + layout.css (do not redefine .container here). */

/* Section nav – same sticky / blur / border language as breadcrumb bars on Features, Contact, etc. */
.rr-subnav{
  position:sticky;
  top:var(--nav-height,64px);
  z-index:40;
  width:100%;
  -webkit-backdrop-filter:blur(8px);
  backdrop-filter:blur(8px);
  background:hsl(var(--background) / 0.95);
  border-bottom:1px solid hsl(var(--border));
}
.rr-subnav-tabs{
  display:flex;
  gap:0;
  flex-wrap:nowrap;
  overflow-x:auto;
  scrollbar-width:none;
}
.rr-subnav-tabs::-webkit-scrollbar{display:none}
.rr-subnav-tabs a{
  flex:0 0 auto;
  display:flex;
  align-items:center;
  gap:6px;
  padding:10px 16px;
  font-size:0.875rem;
  font-weight:600;
  color:hsl(var(--muted-foreground));
  border-bottom:2px solid transparent;
  white-space:nowrap;
  transition:color .15s ease,background-color .15s ease,border-color .15s ease;
}
.rr-subnav-tabs a:hover{
  color:hsl(var(--accent));
  background:hsl(var(--accent) / 0.08);
  border-bottom-color:hsl(var(--accent) / 0.35);
}
.rr-subnav-tabs a.active{
  color:hsl(var(--accent));
  border-bottom-color:hsl(var(--accent));
  background:hsl(var(--accent) / 0.1);
}

/* Mirror .modern-card from app.css (rounded-lg, card bg, border-border/50, shadow-sm, transition) */
main.risk-review-main .hero-card,
main.risk-review-main .hero-side,
main.risk-review-main .section-card{
  border-radius:0.75rem;
  border-width:1px;
  border-style:solid;
  border-color:hsl(var(--border) / 0.5);
  background-color:hsl(var(--card));
  color:hsl(var(--card-foreground));
  box-shadow:0 1px 2px 0 rgb(0 0 0 / 0.05);
  transition-property:box-shadow,transform,border-color;
  transition-duration:0.3s;
  transition-timing-function:cubic-bezier(0.4,0,0.2,1);
}
main.risk-review-main .hero-card:hover,
main.risk-review-main .hero-side:hover,
main.risk-review-main .section-card:hover{
  box-shadow:0 10px 15px -3px rgb(0 0 0 / 0.1),0 4px 6px -4px rgb(0 0 0 / 0.1);
}
.dark main.risk-review-main .hero-card:hover,
.dark main.risk-review-main .hero-side:hover,
.dark main.risk-review-main .section-card:hover{
  box-shadow:0 10px 15px -3px rgb(0 0 0 / 0.35),0 4px 6px -4px rgb(0 0 0 / 0.25);
}

/* Eyebrow – brand accent (orange), same family as accent/10 usage sitewide */
.kicker{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 12px;
  border-radius:9999px;
  border:1px solid hsl(var(--accent) / 0.35);
  background:hsl(var(--accent) / 0.1);
  color:hsl(var(--accent));
  font-size:0.75rem;
  font-weight:700;
  letter-spacing:0.08em;
  text-transform:uppercase;
}

main.risk-review-main h1{
  font-size:clamp(1.875rem,4vw,3rem);
  line-height:1.1;
  letter-spacing:-0.025em;
  font-weight:700;
  margin:0.75rem 0;
  color:hsl(var(--foreground));
}
.hero p{
  margin:0;
  color:hsl(var(--muted-foreground));
  font-size:1rem;
  line-height:1.65;
  max-width:68ch;
}

/* Hero spacing – matches main pages (pt-8 / md:pt-10 rhythm) */
main.risk-review-main section.hero{
  padding-top:2rem;
  padding-bottom:0.5rem;
}
@media (min-width:768px){
  main.risk-review-main section.hero{
    padding-top:2.5rem;
  }
}
.hero-grid{
  display:grid;
  grid-template-columns:1.4fr 0.9fr;
  gap:1.5rem;
  align-items:stretch;
}
.hero-card,.hero-side{padding:1.5rem}
@media (min-width:640px){
  .hero-card,.hero-side{padding:2rem}
}

.hero-stats{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:0.75rem;
  margin-top:1.25rem;
}
.stat{
  padding:0.875rem 1rem;
  border-radius:0.5rem;
  border:1px solid hsl(var(--border));
  background:hsl(var(--muted) / 0.25);
}
.stat-label{
  display:block;
  font-size:0.68rem;
  text-transform:uppercase;
  letter-spacing:0.08em;
  color:hsl(var(--muted-foreground));
  font-weight:700;
  margin-bottom:0.35rem;
}
.stat-value{
  display:block;
  font-size:0.9375rem;
  font-weight:600;
  color:hsl(var(--foreground));
}

.hero-side h2{
  margin:0 0 0.5rem;
  font-size:1.125rem;
  font-weight:600;
  color:hsl(var(--foreground));
}
.hero-side ul{
  padding-left:1.1rem;
  margin:0;
  color:hsl(var(--muted-foreground));
  font-size:0.9375rem;
}

.module-nav{padding:0.5rem 0 0}
.module-tabs{
  display:flex;
  gap:0.75rem;
  flex-wrap:wrap;
}
.module-tabs a{
  flex:1 1 220px;
  padding:1rem 1.125rem;
  border-radius:0.75rem;
  border-width:1px;
  border-style:solid;
  border-color:hsl(var(--border) / 0.5);
  background-color:hsl(var(--card));
  color:hsl(var(--card-foreground));
  min-width:0;
  box-shadow:0 1px 2px 0 rgb(0 0 0 / 0.05);
  transition:border-color .15s ease,background-color .15s ease,box-shadow .15s ease;
}
.module-tabs a:hover{
  border-color:hsl(var(--accent) / 0.35);
  background:hsl(var(--accent) / 0.06);
}
.module-tabs .label{display:block;font-weight:600;color:hsl(var(--foreground))}
.module-tabs .sub{display:block;margin-top:0.35rem;font-size:0.875rem;color:hsl(var(--muted-foreground))}
.module-tabs a.active{
  border-color:hsl(var(--accent) / 0.45);
  background:hsl(var(--accent) / 0.1);
  box-shadow:0 1px 2px 0 rgb(0 0 0 / 0.05);
}

.section{padding:1.25rem 0}
.section-head{
  display:flex;
  justify-content:space-between;
  gap:1rem;
  align-items:flex-end;
  margin-bottom:1rem;
}
.section-head h2{
  margin:0;
  font-size:1.375rem;
  font-weight:600;
  letter-spacing:-0.02em;
  color:hsl(var(--foreground));
}
.section-head p{
  margin:0.35rem 0 0;
  color:hsl(var(--muted-foreground));
  max-width:70ch;
  font-size:0.9375rem;
}

.section-card{padding:1.5rem}
@media (min-width:640px){
  .section-card{padding:2rem}
}

/* Inner cards – muted surface, same radius family as rounded-lg */
.card-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}
main.risk-review-main .card{
  background:hsl(var(--muted) / 0.2);
  border:1px solid hsl(var(--border) / 0.6);
  border-radius:0.5rem;
  padding:1rem;
}
main.risk-review-main .card h3,
main.risk-review-main .card h4{
  margin:0 0 0.5rem;
  font-size:1rem;
  font-weight:600;
  color:hsl(var(--foreground));
}
main.risk-review-main .card p{margin:0;color:hsl(var(--muted-foreground));font-size:0.875rem}

.label{
  display:block;
  font-size:0.72rem;
  text-transform:uppercase;
  letter-spacing:0.08em;
  color:hsl(var(--muted-foreground));
  font-weight:700;
  margin-bottom:0.5rem;
}
select,input{
  width:100%;
  padding:0.625rem 0.875rem;
  border-radius:0.5rem;
  border:1px solid hsl(var(--border));
  background:hsl(var(--background));
  color:hsl(var(--foreground));
}

.analysis-layout{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.option-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:0.625rem}
.option-card{
  padding:0.75rem 0.875rem;
  border-radius:0.5rem;
  border:1px solid hsl(var(--border));
  background:hsl(var(--muted) / 0.15);
  cursor:pointer;
  transition:0.15s ease;
  font-weight:600;
  color:hsl(var(--foreground));
  font-size:0.875rem;
}
.option-card:hover{
  transform:translateY(-1px);
  border-color:hsl(var(--accent) / 0.35);
  background:hsl(var(--muted) / 0.3);
}
.option-card.active{
  border-color:hsl(var(--accent) / 0.5);
  background:hsl(var(--accent) / 0.12);
  box-shadow:0 1px 2px 0 rgb(0 0 0 / 0.05);
}

.action-row{display:flex;justify-content:flex-start;gap:0.625rem;margin-top:1rem;flex-wrap:wrap}

/* Primary CTA – same intent as bg-primary buttons sitewide */
.primary-btn,.secondary-btn,.ghost-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:0.5rem;
  padding:0.75rem 1.125rem;
  border-radius:0.5rem;
  font-weight:600;
  font-size:0.875rem;
  border:1px solid transparent;
  cursor:pointer;
  transition:opacity .15s ease,background-color .15s ease,border-color .15s ease;
}
.primary-btn{
  background:hsl(var(--primary));
  color:hsl(var(--primary-foreground));
  box-shadow:0 1px 2px 0 rgb(0 0 0 / 0.06);
}
.primary-btn:hover{opacity:0.95}
.secondary-btn{
  background:transparent;
  color:hsl(var(--primary));
  border-color:hsl(var(--primary) / 0.35);
}
.secondary-btn:hover{background:hsl(var(--primary) / 0.08)}
.ghost-btn{
  background:transparent;
  color:hsl(var(--muted-foreground));
  border-color:hsl(var(--border));
}
.ghost-btn:hover{
  background:hsl(var(--muted) / 0.35);
  color:hsl(var(--foreground));
}

.result-hero{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}
.result-card{
  padding:1.25rem;
  border-radius:0.5rem;
  border:1px solid hsl(var(--border) / 0.6);
  background:hsl(var(--muted) / 0.15);
}
.score{
  font-size:2.75rem;
  font-weight:800;
  line-height:1;
  letter-spacing:-0.04em;
  color:hsl(var(--foreground));
}
.score-label{margin-top:0.5rem;color:hsl(var(--muted-foreground));font-weight:600;font-size:0.875rem}
.score-band{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:3rem;
  padding:0.5rem 1rem;
  border-radius:9999px;
  font-weight:700;
  font-size:0.9375rem;
  border:1px solid hsl(var(--border));
  background:hsl(var(--muted) / 0.2);
  color:hsl(var(--foreground));
}

.band-low{color:#16a34a;border-color:rgba(34,197,94,.35);background:rgba(34,197,94,.12)}
.band-moderate{color:#d97706;border-color:rgba(245,158,11,.35);background:rgba(245,158,11,.14)}
.band-high,.band-critical{color:#dc2626;border-color:rgba(239,68,68,.35);background:rgba(239,68,68,.12)}
.dark .band-low{color:#4ade80}
.dark .band-moderate{color:#fbbf24}
.dark .band-high,.dark .band-critical{color:#f87171}

.result-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}
.result-grid ul{margin:0;padding-left:1.1rem;color:hsl(var(--muted-foreground));font-size:0.875rem}

.system-state{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:0.625rem}
.state-chip{
  padding:0.75rem 1rem;
  border-radius:0.5rem;
  border:1px solid hsl(var(--border) / 0.6);
  background:hsl(var(--card));
  box-shadow:0 1px 2px 0 rgb(0 0 0 / 0.04);
}
.state-chip strong{display:block;color:hsl(var(--foreground));font-size:0.875rem}
.state-chip span{display:block;margin-top:0.35rem;color:hsl(var(--muted-foreground));font-size:0.8125rem}

@media (max-width:1024px){
  .hero-grid,.analysis-layout,.card-grid,.result-grid,.system-state{grid-template-columns:1fr 1fr}
  .hero-side{order:2}
}
@media (max-width:720px){
  .hero-stats,.hero-grid,.card-grid,.analysis-layout,.result-grid,.result-hero,.system-state{grid-template-columns:1fr}
  .module-tabs a{flex:1 1 100%}
  .option-grid{grid-template-columns:1fr}
  .score{font-size:2.25rem}
}

/* Workflow guidance: hub + dynamic progress line + compute hints */
.rr-workflow-guide .section-head{margin-bottom:0.75rem}
.rr-value-delivered{
  margin:0 0 0.75rem;
  padding:0.85rem 1rem;
  border-radius:0.5rem;
  border:1px solid hsl(var(--border) / 0.65);
  background:hsl(var(--muted) / 0.18);
}
.rr-value-delivered h3{
  margin:0 0 0.5rem;
  font-size:1rem;
  font-weight:700;
  color:hsl(var(--foreground));
}
.rr-value-delivered ul{
  margin:0;
  padding-left:1.15rem;
  color:hsl(var(--muted-foreground));
  font-size:0.9375rem;
  line-height:1.55;
}
.rr-value-delivered li{margin:0.35rem 0}

.rr-progress-checklist{
  margin:0 0 1rem;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:0.75rem;
}
.rr-progress-step{
  border-radius:0.5rem;
  border:1px solid hsl(var(--border) / 0.6);
  background:hsl(var(--muted) / 0.18);
  padding:0.85rem 0.9rem;
  display:flex;
  flex-direction:column;
  gap:0.35rem;
  min-width:0;
}
.rr-progress-step strong{font-size:0.9rem;color:hsl(var(--foreground))}
.rr-progress-step .meta{font-size:0.8125rem;color:hsl(var(--muted-foreground))}
.rr-progress-step .status{font-size:0.75rem;font-weight:700;letter-spacing:0.06em;text-transform:uppercase}
.rr-progress-step.completed{
  border-color:hsl(var(--accent) / 0.35);
  background:hsl(var(--accent) / 0.08);
}
.rr-progress-step.completed .status{color:hsl(var(--accent))}
.rr-progress-step.pending .status{color:hsl(var(--muted-foreground))}
.rr-progress-step a{color:hsl(var(--accent));text-decoration:underline;font-weight:700}

@media (max-width:720px){
  .rr-progress-checklist{grid-template-columns:1fr;gap:0.6rem}
}

.rr-status-banner{
  margin:0;
  padding:0.65rem 1rem;
  border-radius:0.5rem;
  border:1px solid hsl(var(--primary) / 0.35);
  background:hsl(var(--primary) / 0.08);
  color:hsl(var(--foreground));
  font-size:0.8125rem;
  line-height:1.5;
}
.rr-status-banner p{margin:0;max-width:72ch;color:hsl(var(--muted-foreground))}
.rr-status-banner strong{color:hsl(var(--foreground))}
.rr-status-banner a{color:hsl(var(--accent));text-decoration:underline;font-weight:700}
.rr-status-banner a:hover{opacity:0.9}
.rr-workflow-steps{
  margin:0 0 0.75rem;
  padding-left:1.25rem;
  color:hsl(var(--muted-foreground));
  font-size:0.9375rem;
  line-height:1.55;
}
.rr-workflow-steps li{margin:0.35rem 0}
.rr-workflow-footnote{
  margin:0;
  font-size:0.8125rem;
  color:hsl(var(--muted-foreground));
  max-width:68ch;
}
.rr-progress-summary{
  margin:0.5rem 0 0;
  font-size:0.875rem;
  line-height:1.5;
  color:hsl(var(--muted-foreground));
  max-width:68ch;
}
.rr-compute-hint{
  margin:0.75rem 0 0;
  font-size:0.8125rem;
  line-height:1.45;
  color:hsl(var(--muted-foreground));
  max-width:68ch;
}

.rr-tool-context{display:flex;flex-direction:column;gap:0.5rem}
.rr-progress-strip{
  margin:0;
  padding:0.65rem 1rem;
  border-radius:0.5rem;
  border:1px solid hsl(var(--border) / 0.65);
  background:hsl(var(--muted) / 0.2);
}
.rr-progress-strip .rr-progress-summary{margin:0;font-size:0.8125rem}
.rr-workflow-banner{
  margin:0;
  padding:0.65rem 1rem;
  border-radius:0.5rem;
  border:1px solid hsl(var(--accent) / 0.35);
  background:hsl(var(--accent) / 0.08);
  color:hsl(var(--foreground));
  font-size:0.8125rem;
  line-height:1.5;
}
.rr-workflow-banner p{margin:0;max-width:72ch;color:hsl(var(--muted-foreground))}
.rr-workflow-banner strong{color:hsl(var(--foreground))}
.rr-workflow-banner a{color:hsl(var(--accent));text-decoration:underline;font-weight:600}
.rr-workflow-banner a:hover{opacity:0.9}
.rr-assessment-note{
  margin:0.5rem 0 0;
  font-size:0.8125rem;
  line-height:1.45;
  color:hsl(var(--muted-foreground));
  max-width:68ch;
}
.hub-start-cta{margin-top:1rem}
