*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --beige: oklch(0.82 0.04 75);
  --beige-light: oklch(0.94 0.02 75);
  --beige-dark: oklch(0.55 0.05 75);
  --black: #1a1a1a;
  --dark: #222;
  --gray: #777;
  --gray-light: #bbb;
  --bg: #fafaf8;
  --white: #fff;
  --serif: 'Cormorant Garamond', Georgia, serif;
  --sans: 'Montserrat', Helvetica, sans-serif;
}
html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%}
body{font-family:var(--sans);color:var(--black);background:var(--bg);overflow-x:hidden;line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent}
img{max-width:100%;display:block}
button{font-family:inherit;-webkit-tap-highlight-color:transparent}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:1.1rem 3rem;display:flex;align-items:center;justify-content:space-between;background:rgba(255,255,255,.94);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid rgba(0,0,0,.05);transition:padding .3s}
nav.scrolled{padding:.65rem 3rem;box-shadow:0 2px 20px rgba(0,0,0,.04)}
nav .logo img{height:48px;transition:height .3s}
nav.scrolled .logo img{height:36px}
nav ul{list-style:none;display:flex;gap:2.2rem;align-items:center}
nav ul a{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;font-weight:500;position:relative;color:var(--black);transition:color .3s}
nav ul a:hover{color:var(--beige-dark)}
nav ul a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1.5px;background:var(--beige-dark);transition:width .3s}
nav ul a:hover::after{width:100%}
.nav-cta{background:var(--black)!important;color:var(--white)!important;padding:.55rem 1.5rem;border-radius:0;font-size:.68rem!important;letter-spacing:.14em;transition:background .3s}
.nav-cta:hover{background:var(--beige-dark)!important}
.nav-cta::after{display:none!important}
.hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;cursor:pointer;padding:10px;border:none;background:transparent;position:relative;z-index:102;width:44px;height:44px}
.hamburger span{width:22px;height:2px;background:var(--black);transition:transform .3s,opacity .3s;display:block}
nav.open .hamburger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
nav.open .hamburger span:nth-child(2){opacity:0}
nav.open .hamburger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-menu{display:none}
.mobile-overlay{display:none}

/* COMMON */
.container{max-width:1200px;margin:0 auto;padding:0 2rem}
section{padding:6rem 3rem}
.section-label{font-size:.62rem;letter-spacing:.25em;text-transform:uppercase;color:var(--beige-dark);margin-bottom:.8rem;font-weight:600}
.section-title{font-family:var(--serif);font-size:clamp(1.8rem,3.5vw,2.6rem);font-weight:400;margin-bottom:.8rem;line-height:1.25}
.section-subtitle{font-size:.82rem;color:var(--gray);max-width:520px;line-height:1.85;letter-spacing:.02em}
.btn{display:inline-block;padding:.85rem 2.2rem;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;font-family:var(--sans);font-weight:500;border:none;cursor:pointer;transition:all .3s;min-height:44px;line-height:1.8}
.btn-primary{background:var(--black);color:var(--white)}
.btn-primary:hover{background:var(--beige-dark)}
.btn-outline{border:1.5px solid var(--black);background:transparent;color:var(--black)}
.btn-outline:hover{background:var(--black);color:var(--white)}
.btn-beige{background:var(--beige);color:var(--black)}
.btn-beige:hover{background:var(--beige-dark);color:var(--white)}

/* PAGE HERO */
.page-hero{padding:10rem 3rem 4rem;background:var(--white);border-bottom:1px solid rgba(0,0,0,.04)}
.page-hero .section-title{font-size:clamp(2rem,4vw,3rem)}

/* PLACEHOLDER IMG */
.placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:'Courier New',monospace;font-size:.72rem;color:var(--gray);text-align:center;padding:1rem;background:repeating-linear-gradient(45deg,transparent,transparent 12px,rgba(0,0,0,.012) 12px,rgba(0,0,0,.012) 24px);background-color:var(--beige-light)}

/* IMG FRAME — auto-crop with graceful fallback when image missing */
.img-frame{position:relative;width:100%;height:100%;overflow:hidden;background:repeating-linear-gradient(45deg,transparent,transparent 12px,rgba(0,0,0,.012) 12px,rgba(0,0,0,.012) 24px);background-color:var(--beige-light)}
.img-frame::before{content:attr(data-label);position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:'Courier New',monospace;font-size:.7rem;color:var(--gray);text-align:center;padding:1rem;line-height:1.5;letter-spacing:.04em;pointer-events:none}
.img-frame img{position:relative;z-index:1;width:100%;height:100%;object-fit:cover;object-position:center;display:block;background:var(--beige-light)}
.img-frame img.broken{display:none}

