/* ===== Hanora — fonts ===== */
@font-face{font-family:"Rondira";src:url("/assets/fonts/Rondira-Medium.otf") format("opentype");font-weight:500;font-display:swap}
@font-face{font-family:"Chopin";src:url("/assets/fonts/Chopin-Light.ttf") format("truetype");font-weight:300;font-display:swap}
@font-face{font-family:"Champagne";src:url("/assets/fonts/Champagne-Italic.ttf") format("truetype");font-style:italic;font-display:swap}
@font-face{font-family:"Florisha";src:url("/assets/fonts/Florisha-Bold.otf") format("opentype");font-weight:700;font-display:swap}
@font-face{font-family:"Photoshoot";src:url("/assets/fonts/Photoshoot-Regular.ttf") format("truetype");font-display:swap}

/* ===== palette ===== */
:root{
  --navy:#2a394d; --navy-deep:#1f2b3c; --gold:#c7b38e; --gold-deep:#b89f72; --slate:#4f7280;
  --cream:#f5f2e8; --cream-deep:#ece6d6; --ink:#2a394d;
  --hairline:rgba(42,57,77,.12);
  --maxw:1180px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Chopin","Champagne",Georgia,serif;
  color:var(--ink); background:var(--cream);
  background-image:url("/assets/fondos/portada.png");
  background-size:520px; background-repeat:repeat;
  line-height:1.65; font-size:18px; letter-spacing:.2px;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--gold);color:#fff}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.display{font-family:"Rondira",serif;font-weight:500;letter-spacing:1px;line-height:1.05}
.script{font-family:"Champagne",cursive;font-style:italic;color:var(--gold)}

/* ===== buttons — sweep fill ===== */
.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:"Chopin";font-size:14px;letter-spacing:2px;text-transform:uppercase;
  padding:14px 30px;border-radius:2px;border:1px solid var(--navy);color:var(--navy);background:transparent;
  cursor:pointer;overflow:hidden;isolation:isolate;transition:color .35s var(--ease),border-color .35s var(--ease)}
.btn::before{content:"";position:absolute;inset:0;z-index:-1;background:var(--navy);
  transform:scaleX(0);transform-origin:right;transition:transform .45s var(--ease-out)}
.btn:hover{color:var(--cream)}
.btn:hover::before{transform:scaleX(1);transform-origin:left}
.btn.solid{background:var(--navy);color:var(--cream)}
.btn.solid::before{background:var(--slate)}
.btn.gold{background:var(--gold);border-color:var(--gold);color:#fff}
.btn.gold::before{background:var(--navy)}
.btn.gold:hover{border-color:var(--navy)}
.btn.ghost{border-color:var(--cream);color:var(--cream)}
.btn.ghost::before{background:var(--cream)}
.btn.ghost:hover{color:var(--navy)}

/* ===== header ===== */
header{position:sticky;top:0;z-index:50;backdrop-filter:blur(12px);
  background:rgba(245,242,232,.82);border-bottom:1px solid transparent;
  transition:border-color .4s var(--ease),box-shadow .4s var(--ease)}
header.scrolled{border-bottom-color:var(--hairline);box-shadow:0 12px 30px -22px rgba(42,57,77,.35)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px;transition:height .35s var(--ease)}
header.scrolled .nav{height:62px}
.nav .brand{display:flex;align-items:center;gap:12px}
.nav .brand img{height:42px;width:auto;transition:height .35s var(--ease)}
header.scrolled .brand img{height:34px}
.nav .brand b{font-family:"Rondira";font-weight:500;font-size:24px;letter-spacing:2px;color:var(--navy)}
.nav ul{display:flex;gap:34px;list-style:none;align-items:center}
.nav ul a{font-size:14px;letter-spacing:2px;text-transform:uppercase;color:var(--slate);position:relative;padding:4px 0}
.nav ul a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1px;background:var(--gold);transition:width .3s var(--ease)}
.nav ul a:hover{color:var(--navy)}.nav ul a:hover::after{width:100%}
.nav .btn{padding:11px 22px}
.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:6px;width:40px;height:40px;background:none;border:0;cursor:pointer}
.nav-toggle span{display:block;width:24px;height:1.5px;background:var(--navy);margin:0 auto;transition:.35s var(--ease)}
.nav-toggle.open span:first-child{transform:translateY(4px) rotate(45deg)}
.nav-toggle.open span:last-child{transform:translateY(-3.5px) rotate(-45deg)}

