/* ==========================================================
   guide.css — Guide du Débutant (self-contained)
   BloodStreet RP
   ========================================================== */

@import url('../base/tokens.css');
@import url('../base/reset.css');
@import url('../base/animations.css');
@import url('../layout/header.css');
@import url('../layout/footer.css');
@import url('../components/buttons.css');

/* ==========================================================
   HERO
   ========================================================== */

.guide__hero {
  background: linear-gradient(
    135deg,
    #0d0d0d 0%,
    var(--color-red-deeper) 55%,
    var(--bg-body) 100%
  );
  padding: calc(var(--header-height) + var(--space-16)) 0 var(--space-16);
  text-align: center;
}

.guide__hero-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  background: rgba(177, 0, 0, 0.15);
  border: 1px solid rgba(177, 0, 0, 0.4);
  color: var(--color-red);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  padding: var(--space-1) var(--space-4);
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: var(--space-5);
}

.guide__hero-title {
  font-size: clamp(2rem, 6vw, 4rem);
  font-weight: var(--fw-black);
  color: var(--text-white);
  margin-bottom: var(--space-4);
  line-height: 1.1;
}

.guide__hero-title span {
  color: var(--color-red);
}

.guide__hero-sub {
  font-size: var(--fs-md);
  color: rgba(255, 255, 255, 0.6);
  max-width: 560px;
  margin-inline: auto;
  line-height: 1.7;
}

/* ==========================================================
   ARTICLE CONTAINER
   ========================================================== */

.guide__article {
  padding: var(--space-16) 0 var(--space-24);
  max-width: 860px;
}

/* ==========================================================
   TABLE OF CONTENTS
   ========================================================== */

.guide__toc {
  background: var(--bg-card);
  border: var(--border-subtle);
  border-left: 3px solid var(--color-red);
  border-radius: 0 var(--radius-lg) var(--radius-lg) 0;
  padding: var(--space-6) var(--space-8);
  margin-bottom: var(--space-16);
}

.guide__toc-title {
  font-family: var(--font-heading);
  font-size: var(--fs-base);
  font-weight: var(--fw-bold);
  color: var(--text-white);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: var(--space-4);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.guide__toc-title i {
  color: var(--color-red);
}

.guide__toc-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  list-style: none;
  counter-reset: toc-counter;
}

.guide__toc-list li {
  counter-increment: toc-counter;
  display: flex;
  align-items: baseline;
  gap: var(--space-3);
}

.guide__toc-list li::before {
  content: counter(toc-counter, upper-roman);
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  color: var(--color-red);
  opacity: 0.7;
  min-width: 1.5rem;
  text-align: right;
  flex-shrink: 0;
}

.guide__toc-list a {
  font-size: var(--fs-sm);
  color: var(--text-secondary);
  text-decoration: none;
  transition: color var(--transition-fast);
  line-height: 1.4;
}

.guide__toc-list a:hover {
  color: var(--color-red);
}

/* ==========================================================
   SECTIONS
   ========================================================== */

.guide__section {
  margin-bottom: var(--space-16);
  padding-bottom: var(--space-16);
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  scroll-margin-top: calc(var(--header-height) + var(--space-8));
}

.guide__section:last-of-type {
  border-bottom: none;
}

.guide__section-header {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
  margin-bottom: var(--space-8);
}

.guide__section-num {
  font-family: var(--font-heading);
  font-size: var(--fs-4xl);
  font-weight: var(--fw-black);
  color: var(--color-red);
  opacity: 0.2;
  line-height: 1;
  flex-shrink: 0;
}

.guide__section-title {
  font-size: var(--fs-2xl);
  font-weight: var(--fw-bold);
  color: var(--text-white);
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
}

.guide__section-title i {
  color: var(--color-red);
}

/* ==========================================================
   CONTENT
   ========================================================== */

.guide__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.guide__content p {
  color: var(--text-secondary);
  line-height: 1.8;
  font-size: var(--fs-base);
}

.guide__lead {
  font-size: var(--fs-md) !important;
  color: var(--text-primary) !important;
  font-weight: var(--fw-medium);
  line-height: 1.75 !important;
}

.guide__subsection {
  font-size: var(--fs-lg);
  font-weight: var(--fw-semibold);
  color: var(--text-white);
  padding-bottom: var(--space-2);
  border-bottom: 2px solid rgba(177, 0, 0, 0.3);
  margin-top: var(--space-4);
}

.guide__list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding-left: var(--space-4);
}

