
/* =========================
   Gasthof Bischofsmühle
   ========================= */

:root{
  --green:#9a8c19;
  --brown:#ae614b;
  --brown-line:#c98370;
  --ink:#222;
  --muted:#666;
  --bg:#ffffff;
  --panel:#f6f3ea; /* warm light, similar to PDF background */
  --footer:#2b2b2b;
  --max:1100px;
  --radius:14px;
  --shadow: 0 10px 26px rgba(0,0,0,.10);
}


@font-face{
  font-family:"LibreBaskerville";
  src:url("../fonts/LibreBaskerville-VariableFont_wght.woff2") format("woff2");
  font-weight:400 700;
  font-style:normal;
  font-display:swap;
}
@font-face{
  font-family:"Raleway";
  src:url("../fonts/Raleway-VariableFont_wght.woff2") format("woff2");
  font-weight:300 800;
  font-style:normal;
  font-display:swap;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: "Raleway", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.55;
}
img{max-width:100%;display:block}
a {color:inherit}

p > a {
  color:var(--brown);
  text-decoration: none;
}

p > a:hover {
  color:inherit;
  text-decoration: none;
}

.container{max-width:var(--max);margin:0 auto;padding:0 20px}

/* Topbar */
.topbar{
  background:var(--green);
  color:#fff;
  position:sticky;
  top:0;
  z-index:50;
  box-shadow: 0 4px 18px rgba(0,0,0,0.06);
  transition: box-shadow .25s ease, padding .25s ease;
}
.topbar.scrolled{
  box-shadow: 0 6px 24px rgba(0,0,0,0.12);
}
.topbar-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  min-height:68px;
  transition: min-height .25s ease;
}
.topbar.scrolled .topbar-inner{ min-height:56px; }
.brand{
  display:flex;
  align-items:center;
  gap:12px;
  padding:10px 0;
  text-decoration:none;
}
.brand .logo{
  width:140px;
  height:42px;
  border-radius:8px;
  background:transparent;
  display:grid;
  place-items:center;
  font-family:"LibreBaskerville", serif;
  font-style:italic;
  letter-spacing:.4px;
}
.brand .logo span{opacity:.95}
.nav{
  display:flex;
  align-items:center;
  gap:18px;
}
.nav a{
  position:relative;
  text-decoration:none;
  font-size:14px;
  letter-spacing:.4px;
  padding:10px 22px 10px 12px;
  border-radius:999px;
  transition: color .18s ease;
}
.nav a::after{
  content:"";
  position:absolute;
  left:14px;
  right:14px;
  bottom:7px;
  height:2px;
  border-radius:999px;
  background:var(--brown-line);
  transform:scaleX(0);
  transform-origin:center;
  transition: transform .22s ease, opacity .22s ease;
  opacity:0;
}
.nav a:hover,
.nav a.active,
.nav a[aria-current="page"]{
  background:transparent;
  box-shadow:none;
  color:#fff;
}

.nav a:hover::after,
.nav a.active::after,
.nav a[aria-current="page"]::after{transform:scaleX(1);
  opacity:1;
}
.dropdown{position:relative}
.dropdown > button{
  all:unset;
  position:relative;
  cursor:pointer;
  padding:10px 30px 10px 12px;
  border-radius:999px;
  font-size:14px;
  letter-spacing:.4px;
  transition: color .18s ease;
}
.dropdown > button::after{
  content:"";
  position:absolute;
  left:14px;
  right:14px;
  bottom:7px;
  height:2px;
  border-radius:999px;
  background:var(--brown-line);
  transform:scaleX(0);
  transform-origin:center;
  transition: transform .22s ease, opacity .22s ease;
  opacity:0;
}
.dropdown > button:hover,
.dropdown.open > button,
.dropdown > button.active{
  background:transparent;
  box-shadow:none;
  color:#fff !important;
}