/* ===== hero ===== */
.hero{position:relative;min-height:92vh;display:flex;align-items:center;overflow:hidden;text-align:center}
.hero-frame{position:absolute;inset:20px;border:1px solid rgba(199,179,142,.45);pointer-events:none;z-index:2}
.hero-frame::before,.hero-frame::after{content:"";position:absolute;width:14px;height:14px;border-color:var(--gold);border-style:solid}
.hero-frame::before{top:-1px;left:-1px;border-width:1px 0 0 1px}
.hero-frame::after{bottom:-1px;right:-1px;border-width:0 1px 1px 0}
.hero .inner{position:relative;z-index:3;width:100%;padding:90px 0}
.hero img.iso{height:120px;margin:0 auto 22px}
.hero .eyebrow{display:block;font-family:"Champagne";font-style:italic;color:var(--gold);font-size:28px;margin-bottom:4px}
.hero h1{font-family:"Rondira";font-size:clamp(56px,12vw,148px);color:var(--navy);letter-spacing:6px;line-height:.95}
.hero-rule{display:flex;align-items:center;justify-content:center;gap:14px;margin:26px auto 0;max-width:420px}
.hero-rule i{flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--gold));display:block}
.hero-rule i:last-child{background:linear-gradient(90deg,var(--gold),transparent)}
.hero-rule img{height:26px;opacity:.85}
.hero .sub{max-width:560px;margin:24px auto 38px;color:var(--slate);font-size:20px}
.hero .cta-row{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.flor{position:absolute;pointer-events:none;opacity:.92;z-index:1;will-change:transform}
.hero .flor.f1{width:300px;top:-30px;left:-50px;rotate:-12deg}
.hero .flor.f2{width:340px;bottom:-70px;right:-60px;rotate:160deg}
.hero .flor.f3{width:150px;top:14%;right:6%;rotate:24deg;opacity:.35}
.scroll-hint{position:absolute;bottom:34px;left:50%;transform:translateX(-50%);z-index:3;
  font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--slate);opacity:.7}
.scroll-hint span{display:block;width:1px;height:36px;background:var(--gold);margin:8px auto 0;animation:drop 1.8s var(--ease) infinite}
@keyframes drop{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}50.1%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* hero load choreography */
.load-1,.load-2,.load-3,.load-4,.load-5,.load-6{opacity:0;transform:translateY(22px);animation:fadeUp 1s var(--ease-out) forwards}
.load-1{animation-delay:.1s}.load-2{animation-delay:.3s}.load-3{animation-delay:.45s}
.load-4{animation-delay:.65s}.load-5{animation-delay:.8s}.load-6{animation-delay:.95s}
@keyframes fadeUp{to{opacity:1;transform:none}}

/* ===== marquee ===== */
.marquee{overflow:hidden;background:var(--navy);color:var(--cream);padding:18px 0;border-block:1px solid rgba(199,179,142,.35)}
.marquee-track{display:flex;width:max-content;animation:scroll 32s linear infinite}
.marquee-track span{font-family:"Rondira";font-size:15px;letter-spacing:4px;text-transform:uppercase;white-space:nowrap;padding-right:.5em}
.marquee-track i{font-style:normal;color:var(--gold);padding:0 .6em}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ===== sections ===== */
section{position:relative}
.band{padding:110px 0}
.band.alt{background:rgba(42,57,77,.035)}
.shead{text-align:center;max-width:680px;margin:0 auto 64px}
.shead .kicker{font-family:"Champagne";font-style:italic;color:var(--gold);font-size:26px;display:block;margin-bottom:6px}
.shead h2{font-family:"Rondira";font-size:clamp(34px,5vw,54px);color:var(--navy);letter-spacing:2px}
.shead p{color:var(--slate);margin-top:16px}
.orn{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:20px}
.orn i{width:54px;height:1px;background:var(--gold);display:block}
.orn span{color:var(--gold);font-size:13px;line-height:1}
.kicker.light{font-family:"Champagne";font-style:italic;color:var(--cream);opacity:.85;font-size:26px;display:block;margin-bottom:8px}

/* ===== services ===== */
.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:30px}
.card{position:relative;background:rgba(255,255,255,.55);border:1px solid var(--hairline);
  border-radius:3px;padding:46px 40px;overflow:hidden;transition:transform .45s var(--ease),box-shadow .45s var(--ease),background .45s var(--ease)}
.card::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--gold),rgba(199,179,142,0));
  transform:scaleX(0);transform-origin:left;transition:transform .6s var(--ease-out)}
