* { margin: 0; padding: 0; box-sizing: border-box; }
:root{
  --accent-color: #8B2332;
  --frozen-glass: rgba(255,255,255,0.1);
  --frozen-glass-border: rgba(255,255,255,0.2);
  --char-delay: 25ms;
  --char-duration: 300ms;
  --vh: 1vh;
}
html{ overflow-x:hidden; height:100%; }
body{
  font-family: 'Work Sans', sans-serif;
  background:#000;
  color:#fff;
  min-height:100vh;
  min-height: calc(var(--vh, 1vh) * 100);
  overflow-x:hidden;
  position:relative;
}
/* REVEAL */
.animate-in{ animation: slideUpReveal 1s cubic-bezier(0.16,1,0.3,1) forwards; opacity:0; }
@keyframes slideUpReveal{ from{opacity:0; transform:translateY(60px);} to{opacity:1; transform:translateY(0);} }
.header.animate-in{ animation-delay:0.1s; }
.logo-large.animate-in{ animation-delay:0.25s; }
.claim.animate-in{ animation-delay:0.4s; }
.amenities.animate-in{ animation-delay:0.55s; }
.footer-info.animate-in{ animation-delay:0.7s; }
.carta-container.animate-in{ animation-delay:0.85s; }
.logo-large{ width:150px; height:150px; position:relative; cursor:pointer; }
.logo-large img{ width:100%; height:100%; object-fit:contain; transition: transform 0.15s ease; }
/* Animació cicle logo gran */
@keyframes logoCycle{
  0%, 100% { transform: translateY(0) rotate(0deg); }
  25% { transform: translateY(-3px) rotate(-1deg); }
  50% { transform: translateY(0) rotate(1deg); }
  75% { transform: translateY(-2px) rotate(-0.5deg); }
}
body.loaded .logo-large img{ animation: logoCycle 4s ease-in-out infinite; }
@media(min-width:768px){ 
  .logo-large{ width:180px; height:180px; } 
}
a, .amenity{ cursor:pointer; }
/* Video background */
.video-background{ 
  position:fixed; 
  top:0; 
  left:0; 
  width:100vw; 
  height: 100vh;
  z-index:-2; 
  overflow:hidden; 
  background:#1a1a1a;
}
@media(max-width:767px){
  .video-background{
    height: calc(100vh + 60px); /* 60px extra per cobrir quan desapareix la barra */
  }
}
.video-background::after{ content:''; position:absolute; top:0; left:0; width:100%; height:100%; background: rgba(0,0,0,0.55); z-index:1; }

/* Thumbnail image */
.video-thumbnail{
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  z-index:0;
  opacity:1;
  transition: opacity 0.8s ease;
  overflow:hidden;
}
.video-thumbnail.fade-out{
  opacity:0;
}
.video-thumbnail img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
}
@media(max-width:767px){
  .video-thumbnail{
    height:100vh;
    max-height:100vh;
  }
  .video-thumbnail img{
    height:100vh;
    max-height:100vh;
  }
}

