/* edu-ogloszenia.pl — style produkcyjne
   Paleta: jasna, świeża, edukacyjna — biel + miękkie błękity + akcent indygo */

:root{
  --bg:        #f7f9fc;
  --bg-soft:   #ffffff;
  --bg-tint:   #eef3fa;
  --text:      #1a2233;
  --text-soft: #5a6478;
  --muted:     #98a2b3;
  --border:    #e3e8f0;
  --primary:   #3b5bdb;
  --primary-d: #2f4ac0;
  --primary-l: #eaeefc;
  --accent:    #14b8a6;
  --warn:      #f59e0b;
  --error:     #dc2626;
  --success:   #16a34a;
  --shadow:    0 1px 2px rgba(20,30,60,.04), 0 4px 12px rgba(20,30,60,.05);
  --shadow-h:  0 4px 16px rgba(59,91,219,.12);
  --r:         12px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font: 15px/1.55 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  color:var(--text);
  background:var(--bg);
}
a{color:var(--primary); text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%; display:block}
h1,h2,h3,h4{margin:0 0 .5em; line-height:1.25; letter-spacing:-.01em}
h1{font-size:32px}
h2{font-size:22px}
h3{font-size:16px}
h4{font-size:14px; text-transform:uppercase; letter-spacing:.05em; color:var(--text-soft)}
p{margin:0 0 .8em}
hr{border:0; border-top:1px solid var(--border); margin:24px 0}
.wrap{max-width:1180px; margin:0 auto; padding:0 20px}
.muted{color:var(--muted)}

