/* P3 Properties — estilos web v1.0 */
:root{
  --azul:#0E2A47; --noche:#081A2E; --oro:#C2A35A; --oro-d:#a9893f;
  --marfil:#F5F1E8; --blanco:#fff; --piedra:#5B6470; --carbon:#1B1F24;
  --verde:#2E7D5B; --rojo:#B23A3A;
  --serif:'Fraunces',Georgia,serif; --sans:'Inter',Arial,sans-serif;
  --maxw:1120px; --r:14px;
  --shadow:0 14px 40px rgba(14,42,71,.10);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--carbon);background:var(--marfil);line-height:1.65;-webkit-font-smoothing:antialiased}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;color:var(--azul);line-height:1.12;letter-spacing:.01em}
strong{font-weight:600;color:inherit}

/* ---- helpers ---- */
.eyebrow{display:inline-block;font-size:12px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--oro-d)}
.eyebrow.center,.center{text-align:center}
.eyebrow.center{display:block}
.sub{color:var(--piedra);max-width:60ch;margin:12px auto 0}
.light{color:var(--marfil)}
.muted{color:var(--piedra)}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--sans);font-weight:600;font-size:15px;padding:13px 24px;border-radius:99px;border:1.5px solid transparent;cursor:pointer;transition:.18s ease;white-space:nowrap}
.btn-gold{background:var(--oro);color:var(--azul)}
.btn-gold:hover{background:var(--oro-d);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--marfil);border-color:rgba(245,241,232,.4)}
.btn-ghost:hover{border-color:var(--oro);color:var(--oro)}
.btn-wa{background:var(--azul);color:var(--marfil);padding:10px 20px;font-size:14px}
.btn-wa:hover{background:var(--noche)}
.btn.full{width:100%}

