:root{--bg:#111111;--bg2:#1a1a1a;--bg3:#222222;--bg4:#2a2a2a;--border:#333333;--border2:#3f3f3f;--text:#e8e0d0;--text2:#b0a898;--text3:#7a7068;--amber:#c8861e;--amber-l:#f0c060;--amber-dim:#7a4e10;--green:#4a9a38;--green-l:#7acc60;--green-dim:#1e4d14;--red:#c03030;--red-l:#f06050;--red-dim:#4a1010;--white:#ffffff;--radius:6px;--radius-lg:10px;--shadow:0 4px 24px rgba(0,0,0,0.4);--font-display:'Playfair Display',Georgia,serif;--font-body:'Inter',system-ui,sans-serif;--font-mono:'IBM Plex Mono',monospace}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh;display:flex;flex-direction:column}
a{color:var(--amber-l);text-decoration:none;transition:color .15s}
a:hover{color:var(--white)}
img{max-width:100%;display:block}
.container{max-width:1040px;margin:0 auto;padding:0 1.5rem}
.site-header{background:var(--bg);border-bottom:1px solid var(--border);padding:0 1.5rem;height:56px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:200}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none}
.logo-beer{font-size:20px}
.logo-text{font-family:var(--font-display);font-size:20px;font-weight:900;color:var(--amber-l)}
.site-nav{display:flex;align-items:center;gap:4px}
.nav-link{font-size:14px;padding:6px 14px;border-radius:var(--radius);color:var(--text2);transition:background .12s,color .12s}
.nav-link:hover{background:var(--bg3);color:var(--text)}
.nav-cta{background:var(--amber);color:#1a0e00 !important;font-weight:600;font-size:13px;padding:7px 14px}
.nav-cta:hover{background:var(--amber-l);color:#1a0e00 !important}
.flash{padding:12px 18px;border-radius:var(--radius);font-size:14px;margin-bottom:1.25rem}
.flash-success{background:rgba(74,154,56,0.15);color:var(--green-l);border-left:3px solid var(--green)}
.flash-error{background:rgba(192,48,48,0.15);color:var(--red-l);border-left:3px solid var(--red)}
.btn-primary{display:inline-block;background:var(--amber);color:#1a0e00;padding:10px 22px;border-radius:var(--radius);font-weight:600;font-size:14px;border:none;cursor:pointer;transition:background .15s,transform .1s;text-decoration:none;font-family:var(--font-body)}
.btn-primary:hover{background:var(--amber-l);color:#1a0e00;transform:translateY(-1px)}
.btn-primary.btn-large{padding:13px 28px;font-size:15px}
.btn-full{width:100%;text-align:center;display:block}
.btn-ghost-light{display:inline-block;padding:10px 20px;border:1px solid var(--border2);border-radius:var(--radius);color:var(--text2);font-size:14px;transition:border-color .12s,color .12s}
.btn-ghost-light:hover{border-color:var(--amber-dim);color:var(--text)}
.btn-ghost{display:inline-block;padding:7px 14px;border:1px solid var(--border2);border-radius:var(--radius);color:var(--text2);background:none;font-size:13px;cursor:pointer;font-family:var(--font-body);transition:background .12s,color .12s}
.btn-ghost:hover{background:var(--bg3);color:var(--text)}
.btn-ghost.btn-danger{border-color:var(--red-dim);color:var(--red-l)}
.btn-ghost.btn-danger:hover{background:var(--red-dim)}
.back-link{font-size:13px;color:var(--text2);display:inline-block;margin-bottom:1.25rem}
.back-link:hover{color:var(--text)}
.hero{background:var(--bg);background-image:radial-gradient(ellipse at 15% 60%,rgba(200,134,30,.12) 0%,transparent 55%),radial-gradient(ellipse at 85% 20%,rgba(200,134,30,.07) 0%,transparent 50%);padding:5rem 1.5rem 4.5rem;border-bottom:1px solid var(--border)}
.hero-inner{max-width:1040px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:3rem}
.hero-left{flex:1;min-width:0}
.hero-right{flex-shrink:0;text-align:right;border-left:1px solid var(--border);padding-left:2.5rem}
.hero-eyebrow{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--amber);margin-bottom:1.25rem}
.hero-title{font-family:var(--font-display);font-size:clamp(2.4rem,4vw,3.6rem);font-weight:900;color:var(--text);line-height:1.1;margin-bottom:1.1rem}
.hero-title em{color:var(--amber-l);font-style:italic}
.hero-sub{color:var(--text2);font-size:15px;max-width:440px;margin:0 0 2rem;line-height:1.75}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}
.stats-strip{background:var(--bg2);border-bottom:1px solid var(--border);display:flex;justify-content:center;flex-wrap:wrap}
.stat-item{flex:1;min-width:160px;padding:1.25rem 1.5rem;text-align:center;border-right:1px solid var(--border)}
.stat-item:last-child{border-right:none}
.stat-label{font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--text3);margin-bottom:6px}
.stat-val{font-family:var(--font-display);font-size:1.6rem;font-weight:700;line-height:1.1;margin-bottom:3px}
.stat-sub{font-size:11px;color:var(--text2)}
.stat-white{color:var(--text)}.stat-green{color:var(--green-l)}.stat-red{color:var(--red-l)}
.live-section{border-bottom:1px solid var(--border);padding:1.25rem 0;background:var(--bg)}
.live-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}
.live-dot-wrap{display:flex;align-items:center;gap:8px}
.live-dot{width:8px;height:8px;background:var(--green);border-radius:50%;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.live-label{font-family:var(--font-mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--text2)}
.live-viewall{font-size:13px;color:var(--amber-l)}
.live-feed{display:flex;gap:10px;overflow-x:auto;padding-bottom:4px;scrollbar-width:thin;scrollbar-color:var(--border) transparent}
.live-card{flex:0 0 180px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px}
.live-venue{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}
.live-loc{font-size:11px;color:var(--text2);margin-bottom:8px}
.live-price{font-family:var(--font-display);font-size:1.4rem;font-weight:700;color:var(--amber-l);margin-bottom:6px}
.live-meta{display:flex;justify-content:space-between;font-size:11px;color:var(--text3)}
.live-submitter{color:var(--text2)}
.map-section{padding:3rem 1.5rem}
.section-title{font-family:var(--font-display);font-size:1.3rem;font-weight:700;color:var(--text);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}
.map-layout{display:grid;grid-template-columns:280px 1fr;gap:2.5rem;align-items:start}
.map-wrap{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1rem;position:relative}
.map-wrap svg{width:100%;height:auto;display:block}
.dp{stroke:var(--bg);stroke-width:1.5;cursor:pointer;transition:opacity .15s}
.map-tooltip{position:absolute;background:var(--bg4);border:1px solid var(--border2);color:var(--text);padding:8px 12px;border-radius:var(--radius);font-size:12px;pointer-events:none;display:none;z-index:50;line-height:1.6;white-space:nowrap}
.map-legend{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px;font-size:11px;color:var(--text2)}
.leg{display:flex;align-items:center;gap:5px}
.leg-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.list-header-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.25rem}
.list-viewall{font-size:13px;color:var(--amber-l)}
.district-row{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border-radius:var(--radius);border:1px solid transparent;transition:background .12s,border-color .12s;text-decoration:none;color:var(--text);margin-bottom:2px}
.district-row:hover{background:var(--bg3);border-color:var(--border);color:var(--text)}
.dinfo{display:flex;flex-direction:column}
.dname{font-size:14px;font-weight:600}
.dcount{font-size:11px;color:var(--text3);margin-top:1px}
.dprice{font-family:var(--font-mono);font-size:15px;font-weight:600;padding:3px 10px;border-radius:4px;flex-shrink:0}
.price-low{background:rgba(74,154,56,.15);color:var(--green-l)}
.price-mid{background:rgba(200,134,30,.15);color:var(--amber-l)}
.price-high{background:rgba(192,48,48,.15);color:var(--red-l)}
.empty-msg{font-size:14px;color:var(--text2)}
.empty-msg a{color:var(--amber-l)}
.cta-section{padding:2rem 1.5rem 4rem}
.cta-box{background:var(--bg2);background-image:radial-gradient(ellipse at 80% 50%,rgba(200,134,30,.1) 0%,transparent 60%);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2.5rem 3rem;display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap}
.cta-text h2{font-family:var(--font-display);font-size:1.6rem;margin-bottom:.5rem}
.cta-text p{color:var(--text2);font-size:14px;max-width:420px}
.districts-page{padding:2.5rem 0 4rem}
.page-header{margin-bottom:2rem}
.page-title{font-family:var(--font-display);font-size:2.2rem;font-weight:900;margin-bottom:.4rem}
.page-sub{font-size:14px;color:var(--text2)}
.district-search-wrap{margin-bottom:1.75rem}
.district-search-input{width:100%;max-width:400px;padding:10px 16px;background:var(--bg2);border:1px solid var(--border2);border-radius:var(--radius);color:var(--text);font-size:14px;font-family:var(--font-body);transition:border-color .15s}
.district-search-input:focus{outline:none;border-color:var(--amber-dim)}
.district-search-input::placeholder{color:var(--text3)}
.districts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}
.district-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;text-decoration:none;color:var(--text);display:block;transition:background .12s,border-color .12s,transform .1s}
.district-card:hover{background:var(--bg3);border-color:var(--border2);transform:translateY(-2px);color:var(--text)}
.dc-empty{opacity:.5}
.dc-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.dc-name{font-size:15px;font-weight:600}
.dc-diff{font-family:var(--font-mono);font-size:11px;padding:2px 7px;border-radius:4px}
.diff-up{background:rgba(192,48,48,.2);color:var(--red-l)}
.diff-down{background:rgba(74,154,56,.2);color:var(--green-l)}
.dc-price{font-family:var(--font-display);font-size:2rem;font-weight:700;color:var(--amber-l);margin-bottom:4px}
.dc-no-data{color:var(--text3) !important;font-size:1.5rem !important}
.dc-meta{font-size:12px;color:var(--text2);margin-bottom:3px}
.dc-national{font-size:11px;color:var(--text3)}
.district-detail-page{padding:2rem 0 4rem}
.detail-nav{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}
.detail-prevnext{display:flex;gap:6px}
.prevnext-btn{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text2);font-size:18px;transition:background .12s,color .12s}
.prevnext-btn:hover{background:var(--bg3);color:var(--text)}
.detail-header{margin-bottom:1.5rem}
.detail-title{font-family:var(--font-display);font-size:2rem;font-weight:900;line-height:1.2}
.detail-district{color:var(--amber-l)}
.detail-sub{color:var(--text2);font-size:14px;margin-top:4px}
.contribute-banner{background:var(--bg2);border:1px solid var(--border);border-left:3px solid var(--amber-dim);border-radius:var(--radius);padding:1rem 1.25rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}
.contribute-text strong{display:block;font-size:14px;margin-bottom:2px}
.contribute-text span{font-size:13px;color:var(--text2)}
.btn-contribute{background:var(--amber);color:#1a0e00;font-size:12px;font-weight:700;letter-spacing:.06em;padding:8px 18px;border-radius:var(--radius);white-space:nowrap;flex-shrink:0;transition:background .12s}
.btn-contribute:hover{background:var(--amber-l);color:#1a0e00}
.no-data-panel{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:3rem;text-align:center}
.no-data-panel p{color:var(--text2);margin-bottom:1.25rem}
.stat-panels{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem;margin-bottom:2.5rem}
.stat-panel{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem}
.sp-eyebrow{font-family:var(--font-mono);font-size:9px;letter-spacing:.14em;color:var(--text3);margin-bottom:4px}
.sp-eyebrow::after{content:'';display:block;width:28px;height:2px;background:var(--amber-dim);margin-top:6px;margin-bottom:10px}
.sp-title{font-family:var(--font-display);font-size:1.2rem;font-weight:700;margin-bottom:1.25rem;color:var(--text)}
.sp-price{font-family:var(--font-display);font-size:2.8rem;font-weight:900;color:var(--text);line-height:1;margin-bottom:4px}
.sp-subtitle{font-size:12px;color:var(--text2);margin-bottom:12px}
.sp-range{font-family:var(--font-mono);font-size:14px;margin-bottom:2px}
.range-cheap{color:var(--green-l)}.range-sep{color:var(--text3)}.range-pricey{color:var(--red-l)}
.sp-range-label{font-size:11px;color:var(--text3);margin-bottom:14px}
.sp-national{font-size:12px;color:var(--text2);padding-top:12px;border-top:1px solid var(--border)}
.nat-up{color:var(--red-l)}.nat-down{color:var(--green-l)}
.sp-list{display:flex;flex-direction:column;gap:0}
.sp-list-item{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--border)}
.sp-list-item:last-child{border-bottom:none}
.sp-rank{font-family:var(--font-mono);font-size:11px;color:var(--text3);width:16px;flex-shrink:0}
.sp-list-info{flex:1;min-width:0}
.sp-list-venue{display:block;font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sp-list-city{font-size:11px;color:var(--text2)}
.sp-list-price{font-family:var(--font-mono);font-size:13px;font-weight:600;flex-shrink:0}
.sp-list-price.cheap{color:var(--green-l)}.sp-list-price.pricey{color:var(--red-l)}
.entries-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:10px}
.entries-sort{display:flex;align-items:center;gap:8px}
.sort-label{font-size:13px;color:var(--text2)}
.sort-select{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:13px;padding:5px 10px;font-family:var(--font-body)}
.entries-list{display:flex;flex-direction:column;gap:2px}
.entry-row{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;transition:background .12s,border-color .12s}
.entry-row:hover{background:var(--bg3);border-color:var(--border2)}
.er-main{flex:1;min-width:0}
.er-venue{font-size:15px;font-weight:600;display:flex;align-items:center;gap:8px}
.er-rating{font-size:12px;color:var(--amber-l);font-weight:500}
.er-meta{font-size:12px;color:var(--text2);margin-top:3px;display:flex;flex-wrap:wrap;gap:4px}
.er-sep{color:var(--text3)}
.er-comment{font-size:12px;font-style:italic;color:var(--text2);margin-top:5px}
.er-submitter{font-size:11px;color:var(--text3);margin-top:4px}
.er-right{text-align:right;flex-shrink:0}
.er-price{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--amber-l)}
.er-size{font-size:11px;color:var(--text3);margin-top:2px}
.er-maps{font-size:11px;color:var(--amber-l);display:block;margin-top:6px}
.submit-page{padding:2.5rem 1.5rem 4rem}
.submit-layout{display:grid;grid-template-columns:280px 1fr;gap:3rem;align-items:start}
.page-title{font-family:var(--font-display);font-size:2rem;font-weight:900;margin:.75rem 0 1rem}
.submit-desc{font-size:14px;color:var(--text2);margin-bottom:1.25rem}
.submit-rules{list-style:none;margin-bottom:1.5rem}
.submit-rules li{font-size:13px;padding:7px 0;border-bottom:1px solid var(--border);color:var(--text2);display:flex;gap:8px;align-items:center}
.rule-yes{color:var(--green-l)}.rule-no{color:var(--red-l)}
.fino-note{background:rgba(200,134,30,.08);border:1px solid var(--amber-dim);border-radius:var(--radius);padding:12px 14px;font-size:13px;color:var(--text2);line-height:1.6}
.fino-note strong{color:var(--amber-l);display:block;margin-bottom:4px}
.submit-form{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.75rem}
.form-errors{background:rgba(192,48,48,.12);border-left:3px solid var(--red);border-radius:var(--radius);padding:12px 14px;margin-bottom:1.25rem;font-size:14px;color:var(--red-l)}
.form-errors p{margin-bottom:3px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field{margin-bottom:1.1rem}
.field label{display:block;font-size:12px;font-weight:600;color:var(--text2);margin-bottom:6px;text-transform:uppercase;letter-spacing:.05em;font-family:var(--font-mono)}
.field input,.field select,.field textarea{width:100%;padding:9px 12px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:14px;font-family:var(--font-body);transition:border-color .15s,box-shadow .15s;appearance:none}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--amber-dim);box-shadow:0 0 0 3px rgba(200,134,30,.12);background:var(--bg4)}
.field input::placeholder,.field textarea::placeholder{color:var(--text3)}
.field textarea{resize:vertical}
.field-hint{display:flex;gap:8px;align-items:center;margin-top:6px;font-size:12px;color:var(--text2)}
.places-verified{color:var(--green-l);font-weight:600}
.autocomplete-wrap{position:relative}
.places-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--bg3);border:1px solid var(--border2);border-top:none;border-radius:0 0 var(--radius) var(--radius);z-index:100;max-height:260px;overflow-y:auto}
.places-item{padding:10px 14px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .1s}
.places-item:last-child{border-bottom:none}
.places-item:hover{background:var(--bg4)}
.pi-name{display:block;font-size:14px;font-weight:600;color:var(--text)}
.pi-addr{display:block;font-size:12px;color:var(--text2);margin-top:2px}
.upload-zone{display:block;border:2px dashed var(--border2);border-radius:var(--radius);padding:2rem 1rem;text-align:center;cursor:pointer;background:var(--bg3);transition:background .15s,border-color .15s}
.upload-zone:hover,.upload-zone.has-photo{background:var(--bg4);border-color:var(--amber-dim)}
.upload-icon{font-size:28px;display:block;margin-bottom:8px}
.upload-main{font-size:14px;font-weight:600;color:var(--text);margin-bottom:4px}
.upload-sub{font-size:12px;color:var(--text2)}
#photo-preview{max-width:100%;max-height:180px;border-radius:var(--radius);margin:10px auto 6px;object-fit:cover;border:1px solid var(--border)}
.form-note{font-size:12px;color:var(--text3);text-align:center;margin-top:10px}
.admin-login-page{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 120px);padding:2rem}
.login-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2.5rem;width:100%;max-width:360px;text-align:center}
.login-icon{font-size:2.5rem;margin-bottom:1rem;display:block}
.login-card h1{font-family:var(--font-display);font-size:1.6rem;margin-bottom:.5rem}
.login-card p{font-size:14px;color:var(--text2);margin-bottom:1.5rem}
.login-card .field{text-align:left}
.admin-page{padding:2rem 1.5rem 4rem}
.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}
.admin-header h1{font-family:var(--font-display);font-size:1.8rem}
.admin-actions{display:flex;gap:8px}
.admin-counts{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:2rem}
.count-card{flex:1;min-width:110px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.25rem;text-align:center}
.cn{display:block;font-family:var(--font-display);font-size:2rem;font-weight:700}
.cl{font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;font-family:var(--font-mono)}
.count-pending .cn{color:var(--amber-l)}.count-approved .cn{color:var(--green-l)}.count-rejected .cn{color:var(--red-l)}
.pending-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px;margin-top:.75rem}
.pending-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
.pending-photo{width:100%;height:180px;object-fit:cover;background:var(--bg3);display:block;cursor:zoom-in}
.pending-body{padding:14px}
.pending-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.pending-top strong{font-size:14px}
.price-tag{background:rgba(200,134,30,.15);color:var(--amber-l);font-weight:700;font-family:var(--font-mono);padding:3px 9px;border-radius:4px;font-size:14px}
.pending-meta{font-size:12px;color:var(--text2);margin-bottom:3px}
.pending-comment{font-size:12px;font-style:italic;color:var(--text2);margin-top:4px}
.pending-date{font-size:11px;color:var(--text3);margin-top:6px}
.pending-btns{display:flex;gap:8px;margin-top:10px}
.btn-approve{padding:6px 14px;background:rgba(74,154,56,.15);color:var(--green-l);border:1px solid rgba(74,154,56,.3);border-radius:var(--radius);font-size:13px;font-weight:600;cursor:pointer;transition:background .12s}
.btn-approve:hover{background:rgba(74,154,56,.3)}
.btn-reject{padding:6px 14px;background:rgba(192,48,48,.12);color:var(--red-l);border:1px solid rgba(192,48,48,.25);border-radius:var(--radius);font-size:13px;font-weight:600;cursor:pointer;transition:background .12s}
.btn-reject:hover{background:rgba(192,48,48,.25)}
.btn-delete{padding:6px 10px;background:none;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;cursor:pointer;color:var(--text3);margin-left:auto}
.btn-delete:hover{background:rgba(192,48,48,.12);border-color:rgba(192,48,48,.3);color:var(--red-l)}
.data-table{width:100%;border-collapse:collapse;font-size:13px;margin-top:.75rem;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
.data-table th{background:var(--bg3);padding:10px 12px;text-align:left;font-size:11px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);font-family:var(--font-mono)}
.data-table td{padding:9px 12px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle}
.data-table tr:last-child td{border-bottom:none}
.data-table tr:hover td{background:var(--bg3)}
.btn-delete-sm{background:none;border:none;cursor:pointer;font-size:14px;opacity:.4;color:var(--text)}
.btn-delete-sm:hover{opacity:1}
.change-pw{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.25rem;margin-top:2rem}
.change-pw summary{font-size:14px;font-weight:600;cursor:pointer;color:var(--text2);user-select:none}
.pw-form{margin-top:1rem;max-width:380px}
.error-page{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 120px)}
.error-inner{text-align:center}
.error-code{font-family:var(--font-display);font-size:6rem;font-weight:900;color:var(--bg3);display:block;line-height:1;margin-bottom:-.5rem}
.error-inner h1{font-size:1.5rem;margin-bottom:.5rem}
.error-inner p{color:var(--text2);margin-bottom:1.5rem;font-size:14px}
.site-footer{background:var(--bg2);border-top:1px solid var(--border);padding:2rem 1.5rem 1.25rem;margin-top:auto}
.footer-inner{max-width:1040px;margin:0 auto;display:flex;justify-content:space-between;align-items:flex-start;gap:2rem;flex-wrap:wrap;margin-bottom:1.5rem}
.footer-brand .footer-logo{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--amber-l);display:block;margin-bottom:6px}
.footer-brand p{font-size:12px;color:var(--text3);max-width:260px}
.footer-links{display:flex;gap:16px;flex-wrap:wrap;padding-top:4px}
.footer-links a{font-size:13px;color:var(--text2)}
.footer-links a:hover{color:var(--text)}
.footer-bottom{max-width:1040px;margin:0 auto;border-top:1px solid var(--border);padding-top:1rem;font-size:11px;color:var(--text3)}
/* Brand bar */
.brand-section{padding:0 1.5rem 3rem}
.brand-bar-wrap{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem}
.brand-bar{display:flex;height:28px;border-radius:var(--radius);overflow:hidden;margin-bottom:1rem;gap:2px}
.brand-seg{height:100%;transition:width .4s ease}
.brand-sb{background:#0052a5}.brand-sag{background:#c8000a}.brand-ot{background:var(--bg4)}
.brand-labels{display:flex;gap:1.5rem;flex-wrap:wrap}
.brand-label{display:flex;align-items:center;gap:6px;font-size:13px}
.brand-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.brand-pct{font-family:var(--font-mono);font-weight:600;color:var(--text)}
.brand-n{color:var(--text3);font-size:11px}.brand-name{color:var(--text2)}
/* Changelog */
.changelog-page{padding:2.5rem 1.5rem 4rem}
.changelog-stats{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:1.5rem}
.changelog-stats .count-card{flex:1;min-width:110px}
.changelog-cta{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem 2rem;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;margin-bottom:2rem}
.changelog-cta-text h3{font-family:var(--font-display);font-size:1.2rem;margin-bottom:4px}
.changelog-cta-text p{font-size:13px;color:var(--text2);max-width:420px}
.changelog-list{display:flex;flex-direction:column;gap:2px}
.changelog-item{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;transition:background .12s}
.changelog-item:hover{background:var(--bg3)}
.ci-left{flex:1;min-width:0}
.ci-badges{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:6px}
.ci-badge{font-size:11px;padding:2px 8px;border-radius:4px;font-weight:600}
.ci-new{background:rgba(74,154,56,.15);color:var(--green-l)}
.ci-confirmed{background:rgba(200,134,30,.15);color:var(--amber-l)}
.ci-updated{background:rgba(100,100,200,.15);color:#9090f0}
.ci-conn{background:var(--bg4);color:var(--text3)}
.ci-venue{font-size:14px;font-weight:600;margin-bottom:3px}
.ci-loc{font-size:12px;color:var(--text2);font-weight:400;margin-left:6px}
.ci-rating{font-size:12px;color:var(--amber-l);display:block;margin-bottom:4px}
.ci-meta{font-size:12px;color:var(--text3);display:flex;gap:10px;margin-top:4px}
.ci-right{text-align:right;flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;gap:3px}
.ci-price{font-family:var(--font-display);font-size:1.4rem;font-weight:700;color:var(--amber-l)}
.ci-old{font-family:var(--font-mono);font-size:12px;color:var(--text3);text-decoration:line-through}
.ci-arrow{font-size:12px;color:var(--text3)}
.ci-diff{font-family:var(--font-mono);font-size:11px;font-weight:600}
.ci-diff-up{color:var(--red-l)}.ci-diff-down{color:var(--green-l)}
/* Responsive */
@media(max-width:768px){.map-layout{grid-template-columns:1fr}.submit-layout{grid-template-columns:1fr}.stat-panels{grid-template-columns:1fr}}
@media(max-width:640px){.stats-strip{flex-wrap:nowrap;overflow-x:auto;justify-content:flex-start}.stat-item{min-width:140px;flex:0 0 140px;padding:1rem}.hero{padding:3.5rem 1rem 3rem}.hero-title{font-size:2.2rem}.cta-box{flex-direction:column;text-align:center;padding:2rem}.districts-grid{grid-template-columns:1fr 1fr}.pending-grid{grid-template-columns:1fr}.detail-title{font-size:1.5rem}.form-row{grid-template-columns:1fr}}

/* ── Venue page ── */
.venue-page{padding:2rem 1.5rem 4rem}
.venue-header{display:flex;justify-content:space-between;align-items:flex-start;gap:2rem;flex-wrap:wrap;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}
.venue-name{font-family:var(--font-display);font-size:2rem;font-weight:900;margin-bottom:.5rem}
.venue-meta-row{display:flex;flex-wrap:wrap;gap:6px;align-items:center;font-size:13px;color:var(--text2);margin-bottom:4px}
.venue-type{background:var(--bg3);padding:2px 8px;border-radius:4px;font-size:12px}
.venue-sep{color:var(--text3)}
.venue-grating{color:var(--amber-l)}
.venue-address{font-size:12px;color:var(--text3);margin-top:4px}
.venue-header-right{text-align:right;flex-shrink:0}
.venue-main-price{font-family:var(--font-display);font-size:2.8rem;font-weight:900;color:var(--amber-l);line-height:1}
.venue-ppl{font-family:var(--font-mono);font-size:13px;color:var(--text2);margin-top:4px}
.venue-updated{font-size:12px;color:var(--text3);margin-top:4px}
.venue-maps-btn{display:inline-block;font-size:12px;color:var(--amber-l);margin-top:8px}
.venue-photo-wrap{margin-bottom:2rem}
.venue-photo{width:100%;max-height:320px;object-fit:cover;border-radius:var(--radius-lg);border:1px solid var(--border)}
.venue-photo-caption{font-size:11px;color:var(--text3);margin-top:6px;text-align:center}
.venue-section{margin-bottom:2.5rem}
.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px;margin-top:.75rem}
.product-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1rem;transition:border-color .12s}
.product-card:hover{border-color:var(--border2)}
.product-main{border-color:var(--amber-dim)}
.product-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.product-brand{font-size:13px;font-weight:600}
.product-size{font-family:var(--font-mono);font-size:11px;background:var(--bg4);padding:2px 6px;border-radius:4px;color:var(--text2)}
.product-price{font-family:var(--font-display);font-size:1.6rem;font-weight:700;color:var(--amber-l);margin-bottom:2px}
.product-ppl{font-family:var(--font-mono);font-size:11px;color:var(--text2);margin-bottom:6px}
.product-updated{font-size:11px;color:var(--text3)}
.product-by{font-size:11px;color:var(--text3);margin-top:2px}
.history-list{display:flex;flex-direction:column;gap:2px}
.history-item{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.history-left{flex:1}
.history-badges{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:5px}
.history-meta{display:flex;gap:10px;font-size:12px;color:var(--text3)}
.history-time{color:var(--text3)}
.history-right{text-align:right;display:flex;align-items:center;gap:6px;flex-shrink:0}
.venue-cta{background:var(--bg2);border:1px solid var(--border);border-left:3px solid var(--amber-dim);border-radius:var(--radius);padding:1rem 1.25rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-top:2rem}
.venue-cta-text strong{display:block;font-size:14px;margin-bottom:2px}
.venue-cta-text span{font-size:13px;color:var(--text2)}

/* Price per litre display */
.ppl-display{display:flex;flex-direction:column;gap:2px}
.ppl-label{font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:.05em;font-family:var(--font-mono)}
.ppl-value{font-family:var(--font-mono);font-size:15px;font-weight:600;color:var(--amber-l)}

/* Product photo thumb */
.product-photo-link{display:block;margin-top:8px}
.product-photo-thumb{width:100%;height:80px;object-fit:cover;border-radius:var(--radius);border:1px solid var(--border)}
.product-comment{font-size:11px;font-style:italic;color:var(--text2);margin-top:4px}

/* ── Stats Panels (Most Reviewed, Famous, Expensive) ── */
.statpanels-section{padding:0 1.5rem 3rem}
.statpanels-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.statpanel{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
.statpanel-head{padding:1.25rem 1.25rem .75rem;display:flex;justify-content:space-between;align-items:flex-start;border-bottom:1px solid var(--border)}
.statpanel-title{font-family:var(--font-display);font-size:1.1rem;font-weight:700;margin-bottom:2px}
.statpanel-sub{font-size:11px;color:var(--text3)}
.statpanel-source{font-family:var(--font-mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--text3);border:1px solid var(--border);border-radius:3px;padding:2px 6px;flex-shrink:0;margin-top:2px}
.statpanel-list{list-style:none;padding:0;margin:0}
.statpanel-item{display:flex;align-items:center;gap:10px;padding:10px 1.25rem;border-bottom:1px solid var(--border);transition:background .1s}
.statpanel-item:last-child{border-bottom:none}
.statpanel-item:hover{background:var(--bg3)}
.spi-rank{font-family:var(--font-mono);font-size:11px;color:var(--text3);width:16px;flex-shrink:0;text-align:right}
.spi-info{flex:1;min-width:0}
.spi-name{display:block;font-size:13px;font-weight:600;color:var(--text);text-decoration:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.spi-name:hover{color:var(--amber-l)}
.spi-meta{font-size:11px;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}
.spi-value{font-family:var(--font-mono);font-size:12px;color:var(--text2);flex-shrink:0;white-space:nowrap}
.spi-expensive{color:var(--red-l);font-size:14px;font-weight:600;font-family:var(--font-display)}
@media(max-width:960px){.statpanels-grid{grid-template-columns:1fr}}

/* ── Hero stat block ── */
.hero-stat-label{font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--text2);margin-bottom:8px}
.hero-stat-price{font-family:var(--font-display);font-size:3.8rem;font-weight:900;color:var(--text);line-height:1;margin-bottom:14px}
.hero-stat-meta{display:flex;flex-direction:row;gap:6px;align-items:center;justify-content:flex-end;flex-wrap:wrap;font-size:13px}
.hstat-val{color:var(--amber-l);font-weight:700;font-family:var(--font-mono)}
.hstat-lbl{color:var(--text2)}
.hstat-dot{color:var(--text3);margin:0 2px}
@media(max-width:768px){.hero-inner{flex-direction:column;text-align:center}.hero-right{border-left:none;border-top:1px solid var(--border);padding-left:0;padding-top:2rem;text-align:center;width:100%}.hero-sub{margin:0 auto 2rem}.hero-actions{justify-content:center}.hero-stat-meta{justify-content:center}}

/* ── Product card enhancements ── */
.product-price-row{display:flex;align-items:center;gap:6px;margin-bottom:2px}
.product-trend{font-size:1rem;font-weight:700;line-height:1}
.trend-up{color:var(--red-l)}
.trend-down{color:var(--green-l)}
.product-meta-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px;margin-top:4px}
.product-stale{font-size:11px;color:var(--amber-l);background:rgba(200,134,30,.06);border-top:1px solid var(--amber-dim);padding:8px 1rem;margin:8px -1rem -1rem;display:block;font-family:var(--font-mono);letter-spacing:.01em;border-radius:0 0 var(--radius-lg) var(--radius-lg)}
.product-confidence{display:flex;gap:3px;align-items:center}
.conf-dot{width:12px;height:3px;border-radius:2px;background:var(--border2);display:inline-block;font-size:0;line-height:0}
.conf-filled{background:var(--amber-l)}

/* ═══════════════════════════════════════════════════════
   MOBILE OPTIMISATION — comprehensive responsive pass
   ═══════════════════════════════════════════════════════ */

/* ── Hamburger nav ── */
.nav-burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;background:none;border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;padding:8px;flex-shrink:0}
.nav-burger span{display:block;height:2px;background:var(--text2);border-radius:2px;transition:transform .2s,opacity .2s}
.burger-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger-open span:nth-child(2){opacity:0}
.burger-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media(max-width:860px){
  /* Header */
  .nav-burger{display:flex}
  .site-nav{
    display:none;flex-direction:column;gap:0;
    position:absolute;top:56px;left:0;right:0;
    background:var(--bg2);border-bottom:1px solid var(--border);
    padding:.75rem 0;z-index:199
  }
  .site-nav.nav-open{display:flex}
  .nav-link{padding:12px 1.5rem;border-radius:0;font-size:15px}
  .nav-link:hover{background:var(--bg3)}
  .nav-cta{margin:8px 1.5rem;border-radius:var(--radius);text-align:center;padding:12px}

  /* Hero */
  .hero{padding:3rem 1.25rem 2.5rem}
  .hero-inner{flex-direction:column;gap:2rem;text-align:center}
  .hero-left{width:100%}
  .hero-right{border-left:none;border-top:1px solid var(--border);padding-left:0;padding-top:1.5rem;text-align:center;width:100%}
  .hero-sub{margin:0 auto 1.5rem}
  .hero-actions{justify-content:center}
  .hero-stat-meta{justify-content:center;flex-wrap:wrap}
  .hero-stat-price{font-size:3rem}

  /* Stats strip */
  .stats-strip{flex-wrap:nowrap;overflow-x:auto;justify-content:flex-start;-webkit-overflow-scrolling:touch}
  .stat-item{min-width:130px;flex:0 0 130px;padding:.9rem 1rem}
  .stat-val{font-size:1.3rem}

  /* Map section */
  .map-section{padding:2rem 1rem}
  .map-layout{grid-template-columns:1fr;gap:1.5rem}

  /* Live feed */
  .live-card{flex:0 0 160px}

  /* Stat panels */
  .statpanels-grid{grid-template-columns:1fr}
  .stat-panels{grid-template-columns:1fr}

  /* District cards */
  .districts-grid{grid-template-columns:1fr 1fr}

  /* District detail */
  .detail-nav{flex-wrap:wrap;gap:.5rem}
  .contribute-banner{flex-direction:column;gap:.75rem}
  .entries-header{flex-direction:column;align-items:flex-start;gap:.5rem}

  /* Submit form */
  .submit-layout{grid-template-columns:1fr}
  .submit-info{display:none}
  .form-row{grid-template-columns:1fr}

  /* Venue page */
  .venue-header{flex-direction:column;gap:1rem}
  .venue-header-right{text-align:left}
  .products-grid{grid-template-columns:1fr 1fr}

  /* Admin */
  .admin-counts{grid-template-columns:1fr 1fr}
  .pending-grid{grid-template-columns:1fr}
  .data-table{font-size:12px}
  .data-table th,.data-table td{padding:6px 8px}

  /* Stats page */
  .stats-summary{grid-template-columns:repeat(3,1fr)}
  .charts-grid{grid-template-columns:1fr}
  .chart-wide,.chart-full{grid-column:span 1}

  /* Search page */
  .filters-row{flex-direction:column}
  .filter-group{min-width:100%}

  /* API docs */
  .api-layout{grid-template-columns:1fr}
  .api-nav{display:none}

  /* Changelog */
  .changelog-item{flex-direction:column;gap:.5rem}
  .ci-right{text-align:left;flex-direction:row;align-items:center}

  /* Footer */
  .footer-inner{flex-direction:column;gap:1rem}
  .footer-links{gap:10px}
}

