/*
Theme Name: Hello Nella Child
Theme URI: http://example.com/
Description: Child theme for Hello Nella guesthouse.
Author: M.Meter
Template: hello-elementor
Version: 1.0.2
Text Domain: hello-nella-child
Requires: Hello Elementor parent theme must be installed and active.
*/

/* =========================
   Variables / Base
========================= */
:root{
  --color-cream:#f6f0e7;
  --color-cream-dark:#efe7dc;
  --color-white:#fff;
  --color-border:#e6dccf;
  --color-text:#3c342c;
  --color-muted:#7b6f62;
  --color-primary:#f2c66a;
  --color-secondary:#2f4a3f;
  --color-accent:#c9b59f;
  --shadow-soft:0 12px 40px rgba(43,34,23,.12);
  --radius-xl:28px;
  --radius-lg:20px;
  --radius-pill:999px;
  --container:1240px;
}

*{box-sizing:border-box;}
body{
  margin:0;
  font-family:"Inter","Manrope",system-ui,-apple-system,sans-serif;
  color:var(--color-text);
  background:var(--color-cream);
  line-height:1.6;
}
a{color:inherit;text-decoration:none;}
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{
  outline:3px solid rgba(242,198,106,.6);outline-offset:2px;
}
img{max-width:100%;display:block;}
.container{max-width:var(--container);margin:0 auto;padding:0 24px;}

/* =========================
   Header
========================= */
.site-header{position:relative;background:var(--color-cream);width:100%;padding:28px 0 12px;max-width:none!important;}
.site-header .header-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;}
.brand{display:flex;align-items:center;gap:12px;}
.brand-logo{width:100%;height:100%;border-radius:16px;background:var(--color-primary);display:grid;place-items:center;font-weight:700; object-fit: cover;}
.brand-text{font-family:"Playfair Display","Times New Roman",serif;font-size:24px;letter-spacing:.4px;}
.main-nav ul{list-style:none;display:flex;gap:28px;margin:0;padding:0;font-weight:500;}
.header-cta{display:flex;gap:12px;}
/* Elementor width safety */
.site-header .elementor-section,.site-header .elementor-container,.site-header .e-con,.site-header .e-con-inner{width:100%;max-width:none!important;}
.site-header .header-inner,.site-header .container{max-width:var(--container);margin:0 auto;padding:0 24px;}

