:root{
  --primary:#241864;
  --primary-glow:#4b3aa8;
  --accent:#e0b94a;
  --accent-foreground:#3a2e10;
  --bg:#fbfaf7;
  --fg:#1a1230;
  --muted:#6b6786;
  --border:#e7e3ef;
  --card:#ffffff;
  --whatsapp:#25d366;
  --radius:14px;
  --shadow-soft:0 8px 24px -12px rgba(36,24,100,.18);
  --shadow-elegant:0 20px 50px -20px rgba(36,24,100,.35);
  --gradient-primary:linear-gradient(135deg,#241864,#4b3aa8);
  --gradient-soft:linear-gradient(180deg,#fbfaf7,#efeaff);
  --font-display:"Fraunces",ui-serif,Georgia,serif;
  --font-sans:"Inter",ui-sans-serif,system-ui,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font-sans);background:var(--bg);color:var(--fg);line-height:1.55}
h1,h2,h3{font-family:var(--font-display);letter-spacing:-.02em;color:var(--primary);margin:0}
h1{font-size:clamp(2.2rem,5vw,3.75rem);line-height:1.05;font-weight:600;margin-top:1.25rem}
h1 em{font-style:italic;color:var(--primary-glow)}
h2{font-size:clamp(1.75rem,3vw,2.4rem);font-weight:600}
h3{font-size:1.15rem;color:var(--fg);font-family:var(--font-sans);font-weight:600;letter-spacing:0}
p{margin:.5rem 0}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:1180px;margin:0 auto;padding:0 1.25rem}
.muted{color:var(--muted)}
.small{font-size:.875rem}

/* Header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(251,250,247,.85);backdrop-filter:blur(10px);border-bottom:1px solid var(--border)}
.utility-strip{background:var(--primary);color:#fff;font-size:.8rem}
.utility-inner{display:flex;gap:1.5rem;justify-content:flex-end;padding:.45rem 1.25rem;flex-wrap:wrap}
.utility-inner a:hover{color:var(--accent)}
.header-bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 1.25rem}
.logo{display:flex;align-items:center}
.logo-wordmark{width:360px;}
.logo-mark{height:40px;width:auto;display:none}
.desktop-nav{display:flex;gap:1.75rem;font-weight:500}
.desktop-nav a{color:var(--fg);font-size:.95rem}
.desktop-nav a:hover{color:var(--primary)}
.header-cta{display:inline-flex}
.hamburger{display:none;background:none;border:0;padding:.5rem;cursor:pointer;flex-direction:column;gap:5px}
.hamburger span{display:block;width:22px;height:2px;background:var(--primary);border-radius:2px}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.4rem;border-radius:999px;font-weight:600;font-size:.95rem;border:1px solid transparent;cursor:pointer;transition:all .2s;white-space:nowrap}
.btn-primary{background:var(--primary);color:#fff;box-shadow:var(--shadow-elegant)}
.btn-primary:hover{background:var(--primary-glow)}
.btn-outline{border-color:rgba(36,24,100,.3);color:var(--primary);background:transparent}
.btn-outline:hover{background:rgba(36,24,100,.05)}
.btn-accent{background:var(--accent);color:var(--accent-foreground)}
.btn-accent:hover{opacity:.9}
.btn-whatsapp{background:var(--whatsapp);color:#fff}
.btn-whatsapp:hover{opacity:.9}
.btn-row{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.5rem}

/* Drawer */
.drawer-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.4);opacity:0;pointer-events:none;transition:opacity .25s;z-index:60}
.drawer-backdrop.open{opacity:1;pointer-events:auto}
.drawer{position:fixed;top:0;right:0;bottom:0;width:320px;max-width:85vw;background:#fff;z-index:70;transform:translateX(100%);transition:transform .3s ease;display:flex;flex-direction:column;padding:1.25rem;overflow-y:auto}
.drawer.open{transform:translateX(0)}
.drawer-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}
.drawer-close{background:none;border:0;font-size:2rem;line-height:1;color:var(--primary);cursor:pointer}
.drawer-nav{display:flex;flex-direction:column;gap:.25rem}
.drawer-nav a{padding:.75rem .5rem;border-radius:8px;font-weight:500;color:var(--fg)}
.drawer-nav a:hover{background:rgba(36,24,100,.06);color:var(--primary)}
.drawer hr{border:0;border-top:1px solid var(--border);margin:1rem 0}
.drawer-contact p{font-size:.9rem;color:var(--muted);margin:.5rem 0}
.drawer-contact a:hover{color:var(--primary)}
.drawer-cta{justify-content:center;margin-top:1rem}