/* Burger button (mobile only) */
.nav-toggle{
  display:none;
  align-items:center;
  justify-content:center;
  width:54px;
  height:54px;
  padding:0;
  border:0;
  border-radius:14px;
  background:var(--brown-line);
  color:#fff;
  cursor:pointer;
  transition: filter .18s ease, transform .18s ease;
}
.nav-toggle:hover{ filter:brightness(.95); transform:translateY(-1px); }
.nav-toggle:active{ transform:translateY(0); }
.nav-toggle .icon{ color:#fff; stroke:#fff; }

.dropdown > button:hover::after,
.dropdown.open > button::after,
.dropdown > button.active::after{transform:scaleX(1);
  opacity:1;
}
.dropdown-menu{
  position:absolute;
  right:0;
  top:100%;
  margin-top:8px;
  min-width:240px;
  background:#fff;
  color:var(--ink);
  border-radius:14px;
  box-shadow:var(--shadow);
  padding:10px;
  display:none;
}
.dropdown-menu::before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:-14px;
  height:14px;
}
.dropdown.open .dropdown-menu{display:block}

/* Dropdown: hover open on desktop, click open on mobile */
@media (hover:hover){
  .dropdown:hover .dropdown-menu{display:block;}
}
.dropdown-menu a{
  display:block;
  position:relative;
  padding:10px 12px;
  text-decoration:none;
  font-size:14px;
  letter-spacing:.3px;
  color:var(--ink);
}
.dropdown-menu a::after{
  content:"";
  position:absolute;
  left:12px;
  right:12px;
  bottom:6px;
  height:2px;
  border-radius:999px;
  background:var(--brown-line);
  transform:scaleX(0);
  transform-origin:center;
  opacity:0;
  transition: transform .22s ease, opacity .22s ease;
}
.dropdown-menu a:hover,
.dropdown-menu a.active,
.dropdown-menu a[aria-current="page"]{
  background:transparent;
  color:var(--brown);
}
.dropdown-menu a:hover::after,
.dropdown-menu a.active::after,
.dropdown-menu a[aria-current="page"]::after{
  transform:scaleX(1);
  opacity:1;
}

  border-radius:12px;
  background:transparent;
  color:#fff;
  font-size:14px;
}
.nav-toggle .icon-md{width:1.85em; height:1.85em;}

/* Hero */

.hero--start{ background-image:url('../img/header/gasthof-bischofsmuehle.jpg'); }
.hero--chalet{ background-image:url('../img/header/chalet-bischofsmuehle.jpg'); }
.hero--jagdhaus{ background-image:url('../img/header/chalet-jagdhaus-bischofsmuehle.jpg'); }
.hero--ferienhaus{ background-image:url('../img/header/ferienhaus-oberleupoldsberg.jpg'); }
.hero--zimmer{ background-image:url('../img/header/ferienwohnung-bischofsmuehle.jpg'); }
.hero--gasthof{ background-image:url('../img/header/gasthof-bischofsmuehle.jpg'); }
.hero--heiraten{ background-image:url('../img/header/hochzeit-feiern-bischofsmuehle.jpg'); }
.hero--kontakt{ background-image:url('../img/header/kontakt-gasthof-bischofsmuehle.jpg'); }
.hero--impressum{ background-image:url('../img/header/gasthof-bischofsmuehle-impressum.jpg'); }
.hero--datenschutz{ background-image:url('../img/header/gasthof-bischofsmuehle-impressum.jpg'); }


.hero{
  width:100%;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  aspect-ratio: 16 / 6;
  min-height:260px;
  background-color:#ddd;
  background-size:cover;
  background-position:center;
}

/* Page header */
.page-title{
  text-align:center;
  padding:46px 0 10px;
}
.page-title h1{
  margin:0;
  font-family:"LibreBaskerville", serif;
  font-weight:400;
  font-style:italic;
  color:#5b8d8f; /* subtle teal like in PDFs */
  letter-spacing:.2px;
}
.page-title span{
  font-family: "Raleway", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-style:normal;
  margin:6px 0 0;
  color:var(--muted);
  font-size:20px;
  line-height:1.4;
}

.page-title p{
  margin:6px 0 0;
  color:var(--muted);
  font-size:20px;
  line-height:1.4;
}

