/* ========================================
0. FONT
======================================== */

@font-face{
  font-family:"Inter";
  src:url("../fonts/InterVariable.woff2") format("woff2");
  font-weight:100 900;
  font-style:normal;
  font-display:swap;
}

@font-face{
  font-family:"Inter";
  src:url("../fonts/InterVariable-Italic.woff2") format("woff2");
  font-weight:100 900;
  font-style:italic;
  font-display:swap;
}

/* ========================================
1. VARIABLES
======================================== */

:root{

  /* ========================================
  COLORS
  ======================================== */

--bg:#050505;
--bg-2:#0b0b0c;
--bg-3:#121214;
--bg-4:#18181b;

--primary:#f45a1a;
--primary-2:#ff6f00;
--gold:#f2c14e;


/* ========================================
TEXT-COLOUR
======================================== */

--text:#fcfcfc;
--text-soft:#e7e7e7;
--muted:#b4b4b8;
--muted-2:#8b8b92;

/* ========================================
TYPOGRAPHY
======================================== */

/* FONT FAMILIES */
--font-base:"Inter",sans-serif;
--font-heading:"Inter",sans-serif;
--font-ui:"Inter",sans-serif;

--weight-regular:400;
--weight-medium:500;
--weight-semibold:580;
--weight-bold:660;
--weight-heavy:720;

--track-body:-0.008em;
--track-nav:-0.004em;
--track-h1:-0.045em;
--track-h2:-0.032em;
--track-h3:-0.018em;
--track-eyebrow:.16em;

--lh-body:1.72;
--lh-copy:1.78;
--lh-tight:.98;
--lh-heading:1.02;
--lh-subheading:1.14;

/* ========================================
SURFACES / BORDERS
======================================== */

--line:rgba(255,255,255,.08);
--line-2:rgba(255,255,255,.12);
--line-soft:rgba(255,255,255,.04);

--glass:rgba(255,255,255,.035);
--glass-2:rgba(255,255,255,.055);
--glass-3:rgba(255,255,255,.075);


/* ========================================
RADII + SHADOWS
======================================== */

--radius:24px;
--radius-sm:16px;
--radius-pill:999px;

--shadow:0 20px 60px rgba(0,0,0,.52);
--shadow-soft:0 10px 28px rgba(0,0,0,.34);

--glow-brand:
0 0 0 1px rgba(244,90,26,.12),
0 5px 12px rgba(244,90,26,.08),
0 0 14px rgba(244,90,26,.05);

--glow-brand-soft:
0 0 0 1px rgba(244,90,26,.08),
0 4px 10px rgba(244,90,26,.06),
0 0 12px rgba(244,90,26,.04);


/* ========================================
BUTTON TOKENS
======================================== */

--btn-pad-y:.82rem;
--btn-pad-x:1.28rem;
--btn-pad-y-sm:.78rem;
--btn-pad-x-sm:1rem;

--btn-primary-bg:
linear-gradient(135deg,var(--primary),var(--primary-2));

--btn-ghost-bg:
linear-gradient(
180deg,
rgba(255,255,255,.03),
rgba(255,255,255,.008)
);

--btn-ghost-bg-hover:
linear-gradient(
180deg,
rgba(255,255,255,.045),
rgba(255,255,255,.012)
);

--btn-border:1px solid rgba(255,255,255,.08);
--btn-border-ghost:1px solid rgba(255,255,255,.12);
--btn-border-brand:1px solid rgba(244,90,26,.35);

--btn-shadow-primary:
0 8px 18px rgba(0,0,0,.30),
0 3px 8px rgba(244,90,26,.08),
inset 0 1px 0 rgba(255,255,255,.16);

--btn-shadow-primary-hover:var(--glow-brand);

--btn-shadow-ghost:
inset 0 1px 0 rgba(255,255,255,.04),
0 8px 18px rgba(0,0,0,.28);

--btn-shadow-ghost-hover:
0 12px 24px rgba(0,0,0,.34),
var(--glow-brand-soft);


/* ========================================
LAYOUT + MOTION
======================================== */


/* spacing scale */
--space-xs:.5rem;
--space-sm:.8rem;
--space-md:1rem;
--space-lg:1.6rem;
--space-xl:2.4rem;
--space-2xl:3rem;
--space-3xl:5rem;
--space-4xl:7rem;

/* component spacing */
--card-pad:1.6rem;
--card-gap:1rem;

--stack-sm:.8rem;
--stack-md:1rem;
--stack-lg:1.3rem;
--stack-xl:2rem;

--grid-gap:1rem;
--grid-gap-lg:3rem;

/* layout */
--max:1200px;

/* motion */
--speed:.28s ease;

}

