/*
Theme Name: RAMAS Fluid
Theme URI: https://somosramas.com
Author: WIXA / RAMAS
Description: Tema minimalista tipo "fluid" para RAMAS + RA+. Crea páginas y menús al activarse.
Version: 1.1.3
License: GPLv2 or later
Text Domain: ramas-fluid
*/

:root{
  --bg:#FAF9F6;
  --ink:#0B0B0B;
  --muted:#6B6B6B;
  --line:rgba(0,0,0,.12);
  --max:1200px;
  --pad:clamp(18px,3vw,42px);
  --h1:clamp(34px,5vw,64px);
  --h2:clamp(22px,3vw,34px);
  --p:clamp(15px,1.35vw,18px);
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Noto Sans", "Helvetica Neue", sans-serif;
  line-height:1.55;
  letter-spacing:.01em;
}
a{color:inherit;text-decoration:none}
a:hover{opacity:.85}
hr{border:0;border-top:1px solid var(--line);margin:0}
.wrap{max-width:var(--max);margin:0 auto;padding:0 var(--pad)}
.section{padding:clamp(46px,7vw,96px) 0}
.kicker{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
h1{font-size:var(--h1);line-height:1.05;margin:.25em 0 .35em}
h2{font-size:var(--h2);line-height:1.15;margin:0 0 .6em}
p{font-size:var(--p);margin:0 0 1em;color:rgba(0,0,0,.82)}
.small{font-size:14px;color:var(--muted)}
.btn{display:inline-flex;align-items:center;gap:.6rem;border:1px solid var(--ink);padding:.9rem 1.1rem;border-radius:999px;font-size:14px;letter-spacing:.12em;text-transform:uppercase}
.btn.secondary{border-color:var(--line)}
.grid{display:grid;gap:clamp(18px,2.4vw,28px)}
.grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
@media (max-width:900px){.grid.cols-2,.grid.cols-3{grid-template-columns:1fr}}
.card{border:1px solid var(--line);border-radius:18px;padding:22px;background:rgba(255,255,255,.55)}
.card h3{margin:.2em 0 .4em;font-size:18px}
.card p{margin:0;color:rgba(0,0,0,.75)}
.site-header{position:sticky;top:0;z-index:50;backdrop-filter:saturate(180%) blur(10px);background:rgba(250,249,246,.82);border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:14px var(--pad);max-width:var(--max);margin:0 auto}
.brand{display:flex;align-items:baseline;gap:.55rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;font-size:13px}
.brand .mark{font-weight:800;letter-spacing:.06em;font-size:14px}
.nav{display:flex;gap:18px;align-items:center;font-size:13px;letter-spacing:.12em;text-transform:uppercase}
.nav a{padding:10px 8px;border-radius:10px}
.nav a:hover{background:rgba(0,0,0,.04)}
.nav-toggle{display:none}
@media (max-width:900px){
  .nav{display:none}
  .nav-toggle{display:inline-flex;border:1px solid var(--line);background:transparent;border-radius:12px;padding:10px 12px;font-size:12px;letter-spacing:.14em;text-transform:uppercase}
  .mobile{display:none;border-top:1px solid var(--line);padding:10px var(--pad) 18px}
  .mobile a{display:block;padding:12px 0;border-bottom:1px solid rgba(0,0,0,.06)}
  .mobile a:last-child{border-bottom:0}
  body.menu-open .mobile{display:block}
}
.hero{padding:clamp(64px,9vw,120px) 0}
.hero .lead{font-size:clamp(16px,1.6vw,20px);max-width:58ch;color:rgba(0,0,0,.78)}
.hero .actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px}
.hero .meta{margin-top:28px;display:flex;gap:10px;flex-wrap:wrap;color:var(--muted);font-size:12px;letter-spacing:.14em;text-transform:uppercase}
.meta span{padding:7px 10px;border:1px solid var(--line);border-radius:999px}
.footer{border-top:1px solid var(--line);padding:36px 0}
.footer-cols{display:grid;grid-template-columns:2fr 1fr 1fr;gap:24px}
@media (max-width:900px){.footer-cols{grid-template-columns:1fr}}
.form-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
input[type="email"]{padding:12px 14px;border:1px solid var(--line);border-radius:999px;min-width:min(420px,92vw);background:rgba(255,255,255,.65)}


/* Nav list normalization */
.nav ul{list-style:none; margin:0; padding:0; display:flex; gap:18px; align-items:center}
.nav li{margin:0; padding:0}
.nav a{display:inline-block}
.mobile{display:none !important}
.nav-toggle{display:none !important}

/* Disable mobile duplicate menu (single top nav) */
.mobile{display:none !important}
.nav-toggle{display:none !important}

@media (max-width: 768px){
  .nav-toggle{display:block}
  .nav ul{display:none;flex-direction:column;gap:14px;margin-top:18px}
  .nav.open ul{display:flex}
}


/* Mobile menu overlay (fullscreen) */
.nav-toggle{
  display:none;
  background:none;
  border:0;
  font-size:26px;
  line-height:1;
  padding:10px 12px;
  cursor:pointer;
}
@media (max-width: 768px){
  .nav-toggle{display:block}
  .nav ul{display:flex} /* desktop default; overridden by overlay */
  .nav{
    position:fixed;
    inset:0;
    width:100%;
    height:100vh;
    background:rgba(255,255,255,.96);
    backdrop-filter:saturate(120%) blur(10px);
    display:none;
    align-items:center;
    justify-content:center;
    z-index:9999;
  }
  .nav.open{display:flex}
  .nav ul{
    display:flex;
    flex-direction:column;
    gap:22px;
    margin:0;
    padding:0;
    list-style:none;
    text-align:center;
  }
  .nav a{
    font-size:14px;
    letter-spacing:.18em;
  }
  body.nav-open{overflow:hidden}
}


/* v1.1.3 definitive mobile overlay overrides */
@media (max-width: 768px){
  .nav-toggle{display:block !important}
  .nav{
    display:none !important;
    position:fixed !important;
    inset:0 !important;
    width:100% !important;
    height:100vh !important;
    background:rgba(255,255,255,.96) !important;
    backdrop-filter:saturate(120%) blur(10px) !important;
    align-items:center !important;
    justify-content:center !important;
    z-index:9999 !important;
  }
  .nav.open{display:flex !important}
  .nav ul{
    display:flex !important;
    flex-direction:column !important;
    gap:22px !important;
    margin:0 !important;
    padding:0 !important;
    list-style:none !important;
    text-align:center !important;
  }
  body.nav-open{overflow:hidden}
}
@media (min-width: 769px){
  .nav-toggle{display:none !important}
  .nav{display:block !important; position:static !important; height:auto !important; background:transparent !important; backdrop-filter:none !important}
  .nav ul{display:flex !important; flex-direction:row !important; gap:18px !important}
}
