@custom-variant dark (&:is(.dark *));:root{--bg-primary:#fff;--bg-secondary:#f8f9fa;--bg-header:#303030a1;--bg-accent:#204584;--bg-toggle:hsla(0,0%,65%,.849);--text-primary:#000;--text-header:#f8f9fa;--text-secondary:#394749;--text-sec-reserv:#973131;--text-accent:#8f0000;--border-color:#e0e0e0;--shadow:rgba(0,0,0,.1);--background:oklch(1 0 0);--foreground:oklch(0 0 0);--card:oklch(1 0 0);--card-foreground:oklch(0 0 0);--popover:oklch(1 0 0);--popover-foreground:oklch(0 0 0);--primary:oklch(0.35 0.15 250);--primary-foreground:oklch(1 0 0);--secondary:oklch(0.25 0.08 300);--secondary-foreground:oklch(1 0 0);--muted:oklch(0.97 0 0);--muted-foreground:oklch(0.25 0.08 300);--accent:oklch(0.3 0.2 25);--accent-foreground:oklch(1 0 0);--destructive:oklch(0.3 0.2 25);--destructive-foreground:oklch(1 0 0);--border:oklch(0.9 0 0);--input:oklch(0.9 0 0);--ring:oklch(0.35 0.15 250);--chart-1:oklch(0.35 0.15 250);--chart-2:oklch(0.3 0.2 25);--chart-3:oklch(0.25 0.08 300);--chart-4:oklch(0.5 0.1 250);--chart-5:oklch(0.4 0.15 25);--radius:0.625rem;--sidebar:oklch(0.985 0 0);--sidebar-foreground:oklch(0 0 0);--sidebar-primary:oklch(0.35 0.15 250);--sidebar-primary-foreground:oklch(1 0 0);--sidebar-accent:oklch(0.97 0 0);--sidebar-accent-foreground:oklch(0 0 0);--sidebar-border:oklch(0.9 0 0);--sidebar-ring:oklch(0.35 0.15 250);--font-ubuntu:"Ubuntu",sans-serif}.dark{--bg-primary:#000;--bg-secondary:#1a1a1a;--bg-accent:#204584;--bg-toggle:hsla(0,0%,53%,.301);--text-primary:#fff;--text-secondary:#b8b8b8;--text-accent:#861b1b;--text-sec-reserv:#e0ecff;--border-color:#333;--shadow:hsla(0,0%,100%,.1);--background:oklch(0 0 0);--foreground:oklch(1 0 0);--card:oklch(0.1 0 0);--card-foreground:oklch(1 0 0);--popover:oklch(0.1 0 0);--popover-foreground:oklch(1 0 0);--primary:oklch(0.35 0.15 250);--primary-foreground:oklch(1 0 0);--secondary:oklch(0.25 0.08 300);--secondary-foreground:oklch(1 0 0);--muted:oklch(0.15 0 0);--muted-foreground:oklch(0.7 0 0);--accent:oklch(0.3 0.2 25);--accent-foreground:oklch(1 0 0);--destructive:oklch(0.3 0.2 25);--destructive-foreground:oklch(1 0 0);--border:oklch(0.2 0 0);--input:oklch(0.2 0 0);--ring:oklch(0.35 0.15 250);--chart-1:oklch(0.35 0.15 250);--chart-2:oklch(0.3 0.2 25);--chart-3:oklch(0.25 0.08 300);--chart-4:oklch(0.5 0.1 250);--chart-5:oklch(0.4 0.15 25);--sidebar:oklch(0 0 0);--sidebar-foreground:oklch(1 0 0);--sidebar-primary:oklch(0.35 0.15 250);--sidebar-primary-foreground:oklch(1 0 0);--sidebar-accent:oklch(0.15 0 0);--sidebar-accent-foreground:oklch(1 0 0);--sidebar-border:oklch(0.2 0 0);--sidebar-ring:oklch(0.35 0.15 250)}@theme inline{--font-sans:var(--font-ubuntu);--color-background:var(--background);--color-foreground:var(--foreground);--color-card:var(--card);--color-card-foreground:var(--card-foreground);--color-popover:var(--popover);--color-popover-foreground:var(--popover-foreground);--color-primary:var(--primary);--color-primary-foreground:var(--primary-foreground);--color-secondary:var(--secondary);--color-secondary-foreground:var(--secondary-foreground);--color-muted:var(--muted);--color-muted-foreground:var(--muted-foreground);--color-accent:var(--accent);--color-accent-foreground:var(--accent-foreground);--color-destructive:var(--destructive);--color-destructive-foreground:var(--destructive-foreground);--color-border:var(--border);--color-input:var(--input);--color-ring:var(--ring);--color-chart-1:var(--chart-1);--color-chart-2:var(--chart-2);--color-chart-3:var(--chart-3);--color-chart-4:var(--chart-4);--color-chart-5:var(--chart-5);--radius-sm:calc(var(--radius) - 4px);--radius-md:calc(var(--radius) - 2px);--radius-lg:var(--radius);--radius-xl:calc(var(--radius) + 4px);--color-sidebar:var(--sidebar);--color-sidebar-foreground:var(--sidebar-foreground);--color-sidebar-primary:var(--sidebar-primary);--color-sidebar-primary-foreground:var(--sidebar-primary-foreground);--color-sidebar-accent:var(--sidebar-accent);--color-sidebar-accent-foreground:var(--sidebar-accent-foreground);--color-sidebar-border:var(--sidebar-border);--color-sidebar-ring:var(--sidebar-ring)}@layer base{*,body{@apply bg-background text-foreground}}html{scroll-behavior:smooth}body{font-family:var(--font-ubuntu),-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;line-height:1.6;color:var(--text-primary);background-color:var(--bg-primary);transition:background-color .3s ease,color .3s ease}.hostal-container{min-height:100vh}.header{position:fixed;top:0;left:0;right:0;background:var(--bg-header);z-index:1000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.header-content{max-width:1200px;margin:0 auto;padding:1rem;justify-content:space-between}.header-content,.logo{display:flex;align-items:center}.logo-image{height:auto;max-height:40px;width:auto;object-fit:contain;transition:opacity .2s ease}.logo-image:hover{opacity:.8}.logo h1{font-size:1.5rem;font-weight:600;color:var(--text-accent);letter-spacing:-.02em}.nav{display:flex;gap:2rem}.nav button{background:none;border:none;color:var(--text-header);font-size:1.1rem;cursor:pointer;transition:color .2s ease;padding:.5rem 0}.nav button:hover{color:var(--text-accent)}.header-controls{display:flex;align-items:center;gap:1rem}.theme-toggle{background:none;border:none;font-size:1.2rem;cursor:pointer;padding:.5rem;border-radius:20%;transition:background-color .2s ease}.theme-toggle:hover{background-color:var(--bg-toggle)}.language-toggle{background:none;border:none;font-size:1.2rem;cursor:pointer;padding:.5rem;border-radius:20%;transition:background-color .2s ease}.language-toggle:hover{background-color:var(--bg-toggle)}.menu-toggle{display:none;flex-direction:column;background:none;border:none;cursor:pointer;padding:.5rem;gap:3px}.menu-toggle span{width:20px;height:2px;background-color:#e0ecff;transition:all .3s ease}.language-selector{position:relative}.language-button{background:none;border:1px solid var(--border-color);color:var(--text-primary);padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;display:flex;align-items:center;gap:.5rem;transition:all .2s ease}.language-button:hover{background-color:var(--bg-accent);border-color:var(--text-accent)}.language-dropdown{position:absolute;top:calc(100% + .5rem);right:0;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;box-shadow:0 10px 30px var(--shadow);min-width:150px;z-index:1000;overflow:hidden}.language-option{width:100%;padding:.75rem 1rem;background:none;border:none;color:var(--text-primary);text-align:left;cursor:pointer;transition:background-color .2s ease;font-size:.9rem}.language-option.active,.language-option:hover{background-color:var(--bg-accent)}.language-option.active{color:var(--text-accent);font-weight:500}.hero{padding:8rem 2rem 4rem;max-width:1200px;margin:0 auto;text-align:center}.hero-content{max-width:800px;margin:0 auto}.hero-title{font-size:clamp(2rem,5vw,3.5rem);font-weight:300;line-height:1.2;margin-bottom:1.5rem;color:var(--text-primary);letter-spacing:-.02em}.hero-subtitle{font-size:1.1rem;color:var(--text-secondary);margin-bottom:3rem;max-width:600px;margin-left:auto;margin-right:auto}.hero-image{margin-top:3rem;border-radius:12px;overflow:hidden;box-shadow:0 20px 40px var(--shadow)}.hero-image img{width:100%;height:auto;display:block}.hero-fullscreen{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;padding-top:80px}.hero-background{position:absolute;top:0;left:0;width:100%;height:100%;z-index:0}.hero-background img{margin-top:5%;width:100%;height:100%;object-fit:cover}.hero-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.4);z-index:1}.hero-content-centered{position:relative;z-index:2;text-align:center;color:#fff;padding:2rem;max-width:900px}.hero-content-centered h1{font-size:clamp(2rem,4vw,4.5rem);font-weight:700;margin-bottom:1.5rem;text-shadow:2px 2px 8px rgba(0,0,0,.7);line-height:1.2}.hero-content-centered p{font-size:clamp(1rem,2.2vw,1.5rem);margin-bottom:2rem;text-shadow:1px 1px 4px rgba(0,0,0,.7)}.about{padding:4rem 2rem;background-color:var(--bg-secondary)}.about-content{max-width:1200px;margin:0 auto}.about-header{text-align:center;margin-bottom:4rem;max-width:900px;margin-left:auto;margin-right:auto}.about-title{font-size:2.5rem;font-weight:300;margin-bottom:1.5rem;color:var(--text-primary);letter-spacing:-.02em}.about-intro{font-size:1.2rem;color:var(--text-primary);margin-bottom:1rem;line-height:1.7;font-weight:500}.about-description{font-size:1.05rem;color:var(--text-secondary);line-height:1.7}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));grid-gap:2rem;gap:2rem;margin-top:3rem}.feature-card{background-color:var(--bg-primary);padding:2.5rem 2rem;border-radius:12px;text-align:center;box-shadow:0 4px 12px var(--shadow);transition:all .3s ease;border:1px solid var(--border-color)}.feature-card:hover{transform:translateY(-5px);box-shadow:0 8px 24px var(--shadow);border-color:var(--bg-accent)}.feature-icon{width:60px;height:60px;margin:0 auto 1.5rem;color:var(--bg-accent);transition:all .3s ease}.feature-card:hover .feature-icon{color:var(--text-accent);transform:scale(1.1)}.feature-icon svg{width:100%;height:100%}.feature-title{font-size:1.3rem;font-weight:600;margin-bottom:.75rem;color:var(--text-primary)}.feature-description{color:var(--text-secondary);font-size:.95rem;line-height:1.6}.feature-link{color:var(--bg-accent);text-decoration:none;font-weight:500;transition:color .2s ease}.feature-link:hover{color:var(--text-accent);text-decoration:underline}.location{padding:4rem 2rem}.location-content{max-width:1000px;margin:0 auto}.location h3{font-size:2.5rem;font-weight:300;text-align:center;margin-bottom:3rem;color:var(--text-primary)}.location-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:3rem;gap:3rem;align-items:center}.location-info h4{font-size:1.5rem;font-weight:500;margin-bottom:1rem;color:var(--text-accent)}.location-info p{color:var(--text-secondary);margin-bottom:2rem}.nearby h5{font-size:1.1rem;font-weight:500;margin-bottom:1rem;color:var(--text-primary)}.nearby ul{list-style:none}.nearby li{color:var(--text-secondary);margin-bottom:.5rem;padding-left:1rem;position:relative}.nearby li:before{content:"•";color:var(--text-accent);position:absolute;left:0}.location-visual{display:flex;flex-direction:column;gap:1rem}.location-visual img{width:100%;height:auto;border-radius:8px;box-shadow:0 10px 30px var(--shadow)}.reservation{padding:4rem 2rem;background-color:var(--bg-secondary)}.reservation-content{max-width:1000px;margin:0 auto}.reservation h3{font-size:2.5rem;font-weight:300;text-align:center;margin-bottom:3rem;color:var(--text-primary)}.reservation-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:3rem;gap:3rem}.reservation-item{margin-bottom:2rem}.reservation-item h4{font-size:1.2rem;font-weight:500;margin-bottom:1rem;color:var(--text-primary)}.reservation-item p{color:var(--text-primary);line-height:1.6}.reservation-item a{color:var(--bg-accent);text-decoration:none;transition:color .2s ease}.reservation-item a:hover{color:var(--text-accent);text-decoration:underline}.reservation-item ul{list-style:none;padding-left:0}.reservation-item li{color:var(--text-sec-reserv);margin-bottom:.75rem;padding-left:1.5rem;position:relative;line-height:1.6}.reservation-item li:before{content:"•";color:var(--text-accent);position:absolute;left:0;font-weight:700;font-size:1.2rem}.reservation-form h4{font-size:1.3rem;font-weight:500;margin-bottom:1.5rem;color:var(--text-primary)}.reservation-form form{display:flex;flex-direction:column;gap:1rem}.form-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:1rem;gap:1rem}.reservation-form input,.reservation-form select,.reservation-form textarea{padding:.875rem;border:1px solid var(--border-color);border-radius:6px;background-color:var(--bg-primary);color:var(--text-primary);font-size:.95rem;transition:all .2s ease;font-family:inherit}.reservation-form input:focus,.reservation-form select:focus,.reservation-form textarea:focus{outline:none;border-color:var(--bg-accent);box-shadow:0 0 0 3px rgba(32,69,132,.1)}.reservation-form select{cursor:pointer}.reservation-form button{padding:.875rem 1.5rem;background-color:var(--bg-accent);color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;font-family:inherit}.reservation-form button:hover:not(:disabled){background-color:var(--text-accent);transform:translateY(-1px);box-shadow:0 4px 12px rgba(32,69,132,.3)}.reservation-form button:disabled,.reservation-form input:disabled,.reservation-form select:disabled,.reservation-form textarea:disabled{opacity:.6;cursor:not-allowed}.submit-message{margin-top:1rem;padding:.875rem;border-radius:6px;font-size:.95rem;text-align:center;font-weight:500}.submit-message.success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.submit-message.error{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.dark .submit-message.success{background-color:#1e4d2b;color:#a3d9a5;border:1px solid #2d5a3d}.dark .submit-message.error{background-color:#4d1e1e;color:#d9a3a3;border:1px solid #5a2d2d}.rooms{padding:4rem 2rem;background-color:var(--bg-primary)}.rooms-content{max-width:1200px;margin:0 auto}.rooms h3{font-size:2.5rem;font-weight:300;text-align:center;margin-bottom:1rem;color:var(--text-primary)}.rooms-intro{text-align:center;color:var(--text-secondary);font-size:1.1rem;margin-bottom:3rem;max-width:600px;margin-left:auto;margin-right:auto}.rooms-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));grid-gap:2rem;gap:2rem}.room-card{background-color:var(--bg-secondary);border-radius:12px;overflow:hidden;box-shadow:0 10px 30px var(--shadow);transition:transform .3s ease,box-shadow .3s ease}.room-card:hover{transform:translateY(-5px);box-shadow:0 20px 40px var(--shadow)}.room-carousel{position:relative;height:250px;overflow:hidden}.carousel-container{position:relative;width:100%;height:100%}.carousel-slides{display:flex;width:100%;height:100%;transition:transform .5s ease}.carousel-slides img{width:100%;height:100%;object-fit:cover;flex-shrink:0}.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.5);color:#fff;border:none;width:40px;height:40px;border-radius:50%;font-size:1.2rem;cursor:pointer;transition:background-color .3s ease;z-index:10}.carousel-btn:hover{background:rgba(0,0,0,.7)}.carousel-btn.prev{left:10px}.carousel-btn.next{right:10px}.room-info{padding:1.5rem}.room-info h4{font-size:1.3rem;font-weight:500;margin-bottom:.5rem;color:var(--text-accent)}.room-info p{color:var(--text-secondary);font-size:.95rem;line-height:1.5}.whatsapp-button{position:fixed;bottom:2rem;right:2rem;width:60px;height:60px;background-color:#25d366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(37,211,102,.4);cursor:pointer;transition:all .3s ease;z-index:999;text-decoration:none}.whatsapp-button:hover{transform:scale(1.1);box-shadow:0 6px 20px rgba(37,211,102,.6)}.whatsapp-button svg{width:35px;height:35px;fill:#fff}.image-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.95);z-index:9999;display:flex;align-items:center;justify-content:center;padding:2rem;cursor:pointer}.image-modal-content{position:relative;max-width:95%;max-height:95%;cursor:default}.image-modal-content img{max-width:100%;max-height:90vh;object-fit:contain;border-radius:8px}.image-modal-close{position:absolute;top:-50px;right:0;background:hsla(0,0%,100%,.1);border:2px solid #fff;color:#fff;font-size:2rem;cursor:pointer;padding:.5rem 1rem;line-height:1;transition:all .2s ease;border-radius:6px;font-weight:300}.image-modal-close:hover{background:hsla(0,0%,100%,.2);transform:scale(1.1)}.room-type-selector{display:flex;gap:1rem;margin-bottom:1rem}.room-type-option{flex:1 1;position:relative}.room-type-option input[type=radio]{position:absolute;opacity:0;width:0;height:0}.room-type-label{display:block;padding:.75rem 1rem;border:2px solid var(--border-color);border-radius:6px;background-color:var(--bg-primary);color:var(--text-primary);text-align:center;cursor:pointer;transition:all .2s ease;font-size:.95rem}.room-type-option input[type=radio]:checked+.room-type-label{border-color:var(--bg-accent);background-color:var(--bg-accent);color:#fff;font-weight:500}.room-type-label:hover{border-color:var(--text-accent)}.google-map{width:100%;height:400px;border-radius:8px;box-shadow:0 10px 30px var(--shadow)}.footer{padding:2rem;border-top:1px solid var(--border-color)}.footer-content{max-width:1000px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.footer-info h4{font-size:1.1rem;font-weight:500;color:var(--text-accent);margin-bottom:.25rem}.footer-info p,.footer-links p{color:var(--text-secondary);font-size:.9rem}.visits-counter{margin-top:.5rem}.visits-counter p{color:var(--text-accent);font-size:.85rem;font-weight:500}@media (max-width:768px){.hero-fullscreen{min-height:85vh;padding-top:70px}.hero-content-centered{padding:1.5rem;max-width:90%}.hero-content-centered h1{font-size:clamp(1.8rem,5vw,3rem);margin-bottom:1rem}.hero-content-centered p{font-size:clamp(.95rem,2.5vw,1.2rem);margin-bottom:1.5rem}.menu-toggle{display:flex}.hero-background{top:0;width:100%;height:100%;z-index:0}.hero-background,.nav{position:absolute;left:0}.nav{top:100%;right:0;background:var(--bg-header);flex-direction:column;padding:1rem 2rem;border-bottom:1px solid var(--border-color);transform:translateY(-100%);opacity:0;visibility:hidden;transition:all .3s ease}.nav-open{transform:translateY(0);opacity:1;visibility:visible}.hero{padding:6rem 1rem 3rem}.hero-title{font-size:2rem}.location-grid,.reservation-grid{grid-template-columns:1fr;gap:2rem}.form-row{grid-template-columns:1fr}.footer-content{flex-direction:column;gap:1rem;text-align:center}.features-grid{grid-template-columns:1fr;gap:1.5rem}.feature-card{padding:2rem 1.5rem}.feature-icon{width:50px;height:50px}.rooms-grid{gap:1.5rem}.room-carousel{height:180px}.carousel-btn{width:35px;height:35px;font-size:1rem}.google-map{height:300px}.logo-image{max-height:50px}.image-modal-close{top:10px;right:10px;font-size:1.5rem;padding:.25rem .75rem}}@media (max-width:480px){.header-content{padding:1rem}.about,.hero,.location,.reservation{padding-left:1rem;padding-right:1rem}.hero-title{font-size:1.75rem}.about h3,.location h3,.reservation h3,.rooms h3{font-size:2rem}.rooms{padding-left:1rem;padding-right:1rem}.rooms-grid{gap:1.5rem}.room-carousel{height:180px}.carousel-btn{width:35px;height:35px;font-size:1rem}.google-map{height:250px}.logo-image{max-height:40px}.about-title{font-size:1.75rem}.about-intro{font-size:1rem}.about-description{font-size:.95rem}.feature-card{padding:1.5rem 1rem}.feature-title{font-size:1.1rem}.feature-description{font-size:.9rem}}