:root{
  --ag-max:1120px;
  --ag-bg:#efe5d2;
  --ag-bg-2:#e6d5bb;
  --ag-surface:#fffaf1;
  --ag-border:#d3bea0;
  --ag-green:#2d4a2d;
  --ag-green-2:#3f6b3f;
  --ag-gold:#b98738;
  --ag-text:#2b241c;
  --ag-muted:#665a4b;
  --ag-shadow:0 14px 34px rgba(64,43,20,.10);
}
html{scroll-behavior:smooth;}
body{min-width:0;}
img,svg,video{max-width:100%;height:auto;}
.global-header{
  position:sticky;
  top:0;
  z-index:2000;
  background:rgba(239,229,210,.94);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(211,190,160,.86);
}
.global-nav{
  max-width:var(--ag-max);
  margin:0 auto;
  min-height:76px;
  padding:12px 20px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
}
.global-logo{
  display:inline-flex;
  align-items:center;
  text-decoration:none;
  min-width:0;
}
.global-logo img{
  display:block;
  height:52px;
  width:auto;
  object-fit:contain;
}
.global-menu{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:.88rem;
  font-weight:800;
}
.global-menu a{
  color:var(--ag-muted);
  text-decoration:none;
  padding:9px 12px;
  border-radius:999px;
  border:1px solid transparent;
  line-height:1.15;
}
.global-menu a:hover,
.global-menu a.is-active{
  color:var(--ag-green);
  background:rgba(255,250,241,.66);
  border-color:rgba(211,190,160,.85);
}
.global-menu a.menu-primary{
  background:var(--ag-green);
  color:#fff;
  border-color:var(--ag-green);
  box-shadow:0 8px 18px rgba(45,74,45,.18);
}
.global-menu a.menu-primary:hover{background:#213b21;color:#fff;}
.global-menu-toggle{
  display:none;
  width:44px;
  height:44px;
  border:1px solid rgba(211,190,160,.95);
  border-radius:12px;
  background:rgba(255,250,241,.78);
  cursor:pointer;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:5px;
  padding:0;
  flex-shrink:0;
}
.global-menu-toggle span{
  width:21px;
  height:2px;
  background:var(--ag-green);
  border-radius:999px;
  transition:transform .18s ease,opacity .18s ease;
}
.global-menu-toggle.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.global-menu-toggle.is-open span:nth-child(2){opacity:0;}
.global-menu-toggle.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

.breadcrumb-shell{
  max-width:var(--ag-max);
  margin:0 auto;
  padding:18px 20px 0;
}
.breadcrumbs{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
  color:var(--ag-muted);
  font-size:.82rem;
}
.breadcrumbs a{
  color:var(--ag-green);
  font-weight:900;
  text-decoration:none;
}
.breadcrumbs span{color:var(--ag-muted);}
.page-intro{
  max-width:var(--ag-max);
  margin:14px auto 20px;
  padding:22px 22px 20px;
  background:rgba(255,250,241,.72);
  border:1px solid rgba(211,190,160,.88);
  border-radius:24px;
  box-shadow:var(--ag-shadow);
}
.page-intro .eyebrow,
.page-intro .ag-eyebrow{
  display:inline-block;
  background:rgba(45,74,45,.10);
  color:var(--ag-green);
  border:1px solid rgba(45,74,45,.18);
  padding:5px 10px;
  border-radius:999px;
  font-size:.72rem;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.07em;
  margin-bottom:10px;
}
.page-intro h1{
  color:var(--ag-text);
  font-size:clamp(1.45rem,3.4vw,2.35rem);
  line-height:1.05;
  letter-spacing:-.035em;
  margin:0 0 8px;
}
.page-intro p{
  color:var(--ag-muted);
  font-size:.96rem;
  max-width:760px;
  margin:0;
}
.contact-section{
  max-width:var(--ag-max);
  margin:0 auto 70px;
  padding:0 20px;
}
.contact-card{
  background:rgba(255,250,241,.78);
  border:1px solid rgba(211,190,160,.9);
  border-radius:24px;
  box-shadow:var(--ag-shadow);
  padding:28px;
}
.contact-grid{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:24px;
  align-items:start;
}
.contact-card h2{
  font-size:clamp(1.5rem,3vw,2.4rem);
  line-height:1.08;
  letter-spacing:-.035em;
  margin:0 0 10px;
  color:var(--ag-text);
}
.contact-card p{color:var(--ag-muted);margin:0 0 14px;}
.contact-note{
  background:rgba(45,74,45,.08);
  border:1px solid rgba(45,74,45,.16);
  border-left:5px solid var(--ag-green);
  border-radius:16px;
  padding:14px;
  color:var(--ag-muted);
  font-size:.92rem;
}
.contact-form{
  display:grid;
  gap:12px;
}
.contact-form label{
  display:grid;
  gap:5px;
  color:var(--ag-muted);
  font-size:.82rem;
  font-weight:800;
}
.contact-form input,
.contact-form textarea,
.contact-form select{
  width:100%;
  border:1px solid rgba(211,190,160,.95);
  border-radius:12px;
  background:#fffaf1;
  color:var(--ag-text);
  padding:12px 13px;
  font:inherit;
}
.contact-form textarea{min-height:118px;resize:vertical;}
.contact-form button,
.contact-form .mailto-button{
  border:0;
  border-radius:999px;
  background:var(--ag-green);
  color:#fff;
  font-weight:900;
  padding:13px 18px;
  cursor:pointer;
  text-align:center;
  text-decoration:none;
  display:inline-flex;
  justify-content:center;
}
.contact-form small{color:var(--ag-muted);font-size:.75rem;line-height:1.45;}
.table-wrap{max-width:100%;}
table{max-width:100%;}
@media (max-width:860px){
  .global-nav{min-height:68px;padding:10px 16px;position:relative;}
  .global-logo img{height:46px;}
  .global-menu-toggle{display:inline-flex;}
  .global-menu{
    position:absolute;
    top:calc(100% + 8px);
    left:16px;
    right:16px;
    display:none;
    flex-direction:column;
    align-items:stretch;
    gap:8px;
    padding:12px;
    background:rgba(255,250,241,.98);
    border:1px solid rgba(211,190,160,.95);
    border-radius:18px;
    box-shadow:0 18px 34px rgba(64,43,20,.16);
  }
  .global-menu.is-open{display:flex;}
  .global-menu a{
    display:block;
    width:100%;
    white-space:normal;
    background:rgba(239,229,210,.58);
    border:1px solid rgba(211,190,160,.72);
    border-radius:12px;
    padding:12px;
    color:var(--ag-text);
  }
  .global-menu a.menu-primary{
    background:var(--ag-green);
    color:#fff;
    text-align:center;
  }
  .breadcrumb-shell{padding-left:16px;padding-right:16px;}
  .contact-grid{grid-template-columns:1fr;}
}
@media (max-width:520px){
  .global-logo img{height:40px;}
  .contact-card{padding:20px;}
}


/* V3: header desktop completo y hamburguesa limpia en páginas con CSS heredado */
.global-menu-toggle,
button.global-menu-toggle{
  background:rgba(255,250,241,.78) !important;
  background-color:rgba(255,250,241,.78) !important;
  border:1px solid rgba(211,190,160,.95) !important;
  box-shadow:none !important;
  color:var(--ag-green) !important;
}
.global-menu-toggle span,
button.global-menu-toggle span{
  display:block !important;
  width:21px !important;
  height:2px !important;
  min-height:2px !important;
  padding:0 !important;
  margin:0 !important;
  border:0 !important;
  border-radius:999px !important;
  background:var(--ag-green) !important;
  background-color:var(--ag-green) !important;
  opacity:1;
}
.global-menu-toggle.is-open span:nth-child(2),
button.global-menu-toggle.is-open span:nth-child(2){opacity:0 !important;}
.global-menu-toggle:hover,
button.global-menu-toggle:hover{
  background:#fffaf1 !important;
  background-color:#fffaf1 !important;
}
@media (min-width:861px){
  .global-menu-toggle,
  button.global-menu-toggle{display:none !important;}
  .global-menu{display:flex !important;}
}
@media (max-width:860px){
  .global-menu-toggle,
  button.global-menu-toggle{display:inline-flex !important;}
}


/* V11: sistema definitivo de ancho y alineación transversal */
:root{
  --ag-container:1120px;
  --ag-gutter-desktop:40px;
  --ag-gutter-tablet:32px;
  --ag-gutter-mobile:28px;
  --ag-page-width:min(calc(100% - var(--ag-gutter-desktop)), var(--ag-container));
}
.global-nav,
.breadcrumb-shell,
.page-intro,
.app-wrap,
.wrap,
.shell,
.contact-section{
  width:var(--ag-page-width) !important;
  max-width:none !important;
  margin-left:auto !important;
  margin-right:auto !important;
  box-sizing:border-box !important;
}
.global-nav,
.breadcrumb-shell,
.app-wrap,
.wrap,
.shell,
.contact-section{
  padding-left:0 !important;
  padding-right:0 !important;
}
.page-intro{
  padding-left:22px !important;
  padding-right:22px !important;
}
.global-nav{
  padding-left:0 !important;
  padding-right:0 !important;
}
@media (max-width:860px){
  :root{--ag-page-width:min(calc(100% - var(--ag-gutter-tablet)), var(--ag-container));}
  .global-nav{padding-top:12px !important;padding-bottom:12px !important;}
  .page-intro{padding-left:18px !important;padding-right:18px !important;}
}
@media (max-width:520px){
  :root{--ag-page-width:min(calc(100% - var(--ag-gutter-mobile)), var(--ag-container));}
  .page-intro{padding-left:16px !important;padding-right:16px !important;}
}
