/* =========================================================================
   FALCON ACADEMY — STYLES
   Design system rooted in brand guidelines:
   Crimson Strike #960014 · Warrior Blood #70000F · Black Belt #000000 · Inner Balance #A3A3A3
   ========================================================================= */

:root {
  --crimson:        #960014;
  --blood:          #70000F;
  --black-belt:     #000000;
  --white:          #FFFFFF;
  --ash:            #A3A3A3;
  --hairline:       rgba(0,0,0,0.08);
  --hairline-dark:  rgba(255,255,255,0.08);

  --f-display: 'Montserrat', system-ui, sans-serif;
  --f-secondary: 'ArponaSans', 'Montserrat', system-ui, sans-serif;

  --ease-out-expo: cubic-bezier(0.16, 1, 0.3, 1);
  --max: 1440px;
  --gutter: clamp(20px, 4vw, 56px);
}

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  background:var(--black-belt);
  color:var(--white);
  font-family:var(--f-display);
  font-weight:400;
  line-height:1.5;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  cursor:none;
}
@media (max-width:900px){ body{ cursor:auto; } }

img,svg{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; background:none; border:0; cursor:none; }
@media (max-width:900px){ button{ cursor:pointer; } }

::selection{ background:var(--crimson); color:var(--white); }

/* ---------- Section Alternation ---------- */
.section--dark {
  background: var(--black-belt);
  color: var(--white);
}
.section--light {
  background: var(--white);
  color: var(--black-belt);
}
.section--dark .tag { color: var(--crimson); }
.section--light .tag { color: var(--crimson); }

/* ---------- Custom cursor ---------- */
.cursor{
  position:fixed; top:0; left:0; width:8px; height:8px; border-radius:50%;
  background:var(--crimson); pointer-events:none; z-index:9999;
  transform:translate(-50%,-50%);
  mix-blend-mode:difference;
  transition:width .25s var(--ease-out-expo), height .25s var(--ease-out-expo), background .2s ease;
}
.cursor-ring{
  position:fixed; top:0; left:0; width:38px; height:38px; border-radius:50%;
  border:1px solid rgba(150,0,20,0.45); pointer-events:none; z-index:9998;
  transform:translate(-50%,-50%);
  transition:transform .3s var(--ease-out-expo), width .3s var(--ease-out-expo), height .3s var(--ease-out-expo), border-color .25s ease;
  mix-blend-mode:difference;
}
.cursor.is-hover{ width:0; height:0; }
.cursor-ring.is-hover{ width:72px; height:72px; border-color:var(--crimson); }
@media (max-width:900px){ .cursor,.cursor-ring{ display:none; } }

/* ---------- Loader ---------- */
.loader{
  position:fixed; inset:0; background:var(--black-belt); z-index:9000;
  display:grid; place-items:center;
  transition:opacity .6s var(--ease-out-expo), visibility .6s;
}
.loader.is-done{ opacity:0; visibility:hidden; }
.loader__mark{ width:160px; height:160px; }
.loader__mark path{
  fill:none; stroke:var(--crimson); stroke-width:2;
}