/* Sections */
.section{padding:26px 0}
.section.alt{background:var(--panel)}
.grid-2{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:26px;
  align-items:start;
}
.kicker{
  font-family:"LibreBaskerville", serif;
  font-style:italic;
  color:#5b8d8f;
  font-size:26px;
  margin:0 0 10px;
}
h2{
  font-family:"LibreBaskerville", serif;
  font-weight:400;
  font-style:italic;
  color:#5b8d8f;
  letter-spacing:.2px;
  margin:0 0 12px;
}

h3{
  letter-spacing:.2px;
  margin: 26px 0 0 0;
}

p{margin:0 0 12px;color:var(--ink)}
.small{font-size:13px;color:var(--muted)}

.card{
  background:#fff;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  overflow:hidden;
}
.card .card-body{padding:18px}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:10px 14px;
  border-radius:12px;
  text-decoration:none;
  font-weight:600;
  font-size:14px;
  border:1px solid rgba(0,0,0,.08);
  transition: transform .12s ease, box-shadow .12s ease;
}
.btn:hover{transform: translateY(-1px); box-shadow: 0 10px 20px rgba(0,0,0,.08)}
.btn.green{background:var(--green);color:#fff;border-color:transparent}
.btn.brown{background:var(--brown);color:#fff;border-color:transparent}
.btn.ghost{background:#fff;color:var(--ink)}
.btn.full{width:100%}

/* Booking box (replaces "JETZT BUCHEN") */
.booking-box{
  background:var(--brown);
  color:#fff;
  border-radius:18px;
  padding:18px;
  box-shadow:var(--shadow);
}
.booking-box h3{
  margin:0 0 10px;
  font-family:"LibreBaskerville", serif;
  font-style:italic;
  font-weight:700;
  letter-spacing:.2px;
}
.booking-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:12px;
}
.booking-grid a{
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.22);
  color:#fff;
  text-decoration:none;
  padding:12px 12px;
  border-radius:14px;
  font-weight:600;
  text-align:center;
  transition: background .15s ease, transform .12s ease;
}
.booking-grid a:hover{background:rgba(255,255,255,.20); transform: translateY(-1px)}

/* Slider (vanilla) */
.slider{
  position:relative;
  border-radius:var(--radius);
  overflow:hidden;
  background:#000;
  box-shadow:var(--shadow);
}
.slider .slides{
  display:flex;
  transition: transform .35s ease;
  will-change: transform;
}
.slider .slide{
  min-width:100%;
  background:#000;
}
.slider img{width:100%;height:auto;display:block}
.slider .dots{
  position:absolute;
  left:50%;
  bottom:12px;
  transform:translateX(-50%);
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:8px;
  max-width: calc(100% - 24px);
  padding:6px 10px;
  border-radius:999px;
  background:transparent;
  backdrop-filter: blur(6px);
}
.slider .dot{
  width:10px;height:10px;border-radius:999px;
  background:rgba(255,255,255,.42);
  border:1px solid rgba(255,255,255,.55);
  cursor:pointer;
}
.slider .dot.active{background:#fff}

/* =========================
   Slider Caption
========================= */

.slide {
  position: relative;
}

/* Verlauf + Text */
.slide-caption {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;

  padding: 14px 18px;

  background: linear-gradient(
    to top,
    rgba(154, 140, 25, 0.9) 0%,   /* dein Grün */
    rgba(154, 140, 25, 0.75) 40%,
    rgba(154, 140, 25, 0.4) 70%,
    rgba(154, 140, 25, 0) 100%
  );

  color: #ffffff;

  font-size: 14px;
  line-height: 1.4;
}

/* Text etwas schöner */
.slide-caption span {
  display: block;
  max-width: 90%;
}

/* Mobile */
@media (max-width: 768px) {
  .slide-caption {
    padding: 10px 12px;
    font-size: 13px;
  }
}

/* Footer */
.footer{
  background:var(--footer);
  color:#ddd;
  padding:34px 0 24px;
  margin-top:36px;
}
.footer-grid{
  display:grid;
  grid-template-columns: 1.2fr 1fr 1fr;
  gap:26px;
  align-items:start;
}
.footer h4{
  margin:0 0 12px;
  color:#fff;
  font-size:13px;
  letter-spacing:.6px;
  text-transform:uppercase;
}
.footer a{color:#ddd;text-decoration:none}
.footer a:hover{text-decoration:underline}
.footer .fineprint{
  text-align:center;
  margin-top:18px;
  font-size:12px;
  color:#aaa;
}


/* Utilities */
.mt-0{ margin-top:0 !important; }
.mt-10{ margin-top:10px !important; }
.mt-14{ margin-top:14px !important; }
.list-compact{ margin:0; padding-left:18px; color:#333; }
.section-title-center{ text-align:center; margin-bottom:18px; }
.teaser-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}

.teaser-grid-2{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:18px;
}

@media (max-width: 980px){
  .teaser-grid,
  .teaser-grid-2{ grid-template-columns:1fr; }
}

/* Active navigation */
.nav a.active,
.nav a[aria-current="page"]{
  background:transparent !important;
}
.dropdown-menu a.active{
  background:transparent !important;
}
/* Dropdown hover on desktop */
@media (hover:hover){
  .dropdown:hover .dropdown-menu{ display:block; }
  .dropdown:hover > button{ background:transparent; color:var(--brown); }
}

/* Booking highlight (above booking options) */
.booking-highlight{
  background:#fff;
  border:none;
  border-radius:16px;
  padding:14px 14px;
  margin-bottom:14px;
  color:var(--ink);
}
.booking-highlight-title{
  font-family:"Raleway", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  font-size:16px;
  letter-spacing:.3px;
  margin-bottom:10px;
  font-weight:600;
}
.booking-highlight-title .em{
  font-weight:800;
  text-transform:uppercase;
}
.booking-highlight-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px 14px;
  margin-bottom:10px;
}
.booking-highlight-grid .label{
  display:inline-block;
  min-width:54px;
  font-weight:700;
}
.booking-highlight a{ color:var(--brown); text-decoration:underline; text-underline-offset:2px; }
.booking-highlight-text{ font-size:18px; font-weight: bold; }

/* Offer card on start page */
.offer-card{
  border:none;
  background: rgba(154,140,25,.10);
}
.offer-card .card-body h2{ margin-top:0; }
.offer-card .card-body p strong{ font-size:18px; }

/* Card titles under images */
.card-title{
  margin:0 0 8px;
  font-size:18px;
  font-weight:400;
  font-family:"LibreBaskerville", serif;
}

/* Footer */
.footer-brand{
  font-family:"LibreBaskerville", serif;
  font-style:italic;
  font-size:22px;
  color:#fff;
  margin-bottom:10px;
}
.footer-muted{ color:#cfcfcf; }
.footer-links{ display:grid; gap:8px; }

/* Slider dots consistent */
.slider .dots{
  flex-wrap:wrap;
  justify-content:center;
  max-width: calc(100% - 24px);
}

/* ====================================
   Direkt buchen Hinweis
==================================== */

.booking-call {
  position: fixed;
  top: 120px;
  right: 0;
  z-index: 1200;
  display: flex;
  justify-content: flex-end;
}

.booking-call-panel {
  display: flex;
  align-items: stretch;
  border-radius: 12px 0 0 12px;
  overflow: hidden;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.16);
}

/* WICHTIG: Breite sauber animieren */
.booking-call-main {
  display: flex;
  align-items: center;
  gap: 12px;
  background: #ae614b;
  color: #fff;
  text-decoration: none;
  padding: 14px 18px;
  width: 260px;
  min-width: 260px;
  max-width: 260px;
  overflow: hidden;
  white-space: nowrap;
  transition:
    width 0.3s ease,
    min-width 0.3s ease,
    max-width 0.3s ease,
    padding 0.3s ease,
    opacity 0.22s ease;
}

.booking-call-main:hover,
.booking-call-main:focus {
  color: #fff;
  text-decoration: none;
}

.booking-call-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
}

.booking-call-icon svg {
  width: 24px;
  height: 24px;
}

.booking-call-text {
  display: flex;
  flex-direction: column;
  line-height: 1.2;
  transition: opacity 0.18s ease;
}

.booking-call-text strong {
  font-size: 15px;
  font-weight: 600;
  color: #fff;
}

.booking-call-text span {
  font-size: 17px;
  font-weight: 500;
  color: #fff;
}

.booking-call-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 46px;
  min-width: 46px;
  border: 0;
  padding: 0;
  cursor: pointer;
  background: #c37a63;
  color: #fff;
  transition: background-color 0.25s ease;
}

