/* =========================================================
   Bella Casa – Website
   Foto-geführt, ruhig, ohne externe Schriften/Skripte/Tracker
   ========================================================= */

:root{
  --ink:#2a2622; --muted:#6f675f;
  --rose:#a35e48; --rose-d:#834733; --belegt:#c0392b; --frei:#6ba368; --anab:#edc23f;
  --paper:#fbf9f5; --line:#e3ddd3; --dark:#221f1b;
  --see:#2c5282;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0; background:var(--paper); color:var(--ink);
  font:17px/1.75 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  -webkit-font-smoothing:antialiased;}
h1,h2,h3,.serif{font-family:"Iowan Old Style","Palatino Linotype",Palatino,Georgia,"Times New Roman",serif;
  font-weight:600; line-height:1.18;}
img{max-width:100%; display:block}
a{color:var(--rose-d)}
.wrap{max-width:1120px; margin:0 auto; padding:0 26px}
.narrow{max-width:820px}
.center{text-align:center}
.eyebrow{text-transform:uppercase; letter-spacing:.24em; font-size:12px; font-weight:600; color:var(--rose); margin:0 0 16px}

/* Buttons */
.btn{display:inline-block; font-weight:600; font-size:15px; padding:14px 28px; border:1px solid var(--dark);
  background:var(--dark); color:#fff; border-radius:2px; cursor:pointer; transition:.18s; text-decoration:none}
.btn:hover{background:transparent; color:var(--dark)}
.btn-light{background:transparent; color:#fff; border-color:rgba(255,255,255,.7)}
.btn-light:hover{background:#fff; color:var(--ink); border-color:#fff}
.btn-line{background:transparent; color:var(--ink); border-color:var(--ink)}
.btn-line:hover{background:var(--ink); color:#fff}
.tlink{color:var(--rose-d); font-weight:600; text-decoration:none; border-bottom:1px solid var(--rose); padding-bottom:2px}
.tlink:hover{color:var(--ink); border-color:var(--ink)}

/* Navigation */
.nav{position:fixed; inset:0 0 auto 0; z-index:50; transition:.25s}
.nav-inner{display:flex; align-items:center; justify-content:space-between; padding:20px 26px; max-width:1120px; margin:0 auto}
.brand{font-family:"Iowan Old Style",Palatino,Georgia,serif; font-size:24px; color:#fff; text-decoration:none}
.brand small{display:block; font-family:-apple-system,Segoe UI,Roboto,sans-serif; font-size:10px; font-weight:600;
  letter-spacing:.26em; text-transform:uppercase; opacity:.8; margin-top:2px}
.nav-links{display:flex; gap:26px; align-items:center}
.nav-links a{color:#fff; font-size:15px; text-decoration:none; opacity:.92}
.nav-links a:hover,.nav-links a.active{opacity:1}
.nav-links a.navcta{border:1px solid rgba(255,255,255,.6); padding:9px 18px; border-radius:2px; font-weight:600}
.nav.scrolled{background:var(--paper); box-shadow:0 1px 0 var(--line)}
.nav.scrolled .brand,.nav.scrolled .nav-links a{color:var(--ink)}
.nav.scrolled .brand small{color:var(--rose)}
.nav.scrolled .nav-links a.active{color:var(--rose-d)}
.nav.scrolled .nav-links a.navcta{border-color:var(--ink)}
.nav-toggle{display:none; background:none; border:0; color:#fff; font-size:24px; cursor:pointer}
.nav.scrolled .nav-toggle{color:var(--ink)}

/* Hero */
.hero{position:relative; min-height:94vh; display:flex; align-items:flex-end; color:#fff; background:#333}
.hero img.bg{position:absolute; inset:0; width:100%; height:100%; object-fit:cover}
.hero::after{content:""; position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(180deg,rgba(20,16,12,.34) 0%,rgba(20,16,12,0) 20%)}
.hero-content{position:relative; z-index:2; max-width:560px; margin-bottom:72px; padding:38px 44px 42px;
  border-left:4px solid var(--rose); border-radius:5px; background:rgba(251,249,245,.74);
  -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px); box-shadow:0 16px 44px rgba(20,16,12,.22)}
.hero .eyebrow{color:var(--rose-d)}
.hero h1{font-size:clamp(40px,6.2vw,68px); margin:0 0 18px; color:var(--ink)}
.hero p.lead{font-size:clamp(18px,2.1vw,21px); line-height:1.62; color:var(--muted); margin:0 0 30px; max-width:480px}
.hero-actions{display:flex; gap:16px; flex-wrap:wrap; align-items:center}

/* Seitentitel (innere Seiten) */
.page-head{padding-top:128px; padding-bottom:10px}
.page-head .eyebrow{margin-bottom:12px}
.page-head h1{font-size:clamp(32px,5vw,52px); margin:0}
.page-head p.sub{color:var(--muted); max-width:680px; margin:14px 0 0; font-size:19px}

/* Sections */
section{padding:84px 0}
.section-soft{background:#fff; border-top:1px solid var(--line); border-bottom:1px solid var(--line)}
.section-head{max-width:680px; margin:0 0 50px}
.section-head.center{margin-left:auto; margin-right:auto}
.section-head h2{font-size:clamp(28px,4vw,42px); margin:0 0 14px}
.section-head p{color:var(--muted); font-size:18px; margin:0}

/* Duo */
.duo{display:grid; grid-template-columns:1.05fr .95fr; gap:60px; align-items:center}
.duo.flip .pic{order:2}
.duo .pic{aspect-ratio:4/3; overflow:hidden}
.duo .pic img{width:100%; height:100%; object-fit:cover}
.duo h2{font-size:clamp(28px,3.6vw,40px); margin:0 0 18px}
.duo p{color:var(--muted); margin:0 0 16px}

/* Spalten ohne Icons */
.cols{display:grid; grid-template-columns:repeat(4,1fr); gap:0}
.col{padding:30px 26px 4px 0; border-top:2px solid var(--ink)}
.col h3{font-size:20px; margin:0 0 10px}
.col p{color:var(--muted); font-size:15.5px; margin:0}

/* Ausflugsziele nach Abteilungen (Bodensee-Seite) */
.ziel-nav{display:flex; flex-wrap:wrap; justify-content:center; gap:10px; margin:0 0 46px}
.ziel-nav a{--c:var(--rose); display:inline-flex; align-items:center; gap:8px; text-decoration:none;
  font-size:14px; font-weight:600; color:var(--ink); background:#fff; border:1px solid var(--line);
  padding:9px 16px; border-radius:2px; transition:.15s}
.ziel-nav a::before{content:""; width:9px; height:9px; border-radius:50%; background:var(--c); flex:0 0 auto}
.ziel-nav a:hover{border-color:var(--c); color:var(--c)}
.ziel-gruppe{--c:var(--rose); scroll-margin-top:96px; margin:0 0 42px}
.ziel-gruppe>h3{display:flex; align-items:center; gap:12px; font-size:23px; margin:0 0 20px;
  padding-bottom:11px; border-bottom:2px solid var(--c)}
.ziel-gruppe>h3::before{content:""; width:15px; height:15px; border-radius:4px; background:var(--c); flex:0 0 auto}
.ziel-cards{display:grid; grid-template-columns:repeat(3,1fr); gap:16px}
.ziel{background:#fff; border:1px solid var(--line); border-left:4px solid var(--c); padding:16px 18px}
.ziel .z-top{display:flex; justify-content:space-between; align-items:baseline; gap:12px}
.ziel h4{font-size:16px; margin:0; line-height:1.3}
.ziel h4 a{color:var(--ink); text-decoration:none; border-bottom:1px solid transparent}
.ziel h4 a:hover{color:var(--c); border-bottom-color:var(--c)}
.ziel .z-km{font-size:12.5px; font-weight:600; color:var(--muted); white-space:nowrap}
.ziel p{font-size:14px; color:var(--muted); margin:8px 0 0; line-height:1.5}
@media(max-width:920px){ .ziel-cards{grid-template-columns:repeat(2,1fr)} }
@media(max-width:600px){ .ziel-cards{grid-template-columns:1fr} }

/* Apartment-Karten */
.cards{display:grid; grid-template-columns:repeat(3,1fr); gap:28px}
.card{background:#fff; border:1px solid var(--line); overflow:hidden; display:flex; flex-direction:column; text-decoration:none; color:inherit}
.card .pic{aspect-ratio:3/2; overflow:hidden; position:relative}
.card .pic img{width:100%; height:100%; object-fit:cover; transition:.5s}
.card:hover .pic img{transform:scale(1.04)}
.card .body{padding:22px 24px 26px; display:flex; flex-direction:column; flex:1}
.card h3{font-size:22px; margin:0 0 8px}
.card .meta{color:var(--muted); font-size:14px; margin:0 0 12px}
.card p{color:var(--muted); margin:0 0 18px; font-size:15.5px}
.card .foot{margin-top:auto; display:flex; align-items:center; justify-content:space-between; gap:12px}
.tag{position:absolute; top:12px; left:12px; background:var(--rose); color:#fff; font-size:11px;
  letter-spacing:.12em; text-transform:uppercase; font-weight:700; padding:5px 11px; border-radius:2px}
.chip{display:inline-block; font-size:12px; color:var(--muted); border:1px solid var(--line);
  border-radius:999px; padding:2px 10px; margin:0 4px 4px 0}

/* Region Band */
.band{position:relative; color:#fff; min-height:480px; display:flex; align-items:center; background:#333}
.band img.bg{position:absolute; inset:0; width:100%; height:100%; object-fit:cover}
.band::after{content:""; position:absolute; inset:0; background:linear-gradient(90deg,rgba(20,16,12,.72),rgba(20,16,12,.25))}
.band .inner{position:relative; z-index:2; max-width:540px}
.band .eyebrow{color:#eccdb9}
.band h2{font-size:clamp(28px,3.8vw,40px); margin:0 0 18px; text-shadow:0 1px 8px rgba(0,0,0,.4)}
.band p,.band li{text-shadow:0 1px 8px rgba(0,0,0,.4)}
.band p{opacity:.95; margin:0 0 18px}
.band ul{list-style:none; padding:0; margin:0; display:grid; gap:12px}
.band li{padding-left:22px; position:relative}
.band li::before{content:"—"; position:absolute; left:0; color:#eccdb9}

/* Galerie (Apartment-Detail) */
.gallery{display:grid; grid-template-columns:2fr 1fr 1fr; grid-auto-rows:1fr; gap:12px; margin-top:34px}
.gallery a{overflow:hidden; display:block}
.gallery img{width:100%; height:100%; object-fit:cover; aspect-ratio:3/2}
.gallery .big{grid-row:span 2}
.gallery .big img{aspect-ratio:auto; height:100%}

.detail-body{display:grid; grid-template-columns:1.6fr 1fr; gap:52px; align-items:start; padding-top:56px}
.detail-body h2{font-size:26px; margin:34px 0 14px}
.detail-body h2:first-child{margin-top:0}
.detail-body p{color:var(--muted)}
.amen{list-style:none; padding:0; margin:0; columns:2; column-gap:28px}
.amen li{padding:9px 0; border-bottom:1px solid var(--line); break-inside:avoid}
.book-box{position:sticky; top:100px; border:1px solid var(--line); background:#fff; padding:28px}
.book-box .facts .r{display:flex; justify-content:space-between; padding:11px 0; border-top:1px solid var(--line); font-size:15px}
.book-box .facts .r:first-child{border-top:0}
.book-box .facts .r span{color:var(--muted)}
.book-box .btn{display:block; text-align:center; width:100%; margin-top:14px}

/* Formulare */
form.form{background:#fff; border:1px solid var(--line); padding:30px}
.field{margin-bottom:18px}
.field label{display:block; font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); font-weight:600; margin-bottom:7px}
.field input,.field textarea,.field select{width:100%; padding:13px 14px; border:1px solid var(--line);
  border-radius:2px; font:inherit; font-size:15px; background:var(--paper); color:var(--ink)}
.field input:focus,.field textarea:focus,.field select:focus{outline:none; border-color:var(--rose); background:#fff}
.field-row{display:grid; grid-template-columns:1fr 1fr; gap:18px}
.form-note{font-size:13px; color:var(--muted); margin:10px 0 0}
.notice{padding:14px 18px; border-radius:4px; margin-bottom:18px; font-size:15px}
.notice.ok{background:#eaf5ec; border:1px solid #b7dcc0; color:#1f5130}
.notice.err{background:#fbecea; border:1px solid #f0c4bd; color:#8a2c1c}

.dl{margin:0}
.dl .row{padding:16px 0; border-top:1px solid var(--line); display:grid; grid-template-columns:140px 1fr; gap:14px}
.dl dt{font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--rose); font-weight:700; padding-top:2px}
.dl dd{margin:0}
.dl dd b{display:block}
.dl dd span{color:var(--muted); font-size:15px}

.contact-grid{display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:start}
.prose{max-width:780px}
.prose h2{font-size:24px; margin:32px 0 12px}
.prose p,.prose li{color:var(--muted)}
.prose address{font-style:normal; color:var(--ink)}

.book-box .bb-price{font-family:"Iowan Old Style",Palatino,Georgia,serif; font-size:30px; color:var(--ink); margin-bottom:14px}
.book-box .bb-price small{font-family:-apple-system,sans-serif; font-size:14px; color:var(--muted); font-weight:400}
.book-box .bb-price.bb-price-sm{font-size:22px}

/* ── Slider (mobil per Wisch) ── */
.slider{position:relative; overflow:hidden; background:#eee}
.slider-track{display:flex; overflow-x:auto; scroll-snap-type:x mandatory; scroll-behavior:smooth;
  -webkit-overflow-scrolling:touch; scrollbar-width:none}
.slider-track::-webkit-scrollbar{display:none}
.slider .slide{position:relative; flex:0 0 100%; scroll-snap-align:center;
  height:clamp(280px,46vw,520px); overflow:hidden; background:#2a2622}
/* Bild füllt die Kachel pass-genau (keine dunklen Ränder) */
.slider .slide img{position:relative; z-index:1; width:100%; height:100%; object-fit:cover; display:block}
.slider-btn{position:absolute; top:50%; transform:translateY(-50%); width:44px; height:44px; border:0;
  background:rgba(251,249,245,.85); color:var(--ink); font-size:26px; line-height:1; cursor:pointer;
  border-radius:50%; box-shadow:0 2px 8px rgba(0,0,0,.18); display:grid; place-items:center; transition:.15s}
.slider-btn:hover{background:#fff}
.slider-btn.prev{left:14px} .slider-btn.next{right:14px}
.slider-dots{position:absolute; left:0; right:0; bottom:14px; display:flex; justify-content:center; gap:8px}
.slider-dots button{width:9px; height:9px; padding:0; border:0; border-radius:50%; cursor:pointer;
  background:rgba(255,255,255,.55); box-shadow:0 1px 2px rgba(0,0,0,.35)}
.slider-dots button.active{background:#fff; transform:scale(1.3)}
@media(max-width:600px){ .slider-btn{width:38px; height:38px; font-size:22px} }

/* Galerie (Splide): großes Hauptbild + synchronisierte Vorschaubilder als Leiste darunter */
.gallery{display:flex; flex-direction:column; gap:10px; max-width:640px; margin:0 auto}
.gallery-wide .gallery{max-width:none}
.gal-main{position:relative; min-width:0; border-radius:4px; overflow:hidden}
.gal-main .splide__slide img{width:100%; height:auto; display:block}
.gal-main .splide__arrow{position:absolute; top:50%; transform:translateY(-50%); z-index:2;
  width:44px; height:44px; border:0; border-radius:50%; cursor:pointer;
  background:rgba(251,249,245,.85); box-shadow:0 2px 8px rgba(0,0,0,.18);
  display:grid; place-items:center; transition:.15s}
.gal-main .splide__arrow:hover{background:#fff}
.gal-main .splide__arrow svg{width:17px; height:17px; fill:var(--ink)}
.gal-main .splide__arrow--prev{left:14px}
.gal-main .splide__arrow--next{right:14px}
.gal-thumbs{min-width:0}
.gal-thumbs .splide__slide{opacity:.5; border:2px solid transparent; border-radius:4px; overflow:hidden;
  cursor:pointer; background:#2a2622; transition:opacity .15s, border-color .15s}
.gal-thumbs .splide__slide img{width:100%; height:100%; object-fit:cover; display:block}
.gal-thumbs .splide__slide:hover{opacity:.8}
.gal-thumbs .splide__slide.is-active{opacity:1; border-color:var(--rose)}

/* Gemeinschaftseinrichtungen */
.facility{display:grid; grid-template-columns:1.1fr .9fr; gap:0; align-items:stretch; margin-bottom:28px;
  border:1px solid var(--line); background:#fff; overflow:hidden}
.facility:nth-child(even){grid-template-columns:.9fr 1.1fr}
.facility:nth-child(even) .facility-pic{order:2}
.facility.facility-nopic{grid-template-columns:1fr; border-left:4px solid var(--rose)}
.facility-text{padding:36px 38px; display:flex; flex-direction:column; justify-content:center}
.facility-text h3{font-size:24px; margin:0 0 10px}
.facility-text p{color:var(--muted); margin:0}
.access{border:1px solid var(--line); background:#fff; padding:22px 24px; margin-top:26px}
.access h3{font-size:18px; margin:0 0 6px}
.access p.note{color:var(--muted); font-size:14px; margin:0 0 14px}
.access ul{list-style:none; padding:0; margin:0; display:grid; grid-template-columns:1fr 1fr; gap:10px 22px}
.access li{display:flex; align-items:center; gap:10px}
.access li::before{content:"✓"; color:#fff; background:var(--see); width:22px; height:22px; border-radius:50%;
  display:grid; place-items:center; font-size:13px; font-weight:700; flex:0 0 auto}

/* ── Footer ── */
footer.site{background:var(--dark); color:#c9c1b6; padding:72px 0 30px; font-size:15px}
.foot-grid{display:grid; grid-template-columns:1.6fr 1fr 1fr; gap:48px; margin-bottom:44px}
footer.site h4{font-family:"Iowan Old Style",Palatino,Georgia,serif; color:#fff; font-size:18px; margin:0 0 16px; font-weight:600}
footer.site p{margin:0; line-height:1.7}
footer.site a{color:#c9c1b6; text-decoration:none}
footer.site a:hover{color:#fff}
.foot-links{list-style:none; padding:0; margin:0; display:grid; gap:10px}
.foot-bottom{border-top:1px solid rgba(255,255,255,.14); padding-top:24px; display:flex;
  justify-content:space-between; flex-wrap:wrap; gap:10px; font-size:13px; color:#8f877c}

/* ── Kalender ── */
.cal-tools{display:flex; flex-wrap:wrap; gap:16px; align-items:center; margin:0 0 24px}
.cal-tools select{padding:10px 14px; border:1px solid var(--line); border-radius:2px; font:inherit; background:#fff}
.cal-legend{display:flex; gap:18px; font-size:14px; color:var(--muted); margin-left:auto; flex-wrap:wrap}
.cal-legend i{display:inline-block; width:14px; height:14px; border-radius:3px; vertical-align:-2px; margin-right:6px}
.cal-legend .lg-frei{background:#fff; border:1px solid var(--line)}
.cal-legend .lg-belegt{background:var(--belegt)}
.cal-legend .lg-ofrei{background:var(--frei)}
.cal-legend .lg-oanab{background:var(--anab)}
.cal-legend .lg-obelegt{background:var(--belegt)}
.cal-months{display:grid; grid-template-columns:repeat(2,1fr); gap:26px}
.cal{width:100%; border-collapse:collapse; background:#fff; border:1px solid var(--line)}
.cal caption{font-family:"Iowan Old Style",Palatino,Georgia,serif; font-size:20px; padding:14px; color:var(--ink); border-bottom:1px solid var(--line)}
.cal th{font-size:12px; text-transform:uppercase; letter-spacing:.06em; color:var(--muted); font-weight:600; padding:8px 0; border-bottom:1px solid var(--line)}
.cal td{height:46px; text-align:center; border:1px solid var(--line); font-size:14px; position:relative}
.cal td.empty{background:#faf7f2; border-color:#f0ece4}
.cal td.frei{background:var(--frei)}
.cal td.anab{background:var(--anab)}
.cal td.belegt{background:var(--belegt); color:#fff; font-weight:600}
.cal td.past{opacity:.5}
.cal td.heute{outline:2px solid var(--see); outline-offset:-2px}
.pager{display:flex; gap:10px; align-items:center; margin:6px 0 22px}
.pager a{text-decoration:none; border:1px solid var(--line); padding:8px 14px; border-radius:2px; color:var(--ink); background:#fff}
.pager a:hover{background:var(--ink); color:#fff}

/* ── Belegung-Übersicht (Matrix: Apartments × Tage) ── */
.matrix-scroll{overflow-x:auto; -webkit-overflow-scrolling:touch; border:1px solid var(--line); background:#fff}
.occ{border-collapse:collapse; width:100%; font-size:13px}
.occ th,.occ td{border:1px solid var(--line); text-align:center}
.occ thead th{background:#f6f3ee; color:var(--muted); font-weight:600}
.occ th.corner{position:sticky; left:0; z-index:3; background:#f6f3ee; text-align:left;
  padding:8px 14px; min-width:140px; font-family:"Iowan Old Style",Palatino,Georgia,serif; color:var(--ink)}
.occ th.day{padding:6px 0; min-width:26px; font-size:12px}
.occ th.wd{padding:3px 0; font-size:10px; font-weight:500; border-top:0}
.occ th.day.heute{color:var(--see); font-weight:700}
.occ th.we{background:#f1ece3}
.occ tbody th.room{position:sticky; left:0; z-index:2; background:#fff; text-align:left;
  padding:9px 14px; white-space:nowrap; font-weight:600; border-right:2px solid var(--line)}
.occ tbody th.room a{color:var(--ink); text-decoration:none}
.occ tbody th.room a:hover{color:var(--rose)}
.occ td{height:34px}
.occ td.frei{background:var(--frei)}
.occ td.anab{background:var(--anab)}
.occ td.belegt{background:var(--belegt)}
.occ td.past{opacity:.5}
.occ td.heute{outline:2px solid var(--see); outline-offset:-2px}

/* ── Admin ── */
.admin-body{background:#eef1f5; color:#2d3748; font-family:'Segoe UI',Arial,sans-serif}
.admin-top{background:linear-gradient(135deg,#1e3a5f,#2c5282); color:#fff; padding:16px 26px;
  display:flex; justify-content:space-between; align-items:center}
.admin-top .brand2{font-weight:700; letter-spacing:.5px}
.admin-top a{color:#cfe0f0; text-decoration:none; font-size:14px}
.admin-wrap{max-width:1000px; margin:26px auto; padding:0 20px}
.admin-card{background:#fff; border:1px solid #e2e8f0; border-radius:8px; padding:24px 26px; margin-bottom:22px; box-shadow:0 2px 10px rgba(0,0,0,.05)}
.admin-card h2{font-family:inherit; font-size:1.15rem; color:#1e3a5f; margin:0 0 16px}
.admin-grid{display:grid; grid-template-columns:repeat(auto-fill,minmax(150px,1fr)); gap:10px}
.admin-grid label{display:block; font-size:.72rem; text-transform:uppercase; letter-spacing:.08em; color:#718096; margin-bottom:5px; font-weight:600}
.admin-grid input,.admin-grid select{width:100%; padding:10px 12px; border:1px solid #cbd5e0; border-radius:5px; font:inherit}
.admin-btn{background:#2c5282; color:#fff; border:0; border-radius:5px; padding:11px 22px; font-weight:600; cursor:pointer; font-size:.95rem}
.admin-btn:hover{background:#1e3a5f}
.admin-btn.danger{background:#fff; color:#c53030; border:1px solid #f0b6ae; padding:6px 12px; font-size:.8rem}
.admin-btn.danger:hover{background:#c53030; color:#fff}
.btab{width:100%; border-collapse:collapse; font-size:.93rem}
.btab th{text-align:left; color:#718096; font-size:.74rem; text-transform:uppercase; letter-spacing:.06em; padding:8px 10px; border-bottom:2px solid #e2e8f0}
.btab td{padding:9px 10px; border-bottom:1px solid #edf2f7}
.btab tr:hover td{background:#f7fafc}
.login-box{max-width:360px; margin:90px auto; background:#fff; border:1px solid #e2e8f0; border-radius:8px; padding:30px; box-shadow:0 4px 20px rgba(0,0,0,.08)}
.login-box h1{font-family:inherit; font-size:1.3rem; color:#1e3a5f; margin:0 0 18px; text-align:center}
.login-box input{width:100%; padding:12px 14px; border:1px solid #cbd5e0; border-radius:5px; font:inherit; margin-bottom:14px}
.admin-mini .cal td{height:34px; font-size:12px}
.admin-cal-grid{display:grid; grid-template-columns:repeat(auto-fill,minmax(230px,1fr)); gap:18px}
.admin-msg{padding:12px 16px; border-radius:6px; margin-bottom:16px; font-size:.92rem}
.admin-msg.ok{background:#f0fff4; border:1px solid #9ae6b4; color:#22543d}
.admin-msg.err{background:#fff5f5; border:1px solid #feb2b2; color:#822727}

/* Responsive */
@media(max-width:920px){
  .duo,.contact-grid,.detail-body{grid-template-columns:1fr; gap:38px}
  .duo.flip .pic{order:0}
  .cols{grid-template-columns:1fr 1fr; gap:0 28px}
  .cards{grid-template-columns:1fr 1fr}
  .cal-months{grid-template-columns:1fr}
  .facility,.facility:nth-child(even){grid-template-columns:1fr}
  .facility .facility-text{order:1}
  .facility .facility-pic{order:2}
  .book-box{position:static}
}
@media(max-width:600px){
  section{padding:58px 0}
  .nav-links{position:fixed; inset:66px 0 auto 0; background:var(--paper); flex-direction:column; align-items:stretch;
    gap:0; padding:8px 26px 20px; box-shadow:0 12px 24px rgba(0,0,0,.1); transform:translateY(-150%); transition:.25s}
  .nav-links.open{transform:translateY(0)}
  .nav-links a{color:var(--ink)!important; padding:13px 0; border-bottom:1px solid var(--line)}
  .nav-links a.navcta{border:1px solid var(--ink)!important; text-align:center; margin-top:12px}
  .nav-toggle{display:block}
  .cols,.cards{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr; gap:30px}
  .field-row{grid-template-columns:1fr}
  .amen{columns:1}
  .page-head{padding-top:104px; padding-bottom:6px}
  .facility-text{padding:26px 24px}
}