/* ========================================
2. CSS RESET
======================================== */

*{
  margin:0;
  padding:0;
  box-sizing:border-box;
}

html{
  scroll-behavior:smooth;
  font-feature-settings:"cv11","ss01","ss03","kern";
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

img{
  max-width:100%;
  display:block;
}

a{
  color:inherit;
  text-decoration:none;
}

button,
input{
  font:inherit;
}

button{
  border:none;
  cursor:pointer;
}

/* ========================================
3. BASE
======================================== */

body{
  font-family:var(--font-base);
  font-weight:var(--weight-regular);
  line-height:var(--lh-body);
  letter-spacing:var(--track-body);
  color:var(--text);
  overflow-x:hidden;
  background:
  radial-gradient(circle at 80% 12%, rgba(255,90,31,.08), transparent 26%),
  radial-gradient(circle at 14% 78%, rgba(242,193,78,.05), transparent 22%),
  linear-gradient(180deg,#050505,#070707 40%,#050505);
}

p{
  color:var(--muted);
}

h1{
  font-weight:var(--weight-heavy);
  line-height:var(--lh-tight);
  letter-spacing:var(--track-h1);
}

h2{
  font-weight:var(--weight-bold);
  line-height:var(--lh-heading);
  letter-spacing:var(--track-h2);
}

h3{
  font-weight:var(--weight-semibold);
  line-height:var(--lh-subheading);
  letter-spacing:var(--track-h3);
}

h1{font-size:clamp(3.4rem,9vw,7rem);}
h2{font-size:clamp(2.6rem,7vw,4.4rem);}
h3{font-size:clamp(1.5rem,4vw,2rem);}

/* ========================================
4. LAYOUT
======================================== */

.container{
  width:min(100% - 2rem,var(--max));
  margin:auto;
}

.section{
  padding: var(--space-4xl) 0;
  position:relative;
}

.section::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
  linear-gradient(180deg,transparent,rgba(255,255,255,.01),transparent);
}

.dark{
  background:linear-gradient(180deg,#0c0c0d,#131316);
}

.section-head{
  margin-bottom: var(--space-xl);
}

.eyebrow{
  color:var(--primary);
  font-family:var(--font-ui);
  font-weight:var(--weight-semibold);
  letter-spacing:var(--track-eyebrow);
  text-transform:uppercase;
  margin-bottom:.9rem;
}

/* ========================================
5. HEADER / NAVBAR
======================================== */

.site-header{
  position:sticky;
  top:0;
  z-index:1500;

  background:
  linear-gradient(
  180deg,
  rgba(255,255,255,.02),
  rgba(255,255,255,.003)
  );

  backdrop-filter:none;
  -webkit-backdrop-filter:none;

  border-bottom:1px solid rgba(255,255,255,.10);

  box-shadow:
  inset 0 1px 0 rgba(255,255,255,.02);
}


.nav-wrap{
  min-height:78px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1.2rem;
}

.logo{
  font-family:var(--font-heading);
  font-weight:var(--weight-heavy);
  color:#fff;
}

.nav{
  display:flex;
  align-items:center;
  gap:.28rem;
}

.nav a{
  color:#d6d6da;
  font-family:var(--font-ui);
  font-weight:var(--weight-medium);
  letter-spacing:var(--track-nav);
  padding:.68rem .82rem;
  border-radius:12px;
  transition:var(--speed);
}

.nav a:hover{
  color:var(--primary);
  background:rgba(255,90,31,.045);
}

/* language */

.lang-switch{
  display:flex;
  gap:.4rem;
  align-items:center;
  margin-left:.55rem;
}

.lang-switch button{
  min-width:34px;
  height:34px;
  padding:0 .55rem;
  border-radius:999px;

  background:rgba(255,255,255,.018);
  border:1px solid rgba(255,255,255,.06);

  color:#e9e9eb;
  font-size:.74rem;
  font-weight:700;

  transition:var(--speed);
}

.lang-switch button:hover{
  border-color:rgba(255,90,31,.25);
  color:#fff;
}

.lang-switch button.active{
  background:linear-gradient(135deg,var(--primary),var(--primary-2));
  border-color:transparent;
}

/* ========================================
6. BUTTON SYSTEM
======================================== */

.btn,
.btn-outline{
  position:relative;
  overflow:hidden;
  isolation:isolate;

  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.55rem;

  min-height:50px;
  padding:var(--btn-pad-y) var(--btn-pad-x);

  border-radius:var(--radius-pill);

  font-weight:700;
  font-size:1rem;
  line-height:1;
  white-space:nowrap;

  transition:
  color var(--speed),
  background var(--speed),
  border-color var(--speed),
  box-shadow var(--speed),
  transform var(--speed),
  filter var(--speed);
}

/* PRIMARY */

.btn{
  color:#fff;
  border:var(--btn-border);
  background:transparent;
  box-shadow:var(--btn-shadow-primary);
}

.btn::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:-1;

  background:var(--btn-primary-bg);

  transform:scaleX(1);
  transform-origin:right;
  transition:transform .38s ease;
}

.btn:hover{
  color:var(--primary);
  background:rgba(255,255,255,.02);
  border:var(--btn-border-brand);
  box-shadow:var(--btn-shadow-primary-hover);
  transform:translateY(-2px);
}

.btn:hover::before{
  transform:scaleX(0);
}

/* GHOST */

.btn-outline{
  color:#fff;
  background:var(--btn-ghost-bg);
  border:var(--btn-border-ghost);
  box-shadow:var(--btn-shadow-ghost);
}

.btn-outline:hover{
  border-color:rgba(255,90,31,.18);
  box-shadow:var(--btn-shadow-ghost-hover);
  transform:translateY(-2px);
}

/* NAV */

.nav .btn{
  min-height:42px;
  padding:var(--btn-pad-y-sm) 1.18rem;
  font-size:.92rem;
  margin-left:.55rem;
}

/* UTILS */

.btn-sm{
  min-height:42px;
  padding:var(--btn-pad-y-sm) var(--btn-pad-x-sm);
  font-size:.92rem;
}

.full{
  width:100%;
}

/* ========================================
7. HERO
======================================== */

.hero{
  padding:7.5rem 0 5.5rem;
  position:relative;
}

.hero h1{
  max-width: 10ch;
}

.hero::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;

  background:
  radial-gradient(circle at 78% 28%, rgba(255,90,31,.09), transparent 28%),
  radial-gradient(circle at 28% 78%, rgba(255,255,255,.015), transparent 20%);
}