.booking-call-toggle:hover,
.booking-call-toggle:focus {
  background: #b96d57;
}

.booking-call-toggle svg {
  width: 22px;
  height: 22px;
}

.booking-call .toggle-closed-icon {
  display: none;
}

.booking-call.is-collapsed .booking-call-panel {
  background: transparent;
  box-shadow: none;
}

.booking-call.is-collapsed .toggle-open-icon {
  display: none;
}

.booking-call.is-collapsed .toggle-closed-icon {
  display: block;
}

/* Desktop eingeklappt: Text komplett weg, nur Toggle bleibt sichtbar */
.booking-call.is-collapsed .booking-call-main {
  width: 0;
  min-width: 0;
  max-width: 0;
  padding-left: 0;
  padding-right: 0;
  opacity: 0;
  pointer-events: none;
}

.booking-call.is-collapsed .booking-call-text,
.booking-call.is-collapsed .booking-call-icon {
  opacity: 0;
}

/* auffälliger Call-Button im eingeklappten Zustand */

.booking-call.is-collapsed .booking-call-toggle {
  background: #ae614b;
  border-radius: 50%;
  width: 52px;
  min-width: 52px;
  height: 52px;
}

/* Puls Effekt */
.booking-call.is-collapsed .booking-call-toggle::after {
  content: "";
  position: absolute;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: rgba(174,97,75,0.35);
  animation: callPulse 2s infinite;
}

