/* ============================================================
   Escuela IA LatAm — styles.css
   v1 producción · paleta 80/15/5 · papel + tinta + sello terracota
   Extraído del HTML de identidad v0.3, productizado y responsive.
   ============================================================ */

:root{
  --paper:    #f5efe1;
  --paper-2:  #efe8d6;
  --paper-3:  #fbf7ec;
  --ink:      #1a1a1a;
  --ink-soft: #3a3a3a;
  --ink-faint:#8a8276;
  --accent:   #c8442a; /* sello terracota */
  --accent-2: #8a5a2b; /* tabaco */

  --hand:    'Kalam', cursive;
  --note:    'Caveat', cursive;
  --sans:    'Inter', system-ui, sans-serif;
  --serif:   'Fraunces', Georgia, serif;
  --serif-2: 'Newsreader', Georgia, serif;
  --mono:    'JetBrains Mono', monospace;
}

*{box-sizing:border-box}
html,body{margin:0; padding:0; background:var(--paper); color:var(--ink); font-family:var(--sans);}
body{
  background-image:
    radial-gradient(circle at 15% 12%, rgba(0,0,0,.025) 0, transparent 60%),
    radial-gradient(circle at 85% 88%, rgba(0,0,0,.03) 0, transparent 55%),
    repeating-linear-gradient(180deg, transparent 0 38px, rgba(31,40,40,.05) 38px 39px);
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;}

/* ===== layout container ===== */
.site{padding:0 60px; max-width:1320px; margin:0 auto;}

/* ===== nav ===== */
.site-nav{
  display:flex; justify-content:space-between; align-items:center;
  padding:22px 0 18px;
  border-bottom:1.2px solid var(--ink);
  flex-wrap:wrap; gap:16px;
}
.site-nav .brand{display:flex; align-items:baseline; gap:8px; text-decoration:none;}
.site-nav .brand .e{font-family:var(--serif); font-size:22px; font-weight:600; letter-spacing:-.4px; color:var(--ink);}
.site-nav .brand .ia{font-family:var(--serif); font-size:22px; font-weight:700; color:var(--accent); font-style:italic;}
.site-nav .brand .latam{font-family:var(--mono); font-size:10px; letter-spacing:.25em; color:var(--ink-faint); margin-left:2px;}
.site-nav .nav-links{display:flex; gap:24px; font-family:var(--serif); font-size:15px;}
.site-nav .nav-links a{color:var(--ink); text-decoration:none;}
.site-nav .nav-links a:hover{color:var(--accent);}
.site-nav .nav-links a.active{color:var(--accent); font-weight:600;}
.site-nav .cta{
  padding:8px 14px; background:var(--ink); color:var(--paper);
  font-family:var(--serif); font-size:14px; font-weight:600;
  border-radius:4px; text-decoration:none;
}
.site-nav .cta:hover{background:var(--accent);}

/* ===== hero ===== */
.site-hero{
  padding:60px 0 50px; display:grid; grid-template-columns:1.4fr 1fr; gap:50px; align-items:start;
  border-bottom:1.2px solid var(--ink);
}
.site-hero h1{
  font-family:var(--serif); font-size:64px; line-height:1; margin:0;
  font-weight:700; letter-spacing:-2.5px;
  text-wrap:balance;
}
.site-hero h1 em{font-family:var(--serif); font-style:italic; color:var(--accent); font-weight:700;}
.site-hero h1 .underline{text-decoration:underline; text-decoration-color:var(--accent); text-decoration-thickness:3px; text-underline-offset:6px;}
.site-hero .lede{font-family:var(--serif-2); font-size:21px; line-height:1.45; margin:20px 0 0; font-weight:400;}
.site-hero .lede em{font-family:var(--note); font-style:normal; color:var(--accent); font-size:26px;}
.site-hero .pre{font-family:var(--mono); font-size:11px; letter-spacing:.22em; color:var(--accent); text-transform:uppercase; margin-bottom:14px; font-weight:500;}
.site-hero .ctas{display:flex; gap:14px; margin-top:24px; flex-wrap:wrap;}
.site-hero .btn-1{
  padding:14px 22px; background:var(--ink); color:var(--paper);
  font-family:var(--serif); font-size:16px; font-weight:600;
  border-radius:5px; text-decoration:none;
  box-shadow:3px 3px 0 var(--accent);
  display:inline-flex; align-items:center; gap:8px;
  transition:transform .12s;
}
.site-hero .btn-1:hover{transform:translate(-1px,-1px); box-shadow:4px 4px 0 var(--accent);}
.site-hero .btn-2{
  padding:14px 22px; background:transparent; color:var(--ink);
  font-family:var(--serif); font-size:16px; font-weight:500;
  border:1.5px solid var(--ink); border-radius:5px; text-decoration:none;
  display:inline-flex; align-items:center; gap:8px;
}
.site-hero .btn-2:hover{background:var(--ink); color:var(--paper);}

