/* ===== Cotizador Cúspide — estética alineada con cuspide.com.co (v3) ===== */
:root{
  --green:#2e7d32; --green-900:#1b5e20; --green-400:#4caf50;
  --verde:#2e7d32; --verde-osc:#1b5e20; --verde-claro:#eaf4ec;
  --amber:#ffc107;
  --ink:#16181d; --gris:#6b7280; --gris-claro:#f6f8f6; --borde:#e5e7eb;
  --r:16px; --sombra:0 18px 40px -22px rgba(16,24,29,.28);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:"Inter",system-ui,-apple-system,"Segoe UI",sans-serif;
  color:var(--ink);background:#f7faf8;line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,.brand-text,.mark{font-family:"Manrope","Inter",sans-serif;letter-spacing:-.01em}
a{color:var(--green);text-decoration:none}
a:hover{text-decoration:underline}
:focus-visible{outline:3px solid var(--green-900);outline-offset:2px}

/* Topbar (como site-header del sitio principal) */
.topbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;
  background:rgba(255,255,255,.92);backdrop-filter:saturate(1.4) blur(6px);
  padding:14px clamp(16px,4vw,40px);border-bottom:1px solid var(--borde);
  position:sticky;top:0;z-index:20}
.brand{display:flex;align-items:center;gap:.6rem}
.brand img{height:38px;display:block}
.brand-text,.mark{font-weight:800;color:var(--green-900);font-size:1.2rem}
.topbar nav{display:flex;align-items:center;gap:clamp(14px,2.4vw,26px)}
.topbar nav a{font-weight:600;color:var(--ink);font-size:.95rem}
.topbar nav a:hover{color:var(--green);text-decoration:none}
.topbar nav a.ext{color:var(--green)}
.topbar nav a.btn{color:#fff}
.topbar nav a.btn.secondary{color:var(--green)}

.container{max-width:940px;margin:clamp(24px,5vw,44px) auto;padding:0 20px}

/* Hero / landing */
.hero{text-align:center;padding:clamp(18px,4vw,34px) 0 6px}
.hero h1{font-size:clamp(1.8rem,4.5vw,2.6rem);color:var(--ink);margin:.2em 0;font-weight:800}
.hero p{color:var(--gris);max-width:660px;margin:10px auto;font-size:1.06rem}

.cards{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:28px}
@media(max-width:720px){.cards{grid-template-columns:1fr}}
.card{background:#fff;border:1px solid var(--borde);border-radius:var(--r);
  padding:28px;box-shadow:var(--sombra);display:flex;flex-direction:column;
  transition:transform .2s ease, box-shadow .2s ease}
.card:hover{transform:translateY(-4px);box-shadow:0 26px 50px -24px rgba(16,24,29,.4)}
.card .tag{display:inline-block;background:var(--verde-claro);color:var(--green-900);
  font-size:.72rem;font-weight:800;padding:5px 11px;border-radius:20px;
  letter-spacing:.5px;align-self:flex-start;margin-bottom:12px}
.card h2{margin:.1em 0 .4em;color:var(--ink);font-size:1.28rem}
.card p{color:var(--gris);flex:1}
.card .btn{margin-top:18px}

/* Botones (como .btn del sitio principal) */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  background:var(--green);color:#fff;border:none;padding:13px 24px;border-radius:10px;
  font-weight:700;font-size:1rem;font-family:inherit;cursor:pointer;text-align:center;
  transition:background .15s, transform .15s;box-shadow:0 10px 22px -12px rgba(46,125,50,.6)}
.btn:hover{background:var(--green-900);text-decoration:none;transform:translateY(-1px)}
.btn.secondary{background:#fff;color:var(--green);border:1.5px solid var(--green);box-shadow:none}
.btn.secondary:hover{background:var(--verde-claro)}
.btn-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:8px}

