/* ============================================================================
   KOYCHI · Landing "Postula tu espacio" — V3 (estilo franquicias.koychi.cl)
   Tema CLARO de alto impacto: fondos blancos/gris claro, acento rojo,
   titulares negros con palabras en rojo, bloque de cifras en rojo, footer oscuro.
   Tipografía condensada en mayúsculas (Anton) + grotesca de marca (Brother).
   Edita la marca en :root.
   ============================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Anton&display=swap');

/* ---------- FUENTES -------------------------------------------------------- */
@font-face{ font-family:'Fuji';   src:url('assets/fonts/FujiQuakeZone.ttf') format('truetype'); font-display:swap; }
@font-face{ font-family:'Retro';  src:url('assets/fonts/RetroTeam.otf') format('opentype'); font-display:swap; }
@font-face{ font-family:'Brother'; src:url('assets/fonts/Brother1816-Book.otf') format('opentype'); font-weight:400; font-display:swap; }
@font-face{ font-family:'Brother'; src:url('assets/fonts/Brother1816-Medium.otf') format('opentype'); font-weight:500; font-display:swap; }
@font-face{ font-family:'Brother'; src:url('assets/fonts/Brother1816-Bold.otf') format('opentype'); font-weight:700; font-display:swap; }
@font-face{ font-family:'Brother'; src:url('assets/fonts/Brother1816-Black.otf') format('opentype'); font-weight:900; font-display:swap; }

/* ---------- TOKENS --------------------------------------------------------- */
:root{
  --red:#E8472A; --red-deep:#C73A1F; --red-soft:#ff5a3c;
  --yellow:#F5C518;
  --bg:#FFFFFF;            /* fondo principal (claro) */
  --bg-2:#F4F2ED;          /* secciones / tarjetas gris claro */
  --bg-3:#FFFFFF;          /* inputs */
  --ink:#141414;           /* texto y titulares */
  --white:#FFFFFF;
  --dark:#0A0A0A;          /* footer / bloques oscuros */
  --muted:#5a5854;         /* texto secundario sobre claro */
  --muted-2:#8a8780;
  --line:rgba(0,0,0,.10);
  --line-2:rgba(0,0,0,.16);

  --f-cond:'Anton','Arial Narrow',sans-serif;     /* titulares condensados MAYÚS */
  --f-fuji:'Fuji', sans-serif;                     /* acentos de marca */
  --f-head:'Brother', sans-serif;                  /* subtítulos / labels */
  --f-body:'Brother', sans-serif;                  /* cuerpo */

  --maxw:1240px;
  --r:14px; --r-lg:22px;
}

/* ---------- RESET / BASE --------------------------------------------------- */
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:var(--f-body); font-size:18px; line-height:1.6; font-weight:400;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; overflow-x:hidden;
}
img{max-width:100%; display:block;}
a{color:inherit; text-decoration:none;}
h1,h2,h3,h4{margin:0; line-height:1; font-weight:900; color:var(--ink);}
p{margin:0;}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 24px;}
section{position:relative; overflow:hidden;}