.hero-grid{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap: var(--space-2xl);
  align-items:center;
}

.hero-text{
  max-width:620px;
  margin:1rem 0 2rem;
  font-size:1.12rem;
  color:var(--text-soft);
}

.hero-actions{
  display:flex;
  gap:1rem;
  flex-wrap:wrap;
}

.hero-proof{
  display:flex;
  gap:1rem;
  flex-wrap:wrap;
  margin-top:1.3rem;
  color:#d6d6d8;
  font-size:.95rem;
}

/* ========================================
8. GLASS SYSTEM
======================================== */

.glass,
.card,
.stat,
.slide,
.modal-box{
  background:
  linear-gradient(
  180deg,
  rgba(255,255,255,.045),
  rgba(255,255,255,.018)
  );

  border:1px solid rgba(255,255,255,.07);

  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);

  box-shadow:
  0 16px 42px rgba(0,0,0,.42),
  inset 0 1px 0 rgba(255,255,255,.05);

  border-radius:var(--radius);
}

.card,
.stat,
.slide,
.hero-card{
  transition:var(--speed);
}

.card:hover,
.stat:hover,
.slide:hover,
.hero-card:hover{
  transform:translateY(-4px);
  border-color:rgba(255,255,255,.13);
  box-shadow: var(--glow-brand-soft);
}

/* ========================================
9. CARDS / STATS / CONTENT
======================================== */

.hero-card{
  padding:2rem;
}

.hero-card ul{
  margin-top:1rem;
  padding-left:1rem;
}

.hero-card li{
  margin:.7rem 0;
  color:#dddddf;
}

.stats{
  padding:0 0 5rem;
}

.stats-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap: var(--space-md);
}

.stat{
  text-align:center;
  padding:2rem 1rem;
}

.stat h3{
  color:var(--gold);
  margin-bottom:.2rem;
}

.card-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap: var(--space-md);
}

.card{
  padding:1.6rem;
}

.card p{
  margin-top:.55rem;
}

.split{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:3rem;
  align-items:start;
}

.check-list p{
  margin-bottom:1rem;
  color:#d7d7da;
}

.contact-card{
  display:flex;
  flex-direction:column;
  gap:1.1rem;
  min-height:100%;
}

.contact-meta{
  display:grid;
  gap:.45rem;
}

.contact-meta p{
  margin:0;
}

.contact-actions{
  margin-top:auto;
  display:grid;
  gap:.8rem;
}

/* ========================================
10. REVIEWS
======================================== */

.slider{
  position:relative;
}

.slide{
  display:none;
  padding:2rem;
  min-height:160px;
}

.slide.active{
  display:block;
}

.slide p{
  font-size:1.08rem;
  line-height:1.75;
  color:#fff;
  margin-bottom:.8rem;
}