/* ---------- Nav (Glassmorphism) ---------- */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  padding:22px var(--gutter);
  background: rgba(0, 0, 0, 0.05);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition: transform .4s var(--ease-out-expo), background .3s ease;
  border-bottom: 1px solid rgba(255, 255, 255, 0.03);
}
.nav.is-hidden{ transform:translateY(-110%); }
.nav__brand{ display:flex; align-items:center; gap:12px; }
.nav__brand-mark{ width:30px; height:30px; color:var(--white); transition: transform 0.3s ease; }
.nav__brand:hover .nav__brand-mark { transform: rotate(10deg) scale(1.1); }
.nav__brand-text{
  font-family:var(--f-display); font-weight:800; font-size:14px;
  letter-spacing:.2em; text-transform:uppercase; color: var(--white);
}
.nav__brand-text small{
  display:block; font-weight:600; font-family:var(--f-secondary); font-size:9px; letter-spacing:.45em;
  color:var(--ash); margin-top:2px; text-transform:uppercase;
}
.nav__links{ display:flex; gap:36px; }
.nav__links a{
  font-size:12px; font-weight:500; letter-spacing:.18em; text-transform:uppercase;
  position:relative; padding:6px 0; color: var(--white);
}
.nav__links a::after{
  content:""; position:absolute; left:50%; bottom:0; width:0; height:1px;
  background:var(--crimson); transition:width .4s var(--ease-out-expo), left .4s var(--ease-out-expo);
}
.nav__links a:hover::after{ width:100%; left: 0; }
.nav__cta{
  position: relative;
  display:inline-flex; align-items:center; gap:10px;
  padding:12px 22px; border:1px solid var(--white); border-radius:0;
  font-size:11px; font-weight:700; font-family:var(--f-secondary); letter-spacing:.2em; text-transform:uppercase;
  transition: color .3s ease;
  color: var(--white); background: transparent;
  overflow: hidden;
}
.nav__cta::before {
  content: "";
  position: absolute;
  top: 0; left: -100%;
  width: 100%; height: 100%;
  background: var(--crimson);
  transition: left 0.4s var(--ease-out-expo);
  z-index: -1;
}
.nav__cta:hover::before { left: 0; }
.nav__cta:hover { color: var(--white); border-color: var(--crimson); }
@media (max-width:900px){ .nav__links{ display:none; } }

/* ---------- HERO (Grain & Scanning line) ---------- */
.hero{
  position:relative; min-height:100vh; padding:180px var(--gutter) 60px;
  display:flex; flex-direction:column; justify-content:center;
  overflow:hidden;
}
.hero::before {
  content: "";
  position: absolute; inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E");
  opacity: 0.04;
  pointer-events: none;
  z-index: 1;
}
.hero::after {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 2px;
  background: rgba(150, 0, 20, 0.1);
  animation: scan 4s linear infinite;
  z-index: 1;
}
@keyframes scan {
  from { top: -10%; }
  to { top: 110%; }
}

.hero__ghost{
  position:absolute; right:-8%; top:50%; transform:translateY(-50%);
  width:80vh; height:80vh; color:var(--blood); opacity:.18;
  pointer-events:none; z-index:0;
}

.hero__content{ position:relative; z-index:2; max-width:800px; }

.hero__eyebrow{
  display:inline-flex; align-items:center; gap:14px;
  font-family:var(--f-secondary); font-weight:700; font-size:11px; letter-spacing:.4em;
  color:var(--ash); text-transform:uppercase; margin-bottom:36px;
}
.hero__eyebrow .line{
  display:inline-block; width:44px; height:1px; background:var(--crimson);
}

.hero__title{
  font-family:var(--f-display); font-weight:900;
  font-size:clamp(48px, 8vw, 96px);
  line-height:.95; letter-spacing:-.04em; text-transform:uppercase;
  margin-bottom:36px;
}
.hero__title .row{ display:block; overflow:hidden; }
.hero__title .word{
  display:inline-block;
}
.hero__title .row:nth-child(3) .word{ color:var(--crimson); }

.hero__lede{
  max-width:520px; font-size:clamp(15px,1.1vw,17px); line-height:1.6;
  color:var(--ash); margin-bottom:44px;
}
.hero__lede strong{ color:var(--white); font-weight:600; }