/* =========================
   Buttons
========================= */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:12px 26px;border-radius:var(--radius-pill);border:1px solid transparent;
  font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;
}
.btn:hover{transform:translateY(-1px);box-shadow:0 10px 20px rgba(43,34,23,.15);}
.btn-primary{background:var(--color-primary);color:#3c2f21;}
.btn-secondary{background:var(--color-secondary);color:#fff;}

/* =========================
   Hero
========================= */
.hero{padding:48px 0 80px;}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center;}
.hero-copy h1{font-family:"Playfair Display",serif;font-size:54px;line-height:1.1;margin:0 0 16px;}
.hero-copy p{font-size:18px;color:var(--color-muted);margin-bottom:28px;}
.hero-actions{display:flex;gap:14px;margin-bottom:32px;}
.booking-card{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:24px;box-shadow:var(--shadow-soft);}
.booking-card h3{margin-top:0;font-family:"Playfair Display",serif;font-size:22px;}
.booking-form{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.booking-form label{font-size:13px;color:var(--color-muted);display:block;margin-bottom:6px;}
.booking-form input,.booking-form select{width:100%;padding:12px 14px;border-radius:14px;border:1px solid var(--color-border);background:#fff;}
.hero-image{border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-soft);height:520px;}
.hero-image img{width:100%;height:100%;object-fit:cover;}
.hn-hero-image{transition:opacity .5s ease;}
.hn-hero-image.is-fading{opacity:0;}

/* =========================
   Sections / Titles
========================= */
.section{padding:70px 0;}
.section-title{font-family:"Playfair Display",serif;font-size:38px;margin:0 0 12px;}
.section-subtitle{color:var(--color-muted);max-width:680px;margin:0 0 18px;}

/* =========================
   Features
========================= */
.features-row{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:30px;}
.feature-card{background:#fff;border-radius:var(--radius-lg);padding:20px;border:1px solid var(--color-border);display:flex;gap:16px;align-items:center;}
.feature-card p{margin:4px 0 0;color:var(--color-muted);font-size:14px;}
.feature-icon{width:48px;height:48px;border-radius:16px;background:var(--color-cream-dark);display:grid;place-items:center;font-weight:700;}

/* =========================
   Rooms
========================= */
.rooms-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:32px;}
.room-card{background:#fff;border-radius:var(--radius-xl);border:1px solid var(--color-border);overflow:hidden;box-shadow:var(--shadow-soft);display:flex;flex-direction:column;}
.room-card .room-content{padding:22px;display:flex;flex-direction:column;}
.room-card h3{margin:0 0 8px;font-family:"Playfair Display",serif;font-size:24px;}
.room-card p{margin:0 0 12px;color:var(--color-muted);}
.room-features{list-style:none;padding:0;margin:16px 0 20px;color:var(--color-muted);}
.room-features li{margin:6px 0;}
.hn-room-button{align-self:center;}

/* =========================
   About
========================= */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;}
.about-image{max-width:520px;width:100%;margin:0 auto;}
.hn-about-image{width:100%;max-height:420px;object-fit:cover;object-position:center 20%;border-radius:var(--radius-xl);box-shadow:var(--shadow-soft);}

/* =========================
   Gallery
========================= */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:28px;}
.gallery-grid .hn-gallery-item,
.gallery-grid .hn-gallery-item:focus,
.gallery-grid .hn-gallery-item:active,
.gallery-grid .hn-gallery-item:hover{outline:none!important;border:0!important;box-shadow:none;}
.hn-gallery-item{border:none;padding:0;background:transparent;aspect-ratio:4/3;cursor:pointer;display:block;width:100%;-webkit-tap-highlight-color:transparent;}
.hn-gallery-item:focus-visible{outline:3px solid rgba(242,198,106,.6);outline-offset:4px;border-radius:20px;}
.gallery-grid .hn-gallery-item:hover{box-shadow:0 14px 34px rgba(0,0,0,.08)!important;border-radius:18px;background:rgba(244,236,223,.7)!important;}
.hn-gallery-image{border-radius:18px;box-shadow:var(--shadow-soft);width:100%;height:100%;object-fit:cover;}

/* =========================
   Lightbox
========================= */
.hn-lightbox{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(30,24,18,.65);opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:1000;}
.hn-lightbox.is-open{opacity:1;pointer-events:auto;}
.hn-lightbox__backdrop{position:absolute;inset:0;}
.hn-lightbox__content{background:#fff;padding:16px;border-radius:22px;box-shadow:0 18px 60px rgba(0,0,0,.35);position:relative;}
.hn-lightbox__image{max-width:88vw;max-height:82vh;border-radius:12px;}
.hn-lightbox__close{position:absolute;top:10px;right:12px;width:36px;height:36px;border-radius:50%;border:1px solid var(--color-border);background:#fff;font-size:20px;cursor:pointer;display:grid;place-items:center;}
body.hn-lightbox-open{overflow:hidden;}

/* =========================
   Testimonials (slider)
========================= */
.hn-testimonials{position:relative;margin-top:28px;padding-top:12px;}
.hn-testimonials__track{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(280px,1fr);gap:54px;overflow-x:auto;padding-bottom:18px;scroll-snap-type:x mandatory;}
.hn-testimonials__track::-webkit-scrollbar{height:8px;}
.hn-testimonials__track::-webkit-scrollbar-thumb{background:rgba(123,111,98,.35);border-radius:999px;}
.hn-testimonials__controls{position:absolute;right:0;top:-44px;display:flex;gap:10px;z-index:5;}
.hn-slider-button{width:40px;height:40px;border-radius:50%;border:1px solid var(--color-border);background:#fff;font-size:20px;cursor:pointer;display:grid;place-items:center;box-shadow:var(--shadow-soft);}
@media (max-width:768px){.hn-slider-button{display:none!important;}}
.hn-testimonial-card{min-width:320px;max-width:320px;height:260px;display:flex;flex-direction:column;background:#fff;border-radius:var(--radius-lg);border:1px solid var(--color-border);padding:22px;box-shadow:var(--shadow-soft);scroll-snap-align:start;text-decoration:none;color:inherit;}
.stars{color:#f2b94d;letter-spacing:2px;font-size:18px;margin-bottom:10px;}
.hn-testimonial-body{flex:1;overflow:hidden;}
.hn-testimonial-quote{font-size:15px;line-height:1.45;color:var(--color-text);display:-webkit-box;-webkit-line-clamp:5;-webkit-box-orient:vertical;overflow:hidden;}
.hn-testimonial-more{display:inline;margin-left:6px;font-weight:600;color:var(--color-secondary);text-decoration:underline;white-space:nowrap;}
.hn-testimonial-meta{display:flex;justify-content:space-between;align-items:center;margin-top:16px;padding-top:12px;border-top:1px solid var(--color-border);font-size:14px;color:var(--color-muted);}
.hn-testimonials-cta{margin-top:26px;display:flex;justify-content:center;gap:14px;flex-wrap:wrap;}
.hn-testimonials-cta .btn{border-radius:999px;padding:12px 22px;font-weight:700;box-shadow:var(--shadow-soft);border:1px solid transparent;transition:transform .2s ease,box-shadow .2s ease;}
.hn-testimonials-cta .btn:hover{transform:translateY(-1px);}
.btn-google{background:#e76161;border-color:#e6e6e6;color:#fff;}
.btn-google:hover{box-shadow:0 12px 26px rgba(0,0,0,.12);}
.btn-booking{background:#003580;color:#fff;border-color:#003580;}
.btn-booking:hover{box-shadow:0 12px 26px rgba(0,0,0,.12);}

/* =========================
   Contact / Map
========================= */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;}
.contact-card{background:#fff;border-radius:var(--radius-xl);border:1px solid var(--color-border);padding:26px;box-shadow:var(--shadow-soft);}
.map-embed{border-radius:18px;overflow:hidden;border:1px solid var(--color-border);box-shadow:var(--shadow-soft);min-height:360px;}

/* =========================
   CONTACT FORM (Hello Nella)
   ========================= */

.hn-contact .hn-contact-form{
  display: grid;
  gap: 12px;
  margin-top: 14px;
}

.hn-contact .hn-contact-form label{
  display:block;
  font-size: 14px;
  font-weight: 600;
  margin: 0 0 6px;
  color: #2b241d;
}

.hn-contact .hn-contact-form input[type="text"],
.hn-contact .hn-contact-form input[type="email"],
.hn-contact .hn-contact-form input[type="tel"],
.hn-contact .hn-contact-form textarea{
  width: 100%;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid #e6dccf;
  background: #fff;
  box-shadow: inset 0 1px 0 rgba(0,0,0,.03);
  outline: none;
  font-size: 15px;
}

.hn-contact .hn-contact-form textarea{
  min-height: 120px;
  resize: vertical;
}

.hn-contact .hn-contact-form input:focus,
.hn-contact .hn-contact-form textarea:focus{
  border-color: #2f4a3f;
  box-shadow: 0 0 0 4px rgba(47,74,63,.12);
}

.hn-contact .hn-contact-row{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

@media (max-width: 680px){
  .hn-contact .hn-contact-row{ grid-template-columns: 1fr; }
}

.hn-contact-actions{
  margin-top: 18px;
  display: flex;
  gap: 14px;
  align-items: center;
}





/* =========================
   Footer
========================= */
.site-footer{background:#efe7dc;padding:56px 0 20px;width:100%;border-top:1px solid var(--color-border);max-width:none!important;}
.site-footer .elementor-section,.site-footer .elementor-container,.site-footer .e-con,.site-footer .e-con-inner{max-width:none!important;width:100%;}
.site-footer .footer-grid,.site-footer .footer-bottom .footer-bottom-adwords{max-width:var(--container);margin:0 auto;padding:0 24px;}
.footer-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}
.footer-title{font-weight:700;margin-bottom:12px;}
.footer-bottom{border-top:1px solid var(--color-border);margin-top:32px;padding-top:16px;display:flex;justify-content:space-between;font-size:14px;color:var(--color-muted);}

.fab.fa-facebook-f {
    font-size: 24px; 
    color: #1877F2; 
    margin: 10px;
    padding: 15px;
    border-radius: 50%; /* Okrągła */
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2); /* Ładny cień */
    transition: transform 0.3s ease;
}

.fab.fa-facebook-f:hover {
    transform: scale(1.1); /* Efekt po najechaniu */
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.3);
}

.fab.fa-instagram {
 

     font-size: 24px; 
    color: #C92BB7; 
    margin: 10px;
    padding: 15px;
    border-radius: 50%; 
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2); 
    transition: transform 0.3s ease;
}

/* =========================
   Bottom bar (sticky)
========================= */
.hn-bottom-bar{position:fixed;bottom:0;left:0;width:100%;padding:14px 20px;background:rgba(246,240,231,.9);border-top:1px solid var(--color-border);backdrop-filter:blur(8px);z-index:999;transition:opacity .25s ease,transform .25s ease,bottom .2s ease;}
.hn-bottom-bar.is-top{bottom:auto;top:0;}
.hn-bottom-bar.is-hidden{opacity:0;transform:translateY(110%);pointer-events:none;}
.hn-bottom-bar__inner{max-width:var(--container);margin:0 auto;display:flex;justify-content:center;gap:14px;}
.hn-bottom-bar.is-pinned{bottom:var(--hn-footer-offset,0px);}
.hn-call-button{animation:hn-pulse 2.4s ease-in-out infinite;}
.hn-call-button--header{animation:hn-pulse-soft 3.2s ease-in-out infinite;}
@keyframes hn-pulse{0%{box-shadow:0 0 0 rgba(242,198,106,.4);transform:scale(1);}50%{box-shadow:0 0 20px rgba(242,198,106,.35);transform:scale(1.03);}100%{box-shadow:0 0 0 rgba(242,198,106,.4);transform:scale(1);}}
@keyframes hn-pulse-soft{0%{box-shadow:0 0 0 rgba(242,198,106,.25);transform:scale(1);}50%{box-shadow:0 0 12px rgba(242,198,106,.2);transform:scale(1.015);}100%{box-shadow:0 0 0 rgba(242,198,106,.25);transform:scale(1);}}
@media (prefers-reduced-motion: reduce){.hn-call-button,.hn-call-button--header{animation:none;}}

/* =========================
   HNB booking (shortcode inside card)
========================= */
.booking-card .hnb-grid{grid-template-columns:repeat(3,1fr);}
.booking-card .hnb-btn{width:100%;justify-content:center;}

/* =========================
   Room page
========================= */
.hn-room-hero__media{min-height:280px;background-size:cover;background-position:center;border-bottom:1px solid var(--color-border);}
.hn-room-hero__overlay{min-height:280px;display:flex;align-items:flex-end;padding:26px 0 30px;background:linear-gradient(to top,rgba(15,12,10,.55),rgba(15,12,10,.08));}
.hn-breadcrumbs{font-size:13px;color:rgba(0,0,0,.85);display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px;justify-content:center;}
.hn-breadcrumbs a{color:rgba(51,48,48,.9);text-decoration:none;}
.hn-breadcrumbs span{opacity:.9;}
.hn-room-hero__title{margin:0 0 6px;color:#fff;font-family:"Playfair Display",serif;font-size:44px;line-height:1.1;}
.hn-room-hero__subtitle{margin:0;color:rgba(255,255,255,.88);max-width:720px;}
.hn-room-top{margin-top:-44px;display:grid;grid-template-columns:1.35fr .65fr;gap:22px;align-items:start;}
.hn-room-gallery__main{border:0;padding:0;background:transparent;width:100%;cursor:pointer;border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-soft);}
.hn-room-gallery__main img{width:100%;height:420px;object-fit:cover;display:block;}
.hn-room-gallery__thumbs{display:none!important;} /* hide thumbs */
.hn-room-booking__card{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-soft);padding:18px;position:sticky;top:110px;}
.hn-room-booking__card h3{margin:0 0 14px;font-family:"Playfair Display",serif;}
.hn-room-section{margin-top:46px;}
.hn-room-bullets{margin-top:18px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px 18px;}
.hn-room-bullet{display:flex;gap:10px;align-items:center;padding:10px 12px;border-radius:16px;border:1px solid var(--color-border);background:rgba(255,255,255,.65);}
.hn-room-bullet span{font-size:18px;}
.hn-room-bullet p{margin:0;color:var(--color-muted);font-weight:600;}
.hn-amenities-grid{margin-top:16px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;}
.hn-amenity-card{background:#fff;border:1px solid var(--color-border);border-radius:16px;padding:14px 16px;box-shadow:0 10px 26px rgba(43,34,23,.08);display:flex;align-items:center;gap:10px;min-height:58px;}
.hn-amenity-card__icon{font-size:18px;}
.hn-amenity-card__label{font-weight:700;color:var(--color-text);}
.hn-location-card{margin-top:16px;display:grid;grid-template-columns:1fr 1fr;gap:16px;background:rgba(255,255,255,.65);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:16px;}
.hn-location-points{display:grid;gap:10px;align-content:start;}
.hn-location-point{display:flex;gap:10px;align-items:center;padding:10px 12px;border-radius:16px;border:1px solid var(--color-border);background:#fff;}
.hn-location-point p{margin:0;color:var(--color-muted);font-weight:600;}

/* =========================
   Room SEO links (one clean version)
========================= */
.hn-room-links{margin-top:64px;padding:34px 26px;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-xl);}
.hn-room-links__title{margin:0 0 18px;font-family:"Playfair Display",serif;font-size:26px;text-align:center;}
.hn-room-links__list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px 22px;justify-items:start;}
.hn-room-links__list li{margin:0;padding:0;justify-self:start;width:100%;}
.hn-room-links__list a{display:inline-flex;align-items:center;gap:10px;width:100%;padding:12px 14px;border-radius:14px;background:rgba(239,231,220,.75);border:1px solid rgba(230,220,207,.9);transition:transform .18s ease,box-shadow .18s ease,background .18s ease;color:var(--color-text);}
.hn-room-links__list a::before{content:"→";opacity:.75;}
.hn-room-links__list a:hover{background:rgba(239,231,220,.95);transform:translateY(-1px);box-shadow:0 10px 22px rgba(43,34,23,.08);}
.hn-room-links__list a:focus-visible{outline:3px solid rgba(242,198,106,.55);outline-offset:3px;}
@media (max-width:1024px){.hn-room-links__list{grid-template-columns:repeat(2,minmax(0,1fr));}}
@media (max-width:768px){.hn-room-links{padding:26px 16px;}.hn-room-links__list{grid-template-columns:1fr;}}

/* =========================
   Room title (center, sand gradient)
========================= */
.hn-room-title{padding:60px 0 72px;background:linear-gradient(180deg,#f8f3ec 0%,#efe7dc 55%,#e6dccf 100%);border-bottom:1px solid var(--color-border);}
.hn-room-title__inner{max-width:820px;margin:0 auto;text-align:center;}
.hn-breadcrumbs--dark{justify-content:center;color:var(--color-muted);font-size:13px;margin-bottom:14px;}
.hn-breadcrumbs--dark a{color:var(--color-muted);text-decoration:none;}
.hn-breadcrumbs--dark span{opacity:.7;}
.hn-room-title__heading{margin:0 0 10px;font-family:"Playfair Display",serif;font-size:46px;line-height:1.1;color:var(--color-text);}
.hn-room-title__subtitle{margin:0 auto;max-width:640px;font-size:17px;color:var(--color-muted);}
@media (max-width:768px){
  .hn-room-title{padding:64px 0 56px;}
  .hn-room-title__heading{font-size:34px;}
  .hn-room-title__subtitle{font-size:15px;}
}

/* =========================
   Checkout page (single consolidated version)
========================= */
.hn-checkout-hero{padding:48px 0 18px;background:linear-gradient(to bottom,rgba(246,240,231,.92),rgba(239,231,220,.96));border-bottom:1px solid var(--color-border);}
.hn-checkout-title{margin:10px 0 6px;font-family:"Playfair Display",serif;font-size:56px;line-height:1.05;text-align:center;}
.hn-checkout-subtitle{margin:0 auto;text-align:center;color:var(--color-muted);max-width:680px;}

.hn-checkout-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:22px;align-items:start;}
.hn-card{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-soft);padding:22px;}
.hn-card__title{margin:0 0 14px;font-family:"Playfair Display",serif;font-size:28px;}
.hn-card--summary{position:sticky;top:110px;}

.hn-summary-room{display:flex;gap:12px;align-items:center;padding:14px;border-radius:18px;border:1px solid var(--color-border);background:rgba(239,231,220,.55);margin-bottom:14px;}
.hn-summary-room__badge{width:22px;height:22px;border-radius:6px;display:grid;place-items:center;background:rgba(47,74,63,.14);color:var(--color-secondary);font-weight:800;}
.hn-summary-room__name{font-weight:800;color:var(--color-text);}
.hn-summary-room__meta{font-size:13px;color:var(--color-muted);}

.hn-summary-row{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border-radius:16px;border:1px solid var(--color-border);background:rgba(255,255,255,.75);margin:10px 0;}
.hn-summary-row span{color:var(--color-muted);font-weight:600;}
.hn-summary-row strong{color:var(--color-text);}
.hn-summary-prices{margin-top:12px;padding-top:12px;border-top:1px solid var(--color-border);}
.hn-price-line{display:flex;justify-content:space-between;padding:8px 0;color:var(--color-muted);}
.hn-price-line strong{color:var(--color-text);}
.hn-price-line--total{margin-top:6px;padding-top:10px;border-top:1px dashed rgba(230,220,207,.9);font-weight:800;}
.hn-price-line--deposit{color:var(--color-secondary);font-weight:800;}
.hn-summary-warning{margin-top:14px;padding:14px;border-radius:16px;border:1px solid rgba(242,198,106,.55);background:rgba(242,198,106,.14);color:var(--color-text);}
.hn-summary-help{margin-top:12px;color:var(--color-muted);font-size:14px;line-height:1.55;}

.hn-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.hn-field label{display:block;font-size:13px;color:var(--color-muted);margin-bottom:6px;font-weight:600;}
.hn-field input,.hn-field select{width:100%;padding:12px 14px;border-radius:14px;border:1px solid var(--color-border);background:#fff;}
.hn-field--full{grid-column:1 / -1;}
.hn-form-grid--pet{margin-top:12px;padding-top:12px;border-top:1px solid var(--color-border);}

.hn-terms{display:flex;gap:10px;align-items:flex-start;margin-top:12px;color:var(--color-muted);font-size:13px;}
.hn-terms input{width:auto;margin-top:2px;}

.hn-checkout-actions{display:flex;justify-content:center;margin-top:14px;}
.hn-checkout-btn{min-width:240px;justify-content:center;padding:12px 26px;border-radius:var(--radius-pill);font-weight:800;background:var(--color-primary);color:#3c2f21;border:1px solid transparent;box-shadow:var(--shadow-soft);transition:transform .2s ease,box-shadow .2s ease;}
.hn-checkout-btn:hover{transform:translateY(-1px);box-shadow:0 16px 32px rgba(43,34,23,.14);}
.hn-checkout-footnote{text-align:center;color:var(--color-muted);margin:12px 0 0;font-size:13px;}

.hn-checkout-success,.hn-checkout-error{border-radius:18px;padding:14px 16px;margin-bottom:16px;border:1px solid var(--color-border);background:rgba(255,255,255,.85);}
.hn-checkout-success{border-color:rgba(47,74,63,.25);background:rgba(47,74,63,.08);}
.hn-checkout-error{border-color:rgba(231,97,97,.45);background:rgba(231,97,97,.10);}

@media (max-width:1024px){
  .hn-checkout-grid{grid-template-columns:1fr;}
  .hn-card--summary{position:relative;top:0;}
  .hn-checkout-title{font-size:44px;}
}
@media (max-width:768px){
  .hn-form-grid{grid-template-columns:1fr;}
}

/* =========================
   HOME AVAILABILITY (HERO) – single version
========================= */
.hn-home-form{margin-top:26px;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-soft);padding:22px;max-width:760px;}
.hn-home-form__grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.hn-home-form label{display:block;font-size:13px;color:var(--color-muted);margin-bottom:6px;}
.hn-home-form input,.hn-home-form select{width:100%;padding:12px 14px;border-radius:14px;border:1px solid var(--color-border);background:#fff;outline:none;}
.hn-home-form input:focus,.hn-home-form select:focus{border-color:rgba(242,198,106,.65);box-shadow:0 0 0 4px rgba(242,198,106,.18);}
.hn-home-form__actions{display:flex;flex-direction:column;align-items:center;gap:10px;margin-top:14px;}
.hn-home-form__actions .btn{min-width:260px;justify-content:center;}
.hn-home-status{font-size:13px;color:var(--color-muted);min-height:18px;text-align:center;}
.hn-home-status.is-ok{color:#1f7a39;}
.hn-home-status.is-bad{color:#b42318;}
.hn-home-status.is-warn{color:#8a6a14;}
@media (max-width:768px){.hn-home-form{max-width:100%;}.hn-home-form__grid{grid-template-columns:1fr;}}

#hn-home-availability .hn-home-form__actions{display:flex;justify-content:center;margin-top:14px;}
#hn-home-availability #hn_home_check_btn,
#hn-home-availability button.hn-btn,
#hn-home-availability .hn-btn{
  appearance:none;-webkit-appearance:none;
  background:var(--color-primary)!important;color:#3c2f21!important;border:1px solid transparent!important;
  border-radius:var(--radius-pill)!important;padding:12px 20px!important;font-weight:700!important;
  line-height:1.1;cursor:pointer;box-shadow:var(--shadow-soft);transition:transform .2s ease,box-shadow .2s ease,filter .2s ease;
  width:auto;min-width:240px;margin-top:20px;
}
#hn-home-availability #hn_home_check_btn:hover{transform:translateY(-1px);box-shadow:0 10px 20px rgba(43,34,23,.15);}
#hn-home-availability #hn_home_check_btn:focus-visible{outline:3px solid rgba(198,178,135,.55)!important;outline-offset:4px;}

/* Rooms filtering */
.room-card.is-dim{opacity:.35;filter:grayscale(1);transform:none!important;pointer-events:none;}
.room-card.is-active{opacity:1;filter:none;pointer-events:auto;outline:3px solid rgba(242,198,106,.55);outline-offset:6px;border-radius:18px;}

/* =========================
   Cookies Banner
========================= */
.hn-cookie-banner{position:fixed;inset:auto 0 0 0;background:#fff;border-top:1px solid rgba(0,0,0,.08);box-shadow:0 -10px 30px rgba(0,0,0,.08);z-index:9999;padding:16px;}
.hn-cookie-inner{max-width:1200px;margin:0 auto;display:grid;gap:14px;}
.hn-cookie-inner p{margin:0;font-size:14px;color:#3c2f21;}
.hn-cookie-inner a{color:#b58b2a;text-decoration:underline;}
.hn-cookie-actions{display:flex;gap:12px;justify-content:flex-end;flex-wrap:wrap;}
.hn-cookie-btn{padding:10px 18px;border-radius:999px;font-weight:600;cursor:pointer;border:1px solid transparent;}
.hn-cookie-btn--primary{background:#f2c66a;color:#3c2f21;}
.hn-cookie-btn--ghost{background:transparent;border-color:rgba(0,0,0,.2);color:#3c2f21;}
@media (max-width:768px){.hn-cookie-actions{justify-content:center;}}

/* =========================
   404
========================= */
.hn-404{text-align:center;}
.hn-404 h1{font-size:96px;margin-bottom:10px;color:#f2c66a;}
.hn-404 h2{font-size:28px;margin-bottom:16px;}
.hn-404 p{max-width:520px;margin:0 auto 28px;color:#555;}
.hn-404__actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}

/* =========================
   SEO links – generic section (home/footer use)
========================= */
.hn-seo-links__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:18px;}
.hn-seo-links__box{background:#fff;border:1px solid var(--color-border);border-radius:28px;box-shadow:var(--shadow-soft);padding:18px;}
.hn-seo-links__box h3{margin:0 0 10px;font-size:18px;}
.hn-seo-links__box ul{list-style:none;padding:0;margin:0;display:grid;gap:10px;}
.hn-seo-links__box a{font-weight:700;text-decoration:none;}
.hn-seo-links__note{margin-top:16px;font-size:13px;color:var(--color-muted);}
@media (max-width:1024px){.hn-seo-links__grid{grid-template-columns:1fr;}}

/* =========================
   SEO links (Room) – cards
========================= */
.hn-seo-shell{margin-top:8px;}
.hn-seo-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;margin-top:18px;}
.hn-seo-card{background:#fff;border:1px solid var(--color-border);border-radius:22px;box-shadow:var(--shadow-soft);padding:18px 18px 16px;}
.hn-seo-card__title{font-weight:800;margin-bottom:10px;}
.hn-seo-list{list-style:none;padding:0;margin:0;display:grid;gap:10px;}
.hn-seo-link{text-decoration:none;font-weight:700;}
.hn-seo-link:hover{text-decoration:underline;}
@media (max-width:1024px){.hn-seo-grid{grid-template-columns:repeat(2,minmax(0,1fr));}}
@media (max-width:640px){.hn-seo-grid{grid-template-columns:1fr;}}

/* =========================
   Responsive (global)
========================= */
@media (max-width:1024px){
  .hero-grid,.about-grid,.contact-grid{grid-template-columns:1fr;}
  .booking-card .hnb-grid{grid-template-columns:1fr;}
  .features-row,.gallery-grid{grid-template-columns:1fr 1fr;}
  .rooms-grid{grid-template-columns:1fr;}
  .hn-room-top{grid-template-columns:1fr;margin-top:-28px;}
  .hn-room-booking__card{position:relative;top:0;}
  .hn-amenities-grid{grid-template-columns:repeat(2,1fr);}
  .hn-location-card{grid-template-columns:1fr;}
}
@media (max-width:768px){
  .main-nav{display:none;}
  .features-row,.rooms-grid,.gallery-grid,.footer-grid{grid-template-columns:1fr;}
  .hero-copy h1{font-size:40px;}
  .about-image{max-width:100%;}
  .hn-about-image{max-height:300px;}
  .hn-bottom-bar__inner{flex-direction:column;}
  .hn-room-hero__title{font-size:34px;}
  .hn-room-gallery__main img{height:320px;}
  .hn-room-bullets{grid-template-columns:1fr;}
}

/* =========================
   CONTACT FORM (Hello Nella)
   ========================= */

.hn-contact .hn-contact-form{
  display: grid;
  gap: 12px;
  margin-top: 14px;
}

.hn-contact .hn-contact-form label{
  display:block;
  font-size: 14px;
  font-weight: 600;
  margin: 0 0 6px;
  color: #2b241d;
}

.hn-contact .hn-contact-form input[type="text"],
.hn-contact .hn-contact-form input[type="email"],
.hn-contact .hn-contact-form input[type="tel"],
.hn-contact .hn-contact-form textarea{
  width: 100%;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid #e6dccf;
  background: #fff;
  box-shadow: inset 0 1px 0 rgba(0,0,0,.03);
  outline: none;
  font-size: 15px;
}

.hn-contact .hn-contact-form textarea{
  min-height: 120px;
  resize: vertical;
}

.hn-contact .hn-contact-form input:focus,
.hn-contact .hn-contact-form textarea:focus{
  border-color: #2f4a3f;
  box-shadow: 0 0 0 4px rgba(47,74,63,.12);
}

.hn-contact .hn-contact-row{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

@media (max-width: 680px){
  .hn-contact .hn-contact-row{ grid-template-columns: 1fr; }
}

/* RODO checkbox */
.hn-contact .hn-contact-rodo{
  display:flex;
  gap: 10px;
  align-items:flex-start;
  padding: 12px 14px;
  border: 1px solid #e6dccf;
  border-radius: 14px;
  background: rgba(239,231,220,.45);
}

.hn-contact .hn-contact-rodo input[type="checkbox"]{
  margin-top: 3px;
  width: 18px;
  height: 18px;
  accent-color: #2f4a3f;
}

.hn-contact .hn-contact-rodo span{
  font-size: 13px;
  line-height: 1.5;
  color:#3c342c;
}

/* Button */
.hn-contact .hn-contact-submit{
  display:inline-flex;
  justify-content:center;
  align-items:center;
  gap:10px;
  padding: 12px 18px;
  border: 0 !important;
  border-radius: 999px;
  background: #2f4a3f !important;
  color: #fff !important;
  font-weight: 800;
  cursor: pointer;
  box-shadow: 0 10px 24px rgba(47,74,63,.25);
  transition: transform .12s ease, box-shadow .12s ease, opacity .12s ease;
  width: fit-content;
}

.hn-contact .hn-contact-submit:hover{
  transform: translateY(-1px);
  box-shadow: 0 14px 30px rgba(47,74,63,.28);
}

.hn-contact .hn-contact-submit:active{
  transform: translateY(0);
  opacity: .92;
}

/* Success / error messages */
.hn-contact .hn-contact-msg{
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid #e6dccf;
  background: #fff;
  font-size: 14px;
}

.hn-contact .hn-contact-msg--ok{
  border-color: rgba(47,74,63,.35);
  background: rgba(47,74,63,.08);
}

.hn-contact .hn-contact-msg--err{
  border-color: rgba(180,50,50,.35);
  background: rgba(180,50,50,.08);
}