/* Tipografía utilitaria */
.cond{font-family:var(--f-cond); font-weight:900; text-transform:uppercase; letter-spacing:.005em; line-height:.92;}
.fuji{font-family:var(--f-fuji); text-transform:uppercase; line-height:.92;}
.txt-red{color:var(--red);} .txt-yel{color:#caa400;}

/* Eyebrow tipo pill (negro, estilo franquicias) ---------------------------- */
.ribbon{
  display:inline-flex; align-items:center; gap:12px; flex-wrap:wrap;
  font-family:var(--f-head); font-weight:700; text-transform:uppercase;
  font-size:13px; letter-spacing:.16em; color:var(--white);
  background:var(--ink); padding:9px 16px; border-radius:6px;
}
.ribbon .dot{width:5px; height:5px; border-radius:50%; background:rgba(255,255,255,.7);}
.ribbon.red{background:var(--red);}
.ribbon.yellow{background:var(--yellow); color:var(--ink);}
.ribbon.ghost{background:transparent; border:1px solid var(--line-2); color:var(--muted);}
.ribbon.ghost .txt-red{color:var(--red);}

/* Carácter coreano decorativo de fondo ------------------------------------- */
.kr-deco{
  position:absolute; z-index:0; pointer-events:none; user-select:none;
  font-weight:900; line-height:.8; color:var(--ink); opacity:.045;
  font-size:clamp(180px, 34vw, 520px); letter-spacing:-.02em;
}

/* ---------- BOTONES -------------------------------------------------------- */
.btn{
  font-family:var(--f-head); font-weight:900; text-transform:uppercase; letter-spacing:.04em;
  font-size:15px; display:inline-flex; align-items:center; gap:10px; cursor:pointer;
  padding:17px 30px; border-radius:8px; border:2px solid transparent;
  transition:transform .15s ease, background .2s, color .2s, border-color .2s, box-shadow .2s;
}
.btn .ar{transition:transform .2s;}
.btn:hover .ar{transform:translateX(4px);}
.btn-red{background:var(--red); color:#fff; box-shadow:0 12px 30px -12px var(--red);}
.btn-red:hover{background:var(--red-deep); transform:translateY(-2px);}
.btn-out{background:transparent; color:var(--ink); border-color:var(--line-2);}
.btn-out:hover{border-color:var(--ink); background:rgba(0,0,0,.05); transform:translateY(-2px);}
.btn-block{width:100%; justify-content:center;}

/* ---------- NAV ------------------------------------------------------------ */
.nav{position:fixed; inset:0 0 auto 0; z-index:100; display:flex; align-items:center; justify-content:space-between;
  padding:18px 24px; transition:background .25s, padding .25s, box-shadow .25s, border-color .25s; border-bottom:1px solid transparent;}
.nav.scrolled{background:rgba(255,255,255,.92); backdrop-filter:blur(12px); padding:12px 24px; border-bottom-color:var(--line); box-shadow:0 6px 24px -18px #000;}
.nav .logo{height:36px;}
.nav-links{display:none; gap:32px;}
.nav-links a{font-family:var(--f-head); font-weight:700; text-transform:uppercase; font-size:13.5px; letter-spacing:.05em; color:var(--ink); opacity:.78; transition:opacity .2s;}
.nav-links a:hover{opacity:1;}
.nav .btn{padding:11px 20px; font-size:13px;}
.nav-cta-d{display:none;}
@media(min-width:1000px){ .nav-links{display:flex;} .nav-cta-d{display:inline-flex;} .nav-cta-m{display:none;} }

/* ---------- HERO ----------------------------------------------------------- */
.hero{min-height:100svh; display:flex; align-items:center; padding:130px 0 70px;
  background:radial-gradient(120% 90% at 85% 0%, rgba(232,71,42,.12), transparent 55%), var(--bg);}
.hero .kr-deco{top:2%; right:-4%; opacity:.05;}
.hero-grid{position:relative; z-index:2; display:grid; gap:40px; align-items:center;}
.hero-copy{max-width:760px;}
.hero .ribbon{margin-bottom:26px;}
.hero h1{font-family:var(--f-cond); font-weight:900; text-transform:uppercase; font-size:clamp(58px,10vw,128px); line-height:.88; letter-spacing:0; margin-bottom:24px;}
.hero h1 .blk{display:block;}
.hero h1 em{font-style:normal; color:var(--red);}
.hero .lead{font-size:clamp(17px,2.2vw,21px); color:var(--muted); max-width:40em; margin-bottom:34px;}
.hero-ctas{display:flex; flex-wrap:wrap; gap:14px;}
.hero-media{position:relative;}
.hero-media .truck{width:100%; border-radius:var(--r-lg); border:1px solid var(--line); box-shadow:0 40px 80px -34px rgba(0,0,0,.45);}
.hero-media .heart{position:absolute; width:118px; right:-10px; top:-40px; transform:rotate(8deg); animation:float 5s ease-in-out infinite;}
@keyframes float{0%,100%{transform:rotate(8deg) translateY(0);}50%{transform:rotate(8deg) translateY(-12px);}}
.hero-kr{margin-top:24px; font-family:var(--f-head); font-weight:700; color:var(--muted-2); font-size:14px; letter-spacing:.05em;}
.hero-kr b{color:var(--red);}
@media(min-width:1000px){ .hero-grid{grid-template-columns:1.15fr .85fr;} .hero-media .heart{width:150px;} }

/* ---------- STATS / TRACCIÓN (bloque rojo) --------------------------------- */
.stats{padding:78px 0; background:var(--red); color:#fff;}
.stats .kr-deco{bottom:-18%; left:-2%; opacity:.10; color:#fff;}
.stats .head{text-align:center; margin-bottom:50px; position:relative; z-index:2;}
.stats .head .ribbon{margin-bottom:18px; background:rgba(0,0,0,.22); color:#fff;}
.stats .head h2{font-family:var(--f-cond); font-weight:900; text-transform:uppercase; font-size:clamp(30px,5vw,52px); color:#fff;}
.stat-grid{position:relative; z-index:2; display:grid; gap:24px; grid-template-columns:1fr 1fr;}
@media(min-width:860px){ .stat-grid{grid-template-columns:repeat(4,1fr);} }
.stat{text-align:center; padding:18px;}
@media(min-width:860px){ .stat + .stat{border-left:1px solid rgba(255,255,255,.28);} }
.stat .n{font-family:var(--f-cond); font-weight:900; font-size:clamp(54px,8vw,86px); line-height:.9; color:#fff;}
.stat .n .u{color:#ffd9cf;}
.stat .l{font-family:var(--f-head); font-weight:700; text-transform:uppercase; letter-spacing:.06em; font-size:13px; color:rgba(255,255,255,.88); margin-top:10px;}

/* ---------- SECCIÓN GENÉRICA ----------------------------------------------- */
.sec{padding:96px 0;}
.sec-head{max-width:820px; margin-bottom:54px; position:relative; z-index:2;}
.sec-head.center{margin-left:auto; margin-right:auto; text-align:center;}
.sec-head .ribbon{margin-bottom:20px;}
.sec-head h2{font-family:var(--f-cond); font-weight:900; text-transform:uppercase; font-size:clamp(36px,6vw,72px); line-height:.92;}
.sec-head h2 em{font-style:normal; color:var(--red);}
.sec-head p{margin-top:20px; color:var(--muted); font-size:19px; max-width:50em;}
.sec-head.center p{margin-left:auto; margin-right:auto;}

/* ---------- ¿QUÉ ES KOYCHI? ------------------------------------------------ */
.about{background:var(--bg-2); border-top:1px solid var(--line); border-bottom:1px solid var(--line);}
.about .kr-deco{top:50%; right:-3%; transform:translateY(-50%); opacity:.05;}
.about-grid{position:relative; z-index:2; display:grid; gap:44px; align-items:center;}
@media(min-width:980px){ .about-grid{grid-template-columns:1fr 1fr;} }
.about-media{position:relative; border-radius:var(--r-lg); overflow:hidden; border:1px solid var(--line); aspect-ratio:5/4; background:#eee; box-shadow:0 30px 60px -40px rgba(0,0,0,.4);}
.about-media img{width:100%; height:100%; object-fit:cover;}
.about-media .hot{position:absolute; right:16px; top:16px; width:120px; height:auto; transform:rotate(-7deg);}
.about-body h2{font-family:var(--f-cond); font-weight:900; text-transform:uppercase; font-size:clamp(34px,5vw,60px); line-height:.92; margin-bottom:22px;}
.about-body h2 em{font-style:normal; color:var(--red);}
.about-body p{color:var(--muted); font-size:18px; margin-bottom:18px;}
.about-body p strong{color:var(--ink); font-weight:700;}
.about-tags{display:flex; flex-wrap:wrap; gap:10px; margin-top:26px;}
.tag{font-family:var(--f-head); font-weight:700; text-transform:uppercase; font-size:12.5px; letter-spacing:.05em;
  color:var(--ink); border:1px solid var(--line-2); border-radius:999px; padding:8px 15px;}
.tag.red{background:var(--red); border-color:var(--red); color:#fff;}

/* ---------- BENEFICIOS (cards con tag + hover) ----------------------------- */
.cards{display:grid; gap:18px; grid-template-columns:1fr;}
@media(min-width:680px){ .cards{grid-template-columns:1fr 1fr;} }
@media(min-width:1040px){ .cards{grid-template-columns:repeat(3,1fr);} }
.card{position:relative; background:#fff; border:1px solid var(--line); border-radius:var(--r); padding:30px 28px 32px;
  overflow:hidden; box-shadow:0 18px 40px -34px rgba(0,0,0,.5); transition:transform .25s, border-color .25s, box-shadow .25s;}
.card::after{content:""; position:absolute; left:0; top:0; height:4px; width:100%; background:var(--red); transform:scaleX(0); transform-origin:left; transition:transform .3s;}
.card:hover{transform:translateY(-6px); border-color:var(--line-2); box-shadow:0 28px 50px -30px rgba(0,0,0,.45);}
.card:hover::after{transform:scaleX(1);}
.card .ctag{font-family:var(--f-head); font-weight:700; text-transform:uppercase; font-size:11px; letter-spacing:.1em; color:var(--red); margin-bottom:18px; display:block;}
.card .ic{width:52px; height:52px; border-radius:12px; background:rgba(232,71,42,.10); color:var(--red); display:flex; align-items:center; justify-content:center; margin-bottom:20px;}
.card .ic svg{width:28px; height:28px; stroke:var(--red); fill:none; stroke-width:2; stroke-linecap:round; stroke-linejoin:round;}
.card h3{font-family:var(--f-head); font-weight:900; font-size:21px; margin-bottom:10px; text-transform:uppercase; letter-spacing:.01em;}
.card p{color:var(--muted); font-size:16px; line-height:1.55;}

/* ---------- ESPACIOS ------------------------------------------------------- */
.spaces{display:grid; gap:16px; grid-template-columns:1fr 1fr;}
@media(min-width:820px){ .spaces{grid-template-columns:repeat(3,1fr);} }
.space{position:relative; border:1px solid var(--line); border-radius:var(--r); padding:28px 24px; background:#fff;
  box-shadow:0 14px 34px -32px rgba(0,0,0,.5); transition:transform .25s, border-color .25s, background .25s; overflow:hidden;}
.space:hover{transform:translateY(-5px); border-color:var(--red); background:rgba(232,71,42,.05);}
.space .ic{width:48px; height:48px; margin-bottom:18px;}
.space .ic svg{width:48px; height:48px; stroke:var(--red); fill:none; stroke-width:1.7; stroke-linecap:round; stroke-linejoin:round;}
.space h3{font-family:var(--f-head); font-weight:900; text-transform:uppercase; font-size:18px; letter-spacing:.01em;}
.space p{color:var(--muted); font-size:14.5px; margin-top:7px;}
.space .kr{position:absolute; right:14px; bottom:6px; font-size:40px; font-weight:900; color:var(--ink); opacity:.06;}

/* ---------- PROCESO (pasos numerados) -------------------------------------- */
.proc{background:var(--bg-2); border-top:1px solid var(--line); border-bottom:1px solid var(--line);}
.proc .kr-deco{top:-10%; left:-3%; opacity:.05;}
.steps{position:relative; z-index:2; display:grid; gap:8px; grid-template-columns:1fr;}
.step{display:grid; grid-template-columns:auto 1fr; gap:24px; align-items:start; padding:28px 0; border-top:1px solid var(--line-2);}
.step:last-child{border-bottom:1px solid var(--line-2);}
.step .sn{font-family:var(--f-cond); font-weight:900; font-size:clamp(46px,7vw,78px); line-height:.8; color:var(--red); min-width:1.6em;}
.step .sb h3{font-family:var(--f-head); font-weight:900; text-transform:uppercase; font-size:clamp(22px,3vw,30px); margin-bottom:8px;}
.step .sb p{color:var(--muted); font-size:17px; max-width:48em;}
@media(min-width:820px){ .step{grid-template-columns:auto 1fr; gap:40px; align-items:center;} }

/* ---------- RESPALDO DE MARCA ---------------------------------------------- */
.trust{text-align:center; background:var(--bg);}
.trust .kr-deco{top:50%; left:50%; transform:translate(-50%,-50%); opacity:.04;}
.trust .lbl{font-family:var(--f-head); font-weight:700; text-transform:uppercase; letter-spacing:.1em; font-size:13px; color:var(--muted); margin-bottom:30px; position:relative; z-index:2;}
.logos{position:relative; z-index:2; display:flex; flex-wrap:wrap; gap:16px; justify-content:center; align-items:center;}
.logo-card{background:#fff; border:1px solid var(--line); border-radius:12px; height:78px; min-width:170px; display:flex; align-items:center; justify-content:center; padding:0 24px; box-shadow:0 14px 30px -26px rgba(0,0,0,.5);}
.logo-card img{max-height:42px; width:auto;}
.logo-card.txt{background:var(--ink); border-color:var(--ink); color:#fff; font-family:var(--f-head); font-weight:900; text-transform:uppercase; letter-spacing:.02em; font-size:16px;}
.trust .places{position:relative; z-index:2; margin-top:30px; display:flex; flex-wrap:wrap; gap:10px; justify-content:center;}

/* ---------- FORMULARIO ----------------------------------------------------- */
.form-sec{background:var(--bg-2); border-top:1px solid var(--line);}
.form-wrap{position:relative; z-index:2; max-width:920px; margin:0 auto;}
.form-card{background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:34px; box-shadow:0 40px 90px -50px rgba(0,0,0,.5);}
@media(min-width:680px){ .form-card{padding:48px;} }
.form-row{display:grid; gap:18px; grid-template-columns:1fr;}
@media(min-width:560px){ .form-row.two{grid-template-columns:1fr 1fr;} }
.field{display:flex; flex-direction:column; gap:8px; margin-bottom:18px;}
.field label{font-family:var(--f-head); font-weight:700; text-transform:uppercase; font-size:12.5px; letter-spacing:.05em; color:var(--muted);}
.field label .req{color:var(--red);}
.field input,.field select,.field textarea{
  font-family:var(--f-body); font-size:16px; color:var(--ink); background:var(--bg-3);
  border:1.5px solid var(--line-2); border-radius:11px; padding:14px 16px; width:100%; appearance:none; transition:border-color .2s, box-shadow .2s;}
.field input::placeholder,.field textarea::placeholder{color:var(--muted-2);}
.field input:focus,.field select:focus,.field textarea:focus{outline:none; border-color:var(--red); box-shadow:0 0 0 3px rgba(232,71,42,.18);}
.field select{color:var(--ink);} .field select option{color:#111;}
.field textarea{resize:vertical; min-height:120px;}
.select-wrap{position:relative;}
.select-wrap::after{content:""; position:absolute; right:18px; top:50%; width:9px; height:9px; border-right:2px solid var(--muted); border-bottom:2px solid var(--muted); transform:translateY(-70%) rotate(45deg); pointer-events:none;}
.form-card .btn{margin-top:8px; font-size:17px; padding:18px;}
.form-foot{margin-top:14px; font-size:13px; color:var(--muted-2); text-align:center;}
/* éxito */
.form-success{display:none; text-align:center; padding:30px 10px;}
.form-success.on{display:block;}
.form-success .chk{width:78px; height:78px; border-radius:50%; background:rgba(232,71,42,.12); display:flex; align-items:center; justify-content:center; margin:0 auto 22px;}
.form-success .chk svg{width:40px; height:40px; stroke:var(--red); fill:none; stroke-width:3; stroke-linecap:round; stroke-linejoin:round;}
.form-success h3{font-family:var(--f-cond); font-weight:900; text-transform:uppercase; font-size:clamp(30px,5vw,46px); margin-bottom:12px;}
.form-success p{color:var(--muted); font-size:18px; max-width:34em; margin:0 auto;}
.is-hidden{display:none !important;}

/* ---------- FOOTER (oscuro) ------------------------------------------------ */
.footer{background:var(--dark); color:#fff; border-top:3px solid var(--red); padding:70px 0 30px;}
.footer-top{display:grid; gap:40px; grid-template-columns:1fr;}
@media(min-width:860px){ .footer-top{grid-template-columns:1.4fr 1fr 1fr;} }
.footer .f-logo{height:74px; margin-bottom:18px;}
.footer .f-tag{color:#b8b4ab; font-size:15px; max-width:30ch;}
.fcol h4{font-family:var(--f-head); font-weight:900; text-transform:uppercase; letter-spacing:.06em; font-size:13px; color:#8a8780; margin-bottom:18px;}
.fcol a{display:flex; gap:9px; align-items:flex-start; color:#d8d4cc; font-size:15px; margin-bottom:12px; transition:color .2s;}
.fcol a:hover{color:var(--yellow);}
.fcol a .pin{color:var(--red);}
.socials{display:flex; gap:12px; margin-top:6px;}
.socials a{width:44px; height:44px; border-radius:50%; border:1px solid rgba(255,255,255,.18); display:flex; align-items:center; justify-content:center; transition:.2s;}
.socials a:hover{background:var(--red); border-color:var(--red); transform:translateY(-3px);}
.socials svg{width:19px; height:19px; fill:#fff;}
.f-bottom{border-top:1px solid rgba(255,255,255,.12); margin-top:50px; padding-top:24px; display:flex; flex-wrap:wrap; gap:10px; justify-content:space-between; color:#8a8780; font-size:13px;}
.f-bottom a{color:var(--yellow);}

/* ---------- REVEAL (a prueba de fallos) ------------------------------------ */
.js .reveal{opacity:0;}
.js .reveal.in{animation:revealUp .7s cubic-bezier(.16,.84,.44,1) both;}
.js .reveal.d1.in{animation-delay:.07s;} .js .reveal.d2.in{animation-delay:.14s;}
.js .reveal.d3.in{animation-delay:.21s;} .js .reveal.d4.in{animation-delay:.28s;} .js .reveal.d5.in{animation-delay:.35s;}
.js .reveal.shown{opacity:1 !important; transform:none !important; animation:none !important;}
@keyframes revealUp{from{opacity:0; transform:translateY(28px);} to{opacity:1; transform:none;}}
@media(prefers-reduced-motion:reduce){ .js .reveal{opacity:1;} .js .reveal.in{animation:none;} .hero-media .heart{animation:none;} html{scroll-behavior:auto;} }