.site-hero .side{
  padding:20px;
  border:1.5px solid var(--ink); border-radius:6px;
  background:var(--paper); position:relative;
  box-shadow:3px 3px 0 var(--ink);
}
.site-hero .side .lab{font-family:var(--mono); font-size:10px; letter-spacing:.18em; color:var(--ink-faint); text-transform:uppercase; margin-bottom:8px;}
.site-hero .side h4{font-family:var(--serif); font-size:22px; margin:0 0 4px; font-weight:600;}
.site-hero .side .when{font-family:var(--hand); font-size:16px; color:var(--ink-soft);}
.site-hero .side .progress{display:flex; gap:4px; margin:14px 0 10px;}
.site-hero .side .progress .seat{flex:1; height:14px; border:1.2px solid var(--ink); border-radius:2px; background:var(--accent);}
.site-hero .side .progress .seat.empty{background:var(--paper-3);}
.site-hero .side .seats-line{font-family:var(--hand); font-size:15px;}
.site-hero .side .seats-line b{color:var(--accent);}
.site-hero .side .side-cta{
  display:inline-block; margin-top:14px; padding:8px 14px;
  border:1.5px solid var(--ink); border-radius:4px;
  background:var(--ink); color:var(--paper);
  font-family:var(--serif); font-weight:600; font-size:14px; text-decoration:none;
}
.site-hero .side .side-cta:hover{background:var(--accent); border-color:var(--accent);}

/* ===== strip ===== */
.strip{padding:18px 0; border-bottom:1.2px solid var(--ink); display:flex; gap:32px; align-items:center; font-family:var(--mono); font-size:11px; letter-spacing:.18em; color:var(--ink-faint); text-transform:uppercase; flex-wrap:wrap;}
.strip .pill{padding:4px 10px; border:1.2px solid var(--ink); border-radius:99px; background:var(--paper); color:var(--ink); letter-spacing:.12em;}

/* ===== products ===== */
.site-products{
  padding:60px 0 40px; display:grid; grid-template-columns:1fr 1fr; gap:30px;
  border-bottom:1.2px solid var(--ink);
}
.p-card{
  border:1.5px solid var(--ink); border-radius:6px; padding:28px;
  background:var(--paper); position:relative;
  box-shadow:4px 4px 0 var(--ink);
}
.p-card .badge{
  position:absolute; top:-12px; left:24px;
  font-family:var(--mono); font-size:10px; letter-spacing:.18em; color:var(--ink-faint);
  background:var(--paper); padding:0 8px; text-transform:uppercase;
}
.p-card h3{font-family:var(--serif); font-size:32px; margin:0 0 4px; font-weight:700; letter-spacing:-.6px;}
.p-card .price{font-family:var(--serif); font-size:46px; font-weight:700; color:var(--accent); line-height:1;}
.p-card .price small{font-family:var(--mono); font-size:13px; color:var(--ink-soft); font-weight:400; letter-spacing:.1em;}
.p-card .pitch{font-family:var(--note); font-size:24px; color:var(--ink-soft); margin:6px 0 16px;}
.p-card ul{font-family:var(--serif-2); font-size:16px; line-height:1.55; margin:0 0 14px; padding-left:18px;}
.p-card ul li{padding:2px 0;}
.p-card .meta-line{font-family:var(--mono); font-size:11px; color:var(--ink-faint); letter-spacing:.1em; margin-top:14px; padding-top:12px; border-top:1px dashed rgba(0,0,0,.25);}
.p-card .card-cta{
  display:inline-block; margin-top:8px; padding:10px 16px;
  border:1.5px solid var(--ink); border-radius:5px;
  background:var(--ink); color:var(--paper);
  font-family:var(--serif); font-weight:600; font-size:14px; text-decoration:none;
}
.p-card .card-cta:hover{background:var(--accent); border-color:var(--accent);}

