/*
Theme Name: Plumbers Corners
Theme URI: https://plumberscorners.com
Author: PlumbersCorners
Description: Custom directory + blog theme for PlumbersCorners — a national plumbing company directory and trade blog. Includes a Plumbing Listing custom post type, service/city filtering, front-end Add Listing and Guest Blog submission forms.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
Text Domain: plumberscorners
*/

/* ---------- Design tokens ---------- */
:root{
  --ink:#0F2238;
  --ink-2:#16314A;
  --brass:#C68A2E;
  --brass-dark:#9C6B1F;
  --teal:#1C7C82;
  --rust:#C1440E;
  --bg:#EDF1F2;
  --surface:#FFFFFF;
  --text:#16232C;
  --text-2:#51606B;
  --border:#D7DEE0;
  --font-display:'Poppins', sans-serif;
  --font-body:'Work Sans', sans-serif;
  --font-mono:'IBM Plex Mono', monospace;
  --radius:6px;
  --container:1180px;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;font-size:18px;}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-body);
  font-size:1rem;
  line-height:1.65;
}
img{max-width:100%;display:block;}
a{color:var(--teal);text-decoration:none;}
a:hover{text-decoration:underline;}
ul{margin:0;padding:0;list-style:none;}
button,input,select,textarea{font-family:inherit;font-size:1rem;}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;line-height:1.2;margin:0 0 .5em;color:var(--ink);}
h1{font-size:2.2rem;}
h2{font-size:1.7rem;}
h3{font-size:1.25rem;}
.container{max-width:var(--container);margin:0 auto;padding:0 24px;}
.visually-hidden{position:absolute;left:-9999px;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-display);font-weight:600;
  letter-spacing:.01em;font-size:1rem;
  padding:13px 24px;border-radius:var(--radius);border:2px solid transparent;
  cursor:pointer;transition:transform .15s ease;
}
.btn:hover{text-decoration:none;transform:translateY(-1px);}
.btn-brass{background:var(--brass);color:var(--ink);}
.btn-brass:hover{background:var(--brass-dark);}
.btn-outline{background:transparent;border-color:var(--surface);color:var(--surface);}
.btn-outline:hover{background:rgba(255,255,255,.08);}
.btn-rust{background:var(--rust);color:#fff;}
.btn-rust:hover{background:#a3380b;}
.btn-block{width:100%;justify-content:center;}

/* ---------- Header ---------- */
.site-header{background:var(--ink);position:relative;z-index:50;}
.header-top{display:flex;align-items:center;justify-content:space-between;padding:18px 0;gap:24px;}
.site-logo{font-family:var(--font-display);font-weight:900;font-size:1.7rem;color:#fff;letter-spacing:.01em;}
.site-logo span{color:var(--brass);}
.header-actions{display:flex;align-items:center;gap:14px;}
.main-nav{border-top:1px solid rgba(255,255,255,.12);}
.main-nav ul{display:flex;gap:2px;flex-wrap:wrap;}
.main-nav li{position:relative;}
.main-nav a{
  display:block;padding:14px 16px;color:#cfd8dc;
  font-family:var(--font-display);font-weight:700;font-size:.95rem;
  text-transform:uppercase;letter-spacing:.04em;
}
.main-nav a:hover{color:var(--brass);text-decoration:none;}
.main-nav .sub-menu{
  display:none;position:absolute;left:0;top:100%;min-width:240px;
  background:var(--ink-2);border:1px solid rgba(255,255,255,.12);
  border-radius:0 0 var(--radius) var(--radius);padding:6px;z-index:60;
}
.main-nav li:hover>.sub-menu{display:block;}
.main-nav .sub-menu a{padding:10px 12px;font-size:.88rem;}
.menu-toggle{display:none;background:none;border:1px solid rgba(255,255,255,.3);color:#fff;padding:8px 10px;border-radius:var(--radius);}

/* ---------- Pipe joint divider (signature element) ---------- */
.pipe-divider{display:flex;align-items:center;gap:0;height:18px;margin:0;}
.pipe-divider .seg{flex:1;height:4px;background:var(--brass);}
.pipe-divider .joint{width:14px;height:14px;border-radius:50%;background:var(--brass);border:3px solid var(--ink);margin:0 -7px;flex:none;position:relative;z-index:1;}
.pipe-divider.on-light .seg{background:var(--teal);}
.pipe-divider.on-light .joint{border-color:var(--bg);background:var(--teal);}

/* ---------- Hero ---------- */
.hero{background:var(--ink);color:#fff;padding:64px 0 56px;}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center;}
.hero h1{color:#fff;font-size:2.6rem;max-width:520px;}
.hero h1 .accent{color:var(--brass);}
.hero p.lede{color:#cfd8dc;font-size:1.1rem;max-width:480px;margin-bottom:28px;}
.hero-stats{display:flex;gap:28px;margin-top:28px;}
.hero-stats .stat{font-family:var(--font-mono);}
.hero-stats .stat b{display:block;color:var(--brass);font-size:1.4rem;}
.hero-stats .stat span{color:#9fb0ba;font-size:.88rem;text-transform:uppercase;letter-spacing:.04em;}
.hero-art{background:var(--ink-2);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);min-height:280px;display:flex;align-items:center;justify-content:center;color:#5d7384;font-family:var(--font-mono);font-size:.95rem;}

/* ---------- Search panel ---------- */
.search-panel{
  background:var(--surface);border-radius:var(--radius);padding:20px;
  display:grid;grid-template-columns:1fr 1fr auto;gap:12px;
  margin-top:-30px;position:relative;z-index:10;box-shadow:0 6px 0 0 var(--brass);
}
.search-panel label{display:block;font-size:.82rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-2);margin-bottom:6px;font-weight:600;}
.search-panel select,.search-panel input[type=text]{
  width:100%;padding:11px 12px;border:1px solid var(--border);border-radius:var(--radius);
  background:#fafbfb;color:var(--text);
}
.search-panel .btn{align-self:end;}

/* ---------- Section headings ---------- */
.section{padding:56px 0;}
.section-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:28px;gap:16px;flex-wrap:wrap;}
.section-head h2{font-size:1.9rem;}
.section-head .eyebrow{font-family:var(--font-mono);color:var(--teal);font-size:.88rem;text-transform:uppercase;letter-spacing:.08em;display:block;margin-bottom:6px;}
.section-head a.view-all{font-family:var(--font-display);font-weight:700;text-transform:uppercase;font-size:.92rem;color:var(--ink);white-space:nowrap;}

/* ---------- Category grid ---------- */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px;}
.cat-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:20px 16px;text-align:center;transition:border-color .15s ease;
}
.cat-card:hover{border-color:var(--brass);text-decoration:none;}
.cat-card .ic{width:40px;height:40px;margin:0 auto 10px;color:var(--teal);}
.cat-card .ic svg{width:100%;height:100%;}
.cat-card h3{font-size:1.05rem;margin:0 0 4px;color:var(--text);}
.cat-card span{font-family:var(--font-mono);font-size:.84rem;color:var(--text-2);}

/* ---------- Listing cards ---------- */
.listing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;}
.listing-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;}
.listing-card .thumb{height:150px;background:var(--ink-2);position:relative;}
.listing-card .thumb img{width:100%;height:100%;object-fit:cover;}
.listing-card .badge{position:absolute;top:10px;left:10px;background:var(--rust);color:#fff;font-family:var(--font-mono);font-size:.78rem;text-transform:uppercase;padding:4px 8px;border-radius:3px;}
.listing-card .body{padding:16px;flex:1;display:flex;flex-direction:column;}
.listing-card h3{font-size:1.1rem;margin-bottom:6px;}
.listing-card h3 a{color:var(--ink);}
.listing-card .meta{font-family:var(--font-mono);font-size:.88rem;color:var(--text-2);margin-bottom:10px;}
.listing-card .meta div{margin-bottom:3px;display:flex;gap:6px;align-items:baseline;}
.listing-card .services{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px;}
.listing-card .services span{background:#E6EEF0;color:var(--teal);font-size:.8rem;padding:3px 8px;border-radius:3px;font-weight:600;}
.listing-card .body .btn{margin-top:auto;}

/* ---------- Blog grid ---------- */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;}
.blog-card .thumb{height:150px;background:var(--border);border-radius:var(--radius);margin-bottom:14px;overflow:hidden;}
.blog-card .thumb img{width:100%;height:100%;object-fit:cover;}
.blog-card .cat{font-family:var(--font-mono);font-size:.82rem;text-transform:uppercase;letter-spacing:.04em;color:var(--rust);display:block;margin-bottom:6px;}
.blog-card h3{font-size:1.15rem;margin-bottom:6px;}
.blog-card h3 a{color:var(--ink);}
.blog-card p{color:var(--text-2);font-size:1.02rem;margin:0;}
.blog-card .date{font-family:var(--font-mono);font-size:.85rem;color:var(--text-2);}

/* ---------- Emergency band ---------- */
.emergency-band{background:var(--rust);color:#fff;padding:26px 0;}
.emergency-band .row{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;}
.emergency-band h2{color:#fff;font-size:1.4rem;margin:0;}
.emergency-band p{margin:4px 0 0;color:#fde3da;font-size:1.02rem;}

/* ---------- List your business band ---------- */
.cta-band{background:var(--ink);color:#fff;padding:56px 0;}
.cta-band h2{color:#fff;}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:32px;}
.step{background:var(--ink-2);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);padding:22px;}
.step .num{font-family:var(--font-mono);color:var(--brass);font-size:.95rem;display:block;margin-bottom:8px;}
.step h3{color:#fff;font-size:1.05rem;}
.step p{color:#b9c5cc;font-size:1rem;margin:0;}

/* ---------- Sidebar (single listing / archive) ---------- */
.layout-with-sidebar{display:grid;grid-template-columns:2.2fr 1fr;gap:40px;align-items:start;}
.sidebar-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px;margin-bottom:20px;}
.sidebar-box h4{font-size:1.05rem;text-transform:uppercase;letter-spacing:.03em;border-bottom:2px solid var(--brass);padding-bottom:8px;margin-bottom:12px;}
.sidebar-box ul li{padding:6px 0;border-bottom:1px solid var(--border);font-size:1rem;}
.sidebar-box ul li:last-child{border-bottom:none;}

/* ---------- Filter form (directory archive) ---------- */
.filter-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px;display:grid;grid-template-columns:1fr 1fr auto;gap:12px;margin-bottom:28px;}
.filter-form label{display:block;font-size:.82rem;text-transform:uppercase;color:var(--text-2);margin-bottom:6px;font-weight:600;}
.filter-form select{width:100%;padding:10px;border:1px solid var(--border);border-radius:var(--radius);}

/* ---------- Single listing profile ---------- */
.listing-head{background:var(--ink);color:#fff;padding:40px 0;}
.listing-head h1{color:#fff;}
.listing-head .meta{font-family:var(--font-mono);color:#cfd8dc;display:flex;gap:18px;flex-wrap:wrap;margin-top:10px;font-size:.98rem;}
.spec-table{width:100%;border-collapse:collapse;margin-bottom:24px;}
.spec-table td{padding:10px 0;border-bottom:1px solid var(--border);font-size:1.02rem;}
.spec-table td:first-child{color:var(--text-2);width:160px;font-family:var(--font-mono);font-size:.9rem;text-transform:uppercase;}

/* ---------- Forms (Add Listing / Guest Blog) ---------- */
.form-page-head{background:var(--ink);color:#fff;padding:48px 0;text-align:center;}
.form-page-head h1{color:#fff;}
.submission-form{max-width:680px;margin:0 auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:32px;}
.form-row{margin-bottom:18px;}
.form-row label{display:block;font-weight:600;font-size:1rem;margin-bottom:6px;}
.form-row .req{color:var(--rust);}
.form-row input[type=text],.form-row input[type=email],.form-row input[type=url],.form-row input[type=tel],.form-row textarea,.form-row select{
  width:100%;padding:11px 12px;border:1px solid var(--border);border-radius:var(--radius);background:#fafbfb;
}
.form-row textarea{min-height:140px;resize:vertical;}
.checkbox-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;}
.checkbox-grid label{display:flex;align-items:center;gap:8px;font-weight:400;font-size:1rem;}
.form-notice{padding:14px 16px;border-radius:var(--radius);margin-bottom:20px;font-size:1.02rem;}
.form-notice.success{background:#E1F0E8;color:#1F5B3A;border:1px solid #BBE0C9;}
.form-notice.error{background:#FBE6E2;color:#8A2E15;border:1px solid #F2C2B4;}
.honeypot-field{position:absolute;left:-9999px;}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:#9fb0ba;padding:48px 0 24px;margin-top:0;}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:32px;margin-bottom:32px;}
.footer-grid h4{color:#fff;font-size:1.05rem;text-transform:uppercase;letter-spacing:.03em;margin-bottom:14px;}
.footer-grid li{margin-bottom:8px;font-size:.98rem;}
.footer-grid a{color:#9fb0ba;}
.footer-grid a:hover{color:var(--brass);}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:20px;font-size:.9rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;}

/* ---------- Pagination ---------- */
.pagination{display:flex;gap:8px;margin-top:32px;font-family:var(--font-mono);font-size:.95rem;}
.pagination a,.pagination span{padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);}
.pagination .current{background:var(--ink);color:#fff;border-color:var(--ink);}

/* ---------- Responsive ---------- */
@media (max-width:900px){
  .hero-grid{grid-template-columns:1fr;}
  .hero-art{display:none;}
  .search-panel{grid-template-columns:1fr;}
  .layout-with-sidebar{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;}
  .steps{grid-template-columns:1fr;}
  .filter-form{grid-template-columns:1fr;}
}
@media (max-width:760px){
  .menu-toggle{display:inline-block;}
  .main-nav ul{display:none;flex-direction:column;padding:8px 16px 16px;}
  .main-nav.open ul{display:flex;}
  .main-nav .sub-menu{position:static;display:block;background:none;border:none;padding-left:12px;}
  .emergency-band .row{flex-direction:column;align-items:flex-start;}
}