/* ---------- METHOD / 3 PILLARS (Glow & Gradient) ---------- */
.method{
  position:relative; padding:140px var(--gutter); overflow:hidden;
}
.method__inner{ max-width:var(--max); margin:0 auto; position:relative; }
.method__head{ text-align:center; margin-bottom:90px; }
.method__head .tag{ font-family:var(--f-secondary); font-weight:700; font-size:11px; letter-spacing:.4em; color:var(--crimson); text-transform:uppercase; }
.method__head h2{
  margin-top:24px;
  font-family:var(--f-display); font-weight:800;
  font-size:clamp(36px,5.5vw,72px);
  line-height:.95; letter-spacing:-.04em; text-transform:uppercase;
}
.method__head h2 em{
  display:block; font-family:var(--f-display); font-style:normal; font-weight:800;
  color:var(--crimson); text-transform:uppercase; letter-spacing:-.04em;
}
.pillars{
  display:grid; grid-template-columns:repeat(3,1fr); gap:0;
  border-top:1px solid var(--hairline-dark); border-bottom:1px solid var(--hairline-dark);
}
@media (max-width:900px){ .pillars{ grid-template-columns:1fr; } }
.pillar{
  padding:60px 40px; border-left:1px solid var(--hairline-dark);
  display:flex; flex-direction:column; gap:24px;
  transition: background 0.6s var(--ease-out-expo), box-shadow 0.4s ease;
  position: relative;
  overflow: hidden;
}
.pillar:first-child{ border-left:0; }
@media (max-width:900px){
  .pillar{ border-left:0; border-top:1px solid var(--hairline-dark); }
  .pillar:first-child{ border-top:0; }
}
.pillar::before {
  content: "";
  position: absolute; inset: 0;
  background: radial-gradient(circle at center, var(--blood), transparent 70%);
  opacity: 0;
  transition: opacity 0.6s var(--ease-out-expo);
  z-index: 0;
}
.pillar:hover::before { opacity: 0.3; }
.pillar:hover {
  box-shadow: inset 0 0 20px rgba(150, 0, 20, 0.2), 0 0 15px rgba(150, 0, 20, 0.1);
}

.pillar__num{
  position: relative; z-index: 1;
  font-family:var(--f-secondary); font-weight:700; font-size:11px; letter-spacing:.35em; color:var(--crimson);
  text-transform:uppercase;
}
.pillar__h{
  position: relative; z-index: 1;
  font-family:var(--f-display); font-weight:900;
  font-size:clamp(28px,3vw,42px); line-height:.95; letter-spacing:-.02em; text-transform:uppercase;
}
.pillar__p{ position: relative; z-index: 1; font-size:14px; line-height:1.65; color:var(--ash); max-width:340px; font-weight:500; }
.pillar__icon{ position: relative; z-index: 1; width:48px; height:54px; color:var(--crimson); margin-top:auto; }

/* ---------- INQUIRE ---------- */
.inquire{
  padding:140px var(--gutter);
}
.inquire__inner{
  max-width:800px; margin:0 auto;
}
.inquire__head{ margin-bottom: 50px; text-align: center; }
.inquire__head h2{
  font-family:var(--f-display); font-weight:800;
  font-size:clamp(36px,5.5vw,72px); line-height:.95; letter-spacing:-.03em; text-transform:uppercase;
}
.inquire__head p{ margin-top: 18px; color:var(--ash); font-size:16px; }