/* ===== pistas (arco del curso) ===== */
.site-pistas{padding:56px 0 50px; border-bottom:1.2px solid var(--ink);}
.site-pistas h2{font-family:var(--serif); font-size:42px; margin:0 0 8px; font-weight:700; letter-spacing:-1px;}
.site-pistas .h-sub{font-family:var(--note); font-size:24px; color:var(--accent); margin-bottom:24px;}
.pistas-grid{display:grid; grid-template-columns:repeat(4, 1fr); gap:16px;}
.pista-card{
  border:1.5px solid var(--ink); border-radius:5px; padding:18px;
  background:var(--paper); position:relative;
  transition:transform .15s;
}
.pista-card:hover{transform:translateY(-3px); box-shadow:3px 3px 0 var(--accent);}
.pista-card .code{font-family:var(--mono); font-size:10px; color:var(--ink-faint); letter-spacing:.18em;}
.pista-card h4{font-family:var(--serif); font-size:20px; margin:4px 0 6px; font-weight:600; letter-spacing:-.3px;}
.pista-card p{font-family:var(--serif-2); font-size:14px; line-height:1.45; margin:0 0 10px; color:var(--ink-soft);}
.pista-card .formats{display:flex; gap:6px; font-family:var(--mono); font-size:10px; flex-wrap:wrap;}
.pista-card .formats span{padding:2px 6px; border:1px solid var(--ink); border-radius:99px; background:var(--paper-3);}
.pista-card .formats .live{background:var(--accent); color:var(--paper); border-color:var(--accent);}

/* ===== proof ===== */
.site-proof{padding:56px 0; border-bottom:1.2px solid var(--ink); display:grid; grid-template-columns:1fr 1.4fr; gap:50px; align-items:center;}
.site-proof .quote{font-family:var(--serif-2); font-size:32px; line-height:1.3; font-weight:400; letter-spacing:-.3px;}
.site-proof .quote::before{content:'"'; font-family:var(--serif); font-size:90px; color:var(--accent); line-height:.4; vertical-align:-30px; margin-right:6px;}
.site-proof .by{font-family:var(--mono); font-size:11px; color:var(--ink-faint); letter-spacing:.15em; margin-top:18px; text-transform:uppercase;}
.proof-stats{display:grid; grid-template-columns:repeat(2,1fr); gap:18px;}
.proof-stat{
  border:1.5px solid var(--ink); border-radius:5px; padding:18px;
  background:var(--paper);
}
.proof-stat .big{font-family:var(--serif); font-size:48px; font-weight:700; color:var(--accent); line-height:1; letter-spacing:-1.5px;}
.proof-stat .lab{font-family:var(--hand); font-size:14px; line-height:1.4; color:var(--ink-soft); margin-top:6px;}

