/*
 Theme Name: Urbico
 Theme URI: https://urbico.com.au
 Author: Urbico
 Description: Urbico Plumbing & Gas theme 
 Version: 1.0.3
 License: GPL-2.0-or-later
 Text Domain: urbico
*/

:root{
  --urbico-blue:#213a8f;
  --urbico-gold:#f0a41a;
  --urbico-dark:#0b0f18;
  --urbico-mid:#1b2433;
  --urbico-light:#f7f8fb;
  --radius:14px;
  --maxw:1200px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:#fff;color:#0a0a0a;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,Ubuntu,Inter,sans-serif;line-height:1.6}
a{color:var(--urbico-blue);text-decoration:none}
a:hover{opacity:.85}

.container{max-width:var(--maxw);margin:0 auto;padding:0 20px}

.btn{display:inline-block;padding:14px 22px;border-radius:10px;font-weight:700}
.btn-primary{background:var(--urbico-gold);color:#000}
.btn-secondary{background:var(--urbico-blue);color:#fff}

/* ===== Header (clean + visible) ===== */
.site-header{
  background:#fff;
  border-bottom:1px solid #eee;
  color:#111;
}

.header-inner{
  max-width:var(--maxw);
  margin:0 auto;
  padding:14px 20px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  min-height:88px;
}

.site-logo img{
  max-height:64px;
  width:auto;
  display:block;
}

/* Nav */
.main-navigation{
  flex:1;
  display:flex;
  justify-content:center;
}

.main-menu{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  gap:28px;
  align-items:center;
}

.main-menu > li{position:relative}

.main-menu a{
  text-decoration:none;
  color:#111;
  font-weight:800;
  font-size:15px;
  padding:10px 2px;
  display:inline-flex;
  align-items:center;
}

/* Dropdowns */
.main-menu ul{
  list-style:none;
  margin:0;
  padding:8px 0;
  display:none;
  position:absolute;
  top:calc(100% + 8px);
  left:0;
  min-width:240px;
  background:#fff;
  border:1px solid #eee;
  border-radius:12px;
  box-shadow:0 14px 34px rgba(0,0,0,.12);
  z-index:9999;
}

.main-menu li:hover > ul{display:block}

.main-menu ul a{
  display:block;
  padding:10px 16px;
  font-weight:700;
  font-size:14px;
  white-space:nowrap;
}

.main-menu ul a:hover{background:#f7f7f7}

/* Actions */
.header-actions{
  display:flex;
  align-items:center;
  gap:14px;
}

.header-phone{
  font-weight:800;
  color:#111;
  text-decoration:none;
}

.header-booking{
  background:#0073aa;
  color:#fff;
  text-decoration:none;
  padding:10px 18px;
  border-radius:10px;
  font-weight:900;
}

/* ===== Rest of your original theme sections ===== */
.hero{padding:70px 0 40px;background:linear-gradient(200deg,var(--urbico-mid),var(--urbico-dark));color:#fff}
.hero h1{font-size:42px;margin:.2em 0}
.hero p.lede{font-size:18px;opacity:.9}
.badges{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:24px 0}
.badge{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);padding:14px;border-radius:12px;text-align:center;color:#fff}
.section{padding:56px 0}
.section.light{background:var(--urbico-light)}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card{background:#fff;border:1px solid #eee;border-radius:var(--radius);padding:18px}
.footer{background:#0b0f18;color:#cfd6e6;padding:36px 0;margin-top:40px}
.small{font-size:14px;color:#6b7280}
.sticky-call{position:fixed;right:18px;bottom:18px;z-index:9999}
.sticky-call a{display:inline-block;padding:14px 18px;border-radius:999px;background:var(--urbico-gold);color:#000;font-weight:800;box-shadow:0 10px 24px rgba(0,0,0,.25)}

@media(max-width:900px){
  .grid-3{grid-template-columns:1fr}
  .badges{grid-template-columns:1fr 1fr}
  .hero{padding:54px 0}
  .main-navigation{display:none}
}
/* =========================
   ALIGNMENT FIX (DESKTOP)
   ========================= */

/* 1) Default: left-align content inside grid/boxes on desktop */
@media (min-width: 920px){

  /* Hero: left align the main text column */
  .upg-hero-grid > div{
    text-align:left;
  }

  /* Keep the badge and trust pills aligned nicely */
  .upg-row,
  .upg-trust{
    justify-content:flex-start;
  }

  /* Paragraph blocks: remove auto-centering so they sit flush */
  .upg-hero-grid > div .upg-p{
    margin-left:0;
    margin-right:0;
  }

  /* 2-column sections: stop inherited center alignment from wrappers */
  .upg-split .upg-box,
  .upg-split aside.upg-box{
    text-align:left;
  }

  /* Any centered section wrapper should not force center inside split grids */
  .upg-sec .upg-split,
  .upg-sec-tight .upg-split{
    text-align:left;
  }

  /* Make link cards feel aligned (no accidental centering) */
  .upg-card,
  .upg-box{
    text-align:left;
  }
}

/* =========================
   MOBILE: KEEP CENTERED HERO
   ========================= */
@media (max-width: 919px){
  .upg-hero-grid > div{
    text-align:center;
  }
  .upg-row,
  .upg-trust{
    justify-content:center;
  }
  .upg-hero-grid > div .upg-p{
    margin-left:auto;
    margin-right:auto;
  }
}


/* --- PATCH: stop theme styles taking over half-way down --- */
.urbico-platinum-gas h1,
.urbico-platinum-gas h2,
.urbico-platinum-gas h3{
  margin: 0;
  color: var(--ink) !important;
  letter-spacing: -0.02em;
}

.urbico-platinum-gas h1{font-size:50px !important; line-height:1.05 !important; margin:18px 0 10px !important;}
.urbico-platinum-gas h2{font-size:34px !important; line-height:1.2 !important;}
.urbico-platinum-gas h3{font-size:18px !important; line-height:1.3 !important;}

.urbico-platinum-gas p{
  color: var(--text) !important;
  line-height: 1.75 !important;
  font-size: 17px !important;
  margin: 14px 0 0 !important;
}

.urbico-platinum-gas ul,
.urbico-platinum-gas ol{
  margin: 14px 0 0 !important;
  padding-left: 18px !important;
  color: var(--text) !important;
  line-height: 1.75 !important;
}

.urbico-platinum-gas a{
  text-decoration: none !important;
}

.urbico-platinum-gas .upg-link{
  display:block !important;
  padding:14px !important;
  border-radius:14px !important;
  border:1px solid var(--b) !important;
  background:#fff !important;
  color: var(--ink) !important;
  font-weight: 900 !important;
}


/* =========================
   FINAL CTA BALANCE PATCH
   (Gas page - dark CTA section)
   ========================= */

.urbico-platinum-gas .upg-final{
  padding: 86px 0 78px;
}

/* Constrain CTA content so it feels centred in the wide background */
.urbico-platinum-gas .upg-final .upg-wrap{
  max-width: 980px;
  text-align: center;
}

/* Tighten headline + paragraph measure for nicer balance */
.urbico-platinum-gas .upg-final h2{
  max-width: 22ch;
  margin-left: auto;
  margin-right: auto;
}

.urbico-platinum-gas .upg-final p{
  max-width: 70ch;
  margin-left: auto;
  margin-right: auto;
}

/* Centre and balance the buttons */
.urbico-platinum-gas .upg-final .upg-row{
  justify-content: center;
  gap: 16px;
}

/* Equal button sizing on desktop so one doesn't dominate */
@media (min-width: 920px){
  .urbico-platinum-gas .upg-final .upg-btn{
    min-width: 260px;
  }
}

/* Make outline button suitable for dark background (reduces "left heavy" look) */
.urbico-platinum-gas .upg-final .upg-outline{
  background: rgba(255,255,255,.08);
  color: #fff;
  border-color: rgba(255,255,255,.35);
  box-shadow: none;
}

.urbico-platinum-gas .upg-final .upg-outline:hover{
  background: rgba(255,255,255,.14);
  transform: translateY(-2px);
}


/* =========================
   FORCE CTA TO BE BALANCED
   ========================= */

/* Cover multiple page wrappers just in case */
.urbico-platinum-gas .upg-final .upg-wrap,
.urbico-platinum-emergency .upe-final .upe-wrap,
.urbico-platinum-pas .upp-final .upp-wrap{
  max-width: 980px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  text-align: center !important;
}

/* Force button row centering */
.urbico-platinum-gas .upg-final .upg-row,
.urbico-platinum-emergency .upe-final .upe-row,
.urbico-platinum-pas .upp-final .upp-row{
  justify-content: center !important;
  gap: 16px !important;
}

/* Equal button sizing on desktop */
@media (min-width: 920px){
  .urbico-platinum-gas .upg-final .upg-btn,
  .urbico-platinum-emergency .upe-final .upe-btn,
  .urbico-platinum-pas .upp-final .upp-btn{
    min-width: 260px !important;
  }
}

/* Make outline button not look "left heavy" on dark background */
.urbico-platinum-gas .upg-final .upg-outline,
.urbico-platinum-emergency .upe-final .upe-outline,
.urbico-platinum-pas .upp-final .upp-outline{
  background: rgba(255,255,255,.08) !important;
  color: #fff !important;
  border-color: rgba(255,255,255,.35) !important;
  box-shadow: none !important;
}



/* Make trust chips line up neatly */
.ucu-trust{
  display:grid !important;
  gap:12px !important;
  margin-top:18px !important;
  justify-items:center; /* centers each chip in its cell */
}

/* 4 across on desktop, 2 on tablets, 1 on phones */
@media (min-width: 980px){
  .ucu-trust{ grid-template-columns: repeat(4, minmax(0, 1fr)) !important; }
}
@media (min-width: 620px) and (max-width: 979px){
  .ucu-trust{ grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
}
@media (max-width: 619px){
  .ucu-trust{ grid-template-columns: 1fr !important; }
}

/* Make each chip consistent */
.ucu-trust span{
  width:100% !important;
  max-width:260px;           /* keeps them uniform */
  text-align:center !important;
  justify-content:center !important;
  display:flex !important;
  align-items:center !important;
  gap:10px !important;
}



/* FULL-WIDTH CTA BAND (bulletproof breakout, ignores parent padding/offset) */
.urp-bandwide{
  background:
    radial-gradient(900px 420px at 50% -180px, rgba(255,255,255,.10), transparent 70%),
    linear-gradient(180deg,#0b2a3a,#071b26);
  color:#fff;
  padding:46px 0;
  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(255,255,255,.08);

  position:relative;
  left:50%;
  transform:translateX(-50%);
  width:100vw;
  max-width:100vw;
}