/* Hero */
.hero{position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;z-index:-1;opacity:.08;background:radial-gradient(circle at 20% 20%,var(--primary) 0,transparent 40%),radial-gradient(circle at 80% 60%,var(--accent) 0,transparent 40%)}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;padding:4rem 1.25rem 5rem}
.pill{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .85rem;border-radius:999px;border:1px solid rgba(36,24,100,.2);background:rgba(36,24,100,.05);color:var(--primary);font-size:.75rem;font-weight:500}
.lead{font-size:1.125rem;color:var(--muted);max-width:36rem;margin-top:1.25rem}
.hero-image-wrap{position:relative}
.hero-image-wrap::before{content:"";position:absolute;inset:-1rem;border-radius:28px;background:var(--gradient-primary);opacity:.2;filter:blur(40px)}
.hero-image-wrap img{position:relative;border-radius:24px;box-shadow:var(--shadow-elegant);aspect-ratio:1/1;object-fit:cover;width:100%}

/* Services */
.services{padding:5rem 0;background:var(--gradient-soft)}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-top:3rem}
.card{background:var(--card);border:1px solid var(--border);border-radius:18px;padding:1.5rem;transition:all .2s}
.card:hover{border-color:rgba(36,24,100,.4);box-shadow:var(--shadow-soft)}
.card .icon{width:48px;height:48px;border-radius:14px;background:rgba(36,24,100,.1);color:var(--primary);display:grid;place-items:center;font-size:1.4rem}
.card:hover .icon{background:var(--primary);color:#fff}
.card h3{margin-top:1.25rem}
.card p{font-size:.9rem;color:var(--muted);margin-top:.5rem}

/* Why */
.why{padding:5rem 0}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-top:3rem}
.badge{width:44px;height:44px;border-radius:12px;background:rgba(224,185,74,.3);display:grid;place-items:center;font-size:1.2rem}
.grid-4 h3{margin-top:1rem}
.grid-4 p{font-size:.9rem;color:var(--muted)}

/* About */
.about{padding:5rem 0;background:var(--primary);color:#fff;text-align:center}
.about-inner{max-width:760px;margin:0 auto}
.about h2{color:#fff;margin-top:1rem}
.about p{color:rgba(255,255,255,.8);font-size:1.125rem;margin:1.5rem 0 2rem}
.eyebrow{font-size:.75rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--accent)}

/* Contact */
.contact{padding:5rem 0}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem}
.contact-list{list-style:none;padding:0;margin:2rem 0;display:flex;flex-direction:column;gap:1.25rem}
.contact-list li{display:flex;gap:1rem}
.ci{width:40px;height:40px;flex-shrink:0;border-radius:12px;background:rgba(36,24,100,.1);color:var(--primary);display:grid;place-items:center;font-size:1.1rem}
.contact-list b{font-size:.7rem;letter-spacing:.1em;color:var(--muted);font-weight:600}
.contact-list p{margin:.15rem 0 0}
.contact-list a:hover{color:var(--primary)}
.map-wrap{border-radius:24px;overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow-soft);min-height:380px}
.map-wrap iframe{width:100%;height:100%;min-height:380px;border:0;display:block}

/* Footer */
.site-footer{border-top:1px solid var(--border);padding:2.5rem 0}
.footer-inner{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;font-size:.875rem;color:var(--muted)}
.footer-nav{display:flex;gap:1.5rem}
.footer-nav a:hover{color:var(--primary)}

/* Floating WA */
.float-wa{position:fixed;bottom:1.5rem;right:1.5rem;z-index:40;width:56px;height:56px;border-radius:50%;background:var(--whatsapp);color:#fff;display:grid;place-items:center;font-size:1.6rem;box-shadow:var(--shadow-elegant);transition:transform .2s}
.float-wa:hover{transform:scale(1.08)}

/* Responsive */
@media (max-width:900px){
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .hero-grid{grid-template-columns:1fr;padding:2.5rem 1.25rem 3rem}
  .contact-grid{grid-template-columns:1fr}
  .desktop-nav,.header-cta{display:none}
  .hamburger{display:flex}
  .utility-strip{display:none}
  .logo-wordmark{display:block}
  .logo-mark{display:none}
}
@media (max-width:560px){
  .grid-3,.grid-4{grid-template-columns:1fr}
}