@keyframes callPulse {
  0% {
    transform: scale(1);
    opacity: 0.7;
  }
  70% {
    transform: scale(1.6);
    opacity: 0;
  }
  100% {
    opacity: 0;
  }
}

.booking-call.is-collapsed .booking-call-toggle svg {
  width: 36px;
  height: 36px;
}

/* Badge Punkt */

.info-badge-dot {
  fill: white;
  stroke: none;
  animation: infoPulse 2s infinite;
}

/* leichte Aufmerksamkeit */

@keyframes infoPulse {
  0% {
    transform: scale(1);
    opacity: 1;
  }

  50% {
    transform: scale(1.3);
    opacity: 0.7;
  }

  100% {
    transform: scale(1);
    opacity: 1;
  }
}

/* Mobile / Tablet */
@media (max-width: 1023px) {
  .booking-call {
    top: auto;
    right: 12px;
    left: auto;
    bottom: 12px;
  }

  .booking-call-panel {
    border-radius: 12px;
  }

  .booking-call-main {
    width: 230px;
    min-width: 230px;
    max-width: 230px;
    padding: 12px 14px;
  }

  .booking-call-text strong {
    font-size: 14px;
  }

  .booking-call-text span {
    font-size: 16px;
  }

  /* Auch mobil: komplett einklappen auf nur den Button */
  .booking-call.is-collapsed .booking-call-main {
    width: 0;
    min-width: 0;
    max-width: 0;
    padding-left: 0;
    padding-right: 0;
    opacity: 0;
    pointer-events: none;
  }
}

/* Sehr kleine Displays */
@media (max-width: 480px) {
  .booking-call {
    right: 8px;
    bottom: 8px;
  }

  .booking-call-main {
    width: 210px;
    min-width: 210px;
    max-width: 210px;
    gap: 10px;
    padding: 11px 12px;
  }

  .booking-call-icon svg {
    width: 22px;
    height: 22px;
  }

  .booking-call-text strong {
    font-size: 13px;
  }

  .booking-call-text span {
    font-size: 15px;
  }

  .booking-call-toggle {
    width: 44px;
    min-width: 44px;
  }
}