.slide span{
  color:var(--gold);
  font-weight:600;
  font-size:.95rem;
}

/* ========================================
11. CTA
======================================== */

.cta-band{
  padding: var(--space-3xl) 0;

  background:
  radial-gradient(circle at left center, rgba(255,90,31,.16), transparent 34%),
  radial-gradient(circle at right center, rgba(255,255,255,.02), transparent 26%),
  linear-gradient(180deg,#101011,#090909);
}

.cta-flex{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:2rem;
}

/* ========================================
12. FOOTER
======================================== */

.site-footer{
  padding: var(--space-3xl) 0 3.5rem;
  border-top:1px solid rgba(255,255,255,.05);
  background:#050505;
}

.footer-grid{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:2rem;
}

.footer-grid h3{
  margin-bottom:.8rem;
}

.footer-grid p,
.footer-grid a{
  color:#cfcfd2;
  font-size:.95rem;
}

.footer-links{
  display:flex;
  flex-direction:column;
  gap:.6rem;
}

.footer-links a:hover{
  color:var(--primary);
}

.footer-social{
  display:flex;
  gap:.8rem;
  flex-wrap:wrap;
  margin-top:1rem;
}

.footer-social a{
  width:42px;
  height:42px;
  border-radius:50%;
  display:grid;
  place-items:center;

  background:rgba(255,255,255,.025);
  border:1px solid rgba(255,255,255,.07);

  transition:var(--speed);
}

.footer-social a:hover{
  transform:translateY(-2px);
  border-color:rgba(255,255,255,.16);
  box-shadow: var(--glow-brand-soft);
}

.footer-social svg{
  width:18px;
  height:18px;
  fill:currentColor;
}

.footer-copy{
  margin-top:2.5rem;
  text-align:center;
  color:#76767b;
  font-size:.82rem;
}

/* ========================================
13. MODAL / FORMS
======================================== */

.modal{
  position:fixed;
  inset:0;
  z-index:2000;
  display:none;
  align-items:center;
  justify-content:center;
  padding:1rem;
  background:rgba(0,0,0,.68);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}

.modal.show{
  display:flex;
}

.modal-box{
  width:min(100%,560px);
  padding:1.6rem;
}

.close-modal{
  float:right;
  background:transparent;
  color:#fff;
  font-size:2rem;
  line-height:1;
}

#assessmentForm,
#contactForm{
  display:grid;
  gap:1rem;
  margin-top:1.2rem;
}

input,
select{
  width:100%;
  min-height:56px;
  padding:1rem;

  font:inherit;
  color:var(--text);

  background:rgba(255,255,255,.025);
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius-sm);

  transition:
  border-color var(--speed),
  box-shadow var(--speed),
  background var(--speed);
}

select{
  appearance:none;
  -webkit-appearance:none;
  -moz-appearance:none;
  cursor:pointer;
}

input:focus,
select:focus{
  outline:none;
  border-color:rgba(255,90,31,.72);
  box-shadow:var(--glow-brand-soft);
}

select option{
  background:var(--bg-3);
  color:var(--text);
}

.modal-box h2{
  margin-bottom:.45rem;
}

.modal-box > div > p{
  margin-bottom:1rem;
}

/* RESULTS / REVIEW CARDS */

#result{
  margin-top:1rem;
  color:var(--text);
  font-weight:700;
}

.result-card,
.review-card{
  margin-top:1.25rem;
}

.result-card h3{
  margin-bottom:.6rem;
}

.result-card p{
  margin-top:.7rem;
}

.review-card{
  display:flex;
  flex-direction:column;
  height:100%;
}

.review-card h3{
  margin-bottom:.45rem;
}

.review-card p{
  margin-top:0;
}

.review-card .stars{
  color:var(--gold);
  font-size:1rem;
  letter-spacing:.16em;
  line-height:1;
  margin-bottom:.7rem;
}

.review-name{
  margin-top:1rem !important;
  color:var(--text);
  font-weight:700;
  font-size:.95rem;
  opacity:.9;
}

.result-btn{
  width:100%;
  margin-top:1.4rem;
}

/* ========================================
14. FLOATING WHATSAPP
======================================== */

.wa-float{
  position:fixed;
  right:2rem;
  bottom:2rem;
  width:60px;
  height:60px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:999;

  color:#fff;

  background:linear-gradient(135deg,#25D366,#1ebe5d);

  box-shadow:
  0 14px 34px rgba(37,211,102,.28),
  0 0 0 1px rgba(255,255,255,.08);

  transition:var(--speed);
}

.wa-float:hover{
  transform:translateY(-4px) scale(1.04);
}

.wa-float svg{
  width:28px;
  height:28px;
  fill:currentColor;
}