/* ===== method ===== */
.site-method{padding:56px 0; border-bottom:1.2px solid var(--ink);}
.site-method h2{font-family:var(--serif); font-size:42px; margin:0 0 8px; font-weight:700; letter-spacing:-1px;}
.site-method .h-sub{font-family:var(--note); font-size:24px; color:var(--accent); margin-bottom:24px;}
.method-grid{display:grid; grid-template-columns:repeat(4, 1fr); gap:18px;}
.method-step{
  border:1.5px solid var(--ink); border-radius:5px; padding:18px;
  background:var(--paper-3); position:relative;
}
.method-step .n{font-family:var(--serif); font-size:42px; font-weight:700; color:var(--accent); line-height:1; letter-spacing:-2px;}
.method-step h5{font-family:var(--serif); font-size:18px; margin:8px 0 4px; font-weight:600;}
.method-step p{font-family:var(--serif-2); font-size:14px; margin:0; line-height:1.5; color:var(--ink-soft);}

/* ===== team ===== */
.site-team{padding:56px 0; border-bottom:1.2px solid var(--ink); display:grid; grid-template-columns:1fr 1fr; gap:50px;}
.teacher{display:flex; gap:18px;}
.teacher .avatar{
  width:80px; height:80px; border-radius:50%; border:1.5px solid var(--ink);
  background:repeating-linear-gradient(45deg, rgba(0,0,0,.08) 0 4px, transparent 4px 10px);
  flex:0 0 80px;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--serif); font-size:26px; font-weight:700; color:var(--ink-soft);
}
.teacher h4{font-family:var(--serif); font-size:22px; margin:0 0 4px; font-weight:600;}
.teacher .role{font-family:var(--mono); font-size:10px; letter-spacing:.15em; color:var(--accent); text-transform:uppercase;}
.teacher p{font-family:var(--serif-2); font-size:15px; line-height:1.5; margin:8px 0 0; color:var(--ink-soft);}

/* ===== form (reservar plaza / probar asíncrono) ===== */
.site-form{padding:60px 0; border-bottom:1.2px solid var(--ink);}
.site-form h2{font-family:var(--serif); font-size:42px; margin:0 0 8px; font-weight:700; letter-spacing:-1px;}
.site-form .h-sub{font-family:var(--note); font-size:24px; color:var(--accent); margin-bottom:24px;}
.form-grid{display:grid; grid-template-columns:1.2fr 1fr; gap:50px; align-items:start;}
.form-grid .form-intro{font-family:var(--serif-2); font-size:17px; line-height:1.55; color:var(--ink-soft);}
.form-grid .form-intro p{margin:0 0 12px;}
.form-grid .form-card{
  border:1.5px solid var(--ink); border-radius:6px; padding:24px;
  background:var(--paper); box-shadow:4px 4px 0 var(--ink);
}
.form-card label{display:block; font-family:var(--mono); font-size:10px; letter-spacing:.16em; color:var(--ink-faint); margin:14px 0 6px; text-transform:uppercase;}
.form-card label:first-child{margin-top:0;}
.form-card input, .form-card select, .form-card textarea{
  width:100%; padding:10px 12px;
  border:1.2px solid var(--ink); border-radius:4px;
  background:var(--paper-3); color:var(--ink);
  font-family:var(--serif-2); font-size:15px;
}
.form-card textarea{min-height:80px; resize:vertical;}
.form-card input:focus, .form-card select:focus, .form-card textarea:focus{outline:none; border-color:var(--accent); box-shadow:0 0 0 2px rgba(200,68,42,.15);}
.form-card button{
  margin-top:18px; padding:12px 22px;
  background:var(--ink); color:var(--paper);
  border:none; border-radius:5px; cursor:pointer;
  font-family:var(--serif); font-weight:600; font-size:16px;
  box-shadow:3px 3px 0 var(--accent);
  transition:transform .12s;
}
.form-card button:hover{transform:translate(-1px,-1px); box-shadow:4px 4px 0 var(--accent);}
.form-card .fine{font-family:var(--mono); font-size:10px; color:var(--ink-faint); letter-spacing:.08em; margin-top:14px;}

