/* Masbate Voices — Clean Civic Freedom Wall */
:root{
  --mv-navy:#122033;
  --mv-blue:#2563eb;
  --mv-blue-dark:#1d4ed8;
  --mv-paper:#f7f8fb;
  --mv-card:#ffffff;
  --mv-card-soft:#fbfcff;
  --mv-border:#e1e6ef;
  --mv-muted:#687386;
  --mv-ink:#17212f;
  --mv-text-soft:#344054;
  --mv-soft:#eef4ff;
  --mv-field:#ffffff;
  --mv-page:#f8fafc;
  --mv-nav:rgba(255,255,255,.9);
  --mv-shadow:rgba(18,32,51,.08);
  --mv-green:#14845a;
  --mv-yellow:#9a6a00;
  --mv-red:#b42318;
  --mv-line:rgba(18,32,51,.11);
}

:root[data-theme="dark"]{
  color-scheme:dark;
  --mv-navy:#e8eef8;
  --mv-blue:#8ab4ff;
  --mv-blue-dark:#a8c7ff;
  --mv-paper:#0f1724;
  --mv-card:#151f2e;
  --mv-card-soft:#111a27;
  --mv-border:#2a374a;
  --mv-muted:#98a6ba;
  --mv-ink:#e6edf7;
  --mv-text-soft:#c3ccda;
  --mv-soft:#1b2b45;
  --mv-field:#101927;
  --mv-page:#0b111b;
  --mv-nav:rgba(15,23,36,.92);
  --mv-shadow:rgba(0,0,0,.32);
  --mv-green:#69d39d;
  --mv-yellow:#f2cc72;
  --mv-red:#ff9b92;
  --mv-line:rgba(232,238,248,.07);
}

body{
  font-family:Inter,system-ui,sans-serif;
  color:var(--mv-ink);
  background:
    linear-gradient(var(--mv-line) 1px,transparent 1px),
    linear-gradient(90deg,var(--mv-line) 1px,transparent 1px),
    var(--mv-page);
  background-size:32px 32px;
}

button,input,select,textarea,.btn,.form-control,.form-select,.navbar{
  font-family:Inter,system-ui,sans-serif;
}

