/* ============================================================
   TU ASESOR CONTABLE HG — ESTILOS GLOBALES 2026
   Paleta: crema/beige + verde institucional oscuro + dorado suave
   Tipografía: Cormorant Garamond (display/cursiva) + Jost (cuerpo)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500;1,600;1,700&family=Jost:wght@300;400;500;600;700&family=DM+Mono:wght@400;500&display=swap');

:root {
  --crema:      #F5F0E8;
  --crema2:     #EDE8DC;
  --crema3:     #E2DBD0;
  --verde:      #2D4A3E;
  --verde-med:  #3A5F51;
  --verde-clr:  #4E7A69;
  --verde-band: #2D4A3E;
  --dorado:     #8B7355;
  --dorado-cl:  #A08B6E;
  --texto:      #1C2B24;
  --texto-med:  #3D4F47;
  --muted:      #7A8C82;
  --borde:      #D5CEC4;
  --borde-v:    rgba(45,74,62,.15);
  --blanco:     #FFFFFF;
  --sombra:     rgba(45,74,62,.08);
  --sombra-md:  rgba(45,74,62,.15);
  --font-titulo: 'Cormorant Garamond', Georgia, serif;
  --font-body:   'Jost', system-ui, sans-serif;
  --font-mono:   'DM Mono', monospace;
  --max-w: 1280px;
  --r:    6px;
  --r-lg: 14px;
  --r-xl: 24px;
  --trans: all .25s ease;
  --shadow: 0 4px 24px var(--sombra);
  --shadow-hover: 0 10px 40px var(--sombra-md);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-body);background:var(--crema);color:var(--texto);line-height:1.75;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
input,textarea,select,button{font-family:var(--font-body)}

.container{max-width:var(--max-w);margin:0 auto;padding:0 2rem}
.container-sm{max-width:860px;margin:0 auto;padding:0 2rem}

.tag{display:inline-block;font-family:var(--font-mono);font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--verde);border:1px solid var(--verde-clr);padding:.3rem .9rem;border-radius:50px;margin-bottom:1.2rem;background:rgba(45,74,62,.06)}

.sec-titulo{font-family:var(--font-titulo);font-size:clamp(2rem,4vw,3.4rem);font-weight:600;line-height:1.1;margin-bottom:1rem;color:var(--texto);letter-spacing:-.01em}
.sec-titulo em{font-style:italic;color:var(--verde-clr);font-weight:500}
.sec-sub{font-size:1rem;color:var(--muted);line-height:1.85;max-width:560px;font-weight:400}
.linea{width:50px;height:2px;background:linear-gradient(90deg,var(--verde),transparent);margin:.8rem 0 1.8rem}
.linea-c{margin-left:auto;margin-right:auto}
.text-c{text-align:center}
.text-muted{color:var(--muted)}

.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 1.8rem;font-size:.9rem;font-weight:600;letter-spacing:.02em;border-radius:50px;cursor:pointer;transition:var(--trans);border:none;text-decoration:none;white-space:nowrap;font-family:var(--font-body)}
.btn-sm{padding:.6rem 1.4rem;font-size:.82rem}
.btn-p{background:var(--verde);color:var(--crema)}
.btn-p:hover{background:var(--verde-med);transform:translateY(-2px);box-shadow:0 6px 20px rgba(45,74,62,.3)}
.btn-s{background:transparent;color:var(--verde);border:1.5px solid var(--verde)}
.btn-s:hover{background:var(--verde);color:var(--crema)}
.btn-full{width:100%;justify-content:center}
.btn-dorado{background:var(--dorado);color:var(--blanco)}
.btn-dorado:hover{background:var(--dorado-cl);transform:translateY(-2px)}
.btn-danger{background:rgba(180,50,40,.1);color:#b43228;border:1px solid rgba(180,50,40,.25)}
.btn-danger:hover{background:#b43228;color:#fff}

.chip{display:inline-block;padding:.28rem .9rem;border-radius:50px;font-size:.72rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}
.chip-v{background:rgba(45,74,62,.1);color:var(--verde);border:1px solid rgba(45,74,62,.2)}
.chip-d{background:var(--dorado);color:var(--blanco)}
.chip-s{background:var(--crema3);color:var(--muted);border:1px solid var(--borde)}

.card{background:var(--blanco);border:1px solid var(--borde);border-radius:var(--r-lg);overflow:hidden;transition:var(--trans)}
.card:hover{transform:translateY(-4px);border-color:rgba(45,74,62,.25);box-shadow:var(--shadow-hover)}
.card-body{padding:1.5rem}
.card-body-lg{padding:2rem 2.5rem}

.form-group{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem}
.form-label{font-size:.75rem;font-weight:600;color:var(--verde);letter-spacing:.06em;text-transform:uppercase}
.form-control{background:var(--blanco);border:1.5px solid var(--borde);border-radius:var(--r);padding:.8rem 1rem;color:var(--texto);font-size:.9rem;outline:none;transition:border-color .2s;width:100%}
.form-control::placeholder{color:var(--muted);opacity:.7}
.form-control:focus{border-color:var(--verde-clr);box-shadow:0 0 0 3px rgba(78,122,105,.12)}
textarea.form-control{resize:vertical;min-height:130px}
select.form-control{cursor:pointer}

.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}

.avatar{width:42px;height:42px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,var(--verde),var(--verde-clr));display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;color:var(--crema)}
.avatar-lg{width:72px;height:72px;font-size:1.2rem}
.avatar-xl{width:100px;height:100px;font-size:1.6rem}

.divider{height:1px;background:var(--borde);margin:2rem 0}
.img-ph{background:linear-gradient(135deg,var(--crema2) 0%,var(--crema3) 100%);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:.8rem;color:var(--borde);font-family:var(--font-mono);font-size:.78rem}

.section{padding:7rem 0}
.section-alt{background:var(--crema2)}
.section-verde{background:var(--verde)}

.fade-in{opacity:0;transform:translateY(24px);transition:opacity .65s ease,transform .65s ease}
.fade-in.visible{opacity:1;transform:translateY(0)}
.fade-in-d1{transition-delay:.1s}
.fade-in-d2{transition-delay:.2s}
.fade-in-d3{transition-delay:.3s}

@keyframes pulso{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.4)}}
@keyframes deslizar{from{transform:translateX(0)}to{transform:translateX(-50%)}}

.toast{position:fixed;bottom:2rem;left:50%;transform:translateX(-50%) translateY(80px);background:var(--verde);border-radius:50px;padding:.75rem 1.8rem;font-size:.88rem;font-weight:500;color:var(--crema);box-shadow:var(--shadow);z-index:9999;opacity:0;transition:all .35s ease;white-space:nowrap}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.error{background:#b43228}

.overlay{position:fixed;inset:0;background:rgba(28,43,36,.65);z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem;opacity:0;pointer-events:none;transition:opacity .3s}
.overlay.open{opacity:1;pointer-events:all}
.modal{background:var(--blanco);border-radius:var(--r-xl);max-width:540px;width:100%;padding:2.5rem;position:relative;transform:scale(.96);transition:transform .3s}
.overlay.open .modal{transform:scale(1)}
.modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;color:var(--muted);cursor:pointer;font-size:1.4rem;line-height:1;transition:color .2s}
.modal-close:hover{color:var(--texto)}

#scrollTop{position:fixed;bottom:2rem;right:2rem;width:46px;height:46px;background:var(--verde);color:var(--crema);border:none;border-radius:50%;font-size:1.1rem;cursor:pointer;box-shadow:0 4px 20px rgba(45,74,62,.3);transition:var(--trans);z-index:99;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none}
#scrollTop.visible{opacity:1;pointer-events:all}
#scrollTop:hover{transform:translateY(-3px)}

#carritoBtn{position:fixed;bottom:2rem;left:2rem;background:var(--blanco);border:1.5px solid var(--borde);color:var(--verde);border-radius:50px;padding:.65rem 1.2rem;font-size:.85rem;font-weight:600;cursor:pointer;transition:var(--trans);z-index:99;display:flex;align-items:center;gap:.6rem;box-shadow:var(--shadow)}
#carritoBtn:hover{border-color:var(--verde);background:var(--verde);color:var(--crema)}
#carritoBadge{background:var(--verde);color:var(--crema);border-radius:50%;width:20px;height:20px;font-size:.7rem;font-weight:700;display:flex;align-items:center;justify-content:center}

.nav-logo-wrap{display:flex;align-items:center;flex-shrink:0;text-decoration:none}
.nav-logo-img{height:52px;width:auto;object-fit:contain;filter:drop-shadow(0 2px 6px rgba(45,74,62,.12));transition:filter .25s,transform .25s}
.nav-logo-img:hover{filter:drop-shadow(0 4px 14px rgba(45,74,62,.25));transform:scale(1.03)}

.footer-logo-wrap{margin-bottom:.5rem}
.footer-logo-img{height:70px;width:auto;object-fit:contain;filter:brightness(0) invert(1) opacity(.85)}

.footer-visitas{display:flex;align-items:center;justify-content:center;gap:.6rem;padding:1.2rem 0;margin:1.5rem 0 0;border-top:1px solid rgba(255,255,255,.12);border-bottom:1px solid rgba(255,255,255,.12);font-size:.8rem;color:rgba(245,240,232,.6);font-family:var(--font-mono);letter-spacing:.04em}
.footer-visitas strong{color:var(--crema);font-size:.95rem}
.visitas-icon{font-size:1rem}

@media(max-width:1024px){.grid-4{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){.section{padding:4.5rem 0}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.sec-titulo{font-size:2rem}.btn{padding:.75rem 1.5rem}}