.guide__list li {
  color: var(--text-secondary);
  font-size: var(--fs-sm);
  line-height: 1.6;
  position: relative;
}

.guide__list li::before {
  content: '›';
  position: absolute;
  left: calc(-1 * var(--space-4));
  color: var(--color-red);
  font-weight: var(--fw-bold);
}

/* ==========================================================
   CALLOUT BOXES
   ========================================================== */

/* Tip — vert */
.guide__tip {
  background: rgba(34, 197, 94, 0.07);
  border: 1px solid rgba(34, 197, 94, 0.25);
  border-radius: var(--radius-lg);
  padding: var(--space-5) var(--space-6);
  display: flex;
  gap: var(--space-4);
  align-items: flex-start;
}

.guide__tip i {
  color: #22c55e;
  font-size: var(--fs-lg);
  flex-shrink: 0;
  margin-top: 2px;
}

.guide__tip-body strong {
  display: block;
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: #22c55e;
  margin-bottom: var(--space-1);
}

.guide__tip-body p {
  font-size: var(--fs-sm) !important;
  color: rgba(255, 255, 255, 0.6) !important;
  line-height: 1.6 !important;
  margin: 0;
}

/* Warning — orange */
.guide__warning {
  background: rgba(251, 146, 60, 0.07);
  border: 1px solid rgba(251, 146, 60, 0.25);
  border-radius: var(--radius-lg);
  padding: var(--space-5) var(--space-6);
  display: flex;
  gap: var(--space-4);
  align-items: flex-start;
}

.guide__warning i {
  color: #fb923c;
  font-size: var(--fs-lg);
  flex-shrink: 0;
  margin-top: 2px;
}

.guide__warning-body strong {
  display: block;
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: #fb923c;
  margin-bottom: var(--space-1);
}

.guide__warning-body p {
  font-size: var(--fs-sm) !important;
  color: rgba(255, 255, 255, 0.6) !important;
  line-height: 1.6 !important;
  margin: 0;
}

/* Note — rouge */
.guide__note {
  background: linear-gradient(135deg, rgba(177, 0, 0, 0.08), rgba(177, 0, 0, 0.04));
  border: 1px solid rgba(177, 0, 0, 0.3);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.guide__note-header {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.guide__note-header i {
  font-size: var(--fs-xl);
  color: var(--color-red);
}

.guide__note-title {
  font-size: var(--fs-lg);
  font-weight: var(--fw-bold);
  color: var(--text-white);
}

.guide__note p {
  font-size: var(--fs-sm) !important;
  color: var(--text-secondary) !important;
  line-height: 1.7 !important;
}

/* ==========================================================
   STEP LIST
   ========================================================== */

.guide__steps {
  display: flex;
  flex-direction: column;
  gap: 0;
  position: relative;
}

.guide__step {
  display: flex;
  gap: var(--space-5);
  align-items: flex-start;
  position: relative;
  padding-bottom: var(--space-8);
}

/* Ligne verticale de connexion */
.guide__step:not(:last-child)::after {
  content: '';
  position: absolute;
  left: 19px;
  top: 44px;
  bottom: 0;
  width: 2px;
  background: linear-gradient(to bottom, rgba(177, 0, 0, 0.4), rgba(177, 0, 0, 0.05));
}

.guide__step-num {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-full);
  background: var(--gradient-red);
  color: var(--text-white);
  font-family: var(--font-heading);
  font-size: var(--fs-sm);
  font-weight: var(--fw-black);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  box-shadow: var(--shadow-red);
  position: relative;
  z-index: var(--z-base);
}

.guide__step-body {
  flex: 1;
  padding-top: var(--space-1);
}

.guide__step-title {
  font-size: var(--fs-md);
  font-weight: var(--fw-semibold);
  color: var(--text-white);
  margin-bottom: var(--space-2);
}

.guide__step-text {
  font-size: var(--fs-sm);
  color: var(--text-secondary);
  line-height: 1.7;
}

/* ==========================================================
   JOB CARDS
   ========================================================== */

.guide__jobs-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}

.guide__job-card {
  background: var(--bg-card);
  border: var(--border-subtle);
  border-radius: var(--radius-lg);
  padding: var(--space-5) var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  transition: transform var(--transition-base), border-color var(--transition-base);
}

.guide__job-card:hover {
  transform: translateY(-3px);
}

.guide__job-card--legal {
  border-top: 3px solid rgba(34, 197, 94, 0.5);
}

