/* ============================================================
   BASE.CSS — Reset, Typography, Global
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;0,900;1,400;1,600&family=Lato:ital,wght@0,300;0,400;0,700;0,900;1,400&family=Cinzel:wght@400;600;700;900&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%;}
body{
  background:var(--clr-ocean);
  color:var(--clr-text);
  font-family:var(--ff-body);
  font-size:var(--fs-base);
  line-height:1.7;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img,video{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
ul,ol{list-style:none;}
button{cursor:pointer;border:none;background:none;font-family:inherit;}
input,select,textarea{font-family:inherit;}

/* === SCROLLBAR === */
::-webkit-scrollbar{width:6px;}
::-webkit-scrollbar-track{background:var(--clr-ocean-deep);}
::-webkit-scrollbar-thumb{background:var(--clr-red);border-radius:3px;}

/* === SELECTION === */
::selection{background:var(--clr-red);color:#fff;}

/* === CONTAINER === */
.container{
  width:100%;
  max-width:var(--container-max);
  margin-inline:auto;
  padding-inline:var(--container-pad);
}

/* === SECTION BASE === */
.section{padding:var(--sp-3xl) 0;}
.section-sm{padding:var(--sp-2xl) 0;}

/* === SECTION LABEL === */
.section-label{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-family:var(--ff-accent);
  font-size:var(--fs-xs);
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--clr-red);
  margin-bottom:var(--sp-md);
}
.section-label::before{
  content:'';
  display:block;
  width:28px;height:1px;
  background:var(--clr-red);
  flex-shrink:0;
}

/* === HEADINGS === */
.section-title{
  font-family:var(--ff-display);
  font-size:clamp(var(--fs-2xl),4vw,var(--fs-3xl));
  font-weight:700;
  color:var(--clr-text);
  line-height:1.2;
  margin-bottom:var(--sp-md);
}
.section-title span{color:var(--clr-red);}
.section-subtitle{
  font-size:var(--fs-md);
  color:var(--clr-text-light);
  max-width:580px;
  line-height:1.75;
}

/* === DIVIDER === */
.divider{
  height:1px;
  background:linear-gradient(90deg,transparent,var(--clr-border-red),transparent);
  margin:var(--sp-2xl) 0;
}

/* === BUTTONS === */
.btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:13px 28px;
  border-radius:var(--r-md);
  font-family:var(--ff-body);
  font-size:var(--fs-sm);
  font-weight:700;
  letter-spacing:0.04em;
  transition:all var(--tr-base);
  white-space:nowrap;
  border:2px solid transparent;
}
.btn-primary{
  background:var(--grad-red);
  color:#fff;
  border-color:var(--clr-red);
  box-shadow:var(--shadow-red);
}
.btn-primary:hover{
  background:linear-gradient(135deg,#d96535 0%,#8a3c14 100%);
  transform:translateY(-2px);
  box-shadow:0 8px 28px rgba(201,98,47,0.45);
}
.btn-outline{
  background:var(--grad-red);
  color:#fff;
  border-color:var(--clr-red);
  box-shadow:var(--shadow-red);
}
.btn-outline:hover{
  background:linear-gradient(135deg,#d96535 0%,#8a3c14 100%);
  transform:translateY(-2px);
  box-shadow:0 8px 28px rgba(201,98,47,0.45);
}
.btn-white{
  background:#fff;
  color:var(--clr-red);
  border-color:#fff;
  font-weight:700;
}
.btn-white:hover{
  background:var(--clr-cream);
  transform:translateY(-2px);
}

/* === BADGE === */
.badge{
  display:inline-block;
  padding:3px 10px;
  border-radius:var(--r-pill);
  font-size:var(--fs-xs);
  font-weight:600;
  letter-spacing:0.06em;
  text-transform:uppercase;
}
.badge-red{background:var(--clr-red-pale);color:var(--clr-red-bright);border:1px solid var(--clr-border-red);}
.badge-saffron{background:var(--clr-saffron-pale);color:var(--clr-saffron);border:1px solid rgba(232,137,43,0.30);}

/* === REVEAL ANIMATIONS === */
.reveal{
  opacity:0;
  transform:translateY(28px);
  transition:opacity 0.6s ease,transform 0.6s ease;
}
.reveal.in-view{opacity:1;transform:translateY(0);}

/* === FOCUS OUTLINE === */
:focus-visible{outline:2px solid var(--clr-red);outline-offset:3px;}