:root{
  --bg:#F5F0E8; --bg-light:#FDFAF4; --ink:#1C1917; --text:#2C2519;
  --accent:#C84B31; --blue:#1B6CA8; --gold:#D4A843; --subtle:#8C7B6B;
  --line:rgba(28,25,23,.12);
  --font-display:'Playfair Display',Georgia,serif;
  --font-body:'DM Sans',-apple-system,system-ui,sans-serif;
  --shadow:0 8px 30px -10px rgba(28,25,23,.18);
  --radius:14px;
}
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;color:var(--ink);line-height:1.15;margin:0 0 .5em}
h1{font-size:clamp(2.2rem,5vw,4rem)}
h2{font-size:clamp(1.6rem,3vw,2.4rem)}
.wrap{max-width:1200px;margin:0 auto;padding:0 24px}
.site-main{min-height:60vh}

/* Header */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(245,240,232,.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;min-height:72px;gap:24px}
.brand{display:flex;align-items:baseline;gap:6px;color:var(--ink);font-family:var(--font-display);font-size:1.8rem;font-weight:700}
.brand-mark{color:var(--accent);font-style:italic}
.brand-name{}
.brand-sub{font-family:var(--font-body);font-size:.75rem;text-transform:uppercase;letter-spacing:.15em;color:var(--subtle);margin-left:14px;font-weight:500}
.site-nav{display:flex;gap:28px}
.site-nav a{color:var(--ink);font-weight:500;font-size:.95rem;text-transform:uppercase;letter-spacing:.08em;padding:6px 0;border-bottom:2px solid transparent;text-decoration:none}
.site-nav a.active,.site-nav a:hover{border-bottom-color:var(--accent);color:var(--accent)}