a{color:var(--mv-blue)}
.btn-primary{--bs-btn-bg:var(--mv-navy);--bs-btn-border-color:var(--mv-navy);--bs-btn-color:var(--mv-card);--bs-btn-hover-bg:#1d3049;--bs-btn-hover-border-color:#1d3049;--bs-btn-hover-color:#fff}
.btn-outline-primary{--bs-btn-color:var(--mv-navy);--bs-btn-border-color:var(--mv-navy);--bs-btn-hover-bg:var(--mv-navy);--bs-btn-hover-border-color:var(--mv-navy)}
.btn-light{--bs-btn-bg:var(--mv-card);--bs-btn-border-color:var(--mv-border);--bs-btn-color:var(--mv-ink);--bs-btn-hover-bg:var(--mv-soft);--bs-btn-hover-border-color:var(--mv-border);--bs-btn-hover-color:var(--mv-ink)}
.btn-outline-secondary{--bs-btn-color:var(--mv-text-soft);--bs-btn-border-color:var(--mv-border);--bs-btn-hover-bg:var(--mv-soft);--bs-btn-hover-border-color:var(--mv-border);--bs-btn-hover-color:var(--mv-ink)}
.text-primary{color:var(--mv-blue)!important}
.text-muted{color:var(--mv-muted)!important}
.xsmall{font-size:.72rem}
.min-w-0{min-width:0}

/* Header */
.navbar{background:var(--mv-nav)!important;backdrop-filter:blur(16px);border-bottom:1px solid var(--mv-border)!important}
.brand-logo-wrap{display:block;width:56px;height:56px;flex:0 0 56px}
.brand-logo{display:block;width:56px;height:56px;border-radius:12px;object-fit:cover}
.brand-logo-light{display:none}
:root[data-theme="dark"] .brand-logo-default{display:none}
:root[data-theme="dark"] .brand-logo-light{display:block}
.navbar-brand{min-width:0}
.brand-name{text-transform:uppercase;letter-spacing:.08em;font-weight:800;line-height:1;color:var(--mv-navy)}
.brand-tag{font-size:11px;color:var(--mv-muted);line-height:1.2}
.nav-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;border:2px solid #eef2f7}
.searchnav{max-width:420px;width:100%}
.nav-link{font-size:.9rem;font-weight:600;color:var(--mv-text-soft)!important}
.theme-nav-item{margin-left:8px;margin-right:10px}
.theme-toggle{width:38px;height:38px;border-radius:999px;border:1px solid var(--mv-border);background:var(--mv-card);color:var(--mv-ink);display:inline-flex;align-items:center;justify-content:center;font-weight:900;line-height:1;transition:background .15s ease,border-color .15s ease,transform .15s ease}
.theme-toggle:hover{background:var(--mv-soft);border-color:#b9c7dd;transform:translateY(-1px)}
.theme-toggle-icon{font-size:1rem}
.google-mark{width:16px;height:16px;flex:0 0 16px}
.navbar-toggler{border-color:var(--mv-border)}
.navbar-toggler:focus{box-shadow:0 0 0 .18rem rgba(37,99,235,.14)}
.navbar-toggler-icon{background-image:none!important;position:relative;width:1.35em;height:1.35em;color:var(--mv-ink)}
.navbar-toggler-icon::before,.navbar-toggler-icon::after{content:"";position:absolute;left:2px;right:2px;height:2px;border-radius:999px;background:currentColor;transition:transform .15s ease,top .15s ease,bottom .15s ease}
.navbar-toggler-icon::before{top:5px}
.navbar-toggler-icon::after{bottom:5px}
.navbar-toggler-icon{display:inline-flex;align-items:center;justify-content:center}
.navbar-toggler-icon:empty{background:linear-gradient(currentColor,currentColor) center/70% 2px no-repeat}

/* Dashboard */
.wall-shell{min-height:70vh}
.wall-kicker{text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;color:var(--mv-muted);font-weight:800}
.wall-title{max-width:760px;font-size:clamp(2.1rem,5vw,4.3rem);line-height:.98;color:var(--mv-navy);letter-spacing:0}
.wall-subtitle{max-width:680px;color:var(--mv-text-soft);font-size:1.05rem;line-height:1.7}
.wall-actions{display:flex;flex-wrap:wrap;gap:10px}
.wall-pulse{display:grid;grid-template-columns:1fr 1fr;gap:1px;border:1px solid var(--mv-border);background:var(--mv-border);border-radius:14px;overflow:hidden}
.wall-pulse div{background:var(--mv-card);padding:18px}
.wall-pulse strong{display:block;color:var(--mv-navy);font-size:1.6rem;line-height:1;font-weight:900}
.wall-pulse span{display:block;margin-top:6px;color:var(--mv-muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;font-weight:700}
.dashboard-header{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,420px);align-items:stretch;gap:24px;background:color-mix(in srgb,var(--mv-card) 88%,transparent);border:1px solid var(--mv-border);border-radius:8px;padding:22px;margin-bottom:12px}
.dashboard-header h1{font-size:clamp(1.8rem,3vw,3rem);line-height:1;color:var(--mv-navy);letter-spacing:0;margin:0 0 8px;font-weight:900}
.dashboard-header p{max-width:640px;color:var(--mv-muted);font-size:.98rem;line-height:1.6;margin:0}
.dashboard-primary-action{margin-top:22px;padding:.92rem 1.35rem;font-size:1rem;border-radius:10px;min-width:190px}
.dashboard-side{display:grid;align-items:stretch}
.dashboard-metrics{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.dashboard-metrics div{background:var(--mv-card);border:1px solid var(--mv-border);border-radius:8px;padding:15px}
.dashboard-metrics strong{display:block;color:var(--mv-navy);font-size:1.45rem;line-height:1;font-weight:900}
.dashboard-metrics span{display:block;margin-top:7px;color:var(--mv-muted);font-size:.72rem;text-transform:uppercase;letter-spacing:.07em;font-weight:800}
.wall-intro-modal .modal-content{background:var(--mv-card);color:var(--mv-ink);border:1px solid var(--mv-border);border-radius:12px;box-shadow:0 24px 70px rgba(18,32,51,.24)}
.wall-intro-modal .modal-body{position:relative;padding:28px}
.wall-intro-modal .btn-close{position:absolute;top:18px;right:18px}
.wall-intro-modal .wall-title{padding-right:34px}
.modal-impact{max-width:720px;color:var(--mv-navy);font-weight:700;line-height:1.75;padding-left:16px;border-left:4px solid var(--mv-blue)}
.login-required-modal .modal-content{background:var(--mv-card);color:var(--mv-ink);border:1px solid var(--mv-border);border-radius:12px;box-shadow:0 24px 70px rgba(18,32,51,.24)}
.login-required-modal .modal-body{position:relative;padding:28px}
.login-required-modal .btn-close{position:absolute;top:18px;right:18px}
.login-required-modal h2{max-width:420px;color:var(--mv-navy);font-size:clamp(1.6rem,4vw,2.55rem);line-height:1.04;font-weight:900;margin:0 0 14px}
.login-required-modal p{color:var(--mv-text-soft);line-height:1.75;margin:0}
.login-required-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.anonymous-status-modal .modal-content{background:var(--mv-card);color:var(--mv-ink);border:1px solid var(--mv-border);border-radius:12px;box-shadow:0 24px 70px rgba(18,32,51,.24)}
.anonymous-status-modal .modal-body{position:relative;padding:28px}
.anonymous-status-modal .btn-close{position:absolute;top:18px;right:18px}
.anonymous-status-modal h2{max-width:420px;color:var(--mv-navy);font-size:clamp(1.55rem,4vw,2.35rem);line-height:1.05;font-weight:900;margin:0 0 14px}
.anonymous-status-modal p{color:var(--mv-text-soft);line-height:1.75;margin:0}
.anonymous-status-actions{display:flex;justify-content:flex-end;margin-top:24px}

/* Panels */
.civic-panel,.card{border:1px solid var(--mv-border)!important;border-radius:8px!important;box-shadow:none!important;background:var(--mv-card);color:var(--mv-ink)}
.panel-title{text-transform:uppercase;letter-spacing:.11em;font-size:.76rem;font-weight:800;color:var(--mv-navy)}

/* Tables (admin "Recent Reports" etc.) — make Bootstrap tables theme-aware so
   they go fully dark in dark mode instead of keeping default light styling. */
.table{--bs-table-color:var(--mv-ink);--bs-table-bg:transparent;--bs-table-border-color:var(--mv-border);--bs-table-striped-color:var(--mv-ink);--bs-table-striped-bg:var(--mv-card-soft);--bs-table-hover-color:var(--mv-ink);--bs-table-hover-bg:var(--mv-soft);color:var(--mv-ink);border-color:var(--mv-border)}
.table>:not(caption)>*>*{background-color:transparent;color:var(--mv-ink);border-bottom-color:var(--mv-border)}
.table thead th{color:var(--mv-muted);border-bottom-color:var(--mv-border)}
.table a{color:var(--mv-ink)}

/* Wall controls */
.wall-board{position:relative}
.filter-toggle[aria-expanded="true"]{background:var(--mv-soft);border-color:#b9c7dd;color:var(--mv-ink)}
.wall-toolbar{display:grid;grid-template-columns:minmax(220px,1.4fr) minmax(170px,1fr) minmax(170px,1fr) minmax(150px,.8fr) auto;gap:12px;align-items:end;background:var(--mv-card);border:1px solid var(--mv-border);border-radius:8px;padding:14px;margin-bottom:14px}
.filter-panel{display:none}
.filter-panel.is-open{display:grid}
.wall-toolbar .form-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;font-weight:800;color:var(--mv-muted);margin-bottom:6px}
.toolbar-actions{display:flex;gap:8px}
.signal-row{display:flex;align-items:center;gap:8px;overflow:auto;padding:5px 0 20px}
.signal-label{flex:0 0 auto;color:var(--mv-muted);font-size:.74rem;text-transform:uppercase;letter-spacing:.08em;font-weight:800}
.signal-chip{display:block;flex:0 0 auto;text-decoration:none;color:var(--mv-ink);background:var(--mv-card);border:1px solid var(--mv-border);border-radius:999px;padding:7px 11px;font-size:.82rem;font-weight:700;max-width:260px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.signal-chip span{display:inline-flex;min-width:22px;height:22px;border-radius:999px;background:var(--mv-soft);align-items:center;justify-content:center;margin-left:6px;color:var(--mv-blue);font-size:.72rem}
.signal-chip:hover{border-color:#b9c7dd;color:var(--mv-blue)}
.wall-heading{display:flex;align-items:end;justify-content:space-between;gap:20px;margin:8px 0 18px}
.wall-heading h2{font-size:1rem;text-transform:uppercase;letter-spacing:.12em;font-weight:900;color:var(--mv-navy);margin:0}
.wall-heading p{max-width:520px;margin:0;color:var(--mv-muted);font-size:.92rem;text-align:right}

/* Wall entries */
.feed-title{text-transform:uppercase;letter-spacing:.12em;font-size:.78rem;font-weight:800;color:var(--mv-navy);border:0;padding:0}
.wall-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;align-items:start}
.report-card{position:relative;overflow:hidden;border:1px solid var(--mv-border);border-radius:8px;background:var(--mv-card);transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease}
.report-card:hover{transform:translateY(-2px);border-color:#8291a8;box-shadow:0 14px 28px var(--mv-shadow)}
.report-card.pinned{border-color:#d8b46a;box-shadow:inset 0 3px 0 #c88719}
.cat-ico{display:none}
.report-image-link{display:block;background:var(--mv-card-soft)}
.report-thumb{width:100%;height:180px;object-fit:cover;border-bottom:1px solid var(--mv-border)}
.report-body{padding:17px 17px 14px}
.report-topline{display:flex;align-items:center;gap:8px;color:var(--mv-muted);font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;font-weight:800;margin-bottom:12px}
.dot-sep{width:4px;height:4px;border-radius:50%;background:#c5cbd6}
.pin-flag{font-size:.72rem;color:#8a5a00;font-weight:800;text-transform:uppercase;letter-spacing:.08em}
.stretched-link-title{color:inherit;text-decoration:none}
.stretched-link-title:hover h3{color:var(--mv-blue)}
.report-card h3{font-size:1.12rem!important;line-height:1.28;color:var(--mv-navy);letter-spacing:0}
.report-desc{color:var(--mv-text-soft);font-size:.94rem;line-height:1.58;display:-webkit-box;-webkit-line-clamp:5;-webkit-box-orient:vertical;overflow:hidden}
.report-meta{display:flex;flex-wrap:wrap;align-items:center;gap:8px;color:var(--mv-muted);font-size:.76rem}
.status-pill{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:4px 8px;font-size:.72rem;font-weight:800}
.status-pill::before{content:"";width:7px;height:7px;border-radius:999px;background:currentColor;opacity:.75}
.report-actions{display:flex;align-items:center;gap:10px;border-top:1px solid var(--mv-border);padding:11px 13px;background:var(--mv-card-soft)}
.confirm-btn{font-weight:700}
.comment-link{margin-left:auto;color:var(--mv-muted);font-size:.82rem;font-weight:700;text-decoration:none}
.comment-link:hover{color:var(--mv-blue)}
.empty-wall{grid-column:1/-1;text-align:center;color:var(--mv-muted);background:var(--mv-card);border:1px solid var(--mv-border);border-radius:8px;padding:54px 18px}
.empty-wall strong{display:block;color:var(--mv-navy);font-size:1.05rem;margin-bottom:6px}

/* About */
.about-page{min-height:70vh}
.about-hero{background:color-mix(in srgb,var(--mv-card) 90%,transparent);border:1px solid var(--mv-border);border-radius:8px;padding:clamp(24px,5vw,52px);margin-bottom:16px}
.about-hero h1{max-width:920px;font-size:clamp(2.35rem,5.4vw,5.8rem);line-height:.98;color:var(--mv-navy);letter-spacing:0;margin:0 0 18px;font-weight:900}
.about-lead{max-width:760px;color:var(--mv-text-soft);font-size:clamp(1.06rem,2vw,1.28rem);line-height:1.75;margin:0}
.about-urge{max-width:780px;color:var(--mv-navy);font-size:1.02rem;line-height:1.75;font-weight:700;margin:18px 0 0;padding-left:18px;border-left:4px solid var(--mv-blue)}
.about-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px}
.about-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:14px;margin-bottom:14px}
.about-card{background:var(--mv-card);border:1px solid var(--mv-border);border-radius:8px;padding:24px}
.about-card-large{grid-row:span 2}
.about-num{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:999px;background:var(--mv-soft);color:var(--mv-blue);font-weight:900;font-size:.82rem;margin-bottom:22px}
.about-card h2{color:var(--mv-navy);font-size:1.3rem;font-weight:900;margin:0 0 12px}
.about-card p{color:var(--mv-text-soft);font-size:1rem;line-height:1.75;margin:0}
.about-card p + p{margin-top:14px}
.about-statement{display:grid;grid-template-columns:minmax(0,1fr) minmax(280px,.75fr);gap:22px;align-items:start;background:var(--mv-navy);color:var(--mv-card);border-radius:8px;padding:clamp(24px,4vw,38px);margin-bottom:14px}
.about-statement .wall-kicker{color:color-mix(in srgb,var(--mv-card) 68%,transparent)}
.about-statement h2{font-size:clamp(1.6rem,3vw,3rem);line-height:1.05;font-weight:900;margin:0}
.about-statement p{color:color-mix(in srgb,var(--mv-card) 82%,transparent);line-height:1.8;margin:0}
.about-principles{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.about-principles div{background:var(--mv-card);border:1px solid var(--mv-border);border-radius:8px;padding:18px}
.about-principles strong{display:block;color:var(--mv-navy);font-weight:900;margin-bottom:6px}
.about-principles span{display:block;color:var(--mv-muted);font-size:.92rem;line-height:1.55}
.about-callout{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:24px;align-items:center;background:var(--mv-card);border:1px solid var(--mv-border);border-radius:8px;padding:clamp(22px,4vw,34px);margin-top:14px}
.about-callout h2{max-width:760px;color:var(--mv-navy);font-size:clamp(1.55rem,3vw,3.1rem);line-height:1.05;font-weight:900;margin:0 0 12px}
.about-callout p{max-width:840px;color:var(--mv-text-soft);line-height:1.8;margin:0}

/* Legal documents (privacy, terms) */
.legal-doc{max-width:820px;margin:0 auto}
.legal-doc .legal-updated{color:var(--mv-muted);font-size:.85rem;margin-bottom:24px}
.legal-doc h1{color:var(--mv-navy);font-size:clamp(1.7rem,3.4vw,2.6rem);font-weight:900;line-height:1.1;margin:0 0 6px}
.legal-doc h2{color:var(--mv-navy);font-size:1.18rem;font-weight:800;margin:30px 0 10px}
.legal-doc p,.legal-doc li{color:var(--mv-text-soft);line-height:1.75;font-size:.97rem}
.legal-doc ul{padding-left:1.2rem;margin-bottom:1rem}
.legal-doc li{margin-bottom:6px}
.legal-doc a{color:var(--mv-blue);font-weight:600}
.legal-doc .legal-note{background:var(--mv-card-soft);border:1px solid var(--mv-border);border-radius:8px;padding:14px 16px;margin:18px 0;font-size:.9rem}
.footer-links{display:flex;flex-wrap:wrap;justify-content:center;gap:8px 16px;margin-bottom:6px}
.footer-links a{color:var(--mv-muted);text-decoration:none;font-weight:600}
.footer-links a:hover{color:var(--mv-ink)}

/* Site Monitor (owner) */
.monitor-bars{display:flex;flex-direction:column;gap:7px}
.monitor-bar-row{display:grid;grid-template-columns:54px 1fr auto;align-items:center;gap:10px}
.monitor-bar-day{font-size:.74rem;color:var(--mv-muted);font-weight:700}
.monitor-bar-track{height:14px;background:var(--mv-soft);border-radius:999px;overflow:hidden}
.monitor-bar-fill{display:block;height:100%;background:var(--mv-blue);border-radius:999px;min-width:2px}
.monitor-bar-val{font-size:.76rem;font-weight:700;color:var(--mv-ink);white-space:nowrap}
.monitor-list{display:flex;flex-direction:column;gap:8px}
.monitor-list-row{display:flex;align-items:center;justify-content:space-between;gap:10px;font-size:.86rem;color:var(--mv-ink)}
.monitor-list-row .text-truncate{max-width:70%}
.monitor-feed{display:flex;flex-direction:column}
.monitor-feed-row{display:flex;gap:10px;align-items:flex-start;padding:10px 0;border-bottom:1px solid var(--mv-border)}
.monitor-feed-row:last-child{border-bottom:none}
.monitor-feed-type{flex:0 0 auto;margin-top:1px}
.monitor-feed-body{min-width:0}
.about-callout .btn{padding:.92rem 1.35rem;border-radius:10px;white-space:nowrap}

/* Badges */
.badge{font-weight:700}
.text-bg-success{background:#e7f6ee!important;color:#087443!important;border:1px solid #b7e4ca!important}
.text-bg-warning{background:#fff4d6!important;color:#8a5a00!important;border:1px solid #f7d98b!important}
.text-bg-info{background:#eaf2ff!important;color:#1849a9!important;border:1px solid #c8dcff!important}
.text-bg-secondary{background:#eef2f6!important;color:#475467!important;border:1px solid #d0d5dd!important}
.text-bg-light{background:var(--mv-soft)!important;color:var(--mv-text-soft)!important}

/* Sidebar */
.stat-box{background:var(--mv-card-soft);border:1px solid var(--mv-border);border-radius:8px;padding:14px 8px}
.stat-num{font-size:1.55rem;font-weight:900;color:var(--mv-navy);line-height:1}
.stat-lbl{font-size:.72rem;color:var(--mv-muted);text-transform:uppercase;letter-spacing:.05em}
.trending-item{display:block;padding:12px 0;border-bottom:1px solid var(--mv-border);text-decoration:none;color:inherit}
.trending-item:last-child{border-bottom:0}
.trending-item:hover .fw-semibold{color:var(--mv-blue)}

/* Forms */
.form-control,.form-select{background-color:var(--mv-field);border-color:var(--mv-border);color:var(--mv-ink);border-radius:8px;padding:.7rem .85rem}
.form-control::placeholder{color:var(--mv-muted)}
.form-select option{background:var(--mv-field);color:var(--mv-ink)}
.form-control:focus,.form-select:focus{box-shadow:0 0 0 .2rem rgba(36,87,214,.12);border-color:#84a2ef}
.form-label{color:var(--mv-text-soft)}
.detail-meter{margin-top:10px;border:1px solid var(--mv-border);background:var(--mv-card-soft);border-radius:8px;padding:12px}
.detail-meter-top{display:flex;align-items:center;justify-content:space-between;gap:12px;color:var(--mv-text-soft);font-size:.82rem;margin-bottom:9px}
.detail-meter-top strong{color:var(--mv-navy)}
.detail-word-count{color:var(--mv-muted);font-weight:700}
.detail-meter-bar{height:7px;background:var(--mv-soft);border-radius:999px;overflow:hidden;margin-bottom:10px}
.detail-meter-bar span{display:block;width:0;height:100%;background:var(--mv-blue);border-radius:999px;transition:width .16s ease}
.detail-checks{display:flex;flex-wrap:wrap;gap:7px}
.detail-checks span{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--mv-border);border-radius:999px;padding:5px 9px;color:var(--mv-muted);background:var(--mv-card);font-size:.76rem;font-weight:800}
.detail-checks span::before{content:"";width:7px;height:7px;border-radius:999px;background:currentColor;opacity:.35}
.detail-checks span.is-met{color:var(--mv-green);border-color:color-mix(in srgb,var(--mv-green) 42%,var(--mv-border))}
.detail-checks span.is-met::before{opacity:1}

/* Detail */
.detail-photo{margin:0;background:var(--mv-card-soft);border-top-left-radius:8px;border-top-right-radius:8px;overflow:hidden;border-bottom:1px solid var(--mv-border)}
.detail-image-open{display:block;width:100%;border:0;padding:0;background:var(--mv-card-soft);cursor:zoom-in}
.detail-image-open:hover .detail-img{filter:brightness(.96)}
.detail-img{display:block;width:100%;max-height:70vh;object-fit:contain;background:var(--mv-card-soft)}
.photo-viewer-dialog{width:auto;max-width:none;min-height:0!important;margin:18px auto}
.photo-viewer-modal.show .photo-viewer-dialog{transform:none}
.photo-viewer-modal .modal-content{position:relative;width:auto;margin:0 auto;background:transparent;border:0;box-shadow:none}
.photo-viewer-modal .modal-body{display:flex;align-items:center;justify-content:center;padding:0;overflow:hidden}
.photo-viewer-img{display:block;width:auto;height:auto;max-width:calc(100vw - 36px);max-height:calc(100vh - 72px);object-fit:contain;border-radius:8px;background:var(--mv-card);box-shadow:0 24px 70px rgba(0,0,0,.38)}
.photo-viewer-close{position:absolute;top:10px;right:10px;z-index:2;width:38px;height:38px;border:0;border-radius:999px;background:rgba(15,23,36,.72);color:#fff;font-size:28px;line-height:1;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 24px rgba(0,0,0,.28)}
.photo-viewer-close:hover{background:rgba(15,23,36,.92)}
.detail-desc{font-size:1.08rem;line-height:1.8;color:var(--mv-text-soft)}
.admin-post-actions{display:flex;align-items:center;justify-content:space-between;gap:14px;border:1px solid var(--mv-border);background:var(--mv-card-soft);border-radius:8px;padding:14px}

/* Compact post controls (edit/delete icons, top-right of a report) */
.post-controls{display:inline-flex;gap:6px}
.pc-btn{width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;border:1px solid var(--mv-border);background:var(--mv-card);color:var(--mv-muted);text-decoration:none;cursor:pointer;padding:0;transition:background .15s ease,color .15s ease,border-color .15s ease}
.pc-btn:hover{background:var(--mv-soft);color:var(--mv-ink);border-color:#b9c7dd}
.pc-btn.pc-danger:hover{background:color-mix(in srgb,var(--mv-red) 16%,var(--mv-card));color:var(--mv-red);border-color:color-mix(in srgb,var(--mv-red) 45%,var(--mv-border))}
.comment .c-av{width:36px;height:36px;border-radius:50%;background:var(--mv-soft);color:var(--mv-navy);display:flex;align-items:center;justify-content:center;font-weight:800;flex:0 0 36px}
.comment .c-body{background:var(--mv-card-soft);border:1px solid var(--mv-border);border-radius:8px;padding:10px 13px;flex:1}

/* Base modal theming (dark-mode safe) for plain Bootstrap modals */
.modal-content{background:var(--mv-card);color:var(--mv-ink);border:1px solid var(--mv-border)}
.modal-header,.modal-footer{border-color:var(--mv-border)}

/* Confirmers ("residents who experience this too") */
.confirmers{display:flex;flex-wrap:wrap;align-items:center;gap:10px}
.confirmers-empty{color:var(--mv-muted);font-size:.85rem}
.confirmers-avatars{display:inline-flex;align-items:center}
.confirmers-avatars .confirmer-av{margin-left:-8px}
.confirmers-avatars .confirmer-av:first-child{margin-left:0}
.confirmer-av{width:30px;height:30px;border-radius:50%;background:var(--mv-soft);color:var(--mv-navy);border:2px solid var(--mv-card);display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-size:.78rem;flex:0 0 30px}
.confirmers-text{color:var(--mv-muted);font-size:.85rem}
.confirmers-viewall{background:none;border:none;padding:0;color:var(--mv-blue);font-weight:700;font-size:.85rem;cursor:pointer;text-decoration:underline}
.confirmers-modal-list{display:flex;flex-direction:column;gap:4px}
.confirmer-row{display:flex;align-items:center;gap:10px;padding:7px 4px;border-bottom:1px solid var(--mv-border)}
.confirmer-row:last-child{border-bottom:none}
.confirmer-name{color:var(--mv-ink);font-weight:600;font-size:.92rem}

/* Footer */
.site-footer{background:var(--mv-card);border-top:1px solid var(--mv-border)}

:root[data-theme="dark"] .btn-primary{--bs-btn-bg:#e8eef8;--bs-btn-border-color:#e8eef8;--bs-btn-color:#101927;--bs-btn-hover-bg:#cbd8eb;--bs-btn-hover-border-color:#cbd8eb;--bs-btn-hover-color:#101927}
:root[data-theme="dark"] .dropdown-menu{background:var(--mv-card);border-color:var(--mv-border)}
:root[data-theme="dark"] .dropdown-item,:root[data-theme="dark"] .dropdown-header{color:var(--mv-ink)}
:root[data-theme="dark"] .dropdown-item:hover{background:var(--mv-soft)}
:root[data-theme="dark"] .btn-close{filter:invert(1) grayscale(100%) brightness(180%)}
:root[data-theme="dark"] .modal-backdrop.show{opacity:.72}
:root[data-theme="dark"] .text-bg-success{background:#143524!important;color:#8ef0b5!important;border-color:#2c6a49!important}
:root[data-theme="dark"] .text-bg-warning{background:#3d2c0d!important;color:#f8d77c!important;border-color:#73551d!important}
:root[data-theme="dark"] .text-bg-info{background:#132849!important;color:#a8c7ff!important;border-color:#2b5189!important}
:root[data-theme="dark"] .text-bg-secondary{background:#253144!important;color:#c4cedd!important;border-color:#3a485d!important}

@media(max-width:991px){
  .theme-nav-item{margin:10px 0 12px}
  .wall-title{font-size:3rem}
  .wall-pulse{max-width:520px}
  .dashboard-header{grid-template-columns:1fr}
  .dashboard-metrics{grid-template-columns:repeat(2,minmax(0,1fr))}
  .wall-toolbar{grid-template-columns:1fr 1fr}
  .toolbar-search{grid-column:1/-1}
  .toolbar-actions{grid-column:1/-1}
  .wall-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .wall-heading{display:block}
  .wall-heading p{text-align:left;margin-top:6px}
  .about-grid,.about-statement{grid-template-columns:1fr}
  .about-callout{grid-template-columns:1fr}
  .about-callout .btn{justify-self:start}
  .about-card-large{grid-row:auto}
}
@media(max-width:575px){
  body{background-size:24px 24px}
  .navbar .container{gap:8px}
  .navbar-brand{max-width:calc(100% - 58px);gap:8px!important}
  .brand-logo-wrap,.brand-logo{width:44px;height:44px;flex-basis:44px;border-radius:10px}
  .brand-name{display:block;font-size:.88rem;line-height:1.05}
  .brand-tag{display:block!important;max-width:210px;font-size:9px;white-space:normal}
  .navbar-toggler{width:44px;height:44px;padding:0;border-radius:12px;background:var(--mv-card);display:inline-flex;align-items:center;justify-content:center}
  .navbar-toggler-icon{width:1.25em;height:1.25em}
  .navbar-collapse{flex-basis:100%;background:var(--mv-card);border:1px solid var(--mv-border);border-radius:12px;margin-top:12px;padding:12px;box-shadow:0 18px 46px var(--mv-shadow)}
  .searchnav{max-width:none;margin:0 0 10px!important}
  .searchnav .form-control{min-height:44px;border-radius:10px}
  .navbar-nav{align-items:stretch!important;gap:6px!important}
  .navbar-nav .nav-link{display:flex;align-items:center;min-height:42px;padding:9px 10px!important;border-radius:10px;color:var(--mv-ink)!important}
  .navbar-nav .nav-link:hover{background:var(--mv-soft)}
  .theme-nav-item{margin:0}
  .theme-toggle{width:42px;height:42px;border-radius:10px}
  .theme-nav-item::before{content:"Theme";display:inline-flex;align-items:center;color:var(--mv-ink);font-weight:700}
  .theme-nav-item{display:flex;align-items:center;justify-content:space-between;min-height:42px;padding:0 0 0 10px;border-radius:10px}
  .nav-cta,.nav-login{width:100%;min-height:44px;justify-content:center;border-radius:10px}
  .nav-login{background:var(--mv-card-soft)}
  .dropdown-menu{position:static!important;transform:none!important;width:100%;margin-top:6px;border-radius:10px}
  .wall-board{padding-left:14px;padding-right:14px}
  .wall-title{font-size:2.45rem}
  .wall-pulse,.wall-toolbar,.wall-grid{grid-template-columns:1fr}
  .dashboard-metrics{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
  .dashboard-metrics div{padding:12px 10px}
  .dashboard-metrics strong{font-size:1.25rem}
  .dashboard-metrics span{font-size:.64rem;letter-spacing:.04em}
  .toolbar-search{grid-column:auto}
  .wall-actions .btn,.toolbar-actions .btn,.dashboard-primary-action{width:100%}
  .dashboard-header{padding:16px;gap:18px}
  .dashboard-header h1{font-size:2rem}
  .dashboard-header p{font-size:.92rem;line-height:1.55}
  .toolbar-actions{display:grid;grid-template-columns:1fr 1fr}
  .signal-row{margin-left:-14px;margin-right:-14px;padding-left:14px;padding-right:14px}
  .signal-label{display:none}
  .signal-chip{max-width:78vw}
  .report-image-link{display:flex;align-items:center;justify-content:center;min-height:170px}
  .report-thumb{height:auto;max-height:260px;object-fit:contain;border-bottom:1px solid var(--mv-border)}
  .report-card h3{font-size:1.08rem!important}
  .report-actions{align-items:flex-start;flex-direction:column}
  .comment-link{margin-left:0}
  .wall-intro-modal .modal-dialog{margin:10px}
  .wall-intro-modal .modal-body{padding:22px 18px}
  .wall-intro-modal .wall-title{padding-right:28px;font-size:2.2rem}
  .wall-subtitle{font-size:.98rem;line-height:1.6}
  .modal-impact{font-size:.94rem;line-height:1.6}
  .photo-viewer-dialog{margin:12px}
  .photo-viewer-img{max-width:calc(100vw - 24px);max-height:calc(100vh - 64px)}
  .photo-viewer-close{top:8px;right:8px;width:36px;height:36px}
  .admin-post-actions{align-items:flex-start;flex-direction:column}
  .about-actions .btn{width:100%}
  .about-callout .btn{width:100%;white-space:normal}
  .about-principles{grid-template-columns:1fr}
}
@media(max-width:380px){
  .brand-tag{max-width:170px;font-size:8.5px}
  .dashboard-header h1{font-size:1.85rem}
  .dashboard-metrics{grid-template-columns:1fr 1fr}
  .dashboard-metrics span{font-size:.6rem}
}