.inquire__form {
  position:relative;
  background: var(--white);
  border: 1px solid var(--hairline);
  padding: 40px;
}
.field{ position:relative; margin-bottom:28px; }
.field--row{ display:grid; grid-template-columns:1fr 1fr; gap:24px; margin-bottom:28px; }
.field--row .field{ margin-bottom:0; }
.field input{
  width:100%; padding:18px 0 10px; background:transparent; border:0;
  border-bottom:1px solid var(--hairline);
  font-family:var(--f-display); font-size:16px; color:var(--black-belt);
  outline:none; transition:border-color .3s ease;
}
.field label{
  position:absolute; left:0; top:18px;
  font-family:var(--f-secondary); font-weight:700; font-size:11px; letter-spacing:.25em;
  color:var(--ash); text-transform:uppercase;
  pointer-events:none; transition:all .35s var(--ease-out-expo);
}
.field label .opt{ color:var(--ash); margin-left:6px; font-size:9px; }
.field input:focus,
.field input:not(:placeholder-shown){ border-bottom-color:var(--crimson); }
.field input:focus + label,
.field input:not(:placeholder-shown) + label{
  top:-2px; font-size:9px; color:var(--crimson); letter-spacing:.35em;
}
.field__line{
  position:absolute; left:0; bottom:0; height:1px; width:0%; background:var(--crimson);
  transition:width .5s var(--ease-out-expo);
}
.field input:focus ~ .field__line{ width:100%; }
.field textarea{
  width:100%; padding:18px 0 10px; background:transparent; border:0;
  border-bottom:1px solid var(--hairline);
  font-family:var(--f-display); font-size:16px; color:var(--black-belt);
  outline:none; transition:border-color .3s ease;
  resize:none; min-height:100px;
}
.field textarea:focus,
.field textarea:not(:placeholder-shown){ border-bottom-color:var(--crimson); }
.field textarea:focus + label,
.field textarea:not(:placeholder-shown) + label{
  top:-2px; font-size:9px; color:var(--crimson); letter-spacing:.35em;
}
.field textarea:focus ~ .field__line{ width:100%; }
.form__error{
  font-family:var(--f-secondary); font-size:12px; letter-spacing:.05em;
  color:var(--crimson); min-height:18px; margin-bottom:8px; display:none;
}
.form__error.is-visible{ display:block; }

.form__submit{
  position:relative; width:100%; margin-top:14px;
  padding:20px 28px; background:var(--crimson); color:var(--white);
  font-family:var(--f-display); font-weight:700; font-size:13px;
  letter-spacing:.3em; text-transform:uppercase;
  transition:transform .3s var(--ease-out-expo);
  display:flex; align-items:center; justify-content:center;
  overflow: hidden;
}
.form__submit span { position: relative; z-index: 1; }
.form__submit::before {
  content: "";
  position: absolute;
  top: 0; left: -100%;
  width: 100%; height: 100%;
  background: var(--black-belt);
  transition: left 0.4s var(--ease-out-expo);
  z-index: 0;
}
.form__submit:hover::before { left: 0; }
.form__submit:hover { transform: scale(1.02); }

.form__success{
  position:absolute; inset:0; background:var(--white);
  display:none; flex-direction:column; align-items:center; justify-content:center; gap:18px;
  padding:40px; text-align:center;
  z-index: 10;
}
.form__success.is-shown{ display:flex; }
.form__success h4{ font-family:var(--f-display); font-weight:800; font-size:22px; letter-spacing:-.01em; text-transform:uppercase; color:var(--crimson); }
.form__success p{ color:var(--ash); font-size:14px; font-weight:500; }

/* ---------- FOOTER ---------- */
footer{
  padding:80px var(--gutter) 40px;
  border-top:1px solid var(--hairline-dark);
}
.foot__top{
  max-width:var(--max); margin:0 auto 60px;
  display:grid; grid-template-columns:1.5fr 1fr; gap:60px;
}
@media (max-width:900px){ .foot__top{ grid-template-columns:1fr; } }
.foot__brand-mark{ width:48px; height:48px; margin-bottom:24px; }
.foot__brand-text{
  font-family:var(--f-display); font-weight:900; font-size:24px; letter-spacing:.18em;
  text-transform:uppercase;
}
.foot__brand-text small{ display:block; font-weight:700; font-family:var(--f-secondary); font-size:11px; letter-spacing:.4em; color:var(--ash); margin-top:6px; text-transform:uppercase; }

.foot__col h5{
  font-family:var(--f-secondary); font-weight:700; font-size:11px; letter-spacing:.35em;
  text-transform:uppercase; margin-bottom:20px; color:var(--ash);
}
.foot__col p{ font-size:14px; line-height:2; font-weight:500; transition: color 0.3s ease; }
.foot__col p:hover { color: var(--crimson); }

.foot__bot{
  max-width:var(--max); margin:0 auto; padding-top:30px;
  border-top:1px solid var(--hairline-dark);
  text-align: center;
  font-family:var(--f-secondary); font-weight:700; font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--ash);
}