/* Video */
.video-background video{ 
  position:absolute; 
  top:0; 
  left:0; 
  width:100%; 
  height:100%;
  object-fit:cover;
  pointer-events:none;
  opacity: 0;
  transition: opacity 0.8s ease;
}
.video-background video.loaded{
  opacity: 1;
}
@media(max-width:767px){
  .video-background video{
    height:100vh;
    max-height:100vh;
  }
}
/* MAIN */
.main-container{ position:relative; z-index:10; max-width:1400px; margin:0 auto; padding:2rem 1.5rem 0.5rem; display:flex; flex-direction:column; }
/* HEADER */
.header{ display:grid; grid-template-columns: 1fr auto 1fr; align-items:center; gap:2rem; margin-bottom:2rem; }
.header-left{ display:flex; flex-direction:column; gap:0.5rem; }
.header-contact-item{ display:flex; align-items:center; gap:0.5rem; color: rgba(255,255,255,0.8); text-decoration:none; font-size:0.95rem; font-weight:500; transition: color 0.15s; line-height:1; }
.header-contact-item:hover{ color: rgba(255,255,255,0.95); text-decoration:none; }
.header-contact-item svg{ width:16px; height:16px; stroke:currentColor; fill:none; stroke-width:1.5; flex-shrink:0; vertical-align:middle; }
.logo-section{ display:flex; justify-content:center; align-items:center; gap:0.75rem; }
.logo{ width:64px; height:64px; flex-shrink:0; }
.logo img{ width:100%; height:100%; object-fit:contain; }
@media(min-width:768px){
  .logo.spinning img{
    animation: spinPhysicsHeader 1.5s cubic-bezier(0.34, 1.56, 0.64, 1) forwards;
  }
}
@keyframes spinPhysicsHeader{ 
  0% { transform: rotate(0deg); }
  45% { transform: rotate(360deg); }
  55% { transform: rotate(345deg); }
  65% { transform: rotate(355deg); }
  75% { transform: rotate(357deg); }
  85% { transform: rotate(359deg); }
  95% { transform: rotate(359.5deg); }
  100% { transform: rotate(360deg); }
}
.logo-label{ font-family:'Work Sans', sans-serif; font-size:0.75rem; font-weight:400; text-transform:uppercase; letter-spacing:0.08em; color: rgba(255,255,255,0.7); }
.header-right{ display:flex; flex-direction:column; align-items:flex-end; gap:0.5rem; font-size:0.95rem; }
.header-right-row{ display:flex; align-items:center; gap:0.75rem; color: rgba(255,255,255,0.8); font-weight:500; }
.header-right-label{ text-transform:uppercase; font-size:0.75rem; color: rgba(255,255,255,0.6); letter-spacing:0.05em; font-weight:500; }
.header-right a{ color: rgba(255,255,255,0.95); text-decoration:none; }
/* CONTENT */
.content-grid{ display:grid; grid-template-columns:1fr; gap:3rem; flex:1; }
@media(min-width:768px){ .content-grid{ grid-template-columns:1fr 1fr; gap:2.5rem; } }
@media(min-width:1200px){ .content-grid{ gap:4rem; } }
.left-column{ display:flex; flex-direction:column; justify-content:center; gap:2rem; }
@media(min-width:768px){ .left-column{ margin-top:-60px; } }
.claim h2{ font-family:'Work Sans', sans-serif; font-size:1.25rem; font-weight:400; line-height:1.4; color: rgba(255,255,255,0.7); text-transform:uppercase; letter-spacing:0.05em; margin-bottom:0.5rem; order:-1; }
.claim h1{ font-family:'Trocchi', serif; font-size:2.5rem; font-weight:400; line-height:1.5; color: rgba(255,255,255,0.9); margin-bottom:0; }
.claim{ display:flex; flex-direction:column; }
@media(min-width:768px){ .claim h1{ font-size:2.2rem; } .claim h2{ font-size:1.1rem; } }
@media(max-width:767px){ .claim h1{ font-size:1.5rem; } .claim h2{ font-size:0.95rem; } }
/* AMENITIES */
.amenities{ display:flex; flex-wrap:wrap; gap:0.75rem; align-items:center; }
.amenity{ 
  display:inline-flex; 
  align-items:center; 
  gap:0.5rem; 
  padding:0.5rem 1rem; 
  background: rgba(0,0,0,0.5); 
  border:1px solid rgba(255,255,255,0.15); 
  border-radius:50px; 
  backdrop-filter: blur(20px); 
  font-size:0.875rem; 
  position:relative; 
  transition: all 0.3s ease; 
  cursor:help;
  color: rgba(255,255,255,0.85);
}
.amenity:hover{ 
  background: rgba(0,0,0,0.7); 
  border-color: rgba(255,255,255,0.25); 
  backdrop-filter: blur(30px); 
  transform: translateY(-2px);
  color: rgba(255,255,255,0.95);
}
.amenity svg{ display:none; }
/* Amagar Estrella Damm a mòbil */
.amenity[data-mobile-hide]{ display:inline-flex; }
@media(max-width:767px){
  .amenity[data-mobile-hide]{ display:none; }
}
.amenity-tooltip{ 
  position:absolute; 
  bottom: calc(100% + 12px); 
  left:50%; 
  transform: translateX(-50%); 
  background: rgba(0,0,0,0.85); 
  backdrop-filter: blur(20px);
  color:white; 
  padding:0.75rem 1rem; 
  border-radius:10px; 
  font-size:0.8rem; 
  white-space:nowrap; 
  opacity:0; 
  pointer-events:none; 
  transition: opacity .3s ease, transform .3s ease; 
  z-index:100; 
  border:1px solid rgba(255,255,255,0.15);
  transform: translateX(-50%) translateY(5px);
}
.amenity-tooltip::after{ 
  content:''; 
  position:absolute; 
  top:100%; 
  left:50%; 
  transform: translateX(-50%); 
  border:6px solid transparent; 
  border-top-color: rgba(0,0,0,0.85); 
}
@media(min-width:768px){ 
  .amenity:hover .amenity-tooltip{ 
    opacity:1;
    transform: translateX(-50%) translateY(0);
  } 
}
/* Footer info */
.footer-info{ display:flex; flex-direction:column; gap:0.75rem; font-size:1rem; }
.info-row-contact{ display:flex; gap:0.5rem; align-items:center; }
.info-row{ display:flex; flex-wrap:wrap; align-items:center; gap:0.75rem; }
.info-label{ text-transform:uppercase; font-size:0.75rem; color: rgba(255,255,255,0.6); letter-spacing:0.05em; }
.info-row a{ color: rgba(255,255,255,0.95); text-decoration:none; }
/* CARTA */
.carta-container{ display:flex; flex-direction:column; background: rgba(0,0,0,0.4); backdrop-filter: blur(20px); border:1px solid rgba(255,255,255,0.1); border-radius:24px; overflow:hidden; box-shadow:0 20px 60px rgba(0,0,0,0.4); max-height:700px; }
@media(max-width:767px){ .carta-container{ max-height: calc(var(--vh, 1vh) * 80); } }
@media(min-width:768px){ .carta-container{ max-height:80vh; } }
.carta-header{
  display:flex;
  justify-content:center;
  align-items:center;
  padding: 1.5rem 1.5rem;
  border-bottom:1px solid rgba(255,255,255,0.1);
  flex-shrink:0;
  position:relative;
}
.carta-header h3{
  font-family:'Trocchi', serif;
  font-size:1.5rem;
  font-weight:400;
  line-height:1.3;
  transition:
    left 520ms cubic-bezier(0.22,1,0.36,1),
    transform 520ms cubic-bezier(0.22,1,0.36,1);
  position:absolute;
  left:50%;
  transform:translateX(-50%);
}
@media(min-width:768px){
  .carta-container:hover .carta-header h3{
    left:1.5rem;
    transform:translateX(0) translateY(0px);
  }
}
.carta-header-section{
  font-family:'Work Sans',sans-serif;
  font-size:1rem;
  font-weight:400;
  line-height:1.3;
  text-transform:uppercase;
  letter-spacing:0.05em;
  opacity:0;
  position:absolute;
  right:1.5rem;
  text-align:right;
  transform:translateY(10px);
  transition: opacity 380ms cubic-bezier(0.22,1,0.36,1), transform 380ms cubic-bezier(0.22,1,0.36,1);
}
.carta-header-section.show{ opacity:1; transform:translateY(0); }
/* SENSE SCROLL VISIBLE */
.carta-content{ 
  flex:1; 
  overflow-y:auto; 
  padding:0 1.5rem; 
  font-size:1rem;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.carta-content::-webkit-scrollbar{ display:none; }
@media(min-width:768px){ .carta-content{ padding:0 2rem; } }
.menu-section{ margin-bottom:0.75rem; padding:0.75rem 1rem; margin-left:-1rem; margin-right:-1rem; border-radius:12px; transition:background .3s ease; position:relative; }
@media(min-width:768px){ .menu-section:hover{ background: rgba(0,0,0,0.4); } }
.menu-section:last-child{ margin-bottom:0; }
.menu-section:first-child{ padding-top:1.5rem; }
.menu-section:last-child{ padding-bottom:1.5rem; }
.section-title{ font-size:0.875rem; text-transform:uppercase; color: rgba(255,255,255,0.75); letter-spacing:0.05em; margin-bottom:0.75rem; font-weight:500; }
.menu-item{ display:flex; justify-content:space-between; gap:1rem; margin-bottom:1rem; align-items:flex-start; }
.item-content{ flex:1; }
.item-name{ font-weight:500; margin-bottom:0.25rem; }
.item-description{ font-size:0.875rem; color: rgba(255,255,255,0.6); line-height:1.4; }
.item-price{ color: rgba(255,255,255,0.7); white-space:nowrap; font-weight:500; }
.item-price-row{ display:flex; gap:0.5rem; align-items:center; flex-wrap:wrap; margin-top:0.5rem; font-size:0.875rem; }
.item-size{ color: rgba(255,255,255,0.5); font-size:0.75rem; text-transform:uppercase; }
.item-variations{ display:block; font-size:0.9rem; color: rgba(255,255,255,0.6); margin-top:0.35rem; }
.carta-footer{ 
  padding:1rem 1.5rem; 
  border-top:1px solid rgba(255,255,255,0.1); 
  font-size:0.75rem; 
  color: rgba(255,255,255,0.5); 
  display:flex; 
  justify-content:flex-end; 
  align-items:center; 
  flex-wrap:wrap; 
  gap:0.5rem; 
  flex-shrink:0; 
}
/* MOBILE */
@media(max-width:767px){
  .main-container{ padding:1rem 0.75rem; }
  .header{ grid-template-columns:1fr; text-align:center; margin-bottom:1.5rem; }
  .header-left, .logo-section, .header-right-row:first-child { display:none; }
  .header-right{ align-items:center; justify-content:center; }
  .content-grid{ gap:2rem; }
  .logo-large{ margin:0 auto; }
  .claim h1{ text-align:center; }
  .claim h2{ text-align:center; }
  .footer-info{ align-items:center; text-align:center; }
  .info-row-contact{ display:flex !important; }
  .info-row{ justify-content:center; }
  .carta-footer{ justify-content:center; text-align:center; }
  .logo-label{ display:none; }
  .carta-header h3{ transition:left .5s, transform .5s; }
  .carta-header-section{ font-size:0.875rem; right:1rem; }
  .amenities{ max-height:5.6rem; overflow:hidden; justify-content:center; }
}
@media(min-width:768px){
  .footer-info{ display:none; }
}
/* Footer Alabast */
footer{ margin-top: 0.5rem; padding-bottom: calc(1rem - 6px); text-align: right; }
footer a{ color: rgba(255,255,255,0.5); text-decoration: none; font-weight: 400; font-size: 0.85rem; }
@media(max-width:767px){
  footer{ text-align: center !important; margin-top: 1rem; margin-bottom: 0.5rem; }
  .main-container{ padding-bottom: 0 !important; }
}
/* Evitar scroll vertical només a desktop */
@media(min-width:768px){
  html, body{ overflow-y: hidden; }
}
.main-container{ overflow: visible; }
/* ANIMACIÓ PER LLETRA */
.char{ display:inline-block; transform:translateY(0); opacity:1; will-change:transform,opacity; }
@keyframes charPop{
  0% { transform: translateY(0); opacity:1; }
  30% { transform: translateY(-1.0em); opacity:0; }
  31% { transform: translateY(1.0em); opacity:0; }
  100% { transform: translateY(0); opacity:1; }
}
a.header-link.play-chars .char,
.header-right-row.play-chars .char{
  animation-name: charPop;
  animation-duration: var(--char-duration);
  animation-timing-function: cubic-bezier(0.2,0.8,0.2,1);
  animation-fill-mode: both;
}
a.header-link{ color: rgba(255,255,255,0.95); text-decoration:none; }
a.header-link:hover{ color: rgba(255,255,255,0.95); text-decoration: none; }
/* Estil per l'horari animable */
.horari-text{ display:inline-block; }
.horari-text .char{ display:inline-block; }
@media (prefers-reduced-motion: reduce){
  a.header-link .char,
  .header-right-row .char{ animation: none !important; }
  .carta-header h3, .carta-header-section{ transition: none !important; }
}