/* =========================================================
   P35 — Sistema de diseño (hoja de estilos compartida)
   ========================================================= */
:root{
  --navy-900:#08182f;
  --navy-800:#0c2547;
  --navy-700:#123058;
  --blue-500:#1b5e9c;
  --cyan-400:#16a0d7;
  --cyan-300:#3cc0ef;
  --ink:#13202e;
  --slate:#5c6b7b;
  --slate-light:#8794a1;
  --cloud:#f4f7fa;
  --line:#e4eaf1;
  --white:#ffffff;
  --radius:16px;
  --maxw:1200px;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;color:var(--ink);background:var(--white);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%}
a{color:inherit}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
h1,h2,h3,h4,.wordmark{font-family:'Sora',sans-serif;letter-spacing:-.02em}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:12.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--cyan-400);margin-bottom:20px}
.eyebrow::before{content:"";width:28px;height:1.5px;background:currentColor;display:inline-block}

/* ===== Buttons ===== */
.btn{font-family:'Inter';font-weight:600;font-size:14.5px;border-radius:10px;padding:12px 22px;cursor:pointer;border:none;text-decoration:none;display:inline-flex;align-items:center;gap:8px;transition:transform .2s var(--ease),box-shadow .2s var(--ease),background .2s var(--ease)}
.btn svg{width:16px;height:16px}
.btn-primary{background:var(--cyan-400);color:#fff;box-shadow:0 6px 18px -6px rgba(22,160,215,.6)}
.btn-primary:hover{background:#1391c4;transform:translateY(-2px);box-shadow:0 12px 26px -8px rgba(22,160,215,.7)}
.btn-ghost{background:transparent;color:#dce8f4;border:1px solid rgba(220,232,244,.35)}
.btn-ghost:hover{border-color:var(--cyan-300);color:#fff;transform:translateY(-2px)}
.btn-dark{background:var(--navy-800);color:#fff}
.btn-dark:hover{background:var(--navy-700);transform:translateY(-2px)}

/* ===== Header ===== */
header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.9);backdrop-filter:saturate(160%) blur(12px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;gap:28px;height:84px}
.wordmark{display:flex;align-items:center;line-height:1;text-decoration:none}
.wordmark img{display:block;height:52px;width:auto}
nav.menu{display:flex;gap:22px;margin-left:6px}
nav.menu a{text-decoration:none;color:var(--slate);font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;position:relative;padding:4px 0;transition:color .2s var(--ease);white-space:nowrap}
nav.menu a:hover{color:var(--navy-800)}
nav.menu a.active{color:var(--navy-800)}
nav.menu a.active::after{content:"";position:absolute;left:0;bottom:-2px;width:100%;height:2px;background:var(--cyan-400);border-radius:2px}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:16px}
.socials{display:flex;gap:12px}
.socials a{color:var(--slate-light);transition:color .2s var(--ease),transform .2s var(--ease);display:flex}
.socials a:hover{color:var(--cyan-400);transform:translateY(-2px)}
.socials svg{width:17px;height:17px}
.menu-toggle{display:none;background:none;border:1px solid var(--line);border-radius:10px;width:46px;height:42px;cursor:pointer;align-items:center;justify-content:center}
.menu-toggle svg{width:22px;height:22px;stroke:var(--navy-800)}

/* ===== Home hero ===== */
.hero{position:relative;overflow:hidden;background:radial-gradient(900px 500px at 78% 18%, rgba(60,192,239,.22), transparent 60%),radial-gradient(700px 600px at 12% 90%, rgba(27,94,156,.35), transparent 55%),linear-gradient(135deg,var(--navy-900) 0%,var(--navy-700) 100%);color:#fff}
.hero-grid-svg{position:absolute;inset:0;width:100%;height:100%;opacity:.5;pointer-events:none}
.hero .wrap{position:relative;z-index:2;padding-top:96px;padding-bottom:104px}
.hero-inner{max-width:720px}
.hero .eyebrow{color:var(--cyan-300)}
.hero h1{font-size:clamp(34px,5.2vw,60px);font-weight:700;line-height:1.05;letter-spacing:-.03em;margin-bottom:24px}
.hero h1 .accent{background:linear-gradient(100deg,var(--cyan-300),#7fd8f5);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p.lead{font-size:clamp(16px,1.6vw,19px);color:#c4d4e4;max-width:600px;margin-bottom:38px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-stats{display:flex;gap:48px;margin-top:64px;padding-top:34px;border-top:1px solid rgba(255,255,255,.12);max-width:620px;flex-wrap:wrap}
.stat .num{font-family:'Sora';font-size:30px;font-weight:700;color:#fff;line-height:1}
.stat .num span{color:var(--cyan-300)}
.stat .lbl{font-size:13px;color:#9fb3c6;margin-top:6px}

/* ===== Inner page banner ===== */
.page-banner{position:relative;overflow:hidden;color:#fff;background:radial-gradient(700px 400px at 85% 10%, rgba(60,192,239,.20), transparent 60%),linear-gradient(135deg,var(--navy-900) 0%,var(--navy-700) 100%)}
.page-banner .wrap{padding:72px 32px 64px}
.page-banner .eyebrow{color:var(--cyan-300)}
.page-banner h1{font-size:clamp(30px,4.4vw,46px);font-weight:700;line-height:1.06;letter-spacing:-.03em;max-width:760px}
.page-banner p{color:#c4d4e4;font-size:clamp(15px,1.5vw,18px);max-width:620px;margin-top:16px}

/* ===== Sections ===== */
.section{padding:88px 0}
.section.alt{background:var(--cloud)}
.section-head{max-width:720px;margin-bottom:52px}
.section-head h2{font-size:clamp(26px,3.2vw,38px);font-weight:700;color:var(--navy-800);line-height:1.12;margin-bottom:14px}
.section-head p{color:var(--slate);font-size:17px}
.prose p{color:var(--slate);font-size:16.5px;margin-bottom:18px;max-width:760px}
.prose p:last-child{margin-bottom:0}

/* ===== Grid + cards ===== */
.grid{display:grid;gap:24px}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:34px 30px 30px;position:relative;transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease);overflow:hidden}
.card::before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,var(--cyan-400),var(--blue-500));transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease)}
.card:hover{transform:translateY(-6px);box-shadow:0 24px 48px -22px rgba(12,37,71,.4);border-color:transparent}
.card:hover::before{transform:scaleX(1)}
.card .icon{width:58px;height:58px;border-radius:14px;background:linear-gradient(135deg,#eaf5fb,#dcecf6);display:flex;align-items:center;justify-content:center;margin-bottom:22px;transition:background .3s var(--ease);flex:none}
.card:hover .icon{background:linear-gradient(135deg,var(--cyan-400),var(--blue-500))}
.card .icon svg{width:30px;height:30px;stroke:var(--blue-500);fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;transition:stroke .3s var(--ease)}
.card:hover .icon svg{stroke:#fff}
.card h3{font-size:19px;font-weight:600;color:var(--navy-800);margin-bottom:10px}
.card p{color:var(--slate);font-size:15px;margin-bottom:8px}
.card p+p{margin-top:8px}
.card .more{font-size:14px;font-weight:600;color:var(--cyan-400);text-decoration:none;display:inline-flex;align-items:center;gap:6px;margin-top:8px}
.card .more svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round;transition:transform .25s var(--ease)}
.card:hover .more svg{transform:translateX(4px)}

/* ===== Values list ===== */
.values{display:grid;grid-template-columns:repeat(2,1fr);gap:10px 28px;margin-top:6px}
.values li{list-style:none;display:flex;align-items:center;gap:10px;color:var(--slate);font-size:15.5px}
.values li::before{content:"";width:7px;height:7px;border-radius:2px;background:var(--cyan-400);flex:none}

/* ===== Sectors grid ===== */
.sectors{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:16px}
.sector{position:relative;overflow:hidden;display:flex;flex-direction:column;align-items:flex-start;gap:14px;min-height:152px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px 20px;text-decoration:none;color:var(--navy-800);transition:transform .25s var(--ease),box-shadow .25s var(--ease),border-color .25s var(--ease)}
.sector:hover{transform:translateY(-3px);border-color:transparent;box-shadow:0 18px 34px -20px rgba(12,37,71,.5)}
.sector .se-ic{width:46px;height:46px;border-radius:12px;background:linear-gradient(135deg,#eaf5fb,#dcecf6);display:flex;align-items:center;justify-content:center;flex:none;transition:background .25s var(--ease)}
.sector:hover .se-ic{background:linear-gradient(135deg,var(--cyan-400),var(--blue-500))}
.sector .se-ic svg{width:24px;height:24px;stroke:var(--blue-500);fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;transition:stroke .25s var(--ease)}
.sector:hover .se-ic svg{stroke:#fff}
.sector .name{font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;line-height:1.25}
.sector .se-over{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;text-align:center;padding:20px;background:linear-gradient(150deg,var(--navy-800),var(--blue-500));color:#fff;font-size:11.5px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;line-height:1.55;opacity:0;transform:translateY(8px);transition:opacity .28s var(--ease),transform .28s var(--ease)}
.sector:hover .se-over,.sector:focus-visible .se-over{opacity:1;transform:none}
@media (hover:none){.sector:active .se-over{opacity:1;transform:none}}

/* ===== CTA band ===== */
.cta-band{background:linear-gradient(135deg,var(--navy-900),var(--navy-700));color:#fff;border-radius:24px;padding:54px 48px;display:flex;align-items:center;justify-content:space-between;gap:28px;flex-wrap:wrap}
.cta-band h2{font-size:clamp(24px,3vw,32px);font-weight:700;max-width:620px;line-height:1.15}
.cta-band p{color:#c4d4e4;margin-top:10px;max-width:560px}

/* ===== Contact ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:48px;align-items:start}
.contact-info h3{font-size:20px;color:var(--navy-800);margin-bottom:20px}
.info-row{display:flex;gap:14px;align-items:flex-start;margin-bottom:20px}
.info-row .ico{width:42px;height:42px;border-radius:11px;background:var(--cloud);display:flex;align-items:center;justify-content:center;flex:none}
.info-row .ico svg{width:20px;height:20px;stroke:var(--blue-500);fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.info-row a,.info-row span{color:var(--slate);font-size:15.5px;text-decoration:none;line-height:1.5}
.info-row a:hover{color:var(--cyan-400)}
.info-row strong{display:block;color:var(--navy-800);font-size:13px;text-transform:uppercase;letter-spacing:.06em;margin-bottom:3px}

/* ===== Forms ===== */
.form{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:34px}
.field{margin-bottom:18px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--navy-800);text-transform:uppercase;letter-spacing:.05em;margin-bottom:7px}
.field input,.field textarea,.field select{width:100%;border:1px solid var(--line);border-radius:10px;padding:12px 14px;font-family:'Inter';font-size:15px;color:var(--ink);background:#fff;transition:border-color .2s var(--ease),box-shadow .2s var(--ease)}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--cyan-400);box-shadow:0 0 0 3px rgba(22,160,215,.15)}
.field textarea{min-height:130px;resize:vertical}
.form .btn{width:100%;justify-content:center;margin-top:6px}
.form-note{font-size:13px;color:var(--slate-light);margin-top:14px;text-align:center}
.form-status{display:none;margin-top:14px;padding:12px 14px;border-radius:10px;font-size:14px}
.form-status.ok{display:block;background:#e7f6ec;color:#1d7a3e;border:1px solid #bfe6cb}

/* ===== Auth (Capacitación) ===== */
.auth{display:flex;justify-content:center}
.auth-card{width:100%;max-width:420px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:38px;box-shadow:0 30px 60px -40px rgba(12,37,71,.4)}
.auth-card h2{font-size:24px;color:var(--navy-800);margin-bottom:6px;text-align:center}
.auth-card .sub{color:var(--slate);font-size:14.5px;text-align:center;margin-bottom:26px}
.auth-card .link{display:block;text-align:center;margin-top:16px;font-size:13.5px;color:var(--cyan-400);text-decoration:none}
.auth-card .link:hover{text-decoration:underline}

/* ===== Placeholder (POLISYN) ===== */
.placeholder{text-align:center;max-width:640px;margin:0 auto}
.placeholder .badge{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--cyan-400);background:#e8f6fc;border:1px solid #c7e9f6;padding:7px 16px;border-radius:999px;margin-bottom:24px}
.placeholder h2{font-size:clamp(26px,3.4vw,38px);color:var(--navy-800);margin-bottom:16px}
.placeholder p{color:var(--slate);font-size:17px;margin-bottom:28px}

/* ===== Footer ===== */
footer{background:var(--navy-900);color:#9fb3c6;padding:56px 0 28px}
.foot-top{display:flex;justify-content:space-between;align-items:flex-start;gap:40px;flex-wrap:wrap;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.1)}
.foot-brand .wordmark img{height:58px}
.foot-brand p{font-size:14px;margin-top:14px;max-width:300px}
.foot-links{display:flex;gap:64px;flex-wrap:wrap}
.foot-col h4{font-family:'Sora';font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:#cdddec;margin-bottom:14px;font-weight:600}
.foot-col a{display:block;color:#9fb3c6;text-decoration:none;font-size:13px;letter-spacing:.05em;text-transform:uppercase;padding:4px 0;transition:color .2s var(--ease)}
.foot-col a:hover{color:var(--cyan-300)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;padding-top:24px;font-size:13px;color:#7d93a8}
.foot-bottom .socials a{color:#7d93a8}
.foot-bottom .socials a:hover{color:var(--cyan-300)}
.foot-bottom a{color:#9fb3c6;text-decoration:none}
.foot-bottom a:hover{color:var(--cyan-300)}

/* ===== Reveal animation ===== */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.06s}.reveal.d2{transition-delay:.12s}.reveal.d3{transition-delay:.18s}.reveal.d4{transition-delay:.24s}

/* ===== Responsive ===== */
@media (max-width:980px){
  .g3{grid-template-columns:repeat(2,1fr)}
  .contact-grid{grid-template-columns:1fr;gap:32px}
}
@media (max-width:820px){
  .menu-toggle{display:flex}
  nav.menu{position:absolute;top:84px;left:0;right:0;flex-direction:column;gap:0;background:#fff;border-bottom:1px solid var(--line);box-shadow:0 20px 40px -24px rgba(12,37,71,.35);margin:0;padding:8px 0;clip-path:inset(0 0 100% 0);transition:clip-path .3s var(--ease)}
  nav.menu.open{clip-path:inset(0 0 0 0)}
  nav.menu a{padding:14px 32px;font-size:14px}
  nav.menu a.active::after{display:none}
  .nav-right .socials{display:none}
  .g2,.g3{grid-template-columns:1fr}
  .values{grid-template-columns:1fr}
  .cta-band{padding:40px 28px}
  .section{padding:64px 0}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
}