/* Formularios */
.panel{background:#fff;border:1px solid var(--borde);border-radius:var(--r);
  padding:clamp(22px,4vw,34px);box-shadow:var(--sombra)}
.panel h1{color:var(--ink);margin-top:0;font-size:clamp(1.4rem,3.5vw,1.8rem)}
.panel .lead{color:var(--gris);margin-top:-2px}
.section-title{color:var(--green-900);font-size:1.05rem;font-weight:800;
  border-bottom:2px solid var(--verde-claro);padding-bottom:6px;margin:28px 0 14px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:620px){.grid2{grid-template-columns:1fr}}
.field{display:flex;flex-direction:column;margin-bottom:6px}
.field label{font-weight:600;font-size:.9rem;margin-bottom:5px;color:var(--ink)}
.field .hint{font-weight:400;color:var(--gris);font-size:.8rem}
input[type=text],input[type=number],input[type=email],input[type=tel],select{
  padding:11px 13px;border:1px solid var(--borde);border-radius:9px;font-size:.96rem;
  background:#fff;font-family:inherit;color:var(--ink)}
input:focus,select:focus{outline:none;border-color:var(--green);
  box-shadow:0 0 0 3px rgba(46,125,50,.16)}
.check{display:flex;align-items:flex-start;gap:10px;background:var(--gris-claro);
  border:1px solid var(--borde);border-radius:9px;padding:11px 13px;margin-bottom:10px}
.check input{margin-top:3px;width:18px;height:18px;accent-color:var(--green);flex-shrink:0}
.check label{font-weight:600;font-size:.92rem}
.check .hint{font-weight:400;color:var(--gris);font-size:.8rem;display:block}
.check a{text-decoration:underline}
.check.consent{background:#fff7e6;border-color:#f1d98a}

/* Resultado */
.result-head{display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:12px}
.badge{background:#fff7e6;color:#7a5d00;border:1px solid #f1d98a;
  font-weight:800;padding:6px 14px;border-radius:20px;font-size:.8rem}
table.tbl{width:100%;border-collapse:collapse;margin:12px 0;font-size:.92rem}
table.tbl th{background:var(--green);color:#fff;text-align:left;padding:11px 12px;font-weight:600}
table.tbl td{padding:9px 12px;border-bottom:1px solid var(--borde);vertical-align:top}
table.tbl tr:nth-child(even) td{background:var(--gris-claro)}
.num{text-align:right;white-space:nowrap}
.center{text-align:center}
.det{color:var(--gris);font-size:.8rem}
.totales{margin-left:auto;width:320px;max-width:100%}
.totales td{padding:7px 12px}
.totales .total td{border-top:2px solid var(--green);font-weight:800;
  font-size:1.05rem;background:var(--verde-claro)}
.resumen{display:grid;grid-template-columns:1fr 1fr;gap:6px 24px;
  background:var(--gris-claro);border-radius:12px;padding:16px 20px;margin:6px 0 4px}
@media(max-width:620px){.resumen{grid-template-columns:1fr}}
.resumen .r{display:flex;justify-content:space-between;border-bottom:1px dashed #cdd8cf;padding:4px 0}
.resumen .r b{color:var(--green-900)}

.aviso{border:1.5px solid var(--green);background:#f4f9f5;border-radius:12px;
  padding:16px 18px;margin-top:22px;font-size:.88rem;color:#333}
.aviso b{color:var(--green-900)}

/* Footer (como site-footer) */
.footer{text-align:center;color:#d9e4dc;background:var(--green-900);
  font-size:.85rem;padding:34px 20px;margin-top:48px}
.footer a{color:#fff;text-decoration:underline}
.footer .muted{color:rgba(217,228,220,.8);font-size:.78rem}
.muted{color:var(--gris)}
.back{display:inline-block;margin-bottom:14px;font-size:.9rem;font-weight:600}

@media (prefers-reduced-motion: reduce){
  *{transition:none!important}
  html{scroll-behavior:auto}
}