@media(max-width:480px){
  /* Tighter padding */
  .container{padding:0 1rem}
  .hero{padding:2.5rem 1rem 2rem}
  .hero-title{font-size:2rem}
  .hero-stat-price{font-size:2.4rem}

  /* Districts */
  .districts-grid{grid-template-columns:1fr}
  .district-card{padding:1rem}
  .dc-price{font-size:1.6rem}

  /* Products */
  .products-grid{grid-template-columns:1fr}

  /* Stats summary */
  .stats-summary{grid-template-columns:1fr 1fr}

  /* Entry rows */
  .entry-row,.result-card{flex-direction:column;gap:.5rem}
  .er-right,.rc-right{text-align:left}

  /* Stat panels in district */
  .sp-price{font-size:2.2rem}

  /* CTA box */
  .cta-box{flex-direction:column;text-align:center;padding:1.5rem}

  /* Venue header */
  .venue-name{font-size:1.5rem}
  .venue-main-price{font-size:2.2rem}

  /* Admin counts */
  .admin-counts{grid-template-columns:1fr 1fr}

  /* Page titles */
  .page-title{font-size:1.6rem}
  .detail-title{font-size:1.4rem}

  /* Nav buttons */
  .prevnext-btn{width:30px;height:30px}

  /* History items */
  .history-item{flex-direction:column;gap:.4rem}
  .history-right{flex-direction:row;align-items:center;gap:6px}
}
