:root{
  --ink:#15323e; --ink2:#1d4452; --duck:#bcd3d6; --duck-soft:#e2eded;
  --sage:#9bb06f; --sage-deep:#7d9555; --paper:#faf7f0; --paper2:#f2ece0;
  --plum:#6b3a56; --line:#e2dccd; --text:#2c3a40; --muted:#67737a;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Hanken Grotesk',system-ui,sans-serif;color:var(--text);background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,.display{font-family:'Newsreader',Georgia,serif;font-weight:500;line-height:1.14;color:var(--ink);letter-spacing:-.01em}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
.eyebrow{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--plum);font-weight:600}
.btn{display:inline-flex;align-items:center;gap:.5em;background:var(--ink);color:#fff;padding:.85em 1.5em;border-radius:999px;font-weight:600;font-size:.95rem;border:none;cursor:pointer;transition:.2s;font-family:inherit}
.btn:hover{background:var(--ink2);transform:translateY(-1px)}
.btn.ghost{background:transparent;color:var(--ink);border:1.5px solid var(--ink)}
.btn.ghost:hover{background:var(--ink);color:#fff}
.btn.sage{background:var(--sage-deep)}.btn.sage:hover{background:#6c8348}
.topbar{background:var(--ink);color:#dfeaea;font-size:.84rem}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:40px;flex-wrap:wrap;gap:8px}
.topbar a{color:#dfeaea}.topbar a:hover{color:#fff}
header.site{position:sticky;top:0;z-index:50;background:rgba(250,247,240,.93);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
header.site .wrap{display:flex;align-items:center;justify-content:space-between;height:84px;gap:20px}
.logo img{height:60px;width:auto}
nav.main{display:flex;align-items:center;gap:26px}
nav.main a{font-weight:500;font-size:.97rem;color:var(--ink);position:relative;padding:4px 0}
nav.main a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--sage);transition:width .25s}
nav.main a:hover::after{width:100%}
.hero{position:relative;min-height:600px;display:flex;align-items:flex-end;color:#fff;background-size:cover;background-position:center}
.hero::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(21,50,62,.12),rgba(21,50,62,.78))}
.hero .wrap{position:relative;padding:90px 24px 50px;width:100%}
.hero .eyebrow{color:var(--duck)}
.hero h1{color:#fff;font-size:clamp(2.4rem,6vw,4.2rem);font-weight:400;max-width:15ch;margin:.3em 0 .35em}
.hero p.lede{font-size:1.16rem;max-width:46ch;color:#eef4f3}
.bookcard{background:var(--paper);color:var(--text);border-radius:18px;padding:22px;margin-top:30px;box-shadow:0 24px 60px -24px rgba(10,30,38,.55);display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:16px;align-items:end;max-width:860px}
.bookcard label{display:block;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:6px}
.bookcard input,.bookcard select{width:100%;padding:.7em .8em;border:1.5px solid var(--line);border-radius:10px;font:inherit;background:#fff;color:var(--text)}
.bookcard .btn{height:46px;white-space:nowrap;justify-content:center}
section{padding:80px 0}
.sec-head{max-width:660px;margin-bottom:42px}
.sec-head h2{font-size:clamp(1.9rem,3.6vw,2.7rem);margin:.25em 0}
.sec-head p{color:var(--muted);font-size:1.05rem}
.welcome{display:grid;grid-template-columns:1.3fr .9fr;gap:54px;align-items:start}
.welcome p{margin-bottom:1.1em;font-size:1.05rem}
.note{background:var(--duck-soft);border-left:3px solid var(--sage);border-radius:0 12px 12px 0;padding:20px 22px;font-size:.96rem;color:var(--ink2)}
.note strong{display:block;margin-bottom:.3em;color:var(--ink)}
.rooms{background:var(--paper2)}
.roomgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.room{background:#fff;border-radius:16px;overflow:hidden;border:1px solid var(--line);display:flex;flex-direction:column;transition:.2s}
.room:hover{transform:translateY(-4px);box-shadow:0 22px 44px -26px rgba(10,30,38,.5)}
.room .ph{aspect-ratio:16/10;overflow:hidden;position:relative;background:var(--duck-soft)}
.room .ph img{width:100%;height:100%;object-fit:cover;transition:.4s}
.room:hover .ph img{transform:scale(1.05)}
.phcount{position:absolute;left:12px;bottom:12px;background:rgba(15,38,46,.82);color:#fff;font-size:.74rem;font-weight:600;padding:5px 11px;border-radius:999px}
.room .body{padding:20px 22px 24px;display:flex;flex-direction:column;flex:1}
.room h3{font-size:1.3rem;margin-bottom:.3em}
.room .body>p{font-size:.95rem;color:var(--muted)}
.chips{display:flex;flex-wrap:wrap;gap:6px;margin:12px 0 16px}
.chip{font-size:.72rem;background:var(--duck-soft);color:var(--ink2);padding:4px 10px;border-radius:999px;font-weight:500}
.room .foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:12px;padding-top:14px;border-top:1px solid var(--line)}
.price b{font-family:'Newsreader',serif;font-size:1.45rem;color:var(--ink);font-weight:600}
.price span{font-size:.82rem;color:var(--muted)}
.inn{background:linear-gradient(180deg,var(--duck-soft),var(--paper))}
.inn .split{display:grid;grid-template-columns:1fr 1fr;border-radius:20px;overflow:hidden;border:1px solid var(--line);background:#fff}
.inn .pic{background:var(--ink);min-height:320px;display:flex;align-items:center;justify-content:center;color:#cfe0e1;text-align:center;padding:30px}
.inn .pic .crest{font-family:'Newsreader',serif;font-size:2.4rem;color:#fff;line-height:1.1}
.inn .pic small{display:block;letter-spacing:.22em;text-transform:uppercase;font-size:.72rem;color:var(--sage);margin-top:10px}
.inn .txt{padding:44px}
.inn .txt h2{font-size:clamp(1.8rem,3.4vw,2.5rem);margin:.2em 0 .5em}
.inn .txt p{color:var(--muted);margin-bottom:1em;font-size:1.04rem}
.nearby ul{list-style:none;display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.nearby li{background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px 24px}
.nearby li h3{font-size:1.15rem;margin-bottom:.3em}
.nearby li p{font-size:.93rem;color:var(--muted)}
.nearby li .dist{font-size:.76rem;color:var(--sage-deep);font-weight:600;letter-spacing:.04em}
.blog{background:var(--ink);color:#e9f0f0}
.blog .sec-head h2{color:#fff}.blog .sec-head p{color:#aec4c6}
.bloggrid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.post{background:#1b3e4a;border-radius:14px;padding:26px;border:1px solid #2a5260;transition:.2s;display:block}
.post:hover{transform:translateY(-3px);border-color:var(--sage)}
.post .tag{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--sage);font-weight:600}
.post h3{color:#fff;font-size:1.28rem;margin:.5em 0 .4em}
.post p{font-size:.94rem;color:#bdd0d2}
footer.site{background:#0f262e;color:#b9cccd;padding:58px 0 28px;font-size:.93rem}
footer.site .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;margin-bottom:38px}
footer.site h4{color:#fff;font-family:'Newsreader',serif;font-size:1.2rem;margin-bottom:.7em;font-weight:500}
footer.site a{color:#b9cccd}footer.site a:hover{color:#fff}
footer.site .fine{border-top:1px solid #20424c;padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.84rem;color:#80999b}
footer.site .fine a.credit{color:#cdd8d9;font-weight:600}
.page{padding:60px 0 80px;min-height:60vh}
.crumbs{font-size:.85rem;color:var(--muted);margin-bottom:18px}
.gallery{display:grid;grid-template-columns:2fr 1fr 1fr;gap:10px;margin:20px 0 30px;border-radius:16px;overflow:hidden}
.gallery img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3}
.gallery img:first-child{grid-row:span 2;aspect-ratio:auto}
.detailgrid{display:grid;grid-template-columns:1.6fr 1fr;gap:40px;align-items:start}
.bookbox{background:#fff;border:1px solid var(--line);border-radius:16px;padding:24px;position:sticky;top:104px}
.bookbox label{display:block;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:600;margin:12px 0 5px}
.bookbox input,.bookbox select,.field input,.field select,.field textarea{width:100%;padding:.7em .8em;border:1.5px solid var(--line);border-radius:10px;font:inherit;background:#fff}
.quote{background:var(--duck-soft);border-radius:10px;padding:14px 16px;margin:16px 0;font-size:.95rem}
.field{margin-bottom:16px}.field label{display:block;font-weight:600;font-size:.9rem;margin-bottom:5px;color:var(--ink2)}
.prose p{margin-bottom:1em}.prose h2{margin:1.2em 0 .4em;font-size:1.5rem}.prose ul{margin:0 0 1em 1.2em}
.flash{padding:12px 16px;border-radius:10px;margin-bottom:18px;font-size:.92rem}
.flash.err{background:#fbe6e6;color:#8a2b2b}.flash.ok{background:#e3f0e0;color:#2f5d2a}
.hamburger{display:none}
@media(max-width:900px){
  .welcome,.roomgrid,.nearby ul,.bloggrid,footer.site .cols,.inn .split,.detailgrid,.gallery{grid-template-columns:1fr}
  header.site .wrap{height:68px}
  .hamburger{display:flex;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;cursor:pointer;margin-left:auto}
  .hamburger span{display:block;height:2px;width:24px;background:var(--ink);border-radius:2px;transition:.2s}
  nav.main{position:absolute;top:68px;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;
    background:var(--paper);border-bottom:1px solid var(--line);box-shadow:0 12px 24px rgba(21,50,62,.1);
    max-height:0;overflow:hidden;transition:max-height .28s ease;padding:0}
  .navtoggle:checked ~ nav.main{max-height:420px;padding:8px 0 14px}
  nav.main a{padding:13px 24px;font-size:1.05rem}
  nav.main a.btn{margin:10px 24px 0;text-align:center;justify-content:center}
  .navtoggle:checked ~ .hamburger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .navtoggle:checked ~ .hamburger span:nth-child(2){opacity:0}
  .navtoggle:checked ~ .hamburger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .roomgrid,.nearby ul,.bloggrid{grid-template-columns:1fr 1fr}
  .bookcard{grid-template-columns:1fr 1fr}.bookcard .btn{grid-column:1/-1}
  .bookbox{position:static}
}
@media(max-width:600px){.roomgrid,.nearby ul,.bloggrid{grid-template-columns:1fr}.bookcard{grid-template-columns:1fr}}
/* admin */
.adminwrap{display:flex;min-height:100vh}
.sidebar{width:230px;background:var(--ink);color:#cfe0e1;padding:24px 0;flex:none}
.sidebar .brand{padding:0 24px 20px;font-family:'Newsreader',serif;font-size:1.3rem;color:#fff;border-bottom:1px solid #224a56;margin-bottom:14px}
.sidebar a{display:block;padding:11px 24px;color:#bcd2d4;font-size:.95rem}
.sidebar a:hover,.sidebar a.active{background:#1d4452;color:#fff}
.admin-main{flex:1;padding:30px 36px;background:var(--paper);max-width:100%;overflow:auto}
.admin-main h1{font-size:1.8rem;margin-bottom:20px}
.card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px;margin-bottom:22px}
table.data{width:100%;border-collapse:collapse;font-size:.92rem}
table.data th,table.data td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--line)}
table.data th{font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.badge{font-size:.72rem;padding:3px 9px;border-radius:999px;font-weight:600}
.badge.pending{background:#fbf0d8;color:#8a6d1f}.badge.confirmed{background:#e0efe0;color:#2f6b2f}.badge.cancelled{background:#eee;color:#888}
.badge.paid{background:#e0efe0;color:#2f6b2f}.badge.unpaid{background:#f3e7e7;color:#9a4a4a}
.toggle-row{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:18px 0;border-bottom:1px solid var(--line)}
.switch{position:relative;display:inline-block;width:54px;height:30px;flex:none}
.switch input{display:none}
.track{position:absolute;inset:0;background:#c2c8ca;border-radius:999px;transition:.2s;cursor:pointer}
.track::after{content:"";position:absolute;top:3px;left:3px;width:24px;height:24px;background:#fff;border-radius:50%;transition:.2s}
.switch input:checked+.track{background:var(--sage-deep)}
.switch input:checked+.track::after{transform:translateX(24px)}
.thumbs{display:flex;flex-wrap:wrap;gap:12px;margin-top:12px}
.thumb{position:relative;width:130px}
.thumb img{width:130px;height:90px;object-fit:cover;border-radius:8px;border:1px solid var(--line)}
.thumb .del{position:absolute;top:4px;right:4px;background:rgba(0,0,0,.65);color:#fff;border:none;width:24px;height:24px;border-radius:50%;cursor:pointer;font-size:.8rem}
.thumb.cover::after{content:"Cover";position:absolute;left:4px;bottom:4px;background:var(--sage-deep);color:#fff;font-size:.64rem;padding:2px 7px;border-radius:6px}
.btn.sm{padding:.45em 1em;font-size:.85rem}
.btn.danger{background:#9a3b3b}.btn.danger:hover{background:#7e2e2e}
.muted{color:var(--muted);font-size:.9rem}
.row{display:flex;gap:14px;flex-wrap:wrap;align-items:end}
.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--ink)}
.login-card{background:#fff;border-radius:16px;padding:36px;width:360px;max-width:92vw}

/* ---- Things to do / attraction pages ------------------------------------- */
.lede{font-size:1.18rem;line-height:1.6;color:var(--text);max-width:70ch;margin:0 0 1.4em}
.attr-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;margin:24px 0 8px}
.attr-grid.small{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}
.attr-card{display:block;background:#fff;border:1px solid var(--line);border-radius:16px;padding:22px 22px 18px;
  text-decoration:none;color:var(--ink);transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}
.attr-card:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(21,50,62,.12);border-color:var(--duck)}
.attr-cat{display:inline-block;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--sage-deep);
  font-weight:700;margin-bottom:8px}
.attr-card h3{font-family:'Newsreader',serif;font-size:1.4rem;margin:.1em 0 .35em;line-height:1.15}
.attr-card p{color:var(--muted);font-size:.96rem;line-height:1.55;margin:0 0 14px}
.attr-dist{display:inline-block;font-size:.82rem;color:var(--text);font-weight:600}
.attr-more{display:block;margin-top:10px;color:var(--duck);font-weight:700;font-size:.9rem}

/* attraction article */
.attr{max-width:74ch;margin:8px 0 36px}
.attr-head{margin-bottom:10px}
.attr-head h1{font-size:clamp(2rem,4.5vw,3rem);line-height:1.08;margin:.15em 0 0}
.attr h2{font-family:'Newsreader',serif;font-size:1.5rem;margin:1.5em 0 .4em;color:var(--ink)}
.attr p{font-size:1.05rem;line-height:1.7;color:var(--text)}
.ticks{list-style:none;padding:0;margin:.5em 0 0;display:grid;gap:10px}
.ticks li{position:relative;padding-left:30px;font-size:1.04rem;line-height:1.5}
.ticks li::before{content:"";position:absolute;left:0;top:.16em;width:18px;height:18px;border-radius:50%;
  background:var(--sage);box-shadow:inset 0 0 0 2px #fff, inset 0 0 0 3px var(--sage)}
.ticks li::after{content:"✓";position:absolute;left:3px;top:-.02em;color:#fff;font-size:.78rem;font-weight:800}
.ext{margin:1.6em 0 0;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.ext-note{font-size:.85rem;color:var(--muted)}

/* CTA band */
.cta-band{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;
  background:linear-gradient(180deg,var(--duck-soft),var(--paper));border:1px solid var(--line);
  border-radius:20px;padding:28px 32px;margin:34px 0}
.cta-band h2{font-family:'Newsreader',serif;font-size:1.6rem;margin:0 0 .2em;color:var(--ink)}
.cta-band p{margin:0;color:var(--muted)}
.more-h{font-family:'Newsreader',serif;font-size:1.5rem;margin:.4em 0 .2em}

/* site notice banner */
.noticebar{background:var(--plum);color:#fff;text-align:center;padding:10px 16px;font-size:.92rem;
  display:flex;gap:14px;align-items:center;justify-content:center;flex-wrap:wrap;line-height:1.4}
.noticebar .noticecall{background:#fff;color:var(--plum);font-weight:700;padding:4px 12px;border-radius:999px;white-space:nowrap}
@media(max-width:600px){.noticebar{font-size:.86rem;padding:9px 12px}}

/* room photo ribbon (e.g. "Ground floor") */
.room .ph .roomribbon, .card .ph .roomribbon{position:absolute;top:12px;left:0;background:var(--sage-deep);color:#fff;
  font-size:.74rem;font-weight:700;letter-spacing:.03em;padding:5px 12px 5px 14px;border-radius:0 999px 999px 0;
  box-shadow:0 2px 6px rgba(21,50,62,.25);z-index:2}

/* notice modal popup (unmissable, centred) */
.noticemodal{position:fixed;inset:0;z-index:9999;display:none;align-items:center;justify-content:center;
  background:rgba(15,32,40,.72);backdrop-filter:blur(3px);padding:20px}
.noticemodal.show{display:flex;animation:noticefade .25s ease}
@keyframes noticefade{from{opacity:0}to{opacity:1}}
.noticemodal-card{background:#fff;border-radius:18px;max-width:440px;width:100%;padding:34px 28px;text-align:center;
  box-shadow:0 20px 60px rgba(0,0,0,.4);animation:noticepop .28s cubic-bezier(.2,.9,.3,1.3)}
@keyframes noticepop{from{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}
.noticemodal-icon{font-size:2.6rem;margin-bottom:10px}
.noticemodal-text{font-size:1.18rem;line-height:1.5;color:var(--ink);font-weight:500;margin-bottom:22px}
.noticemodal-call{display:inline-flex;width:100%;justify-content:center;margin-bottom:12px;font-size:1.05rem;padding:14px}
.noticemodal-close{background:none;border:none;color:var(--muted);font:inherit;font-size:.92rem;cursor:pointer;
  text-decoration:underline;padding:6px}
