/* Dog Friendly Hotel Association — stylesheet v4 */
/* Art direction: heritage register meets travel editorial. Deep navy authority, warm paper grounds,
   full-bleed photography, Fraunces display, Inter UI. Accent is the badge BLUE; gold lives only on the seal. */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;0,9..144,600;1,9..144,400;1,9..144,500&family=Inter:wght@400;500;600;700&display=swap');

:root{
  --navy:#172a4a; --navy-2:#172a4a; --blue:#172a4a; --blue-dark:#172a4a; --blue-soft:#86a9df;
  --paper:#f6f2ea; --paper-2:#efe8da; --white:#fff;
  --ink:#1c1e23; --muted:#6f6c66; --muted-light:#a9a399;
  --line:#e4dccd; --line-dark:rgba(255,255,255,.16);
  --maxw:1200px; --narrow:760px;
  --serif:"Fraunces",Georgia,serif; --sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --sh:0 18px 50px rgba(16,42,76,.13);
}
*{box-sizing:border-box}
html{}
body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--paper);line-height:1.7;font-size:17px;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
h1,h2,h3,.serif{font-family:var(--serif);font-weight:500;line-height:1.08;letter-spacing:-.015em;color:var(--ink)}
a{color:var(--blue);text-decoration:none}
a:hover{color:var(--blue-dark)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 40px}
.wrap-narrow{max-width:var(--narrow);margin:0 auto;padding:0 40px}
.center{text-align:center}
.eyebrow{font-family:var(--sans);text-transform:uppercase;letter-spacing:3px;font-size:12px;font-weight:600;color:var(--blue);margin:0 0 20px}
.eyebrow.on-dark{color:var(--blue-soft)}
.lead{font-family:var(--serif);font-size:23px;line-height:1.5;font-weight:400;color:#3a3f48;letter-spacing:-.01em}
.accent{font-style:italic;color:var(--blue)}
.rule{height:1px;background:var(--line);border:0;margin:0}
.muted{color:var(--muted)}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--sans);font-size:14px;font-weight:600;letter-spacing:.02em;
  padding:14px 28px;border-radius:2px;border:1.5px solid transparent;cursor:pointer;transition:all .18s ease}