.card:hover{transform:translateY(-8px);box-shadow:0 30px 60px -30px rgba(42,57,77,.5);background:rgba(255,255,255,.8)}
.card:hover::before{transform:scaleX(1)}
.card .num{font-family:"Champagne";font-style:italic;font-size:30px;color:var(--gold)}
.card h3{font-family:"Rondira";font-size:27px;color:var(--navy);margin:8px 0 14px;letter-spacing:1px}
.card p{color:var(--slate);font-size:17px}
.card .flor{width:150px;bottom:-30px;right:-30px;opacity:.4;z-index:0;transition:opacity .5s var(--ease),transform .6s var(--ease)}
.card:hover .flor{opacity:.65;transform:rotate(-6deg) scale(1.06)}
.card>*{position:relative;z-index:1}

/* ===== cta banner ===== */
.cta-banner{position:relative;background:var(--navy);color:var(--cream);padding:110px 0;text-align:center;overflow:hidden}
.cta-banner::before{content:"";position:absolute;inset:0;
  background:radial-gradient(620px 320px at 50% 0%,rgba(199,179,142,.18),transparent 70%)}
.cta-banner .flor{opacity:.16}
.cta-banner .flor.cb1{width:320px;top:-50px;left:-50px;rotate:20deg}
.cta-banner .flor.cb2{width:260px;bottom:-60px;right:-40px;rotate:-160deg}
.cta-inner{position:relative;z-index:2}
.cta-banner h2{font-family:"Rondira";font-size:clamp(30px,4.4vw,48px);color:var(--cream);letter-spacing:1px;margin-bottom:34px}
.cta-banner .cta-row{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.cta-banner .btn.gold:hover{border-color:var(--cream)}
.cta-banner .btn.gold::before{background:var(--cream)}
.cta-banner .btn.gold:hover{color:var(--navy)}

/* ===== menu ===== */
.menu-list{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:8px}
.dish{padding:26px 14px;border-bottom:1px solid var(--hairline);transition:background .35s var(--ease),padding .35s var(--ease)}
.dish:hover{background:rgba(255,255,255,.5);padding-left:22px}
.dish .dh{display:flex;align-items:baseline;gap:14px}
.dish h4{font-family:"Rondira";font-size:21px;color:var(--navy);letter-spacing:.5px;white-space:nowrap}
.dish .dot{flex:1;border-bottom:1px dotted rgba(79,114,128,.5);transform:translateY(-5px)}
.dish .tag{font-family:"Champagne";font-style:italic;color:var(--gold);font-size:18px}
.dish p{color:var(--slate);font-size:16px;margin-top:6px}
.menu-note{text-align:center;margin-top:42px;color:var(--slate);font-style:italic;font-family:"Champagne";font-size:22px}

/* ===== gallery — editorial offset ===== */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.g-tile{margin:0;aspect-ratio:4/5;background:rgba(255,255,255,.55);border:1px solid var(--hairline);border-radius:3px;
  display:flex;align-items:center;justify-content:center;overflow:hidden;transition:.4s var(--ease)}
.g-tile:nth-child(3n+2){transform:translateY(34px)}
.g-tile img{width:62%;transition:.6s var(--ease)}
.g-tile:hover{box-shadow:0 26px 50px -28px rgba(42,57,77,.55);border-color:rgba(199,179,142,.6)}
.g-tile:hover img{transform:scale(1.1) rotate(2deg)}
#galeria .wrap{padding-bottom:34px}

/* ===== contacto / form ===== */
.contact{position:relative;overflow:hidden}
.contact .flor.cf1{width:260px;top:-20px;right:-40px;rotate:40deg;opacity:.4}
.contact .flor.cf2{width:240px;bottom:-50px;left:-50px;rotate:-150deg;opacity:.4}
form{max-width:720px;margin:0 auto;position:relative;z-index:2}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.field{margin-bottom:24px;text-align:left}
.field.full{grid-column:1/-1}
label{display:block;font-size:13px;letter-spacing:2px;text-transform:uppercase;color:var(--slate);margin-bottom:8px}
input,select,textarea{width:100%;font-family:"Chopin";font-size:17px;color:var(--navy);
  background:transparent;border:0;border-bottom:1px solid rgba(42,57,77,.3);border-radius:0;
  padding:12px 2px;transition:.3s var(--ease)}
input:focus,select:focus,textarea:focus{outline:none;border-bottom-color:var(--gold);box-shadow:0 1px 0 0 var(--gold)}
textarea{resize:vertical;min-height:120px;border:1px solid rgba(42,57,77,.25);padding:14px 16px;background:rgba(255,255,255,.5);border-radius:2px}
textarea:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(199,179,142,.16);background:#fff}
.form-actions{text-align:center;margin-top:10px}
.form-actions .btn{width:100%;max-width:340px;padding:17px}
.form-msg{text-align:center;margin-top:20px;font-size:16px;min-height:24px}
.form-msg.ok{color:var(--slate)}.form-msg.err{color:#a8412f}
.hp{position:absolute;left:-9999px}

/* ===== footer ===== */
footer{position:relative;background:var(--navy);color:var(--cream);padding:74px 0 30px;text-align:center;overflow:hidden}
footer::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent)}
footer .flor.ff1{width:240px;bottom:-60px;left:-60px;opacity:.1;rotate:-20deg}
footer .wrap{position:relative;z-index:1}
footer img.iso{height:70px;margin:0 auto 18px;filter:brightness(0) invert(1);opacity:.9}
footer .ft-name{font-family:"Rondira";font-size:32px;letter-spacing:6px;color:var(--cream)}
footer .tagline{font-family:"Champagne";font-style:italic;color:var(--gold);font-size:20px;margin:8px 0 28px}
footer .socials{display:flex;gap:18px;justify-content:center;margin-bottom:32px}
footer .socials a{width:46px;height:46px;border:1px solid rgba(245,242,232,.3);border-radius:50%;color:var(--cream);
  display:flex;align-items:center;justify-content:center;transition:.35s var(--ease)}
