/* ===================================================
   SGP — Sistema de Gestión de Proyectos | Engenerix
   Hoja de estilos compartida
   =================================================== */

  :root{
    /* Fondos cálidos pero más neutros — sutil tinte azul-crema */
    --bg:#f5f3ee;
    --bg-soft:#ebe8e0;
    --card:#ffffff;
    --ink:#141821;
    --ink-soft:#3a4253;
    --muted:#7a8090;
    --line:#e0dfd9;
    --line-strong:#c5c3bb;

    /* Color dominante: azul SGP (derivado del centro del logo) */
    --brand:#1e3a6f;
    --brand-2:#2a4d8c;
    --brand-soft:#dde4f0;

    /* Acento: coral suave (versión refinada del rojo del logo) */
    --accent:#c4574a;
    --accent-soft:#f0d4cf;

    /* Acentos secundarios del logo, para uso puntual en íconos de módulos */
    --logo-green:#3d8c5a;
    --logo-orange:#d9802e;
    --logo-red:#c4574a;
    --logo-blue:#1e3a6f;

    /* Dorado para tonos Premium */
    --gold:#9c7a3a;
    --gold-soft:#e8dcc0;

    --highlight:#fff5d6;
    --check:#3d8c5a;
    --x:#b04a35;
    --r:14px;
    --r-sm:8px;
    --shadow:0 1px 2px rgba(20,30,40,.04), 0 8px 24px -12px rgba(20,30,40,.10);
    --shadow-lg:0 2px 4px rgba(20,30,25,.05), 0 24px 48px -16px rgba(20,30,25,.18);
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{
    font-family:'DM Sans',-apple-system,BlinkMacSystemFont,sans-serif;
    background:var(--bg);
    color:var(--ink);
    line-height:1.55;
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
  }
  body::before{
    content:'';
    position:fixed;inset:0;
    pointer-events:none;
    opacity:.35;
    background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.06 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
    z-index:1;
    mix-blend-mode:multiply;
  }
  .wrap{max-width:1240px;margin:0 auto;padding:0 24px;position:relative;z-index:2}

  /* ---------- HERO ---------- */
  .hero{padding:72px 0 40px;text-align:center;position:relative}
  .hero::before{
    content:'';
    position:absolute;
    top:60px;left:50%;transform:translateX(-50%);
    width:520px;height:520px;
    background:radial-gradient(circle, rgba(196,87,74,.08), transparent 60%);
    z-index:-1;
    border-radius:50%;
  }
  h1{
    font-family:'Fraunces',serif;
    font-weight:500;
    font-size:clamp(38px,6vw,72px);
    line-height:1.02;
    letter-spacing:-.02em;
    margin:18px 0 14px;
    color:var(--ink);
  }
  h1 em{font-style:italic;color:var(--accent);font-weight:500}
  .lede{
    font-size:clamp(16px,1.6vw,19px);
    color:var(--ink-soft);
    max-width:680px;margin:0 auto 16px;
  }

  /* ---------- SGP INTRO BLOCK ---------- */
  .sgp-intro{
    margin:40px auto 0;
    max-width:920px;
    background:var(--card);
    border:1px solid var(--line);
    border-left:4px solid var(--brand);
    border-radius:var(--r);
    padding:28px 32px;
    text-align:left;
    box-shadow:var(--shadow);
  }
  .sgp-intro h2{
    font-family:'Fraunces',serif;font-weight:500;
    font-size:24px;letter-spacing:-.01em;
    color:var(--ink);margin-bottom:10px;
  }
  .sgp-intro h2 em{font-style:italic;color:var(--brand)}
  .sgp-intro p{color:var(--ink-soft);font-size:15px;line-height:1.6}
  .sgp-intro p+p{margin-top:10px}

  /* ---------- CURRENCY TOGGLE ---------- */
  .currency-toggle-wrap{
    margin:40px auto 0;
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:8px;
  }
  .currency-toggle{
    background:var(--card);
    border:1px solid var(--line);
    border-radius:999px;
    padding:5px;
    display:inline-flex;
    box-shadow:var(--shadow);
    position:relative;
  }
  .currency-toggle button{
    border:none;
    background:transparent;
    cursor:pointer;
    padding:9px 22px;
    font:inherit;
    font-weight:600;
    font-size:14px;
    color:var(--muted);
    border-radius:999px;
    transition:color .25s;
    position:relative;
    z-index:1;
    display:inline-flex;
    align-items:center;
    gap:6px;
  }
  .currency-toggle button.active{color:#fff}
  .currency-toggle .pill{
    position:absolute;
    top:5px;
    bottom:5px;
    left:5px;
    background:var(--brand);
    border-radius:999px;
    transition:transform .35s cubic-bezier(.4,0,.2,1), width .35s cubic-bezier(.4,0,.2,1);
    z-index:0;
  }
  .rate-note{
    font-size:12px;
    color:var(--muted);
    text-align:center;
    line-height:1.5;
  }
  .rate-note a{color:var(--brand);text-decoration:none;border-bottom:1px dotted var(--brand)}
  .rate-note a:hover{color:var(--accent);border-bottom-color:var(--accent)}
  .rate-note-fiscal{margin-top:4px;font-size:11.5px;opacity:1;color:var(--accent);font-weight:500}

  /* Volume discount note */
  .volume-note{
    max-width:920px;margin:0 auto 28px;
    background:var(--card);
    border:1px solid var(--line);
    border-left:3px solid var(--gold);
    border-radius:var(--r);
    padding:16px 22px;
    display:flex;align-items:flex-start;gap:14px;
    box-shadow:var(--shadow);
  }
  .volume-note svg{flex-shrink:0;color:var(--gold);margin-top:2px}
  .volume-note p{font-size:14px;color:var(--ink-soft);line-height:1.55;margin:0}
  .volume-note strong{color:var(--ink);font-weight:600}
  .volume-note a{color:var(--brand);text-decoration:none;border-bottom:1px dotted var(--brand);font-weight:500}
  .volume-note a:hover{color:var(--accent);border-bottom-color:var(--accent)}

  /* Pricing model explainer (encima de la tabla) */
  .pricing-model-note{
    max-width:920px;margin:0 auto 28px;
    background:var(--brand-soft);
    border:1px solid #c2cee4;
    border-radius:var(--r);
    padding:16px 22px;
    display:flex;align-items:flex-start;gap:14px;
  }
  .pricing-model-note svg{flex-shrink:0;color:var(--brand);margin-top:2px}
  .pricing-model-note div{font-size:14px;color:var(--ink-soft);line-height:1.6}
  .pricing-model-note strong{color:var(--ink);font-weight:600}

  /* ---------- PRICING GRID ---------- */
  .grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:14px;
    margin:32px 0 16px;
    align-items:stretch;
  }
  @media(max-width:1100px){.grid{grid-template-columns:repeat(2,1fr)}}
  @media(max-width:560px){.grid{grid-template-columns:1fr}}

  .card{
    background:var(--card);
    border:1px solid var(--line);
    border-radius:var(--r);
    padding:28px 22px 24px;
    display:flex;flex-direction:column;
    position:relative;
    transition:transform .3s, box-shadow .3s, border-color .3s;
  }
  .card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--line-strong)}

  .card.entrepreneur-card{
    background:linear-gradient(180deg,#e9fbff 0%,#dff5ff 52%,#eefbff 100%);
    border-color:#8fd8ee;
    box-shadow:0 22px 60px rgba(15,166,199,.14);
  }
  .card.entrepreneur-card .price-annual{
    color:#0b55d9;
    font-weight:800;
  }
  .card.entrepreneur-card .feat-list .head{border-color:#a7deef}

  .card.featured{
    background:var(--brand);
    color:#f3ede0;
    border-color:var(--brand);
    box-shadow:var(--shadow-lg);
  }
  .card.featured .price-num,.card.featured .plan-name{color:#fff}
  .card.featured .price-currency,.card.featured .price-period,.card.featured .feat-text{color:#c9d3e6}
  .card.featured .feat svg{color:#a8b8d9}
  .card.featured .plan-desc{color:#c9d3e6}
  .card.featured .cta{background:var(--accent);color:#fff;border-color:var(--accent)}
  .card.featured .cta:hover{background:#a64739}
  .card.featured .feat-list .head{color:#a8b3c9;border-color:#2a4d8c}

  .card.premium-card{
    background:linear-gradient(135deg, #2a1810 0%, #1a0f08 100%);
    color:#f3ede0;
    border-color:#3d2818;
    box-shadow:var(--shadow-lg);
    position:relative;
    overflow:hidden;
  }
  .card.premium-card::before{
    content:'';
    position:absolute;top:-50%;right:-50%;
    width:200%;height:200%;
    background:radial-gradient(circle, rgba(168,127,58,.15), transparent 50%);
    pointer-events:none;
  }
  .card.premium-card > *{position:relative;z-index:1}
  .card.premium-card .price-num{color:#f5d99a}
  .card.premium-card .plan-name{color:#fff}
  .card.premium-card .price-currency,.card.premium-card .price-period,.card.premium-card .feat-text{color:#d4c5a8}
  .card.premium-card .feat svg{color:#d4a85a}
  .card.premium-card .plan-desc{color:#c9b890}
  .card.premium-card .cta{background:#a87f3a;color:#fff;border-color:#a87f3a}
  .card.premium-card .cta:hover{background:#8a6829}
  .card.premium-card .feat-list .head{color:#9a8456;border-color:#3d2818}

  .badge-feat{
    position:absolute;top:-12px;left:50%;transform:translateX(-50%);
    background:var(--accent);color:#fff;
    font-size:11px;font-weight:700;letter-spacing:.08em;
    text-transform:uppercase;
    padding:6px 14px;border-radius:999px;
    box-shadow:var(--shadow);
    white-space:nowrap;
  }
  .plan-name{
    font-family:'Fraunces',serif;font-weight:500;font-size:22px;
    letter-spacing:-.01em;color:var(--ink);
  }
  .plan-desc{
    font-size:13px;color:var(--ink-soft);
    margin:6px 0 18px;line-height:1.45;
    min-height:54px;
  }
  .price{
    display:flex;align-items:baseline;gap:4px;
    margin-bottom:4px;
    min-height:48px;
  }
  .price-currency{font-size:14px;color:var(--muted);font-weight:500}
  .price-num{
    font-family:'Fraunces',serif;
    font-size:46px;font-weight:500;
    letter-spacing:-.03em;
    color:var(--ink);line-height:1;
    transition:opacity .25s;
  }
  .price-num.is-dop{font-size:34px}
  .price-period{font-size:13px;color:var(--muted);margin-left:2px}
  .price-sub{font-size:12px;color:var(--muted);margin-bottom:18px;min-height:52px;line-height:1.5}
  .price-sub strong{color:var(--ink-soft);font-weight:600}

  .personal-connect-card{
    background:linear-gradient(135deg,#eef7ff 0%,#f5fbff 100%);
    border:1px solid #bfdbfe;
    border-radius:14px;
    padding:14px 14px 13px;
    margin:2px 0 18px;
    box-shadow:0 12px 28px rgba(23,100,245,.08);
  }
  .personal-connect-card strong{
    display:block;
    color:var(--brand);
    font-weight:800;
    font-size:13px;
    margin-bottom:5px;
  }
  .personal-connect-card span{
    display:block;
    color:var(--ink-soft);
    font-size:12.5px;
    line-height:1.45;
  }
  .card.featured .price-sub{color:#c9d3e6}
  .card.featured .price-sub strong{color:#fff}
  .card.premium-card .price-sub{color:#c9b890}
  .card.premium-card .price-sub strong{color:#f5d99a}
  .price-annual{
    display:block;
    font-size:12px;
    color:var(--brand);
    font-weight:500;
    margin-top:3px;
  }
  .card.featured .price-annual{color:#bccae0}
  .card.premium-card .price-annual{color:#d4a85a}

  .cta{
    display:block;text-align:center;
    padding:12px 18px;
    background:var(--ink);color:#fff;
    border:1px solid var(--ink);
    border-radius:10px;
    font-weight:600;font-size:14px;
    text-decoration:none;
    transition:background .2s,transform .2s;
    margin-bottom:22px;
    cursor:pointer;
  }
  .cta:hover{background:#000;transform:translateY(-1px)}
  .cta.ghost{background:transparent;color:var(--ink);border-color:var(--line-strong)}
  .cta.ghost:hover{background:var(--bg-soft);color:var(--ink)}

  .feat-list{list-style:none;display:flex;flex-direction:column;gap:10px;margin-top:auto}
  .feat-list .head{
    font-size:11px;font-weight:600;
    text-transform:uppercase;letter-spacing:.08em;
    color:var(--muted);
    padding-bottom:8px;border-bottom:1px solid var(--line);
    margin-bottom:4px;
  }
  .feat{display:flex;gap:10px;align-items:flex-start;font-size:13.5px}
  .feat svg{flex-shrink:0;color:var(--check);margin-top:3px}
  .feat-text{color:var(--ink-soft);line-height:1.45}

  /* ---------- PREMIUM SPOTLIGHT SECTION ---------- */
  .premium-spotlight{
    margin:80px 0;
    background:linear-gradient(135deg, #1a0f08 0%, #2a1810 50%, #1a0f08 100%);
    color:#f3ede0;
    border-radius:var(--r);
    padding:64px 48px;
    position:relative;
    overflow:hidden;
  }
  .premium-spotlight::before{
    content:'';position:absolute;
    top:-200px;right:-200px;width:600px;height:600px;
    background:radial-gradient(circle, rgba(168,127,58,.18), transparent 60%);
    border-radius:50%;
    pointer-events:none;
  }
  .premium-spotlight::after{
    content:'';position:absolute;
    bottom:-200px;left:-200px;width:500px;height:500px;
    background:radial-gradient(circle, rgba(196,87,74,.12), transparent 60%);
    border-radius:50%;
    pointer-events:none;
  }
  .premium-spotlight > *{position:relative;z-index:1}
  .premium-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:48px;
    align-items:center;
  }
  @media(max-width:880px){.premium-grid{grid-template-columns:1fr;gap:32px}}
  @media(max-width:600px){.premium-spotlight{padding:40px 24px}}
  .premium-eyebrow{
    display:inline-flex;align-items:center;gap:8px;
    font-size:12px;font-weight:600;
    color:#d4a85a;
    background:rgba(168,127,58,.15);
    border:1px solid rgba(168,127,58,.3);
    padding:6px 14px;
    border-radius:999px;
    letter-spacing:.1em;
    text-transform:uppercase;
    margin-bottom:18px;
  }
  .premium-spotlight h2{
    font-family:'Fraunces',serif;font-weight:500;
    font-size:clamp(30px,4vw,44px);
    letter-spacing:-.02em;line-height:1.1;
    color:#fff;
    margin-bottom:18px;
  }
  .premium-spotlight h2 em{font-style:italic;color:#d4a85a}
  .premium-spotlight p{
    color:#c9b890;font-size:15.5px;line-height:1.65;
  }
  .premium-spotlight p+p{margin-top:14px}
  .premium-spotlight strong{color:#f3ede0;font-weight:600}
  .premium-features{
    display:flex;flex-direction:column;gap:18px;
  }
  .premium-feat{
    display:flex;gap:16px;align-items:flex-start;
    padding:18px;
    background:rgba(168,127,58,.06);
    border:1px solid rgba(168,127,58,.15);
    border-radius:10px;
  }
  .premium-feat .num{
    font-family:'Fraunces',serif;
    font-size:24px;font-weight:500;
    color:#d4a85a;
    line-height:1;
    flex-shrink:0;
    font-style:italic;
  }
  .premium-feat h4{
    font-family:'Fraunces',serif;
    font-weight:500;font-size:16px;
    color:#f3ede0;
    margin-bottom:4px;
  }
  .premium-feat p{
    color:#a8997a;font-size:13.5px;line-height:1.5;
    margin:0;
  }

  /* ---------- COMPARISON TABLE ---------- */
  .compare-section{padding:60px 0 40px}
  .section-head{text-align:center;margin-bottom:48px}
  .section-head h2{
    font-family:'Fraunces',serif;font-weight:500;
    font-size:clamp(30px,4vw,46px);
    letter-spacing:-.02em;line-height:1.1;
  }
  .section-head h2 em{font-style:italic;color:var(--accent)}
  .section-head p{color:var(--ink-soft);margin-top:10px;font-size:16px}

  .table-wrap{
    background:var(--card);
    border:1px solid var(--line);
    border-radius:var(--r);
    overflow:hidden;
    box-shadow:var(--shadow);
  }
  .table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}

  /* ===== MOBILE PLAN CARDS ===== */
  .mobile-plans{display:none}
  .mplan{
    background:var(--card);
    border:1px solid var(--line);
    border-radius:var(--r);
    margin-bottom:16px;
    overflow:hidden;
    box-shadow:var(--shadow);
  }
  .mplan.entrepreneur{
    background:linear-gradient(180deg,#f8fbff 0%,#eef6ff 100%);
    border:1px solid #bfdbfe;
  }
  .mplan.featured{
    background:var(--brand);
    border:2px solid var(--brand);
    color:#f3ede0;
  }
  .mplan.premium{
    background:linear-gradient(135deg,#232b3a 0%,#111827 100%);
    border:2px solid #3d4658;
    color:#f3ede0;
  }
  .mplan-head{
    padding:20px;
    border-bottom:1px solid var(--line);
    position:relative;
  }
  .mplan.entrepreneur .mplan-head{background:linear-gradient(180deg,#f8fbff 0%,#eef6ff 100%)}
  .mplan.featured .mplan-head{background:transparent;border-bottom-color:#2a4d8c}
  .mplan.premium .mplan-head{background:transparent;border-bottom-color:#3d4658}
  .mplan.featured .mplan-name,.mplan.premium .mplan-name{color:#fff}
  .mplan.featured .mplan-price,.mplan.featured .mplan-price .per,.mplan.featured .mplan-annual,
  .mplan.featured .mplan-row .rtext,.mplan.featured .mplan-row .rtext strong,.mplan.featured .mplan-section-title{color:#dbeafe}
  .mplan.premium .mplan-price{color:#f5d99a}
  .mplan.premium .mplan-price .per,.mplan.premium .mplan-annual,.mplan.premium .mplan-row .rtext,.mplan.premium .mplan-row .rtext strong,.mplan.premium .mplan-section-title{color:#d4c5a8}
  .mplan.premium .mplan-section-title{border-color:#3d4658}
  .mplan.featured .mplan-section-title{border-color:#2a4d8c}
  .mplan-badge{
    display:inline-block;
    background:var(--accent);color:#fff;
    font-size:10px;font-weight:600;
    text-transform:uppercase;letter-spacing:.06em;
    padding:3px 10px;border-radius:99px;
    margin-bottom:8px;
  }
  .mplan-name{
    font-family:'Fraunces',serif;
    font-size:24px;font-weight:600;
    color:var(--ink);
    letter-spacing:-.01em;
  }
  .mplan-price{
    font-family:'Fraunces',serif;
    font-size:32px;font-weight:500;
    color:var(--brand);
    margin-top:6px;
  }
  .mplan-price .per{
    font-family:'DM Sans',sans-serif;
    font-size:13px;color:var(--muted);font-weight:400;
  }
  .mplan-annual{
    font-size:12px;color:var(--muted);margin-top:2px;
  }
  .mplan-body{padding:8px 20px 16px}
  .mplan-section-title{
    font-size:11px;font-weight:600;
    text-transform:uppercase;letter-spacing:.06em;
    color:var(--brand);
    margin:16px 0 6px;
    padding-top:12px;
    border-top:1px solid var(--line);
  }
  .mplan-section-title:first-child{border-top:none;padding-top:4px}
  .mplan-row{
    display:flex;align-items:flex-start;gap:10px;
    padding:7px 0;
    font-size:13.5px;
    line-height:1.4;
  }
  .mplan-row .ic{
    flex-shrink:0;width:18px;height:18px;
    display:flex;align-items:center;justify-content:center;
    border-radius:50%;
    font-size:11px;font-weight:700;
    margin-top:1px;
  }
  .mplan-row .ic.yes{background:#e3f0e8;color:var(--check)}
  .mplan-row .ic.no{background:#f0e3e1;color:var(--x)}
  .mplan-row .ic.info{background:var(--brand-soft);color:var(--brand)}
  .mplan-row .rtext{flex:1;color:var(--ink-soft)}
  .mplan-row .rtext strong{color:var(--ink)}
  .mplan-row .rlabel{
    display:block;font-size:12px;color:var(--muted);
    margin-top:1px;
  }
  .mplan-cta{
    display:block;margin:8px 20px 20px;
    padding:13px;
    text-align:center;
    background:var(--brand);color:#fff;
    border-radius:var(--r-sm);
    text-decoration:none;
    font-weight:600;font-size:15px;
  }
  .mplan.premium .mplan-cta{background:var(--gold)}
  .mplan-cta.ghost{
    background:transparent;
    color:var(--brand);
    border:2px solid var(--line);
  }
  table.compare{
    width:100%;border-collapse:collapse;
    font-size:14px;min-width:880px;
  }
  table.compare thead th{
    background:var(--bg-soft);
    padding:18px 14px;text-align:center;
    font-weight:600;font-size:13px;
    border-bottom:1px solid var(--line);
    color:var(--ink);
    position:sticky;top:0;z-index:2;
  }
  table.compare thead th:first-child{
    text-align:left;
    background:var(--bg-soft);
    position:sticky;left:0;z-index:3;
  }
  table.compare thead th.feat-col{background:var(--brand);color:#fff;position:relative}
  table.compare thead th.feat-col::after{
    content:'Recomendado';
    position:absolute;top:-1px;right:8px;
    background:var(--accent);color:#fff;
    font-size:9px;font-weight:700;letter-spacing:.08em;
    padding:2px 7px;border-radius:0 0 6px 6px;
  }
  table.compare thead th.prem-col{background:#2a1810;color:#f5d99a;position:relative}
  table.compare tbody td{
    padding:13px 14px;text-align:center;
    border-bottom:1px solid var(--line);
    color:var(--ink-soft);
    vertical-align:top;
  }
  table.compare tbody td:first-child{
    text-align:left;font-weight:500;color:var(--ink);
    background:var(--card);
    position:sticky;left:0;z-index:1;
    border-right:1px solid var(--line);
    min-width:260px;
  }
  table.compare tbody tr.section-row td{
    background:var(--bg-soft);
    font-family:'Fraunces',serif;
    font-size:15px;font-weight:600;
    color:var(--ink);
    padding:12px 14px;
    text-align:left;
  }
  table.compare tbody tr.section-row td:first-child{background:var(--bg-soft)}
  table.compare tbody tr:hover td:not([colspan]){background:#fbf7ed}
  table.compare tbody tr:hover td:first-child{background:#fbf7ed}
  table.compare tbody tr.section-row:hover td{background:var(--bg-soft)}

  .row-sub{font-size:12px;color:var(--muted);display:block;margin-top:2px;font-weight:400;line-height:1.4}
  .cell-note{font-size:12px;color:var(--muted);line-height:1.4;display:block;margin-top:4px}
  .db-modality{text-align:center}
  .db-modality strong{color:var(--ink-soft);font-weight:600}
  .db-asterisk{text-align:center}
  .db-asterisk{font-size:11px;font-style:italic;margin-top:10px;color:var(--muted);text-align:center;line-height:1.45;max-width:280px;margin-left:auto;margin-right:auto}

  /* Module section expandable */
  .section-row.expandable{cursor:pointer;user-select:none;transition:background .2s}
  .section-row.expandable:hover{background:var(--brand-soft)}
  .section-row.expandable td{position:relative;padding-right:42px}
  .section-row.expandable .expand-icon{
    position:absolute;right:18px;top:50%;transform:translateY(-50%);
    width:24px;height:24px;border-radius:50%;
    background:var(--brand);color:#fff;
    display:flex;align-items:center;justify-content:center;
    font-size:14px;font-weight:600;
    transition:transform .25s;
  }
  .section-row.expandable.open .expand-icon{transform:translateY(-50%) rotate(45deg)}
  .module-detail{
    background:#fafaf7;
    border-left:3px solid var(--brand);
    display:none;
  }
  .module-detail.open{
    display:table-row;
  }
  .module-detail td{padding:0 !important}
  .module-detail-inner{
    padding:24px 28px;
    max-width:none;
  }
  .module-detail-inner h4{
    font-family:'Fraunces',serif;
    font-size:20px;font-weight:600;
    color:var(--brand);
    margin:0 0 8px;
    letter-spacing:-.01em;
  }
  .module-detail-inner .lead{
    font-size:15px;color:var(--ink-soft);
    line-height:1.6;margin:0 0 18px;
    max-width:720px;
  }
  .module-detail-inner .feature-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
    gap:8px 24px;
    margin:0;padding:0;list-style:none;
  }
  .module-detail-inner .feature-grid li{
    font-size:13.5px;
    color:var(--ink-soft);
    padding:4px 0 4px 22px;
    position:relative;
    line-height:1.45;
  }
  .module-detail-inner .feature-grid li::before{
    content:"";
    position:absolute;left:0;top:11px;
    width:12px;height:12px;
    background:var(--check);
    -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>") no-repeat center / contain;
    mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>") no-repeat center / contain;
  }
  .module-detail-inner .feature-group{
    margin-top:18px;
  }
  .module-detail-inner .feature-group-title{
    font-size:13px;font-weight:600;
    color:var(--ink);
    margin:0 0 6px;
    text-transform:uppercase;
    letter-spacing:.04em;
  }

  .yes,.no{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%}
  .yes{background:var(--brand-soft);color:var(--check)}
  .no{background:#f5dcd2;color:var(--x)}

  .tip{position:relative;border-bottom:1px dotted var(--muted);cursor:help}
  .tip::after{
    content:attr(data-tip);
    position:absolute;bottom:calc(100% + 8px);left:50%;
    transform:translateX(-50%) translateY(4px);
    background:var(--ink);color:#f3ede0;
    padding:8px 12px;border-radius:8px;
    font-size:12px;font-weight:400;
    white-space:normal;width:260px;
    text-align:left;line-height:1.4;
    opacity:0;pointer-events:none;
    transition:opacity .2s,transform .2s;
    z-index:10;
    box-shadow:var(--shadow-lg);
  }
  .tip:hover::after,.tip:focus::after{opacity:1;transform:translateX(-50%) translateY(0)}

  /* ---------- TRUST ---------- */
  .trust{padding:60px 0;border-top:1px solid var(--line);margin-top:40px}
  .trust-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
  @media(max-width:760px){.trust-grid{grid-template-columns:1fr}}
  .trust-item{display:flex;flex-direction:column;gap:8px}
  .trust-item .icon{
    width:42px;height:42px;
    background:var(--brand-soft);
    border-radius:10px;
    display:flex;align-items:center;justify-content:center;
    color:var(--brand);
    margin-bottom:6px;
  }
  .trust-item h4{font-family:'Fraunces',serif;font-weight:600;font-size:17px}
  .trust-item p{font-size:14px;color:var(--ink-soft);line-height:1.5}

  /* ---------- FAQ ---------- */
  .faq{padding:80px 0}
  .faq-list{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:10px}
  details.faq-item{
    background:var(--card);
    border:1px solid var(--line);
    border-radius:var(--r-sm);
    padding:0;
    overflow:hidden;
    transition:border-color .25s;
  }
  details.faq-item[open]{border-color:var(--line-strong)}
  details.faq-item summary{
    padding:18px 22px;cursor:pointer;
    list-style:none;
    display:flex;justify-content:space-between;align-items:center;gap:16px;
    font-weight:600;font-size:15.5px;
    color:var(--ink);
  }
  details.faq-item summary::-webkit-details-marker{display:none}
  details.faq-item summary::after{
    content:'+';
    font-size:24px;font-weight:300;color:var(--muted);
    transition:transform .25s;
    flex-shrink:0;
  }
  details.faq-item[open] summary::after{transform:rotate(45deg)}
  details.faq-item .answer{
    padding:0 22px 20px;
    color:var(--ink-soft);font-size:14.5px;line-height:1.6;
  }
  details.faq-item .answer p+p{margin-top:10px}
  details.faq-item .answer strong{color:var(--ink)}

  /* ---------- FINAL CTA ---------- */
  .final{
    margin:60px 0 80px;
    background:linear-gradient(135deg,#eef8ff 0%,#e9fdf6 100%);
    color:var(--ink);
    border:1px solid #bfe8dc;
    border-radius:var(--r);
    padding:56px 32px;
    text-align:center;
    position:relative;overflow:hidden;
    box-shadow:0 26px 70px -42px rgba(23,100,245,.45);
  }
  .final::before{
    content:'';position:absolute;
    top:-120px;right:-100px;width:320px;height:320px;
    background:radial-gradient(circle, rgba(34,197,94,.16), transparent 70%);
    border-radius:50%;
  }
  .final h2{
    font-family:'Fraunces',serif;font-weight:500;
    font-size:clamp(28px,4vw,42px);
    letter-spacing:-.02em;color:var(--ink);
    margin-bottom:14px;
    position:relative;
  }
  .final h2 em{font-style:italic;color:var(--logo-green)}
  .final p{font-size:16px;color:var(--ink-soft);max-width:520px;margin:0 auto 28px;position:relative;font-weight:500}
  .final .cta-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;position:relative}
  .final .cta{margin:0;background:linear-gradient(135deg,#1764f5,#0d78ff);border-color:#1764f5;color:#fff}
  .final .cta:hover{filter:saturate(1.08);transform:translateY(-1px)}
  .final .cta.ghost{background:rgba(255,255,255,.78);color:var(--brand);border-color:#b8d7ff}
  .final .cta.ghost:hover{background:#fff;color:var(--brand)}

  footer{
    text-align:center;padding:30px 0;
    color:var(--muted);font-size:13px;
    border-top:1px solid var(--line);
  }

  .reveal{opacity:0;transform:translateY(16px);animation:reveal .7s forwards}
  @keyframes reveal{to{opacity:1;transform:translateY(0)}}
  .d1{animation-delay:.05s}.d2{animation-delay:.12s}.d3{animation-delay:.2s}.d4{animation-delay:.28s}.d5{animation-delay:.36s}.d6{animation-delay:.44s}

  /* ========== SITE HEADER ========== */
  .site-header{
    position:sticky;top:0;z-index:100;
    background:rgba(245,243,238,.85);
    backdrop-filter:blur(12px);
    -webkit-backdrop-filter:blur(12px);
    border-bottom:1px solid var(--line);
  }
  .header-wrap{
    max-width:1240px;margin:0 auto;padding:0 24px;
    display:flex;align-items:center;justify-content:space-between;
    height:68px;gap:32px;
  }
  .site-logo{
    text-decoration:none;
    display:flex;align-items:center;
    flex-shrink:0;
    transition:opacity .2s;
  }
  .site-logo:hover{opacity:.85}
  .logo-img{
    width:44px;height:44px;
    object-fit:contain;flex-shrink:0;
    border-radius:50%;
  }
  .nav-main{display:flex;align-items:center;gap:4px;flex:1;justify-content:center}
  .nav-item{position:relative}
  .nav-link{
    display:flex;align-items:center;gap:5px;
    padding:9px 14px;
    font-size:14.5px;font-weight:500;color:var(--ink-soft);
    text-decoration:none;border-radius:8px;
    transition:background .2s,color .2s;
    cursor:pointer;background:none;border:none;font-family:inherit;
  }
  .nav-link:hover{background:var(--bg-soft);color:var(--ink)}
  .nav-link svg.chev{transition:transform .2s;flex-shrink:0}
  .nav-item.open .nav-link svg.chev{transform:rotate(180deg)}
  .nav-item.open .nav-link{background:var(--bg-soft);color:var(--ink)}

  .dropdown{
    position:absolute;top:calc(100% + 8px);left:50%;
    transform:translateX(-50%) translateY(-8px);
    min-width:320px;
    background:var(--card);
    border:1px solid var(--line);
    border-radius:var(--r);
    box-shadow:var(--shadow-lg);
    padding:10px;
    opacity:0;visibility:hidden;
    transition:opacity .2s,transform .2s,visibility .2s;
  }
  .nav-item.open .dropdown{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
  .dropdown a{
    display:flex;align-items:flex-start;gap:12px;
    padding:11px 12px;
    text-decoration:none;color:var(--ink);
    border-radius:8px;
    transition:background .15s;
  }
  .dropdown a:hover{background:var(--bg-soft)}
  .dd-icon{
    flex-shrink:0;width:34px;height:34px;
    background:var(--brand-soft);color:var(--brand);
    border-radius:8px;
    display:flex;align-items:center;justify-content:center;
    margin-top:2px;
  }
  .dd-text strong{display:block;font-size:14px;font-weight:600;line-height:1.3;color:var(--ink)}
  .dd-text span{display:block;font-size:12.5px;color:var(--muted);line-height:1.4;margin-top:2px}

  .header-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}
  .btn-login{
    padding:9px 16px;font-size:14px;font-weight:600;
    color:var(--ink-soft);text-decoration:none;
    border-radius:8px;transition:background .2s,color .2s;
  }
  .btn-login:hover{background:var(--bg-soft);color:var(--ink)}
  .btn-header-cta{
    padding:9px 18px;font-size:14px;font-weight:600;
    background:var(--accent);color:#fff;text-decoration:none;
    border-radius:8px;transition:background .2s,transform .2s;
    border:1px solid var(--accent);
  }
  .btn-header-cta:hover{background:#a64739;transform:translateY(-1px)}

  .menu-toggle{
    display:none;background:none;border:none;cursor:pointer;
    padding:8px;color:var(--ink);
  }
  @media(max-width:1100px){
    .header-wrap{gap:16px}
    .nav-link{padding:9px 10px;font-size:14px}
  }
  @media(max-width:980px){
    .nav-main{display:none}
    .header-actions .btn-login{display:none}
    .menu-toggle{display:flex}
  }
  @media(max-width:560px){
    .header-actions .btn-header-cta{padding:8px 14px;font-size:13px}
  }

  /* Switch tabla <-> tarjetas en móvil */
  @media(max-width:820px){
    .table-wrap{display:none}
    .mobile-plans{display:block}
  }

  /* Mobile drawer */
  .mobile-drawer{
    display:none;
    position:fixed;top:0;right:0;bottom:0;
    width:min(360px,85vw);
    background:var(--card);
    z-index:200;
    padding:24px;
    overflow-y:auto;
    box-shadow:var(--shadow-lg);
    transform:translateX(100%);
    transition:transform .3s;
  }
  .mobile-drawer.open{transform:translateX(0)}
  .mobile-drawer.open + .drawer-overlay{display:block}
  .drawer-overlay{
    display:none;position:fixed;inset:0;
    background:rgba(0,0,0,.4);z-index:150;
  }
  .drawer-close{
    background:none;border:none;cursor:pointer;
    margin-left:auto;display:block;padding:8px;color:var(--ink);
  }
  .mobile-drawer h4{
    font-size:11px;font-weight:600;
    text-transform:uppercase;letter-spacing:.08em;
    color:var(--muted);margin:24px 0 8px;
  }
  .mobile-drawer a{
    display:block;padding:12px 0;
    color:var(--ink);text-decoration:none;
    font-size:15px;font-weight:500;
    border-bottom:1px solid var(--line);
  }
  .mobile-drawer .drawer-cta{
    display:block;text-align:center;
    margin-top:24px;padding:14px;
    background:var(--accent);color:#fff;
    border-radius:8px;font-weight:600;
    border-bottom:none;
  }
  @media(max-width:980px){.mobile-drawer{display:block}}

  /* ===== ENCABEZADO DE PÁGINA (planes, etc.) ===== */
  .page-head{
    text-align:center;
    padding:80px 0 32px;
  }
  .page-head h1{
    font-family:'Fraunces',serif;
    font-size:clamp(38px,6vw,60px);
    font-weight:400;
    letter-spacing:-.02em;
    line-height:1.05;
    color:var(--ink);
  }
  .page-head h1 em{font-style:italic;color:var(--accent);font-weight:400}
  .page-head p{
    margin-top:14px;
    font-size:17px;
    color:var(--ink-soft);
    max-width:520px;
    margin-left:auto;margin-right:auto;
  }

  /* ===== RECUADRO PUENTE (Home -> Planes) ===== */
  .bridge{padding:32px 0 72px}
  .bridge-card{
    background:var(--card);
    border:1px solid var(--line);
    border-radius:var(--r);
    box-shadow:var(--shadow);
    padding:36px 40px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:32px;
    flex-wrap:wrap;
  }
  .bridge-text h2{
    font-family:'Fraunces',serif;
    font-size:clamp(24px,3.4vw,32px);
    font-weight:400;
    letter-spacing:-.01em;
    color:var(--ink);
    line-height:1.15;
  }
  .bridge-text h2 em{font-style:italic;color:var(--accent);font-weight:400}
  .bridge-text p{
    margin-top:8px;
    font-size:15px;
    color:var(--ink-soft);
  }
  .bridge-btn{
    flex-shrink:0;
    display:inline-flex;
    align-items:center;
    gap:8px;
    background:var(--brand);
    color:#fff;
    text-decoration:none;
    font-weight:600;
    font-size:15px;
    padding:14px 26px;
    border-radius:var(--r-sm);
    transition:background .15s,transform .15s;
  }
  .bridge-btn:hover{background:var(--brand-2);transform:translateY(-1px)}
  @media(max-width:640px){
    .bridge-card{flex-direction:column;align-items:flex-start;padding:28px 24px}
    .bridge-btn{width:100%;justify-content:center}
  }

  /* ===== ENCABEZADO TARJETAS-RECORDATORIO (planes, tras la tabla) ===== */
  .cards-reminder-head{
    text-align:center;
    padding:64px 0 8px;
  }
  .cards-reminder-head h2{
    font-family:'Fraunces',serif;
    font-size:clamp(26px,3.6vw,36px);
    font-weight:400;
    letter-spacing:-.01em;
    color:var(--ink);
    line-height:1.15;
  }
  .cards-reminder-head h2 em{font-style:italic;color:var(--accent);font-weight:400}
  .cards-reminder-head p{
    margin-top:8px;
    font-size:15px;
    color:var(--ink-soft);
  }

  /* ===== SELECTOR DE MONEDA COMPACTO (planes, bajo el título) ===== */
  .compare-section .section-head{margin-bottom:24px}
  .currency-toggle-compact{
    margin-top:0;
    margin-bottom:36px;
  }

  /* ===== SEPARACIÓN SUPERIOR DE LA PRIMERA CAJA INFORMATIVA ===== */
  .pricing-model-note.info-box-spaced{margin-top:32px}

  /* =====================================================
     PÁGINA: ACERCA DEL SGP
     ===================================================== */
  .about-head{
    text-align:center;
    max-width:760px;
    margin:0 auto;
    padding:80px 0 56px;
  }
  .about-eyebrow{
    display:inline-block;
    font-size:13px;
    font-weight:600;
    letter-spacing:.14em;
    text-transform:uppercase;
    color:var(--accent);
    margin-bottom:18px;
  }
  .about-head h1{
    font-family:'Fraunces',serif;
    font-size:clamp(34px,5.2vw,54px);
    font-weight:400;
    letter-spacing:-.02em;
    line-height:1.1;
    color:var(--ink);
  }
  .about-head h1 em{font-style:italic;color:var(--accent);font-weight:400}
  .about-lead{
    margin-top:22px;
    font-size:18px;
    line-height:1.6;
    color:var(--ink-soft);
  }

  /* Bloques de contenido */
  .about-block{
    padding:56px 0;
    border-top:1px solid var(--line);
  }
  .about-block-alt{
    background:var(--card);
    border-radius:var(--r);
    border:1px solid var(--line);
    padding:48px 44px;
    margin:8px 0;
  }
  .about-block-head{
    margin-bottom:24px;
  }
  .about-block-head h2{
    font-family:'Fraunces',serif;
    font-size:clamp(26px,3.6vw,38px);
    font-weight:400;
    letter-spacing:-.01em;
    line-height:1.15;
    color:var(--ink);
  }
  .about-block-head h2 em{font-style:italic;color:var(--accent);font-weight:400}
  .about-block-head p{
    margin-top:10px;
    font-size:16px;
    color:var(--ink-soft);
  }
  .about-prose{max-width:680px}
  .about-prose p{
    font-size:16px;
    line-height:1.7;
    color:var(--ink-soft);
    margin-bottom:16px;
  }
  .about-prose p:last-child{margin-bottom:0}
  .about-prose strong{color:var(--ink);font-weight:600}

  /* Módulos */
  .about-modules{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:20px;
    margin-top:8px;
  }
  .about-module{
    background:var(--bg);
    border:1px solid var(--line);
    border-radius:var(--r-sm);
    padding:22px 24px;
  }
  .about-block-alt .about-module{background:var(--bg)}
  .about-module h3{
    font-family:'DM Sans',sans-serif;
    font-size:16px;
    font-weight:600;
    color:var(--brand);
    margin-bottom:8px;
  }
  .about-module p{
    font-size:14px;
    line-height:1.6;
    color:var(--ink-soft);
  }
  .about-modules-note{
    margin-top:24px;
    font-size:14px;
    color:var(--ink-soft);
    text-align:center;
  }
  .about-modules-note a{
    color:var(--brand);
    font-weight:500;
    text-decoration:none;
    border-bottom:1px dotted var(--brand);
  }
  .about-modules-note a:hover{color:var(--accent);border-bottom-color:var(--accent)}

  @media(max-width:640px){
    .about-block-alt{padding:36px 24px}
    .about-modules{grid-template-columns:1fr}
  }

  /* ===== ENLACE EN EL FOOTER (nombre de la empresa) ===== */
  .footer-link{
    color:inherit;
    text-decoration:none;
    border-bottom:1px dotted currentColor;
    transition:color .15s;
  }
  .footer-link:hover{color:var(--brand)}

  /* ========== HOME — Párrafo de impacto ========== */
  .impact-section{
    max-width:780px;
    margin:56px auto 48px;
    padding:0 24px;
    text-align:left;
  }
  .impact-block{
    position:relative;
    padding-top:36px;
  }
  /* Filete decorativo arriba: línea + punto */
  .impact-mark{
    position:absolute;
    top:0;
    left:0;
    width:64px;
    height:3px;
    background:var(--brand);
    border-radius:2px;
  }
  .impact-mark::after{
    content:"";
    position:absolute;
    right:-12px;
    top:50%;
    transform:translateY(-50%);
    width:8px;
    height:8px;
    border-radius:50%;
    background:var(--accent);
  }
  .impact-title{
    font-family:'Fraunces',serif;
    font-size:clamp(28px,4vw,42px);
    font-weight:500;
    letter-spacing:-.015em;
    line-height:1.12;
    color:var(--ink);
    margin-bottom:28px;
  }
  .impact-block p{
    font-size:16.5px;
    color:var(--ink-soft);
    line-height:1.78;
    margin-bottom:18px;
    max-width:680px;
  }
  .impact-block .impact-pivot{
    font-family:'Fraunces',serif;
    font-style:italic;
    font-size:22px;
    color:var(--brand);
    margin:28px 0;
    text-align:center;
    max-width:none;
  }
  @media(max-width:600px){
    .impact-section{margin:36px auto 32px;padding:0 18px}
    .impact-block{padding-top:28px}
    .impact-mark{width:48px}
  }

  /* ========== HOME — Pilares ========== */
  .pillars{
    max-width:1240px;
    margin:64px auto 64px;
    padding:0 24px;
    display:flex;
    flex-direction:column;
    gap:36px;
  }
  .pillar{
    position:relative;
    background:var(--card);
    border:1px solid var(--line);
    border-radius:var(--r,14px);
    padding:40px 44px 36px;
    box-shadow:var(--shadow);
    transition:transform .25s ease, box-shadow .25s ease;
  }
  .pillar:hover{
    transform:translateY(-2px);
    box-shadow:0 1px 2px rgba(20,30,40,.04), 0 18px 36px -16px rgba(20,30,40,.18);
  }
  .pillar-icon{
    width:48px;
    height:48px;
    display:flex;
    align-items:center;
    justify-content:center;
    border-radius:12px;
    background:var(--brand-soft);
    color:var(--brand);
    margin-bottom:18px;
  }
  .pillar-icon svg{width:24px;height:24px;display:block}
  .pillar-title{
    font-family:'Fraunces',serif;
    font-weight:500;
    font-size:clamp(22px,2.6vw,28px);
    letter-spacing:-.008em;
    line-height:1.22;
    color:var(--brand);
    margin-bottom:16px;
  }
  .pillar p{
    font-size:15px;
    color:var(--ink-soft);
    line-height:1.7;
    margin-bottom:12px;
  }
  .pillar p:last-child{margin-bottom:0}
  .pillar .pillar-close{
    color:var(--ink);
    margin-top:12px;
    padding-top:12px;
    border-top:1px solid var(--line);
  }

  /* ========== HOME — Sello de trayectoria ========== */
  .trajectory-seal{
    position:relative;
    background:
      radial-gradient(circle at 20% 30%, rgba(255,255,255,.05) 0%, transparent 50%),
      radial-gradient(circle at 80% 70%, rgba(255,255,255,.03) 0%, transparent 50%),
      linear-gradient(135deg, #1e3a6f 0%, #2a4d8c 100%);
    color:#fff;
    border-radius:var(--r,14px);
    padding:44px 44px 40px;
    text-align:center;
    margin-top:12px;
    overflow:hidden;
  }
  .seal-icon{
    width:52px;
    height:52px;
    margin:0 auto 16px;
    display:flex;
    align-items:center;
    justify-content:center;
    border-radius:50%;
    background:rgba(255,255,255,.08);
    border:1px solid rgba(255,255,255,.18);
    color:#e3c478;
  }
  .seal-icon svg{width:26px;height:26px;display:block}
  .trajectory-seal h3{
    font-family:'Fraunces',serif;
    font-weight:500;
    font-size:clamp(22px,2.8vw,28px);
    line-height:1.22;
    margin-bottom:12px;
    color:#fff;
    letter-spacing:-.005em;
  }
  .trajectory-seal p{
    font-size:15px;
    color:rgba(255,255,255,.88);
    line-height:1.65;
    max-width:680px;
    margin:0 auto;
  }

  @media(max-width:600px){
    .pillar{padding:28px 22px 24px}
    .pillar-icon{width:42px;height:42px;margin-bottom:14px}
    .pillar-icon svg{width:22px;height:22px}
    .trajectory-seal{padding:32px 22px 28px}
    .pillars{margin:40px auto 40px;gap:24px}
  }

  /* ========== HOME — Separación entre secciones ========== */
  .grid{margin-top:48px}
  @media(max-width:600px){.grid{margin-top:32px}}