.btn .ar{transition:transform .18s ease}.btn:hover .ar{transform:translateX(3px)}
.btn-primary{background:var(--navy);color:#fff}.btn-primary:hover{background:var(--navy);filter:brightness(1.18);color:#fff}
.btn-dark{background:var(--navy);color:#fff}.btn-dark:hover{background:var(--navy-2);color:#fff}
.btn-line{border-color:var(--ink);color:var(--ink)}.btn-line:hover{background:var(--ink);color:#fff}
.btn-light{border-color:rgba(255,255,255,.55);color:#fff}.btn-light:hover{background:#fff;color:var(--navy)}
.btn+.btn{margin-left:12px}

/* Header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(246,242,234,.86);backdrop-filter:saturate(1.1) blur(10px);border-bottom:1px solid var(--line)}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;padding:16px 40px}
.brand{display:flex;align-items:center}
.brand img.nav-logo{height:58px;width:auto}
nav.main{display:flex;align-items:center;gap:30px}
nav.main a{color:#33404f;font-size:14px;font-weight:500;letter-spacing:.01em}
nav.main a:hover{color:var(--navy)}
nav.main a.nav-cta{border:1.5px solid var(--navy);color:var(--navy);padding:9px 20px;border-radius:2px;font-weight:600;transition:all .2s}
nav.main a.nav-cta:hover{background:var(--navy);color:#fff}
.menu-toggle{display:none}

/* Sections / bands */
.band{padding:104px 0}
.band--sm{padding:76px 0}
.band--paper{background:var(--paper)}
.band--paper2{background:var(--paper-2)}
.band--white{background:var(--white)}
.band--navy{background:var(--navy);color:#e7e3da}
.band--navy h1,.band--navy h2,.band--navy h3{color:#fff}
.band--navy .lead{color:#c7d2e2}
h1.display{font-size:60px;letter-spacing:-.025em;margin:0 0 26px}
h2.title{font-size:44px;margin:0 0 20px}
.section-intro{font-size:20px;color:var(--muted);max-width:620px;margin:0 0 36px;text-wrap:balance}
.band--navy .section-intro{color:#b7c2d4}

/* Crest lockup */
.crest{display:inline-flex;flex-direction:column;align-items:center;gap:14px}
.crest img{width:88px;height:88px;border-radius:50%}
.crest .est{font-family:var(--sans);text-transform:uppercase;letter-spacing:3px;font-size:11px;font-weight:600;color:var(--blue-soft)}

/* ===== Hero (home) ===== */
.hero-full{position:relative;min-height:88vh;display:flex;align-items:flex-end;color:#fff;overflow:hidden}
.hero-full .bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.03)}
.hero-full .scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,29,56,.34) 0%,rgba(10,29,56,.28) 38%,rgba(10,29,56,.82) 100%)}
.hero-full .inner{position:relative;width:100%;max-width:var(--maxw);margin:0 auto;padding:0 40px 92px}
.hero-full .seal{width:74px;height:74px;border-radius:50%;margin-bottom:26px;box-shadow:0 8px 26px rgba(0,0,0,.3)}
.hero-full .eyebrow{color:#cfe0ff;margin-bottom:18px}
.hero-full h1{font-size:68px;line-height:1.04;font-weight:500;margin:0 0 24px;letter-spacing:-.025em;max-width:15ch;text-shadow:0 2px 30px rgba(0,0,0,.25)}
.hero-full p.k{font-size:20px;color:#e7ecf5;max-width:46ch;margin:0 0 32px;line-height:1.6}
.hero-full .cta-row{display:flex;flex-wrap:wrap;gap:12px}

/* ===== Statement / manifesto ===== */
.statement{font-family:var(--serif);font-size:40px;line-height:1.25;font-weight:400;letter-spacing:-.02em;max-width:18ch;margin:0}
.statement .accent{color:var(--blue)}
.split{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.split.tilt{grid-template-columns:5fr 6fr}

/* Charter seven (numbered registry list) */
.charter-list{list-style:none;counter-reset:c;margin:0;padding:0}
.charter-list li{position:relative;counter-increment:c;padding:22px 0 22px 64px;border-top:1px solid var(--line)}
.charter-list li:last-child{border-bottom:1px solid var(--line)}
.charter-list li:before{content:counter(c,decimal-leading-zero);position:absolute;left:0;top:22px;font-family:var(--serif);font-size:15px;font-weight:600;color:var(--blue);letter-spacing:.05em}
.band--navy .charter-list li{border-color:var(--line-dark)}
.charter-list strong{font-weight:600}
.charter-list p{margin:6px 0 0;color:var(--muted);font-size:15.5px}
.band--navy .charter-list p{color:#9fb0c8}

/* ===== Member cards (register + featured) ===== */
.member-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.member-card{display:block;background:#fff;border:1px solid var(--line);border-radius:6px;overflow:hidden;color:inherit;transition:transform .2s ease,box-shadow .2s ease}
.member-card:hover{transform:translateY(-4px);box-shadow:var(--sh)}
.member-card .ph{aspect-ratio:4/3;background-size:cover;background-position:center;position:relative}
.member-card .ph .seal{position:absolute;top:14px;right:14px;width:36px;height:36px;border-radius:50%;box-shadow:0 4px 14px rgba(0,0,0,.3)}
.member-card .body{padding:22px 24px 26px}
.member-card .m-name{font-family:var(--serif);font-size:21px;line-height:1.2;margin:0 0 6px;color:var(--ink)}
.member-card .m-loc{font-size:13.5px;color:var(--muted);letter-spacing:.02em;margin:0 0 16px;text-transform:uppercase;letter-spacing:.12em;font-weight:500}
.member-card .m-tag{display:inline-flex;align-items:center;gap:7px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.14em;color:var(--blue)}
.member-card .m-tag:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--blue)}

/* ===== Register tools ===== */
.reg-controls{display:flex;flex-wrap:wrap;gap:16px;align-items:center;justify-content:space-between;margin-bottom:18px}
.reg-filters{display:flex;flex-wrap:wrap;gap:9px}
.reg-chip{font-family:var(--sans);font-size:13.5px;font-weight:500;color:#33404f;background:#fff;border:1px solid var(--line);padding:9px 18px;border-radius:40px;cursor:pointer;transition:all .15s}
.reg-chip:hover{border-color:var(--blue-soft);color:var(--navy)}
.reg-chip.is-active{background:var(--navy);border-color:var(--navy);color:#fff}
.reg-search{font-family:var(--sans);font-size:15px;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:40px;padding:11px 20px;min-width:230px;flex:0 1 270px}
.reg-search:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(28,78,162,.12)}
.reg-count{color:var(--muted);font-size:13px;letter-spacing:.14em;text-transform:uppercase;font-weight:500;margin:0 0 30px}
.reg-empty{color:var(--muted);font-size:17px;padding:40px 0}

/* ===== Registry stat band ===== */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;text-align:center}
.stat .num{font-family:var(--serif);font-size:58px;line-height:1;color:#fff;font-weight:500}
.stat .label{display:block;margin-top:12px;font-size:12px;text-transform:uppercase;letter-spacing:.18em;color:var(--blue-soft);font-weight:600}

/* ===== Hotel page ===== */
.hotel-hero{position:relative;min-height:74vh;display:flex;align-items:flex-end;color:#fff;overflow:hidden}
.hotel-hero .bg{position:absolute;inset:0;background-size:cover;background-position:center}
.hotel-hero .scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,29,56,.15) 0%,rgba(10,29,56,.2) 40%,rgba(10,29,56,.86) 100%)}
.hotel-hero .inner{position:relative;width:100%;max-width:var(--maxw);margin:0 auto;padding:0 40px 70px}
.hotel-hero .seal{width:64px;height:64px;border-radius:50%;margin-bottom:20px;box-shadow:0 8px 24px rgba(0,0,0,.3)}
.hotel-hero .refno{font-family:var(--sans);text-transform:uppercase;letter-spacing:.2em;font-size:12px;font-weight:600;color:#cfe0ff;margin:0 0 12px}
.hotel-hero h1{font-size:56px;line-height:1.02;margin:0 0 14px;letter-spacing:-.02em;max-width:16ch}
.hotel-hero .loc{font-size:17px;color:#dbe3f0;letter-spacing:.04em;margin:0}
.photo-credit{position:absolute;right:14px;bottom:10px;font-size:10.5px;color:rgba(255,255,255,.6);letter-spacing:.04em;z-index:2}

.hotel-body{display:grid;grid-template-columns:1.55fr .95fr;gap:64px;align-items:start}
.hotel-intro p{font-family:var(--serif);font-size:22px;line-height:1.55;color:#33383f;font-weight:400;margin:0 0 22px}
.hotel-intro p.small{font-family:var(--sans);font-size:16px;color:var(--muted);line-height:1.7}
.visit-panel{background:#fff;border:1px solid var(--line);border-radius:8px;padding:30px;position:sticky;top:96px}
.visit-panel h3{font-size:13px;text-transform:uppercase;letter-spacing:.16em;color:var(--blue);font-family:var(--sans);font-weight:600;margin:0 0 18px}
.visit-panel dl{margin:0 0 22px}
.visit-panel dt{font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted-light);font-weight:600;margin-top:14px}
.visit-panel dd{margin:3px 0 0;font-size:16px;color:var(--ink);font-weight:500}
.visit-panel .btn{width:100%;justify-content:center;margin-top:6px}

/* Charter scorecard */
.scorecard{margin-top:8px}
.scorecard .sc-head{display:flex;align-items:center;gap:14px;margin-bottom:8px}
.scorecard .sc-head img{width:40px;height:40px;border-radius:50%}
.scorecard .sc-head .h{font-family:var(--serif);font-size:26px}
.scorecard .sc-sub{color:var(--muted);font-size:15px;margin:0 0 26px}
.sc-list{list-style:none;margin:0;padding:0}
.sc-list li{position:relative;padding:18px 0 18px 44px;border-top:1px solid var(--line);font-size:16px;line-height:1.5;color:#2c3038}
.sc-list li:last-child{border-bottom:1px solid var(--line)}
.sc-list li:before{content:"";position:absolute;left:0;top:19px;width:26px;height:26px;border-radius:50%;background:var(--blue);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E");background-size:15px;background-repeat:no-repeat;background-position:center}
.sc-list li strong{font-weight:600;color:var(--ink)}

.member-nav{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap}
.member-nav a{font-size:14px;font-weight:600;letter-spacing:.02em}

/* ===== Footer ===== */
.site-footer{background:var(--blue);color:#cdd9f0;padding:88px 0 40px;font-size:15px}
.site-footer .cols{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:44px}
.site-footer .brandcol img{height:54px;margin-bottom:18px}
.site-footer .brandcol p{max-width:34ch;color:#c6d3ee;margin:0}
.site-footer h4{color:#fff;font-family:var(--serif);font-weight:500;font-size:16px;margin:0 0 14px}
.site-footer a{color:#e0e8f8}.site-footer a:hover{color:#fff}
.site-footer .fnav a{display:block;padding:5px 0;font-size:14.5px}
.site-footer .base{margin-top:54px;padding-top:24px;border-top:1px solid var(--line-dark);display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;color:#b4c2e1;font-size:13px}
.site-footer .gov{max-width:60ch;color:#b4c2e1;font-size:13px;margin:18px 0 0;line-height:1.6}

/* ===== CTA band ===== */
.cta-band{background:var(--navy);color:#fff;text-align:center;padding:100px 0}
.cta-band h2{color:#fff;font-size:46px;margin:0 0 16px}
.cta-band p{color:#bccbe2;font-size:20px;max-width:560px;margin:0 auto 32px;text-wrap:pretty}

/* Callout */
.callout{border:1px solid var(--line);border-left:4px solid var(--blue);background:#fff;padding:26px 30px;border-radius:6px;font-size:17px}
ul.ticks{list-style:none;padding:0;margin:0}
ul.ticks li{position:relative;padding:10px 0 10px 32px;color:#2c3038}
ul.ticks li:before{content:"";position:absolute;left:0;top:15px;width:18px;height:18px;border-radius:50%;background:var(--blue) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E") center/11px no-repeat}

/* Responsive */
@media (max-width:960px){
  nav.main{gap:20px}
  .split,.hotel-body,.site-footer .cols{grid-template-columns:1fr;gap:40px}
  .member-grid,.stats{grid-template-columns:1fr 1fr}
  h1.display{font-size:46px}.hero-full h1{font-size:48px}.hotel-hero h1{font-size:42px}
  h2.title{font-size:34px}.statement{font-size:30px}
  .visit-panel{position:static}
}
@media (max-width:640px){
  .wrap,.wrap-narrow,.site-header .wrap,.hero-full .inner,.hotel-hero .inner{padding-left:22px;padding-right:22px}
  nav.main{display:none}
  .member-grid,.stats{grid-template-columns:1fr}
  .reg-controls{flex-direction:column;align-items:stretch}
  .hero-full h1{font-size:38px}.band{padding:68px 0}
}

/* ===== Application form (apply.html) ===== */
.form-shell{max-width:820px}
#apply-form{margin-top:8px}
.form-block+.form-block{margin-top:44px}
.block-title{font-family:var(--sans);font-size:13px;text-transform:uppercase;letter-spacing:2.4px;font-weight:600;color:var(--blue);margin:0 0 22px;padding-bottom:12px;border-bottom:1px solid var(--line)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px 24px}
.field{display:flex;flex-direction:column;min-width:0}
.field--full{grid-column:1/-1}
.field label{font-size:14px;font-weight:600;color:var(--ink);margin-bottom:8px}
.field .opt{color:var(--muted);font-weight:500}
.field input,.field select{font-family:var(--sans);font-size:16px;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:4px;padding:13px 14px;width:100%;transition:border-color .15s,box-shadow .15s}
.field input::placeholder{color:#b7afa4}
.field input:focus,.field select:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(28,78,162,.12)}
.field .err{color:#b5453c;font-size:13px;margin-top:6px}
.field.has-error input,.field.has-error select{border-color:#b5453c}
.charter{border:1px solid var(--line);border-left:5px solid var(--blue);background:#fff;border-radius:6px;padding:28px 32px}
.charter h3{font-size:22px;margin:0 0 10px}
.charter p.intro{color:var(--muted);font-size:16px;margin:0}
.charter ol{margin:20px 0 0;padding:0;list-style:none;counter-reset:c}
.charter li{position:relative;padding:13px 0 13px 44px;border-top:1px solid var(--line);color:#3a352f;font-size:16px;line-height:1.55}
.charter li:before{counter-increment:c;content:counter(c);position:absolute;left:0;top:13px;width:26px;height:26px;line-height:26px;text-align:center;font-family:var(--serif);font-size:13px;font-weight:600;color:#fff;background:var(--blue);border-radius:50%}
.charter .align-note{color:var(--muted);font-size:12.5px;margin:20px 0 0}
.check-stack .field+.field{margin-top:18px}
.check{display:flex;gap:13px;align-items:flex-start}
.check input[type=checkbox]{flex:0 0 auto;width:19px;height:19px;margin:3px 0 0;accent-color:var(--blue);cursor:pointer}
.check label{font-size:15px;font-weight:500;color:#3a352f;margin:0;line-height:1.55}
.fee-row{display:flex;align-items:baseline;justify-content:space-between;gap:18px;border-top:1px solid var(--line);padding-top:24px}
.fee-row .fee-label{font-size:15px;color:var(--ink);font-weight:600}
.fee-row .price{font-family:var(--serif);font-size:30px;color:var(--ink)}
.fee-row .price span{font-size:14px;color:var(--muted);font-family:var(--sans);font-weight:400}
.fee-note{color:var(--muted);font-size:14px;margin:12px 0 0}
.btn-submit{display:inline-flex;align-items:center;gap:10px;margin-top:26px;background:var(--navy);color:#fff;border:0;cursor:pointer;padding:15px 32px;border-radius:2px;font-family:var(--sans);font-size:15px;font-weight:600;letter-spacing:.3px;transition:filter .18s}
.btn-submit:hover{background:var(--navy);filter:brightness(1.18)}
.form-status{margin-top:16px;font-size:15px;color:var(--muted)}
.form-status.bad{color:#b5453c}
@media (max-width:720px){.form-grid{grid-template-columns:1fr}}

/* Generic card row + helpers (interior pages) */
.cardrow{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.card{background:#fff;border:1px solid var(--line);border-radius:8px;padding:32px 28px}
.card h3{font-size:20px;margin:0 0 10px}
.card p{color:var(--muted);font-size:15.5px;margin:0;line-height:1.6}
.mt{margin-top:28px}
.contact-card{background:#fff;border:1px solid var(--line);border-radius:8px;padding:38px 34px}
.contact-card+.contact-card{margin-top:22px}
.contact-card h3{font-size:21px;margin:0 0 10px}
.contact-card a{font-weight:600}
@media(max-width:960px){.cardrow{grid-template-columns:1fr}}

/* ===== Approved hero system (home rotating + hotel single) ===== */
.hero{position:relative;min-height:88vh;display:flex;align-items:flex-end;color:#fff;overflow:hidden;background:#172a4a}
.hero .bgs{position:absolute;inset:0}
.hero .slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.2s ease}
.hero .slide.on{opacity:1}
.hero .scrim,.hotel-hero .scrim{position:absolute;inset:0;background:linear-gradient(0deg,rgba(8,20,38,.88) 0%,rgba(8,20,38,.66) 24%,rgba(8,20,38,.30) 44%,rgba(8,20,38,.06) 60%,rgba(8,20,38,0) 74%)}
.hero .inner{position:relative;max-width:var(--maxw);margin:0 auto;width:100%;padding:0 40px 86px}
.hero .eyebrow{color:#dbe7fb;margin-bottom:18px}
.hero h1{color:#fff;font-size:64px;line-height:1.05;margin:0 0 22px;letter-spacing:-.025em;max-width:15ch;text-shadow:0 2px 26px rgba(0,0,0,.5)}
.hero h1 .accent{color:#fff;font-style:italic}
.hero p.k{font-size:20px;color:#f0f4fa;max-width:46ch;margin:0 0 30px;line-height:1.6;text-shadow:0 1px 14px rgba(0,0,0,.5)}
.hero-cap{position:absolute;right:34px;bottom:22px;z-index:3;font:500 13px/1 var(--sans);color:rgba(255,255,255,.85);letter-spacing:.03em;text-shadow:0 1px 12px rgba(0,0,0,.7)}
.hero-cap b{font-weight:600;color:#fff}
/* hotel hero: white headline (fixes the dark-text bug), no stuck-on seal */
.hotel-hero h1{color:#fff}
.hotel-hero .seal{display:none}
.hotel-hero .inner{padding-bottom:64px}
@media(max-width:640px){.hero h1{font-size:38px}.hero .inner,.hotel-hero .inner{padding-left:22px;padding-right:22px}}

/* ===== Footer lockup (seal + wordmark) ===== */
.site-footer .foot-lock{display:flex;align-items:center;gap:13px;margin-bottom:16px}
.site-footer .foot-lock img{height:46px;width:46px;border-radius:50%;margin:0;flex:0 0 auto}
.site-footer .foot-lock .wm{font-family:var(--serif);color:#fff;font-size:18px;line-height:1.12;font-weight:500;letter-spacing:-.01em}

/* ===== Manifesto (centered editorial statement) ===== */
.manifesto{font-family:var(--serif);font-size:50px;line-height:1.12;font-weight:400;letter-spacing:-.02em;margin:0 0 26px;color:var(--ink);white-space:nowrap}
.manifesto .accent{color:var(--blue);font-style:italic}
.mf-wrap{max-width:1020px}
@media(max-width:640px){.manifesto{font-size:32px;white-space:normal}.mf-wrap{max-width:100%}}

/* ===== Footer (rebalanced) ===== */
.site-footer{background:var(--blue);color:#cdd9f0;padding:72px 0 30px;font-size:15px}
.site-footer .ftop{display:flex;justify-content:space-between;gap:56px;flex-wrap:wrap;padding-bottom:40px;border-bottom:1px solid var(--line-dark)}
.site-footer .fbrand{max-width:440px}
.site-footer .foot-lock{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.site-footer .foot-lock img{height:66px;width:auto;border-radius:0;margin:0;flex:0 0 auto}
.site-footer .foot-lock .wm{font-family:var(--serif);color:#fff;font-size:21px;line-height:1.12;font-weight:600;white-space:nowrap}
.site-footer .ftag{color:#c6d3ee;margin:0;font-size:14.5px;line-height:1.65;text-wrap:balance}
.site-footer .fcols{display:flex;gap:60px}
.site-footer h4{color:#fff;font-family:var(--serif);font-weight:500;font-size:15px;margin:0 0 13px}
.site-footer .fnav a{display:block;padding:5px 0;font-size:14.5px;color:#e0e8f8}
.site-footer .fnav a:hover{color:#fff}
.site-footer .fbase{display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;align-items:baseline;padding-top:22px;color:#b4c2e1;font-size:13px}
.site-footer .fgov{color:#b4c2e1;max-width:48ch;text-align:right}
@media(max-width:760px){.site-footer .ftop{flex-direction:column;gap:34px}.site-footer .fcols{gap:48px}.site-footer .fbase{flex-direction:column;gap:8px}.site-footer .fgov{text-align:left}}

.seal-hero{width:124px;height:124px;margin:0 auto 26px;display:block}
@media(max-width:640px){.seal-hero{width:96px;height:96px}}

.seal-split{align-items:center;grid-template-columns:1.32fr .68fr}
.seal-show{text-align:center}
.seal-show img{width:360px;height:360px;max-width:100%;margin:0 auto}
@media(max-width:760px){.seal-show img{width:220px;height:220px}}

/* Charter requirement boxes */
.req-head{max-width:780px;margin:0 0 46px}
.req-head .section-intro{margin-bottom:26px;max-width:680px}
.req-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.req-card{background:rgba(255,255,255,.045);border:1px solid var(--line-dark);border-radius:12px;padding:28px 26px}
.req-card .req-num{font-family:var(--serif);font-size:13px;font-weight:600;color:var(--blue-soft);letter-spacing:.1em}
.req-card h3{color:#fff;font-family:var(--serif);font-size:19px;font-weight:500;margin:13px 0 9px;line-height:1.22}
.req-card p{color:#bcc8dc;font-size:15px;margin:0;line-height:1.6;font-weight:500;text-wrap:pretty
@media(max-width:980px){.req-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.req-grid{grid-template-columns:1fr}.req-head{margin-bottom:32px}}

.nowrap-lg{white-space:nowrap}
@media(max-width:1140px){.nowrap-lg{white-space:normal}}

/* ===== Benefits page ===== */
.req-grid.cols-2{grid-template-columns:repeat(2,1fr)}
@media(max-width:760px){.req-grid.cols-2{grid-template-columns:1fr}}
.review-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:28px 30px;box-shadow:var(--sh)}
.review-card .rc-top{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.review-card .rc-top img{width:42px;height:42px}
.review-card .rc-badge{font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--blue)}
.review-card h4{font-family:var(--serif);font-size:22px;margin:0 0 10px;color:var(--ink)}
.review-card p{margin:0;color:#3a3f48;font-size:15.5px;line-height:1.62}
.review-card .rc-meta{margin-top:18px;padding-top:16px;border-top:1px solid var(--line);font-size:12.5px;color:var(--muted);letter-spacing:.03em;text-transform:uppercase;font-weight:600}
.lang-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px}
.lang-chips span{font-size:12px;font-weight:600;letter-spacing:.06em;color:var(--blue-dark);background:#eef2f9;border:1px solid #dde6f4;border-radius:999px;padding:5px 11px}

/* ===== Legal / prose pages ===== */
.prose{max-width:760px}
.prose h2{font-family:var(--serif);font-weight:500;font-size:25px;margin:42px 0 12px;color:var(--ink)}
.prose h2:first-child{margin-top:0}
.prose p{color:#3a3f48;font-size:17px;line-height:1.72;margin:0 0 16px;text-wrap:balance}
.prose ul{margin:0 0 16px;padding-left:20px;color:#3a3f48;font-size:17px;line-height:1.72}
.prose li{margin:7px 0}
.prose .upd{color:var(--muted);font-size:14px;letter-spacing:.02em}

/* ===== Constitution articles ===== */
.article{padding:20px 0}
.article:first-child{padding-top:0}
.article .art-num{font-family:var(--serif);font-size:14px;font-weight:600;color:var(--blue);letter-spacing:.08em}
.article h3{font-family:var(--serif);font-weight:500;font-size:22px;margin:6px 0 10px;color:var(--ink)}
.article p{margin:0;color:#363a42;font-size:16.5px;line-height:1.72;font-weight:500;text-wrap:pretty}

/* ===== Ombudsman report box ===== */
.report-box{background:var(--navy);color:#fff;border-radius:16px;padding:46px 40px;text-align:center}
.report-box h3{color:#fff;font-family:var(--serif);font-weight:500;font-size:27px;margin:0 0 12px}
.report-box p{color:#c7d2e2;margin:0 auto 24px;max-width:540px}
.report-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* Ombudsman: four-up row */
.req-grid.cols-4{grid-template-columns:repeat(4,1fr);gap:18px}
@media(max-width:1000px){.req-grid.cols-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.req-grid.cols-4{grid-template-columns:1fr}}

/* ===== Report form ===== */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:22px}
.form-grid .field--full{grid-column:1/-1}
@media(max-width:560px){.form-grid{grid-template-columns:1fr}}
.field textarea{font-family:var(--sans);font-size:16px;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:4px;padding:13px 14px;width:100%;min-height:300px;resize:vertical;transition:border-color .15s,box-shadow .15s}
.field textarea::placeholder{color:#b7afa4}
.field textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(28,78,162,.12)}
.field.has-error textarea{border-color:#b5453c}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-status.ok{color:var(--blue-dark);font-weight:600}

/* ===== Hotel pager (prev / all / next) ===== */
.hp-pager{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:28px;border-top:1px solid var(--line);padding-top:30px}
.hp-pager a{text-decoration:none}
.hp-prev{justify-self:start;text-align:left}
.hp-next{justify-self:end;text-align:right}
.hp-prev,.hp-next{display:flex;flex-direction:column;gap:5px;max-width:46%}
.hp-dir{font-size:11.5px;text-transform:uppercase;letter-spacing:.14em;font-weight:600;color:var(--muted-light)}
.hp-name{font-family:var(--serif);font-size:20px;line-height:1.15;color:var(--ink);transition:color .15s}
.hp-prev:hover .hp-name,.hp-next:hover .hp-name{color:var(--blue)}
.hp-all{justify-self:center;font-size:12.5px;text-transform:uppercase;letter-spacing:.14em;font-weight:600;color:var(--blue);white-space:nowrap}
.hp-all:hover{color:var(--blue-dark)}
@media(max-width:600px){.hp-pager{grid-template-columns:1fr;text-align:center;gap:20px}.hp-prev,.hp-next{justify-self:center;text-align:center;max-width:none;align-items:center}}

.fsocial{display:flex;gap:15px;margin-top:20px}.fsocial a{color:#b4c2e1;display:inline-flex;transition:color .2s}.fsocial a:hover{color:#fff}.fsocial svg{width:17px;height:17px;display:block}

.navsoc a{transition:transform .15s ease}.navsoc a:hover{transform:scale(1.2)}

.band--navy .accent,.cta-band .accent{color:#fff}
