/* White Barn BnB — digital guidebook (bottom-tab app). Mobile-first, navy + gold. */
:root{
  --navy:#16293C; --navy-2:#1f3a55; --ink:#1b2530; --muted:#5b6b7b;
  --line:#e6ebf0; --bg:#f4f6f9; --card:#ffffff; --gold:#c9a24b;
  --radius:16px; --shadow:0 2px 16px rgba(22,41,60,.07); --maxw:680px; --tabbar-h:62px;
}
*{box-sizing:border-box}
[hidden]{display:none !important}
html{scroll-behavior:smooth}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--bg);line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:var(--navy-2)}
.skip{position:absolute;left:-999px}.skip:focus{left:8px;top:8px;background:#fff;padding:8px;z-index:200;border-radius:8px}
.muted{color:var(--muted)}.small{font-size:13px}
.pad{padding:0 16px}
img{max-width:100%}

/* Top bar */
.topbar{position:sticky;top:0;z-index:60;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:10px 14px;padding-top:max(10px,env(safe-area-inset-top));background:transparent;transition:background .2s}
.topbar--solid{background:var(--navy)}
.topbar__brand{font-weight:600;font-size:15px;color:#fff;text-shadow:0 1px 6px rgba(0,0,0,.4);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.topbar--solid .topbar__brand{text-shadow:none}
.topbar__actions{display:flex;gap:4px}
.iconbtn{background:rgba(0,0,0,.28);border:0;color:#fff;width:38px;height:38px;border-radius:50%;display:grid;place-items:center;cursor:pointer;font-size:17px;backdrop-filter:blur(4px)}
.topbar--solid .iconbtn{background:rgba(255,255,255,.14)}

/* Language offer bar */
.langbar{position:sticky;top:54px;z-index:55;display:flex;align-items:center;justify-content:space-between;gap:10px;margin:8px 12px 0;padding:10px 14px;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);font-size:14px}
.langbar__btns{display:flex;gap:6px}

/* App / tabs */
.app{max-width:var(--maxw);margin:0 auto;padding-bottom:calc(var(--tabbar-h) + env(safe-area-inset-bottom) + 16px)}
.tabview{animation:fade .2s ease}
@keyframes fade{from{opacity:.4}to{opacity:1}}

/* Hero (Home) — tall, full-bleed, crisp */
.hero{position:relative;margin-top:-54px;min-height:62vh;background:linear-gradient(160deg,var(--navy),var(--navy-2));background-size:cover;background-position:center;color:#fff;display:flex;align-items:flex-end;padding:24px 18px 22px}
.hero__inner{position:relative;width:100%}
.hero__logo{height:50px;margin-bottom:10px;filter:drop-shadow(0 1px 6px rgba(0,0,0,.4))}
.hero__title{margin:0;font-size:30px;line-height:1.12;font-weight:700;text-shadow:0 1px 10px rgba(0,0,0,.4)}
.hero__loc{margin-top:4px;opacity:.92;font-size:14px;text-shadow:0 1px 6px rgba(0,0,0,.4)}
.greet{margin-top:16px;background:rgba(255,255,255,.97);color:var(--ink);border-radius:var(--radius);padding:13px 15px;box-shadow:var(--shadow)}
.greet__hi{font-weight:700;font-size:18px}
.greet__stay{color:var(--muted);font-size:14px;margin-top:2px}
.countdown{margin-top:12px;background:rgba(0,0,0,.34);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.18);border-radius:14px;padding:12px 14px;color:#fff}
.cd__label{font-weight:600;font-size:14px;opacity:.95}
.cd__sub{font-size:13px;opacity:.85;margin-top:2px}
.cd__nums{display:flex;gap:18px;margin-top:6px}
.cd__nums span{font-size:12px;opacity:.85;display:flex;flex-direction:column;align-items:center}
.cd__nums b{font-size:24px;font-weight:700}

/* Quick tiles */
.tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:16px}
.tile{display:flex;flex-direction:column;align-items:center;gap:6px;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:14px 6px;cursor:pointer;box-shadow:var(--shadow);transition:transform .1s}
.tile:active{transform:scale(.96)}
.tile__ico{font-size:24px}
.tile__lbl{font-size:11.5px;font-weight:600;color:var(--ink);text-align:center;line-height:1.15}

/* Add to Home Screen card */
.a2hs{display:flex;align-items:center;gap:12px;margin-top:16px;background:var(--navy);color:#fff;border-radius:var(--radius);padding:14px}
.a2hs__icon{width:42px;height:42px;border-radius:10px}
.a2hs__txt{flex:1;display:flex;flex-direction:column}
.a2hs__txt strong{font-size:15px}.a2hs__txt span{font-size:12.5px;opacity:.82}

/* Cards */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);margin:14px 16px;overflow:hidden;scroll-margin-top:70px}
.card--note{margin:16px 0 0}
.card__h{padding:14px 16px 0;font-size:17px;font-weight:700;color:var(--navy)}
.card__b{padding:12px 16px 16px}
.card__b p{margin:0 0 10px}.card__b p:last-child{margin-bottom:0}
.body-list{margin:6px 0;padding-left:20px}.body-list li{margin:4px 0}
.tabhead{padding:18px 16px 2px}
.tabhead h2{margin:0;font-size:24px;color:var(--navy)}
.tabhead p{margin:4px 0 0;color:var(--muted);font-size:14px}

/* Accordion */
.acc{border:1px solid var(--line);border-radius:12px;margin:10px 0;overflow:hidden}
.acc__h{width:100%;text-align:left;background:var(--bg);border:0;padding:12px 14px;font-weight:600;font-size:15px;color:var(--ink);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:8px}
.acc__chev{color:var(--muted);transition:transform .2s}
.acc.open .acc__chev{transform:rotate(180deg)}
.acc__b{padding:12px 14px}
.acc__b p{margin:0 0 10px}.acc__b p:last-child{margin-bottom:0}

/* Buttons */
.btn{display:inline-block;background:var(--navy);color:#fff;border:0;border-radius:11px;padding:12px 16px;font-size:15px;font-weight:600;text-decoration:none;text-align:center;cursor:pointer}
.btn:active{background:var(--navy-2)}
.btn--ghost{background:#fff;color:var(--navy);border:1.5px solid var(--navy)}
.btn--book{margin-top:12px;background:var(--gold);color:#1c1407}
.chip{background:var(--navy);color:#fff;border:0;border-radius:999px;padding:8px 14px;font-size:13px;font-weight:600;cursor:pointer}
.chip--ghost{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.5)}
.langbar .chip{color:#fff}.langbar .chip--ghost{color:var(--navy);border-color:var(--line)}
.help-actions{display:flex;gap:8px;margin:8px 0}
.help-actions .btn{flex:1}

/* Store / shop tiles with images */
.shop{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:6px}
.shoptile{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:14px;overflow:hidden;text-decoration:none;color:var(--ink);background:#fff;transition:transform .1s}
.shoptile:active{transform:scale(.98)}
.shoptile__img{height:108px;background-size:cover;background-position:center;background-color:#eef2f6}
.shoptile__img--ph{display:grid;place-items:center;font-size:30px}
.shoptile__name{padding:9px 10px 2px;font-size:13px;font-weight:600;line-height:1.25;flex:1}
.shoptile__price{padding:0 10px 11px;color:var(--gold);font-weight:700;font-size:14px}
.store__all{width:100%;margin-top:12px}

/* Local recs */
.rec{border-top:1px solid var(--line);padding:11px 0}
.rec:first-child{border-top:0}
.rec__top{display:flex;justify-content:space-between;gap:8px;align-items:baseline}
.rec__name{font-weight:600}
.rec__area{color:var(--muted);font-size:12.5px;flex:0 0 auto}
.rec__blurb{font-size:14px;margin-top:3px}
.rec__meta{color:var(--muted);font-size:12.5px;margin-top:4px}
.rec__dir{display:inline-block;margin-top:6px;font-size:13px;font-weight:600}
.pair{margin-top:12px;background:var(--bg);border-radius:12px;padding:10px}
.pair__lbl{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;margin-bottom:6px}
.pair__chip{display:inline-block;background:#fff;border:1px solid var(--navy);color:var(--navy);border-radius:999px;padding:6px 11px;font-size:13px;margin:0 6px 6px 0;text-decoration:none}

/* Opt-in */
.optin{display:flex;flex-direction:column;gap:8px;margin-top:10px}
.optin input{border:1px solid var(--line);border-radius:10px;padding:12px 13px;font-size:16px}
.optin__msg{font-size:13.5px;color:var(--muted);min-height:18px}

/* Map + weather */
.map{height:220px;border-radius:12px;overflow:hidden;border:1px solid var(--line)}
.map__fallback{height:100%;display:grid;place-items:center;color:var(--muted);background:var(--bg)}
.maplist{margin-top:10px}.maplist .btn{width:100%}
.weather__now{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.weather__emoji{font-size:32px}.weather__temp{font-size:26px;font-weight:700}
.weather__days{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;text-align:center}
.weather__day{background:var(--bg);border-radius:10px;padding:8px 4px;font-size:12.5px}
.weather__e{font-size:22px;margin:2px 0}

/* Bottom tab bar */
.tabbar{position:fixed;left:0;right:0;bottom:0;z-index:70;height:calc(var(--tabbar-h) + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom);display:flex;background:#fff;border-top:1px solid var(--line);box-shadow:0 -2px 14px rgba(22,41,60,.06)}
.tabbar__btn{flex:1;background:none;border:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--muted);font-size:11px;font-weight:600;cursor:pointer}
.tabbar__ico{font-size:20px;filter:grayscale(.4);opacity:.7}
.tabbar__btn.is-active{color:var(--navy)}
.tabbar__btn.is-active .tabbar__ico{filter:none;opacity:1}

/* Search overlay */
.search{position:fixed;inset:0;z-index:120;background:var(--bg);display:flex;flex-direction:column}
.search__bar{display:flex;gap:8px;padding:12px;padding-top:max(12px,env(safe-area-inset-top));background:var(--navy)}
.search__bar input{flex:1;border:0;border-radius:10px;padding:12px 14px;font-size:16px}
.search__bar button{background:rgba(255,255,255,.15);color:#fff;border:0;border-radius:10px;padding:0 14px;font-size:18px;cursor:pointer}
.search__results{overflow:auto;padding:10px 14px}
.search__hit{display:flex;flex-direction:column;gap:2px;background:#fff;border:1px solid var(--line);border-radius:10px;padding:11px 13px;margin-bottom:8px;text-decoration:none;color:var(--ink)}
.search__hit span{color:var(--muted);font-size:13px}

/* Bottom sheet (door/wifi/language/install) */
.sheet{position:fixed;inset:0;z-index:130;display:flex;align-items:flex-end;justify-content:center}
.sheet__scrim{position:absolute;inset:0;background:rgba(10,18,28,.5)}
.sheet__card{position:relative;width:100%;max-width:var(--maxw);background:#fff;border-radius:20px 20px 0 0;padding:22px 18px calc(24px + env(safe-area-inset-bottom));box-shadow:0 -6px 30px rgba(0,0,0,.3);animation:slideup .22s ease}
@keyframes slideup{from{transform:translateY(40px);opacity:.6}to{transform:translateY(0);opacity:1}}
.sheet__x{position:absolute;top:12px;right:14px;border:0;background:none;font-size:18px;color:var(--muted);cursor:pointer}
.sheet__h{font-size:18px;font-weight:700;color:var(--navy);margin-bottom:8px}
.sheet__big{font-size:40px;font-weight:800;letter-spacing:4px;color:var(--navy);text-align:center;margin:6px 0 10px}
.steps{margin:8px 0 16px;padding-left:20px}.steps li{margin:8px 0}
.ios-share{display:inline-block}
.langgrid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:6px}
.langopt{text-align:left;background:var(--bg);border:1px solid var(--line);border-radius:10px;padding:11px 12px;font-size:15px;cursor:pointer;color:var(--ink)}
.langopt.is-cur{border-color:var(--navy);font-weight:700}

/* Consent + feedback */
.consent{position:fixed;left:10px;right:10px;bottom:calc(var(--tabbar-h) + 10px);z-index:110;background:var(--navy);color:#fff;border-radius:12px;padding:12px 14px;display:flex;flex-wrap:wrap;gap:10px;align-items:center;justify-content:space-between;box-shadow:0 6px 24px rgba(0,0,0,.3);font-size:14px}
.consent__btns{display:flex;gap:8px;margin-left:auto}
.feedback{position:fixed;left:10px;right:10px;bottom:calc(var(--tabbar-h) + 10px);z-index:105;background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px 16px;box-shadow:0 6px 24px rgba(0,0,0,.18);text-align:center;max-width:var(--maxw);margin:0 auto}
.feedback__x{position:absolute;top:8px;right:10px;border:0;background:none;font-size:16px;color:var(--muted);cursor:pointer}
.feedback__q{font-weight:600;margin-bottom:8px}
.feedback__stars button{background:none;border:0;font-size:30px;color:#d4d9df;cursor:pointer;padding:0 3px}
.feedback__stars button.on{color:var(--gold)}
.feedback__after{margin-top:8px;font-size:14px}

/* Landing */
.landing{background:var(--navy);color:#fff;min-height:100vh}
.landing__inner{max-width:var(--maxw);margin:0 auto;padding:48px 20px;text-align:center}
.landing__inner h1{font-size:30px;margin:0 0 6px}
.landing__cards{display:flex;flex-direction:column;gap:12px;margin:24px 0}
.landing__card{display:flex;flex-direction:column;gap:2px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.18);border-radius:12px;padding:16px;color:#fff;text-decoration:none}
.landing__card span{opacity:.75;font-size:13px}
.landing__note{opacity:.7;font-size:13px}

@media(min-width:560px){.shop{grid-template-columns:1fr 1fr 1fr}.langgrid{grid-template-columns:1fr 1fr 1fr}}

/* Print */
@media print{
  .topbar,.tabbar,.langbar,.search,.sheet,.consent,.feedback,#map,.store__all,.rec__dir,.a2hs,.tiles{display:none!important}
  .tabview[hidden]{display:block!important}
  body{background:#fff}
  .hero{min-height:auto;margin-top:0;color:#000;background:#fff!important;padding:0 0 10px}
  .hero__title{color:#000;text-shadow:none}.hero__loc{color:#333;text-shadow:none}
  .acc__b{display:block!important}
  .card{break-inside:avoid;box-shadow:none}
  a{color:#000;text-decoration:none}
}