/* ===== footer ===== */
.site-foot{padding:36px 0 30px;}
.site-foot .row{display:flex; justify-content:space-between; align-items:baseline; font-family:var(--mono); font-size:11px; color:var(--ink-faint); letter-spacing:.1em; gap:14px; flex-wrap:wrap;}
.site-foot .row a{color:var(--ink-faint); text-decoration:none;}
.site-foot .row a:hover{color:var(--accent);}
.site-foot .brand{font-family:var(--serif); font-size:20px; font-weight:600; color:var(--ink); letter-spacing:-.4px;}
.site-foot .brand .ia{color:var(--accent); font-style:italic;}

/* ===== inner-page helpers ===== */
.page-head{padding:48px 0 24px; border-bottom:1.2px solid var(--ink);}
.page-head .crumb{font-family:var(--mono); font-size:11px; letter-spacing:.18em; color:var(--ink-faint); text-transform:uppercase; margin-bottom:10px;}
.page-head h1{font-family:var(--serif); font-size:54px; line-height:1.05; margin:0; font-weight:700; letter-spacing:-2px; text-wrap:balance;}
.page-head h1 em{font-family:var(--serif); font-style:italic; color:var(--accent);}
.page-head .lede{font-family:var(--serif-2); font-size:20px; line-height:1.5; margin:16px 0 0; color:var(--ink-soft); max-width:720px;}

.prose{padding:48px 0; max-width:760px; font-family:var(--serif-2); font-size:17px; line-height:1.65;}
.prose h2{font-family:var(--serif); font-size:30px; margin:36px 0 12px; font-weight:700; letter-spacing:-.6px;}
.prose h3{font-family:var(--serif); font-size:22px; margin:28px 0 8px; font-weight:600;}
.prose p{margin:0 0 14px;}
.prose ul{padding-left:20px; margin:0 0 14px;}
.prose ul li{padding:3px 0;}
.prose em{font-family:var(--serif); font-style:italic; color:var(--accent);}

/* ===== utility ===== */
.accent{color:var(--accent);}
.serif{font-family:var(--serif);}
.hand{font-family:var(--hand);}
.mono{font-family:var(--mono);}
.note{font-family:var(--note);}

/* ===== responsive ===== */
@media (max-width: 980px){
  .site{padding:0 32px;}
  .site-hero{grid-template-columns:1fr; gap:30px;}
  .site-hero h1{font-size:48px; letter-spacing:-1.5px;}
  .site-products{grid-template-columns:1fr;}
  .pistas-grid{grid-template-columns:1fr 1fr;}
  .site-proof{grid-template-columns:1fr;}
  .method-grid{grid-template-columns:1fr 1fr;}
  .site-team{grid-template-columns:1fr; gap:30px;}
  .form-grid{grid-template-columns:1fr;}
  .page-head h1{font-size:42px; letter-spacing:-1.2px;}
}
@media (max-width: 620px){
  .site{padding:0 20px;}
  .site-nav{padding:18px 0 14px;}
  .site-nav .nav-links{gap:14px; font-size:14px;}
  .site-nav .nav-links a:not(.keep-mobile){display:none;}
  .site-hero{padding:40px 0 36px;}
  .site-hero h1{font-size:38px; letter-spacing:-1.2px;}
  .site-hero .lede{font-size:18px;}
  .site-hero .ctas{flex-direction:column; align-items:stretch;}
  .site-hero .btn-1, .site-hero .btn-2{justify-content:center;}
  .strip{gap:14px; font-size:10px;}
  .site-products{padding:36px 0 30px;}
  .p-card h3{font-size:26px;}
  .p-card .price{font-size:38px;}
  .pistas-grid{grid-template-columns:1fr;}
  .site-proof .quote{font-size:24px;}
  .proof-stats{grid-template-columns:1fr 1fr;}
  .method-grid{grid-template-columns:1fr;}
  .page-head h1{font-size:34px; letter-spacing:-1px;}
  .prose h2{font-size:24px;}
}