/* ===== Topbar ===== */
.topbar{background:#fff; border-bottom:1px solid var(--border); position:sticky; top:0; z-index:50}
.topbar .wrap{display:flex; align-items:center; justify-content:space-between; height:64px; gap:16px}
.brand{font-weight:700; font-size:19px; color:var(--text)}
.brand:hover{text-decoration:none}
.brand .logo{color:var(--primary)}
.brand .logo-dot{color:var(--accent); margin:0 1px}
.nav{display:flex; align-items:center; gap:6px}
.nav a{padding:8px 12px; border-radius:8px; color:var(--text-soft); font-weight:500; font-size:14px}
.nav a:hover{background:var(--bg-tint); color:var(--text); text-decoration:none}
.nav a.active{color:var(--primary); background:var(--primary-l)}
/* Przycisk CTA w navie — wyższa specyfika żeby przebić .nav a */
.nav a.btn-primary{background:var(--primary); color:#fff; padding:10px 18px; margin-left:8px}
.nav a.btn-primary:hover{background:var(--primary-d); color:#fff; text-decoration:none}
.nav a.btn-ghost{color:var(--text); border:1px solid var(--border)}
.menu-toggle{display:none; background:none; border:0; font-size:24px; cursor:pointer}

/* ===== Flash ===== */
.flash{padding:12px 0; font-size:14px}
.flash-info{background:var(--primary-l); color:var(--primary)}
.flash-success{background:#dcfce7; color:#16803d}
.flash-error{background:#fee2e2; color:#b91c1c}

/* ===== Buttons ===== */
.btn{display:inline-flex; align-items:center; justify-content:center; gap:6px;
  padding:9px 16px; border-radius:8px; font-size:14px; font-weight:600;
  border:1px solid transparent; cursor:pointer; transition:all .15s;
  text-decoration:none; line-height:1.2}
.btn:hover{text-decoration:none}
.btn-primary{background:var(--primary); color:#fff}
.btn-primary:hover{background:var(--primary-d); color:#fff}
.btn-ghost{background:transparent; color:var(--text); border-color:var(--border)}
.btn-ghost:hover{background:var(--bg-tint)}
.btn-lg{padding:13px 24px; font-size:15px; border-radius:10px}
.btn-block{display:flex; width:100%; margin-bottom:8px}

/* ===== Hero ===== */
.hero{background:linear-gradient(180deg, #f4f7fd 0%, #fbfcfe 100%); padding:64px 0 56px; border-bottom:1px solid var(--border)}
.hero h1{font-size:42px; max-width:780px; line-height:1.15}
.hero h1 .hl{background:linear-gradient(120deg, var(--primary) 0%, var(--accent) 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent}
.hero .lead{color:var(--text-soft); font-size:16px; margin-bottom:32px}
.search{display:flex; gap:8px; background:#fff; padding:8px; border-radius:14px; box-shadow:var(--shadow); border:1px solid var(--border); max-width:880px}
.search-field{flex:1; padding:6px 14px}
.search-field label{display:block; font-size:11px; text-transform:uppercase; color:var(--muted); font-weight:600; letter-spacing:.04em}
.search-field input{border:0; width:100%; font-size:15px; padding:4px 0; background:transparent; outline:none}
.search .btn{flex-shrink:0}
.search-inline{margin-top:20px; max-width:680px}
.search-inline input{padding:10px 14px; border:1px solid var(--border); border-radius:8px; font-size:14px; flex:1}
.search-inline{display:flex; gap:8px}

.quick-tags{margin-top:18px; font-size:14px; color:var(--text-soft)}
.quick-tags .qt-label{margin-right:8px}
.quick-tags a{display:inline-block; padding:4px 10px; background:#fff; border:1px solid var(--border); border-radius:999px; margin:4px 4px 0 0; color:var(--text-soft); font-size:13px}
.quick-tags a:hover{border-color:var(--primary); color:var(--primary); text-decoration:none}

/* ===== Sections ===== */
section{padding:56px 0}
.section-head{display:flex; align-items:baseline; justify-content:space-between; margin-bottom:24px}
.more{font-size:14px; font-weight:500}

/* ===== Categories ===== */
.cat-grid{display:grid; grid-template-columns:repeat(4, 1fr); gap:16px}
.cat-card{background:#fff; border:1px solid var(--border); border-radius:var(--r); padding:24px; color:var(--text); transition:all .15s; display:block}
.cat-card:hover{border-color:var(--primary); box-shadow:var(--shadow-h); transform:translateY(-2px); text-decoration:none}
.cat-ico{font-size:32px; margin-bottom:8px}
.cat-card h3{margin:0 0 4px; font-size:17px}
.cat-card p{color:var(--text-soft); font-size:13px; margin:0 0 12px}
.cat-count{font-size:12px; color:var(--primary); font-weight:600}

/* ===== Cities ===== */
.cities h2{margin-bottom:24px}
.city-list{display:grid; grid-template-columns:repeat(4, 1fr); gap:8px}
.city-list a{background:#fff; border:1px solid var(--border); border-radius:10px; padding:14px 16px; display:flex; justify-content:space-between; align-items:center; color:var(--text); transition:all .15s}
.city-list a:hover{border-color:var(--primary); text-decoration:none}
.city-list a strong{font-weight:600; font-size:14px}
.city-list a span{color:var(--muted); font-size:12px}
.city-list-full{grid-template-columns:repeat(3, 1fr)}

/* ===== Listings ===== */
.listing-grid{display:grid; grid-template-columns:repeat(3, 1fr); gap:20px}
.listing{background:#fff; border:1px solid var(--border); border-radius:var(--r); overflow:hidden; transition:all .15s; display:block; color:var(--text)}
.listing:hover{border-color:var(--primary); box-shadow:var(--shadow-h); transform:translateY(-2px); text-decoration:none}
.listing-img{aspect-ratio:16/10; position:relative; background:var(--bg-tint); display:flex; align-items:center; justify-content:center}
.badge{position:absolute; top:10px; left:10px; padding:3px 8px; border-radius:6px; font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.04em; color:#fff}
.badge-new{background:var(--accent)}
.badge-top{background:var(--warn)}
/* Karta bez zdjęcia — niższy obrazek + ikona kategorii w środku */
.listing-nophoto .listing-img{aspect-ratio:auto; height:80px}
.listing-img-icon{font-size:36px; opacity:.55; line-height:1; filter:saturate(.8)}
.listing-body{padding:14px 16px 16px}
.tags{display:flex; gap:6px; margin-bottom:8px; flex-wrap:wrap}
.tags span{font-size:11px; padding:2px 8px; background:var(--primary-l); color:var(--primary); border-radius:999px; font-weight:600; letter-spacing:.01em}
.tag-pill{display:inline-block; font-size:13px; padding:5px 10px; background:#fff; border:1px solid var(--border); border-radius:999px; color:var(--text-soft); margin:0 4px 6px 0}
.tag-pill:hover{border-color:var(--primary); color:var(--primary); text-decoration:none}
.tag-pill span{font-size:11px; color:var(--muted); margin-left:4px}

.listing h3{font-size:15px; line-height:1.35; margin:0 0 8px; color:var(--text)}
.listing .excerpt{color:var(--text-soft); font-size:13px; margin:0 0 10px;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden}
.listing .meta{display:flex; gap:12px; flex-wrap:wrap; font-size:12px; color:var(--text-soft); padding-top:10px; border-top:1px solid var(--border)}
.listing .meta .price{margin-left:auto; color:var(--text); font-weight:700}
.listing .meta .rating{color:var(--warn)}

/* ===== CTA strip ===== */
.cta{background:linear-gradient(120deg, var(--primary) 0%, #5b6dc6 100%); color:#fff; text-align:center; padding:56px 0}
.cta h2{color:#fff; font-size:28px}
.cta p{color:rgba(255,255,255,.85); max-width:560px; margin:0 auto 24px}
.cta .btn-primary{background:#fff; color:var(--primary)}
.cta .btn-primary:hover{background:#fff; color:var(--primary-d)}

/* ===== Footer ===== */
.footer{background:#fff; border-top:1px solid var(--border); padding:48px 0 24px; font-size:14px}
.foot-cols{display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:32px; margin-bottom:32px}
.foot-cols h4{font-size:12px}
.foot-cols a{display:block; color:var(--text-soft); padding:3px 0}
.foot-cols a:hover{color:var(--primary)}
.foot-cols p{color:var(--text-soft); font-size:13px}
.foot-bottom{border-top:1px solid var(--border); padding-top:20px; color:var(--muted); font-size:12px; text-align:center}

/* ===== Breadcrumbs ===== */
.breadcrumbs{background:#fff; border-bottom:1px solid var(--border); padding:12px 0; font-size:13px}
.breadcrumbs .wrap{display:flex; gap:8px; align-items:center; flex-wrap:wrap}
.breadcrumbs a{color:var(--text-soft)}
.breadcrumbs span{color:var(--muted)}
.breadcrumbs strong{color:var(--text); font-weight:600}

/* ===== Category page ===== */
.cat-hero{background:#fff; padding:40px 0 32px; border-bottom:1px solid var(--border)}
.cat-hero h1{font-size:30px; margin-bottom:8px}
.cat-hero .lead{color:var(--text-soft); margin:0}

.cat-main{padding:40px 0}
.cat-layout{display:grid; grid-template-columns:260px 1fr; gap:32px; align-items:start}

.filters{position:sticky; top:84px}
.filter-box{background:#fff; border:1px solid var(--border); border-radius:var(--r); padding:16px 18px; margin-bottom:12px}
.filter-box h4{margin:0 0 12px}
.filter-box label{display:flex; align-items:center; padding:5px 0; font-size:13px; cursor:pointer; color:var(--text)}
.filter-box label input{margin-right:8px}
.filter-box label span{margin-left:auto; color:var(--muted); font-size:12px}
.price-range{display:flex; align-items:center; gap:6px; font-size:13px}
.price-range input{width:70px; padding:6px 8px; border:1px solid var(--border); border-radius:6px; font-size:13px}

.results-bar{display:flex; justify-content:space-between; align-items:center; margin-bottom:20px}
.result-count{font-size:14px; color:var(--text-soft)}
.result-count strong{color:var(--text)}
.sort{font-size:13px; color:var(--text-soft)}
.sort select{padding:6px 8px; border:1px solid var(--border); border-radius:6px; background:#fff; font-size:13px; margin-left:6px}

.pagination{display:flex; gap:4px; justify-content:center; margin:32px 0 16px; flex-wrap:wrap}
.pagination a{padding:8px 12px; border:1px solid var(--border); border-radius:8px; color:var(--text-soft); font-size:13px; background:#fff}
.pagination a:hover{border-color:var(--primary); color:var(--primary); text-decoration:none}
.pagination a.active{background:var(--primary); border-color:var(--primary); color:#fff}
.pagination .dots{border:0; background:none; pointer-events:none}

.seo-text{background:#fff; border:1px solid var(--border); border-radius:var(--r); padding:24px 28px; margin-top:32px}
.seo-text h2{font-size:18px}
.seo-text p{font-size:14px; color:var(--text-soft)}

.empty-state{text-align:center; padding:48px 24px; background:#fff; border:1px solid var(--border); border-radius:var(--r)}
.empty-state p{font-size:17px; color:var(--text-soft); margin-bottom:20px}

/* ===== Ad detail ===== */
.ad-main{padding:24px 0 56px}
.ad-layout{display:grid; grid-template-columns:1fr 340px; gap:32px; align-items:start}
.ad-body > *{margin-bottom:24px}

.ad-hero h1{font-size:28px; margin-bottom:12px}
.ad-tags{display:flex; gap:8px; margin-bottom:12px; flex-wrap:wrap}
.ad-tags a{text-decoration:none}
.ad-tags span{padding:3px 10px; background:var(--primary-l); color:var(--primary); border-radius:999px; font-size:12px; font-weight:600}
.ad-tags .tag-top{background:var(--warn); color:#fff}
.ad-meta-top{display:flex; gap:16px; flex-wrap:wrap; color:var(--text-soft); font-size:13px}
.ad-meta-top .rating{color:var(--warn)}

.ad-gallery{display:grid; grid-template-columns:1fr; gap:8px}
.ad-photo.main{aspect-ratio:16/9; border-radius:var(--r); position:relative; display:flex; align-items:flex-end; padding:14px}
.photo-label{background:rgba(0,0,0,.55); color:#fff; padding:4px 10px; border-radius:6px; font-size:12px}
.ad-thumbs{display:flex; gap:8px}
.ad-thumbs .thumb{flex:1; aspect-ratio:4/3; border-radius:8px; cursor:pointer; border:2px solid transparent}
.ad-thumbs .thumb:first-child{border-color:var(--primary)}

.ad-section{background:#fff; border:1px solid var(--border); border-radius:var(--r); padding:24px 28px}
.ad-section h2{font-size:18px; margin-bottom:14px}
.ad-section ul{margin:0 0 .8em; padding-left:20px; color:var(--text-soft)}
.ad-section ul li{margin-bottom:4px}

.ad-details{display:grid; grid-template-columns:1fr 1fr; gap:0; border-top:1px solid var(--border)}
.ad-details > div{display:flex; justify-content:space-between; padding:10px 0; border-bottom:1px solid var(--border); font-size:14px}
.ad-details > div:nth-child(odd){padding-right:16px}
.ad-details > div:nth-child(even){padding-left:16px; border-left:1px solid var(--border)}
.ad-details span{color:var(--text-soft)}

.rating-summary{display:flex; gap:24px; align-items:center; margin-bottom:24px; padding-bottom:24px; border-bottom:1px solid var(--border)}
.rating-big{font-size:48px; font-weight:700; color:var(--warn); line-height:1}
.rating-bars{flex:1}
.rating-bars > div{display:flex; align-items:center; gap:10px; font-size:12px; color:var(--text-soft); margin-bottom:4px}
.rating-bars .bar{flex:1; height:6px; background:var(--bg-tint); border-radius:3px; overflow:hidden}
.rating-bars .bar > div{height:100%; background:var(--warn)}

.opinion{padding:14px 0; border-bottom:1px solid var(--border)}
.opinion:last-of-type{border-bottom:0}
.op-head{display:flex; gap:12px; align-items:center; margin-bottom:6px; font-size:13px; flex-wrap:wrap}
.op-head strong{font-weight:600}
.op-head .date{color:var(--muted); margin-left:auto}
.opinion p{margin:0; color:var(--text-soft); font-size:14px}

/* ===== Ad sidebar ===== */
.ad-side{position:sticky; top:84px; display:flex; flex-direction:column; gap:12px}
.ad-card{background:#fff; border:1px solid var(--border); border-radius:var(--r); padding:20px}
.price-big{font-size:32px; font-weight:700; color:var(--text); line-height:1; margin-bottom:6px}
.price-big span{font-size:16px; color:var(--text-soft); font-weight:500}
.price-note{font-size:13px; color:var(--text-soft); margin-bottom:16px; padding-bottom:14px; border-bottom:1px dashed var(--border)}
.price-card .btn{margin-bottom:8px}
.ad-actions{display:flex; justify-content:space-between; padding-top:14px; margin-top:8px; border-top:1px solid var(--border); font-size:13px}
.ad-actions a{color:var(--text-soft)}
.ad-actions a:hover{color:var(--primary); text-decoration:none}

.profile-head{display:flex; gap:12px; align-items:center; margin-bottom:16px}
.avatar{width:48px; height:48px; border-radius:50%; background:linear-gradient(135deg, var(--primary), var(--accent)); color:#fff; display:flex; align-items:center; justify-content:center; font-weight:700}
.avatar-big{width:96px; height:96px; font-size:32px}
.profile-head strong{display:block; font-size:15px}
.role-label{display:block; font-size:12px; color:var(--text-soft); margin-top:2px}
.verified{font-size:12px; color:var(--accent); font-weight:600; display:inline-block; margin-top:2px}
.profile-stats{display:flex; justify-content:space-between; padding:14px 0; border-top:1px solid var(--border); border-bottom:1px solid var(--border); margin-bottom:14px}
.profile-stats > div{text-align:center}
.profile-stats strong{display:block; font-size:16px}
.profile-stats span{font-size:11px; color:var(--muted); text-transform:uppercase; letter-spacing:.04em}

.safety h4{margin-bottom:10px}
.safety ul{margin:0; padding-left:18px; color:var(--text-soft); font-size:13px}
.safety li{margin-bottom:4px}

/* ===== Profile page ===== */
.profile-main{padding:40px 0}
.profile-header{display:flex; gap:24px; align-items:flex-start; background:#fff; border:1px solid var(--border); border-radius:var(--r); padding:32px; margin-bottom:24px}
.profile-info{flex:1}
.profile-info h1{margin:0}
.profile-headline{font-size:17px; color:var(--text-soft); margin:8px 0 16px}
.profile-meta{display:flex; gap:16px; color:var(--text-soft); font-size:13px; margin-bottom:12px; flex-wrap:wrap}
.profile-stats-inline{display:flex; gap:24px; padding-top:12px; border-top:1px solid var(--border)}
.profile-stats-inline strong{color:var(--text)}

/* ===== Related ===== */
.related{background:#fff; border-top:1px solid var(--border)}

/* ===== Add form ===== */
.add-main{padding:48px 0}
.add-wrap{max-width:760px}
.add-wrap h1{margin-bottom:8px}
.add-intro{color:var(--text-soft); margin-bottom:32px}

.add-form{background:#fff; border:1px solid var(--border); border-radius:var(--r); padding:32px}
.form-row{margin-bottom:20px}
.form-row label{display:block; font-weight:600; font-size:14px; margin-bottom:6px}
.form-row .req{color:var(--error)}
.form-row .req-or{color:var(--text-soft); font-weight:400; font-size:12px}
.form-row small{display:block; color:var(--text-soft); font-size:12px; margin-top:4px}
.form-row input[type=text],
.form-row input[type=email],
.form-row input[type=tel],
.form-row input[type=number],
.form-row input[type=password],
.form-row select,
.form-row textarea{width:100%; padding:10px 14px; border:1px solid var(--border); border-radius:8px; font-size:14px; background:#fff; font-family:inherit}
.form-row input:focus,
.form-row select:focus,
.form-row textarea:focus{outline:0; border-color:var(--primary); box-shadow:0 0 0 3px var(--primary-l)}
.form-row textarea{resize:vertical; min-height:120px}
.form-cols{display:grid; grid-template-columns:1fr 1fr; gap:16px}
.form-cols .form-row{margin-bottom:0}
.radio-row{display:flex; gap:12px; flex-wrap:wrap}
.radio-row label{font-weight:400; font-size:14px; margin:0; display:flex; align-items:center; gap:4px}
.price-input{display:flex; gap:8px; align-items:center}
.price-input input{flex:1}
.price-input select{flex:1}
.form-accept{margin-top:24px}
.form-accept label{font-weight:400; font-size:14px}
.form-error{color:var(--error); font-size:13px; margin-top:4px}
.form-hint{margin-top:16px; text-align:center; color:var(--text-soft); font-size:13px}

.alert{padding:12px 16px; border-radius:8px; margin-bottom:20px; font-size:14px}
.alert-error{background:#fee2e2; color:#b91c1c; border:1px solid #fecaca}
.alert-success{background:#dcfce7; color:#16803d; border:1px solid #bbf7d0}

/* ===== Math captcha ===== */
.captcha-row{background:var(--bg-tint); border:1px solid var(--border); border-radius:10px; padding:16px 18px; margin-top:24px}
.captcha-box{display:flex; align-items:center; gap:14px; flex-wrap:wrap}
.captcha-q{font-size:18px; color:var(--text); font-family:'Courier New', monospace; user-select:none}
.captcha-q strong{font-weight:700; color:var(--primary); letter-spacing:.05em}
.captcha-row input[type=text]{width:120px; font-size:18px; text-align:center; font-family:'Courier New', monospace; font-weight:700}

/* ===== Tryb edycji formularza ===== */
.edit-banner{display:flex; justify-content:space-between; align-items:center; gap:12px;
  background:#fef3c7; border:1px solid #fde68a; color:#92400e;
  padding:12px 16px; border-radius:10px; margin-bottom:20px; font-size:14px; flex-wrap:wrap}
.edit-banner a{color:#92400e; font-weight:600}
.btn-danger{background:#fff; color:#dc2626; border:1px solid #fecaca}
.btn-danger:hover{background:#fee2e2; color:#b91c1c; text-decoration:none}

/* Istniejące zdjęcia w trybie edycji */
.existing-photos{display:flex; gap:10px; flex-wrap:wrap; margin-top:6px}
.existing-photo{position:relative; display:block; cursor:pointer; border-radius:8px; overflow:hidden; border:2px solid var(--border); transition:border-color .15s}
.existing-photo img{display:block; width:120px; height:90px; object-fit:cover}
.existing-photo .remove-check{
  position:absolute; bottom:0; left:0; right:0;
  background:rgba(0,0,0,.65); color:#fff;
  padding:4px 6px; font-size:12px; display:flex; align-items:center; gap:4px;
}
.existing-photo .remove-check input{margin:0}
.existing-photo:has(input:checked){border-color:var(--error); opacity:.7}
.existing-photo:has(input:checked) .remove-check{background:var(--error)}

/* ===== Static pages ===== */
.static-page{padding:48px 0; min-height:60vh}
.static-page h1{margin-bottom:24px}
.static-page h2{margin-top:32px; font-size:20px}
.static-page ol, .static-page ul{padding-left:20px; color:var(--text-soft)}
.static-page li{margin-bottom:6px}

/* ===== Pricing ===== */
.pricing{display:grid; grid-template-columns:repeat(3, 1fr); gap:16px; margin:32px 0}
.price-tile{background:#fff; border:1px solid var(--border); border-radius:var(--r); padding:24px; text-align:center}
.price-tile.featured{border-color:var(--primary); box-shadow:var(--shadow-h)}
.price-tile h3{font-size:18px}
.price-tag{font-size:32px; font-weight:700; color:var(--primary); margin:16px 0; line-height:1}
.price-tag small{font-size:14px; color:var(--text-soft); font-weight:500}
.price-tile ul{list-style:none; padding:0; margin:0 0 24px; text-align:left}
.price-tile li{padding:6px 0; font-size:14px; color:var(--text-soft)}

/* ===== Error page ===== */
.error-page .cat-grid{margin-top:24px}

/* ===== Responsive ===== */
@media (max-width: 980px){
  .cat-grid{grid-template-columns:repeat(2,1fr)}
  .city-list, .city-list-full{grid-template-columns:repeat(2,1fr)}
  .listing-grid{grid-template-columns:repeat(2,1fr)}
  .foot-cols{grid-template-columns:1fr 1fr}
  .cat-layout, .ad-layout{grid-template-columns:1fr}
  .filters, .ad-side{position:static}
  .pricing{grid-template-columns:1fr}
  .profile-header{flex-direction:column; align-items:center; text-align:center}
}
@media (max-width: 640px){
  .topbar .wrap{height:auto; padding:12px 20px; flex-wrap:wrap}
  .menu-toggle{display:block}
  .nav{display:none; width:100%; flex-direction:column; align-items:stretch; padding-top:8px}
  body.menu-open .nav{display:flex}
  .nav a{padding:10px 12px}
  .nav .btn{margin-top:8px}
  .hero{padding:40px 0}
  .hero h1{font-size:28px}
  .search{flex-direction:column}
  .search .btn{width:100%}
  .search-inline{flex-direction:column}
  .cat-grid, .listing-grid, .city-list, .city-list-full{grid-template-columns:1fr}
  .foot-cols{grid-template-columns:1fr}
  .ad-details{grid-template-columns:1fr}
  .ad-details > div:nth-child(even){padding-left:0; border-left:0}
  .ad-details > div:nth-child(odd){padding-right:0}
  .form-cols{grid-template-columns:1fr}
  .admin-shell{grid-template-columns:1fr}
  .admin-side{padding:12px 0}
  .admin-stats{grid-template-columns:1fr 1fr}
}
