:root {
  --forest: #124734;
  --leaf: #2f7d46;
  --trail: #f28c28;
  --sky: #dff3ff;
  --mist: #f5f7f4;
  --ink: #17211d;
  --muted: #61706a;
  --line: #dfe7e1;
  --paper: #ffffff;
  --shadow: 0 18px 45px rgba(18, 71, 52, .12);
}
* { box-sizing: border-box; }
body { margin: 0; background: var(--mist); color: var(--ink); font-family: Inter, ui-sans-serif, system-ui, -apple-system, Segoe UI, sans-serif; }
a { color: inherit; }
.shell { width: min(1180px, calc(100% - 32px)); margin: 0 auto; }
.topbar { position: sticky; top: 0; z-index: 20; background: rgba(255,255,255,.92); backdrop-filter: blur(16px); border-bottom: 1px solid var(--line); }
.nav { min-height: 72px; display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: nowrap; }
.brand { display: inline-flex; align-items: center; gap: 10px; color: var(--forest); font-weight: 850; text-decoration: none; font-size: 1.2rem; }
.brand-mark { width: 34px; height: 34px; border-radius: 10px; background: linear-gradient(135deg, var(--forest), var(--leaf)); display: grid; place-items: center; color: white; }
.public-menu { display: flex; align-items: center; gap: 12px; margin-left: auto; }
.nav-links { display: flex; align-items: center; gap: 6px; flex-wrap: nowrap; }
.nav-links a, .admin-link, .btn { min-height: 40px; border-radius: 999px; display: inline-flex; align-items: center; gap: 8px; padding: 0 14px; text-decoration: none; border: 1px solid transparent; font-weight: 700; font-size: .92rem; }
.nav-links a:hover, .nav-links a.active { background: #edf7ef; color: var(--forest); }
.nav-more { position: relative; }
.nav-more summary { min-height: 40px; display: inline-flex; align-items: center; padding: 0 14px; border-radius: 999px; font-weight: 800; cursor: pointer; color: var(--forest); list-style: none; }
.nav-more summary::-webkit-details-marker { display: none; }
.nav-more[open] summary, .nav-more summary:hover { background: #edf7ef; }
.nav-more div { position: absolute; right: 0; top: 46px; min-width: 190px; display: grid; gap: 6px; padding: 10px; border: 1px solid var(--line); border-radius: 12px; background: white; box-shadow: var(--shadow); }
.nav-more div a { justify-content: flex-start; border-radius: 10px; }
.admin-link, .btn.primary { background: var(--forest); color: white; }
.btn.secondary { background: white; border-color: var(--line); color: var(--forest); }
.icon { width: 18px; height: 18px; flex: 0 0 18px; }
.search { display: flex; gap: 8px; align-items: center; flex: 0 0 auto; }
.topbar .search input { width: 170px; }
.search input, .filter input, .filter select, .field input, .field textarea, .field select { width: 100%; min-height: 42px; border: 1px solid var(--line); border-radius: 12px; background: white; padding: 10px 12px; font: inherit; }
.hero { min-height: 520px; display: grid; align-items: end; background: linear-gradient(180deg, rgba(18,71,52,.05), rgba(18,71,52,.45)), var(--hero-image); background-size: cover; background-position: center; color: white; }
.hero-content { padding: 92px 0 44px; max-width: 820px; }
.eyebrow { text-transform: uppercase; letter-spacing: .14em; font-weight: 850; font-size: .78rem; color: var(--trail); }
h1 { font-size: clamp(2.4rem, 6vw, 5.7rem); line-height: .94; margin: 12px 0 16px; letter-spacing: 0; }
h2 { font-size: clamp(1.55rem, 3vw, 2.5rem); line-height: 1.05; margin: 0; }
.lead { font-size: clamp(1.05rem, 2vw, 1.35rem); line-height: 1.55; max-width: 720px; color: rgba(255,255,255,.9); }
.hero-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 26px; }
.stats { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 22px; }
.pill { display: inline-flex; align-items: center; gap: 8px; min-height: 34px; border-radius: 999px; padding: 6px 12px; background: rgba(255,255,255,.88); color: var(--forest); font-weight: 800; font-size: .86rem; }
.section { padding: 54px 0; }
.section-head { display: flex; justify-content: space-between; align-items: end; gap: 18px; margin-bottom: 20px; }
.muted { color: var(--muted); }
.grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 18px; }
.card { grid-column: span 4; background: var(--paper); border: 1px solid var(--line); border-radius: 8px; overflow: hidden; box-shadow: var(--shadow); text-decoration: none; }
.card.wide { grid-column: span 6; }
.card-media { aspect-ratio: 16 / 10; width: 100%; object-fit: cover; display: block; background: #d8e8dd; }
.card-body { padding: 16px; }
.card-title { font-weight: 850; font-size: 1.08rem; margin: 0 0 8px; }
.guide-card .card-body { min-height: 230px; }
.guide-photo { object-position: center 28%; }
.chips { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 12px; }
.chip { border: 1px solid var(--line); background: #f7faf7; color: var(--forest); border-radius: 999px; padding: 6px 10px; font-weight: 750; font-size: .78rem; }
.filter { display: grid; grid-template-columns: 1fr 220px 130px; gap: 10px; margin: 20px 0; }
.detail-hero { min-height: 460px; }
.detail-panel { display: grid; grid-template-columns: 1.5fr .85fr; gap: 24px; align-items: start; }
.city-facts-strip { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; }
.city-facts-strip div { background: white; border: 1px solid var(--line); border-radius: 8px; padding: 16px; box-shadow: var(--shadow); }
.city-facts-strip strong { display: block; color: var(--forest); font-size: 1.05rem; }
.city-facts-strip span { color: var(--muted); font-size: .86rem; }
.panel { background: white; border: 1px solid var(--line); border-radius: 8px; padding: 22px; box-shadow: var(--shadow); }
.prose { line-height: 1.75; color: #2d3a35; }
.footer { border-top: 1px solid var(--line); padding: 32px 0; color: var(--muted); background: white; }
.travel-footer { background: #0f3528; color: rgba(255,255,255,.82); margin-top: 30px; }
.footer-cta { display: grid; grid-template-columns: 1.1fr .9fr; gap: 28px; align-items: end; padding: 46px 0 32px; border-bottom: 1px solid rgba(255,255,255,.14); }
.footer-cta h2 { color: white; max-width: 760px; }
.footer-search { display: grid; grid-template-columns: 1fr auto; gap: 10px; background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.16); padding: 10px; border-radius: 8px; }
.footer-search input { min-height: 44px; border: 0; border-radius: 6px; padding: 0 12px; font: inherit; }
.footer-grid { display: grid; grid-template-columns: 1.5fr repeat(3, 1fr); gap: 34px; padding: 34px 0; }
.footer-brand-block p { line-height: 1.65; max-width: 420px; }
.footer-grid h3 { color: white; margin: 0 0 12px; font-size: .95rem; }
.footer-grid nav a { display: block; color: rgba(255,255,255,.78); text-decoration: none; padding: 7px 0; font-weight: 650; }
.footer-grid nav a:hover { color: white; }
.footer-badges { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 16px; }
.footer-badges span { border: 1px solid rgba(255,255,255,.18); background: rgba(255,255,255,.08); border-radius: 999px; padding: 7px 10px; color: white; font-weight: 750; font-size: .78rem; }
.footer-bottom { display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap; padding: 18px 0 28px; border-top: 1px solid rgba(255,255,255,.14); font-size: .88rem; color: rgba(255,255,255,.68); }
.travel-footer .brand { color: white; }
.admin-top { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-bottom: 20px; padding: 18px 20px; background: white; border: 1px solid var(--line); border-radius: 8px; box-shadow: var(--shadow); }
.admin-footer, .guide-footer { margin-top: 34px; padding: 18px 0; color: var(--muted); border-top: 1px solid var(--line); display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.guide-header { background: #163b5c; color: white; }
.guide-header .brand, .guide-header .nav-links a { color: white; }
.guide-header .nav-links a:hover { background: rgba(255,255,255,.12); }
.guide-footer { background: white; padding: 24px 0; }
.super-admin-side { background: #201335; }
.super-admin-layout .brand-mark { background: linear-gradient(135deg, #6d3fd1, #d14b8f); }
.pagination { display: flex; justify-content: center; margin: 28px 0 0; }
.pagination-nav { width: 100%; display: flex; justify-content: center; }
.pagination-mobile { display: none; }
.pagination-desktop { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 12px; border: 1px solid var(--line); border-radius: 14px; background: white; box-shadow: 0 10px 32px rgba(18,71,52,.08); }
.pagination-summary { color: var(--muted); font-size: .9rem; font-weight: 800; }
.pagination-pages { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; justify-content: flex-end; }
.page-link { min-width: 38px; min-height: 38px; display: inline-flex; align-items: center; justify-content: center; padding: 0 12px; border: 1px solid var(--line); border-radius: 999px; background: #fff; color: var(--forest); text-decoration: none; font-weight: 900; font-size: .88rem; }
.page-link.is-current { background: var(--forest); border-color: var(--forest); color: white; }
.page-link.is-disabled { opacity: .48; }
.admin-layout { display: grid; grid-template-columns: 280px 1fr; min-height: 100vh; }
.admin-side { position: sticky; top: 0; height: 100vh; overflow-y: auto; background: linear-gradient(180deg, #0e3328, #123d4d); color: white; padding: 22px; }
.admin-side a { display: block; color: white; text-decoration: none; padding: 10px 12px; font-weight: 800; border-radius: 10px; }
.admin-side a:hover { background: rgba(255,255,255,.12); }
.admin-nav-group { margin-top: 18px; padding-top: 14px; border-top: 1px solid rgba(255,255,255,.14); }
.admin-nav-group span { display: block; color: rgba(255,255,255,.56); text-transform: uppercase; letter-spacing: .12em; font-size: .7rem; font-weight: 900; margin: 0 0 8px 12px; }
.admin-main { padding: 28px; }
.table { width: 100%; border-collapse: collapse; background: white; border: 1px solid var(--line); border-radius: 8px; overflow: hidden; }
.table th, .table td { padding: 14px; border-bottom: 1px solid var(--line); text-align: left; }
.form-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
.field.full, .span-all { grid-column: 1 / -1; }
.admin-form-pro { display: grid; gap: 16px; }
.check-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
.check-grid label, .toggle-row { min-height: 42px; display: flex; align-items: center; gap: 8px; border: 1px solid var(--line); border-radius: 12px; padding: 10px 12px; background: white; font-weight: 800; }
.admin-filter { display: grid; grid-template-columns: 1fr 220px auto; gap: 10px; margin-bottom: 16px; }
.admin-filter input, .admin-filter select { min-height: 42px; border: 1px solid var(--line); border-radius: 12px; padding: 0 12px; font: inherit; }
.alert { padding: 12px 14px; background: #edf7ef; border: 1px solid #cbe6d1; border-radius: 8px; margin-bottom: 16px; }
.route-stop { border-left: 3px solid var(--trail); padding-left: 14px; margin: 16px 0; }
.pn-hero { position: relative; min-height: 780px; color: white; background-image: var(--hero-image); background-size: cover; background-position: center; overflow: hidden; }
.pn-hero-shade { position: absolute; inset: 0; background: radial-gradient(circle at 72% 30%, rgba(242,140,40,.18), transparent 28%), linear-gradient(90deg, rgba(7,18,17,.88), rgba(7,18,17,.28) 55%, rgba(7,18,17,.72)), linear-gradient(180deg, rgba(7,18,17,.08), rgba(7,18,17,.86)); }
.pn-hero-grid { position: relative; z-index: 1; min-height: 680px; display: grid; grid-template-columns: minmax(0, 1fr) 380px; gap: 36px; align-items: end; padding: 120px 0 88px; }
.pn-hero-copy h1 { max-width: 920px; font-size: clamp(3.2rem, 8vw, 7.6rem); }
.pn-hero-copy p { max-width: 760px; color: rgba(255,255,255,.88); font-size: 1.18rem; line-height: 1.7; }
.pn-hero-search { width: min(780px, 100%); display: grid; grid-template-columns: 1fr auto; gap: 10px; margin-top: 28px; padding: 10px; border: 1px solid rgba(255,255,255,.28); background: rgba(255,255,255,.14); border-radius: 14px; backdrop-filter: blur(16px); box-shadow: 0 20px 80px rgba(0,0,0,.22); }
.pn-hero-search input, .pn-planner select { min-height: 52px; border: 0; border-radius: 10px; padding: 0 14px; font: inherit; }
.pn-hero-actions { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 22px; }
.pn-live-panel { border: 1px solid rgba(255,255,255,.22); background: rgba(255,255,255,.12); backdrop-filter: blur(20px); border-radius: 14px; padding: 18px; box-shadow: 0 20px 90px rgba(0,0,0,.2); }
.pn-live-top strong { display: block; font-size: 3.2rem; line-height: 1; color: white; }
.pn-live-top span, .pn-live-top small { color: rgba(255,255,255,.75); font-weight: 800; }
.pn-live-list { display: grid; gap: 10px; margin-top: 18px; }
.pn-live-list a { display: block; padding: 13px; border-radius: 10px; color: white; text-decoration: none; background: rgba(255,255,255,.12); }
.pn-live-list a:hover { background: rgba(255,255,255,.2); transform: translateY(-2px); }
.pn-live-list span { display: block; color: var(--trail); font-size: .75rem; text-transform: uppercase; font-weight: 900; letter-spacing: .08em; }
.pn-hero-strip { position: relative; z-index: 2; display: grid; grid-template-columns: repeat(5, 1fr); gap: 1px; margin-top: -58px; background: rgba(255,255,255,.22); border-radius: 14px; overflow: hidden; box-shadow: 0 22px 70px rgba(0,0,0,.18); }
.pn-hero-strip a { padding: 22px; background: rgba(255,255,255,.96); text-decoration: none; }
.pn-hero-strip strong { display: block; color: var(--forest); font-size: 2rem; }
.pn-hero-strip span { color: var(--muted); font-weight: 850; }
.pn-search-dock { position: sticky; top: 72px; z-index: 12; padding: 12px 0; background: rgba(245,247,244,.86); backdrop-filter: blur(16px); border-bottom: 1px solid var(--line); }
.pn-dock-inner { display: flex; align-items: center; gap: 10px; overflow-x: auto; }
.pn-dock-inner span { font-weight: 900; color: var(--forest); white-space: nowrap; }
.pn-dock-inner a { white-space: nowrap; text-decoration: none; border: 1px solid var(--line); background: white; border-radius: 999px; padding: 8px 12px; font-weight: 800; color: var(--forest); }
.pn-split-feature, .pn-motion-grid, .pn-planner, .pn-final { display: grid; grid-template-columns: 1fr .9fr; gap: 28px; align-items: center; }
.pn-region-list { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 20px; }
.pn-region-list a, .pn-practical a { display: block; padding: 18px; border: 1px solid var(--line); border-radius: 10px; background: white; box-shadow: var(--shadow); text-decoration: none; }
.pn-region-list span, .pn-practical span { display: block; color: var(--muted); margin-top: 6px; }
.pn-map-visual { position: relative; min-height: 420px; border-radius: 16px; padding: 28px; color: white; background: radial-gradient(circle at 40% 30%, #4f8d69, transparent 22%), radial-gradient(circle at 64% 60%, #2d6284, transparent 22%), linear-gradient(135deg, #112e25, #142f47); overflow: hidden; box-shadow: var(--shadow); }
.pn-map-visual strong { position: absolute; left: 28px; bottom: 56px; font-size: 1.6rem; }
.pn-map-visual > span { position: absolute; left: 28px; bottom: 28px; color: rgba(255,255,255,.72); }
.pn-map-pin { position: absolute; max-width: 160px; padding: 8px 10px; background: rgba(255,255,255,.94); color: var(--forest); text-decoration: none; border-radius: 999px; font-size: .78rem; font-weight: 900; box-shadow: 0 10px 30px rgba(0,0,0,.24); }
.pin-1 { top: 18%; left: 18%; } .pin-2 { top: 38%; right: 12%; } .pin-3 { bottom: 30%; left: 34%; } .pin-4 { top: 58%; right: 30%; }
.pn-map-line { position: absolute; inset: 22%; border: 1px dashed rgba(255,255,255,.35); transform: rotate(-18deg); border-radius: 50%; }
.pn-mood-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.pn-mood { min-height: 150px; display: flex; flex-direction: column; justify-content: end; gap: 8px; padding: 18px; color: white; text-decoration: none; border-radius: 12px; background: linear-gradient(135deg, #153f31, #32734c); box-shadow: var(--shadow); transition: transform .18s ease, filter .18s ease; }
.pn-mood:nth-child(2n) { background: linear-gradient(135deg, #1d4664, #5a86a3); }
.pn-mood:nth-child(3n) { background: linear-gradient(135deg, #5a371f, #bd742f); }
.pn-mood:hover, .pn-image-card:hover, .pn-guide-card:hover, .pn-route-list a:hover { transform: translateY(-4px); filter: saturate(1.05); }
.pn-mood span { color: rgba(255,255,255,.78); line-height: 1.45; }
.pn-feature-grid, .pn-nature-grid { display: grid; grid-template-columns: 1.2fr 1fr 1fr; gap: 18px; }
.pn-image-card { min-height: 340px; position: relative; display: flex; flex-direction: column; justify-content: end; gap: 8px; padding: 20px; color: white; text-decoration: none; border-radius: 14px; overflow: hidden; background: linear-gradient(180deg, rgba(0,0,0,.05), rgba(0,0,0,.78)), var(--card-image); background-size: cover; background-position: center; box-shadow: var(--shadow); transition: transform .18s ease, filter .18s ease; }
.pn-feature-grid .pn-image-card:first-child { grid-row: span 2; min-height: 700px; }
.pn-image-card span { color: var(--trail); font-weight: 900; text-transform: uppercase; letter-spacing: .08em; font-size: .74rem; }
.pn-image-card strong { font-size: 1.55rem; line-height: 1.05; }
.pn-image-card small { color: rgba(255,255,255,.82); line-height: 1.45; }
.pn-motion { background: #0e241f; color: white; }
.pn-motion-main p { color: rgba(255,255,255,.76); max-width: 620px; line-height: 1.7; }
.pn-reel-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.pn-reel { min-height: 300px; display: flex; flex-direction: column; justify-content: end; gap: 8px; padding: 18px; color: white; text-decoration: none; border-radius: 14px; background: linear-gradient(160deg, #203f64, #17382b); box-shadow: 0 20px 60px rgba(0,0,0,.25); }
.pn-reel span { color: rgba(255,255,255,.76); }
.pn-guide-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.pn-guide-card { display: grid; grid-template-rows: 250px 1fr; color: inherit; background: white; border: 1px solid var(--line); border-radius: 14px; overflow: hidden; text-decoration: none; box-shadow: var(--shadow); transition: transform .18s ease; }
.pn-guide-card img { width: 100%; height: 100%; object-fit: cover; }
.pn-guide-card div { padding: 16px; }
.pn-guide-card span { display: block; color: var(--muted); margin-top: 6px; line-height: 1.45; }
.pn-journeys { background: #eef4f5; }
.pn-route-list { display: grid; gap: 12px; }
.pn-route-list a { display: grid; grid-template-columns: 160px 1fr 160px 130px; gap: 16px; align-items: center; padding: 18px; color: inherit; background: white; border: 1px solid var(--line); border-radius: 12px; text-decoration: none; box-shadow: var(--shadow); transition: transform .18s ease; }
.pn-route-list span, .pn-route-list em, .pn-route-list small { color: var(--muted); font-style: normal; }
.pn-planner, .pn-final { padding: 36px; border-radius: 16px; color: white; background: linear-gradient(135deg, #102b3a, #153f31); box-shadow: var(--shadow); }
.pn-planner p, .pn-final p { color: rgba(255,255,255,.76); line-height: 1.7; }
.pn-planner form { display: grid; grid-template-columns: 1fr auto; gap: 10px; }
.pn-practical { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.admin-hero { display: flex; justify-content: space-between; gap: 24px; align-items: flex-end; margin-bottom: 24px; padding: 26px; border: 1px solid var(--line); border-radius: 14px; background: linear-gradient(135deg, #fff, #eef6f1); box-shadow: var(--shadow); }
.admin-hero h1 { margin: 0; font-size: clamp(2rem, 4vw, 3.4rem); }
.admin-metrics { display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px; margin-bottom: 22px; }
.admin-metrics div { padding: 18px; border: 1px solid var(--line); border-radius: 12px; background: white; box-shadow: var(--shadow); }
.admin-metrics strong { display: block; font-size: 2rem; color: var(--forest); }
.admin-metrics span { color: var(--muted); font-weight: 800; }
.admin-panel { margin-bottom: 20px; }
.admin-tabs { position: sticky; top: 0; z-index: 10; display: flex; gap: 8px; flex-wrap: wrap; padding: 10px; margin-bottom: 18px; border: 1px solid var(--line); border-radius: 12px; background: rgba(255,255,255,.92); backdrop-filter: blur(14px); box-shadow: var(--shadow); }
.admin-tabs a { padding: 9px 12px; border-radius: 999px; color: var(--forest); background: #f2f7f3; font-weight: 900; text-decoration: none; }
.admin-savebar { position: sticky; bottom: 0; display: flex; gap: 10px; justify-content: flex-end; padding: 14px 0; background: rgba(245,247,244,.9); backdrop-filter: blur(14px); }
.check { display: flex; align-items: center; gap: 8px; font-weight: 900; }
.simple-editor-toolbar { display: flex; gap: 6px; flex-wrap: wrap; padding: 8px; border: 1px solid var(--line); border-bottom: 0; border-radius: 10px 10px 0 0; background: #f6f8f5; }
.simple-editor-toolbar button { border: 1px solid var(--line); border-radius: 8px; padding: 7px 10px; background: white; font-weight: 900; cursor: pointer; }
.simple-editor { min-height: 220px; padding: 16px; border: 1px solid var(--line); border-radius: 0 0 10px 10px; background: white; line-height: 1.7; outline: none; }
.simple-editor:focus { border-color: var(--forest); box-shadow: 0 0 0 3px rgba(29,78,57,.12); }
.admin-relation-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
.relation-card { padding: 16px; border: 1px solid var(--line); border-radius: 12px; background: #fff; }
.relation-card-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 12px; }
.relation-card-head span { min-width: 34px; min-height: 34px; display: grid; place-items: center; border-radius: 50%; background: #eaf3ed; color: var(--forest); font-weight: 950; }
.relation-card a, .relation-card p { display: block; margin: 6px 0; color: var(--forest); text-decoration: none; }
.photo-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-top: 18px; }
.photo-grid figure { margin: 0; border-radius: 12px; overflow: hidden; background: white; border: 1px solid var(--line); box-shadow: var(--shadow); }
.photo-grid img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; }
.photo-grid figcaption { padding: 10px 12px; color: var(--muted); font-weight: 800; }
.park-nav-section { padding-top: 0; padding-bottom: 12px; }
.park-feature-nav { display: grid; grid-template-columns: repeat(6, 1fr); gap: 12px; margin-top: -40px; position: relative; z-index: 5; }
.park-feature-link { position: relative; min-height: 138px; display: flex; flex-direction: column; gap: 6px; justify-content: center; padding: 16px; border: 1px solid rgba(255,255,255,.65); border-radius: 14px; background: rgba(255,255,255,.94); color: var(--forest); text-decoration: none; box-shadow: var(--shadow); transition: transform .18s ease, border-color .18s ease, background .18s ease; }
.park-feature-link:hover { transform: translateY(-5px); border-color: rgba(29,78,57,.35); background: #fff; }
.park-feature-link.is-active { border-color: rgba(29,78,57,.48); background: #f2faf5; box-shadow: 0 18px 60px rgba(29,78,57,.18); }
.park-feature-icon { width: 46px; height: 46px; display: grid; place-items: center; border-radius: 50%; background: linear-gradient(135deg, #173f31, #2f7652); color: white; font-size: .82rem; font-weight: 950; letter-spacing: .04em; }
.park-feature-link strong { font-size: 1rem; }
.park-feature-link small { color: var(--muted); line-height: 1.35; }
.park-feature-link em { position: absolute; top: 12px; right: 12px; min-width: 28px; height: 28px; display: grid; place-items: center; border-radius: 999px; background: #eef6f1; color: var(--forest); font-style: normal; font-weight: 950; }
.park-inline-panels { margin-top: 18px; }
.park-inline-panel { scroll-margin-top: 110px; padding: 18px; border: 1px solid var(--line); border-radius: 16px; background: rgba(255,255,255,.94); box-shadow: var(--shadow); }
.experience-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.experience-card { min-height: 170px; display: flex; flex-direction: column; justify-content: flex-end; gap: 8px; padding: 18px; border: 1px solid var(--line); border-radius: 14px; background: linear-gradient(135deg, #fff, #edf6f2); color: inherit; text-decoration: none; box-shadow: var(--shadow); transition: transform .18s ease, background .18s ease; }
.experience-card:hover { transform: translateY(-4px); background: white; }
.experience-card span { width: 44px; height: 44px; display: grid; place-items: center; border-radius: 50%; background: #163f31; color: white; font-weight: 950; }
.experience-card strong { font-size: 1.12rem; color: var(--forest); }
.experience-card small { color: var(--muted); line-height: 1.45; }
.activity-hero { min-height: 620px; }
.activity-filter { margin-top: -56px; position: relative; z-index: 4; padding: 12px; border: 1px solid rgba(255,255,255,.72); border-radius: 14px; background: rgba(255,255,255,.95); box-shadow: var(--shadow); }
.activity-card-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.activity-tile { min-height: 360px; display: flex; flex-direction: column; justify-content: end; gap: 8px; padding: 20px; color: white; text-decoration: none; border-radius: 14px; overflow: hidden; background: linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.78)), var(--card-image); background-size: cover; background-position: center; box-shadow: var(--shadow); transition: transform .18s ease, filter .18s ease; }
.activity-tile:hover { transform: translateY(-5px); filter: saturate(1.05); }
.activity-tile span, .activity-tile em { color: var(--trail); font-style: normal; font-weight: 900; text-transform: uppercase; letter-spacing: .08em; font-size: .74rem; }
.activity-tile strong { font-size: 1.45rem; line-height: 1.05; }
.activity-tile small { color: rgba(255,255,255,.84); line-height: 1.45; }
.mobile-menu-toggle { display: none; border: 1px solid var(--line); border-radius: 999px; padding: 9px 13px; background: white; color: var(--forest); font-weight: 950; }
.lake-hero { min-height: 620px; }
.lake-tile { background-position: center; }
.lake-guide-hero { background-position: center; }
.lake-guide-grid { display: grid; grid-template-columns: repeat(6, minmax(0, 1fr)); gap: 12px; }
.lake-guide-card { min-height: 142px; padding: 16px; border: 1px solid var(--line); border-radius: 18px; background: linear-gradient(180deg, #fff, #f7fbf9); box-shadow: var(--shadow); }
.lake-guide-card span { display: inline-flex; min-height: 28px; align-items: center; padding: 0 10px; border-radius: 999px; background: #e9f5f2; color: var(--forest); font-weight: 950; text-transform: uppercase; letter-spacing: .08em; font-size: .72rem; }
.lake-guide-card strong { display: block; margin-top: 12px; color: var(--ink); line-height: 1.25; }
.lake-planner-card { position: sticky; top: 92px; }
.source-list { display: grid; gap: 8px; margin: 10px 0 16px; }
.source-list a { display: flex; align-items: center; min-height: 38px; padding: 0 12px; border-radius: 999px; background: #eef7f1; color: var(--forest); font-weight: 900; text-decoration: none; }
.lake-timeline article::before { background: #176b87; }
.park-index-hero { background-position: center; }
.park-filter { margin-top: -58px; position: relative; z-index: 4; padding: 12px; border: 1px solid rgba(255,255,255,.72); border-radius: 16px; background: rgba(255,255,255,.96); box-shadow: var(--shadow); grid-template-columns: 1fr 210px 210px 120px; }
.park-quick-filters { display: flex; gap: 9px; overflow-x: auto; padding: 8px 0 18px; scrollbar-width: thin; }
.park-quick-filters button { flex: 0 0 auto; min-height: 40px; border: 1px solid var(--line); border-radius: 999px; background: #fff; color: var(--forest); padding: 0 14px; font-weight: 950; cursor: pointer; }
.park-quick-filters button.is-active { background: var(--forest); color: #fff; border-color: var(--forest); }
.park-directory-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.park-directory-card { display: grid; grid-template-rows: 220px 1fr; min-height: 500px; border: 1px solid var(--line); border-radius: 20px; overflow: hidden; background: #fff; color: inherit; text-decoration: none; box-shadow: var(--shadow); transition: transform .18s ease, box-shadow .18s ease; }
.park-directory-card:hover { transform: translateY(-4px); box-shadow: 0 24px 80px rgba(18,71,52,.16); }
.park-directory-card[hidden] { display: none; }
.park-directory-card img { width: 100%; height: 100%; object-fit: cover; background: #eaf2ec; }
.park-directory-card > div { display: flex; flex-direction: column; gap: 10px; padding: 18px; }
.park-directory-card span { color: #176b87; font-size: .76rem; font-weight: 950; text-transform: uppercase; letter-spacing: .08em; }
.park-directory-card strong { color: var(--forest); font-size: 1.35rem; line-height: 1.08; }
.park-directory-card p { color: var(--muted); line-height: 1.5; margin: 0; }
.park-filter-empty { margin-top: 16px; }
.park-guide-grid { display: grid; grid-template-columns: repeat(6, minmax(0, 1fr)); gap: 12px; }
.search-hero, .explore-hero { padding: 70px 0 34px; color: white; background: linear-gradient(135deg, #0d2f25, #174965); }
.search-hero-grid, .explore-hero-grid { display: grid; grid-template-columns: 1fr .9fr; gap: 30px; align-items: center; }
.search-hero h1, .explore-hero h1 { font-size: clamp(2.4rem, 5vw, 5.4rem); }
.search-hero p, .explore-hero p { color: rgba(255,255,255,.8); line-height: 1.7; }
.search-command, .explore-compose { display: grid; gap: 10px; padding: 16px; border: 1px solid rgba(255,255,255,.22); border-radius: 16px; background: rgba(255,255,255,.12); backdrop-filter: blur(16px); box-shadow: 0 20px 80px rgba(0,0,0,.2); }
.search-command input, .search-command select, .explore-compose input, .explore-compose select, .explore-compose textarea { width: 100%; min-height: 46px; border: 0; border-radius: 10px; padding: 10px 12px; font: inherit; }
.search-tabs { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 22px; }
.search-tabs a { padding: 10px 13px; border-radius: 999px; border: 1px solid var(--line); background: white; color: var(--forest); text-decoration: none; font-weight: 850; }
.search-tabs a.is-active { background: var(--forest); color: white; }
.search-result-block { margin-top: 30px; }
.search-result-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; margin-top: 14px; }
.search-result-card { display: grid; grid-template-columns: 140px 1fr; gap: 14px; padding: 12px; border: 1px solid var(--line); border-radius: 14px; background: white; text-decoration: none; box-shadow: var(--shadow); transition: transform .18s ease; }
.search-result-card:hover { transform: translateY(-3px); }
.search-result-card img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; border-radius: 10px; }
.search-result-card span { color: var(--trail); font-size: .75rem; text-transform: uppercase; font-weight: 950; letter-spacing: .08em; }
.search-result-card strong { display: block; margin: 6px 0; color: var(--forest); font-size: 1.1rem; }
.search-result-card small { color: var(--muted); line-height: 1.45; }
.search-command-hero { padding: 44px 0 28px; color: white; background: radial-gradient(circle at 85% 8%, rgba(242,140,40,.24), transparent 28%), linear-gradient(135deg, #102b3a, #174735); }
.search-command-grid { display: grid; grid-template-columns: minmax(0, 1fr) 460px; gap: 28px; align-items: end; }
.search-command-grid h1 { margin: 8px 0 12px; font-size: clamp(2.4rem, 5vw, 5.8rem); }
.search-command-grid p { max-width: 760px; color: rgba(255,255,255,.8); line-height: 1.65; margin: 0; }
.search-glass { display: grid; grid-template-columns: 1fr 150px; gap: 10px; padding: 12px; border: 1px solid rgba(255,255,255,.22); border-radius: 18px; background: rgba(255,255,255,.13); backdrop-filter: blur(18px); box-shadow: 0 24px 80px rgba(0,0,0,.2); }
.search-glass input, .search-glass select { min-height: 50px; border: 0; border-radius: 12px; padding: 0 14px; font: inherit; background: white; }
.search-glass button { grid-column: 1 / -1; justify-content: center; }
.search-type-rail { position: sticky; top: 72px; z-index: 11; display: flex; gap: 10px; overflow-x: auto; padding: 12px 0; background: rgba(245,247,244,.92); backdrop-filter: blur(14px); }
.search-type-rail a { min-width: 104px; display: flex; align-items: center; gap: 9px; padding: 9px 11px; border: 1px solid var(--line); border-radius: 999px; background: white; box-shadow: 0 8px 24px rgba(18,71,52,.07); text-decoration: none; }
.search-type-rail span { width: 30px; height: 30px; display: grid; place-items: center; border-radius: 50%; background: #edf7ef; color: var(--forest); font-size: .68rem; font-weight: 950; }
.search-type-rail strong { color: var(--forest); font-size: .86rem; }
.search-type-rail a.is-active { background: var(--forest); border-color: var(--forest); }
.search-type-rail a.is-active span { background: rgba(255,255,255,.16); color: white; }
.search-type-rail a.is-active strong { color: white; }
.search-live-section { padding-top: 26px; }
.search-summary { display: flex; justify-content: space-between; gap: 18px; align-items: end; margin-bottom: 24px; }
.search-summary h2 { margin-top: 6px; }
.search-suggestions { display: flex; gap: 8px; flex-wrap: wrap; justify-content: flex-end; }
.search-suggestions a { text-decoration: none; border: 1px solid var(--line); border-radius: 999px; padding: 8px 11px; background: white; color: var(--forest); font-weight: 850; }
.search-empty-public { padding: 30px; border: 1px solid var(--line); border-radius: 18px; background: linear-gradient(135deg, #fff, #eef7f2); box-shadow: var(--shadow); }
.search-empty-public strong { display: block; color: var(--forest); font-size: 1.45rem; }
.search-empty-public p { max-width: 680px; color: var(--muted); line-height: 1.7; }
.search-section-list { display: grid; gap: 32px; }
.search-block-head { display: flex; gap: 12px; align-items: center; margin-bottom: 14px; }
.search-block-head > span { width: 48px; height: 48px; display: grid; place-items: center; border-radius: 50%; background: var(--forest); color: white; font-weight: 950; }
.search-block-head h2 { font-size: 1.7rem; }
.search-card-grid { grid-template-columns: repeat(3, 1fr); }
.search-pro-card { grid-template-columns: 1fr; padding: 0; overflow: hidden; border-radius: 16px; }
.search-pro-card img { width: 100%; aspect-ratio: 16 / 10; border-radius: 0; }
.search-pro-card div { padding: 15px; }
.search-pro-card em { display: block; color: var(--muted); font-style: normal; font-size: .82rem; margin-bottom: 6px; }
.review-row { padding: 14px 0; border-bottom: 1px solid var(--line); }
.review-row:last-child { border-bottom: 0; }
.explore-feed { display: grid; gap: 18px; max-width: 860px; }
.explore-post { padding: 18px; border: 1px solid var(--line); border-radius: 16px; background: white; box-shadow: var(--shadow); }
.explore-author { display: flex; gap: 12px; align-items: center; margin-bottom: 14px; }
.explore-author img { width: 52px; height: 52px; border-radius: 50%; object-fit: cover; }
.explore-author span { display: block; color: var(--muted); font-size: .88rem; }
.explore-media { width: 100%; max-height: 460px; object-fit: cover; border-radius: 12px; margin-bottom: 12px; }
.admin-dashboard-hero { display: flex; justify-content: space-between; gap: 24px; align-items: end; padding: 28px; border-radius: 18px; color: white; background: linear-gradient(135deg, #0e3328, #164d64); box-shadow: var(--shadow); margin-bottom: 22px; }
.admin-dashboard-hero h1 { margin: 0; font-size: clamp(2.2rem, 5vw, 4.6rem); }
.admin-dashboard-hero .muted { color: rgba(255,255,255,.78); max-width: 760px; }
.dashboard-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.intel-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 12px; margin-bottom: 18px; }
.intel-card { min-height: 132px; padding: 18px; border: 1px solid var(--line); border-radius: 16px; background: white; box-shadow: var(--shadow); }
.intel-card span, .intel-card small { display: block; color: var(--muted); font-weight: 800; }
.intel-card strong { display: block; margin: 10px 0 8px; color: var(--forest); font-size: 2.25rem; line-height: 1; }
.intel-card.color-forest { background: #123f31; color: white; }
.intel-card.color-forest strong, .intel-card.color-forest span, .intel-card.color-forest small, .intel-card.color-sun strong, .intel-card.color-sun span, .intel-card.color-sun small, .intel-card.color-blue strong, .intel-card.color-blue span, .intel-card.color-blue small { color: white; }
.intel-card.color-sun { background: #b8611b; }
.intel-card.color-blue { background: #245c7c; }
.dashboard-row { display: grid; grid-template-columns: repeat(12, 1fr); gap: 18px; margin-bottom: 18px; }
.dashboard-panel { grid-column: span 12; padding: 20px; border: 1px solid var(--line); border-radius: 16px; background: white; box-shadow: var(--shadow); }
.span-8 { grid-column: span 8; } .span-5 { grid-column: span 5; } .span-4 { grid-column: span 4; } .span-3 { grid-column: span 3; }
.panel-head { display: flex; justify-content: space-between; gap: 16px; align-items: start; margin-bottom: 16px; }
.panel-head h2 { font-size: 1.45rem; }
.trend-bars { min-height: 210px; display: grid; grid-template-columns: repeat(14, 1fr); gap: 8px; align-items: end; padding-top: 22px; }
.trend-day { display: grid; gap: 8px; align-items: end; text-align: center; color: var(--muted); font-size: .72rem; }
.trend-day span { display: block; width: 100%; border-radius: 8px 8px 3px 3px; background: linear-gradient(180deg, #2f7d46, #123f31); }
.action-row, .rank-row, .quality-row, .creator-row { display: flex; align-items: center; gap: 12px; padding: 12px; border: 1px solid var(--line); border-radius: 12px; background: #f8fbf8; text-decoration: none; margin-bottom: 10px; }
.action-row strong, .rank-row span, .quality-row span { min-width: 42px; height: 42px; display: grid; place-items: center; border-radius: 50%; background: var(--forest); color: white; font-size: 1.1rem; }
.rank-row div, .quality-row div { flex: 1; }
.rank-row small, .quality-row small { display: block; color: var(--muted); margin-top: 3px; }
.rank-row em { font-style: normal; font-weight: 950; color: var(--forest); }
.mini-bar { margin-bottom: 14px; }
.mini-bar div { display: flex; justify-content: space-between; gap: 10px; }
.mini-bar small { color: var(--muted); }
.mini-bar span { display: block; height: 8px; margin-top: 7px; border-radius: 999px; background: var(--leaf); }
.status-pill { display: inline-flex; padding: 6px 10px; border-radius: 999px; background: #edf7ef; color: var(--forest); font-weight: 900; }
.gap-box + .gap-box { margin-top: 24px; }
.gap-box a { display: block; padding: 9px 0; color: var(--forest); font-weight: 850; text-decoration: none; border-bottom: 1px solid var(--line); }
.explore-top { padding: 34px 0 18px; color: white; background: radial-gradient(circle at 86% 10%, rgba(242,140,40,.24), transparent 26%), linear-gradient(135deg, #102b3a, #1b4737); }
.explore-top-grid { display: grid; grid-template-columns: minmax(0, 1fr) 280px; gap: 24px; align-items: end; }
.explore-top h1 { margin: 8px 0 10px; font-size: clamp(2rem, 4vw, 4rem); line-height: 1; }
.explore-top p { max-width: 720px; color: rgba(255,255,255,.78); line-height: 1.65; margin: 0; }
.explore-top-stats { padding: 16px; border: 1px solid rgba(255,255,255,.22); border-radius: 16px; background: rgba(255,255,255,.13); backdrop-filter: blur(16px); }
.explore-top-stats strong { display: block; color: white; font-size: 3.2rem; line-height: 1; }
.explore-top-stats span, .explore-top-stats small { display: block; color: rgba(255,255,255,.78); font-weight: 850; margin-top: 5px; }
.explore-command { position: sticky; top: 72px; z-index: 11; display: flex; gap: 10px; overflow-x: auto; padding: 12px 0; background: rgba(245,247,244,.92); backdrop-filter: blur(14px); }
.explore-command a { min-width: 112px; display: grid; grid-template-columns: 36px 1fr; gap: 0 9px; align-items: center; padding: 10px; border: 1px solid var(--line); border-radius: 14px; background: white; box-shadow: 0 8px 24px rgba(18,71,52,.07); text-decoration: none; }
.explore-command a span { grid-row: span 2; width: 36px; height: 36px; display: grid; place-items: center; border-radius: 50%; background: #edf7ef; color: var(--forest); font-size: .72rem; font-weight: 950; }
.explore-command a strong { color: var(--forest); font-size: .82rem; white-space: nowrap; }
.explore-command a small { color: var(--muted); font-weight: 750; font-size: .7rem; }
.explore-command a.active { border-color: rgba(18,71,52,.36); background: #123f31; }
.explore-command a.active span { background: rgba(255,255,255,.16); color: white; }
.explore-command a.active strong, .explore-command a.active small { color: white; }
.explore-section { padding-top: 24px; }
.social-hero { background: linear-gradient(135deg, #102b3a, #1b4737); }
.social-pulse { padding: 22px; border: 1px solid rgba(255,255,255,.22); border-radius: 18px; background: rgba(255,255,255,.13); backdrop-filter: blur(16px); }
.social-pulse strong { display: block; color: white; font-size: 4rem; line-height: 1; }
.social-pulse span { color: rgba(255,255,255,.8); font-weight: 900; }
.social-pulse-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-top: 18px; }
.social-pulse-grid div { padding: 12px; border-radius: 12px; background: rgba(255,255,255,.12); color: white; font-weight: 950; }
.social-pulse-grid small { display: block; color: rgba(255,255,255,.72); font-weight: 750; margin-top: 4px; }
.social-layout { display: grid; grid-template-columns: minmax(0, 1fr) 360px; gap: 22px; align-items: start; }
.social-sidebar { position: sticky; top: 98px; display: grid; gap: 16px; }
.social-card { padding: 18px; border: 1px solid var(--line); border-radius: 16px; background: white; box-shadow: var(--shadow); }
.social-compose { display: grid; gap: 10px; }
.social-post h2 { font-size: 1.5rem; margin: 8px 0; }
.social-post h2 a { color: inherit; text-decoration: none; }
.social-post h2 a:hover { color: var(--forest); }
.explore-author a { color: inherit; text-decoration: none; }
.social-actions { display: flex; justify-content: space-between; gap: 12px; align-items: center; padding-top: 10px; border-top: 1px solid var(--line); }
.social-actions form { display: flex; gap: 8px; align-items: center; }
.social-actions select, .comment-form select { max-width: 150px; min-height: 38px; border: 1px solid var(--line); border-radius: 999px; padding: 0 10px; background: white; }
.social-button { min-height: 38px; border: 0; border-radius: 999px; padding: 0 13px; background: #edf7ef; color: var(--forest); font-weight: 950; cursor: pointer; }
.social-button.subtle { background: #fff4ec; color: #9a4d10; }
.explore-tabs { display: flex; gap: 8px; overflow-x: auto; padding: 14px 0; }
.explore-tabs a { flex: 0 0 auto; text-decoration: none; padding: 9px 13px; border: 1px solid var(--line); border-radius: 999px; background: white; color: var(--forest); font-weight: 850; }
.explore-tabs a.active { background: var(--forest); color: white; }
.post-type-badge { margin-left: auto; padding: 7px 10px; border-radius: 999px; background: #edf7ef; color: var(--forest); font-size: .78rem; font-weight: 950; }
.post-type-badge { text-decoration: none; }
.post-meta-row { display: flex; flex-wrap: wrap; gap: 8px; margin: 12px 0; }
.post-meta-row span, .mini-badge { display: inline-flex; border-radius: 999px; background: #f7faf7; border: 1px solid var(--line); color: var(--forest); padding: 5px 9px; font-size: .76rem; font-weight: 850; }
.explore-actions { flex-wrap: wrap; align-items: stretch; }
.explore-actions form { flex-wrap: wrap; }
.best-answer { border: 1px solid #bfe5c7; background: #effaf1 !important; color: var(--forest) !important; }
.topic-cloud { display: flex; flex-wrap: wrap; gap: 8px; }
.topic-cloud a { text-decoration: none; border: 1px solid var(--line); border-radius: 999px; padding: 7px 10px; background: #f7faf7; color: var(--forest); font-weight: 850; }
.composer-identity { display: flex; align-items: center; gap: 12px; margin-bottom: 12px; }
.composer-identity img { width: 52px; height: 52px; border-radius: 50%; object-fit: cover; }
.composer-identity span { display: block; color: var(--muted); font-size: .9rem; margin-top: 2px; }
.composer-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.composer-live { padding: 12px; }
.composer-trigger { width: 100%; display: grid; grid-template-columns: 48px 1fr auto; gap: 12px; align-items: center; padding: 12px; border: 1px solid var(--line); border-radius: 18px; background: linear-gradient(135deg, #fff, #eef7f2); cursor: pointer; text-align: left; box-shadow: 0 12px 34px rgba(18,71,52,.08); }
.composer-trigger img { width: 48px; height: 48px; border-radius: 50%; object-fit: cover; }
.composer-trigger span { color: var(--muted); font-weight: 850; }
.composer-trigger strong { min-height: 38px; display: inline-flex; align-items: center; padding: 0 14px; border-radius: 999px; background: var(--forest); color: white; }
.composer-panel { display: none; margin-top: 12px; padding: 16px; border: 1px solid var(--line); border-radius: 18px; background: white; box-shadow: 0 18px 55px rgba(18,71,52,.12); }
.composer-live.is-open .composer-panel { display: grid; }
.composer-type-picker { display: flex; gap: 8px; overflow-x: auto; padding-bottom: 4px; }
.composer-type-picker label { position: relative; display: grid; justify-items: center; gap: 6px; padding: 10px 7px; border: 1px solid var(--line); border-radius: 12px; background: #f8fbf8; cursor: pointer; text-align: center; }
.composer-type-picker label { min-width: 92px; }
.composer-type-picker input { position: absolute; opacity: 0; pointer-events: none; }
.composer-type-picker span { width: 38px; height: 38px; display: grid; place-items: center; border-radius: 50%; background: #edf7ef; color: var(--forest); font-size: .72rem; font-weight: 950; }
.composer-type-picker strong { color: var(--forest); font-size: .72rem; }
.composer-type-picker label:has(input:checked) { border-color: rgba(18,71,52,.42); background: #123f31; }
.composer-type-picker label:has(input:checked) span { background: rgba(255,255,255,.16); color: white; }
.composer-type-picker label:has(input:checked) strong { color: white; }
.composer-actions { display: flex; justify-content: flex-end; gap: 10px; }
.locked-composer p { line-height: 1.65; }
.user-home-layout { display: grid; grid-template-columns: minmax(0, 1fr) 380px; gap: 22px; align-items: start; }
.mini-feed-post { padding: 14px 0; border-top: 1px solid var(--line); }
.mini-feed-post span { display: block; color: var(--muted); margin: 4px 0; }
.mini-feed-post p { margin: 0; color: var(--muted); line-height: 1.55; }
.action-stack { display: grid; gap: 10px; }
.action-stack a, .action-stack button { width: 100%; text-align: left; text-decoration: none; padding: 12px; border: 1px solid var(--line); border-radius: 12px; background: #f7faf7; color: var(--forest); font: inherit; font-weight: 900; cursor: pointer; }
.action-stack a:hover, .action-stack button:hover { background: #edf7ef; transform: translateY(-1px); }
.post-type-question { border-left: 5px solid #2d6284; }
.post-type-safety-update { border-left: 5px solid #c94f2f; }
.post-type-guide-tip { border-left: 5px solid var(--leaf); }
.post-type-hidden-gem { border-left: 5px solid var(--trail); }
.comment-list { margin: 10px 0; display: grid; gap: 8px; }
.comment-list p { margin: 0; padding: 10px 12px; border-radius: 12px; background: #f5f8f6; color: var(--muted); }
.comment-list a { color: var(--forest); text-decoration: none; }
.comment-form { display: grid; grid-template-columns: 150px 1fr auto; gap: 8px; align-items: center; }
.comment-form input { min-height: 40px; border: 1px solid var(--line); border-radius: 999px; padding: 0 14px; font: inherit; }
.creator-row img { width: 46px; height: 46px; border-radius: 50%; object-fit: cover; }
.creator-row span { display: grid; }
.creator-row small { color: var(--muted); }
.post-detail-hero { padding: 42px 0 28px; color: white; background: radial-gradient(circle at 80% 10%, rgba(242,140,40,.22), transparent 28%), linear-gradient(135deg, #102b3a, #174735); }
.post-detail-grid { display: grid; grid-template-columns: minmax(0, 1fr) 270px; gap: 24px; align-items: end; }
.post-detail-hero h1 { margin: 10px 0 16px; font-size: clamp(2.2rem, 5vw, 5rem); }
.back-link { color: rgba(255,255,255,.84); font-weight: 900; text-decoration: none; }
.post-detail-type { display: inline-flex; margin-top: 18px; padding: 7px 11px; border-radius: 999px; background: rgba(255,255,255,.14); border: 1px solid rgba(255,255,255,.18); font-weight: 950; }
.detail-author { margin-bottom: 0; }
.detail-author span, .detail-author a { color: rgba(255,255,255,.86); }
.post-detail-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; padding: 16px; border: 1px solid rgba(255,255,255,.22); border-radius: 16px; background: rgba(255,255,255,.13); }
.post-detail-stats > strong { grid-column: 1 / -1; color: white; font-size: 3rem; line-height: 1; }
.post-detail-stats > span { grid-column: 1 / -1; color: rgba(255,255,255,.76); font-weight: 900; margin-top: -6px; }
.post-detail-stats div { padding: 10px; border-radius: 12px; background: rgba(255,255,255,.12); }
.post-detail-stats b, .post-detail-stats small { display: block; color: white; }
.post-detail-stats small { color: rgba(255,255,255,.72); }
.post-detail-layout { display: grid; grid-template-columns: minmax(0, 1fr) 340px; gap: 22px; align-items: start; }
.post-reader { padding: 22px; }
.post-detail-media { width: 100%; max-height: 620px; object-fit: cover; border-radius: 14px; margin-bottom: 16px; background: #dfe7e1; }
.post-body { font-size: 1.06rem; }
.post-comments { margin-top: 24px; padding-top: 20px; border-top: 1px solid var(--line); }
.post-comment-form { grid-template-columns: 1fr auto; }
.related-post-link { display: block; padding: 13px 0; border-bottom: 1px solid var(--line); text-decoration: none; }
.related-post-link:last-child { border-bottom: 0; }
.related-post-link strong { color: var(--forest); }
.related-post-link span { display: block; color: var(--muted); margin-top: 4px; font-size: .86rem; }
.explore-studio { padding: 24px 0 18px; color: white; background: radial-gradient(circle at 80% 16%, rgba(242,140,40,.24), transparent 28%), linear-gradient(135deg, #102b3a, #174735); }
.explore-studio-grid { display: grid; grid-template-columns: minmax(0, 1fr) 300px; gap: 24px; align-items: end; }
.explore-studio-copy h1 { margin: 8px 0 12px; font-size: clamp(2rem, 4vw, 4.2rem); max-width: 920px; }
.explore-studio-copy p { max-width: 760px; margin: 0; color: rgba(255,255,255,.78); line-height: 1.68; }
.explore-searchbar { width: min(780px, 100%); display: grid; grid-template-columns: 1fr auto; gap: 10px; margin-top: 22px; padding: 10px; border: 1px solid rgba(255,255,255,.22); border-radius: 16px; background: rgba(255,255,255,.13); backdrop-filter: blur(16px); }
.explore-searchbar input { min-height: 50px; border: 0; border-radius: 12px; padding: 0 14px; font: inherit; }
.explore-live-card { display: grid; gap: 7px; padding: 18px; border: 1px solid rgba(255,255,255,.22); border-radius: 18px; background: rgba(255,255,255,.13); backdrop-filter: blur(16px); }
.explore-live-card > span, .explore-live-card small { color: rgba(255,255,255,.78); font-weight: 900; }
.explore-live-card > strong { font-size: 4rem; line-height: 1; color: white; }
.explore-live-card div { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin-top: 8px; }
.explore-live-card b, .explore-live-card em { display: block; padding: 8px 6px; border-radius: 10px; background: rgba(255,255,255,.12); color: white; text-align: center; font-style: normal; }
.explore-live-card em { margin-top: -8px; color: rgba(255,255,255,.72); font-size: .72rem; font-weight: 800; }
.explore-hub { margin-top: -8px; }
.explore-format-grid { display: flex; gap: 10px; padding: 12px 0; overflow-x: auto; scroll-snap-type: x proximity; }
.explore-format-grid a { min-width: 148px; min-height: 72px; display: grid; grid-template-columns: 38px 1fr; align-items: center; column-gap: 9px; padding: 10px; border: 1px solid var(--line); border-radius: 14px; background: white; box-shadow: 0 12px 32px rgba(18,71,52,.08); text-decoration: none; transition: transform .18s ease, border-color .18s ease; scroll-snap-align: start; }
.explore-format-grid a:hover { transform: translateY(-3px); border-color: rgba(18,71,52,.32); }
.explore-format-grid span { width: 36px; height: 36px; display: grid; place-items: center; border-radius: 50%; background: #edf7ef; color: var(--forest); font-size: .68rem; font-weight: 950; }
.explore-format-grid strong { color: var(--forest); font-size: .9rem; }
.explore-format-grid small { grid-column: 2; color: var(--muted); font-weight: 750; font-size: .75rem; }
.explore-format-grid a.active { background: var(--forest); border-color: var(--forest); }
.explore-format-grid a.active span { background: rgba(255,255,255,.16); color: white; }
.explore-format-grid a.active strong, .explore-format-grid a.active small { color: white; }
.explore-trending-strip { display: grid; grid-template-columns: 260px minmax(0, 1fr); gap: 14px; align-items: center; margin: 4px 0 6px; padding: 14px; border: 1px solid var(--line); border-radius: 18px; background: linear-gradient(135deg, #fff, #eef7f2); box-shadow: var(--shadow); }
.explore-trending-strip strong { display: block; color: var(--forest); line-height: 1.35; }
.explore-trending-scroll { display: flex; gap: 10px; overflow-x: auto; }
.explore-trending-scroll a { min-width: 230px; display: grid; gap: 4px; padding: 12px; border: 1px solid var(--line); border-radius: 14px; background: white; text-decoration: none; }
.explore-trending-scroll span { width: 34px; height: 34px; display: grid; place-items: center; border-radius: 50%; background: var(--forest); color: white; font-size: .68rem; font-weight: 950; }
.explore-trending-scroll small { color: var(--muted); font-weight: 800; }
.explore-section-v2 { padding-top: 24px; }
.explore-app-layout { display: grid; grid-template-columns: 260px minmax(0, 1fr) 300px; gap: 18px; align-items: start; }
.explore-left-rail, .explore-right-rail { position: sticky; top: 92px; display: grid; gap: 16px; }
.explore-feed-v2 { display: grid; gap: 16px; min-width: 0; }
.question-mini { display: block; padding: 12px 0; border-bottom: 1px solid var(--line); text-decoration: none; }
.question-mini:last-child { border-bottom: 0; }
.question-mini strong { color: var(--forest); line-height: 1.35; }
.question-mini span { display: block; color: var(--muted); margin-top: 5px; font-size: .82rem; }
.studio-trigger { background: linear-gradient(135deg, #fff, #f0f8f3); }
.explore-join-card h2 { font-size: 1.7rem; }
.feed-toolbar { display: flex; justify-content: space-between; gap: 14px; align-items: end; padding: 6px 2px; }
.feed-toolbar h2 { margin-top: 4px; font-size: 1.7rem; }
.explore-post-card { display: grid; grid-template-columns: 220px minmax(0, 1fr); gap: 0; overflow: hidden; border: 1px solid var(--line); border-radius: 18px; background: white; box-shadow: var(--shadow); }
.post-card-media { display: block; min-height: 100%; background: #dfe7e1; }
.post-card-media img, .post-card-media video { width: 100%; height: 100%; min-height: 250px; object-fit: cover; display: block; }
.post-card-body { padding: 18px; min-width: 0; }
.post-card-body h2 { margin: 10px 0 8px; font-size: 1.55rem; }
.post-card-body h2 a { color: var(--ink); text-decoration: none; }
.post-card-body h2 a:hover { color: var(--forest); }
.post-card-body p { color: #33443c; line-height: 1.62; margin: 0; }
.post-intel-row { display: flex; flex-wrap: wrap; gap: 7px; margin: 12px 0; }
.post-intel-row span { display: inline-flex; padding: 6px 9px; border: 1px solid var(--line); border-radius: 999px; background: #f8fbf8; color: var(--forest); font-size: .76rem; font-weight: 850; }
.explore-post-card .explore-author { margin-bottom: 0; }
.explore-post-card .post-type-badge { min-width: 42px; height: 42px; display: grid; place-items: center; padding: 0; }
.profile-hero { padding: 70px 0 34px; color: white; background: linear-gradient(135deg, #102b3a, #174735); }
.profile-grid { display: grid; grid-template-columns: 170px 1fr 280px; gap: 24px; align-items: center; }
.profile-avatar { width: 170px; height: 170px; border-radius: 50%; object-fit: cover; border: 5px solid rgba(255,255,255,.25); }
.profile-grid p { color: rgba(255,255,255,.8); line-height: 1.7; }
.follow-card { display: grid; gap: 12px; padding: 16px; border: 1px solid rgba(255,255,255,.22); border-radius: 16px; background: rgba(255,255,255,.13); }
.follow-card form { display: grid; }
.auth-hero { min-height: 78vh; display: grid; align-items: center; background: linear-gradient(135deg, #0e3328, #1d5970); color: white; padding: 54px 0; }
.auth-card { display: grid; grid-template-columns: 1fr 420px; gap: 32px; align-items: center; }
.auth-card.compact { grid-template-columns: 1fr 380px; }
.auth-card p { color: rgba(255,255,255,.78); line-height: 1.65; }
.auth-card form { display: grid; gap: 12px; padding: 22px; border: 1px solid rgba(255,255,255,.22); border-radius: 18px; background: rgba(255,255,255,.13); backdrop-filter: blur(16px); }
.auth-card label { color: rgba(255,255,255,.78); font-weight: 900; }
.auth-link { color: white; font-weight: 850; text-align: center; }
.guide-command-hero { background: linear-gradient(135deg, #143a5b, #124734); }
.user-dashboard-hero { background: linear-gradient(135deg, #123d4d, #4b5e2c); }
.super-command-hero { background: linear-gradient(135deg, #201335, #174735); }
.account-command { padding: 34px 0 22px; color: white; background: radial-gradient(circle at 84% 8%, rgba(242,140,40,.23), transparent 28%), linear-gradient(135deg, #102b3a, #174735); }
.account-hero-grid { display: grid; grid-template-columns: minmax(0, 1fr) 280px; gap: 22px; align-items: stretch; }
.account-profile-card { display: grid; grid-template-columns: 128px 1fr; gap: 20px; align-items: center; padding: 18px; border: 1px solid rgba(255,255,255,.2); border-radius: 20px; background: rgba(255,255,255,.12); backdrop-filter: blur(16px); }
.account-profile-card > img { width: 128px; height: 128px; object-fit: cover; border-radius: 26px; border: 4px solid rgba(255,255,255,.18); }
.account-profile-card h1 { margin: 8px 0 10px; font-size: clamp(2rem, 4.5vw, 4.8rem); }
.account-profile-card p { margin: 0; color: rgba(255,255,255,.78); line-height: 1.65; max-width: 780px; }
.account-hero-actions { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 18px; }
.account-hero-actions form { display: inline-flex; }
.account-completion { display: grid; align-content: center; gap: 8px; padding: 18px; border: 1px solid rgba(255,255,255,.2); border-radius: 20px; background: rgba(255,255,255,.12); backdrop-filter: blur(16px); }
.account-completion strong { font-size: 3.4rem; line-height: 1; color: white; }
.account-completion span { color: rgba(255,255,255,.82); font-weight: 950; }
.account-completion small { color: rgba(255,255,255,.72); font-weight: 800; }
.account-completion small.done { color: #c7f5d2; }
.account-progress { height: 9px; border-radius: 999px; background: rgba(255,255,255,.16); overflow: hidden; }
.account-progress i { display: block; height: 100%; border-radius: inherit; background: linear-gradient(90deg, #f28c28, #8bd37e); }
.account-tabs-wrap { position: sticky; top: 72px; z-index: 11; background: rgba(245,247,244,.92); backdrop-filter: blur(14px); border-bottom: 1px solid var(--line); }
.account-tabs { display: flex; gap: 9px; overflow-x: auto; padding: 12px 0; }
.account-tabs button { flex: 0 0 auto; min-height: 42px; border: 1px solid var(--line); border-radius: 999px; padding: 0 14px; background: white; color: var(--forest); font: inherit; font-weight: 950; cursor: pointer; }
.account-tabs button.is-active { background: var(--forest); color: white; border-color: var(--forest); }
.account-section { padding-top: 24px; }
.account-layout { display: grid; grid-template-columns: minmax(0, 1fr) 330px; gap: 22px; align-items: start; }
.account-main { min-width: 0; }
.account-side { position: sticky; top: 148px; display: grid; gap: 16px; }
.account-panel { display: none; scroll-margin-top: 150px; }
.account-panel.is-active { display: block; }
.account-kpis { display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px; margin-bottom: 16px; }
.account-kpis div { min-height: 112px; display: grid; align-content: center; padding: 18px; border: 1px solid var(--line); border-radius: 16px; background: white; box-shadow: var(--shadow); }
.account-kpis strong { color: var(--forest); font-size: 2.2rem; line-height: 1; }
.account-kpis span { color: var(--muted); font-weight: 900; margin-top: 6px; }
.account-split { display: grid; grid-template-columns: minmax(0, 1fr) minmax(320px, .78fr); gap: 16px; align-items: start; }
.account-post-row { display: grid; grid-template-columns: 44px 1fr; gap: 12px; align-items: center; padding: 12px 0; border-bottom: 1px solid var(--line); color: inherit; text-decoration: none; }
.account-post-row:last-child { border-bottom: 0; }
.account-post-row > span { width: 42px; height: 42px; display: grid; place-items: center; border-radius: 50%; background: #edf7ef; color: var(--forest); font-size: .72rem; font-weight: 950; }
.account-post-row strong { color: var(--forest); }
.account-post-row small { display: block; color: var(--muted); margin-top: 4px; }
.account-empty { padding: 24px; border: 1px dashed #bdd4c3; border-radius: 16px; background: #f8fbf8; }
.account-empty p { color: var(--muted); line-height: 1.6; }
.account-feed-link { display: block; color: inherit; text-decoration: none; }
.account-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.account-form-grid .full { grid-column: 1 / -1; }
.account-submit-row { display: flex; gap: 10px; justify-content: flex-end; flex-wrap: wrap; }
.account-place-list { display: grid; gap: 8px; margin-top: 14px; }
.account-place-list p { display: flex; justify-content: space-between; gap: 10px; margin: 0; padding: 11px 0; border-top: 1px solid var(--line); }
.account-place-list span { color: var(--muted); font-weight: 800; text-transform: capitalize; }
.account-submission-row { padding: 12px 0; border-bottom: 1px solid var(--line); }
.account-submission-row:last-child { border-bottom: 0; }
.account-submission-row span { display: block; color: var(--muted); margin-top: 4px; }
.compact-form { padding: 12px; border: 1px solid var(--line); border-radius: 14px; background: #f8fbf8; }
.module-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 12px; }
.module-grid a { display: block; padding: 18px; border: 1px solid var(--line); border-radius: 14px; text-decoration: none; background: #f7faf7; }
.module-grid strong { display: block; color: var(--forest); font-size: 2rem; }
.module-grid span { color: var(--muted); font-weight: 900; }
.changelog-hero { padding: 74px 0 46px; color: white; background: radial-gradient(circle at 80% 20%, rgba(242,140,40,.22), transparent 26%), linear-gradient(135deg, #102b3a, #174735); }
.changelog-hero h1 { margin: 8px 0 10px; font-size: clamp(2.4rem, 5vw, 5rem); }
.changelog-hero p { margin: 0; color: rgba(255,255,255,.78); font-size: 1.1rem; }
.changelog-list { display: grid; gap: 16px; }
.changelog-card { display: grid; grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr); gap: 24px; padding: 22px; border: 1px solid var(--line); border-radius: 18px; background: white; box-shadow: var(--shadow); }
.release-pill { display: inline-flex; min-height: 34px; align-items: center; padding: 0 12px; border-radius: 999px; background: #edf7ef; color: var(--forest); font-weight: 950; }
.changelog-card h2 { margin-top: 12px; }
.changelog-card ul { margin: 0; padding-left: 20px; line-height: 1.8; color: #33443c; }
.changelog-meta { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 14px; }
.changelog-meta span { padding: 7px 10px; border: 1px solid var(--line); border-radius: 999px; color: var(--muted); font-size: .82rem; font-weight: 850; }
.notfound-hero { padding: 76px 0 38px; color: white; background: radial-gradient(circle at 15% 20%, rgba(244,161,70,.26), transparent 28%), linear-gradient(135deg, rgba(16,43,58,.96), rgba(18,71,52,.95)); }
.notfound-hero h1 { max-width: 900px; margin: 10px 0 12px; font-size: clamp(2.4rem, 7vw, 6rem); line-height: .95; }
.notfound-hero p { max-width: 720px; color: rgba(255,255,255,.78); font-size: 1.1rem; line-height: 1.7; }
.notfound-search { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 10px; max-width: 760px; margin-top: 24px; }
.notfound-search input { min-height: 52px; border: 1px solid rgba(255,255,255,.2); border-radius: 999px; padding: 0 18px; background: rgba(255,255,255,.96); font: inherit; }
.notfound-stat-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; margin-top: -28px; position: relative; z-index: 2; }
.notfound-stat { padding: 18px; border: 1px solid var(--line); border-radius: 18px; background: white; box-shadow: var(--shadow); }
.notfound-stat strong { display: block; color: var(--forest); font-size: 2rem; line-height: 1; }
.notfound-stat span { display: block; margin-top: 6px; color: var(--muted); font-weight: 900; }
.notfound-grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: 20px; align-items: start; }
.notfound-panel { padding: 22px; border: 1px solid var(--line); border-radius: 20px; background: white; box-shadow: var(--shadow); }
.notfound-links { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
.notfound-links a { min-height: 58px; display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 0 16px; border: 1px solid var(--line); border-radius: 14px; text-decoration: none; background: #f8fbf8; font-weight: 950; color: var(--forest); }
.notfound-links a span { color: var(--muted); font-size: .84rem; }
.notfound-card-list { display: grid; gap: 10px; margin-top: 12px; }
.notfound-mini-card { display: grid; grid-template-columns: 54px minmax(0, 1fr); gap: 12px; align-items: center; padding: 10px; border: 1px solid var(--line); border-radius: 14px; color: inherit; text-decoration: none; background: #fbfdfb; }
.notfound-mini-card img, .notfound-mini-thumb { width: 54px; height: 54px; border-radius: 12px; object-fit: cover; background: linear-gradient(135deg, #dfe9e1, #f4eadc); display: grid; place-items: center; color: var(--forest); font-weight: 950; }
.notfound-mini-card strong { display: block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.notfound-mini-card small { color: var(--muted); font-weight: 800; }
.heritage-hero { background-position: center; }
.heritage-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; }
.heritage-card { min-height: 260px; display: flex; flex-direction: column; justify-content: space-between; gap: 18px; padding: 22px; border: 1px solid var(--line); border-radius: 20px; background: radial-gradient(circle at 80% 15%, rgba(244,161,70,.16), transparent 28%), white; box-shadow: var(--shadow); text-decoration: none; color: inherit; transition: transform .18s ease, box-shadow .18s ease; }
.heritage-card:hover { transform: translateY(-3px); box-shadow: 0 22px 70px rgba(18,71,52,.16); }
.heritage-card span { display: inline-flex; width: fit-content; min-height: 30px; align-items: center; padding: 0 10px; border-radius: 999px; background: #edf7ef; color: var(--forest); font-weight: 950; font-size: .78rem; text-transform: uppercase; letter-spacing: .08em; }
.heritage-card strong { display: block; margin-top: 16px; font-size: 1.35rem; line-height: 1.1; color: var(--forest); }
.heritage-card p { color: var(--muted); line-height: 1.55; }
.heritage-card small { color: #4c6258; font-weight: 900; }
.heritage-card em { color: var(--muted); font-style: normal; font-weight: 800; }
.festival-hero { background-position: center; }
.festival-filter { margin-bottom: 22px; }
.festival-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; }
.festival-card { min-height: 280px; display: flex; flex-direction: column; justify-content: space-between; gap: 18px; padding: 22px; border: 1px solid var(--line); border-radius: 20px; background: radial-gradient(circle at 82% 12%, rgba(244,161,70,.18), transparent 30%), linear-gradient(180deg, #fff, #f9fcf8); box-shadow: var(--shadow); color: inherit; text-decoration: none; transition: transform .18s ease, box-shadow .18s ease; }
.festival-card:hover { transform: translateY(-3px); box-shadow: 0 22px 70px rgba(18,71,52,.16); }
.festival-card span { display: inline-flex; width: fit-content; min-height: 30px; align-items: center; padding: 0 10px; border-radius: 999px; background: #fff2df; color: #8a4a10; font-weight: 950; font-size: .78rem; text-transform: uppercase; letter-spacing: .08em; }
.festival-card strong { display: block; margin-top: 14px; font-size: 1.35rem; line-height: 1.08; color: var(--forest); }
.festival-card p, .festival-card small { color: var(--muted); line-height: 1.55; }
.festival-meta { display: flex; flex-wrap: wrap; gap: 8px; }
.festival-meta em { min-height: 30px; display: inline-flex; align-items: center; padding: 0 10px; border-radius: 999px; background: #edf7ef; color: var(--forest); font-style: normal; font-weight: 850; font-size: .82rem; }
.festival-guide-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; }
.festival-guide-card { padding: 18px; border: 1px solid var(--line); border-radius: 18px; background: white; box-shadow: var(--shadow); }
.festival-guide-card span { color: var(--muted); font-weight: 900; text-transform: uppercase; letter-spacing: .09em; font-size: .74rem; }
.festival-guide-card strong { display: block; margin-top: 8px; color: var(--forest); font-size: 1.15rem; }
.festival-timeline { display: grid; gap: 12px; counter-reset: festival-step; }
.festival-timeline article { position: relative; padding: 18px 18px 18px 54px; border: 1px solid var(--line); border-radius: 18px; background: white; box-shadow: var(--shadow); }
.festival-timeline article::before { counter-increment: festival-step; content: counter(festival-step); position: absolute; left: 16px; top: 18px; width: 26px; height: 26px; border-radius: 999px; background: var(--forest); color: white; display: grid; place-items: center; font-weight: 950; }
.festival-timeline strong { color: var(--forest); }
.festival-faq { display: grid; gap: 10px; }
.festival-faq details { padding: 16px; border: 1px solid var(--line); border-radius: 16px; background: white; }
.festival-faq summary { cursor: pointer; font-weight: 950; color: var(--forest); }
.mini-editor { border: 1px solid var(--line); border-radius: 14px; overflow: hidden; background: white; }
.mini-editor-toolbar { display: flex; flex-wrap: wrap; gap: 6px; padding: 8px; border-bottom: 1px solid var(--line); background: #f8fbf8; }
.mini-editor-toolbar button { min-height: 34px; border: 1px solid var(--line); border-radius: 10px; background: white; color: var(--forest); font-weight: 900; padding: 0 10px; cursor: pointer; }
.mini-editor-area { min-height: 170px; padding: 12px; line-height: 1.65; outline: 0; }
.mini-editor-area:focus { box-shadow: inset 0 0 0 2px rgba(18,71,52,.18); }
.guide-package-link { display: grid; grid-template-columns: 96px minmax(0, 1fr); gap: 14px; align-items: center; padding: 12px; margin-top: 10px; border: 1px solid var(--line); border-radius: 16px; background: linear-gradient(180deg, #fff, #f8fbf8); color: inherit; text-decoration: none; transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease; }
.guide-package-link:hover { transform: translateY(-2px); border-color: rgba(18,71,52,.28); box-shadow: 0 18px 50px rgba(18,71,52,.12); }
.guide-package-link img { width: 96px; height: 78px; object-fit: cover; border-radius: 12px; }
.guide-package-link strong { display: block; color: var(--forest); font-size: 1.03rem; }
.guide-package-link small { display: block; color: var(--muted); line-height: 1.45; margin-top: 4px; }
.guide-package-link em { display: inline-flex; width: fit-content; margin-top: 8px; padding: 6px 10px; border-radius: 999px; background: #edf7ef; color: var(--forest); font-style: normal; font-weight: 950; font-size: .82rem; }
.guide-post-placeholder { display: grid; place-items: center; background: radial-gradient(circle at 80% 15%, rgba(244,161,70,.22), transparent 30%), linear-gradient(135deg, #123d4d, #174735); color: white; font-size: 2rem; font-weight: 950; }
.package-fact-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 10px; margin-top: 22px; }
.package-fact-grid div { padding: 16px; border: 1px solid var(--line); border-radius: 16px; background: #f8fbf8; }
.package-fact-grid strong { display: block; color: var(--forest); font-size: 1.2rem; }
.package-fact-grid span { display: block; margin-top: 4px; color: var(--muted); font-weight: 900; }
.package-booking-panel { position: sticky; top: 96px; }
.package-guide-card { display: grid; grid-template-columns: 70px minmax(0, 1fr); gap: 12px; align-items: center; margin: 12px 0 14px; padding: 12px; border: 1px solid var(--line); border-radius: 16px; background: #f8fbf8; }
.package-guide-card img { width: 70px; height: 70px; object-fit: cover; border-radius: 18px; }
.package-guide-card strong { display: block; color: var(--forest); }
.package-guide-card small { display: block; color: var(--muted); margin: 3px 0 7px; line-height: 1.35; }
.package-guide-card a { color: var(--forest); font-weight: 950; text-decoration: none; }
.booking-form { display: grid; gap: 12px; margin-top: 16px; }
.form-grid.compact { grid-template-columns: 1fr 1fr; gap: 10px; }
@media (max-width: 900px) {
  .topbar { position: sticky; }
  .nav { min-height: 62px; display: grid; grid-template-columns: minmax(0, 1fr) auto; align-items: center; padding: 10px 0; }
  .brand { font-size: 1rem; min-width: 0; }
  .brand-mark { width: 30px; height: 30px; border-radius: 9px; }
  .mobile-menu-toggle { display: inline-flex; position: static; justify-self: end; }
  .public-menu { display: none; grid-column: 1 / -1; width: 100%; margin-left: 0; padding-top: 10px; }
  .public-menu.is-open { display: grid; gap: 10px; }
  .topbar .nav-links { display: grid; width: 100%; grid-template-columns: 1fr; gap: 8px; padding-top: 0; }
  .nav-links a { width: 100%; padding: 12px; border: 1px solid var(--line); border-radius: 10px; background: white; }
  .nav-more div { position: static; box-shadow: none; margin-top: 6px; }
  .nav-more summary { width: 100%; border: 1px solid var(--line); border-radius: 10px; background: white; }
  .topbar .search { display: grid; grid-template-columns: 1fr; width: 100%; padding-top: 0; }
  .topbar .search input { width: 100%; }
  .topbar .search button { width: 100%; justify-content: center; }
  .topbar .search .admin-link { display: none !important; }
  .search:not(.topbar .search) { grid-template-columns: 1fr auto; width: 100%; }
  .filter, .detail-panel, .admin-layout, .form-grid { grid-template-columns: 1fr; display: grid; width: 100%; }
  .city-facts-strip { grid-template-columns: 1fr 1fr; }
  .footer-cta, .footer-grid { grid-template-columns: 1fr; }
  .footer-search { grid-template-columns: 1fr; }
  .card, .card.wide { grid-column: span 12; }
  .hero { min-height: 500px; }
  .pn-hero { min-height: 820px; }
  .pn-hero-grid, .pn-split-feature, .pn-motion-grid, .pn-planner, .pn-final, .pn-planner form { grid-template-columns: 1fr; }
  .pn-hero-strip, .pn-mood-grid, .pn-feature-grid, .pn-nature-grid, .pn-guide-row, .pn-practical, .pn-reel-grid, .pn-region-list { grid-template-columns: 1fr; }
  .pn-feature-grid .pn-image-card:first-child { min-height: 360px; }
  .pn-hero-search { grid-template-columns: 1fr; }
  .pn-live-panel { display: none; }
  .pn-route-list a { grid-template-columns: 1fr; }
  .pn-search-dock { top: 0; }
  .admin-hero, .admin-savebar { flex-direction: column; align-items: stretch; }
  .admin-side { position: static; height: auto; }
  .admin-metrics, .admin-relation-grid, .photo-grid, .park-feature-nav, .experience-grid, .activity-card-grid, .search-hero-grid, .search-command-grid, .explore-hero-grid, .explore-top-grid, .search-result-grid, .search-card-grid, .intel-grid, .dashboard-row, .social-layout, .profile-grid, .comment-form, .auth-card, .auth-card.compact, .module-grid, .admin-filter, .check-grid, .composer-grid, .user-home-layout, .post-detail-grid, .post-detail-layout, .account-hero-grid, .account-profile-card, .account-layout, .account-kpis, .account-split, .account-form-grid { grid-template-columns: 1fr; }
  .span-8, .span-5, .span-4, .span-3 { grid-column: span 1; }
  .social-sidebar { position: static; }
  .search-result-card { grid-template-columns: 1fr; }
  .explore-command { top: 0; }
  .search-type-rail { top: 0; }
  .search-summary { align-items: stretch; flex-direction: column; }
  .search-suggestions { justify-content: flex-start; }
  .search-glass { grid-template-columns: 1fr; }
  .account-tabs-wrap { top: 0; }
  .account-side { position: static; }
  .composer-trigger { grid-template-columns: 44px 1fr; }
  .composer-trigger strong { grid-column: 1 / -1; justify-content: center; }
  .explore-studio-grid, .explore-app-layout, .explore-trending-strip { grid-template-columns: 1fr; }
  .explore-live-card { display: none; }
  .explore-left-rail, .explore-right-rail { position: static; }
  .explore-post-card { grid-template-columns: 1fr; }
  .pagination-desktop { display: grid; justify-items: start; }
  .pagination-pages { justify-content: flex-start; }
  .changelog-card { grid-template-columns: 1fr; }
  .notfound-search, .notfound-grid, .notfound-stat-grid, .notfound-links, .heritage-grid, .festival-grid, .festival-guide-grid, .lake-guide-grid, .park-filter, .park-directory-grid, .park-guide-grid, .package-fact-grid, .form-grid.compact { grid-template-columns: 1fr; }
  .package-booking-panel { position: static; }
  .guide-package-link { grid-template-columns: 84px minmax(0, 1fr); }
  .guide-package-link img { width: 84px; height: 72px; }
  .lake-planner-card { position: static; }
  .notfound-hero { padding-top: 48px; }
}