.guide__job-card--legal:hover {
  border-color: rgba(34, 197, 94, 0.7);
}

.guide__job-card--illegal {
  border-top: 3px solid rgba(177, 0, 0, 0.5);
}

.guide__job-card--illegal:hover {
  border-color: var(--color-red);
}

.guide__job-card--semi {
  border-top: 3px solid rgba(251, 146, 60, 0.5);
}

.guide__job-card--semi:hover {
  border-color: rgba(251, 146, 60, 0.7);
}

.guide__job-card-header {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.guide__job-card-icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--fs-lg);
  flex-shrink: 0;
}

.guide__job-card--legal   .guide__job-card-icon { background: rgba(34, 197, 94, 0.12);  color: #22c55e; }
.guide__job-card--illegal .guide__job-card-icon { background: rgba(177, 0, 0, 0.12);    color: var(--color-red); }
.guide__job-card--semi    .guide__job-card-icon { background: rgba(251, 146, 60, 0.12); color: #fb923c; }

.guide__job-card-name {
  font-size: var(--fs-base);
  font-weight: var(--fw-semibold);
  color: var(--text-white);
}

.guide__job-card-tag {
  font-size: var(--fs-xs);
  font-weight: var(--fw-medium);
  padding: 2px var(--space-2);
  border-radius: var(--radius-sm);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.guide__job-card--legal   .guide__job-card-tag { background: rgba(34, 197, 94, 0.12);  color: #22c55e; }
.guide__job-card--illegal .guide__job-card-tag { background: rgba(177, 0, 0, 0.12);    color: var(--color-red); }
.guide__job-card--semi    .guide__job-card-tag { background: rgba(251, 146, 60, 0.12); color: #fb923c; }

.guide__job-card-desc {
  font-size: var(--fs-sm);
  color: var(--text-secondary);
  line-height: 1.6;
}

/* ==========================================================
   RÈGLES RP — RULE ITEMS
   ========================================================== */

.guide__rules {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.guide__rule {
  background: var(--bg-card);
  border: var(--border-subtle);
  border-radius: var(--radius-lg);
  padding: var(--space-5) var(--space-6);
  display: flex;
  gap: var(--space-4);
  align-items: flex-start;
  transition: border-color var(--transition-base), transform var(--transition-base);
}

.guide__rule:hover {
  border-color: rgba(177, 0, 0, 0.3);
  transform: translateX(4px);
}

.guide__rule-icon {
  width: 44px;
  height: 44px;
  background: rgba(177, 0, 0, 0.1);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-red);
  font-size: var(--fs-lg);
  flex-shrink: 0;
}

.guide__rule-title {
  font-size: var(--fs-base);
  font-weight: var(--fw-semibold);
  color: var(--text-white);
  margin-bottom: var(--space-1);
}

.guide__rule-label {
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  color: var(--color-red);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: var(--space-2);
  display: block;
}

.guide__rule-text {
  font-size: var(--fs-sm);
  color: var(--text-secondary);
  line-height: 1.6;
}

/* ==========================================================
   CHECKLIST
   ========================================================== */

.guide__checklist {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  list-style: none;
}

.guide__checklist li {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  font-size: var(--fs-sm);
  color: var(--text-secondary);
  line-height: 1.6;
}

.guide__checklist li i {
  color: #22c55e;
  font-size: var(--fs-base);
  flex-shrink: 0;
  margin-top: 1px;
}

/* ==========================================================
   FINAL NOTE
   ========================================================== */

.guide__final-note {
  background: var(--bg-secondary);
  border: var(--border-subtle);
  border-top: 3px solid var(--color-red);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  margin-top: var(--space-8);
}

.guide__final-note-inner {
  display: flex;
  gap: var(--space-5);
  align-items: flex-start;
}

.guide__final-note-icon {
  font-size: var(--fs-2xl);
  color: var(--color-red);
  flex-shrink: 0;
  margin-top: var(--space-1);
}

.guide__final-note-title {
  font-size: var(--fs-lg);
  font-weight: var(--fw-bold);
  color: var(--text-white);
  margin-bottom: var(--space-3);
}

.guide__final-note p {
  font-size: var(--fs-sm);
  color: var(--text-secondary);
  line-height: 1.7;
  margin-bottom: var(--space-3);
}

.guide__final-note-cta {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
  margin-top: var(--space-4);
}

/* ==========================================================
   RESPONSIVE
   ========================================================== */

@media (min-width: 48em) {
  .guide__jobs-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 64em) {
  .guide__jobs-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