/* FOOTER */
footer{padding:4rem 3rem 2rem;background:var(--black);color:var(--white)}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
.footer-col h5{font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:var(--beige);margin-bottom:1.2rem}
.footer-col p,.footer-col a{font-size:.8rem;color:rgba(255,255,255,.5);line-height:2;display:block;transition:color .3s}
.footer-col a:hover{color:var(--beige)}
.footer-col .logo-footer{height:40px;margin-bottom:1rem}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:1.5rem;text-align:center;font-size:.68rem;color:rgba(255,255,255,.3);letter-spacing:.06em}

/* WHATSAPP */
.whatsapp-float{position:fixed;bottom:1.5rem;right:1.5rem;width:56px;height:56px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:99;box-shadow:0 4px 16px rgba(37,211,102,.35);transition:transform .3s}
.whatsapp-float:hover{transform:scale(1.1)}
.whatsapp-float svg{width:28px;height:28px;fill:#fff}

/* TABLET */
@media(max-width:960px){
  nav{padding:1rem 2rem}
  nav.scrolled{padding:.6rem 2rem}
  section{padding:5rem 2rem}
  .page-hero{padding:8rem 2rem 3rem}
  footer{padding:3.5rem 2rem 1.5rem}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2.5rem}
}

/* MOBILE */
@media(max-width:640px){
  html{font-size:15px}
  nav{padding:.9rem 1.25rem}
  nav.scrolled{padding:.55rem 1.25rem}
  nav .logo img{height:40px}
  nav.scrolled .logo img{height:32px}
  nav ul.desktop-nav{display:none}
  .hamburger{display:flex}
  .mobile-menu{display:flex!important;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:var(--white);padding:1rem 1.25rem 1.5rem;gap:0;border-bottom:1px solid rgba(0,0,0,.06);box-shadow:0 8px 24px rgba(0,0,0,.06);transform-origin:top;transform:scaleY(0);opacity:0;transition:transform .25s ease,opacity .2s ease;z-index:99;pointer-events:none}
  nav.open .mobile-menu{transform:scaleY(1);opacity:1;pointer-events:auto}
  .mobile-menu a{font-size:.85rem;letter-spacing:.12em;text-transform:uppercase;font-weight:500;padding:1rem .5rem;border-bottom:1px solid rgba(0,0,0,.06);color:var(--black)}
  .mobile-menu a:last-child{border-bottom:none;margin-top:.75rem;background:var(--black);color:var(--white);text-align:center;padding:1rem;letter-spacing:.14em}
  .mobile-overlay{display:block;position:fixed;inset:0;background:rgba(0,0,0,.25);opacity:0;pointer-events:none;transition:opacity .25s;z-index:98}
  nav.open ~ .mobile-overlay{opacity:1;pointer-events:auto}
  section{padding:3.5rem 1.25rem}
  .page-hero{padding:6.5rem 1.25rem 2.5rem}
  .page-hero .section-title{font-size:clamp(1.7rem,6vw,2.2rem)}
  .section-title{font-size:clamp(1.5rem,5vw,2rem)}
  .section-subtitle{font-size:.85rem}
  .btn{padding:.9rem 1.6rem;font-size:.72rem}
  .btn-group{flex-direction:column;align-items:stretch}
  .btn-group .btn{text-align:center}
  footer{padding:3rem 1.25rem 1.5rem}
  .footer-grid{grid-template-columns:1fr;gap:2rem;margin-bottom:2rem}
  .footer-col p,.footer-col a{font-size:.82rem;line-height:1.9}
  .whatsapp-float{bottom:1rem;right:1rem;width:52px;height:52px}
  .whatsapp-float svg{width:26px;height:26px}
}

/* SMALL PHONE */
@media(max-width:380px){
  nav{padding:.8rem 1rem}
  section{padding:3rem 1rem}
  .page-hero{padding:6rem 1rem 2rem}
  footer{padding:2.5rem 1rem 1.25rem}
  .mobile-menu{width:90vw}
}