/* Responsive */
@media (max-width: 980px){
  .grid-2{grid-template-columns:1fr}
  .booking-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr}
  .hero{aspect-ratio:16/8}
}
@media (max-width: 1023px){
  /* Burger only on mobile */
  .nav-toggle{display:inline-flex}
  /* Mobile nav: slide down */
  .nav{
    display:flex;
    flex-direction:column;
    align-items:stretch;
    position:absolute;
    left:0; right:0;
    top:68px;
    background:var(--green);
    padding:10px 20px 16px;
    gap:6px;
    border-bottom-left-radius:18px;
    border-bottom-right-radius:18px;

    max-height:0;
    overflow:hidden;
    opacity:0;
    transform:translateY(-8px);
    pointer-events:none;
    transition: max-height .28s ease, opacity .28s ease, transform .28s ease;
  }
  .topbar.open .nav{
    max-height:80vh;
    opacity:1;
    transform:translateY(0);
    pointer-events:auto;
  }

  .dropdown-menu{position:static; box-shadow:none; border-radius:12px; margin-top:8px}
  .dropdown-menu a{color:var(--ink)}
  .booking-grid{grid-template-columns:1fr}
}


/* Accessibility */
.sr-only{
  position:absolute;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);
  white-space:nowrap;border:0;
}

.brand-logo{
  height:46px;
  width:auto;
  display:block;
  transition: height .25s ease;
}
.topbar.scrolled .brand-logo{ height:38px; }
@media (max-width: 720px){
  .brand-logo{ height:40px; }
}

/* Slider arrows */
.slider{
  position:relative;
}
.slider .arrow{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  border:0;
  width:44px;height:44px;
  border-radius:999px;
  background:rgba(0,0,0,.45);
  color:#fff;
  font-size:30px;
  padding:0;
  display:flex;
  align-items:center;
  justify-content:center;
  line-height:0;
  cursor:pointer;
  opacity:0;
  transition:opacity .18s ease, transform .18s ease, background .18s ease;
  z-index:5;
}
.slider .arrow:hover{ background:rgba(0,0,0,.58); transform:translateY(-50%) scale(1.03); }

.slider .arrow.prev{ left:10px; }
.slider .arrow.next{ right:10px; }
.slider:hover .arrow{ opacity:1; }
@media (hover:none){
  .slider .arrow{ opacity:1; }
}
.slider .arrow:focus-visible{ outline:2px solid #fff; outline-offset:2px; }


/* Icons (outline/fein, DSGVO-safe inline SVG) */
.icon{
  width:1em;
  height:1em;
  display:inline-block;
  vertical-align:-0.15em;
  fill:none;
  stroke:currentColor;
  stroke-width:1.65;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.icon-sm{ width:1.05em; height:1.05em; }
.icon-md{ width:1.35em; height:1.35em; }
.icon-lg{ width:1.45em; height:1.45em; }
.icon-accent{ color:var(--brown); }

/* Dropdown chevron */
.dropdown > button{
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.dropdown > button .chev{
  width:1em;
  height:1em;
  flex:0 0 auto;
  transition:transform .18s ease;
  opacity:.9;
}
.dropdown.open > button .chev{ transform:rotate(180deg); }

.dropdown.open > button::before{
  transform:translateY(-50%) rotate(180deg);
}


/* Dropdown: desktop hover + keyboard focus */
@media (min-width: 1024px){
  .dropdown:hover .dropdown-menu,
  .dropdown:focus-within .dropdown-menu{
    opacity:1;
    visibility:visible;
    transform:translateY(0);
    pointer-events:auto;
  }
}

@media (min-width: 1024px){ .nav-toggle{display:none !important;} .nav{display:flex !important;} }

/* Button icons should be white */
.btn .icon, .btn svg{ color:#fff; stroke:#fff; }



.nav-toggle .icon-md{ width:1.9em; height:1.9em; }

.btn.green .icon, .btn.brown .icon{ stroke:#fff; }

.dropdown-menu a{ color:var(--ink); }

.booking-box a{text-decoration:none}

.btn .icon{color:#fff}