/* Hero */
.hero{
  position:relative;height:min(82vh,780px);overflow:hidden;
  margin:0;background:#1c1917;
}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.15) 0%,rgba(0,0,0,0) 30%,rgba(0,0,0,.65) 100%)}
.hero img{width:100%;height:100%;object-fit:cover;opacity:.95}
.hero-overlay{position:absolute;inset:auto 0 0 0;padding:48px 24px 56px;z-index:2;color:#fff}
.hero-overlay .wrap{}
.live-badge{display:inline-flex;align-items:center;gap:8px;background:var(--accent);color:#fff;padding:8px 16px;border-radius:100px;font-weight:500;font-size:.85rem;text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px}
.live-dot{width:8px;height:8px;border-radius:50%;background:#fff;animation:pulse 1.6s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.85)}}
.hero h1{color:#fff;margin:0;text-shadow:0 2px 30px rgba(0,0,0,.4)}
.hero .meta{margin-top:14px;font-size:1.05rem;color:rgba(255,255,255,.85)}
.hero .meta span+span::before{content:"·";margin:0 12px;opacity:.5}
.hero-empty{display:flex;align-items:center;justify-content:center;height:100%;color:rgba(255,255,255,.6);font-family:var(--font-display);font-style:italic;font-size:1.5rem;text-align:center;padding:24px}

/* Section heading */
.section{padding:80px 0}
.section-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:36px;gap:24px;flex-wrap:wrap}
.section-head h2{margin:0}
.section-head .eyebrow{font-family:var(--font-body);font-size:.78rem;text-transform:uppercase;letter-spacing:.18em;color:var(--accent);font-weight:500;margin-bottom:8px;display:block}
.section-head a{font-size:.9rem;color:var(--subtle);text-transform:uppercase;letter-spacing:.1em}

/* Map strip */
.map-strip{height:340px;background:#dde}
.map-strip #miniMap{width:100%;height:100%}

/* Blog grid */
.blog-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:32px}
.blog-card{background:var(--bg-light);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:transform .25s ease}
.blog-card:hover{transform:translateY(-4px)}
.blog-card .cover{aspect-ratio:16/10;background:#ddd;overflow:hidden}
.blog-card .cover img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.blog-card:hover .cover img{transform:scale(1.05)}
.blog-card .body{padding:24px}
.blog-card .loc{font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);font-weight:500;margin-bottom:8px}
.blog-card h3{font-family:var(--font-display);font-size:1.5rem;margin:0 0 10px;color:var(--ink);line-height:1.2}
.blog-card p{margin:0;color:var(--subtle);font-size:.95rem}
.blog-card a{color:inherit;display:block}
.blog-card.feature{grid-column:span 8}
.blog-card.small{grid-column:span 4}
.blog-card.third{grid-column:span 4}
@media(max-width:900px){.blog-card.feature,.blog-card.small,.blog-card.third{grid-column:span 12}}

/* Foto strip */
.photo-strip{display:flex;gap:14px;overflow-x:auto;padding-bottom:14px;scroll-snap-type:x mandatory}
.photo-strip::-webkit-scrollbar{height:8px}
.photo-strip::-webkit-scrollbar-thumb{background:var(--subtle);border-radius:4px}
.photo-strip a{flex:0 0 280px;aspect-ratio:4/3;border-radius:var(--radius);overflow:hidden;scroll-snap-align:start;box-shadow:var(--shadow)}
.photo-strip img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.photo-strip a:hover img{transform:scale(1.06)}

/* Blog list */
.post-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:36px}
.post-detail{max-width:780px;margin:0 auto;padding:60px 24px}
.post-detail h1{margin-top:24px}
.post-detail .post-meta{color:var(--subtle);font-size:.9rem;text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px}
.post-detail .cover{margin:0 -100px 36px;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.post-detail .cover img{width:100%;height:auto}
.post-detail .post-body{font-size:1.1rem;line-height:1.75}
.post-detail .post-body p{margin:0 0 1.2em}
.post-detail .post-body img{margin:1.5em 0;border-radius:8px}
@media(max-width:980px){.post-detail .cover{margin:0 0 30px}}

/* Photo grid */
.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.photo-grid a{aspect-ratio:1/1;border-radius:10px;overflow:hidden;background:#ddd;display:block}
.photo-grid img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.photo-grid a:hover img{transform:scale(1.08)}

/* Map fullscreen */
.fullmap{height:calc(100vh - 73px)}
#bigMap{width:100%;height:100%}

/* Footer */
.site-footer{margin-top:80px;background:var(--ink);color:rgba(255,255,255,.7);padding:60px 0 0}
.site-footer .wrap{display:grid;grid-template-columns:2fr 1fr 1fr;gap:48px}
.site-footer h4{color:#fff;font-family:var(--font-body);font-size:.85rem;text-transform:uppercase;letter-spacing:.15em;margin:0 0 16px;font-weight:500}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer ul li{margin-bottom:8px}
.site-footer a{color:rgba(255,255,255,.7)}
.site-footer a:hover{color:var(--gold)}
.foot-base{text-align:center;border-top:1px solid rgba(255,255,255,.1);margin-top:48px;padding:24px 0;font-size:.85rem;color:rgba(255,255,255,.4)}
@media(max-width:700px){.site-footer .wrap{grid-template-columns:1fr;gap:32px}}

/* Empty state */
.empty{text-align:center;padding:60px 24px;color:var(--subtle);font-style:italic;font-family:var(--font-display);font-size:1.3rem}

/* Admin */
.admin-shell{max-width:920px;margin:60px auto;padding:0 24px}
.admin-card{background:var(--bg-light);border-radius:var(--radius);padding:36px;box-shadow:var(--shadow)}
.admin-shell input[type=text],.admin-shell input[type=password],.admin-shell input[type=email],.admin-shell textarea,.admin-shell select{
  width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:8px;font:inherit;background:#fff;margin-bottom:14px
}
.admin-shell textarea{min-height:300px;font-family:'SFMono-Regular',Menlo,monospace;font-size:.95rem;line-height:1.6}
.admin-shell label{display:block;font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;color:var(--subtle);margin-bottom:6px;font-weight:500}
.btn{display:inline-block;background:var(--accent);color:#fff;border:none;padding:12px 24px;border-radius:100px;font:inherit;font-weight:500;cursor:pointer;text-transform:uppercase;letter-spacing:.08em;font-size:.85rem}
.btn:hover{background:var(--ink)}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}
.flash{padding:12px 16px;border-radius:8px;margin-bottom:18px;font-size:.95rem}
.flash-ok{background:#e8f1e8;color:#2d5a2d}
.flash-err{background:#f8e6e0;color:#a73a1f}
.adm-table{width:100%;border-collapse:collapse;margin-top:20px}
.adm-table th,.adm-table td{text-align:left;padding:12px 8px;border-bottom:1px solid var(--line);font-size:.95rem}
.adm-table th{font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--subtle)}
.adm-bar{display:flex;gap:14px;justify-content:space-between;align-items:center;margin-bottom:24px}