/* ---- nav ---- */
.nav{position:sticky;top:0;z-index:50;background:rgba(245,241,232,.92);backdrop-filter:blur(10px);border-bottom:1px solid #e7e0d2}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:72px;gap:20px}
.brand{display:flex;align-items:center;gap:12px}
.b-mono{font-family:var(--serif);font-weight:500;font-size:34px;color:var(--azul);line-height:1}
.b-mono.light{color:var(--marfil)}
.b-stack{display:flex;flex-direction:column;border-left:1.5px solid var(--oro);padding-left:11px}
.b-stack b{font-size:13px;font-weight:600;letter-spacing:.18em;color:var(--azul)}
.b-stack span{font-size:8.5px;letter-spacing:.18em;color:var(--piedra);margin-top:2px}
.nav-links{display:flex;gap:28px}
.nav-links a{font-size:14.5px;font-weight:500;color:var(--carbon);transition:color .15s}
.nav-links a:hover{color:var(--oro-d)}

/* ---- hero ---- */
.hero{background:linear-gradient(160deg,#143456,var(--azul) 55%,var(--noche));color:var(--marfil);overflow:hidden}
.hero-in{display:grid;grid-template-columns:1.3fr .7fr;align-items:center;gap:40px;padding:84px 24px 92px}
.hero .eyebrow{color:var(--oro)}
.hero h1{color:#fff;font-size:clamp(40px,6vw,68px);margin:18px 0 0}
.lead{font-size:clamp(16px,2vw,19px);color:#cdd7e2;max-width:46ch;margin-top:20px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:32px}
.hero-note{margin-top:30px;font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--oro)}
.hero-seal{display:flex;justify-content:center}
.seal{width:260px;height:260px;max-width:100%}

/* ---- banner ---- */
.banner{background:var(--oro);color:var(--azul)}
.banner .wrap{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;padding:13px 24px;font-size:14.5px;font-weight:500}
.banner a{font-weight:700;text-decoration:underline;text-underline-offset:3px}

/* ---- sections ---- */
.section{padding:84px 0}
.section.alt{background:var(--blanco)}
.section h2{font-size:clamp(28px,4vw,38px)}

/* ---- cards 3 ---- */
.cards-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:44px}
.card{background:var(--blanco);border:1px solid #e7e0d2;border-radius:var(--r);padding:30px 26px;position:relative;transition:.2s}
.section.alt .card{background:var(--marfil)}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.card-k{font-family:var(--serif);font-size:15px;color:var(--oro-d);font-weight:600}
.card h3{font-size:23px;margin:8px 0 10px}
.card p{color:var(--piedra);font-size:15px}
.card.highlight{border-color:var(--oro);box-shadow:0 0 0 1px var(--oro) inset}
.ribbon{position:absolute;top:18px;right:18px;background:var(--oro);color:var(--azul);font-size:11px;font-weight:700;letter-spacing:.04em;padding:4px 11px;border-radius:99px;text-transform:uppercase}

/* ---- band (diferenciador / contacto) ---- */
.band{background:linear-gradient(160deg,var(--azul),var(--noche));color:var(--marfil);padding:88px 0}
.band-in{display:grid;grid-template-columns:1.2fr .8fr;gap:48px;align-items:center}
.band .eyebrow{color:var(--oro)}
.band h2{font-size:clamp(28px,4vw,40px);margin-top:14px}
.band-lead{color:#cdd7e2;margin-top:18px;font-size:16.5px;max-width:52ch}
.check{list-style:none;margin-top:24px;display:grid;gap:12px}
.check li{position:relative;padding-left:30px;color:#e7ecf2;font-size:15.5px}
.check li::before{content:"✓";position:absolute;left:0;top:-1px;color:var(--azul);background:var(--oro);width:20px;height:20px;border-radius:50%;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center}
.band-quote{background:rgba(255,255,255,.04);border:1px solid rgba(194,163,90,.3);border-radius:var(--r);padding:34px}
.band-quote p{font-family:var(--serif);font-style:italic;font-size:24px;color:#fff;line-height:1.3}
.band-quote .line{display:block;width:46px;height:2px;background:var(--oro);margin:18px 0 14px}
.band-quote .by{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--oro)}

/* ---- steps ---- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:46px}
.step{position:relative;padding-top:14px}
.step-n{font-family:var(--serif);font-size:40px;font-weight:500;color:var(--oro);display:block;line-height:1}
.step h4{font-size:19px;margin:10px 0 8px}
.step p{color:var(--piedra);font-size:14.5px}

/* ---- quiénes somos (texto) ---- */
.about-text{max-width:64ch;margin:30px auto 0;text-align:center}
.about-text p{color:var(--piedra);font-size:17px;margin-bottom:18px}
.about-text p:last-child{margin-bottom:0}
.about-text strong{color:var(--azul)}

/* ---- team (legacy, sin uso) ---- */
.team{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:44px}
.member{background:var(--blanco);border:1px solid #e7e0d2;border-radius:var(--r);padding:32px 26px;text-align:center}
.ava{width:78px;height:78px;border-radius:50%;background:var(--azul);color:var(--oro);border:2px solid var(--oro);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:30px;font-weight:500;margin:0 auto 16px}
.member h4{font-size:20px}
.member .role{display:block;font-size:12.5px;font-weight:600;letter-spacing:.04em;color:var(--oro-d);text-transform:uppercase;margin:6px 0 12px}
.member p{color:var(--piedra);font-size:14.5px}

/* ---- contacto ---- */
.contact{background:linear-gradient(160deg,var(--azul),var(--noche));color:var(--marfil)}
.contact-in{display:grid;grid-template-columns:.9fr 1.1fr;gap:48px;align-items:start}
.contact h2{font-size:clamp(28px,4vw,38px);margin-top:14px}
.contact .eyebrow{color:var(--oro)}
.contact-list{list-style:none;margin-top:30px;display:grid;gap:16px}
.contact-list li{display:flex;flex-direction:column;gap:2px;border-top:1px solid rgba(255,255,255,.12);padding-top:14px}
.contact-list span{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--oro)}
.contact-list a{font-size:17px;color:#fff}
.contact-list a:hover{color:var(--oro)}

/* ---- form ---- */
.form{background:var(--marfil);border-radius:18px;padding:32px;box-shadow:var(--shadow)}
.field{margin-bottom:16px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--azul);margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;font-family:var(--sans);font-size:15px;color:var(--carbon);background:var(--blanco);border:1.5px solid #ddd5c4;border-radius:10px;padding:12px 14px;transition:border-color .15s, box-shadow .15s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--oro);box-shadow:0 0 0 3px rgba(194,163,90,.18)}
.field input.err,.field textarea.err{border-color:var(--rojo);box-shadow:0 0 0 3px rgba(178,58,58,.12)}
.field textarea{resize:vertical}
.hp{position:absolute;left:-9999px;opacity:0;pointer-events:none}
.form-msg{font-size:14px;font-weight:600;margin-top:14px;min-height:20px;text-align:center}
.form-msg.ok{color:var(--verde)}
.form-msg.bad{color:var(--rojo)}
.form-fine{font-size:12px;color:var(--piedra);text-align:center;margin-top:10px}
.btn-gold.full{margin-top:6px}

/* ---- footer ---- */
.footer{background:var(--noche);color:#9fb0c2}
.footer-in{display:flex;justify-content:space-between;align-items:center;gap:30px;padding:46px 24px;flex-wrap:wrap}
.footer-brand{display:flex;align-items:center;gap:16px}
.footer-brand .b-mono{font-size:48px}
.footer-brand p{font-family:var(--serif);font-style:italic;color:var(--marfil);font-size:16px;line-height:1.4}
.footer-brand .muted{font-style:normal;font-family:var(--sans);font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--oro)}
.footer-nav{display:flex;gap:22px;flex-wrap:wrap}
.footer-nav a{font-size:14px;color:#c3cedb}
.footer-nav a:hover{color:var(--oro)}
.footer-bar{border-top:1px solid rgba(255,255,255,.08)}
.footer-bar .wrap{display:flex;justify-content:space-between;padding:18px 24px;font-size:12.5px;color:#7e8da0;flex-wrap:wrap;gap:8px}

/* ---- responsive ---- */
@media(max-width:920px){
  .nav-links{display:none}
  .hero-in{grid-template-columns:1fr;text-align:center}
  .hero .eyebrow{margin:0 auto}
  .lead{margin-left:auto;margin-right:auto}
  .hero-cta{justify-content:center}
  .hero-seal{order:-1}
  .seal{width:180px;height:180px}
  .band-in,.contact-in{grid-template-columns:1fr;gap:32px}
  .steps{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:680px){
  .cards-3,.team{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
  .b-stack{display:none}
  .section{padding:60px 0}
}