footer .socials svg{width:19px;height:19px}
footer .socials a:hover{background:var(--gold);border-color:var(--gold);color:var(--navy);transform:translateY(-4px)}
footer .copy{font-size:13px;color:rgba(245,242,232,.55);letter-spacing:1px;border-top:1px solid rgba(245,242,232,.12);padding-top:24px;margin-top:10px}

/* ===== floating whatsapp ===== */
.wa-float{position:fixed;right:22px;bottom:22px;z-index:60;width:56px;height:56px;border-radius:50%;
  background:#25d366;color:#fff;display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 26px -8px rgba(0,0,0,.4);transition:.3s var(--ease)}
.wa-float::after{content:"";position:absolute;inset:-5px;border-radius:50%;border:1px solid rgba(37,211,102,.55);
  animation:pulse 2.4s var(--ease) infinite}
@keyframes pulse{0%{transform:scale(.85);opacity:.9}70%{transform:scale(1.25);opacity:0}100%{opacity:0}}
.wa-float:hover{transform:translateY(-4px) scale(1.05);box-shadow:0 16px 32px -10px rgba(0,0,0,.45)}

/* ===== reveal anim ===== */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .9s var(--ease-out) var(--d,0s),transform .9s var(--ease-out) var(--d,0s)}
.reveal.in{opacity:1;transform:none}
.g-tile.reveal{transform:translateY(30px)}
.g-tile.reveal.in{transform:none}
.g-tile:nth-child(3n+2).reveal.in{transform:translateY(34px)}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  html{scroll-behavior:auto}
}

/* ===== responsive ===== */
@media(max-width:820px){
  body{font-size:17px}
  .nav ul{position:fixed;inset:74px 0 auto 0;flex-direction:column;background:var(--cream);
    padding:24px 0;gap:18px;border-bottom:1px solid var(--hairline);transform:translateY(-130%);transition:.4s var(--ease);z-index:-1}
  .nav ul.open{transform:none}
  .nav .nav-cta{display:none}
  .nav-toggle{display:flex}
  .grid,.frow{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr 1fr}
  .g-tile:nth-child(3n+2){transform:none}
  .g-tile:nth-child(3n+2).reveal.in{transform:none}
  .g-tile:nth-child(even){transform:translateY(24px)}
  .g-tile:nth-child(even).reveal.in{transform:translateY(24px)}
  .band{padding:80px 0}
  .cta-banner{padding:80px 0}
  .hero{min-height:86vh}
  .hero-frame{inset:12px}
  .scroll-hint{display:none}
  .hero .flor.f1{width:170px}.hero .flor.f2{width:190px}.hero .flor.f3{display:none}
  .wa-float{width:50px;height:50px;right:16px;bottom:16px}
  .dish .dh{flex-wrap:wrap;gap:6px}.dish h4{white-space:normal}.dish .dot{display:none}
  .dish:hover{padding-left:14px}
  .marquee-track{animation-duration:22s}
}
