/*
Theme Name: 3R Handyman Services
Theme URI: https://3rhandymanservices.com
Author: 3R Handyman Services
Description: Custom one-page business theme for 3R Handyman Services. Reliable. Responsive. Reasonable. Edit contact info under Appearance > Customize > Business Info.
Version: 1.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: threer-handyman
*/

:root{
  --orange:#E8532C;
  --orange-dark:#C2401E;
  --ink:#2A2D33;
  --slate:#5B6068;
  --line:#E4E1DB;
  --bg:#F7F6F3;
  --white:#FFFFFF;
  --radius:10px;
  --display:'Barlow Condensed',sans-serif;
  --body:'Barlow',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:var(--body);color:var(--ink);background:var(--bg);line-height:1.55;font-size:17px;}
img{max-width:100%;display:block;height:auto;}
a{color:inherit;}
.container{max-width:1100px;margin:0 auto;padding:0 22px;}
h1,h2,h3{font-family:var(--display);line-height:1.05;letter-spacing:.01em;}
:focus-visible{outline:3px solid var(--orange);outline-offset:3px;border-radius:4px;}

/* ---------- utility bar ---------- */
.utility{background:var(--ink);color:#D8D6D1;font-size:14px;}
.utility .container{display:flex;justify-content:space-between;align-items:center;gap:14px;padding-top:7px;padding-bottom:7px;flex-wrap:wrap;}
.utility a{color:#fff;text-decoration:none;font-weight:600;}
.utility a:hover{color:var(--orange);}
.dot{color:var(--orange);margin:0 8px;}

/* ---------- nav ---------- */
header.site-nav{background:var(--white);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50;}
.site-nav .container{display:flex;align-items:center;justify-content:space-between;gap:18px;padding-top:10px;padding-bottom:10px;}
.brand img{height:62px;width:auto;}
nav.links ul{display:flex;gap:26px;font-weight:600;font-size:15.5px;list-style:none;}
nav.links a{text-decoration:none;color:var(--slate);padding:4px 0;border-bottom:2px solid transparent;}
nav.links a:hover{color:var(--ink);border-bottom-color:var(--orange);}
.btn{display:inline-block;font-family:var(--display);font-weight:700;font-size:19px;letter-spacing:.04em;text-transform:uppercase;text-decoration:none;padding:12px 26px;border-radius:var(--radius);transition:transform .12s ease,background .12s ease;text-align:center;}
.btn:hover{transform:translateY(-1px);}
.btn-orange{background:var(--orange);color:#fff;}
.btn-orange:hover{background:var(--orange-dark);color:#fff;}
.btn-ghost{border:2px solid var(--ink);color:var(--ink);background:transparent;}
.btn-ghost:hover{background:var(--ink);color:#fff;}
.site-nav .btn{padding:10px 20px;font-size:17px;}
@media(max-width:760px){nav.links{display:none;}}

/* ---------- hero ---------- */
.hero{background:var(--white);position:relative;overflow:hidden;}
.hero .container{display:grid;grid-template-columns:1.15fr .85fr;gap:48px;padding-top:72px;padding-bottom:96px;align-items:center;}
.eyebrow{font-family:var(--display);font-weight:600;font-size:17px;letter-spacing:.14em;text-transform:uppercase;color:var(--orange);margin-bottom:14px;}
.hero h1{font-size:clamp(44px,6.2vw,72px);font-weight:700;text-transform:uppercase;}
.hero h1 em{font-style:normal;color:var(--orange);}
.hero p.lede{margin:18px 0 28px;font-size:19px;color:var(--slate);max-width:46ch;}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;}
.hero-note{margin-top:14px;font-size:14.5px;color:var(--slate);}

/* signature: the 3R checklist */
.threer{background:var(--bg);border:1px solid var(--line);border-radius:14px;padding:30px 32px;box-shadow:0 18px 40px rgba(42,45,51,.08);}
.threer .tag{font-family:var(--display);font-weight:700;font-size:15px;letter-spacing:.16em;text-transform:uppercase;color:var(--slate);margin-bottom:18px;}
.threer ul{list-style:none;}
.threer li{display:flex;align-items:center;gap:16px;padding:14px 0;border-bottom:1px dashed var(--line);}
.threer li:last-child{border-bottom:none;}
.check{flex:0 0 auto;width:34px;height:34px;border:3px solid var(--ink);border-radius:7px;position:relative;background:#fff;}
.check::after{content:"";position:absolute;left:7px;top:-7px;width:14px;height:26px;border:solid var(--orange);border-width:0 5px 5px 0;transform:rotate(40deg);}
.threer .r{font-family:var(--display);font-weight:700;font-size:32px;text-transform:uppercase;}
.threer .r span{color:var(--orange);}
.threer .sub{font-size:14.5px;color:var(--slate);margin-top:1px;}
.roofline{height:54px;background:var(--white);clip-path:polygon(0 0,100% 0,100% 18%,0 100%);}
@media(max-width:860px){.hero .container{grid-template-columns:1fr;padding-top:48px;padding-bottom:64px;}}

/* ---------- trust strip ---------- */
.trust{background:var(--ink);color:#fff;}
.trust .container{display:flex;justify-content:space-between;gap:18px;padding-top:20px;padding-bottom:20px;flex-wrap:wrap;}
.trust .item{display:flex;align-items:center;gap:10px;font-weight:600;font-size:15.5px;}
.trust .item b{color:var(--orange);font-family:var(--display);font-size:22px;font-weight:700;letter-spacing:.03em;}

/* ---------- sections ---------- */
section.block{padding:78px 0;}
.section-head{max-width:640px;margin-bottom:42px;}
.section-head h2{font-size:clamp(34px,4.4vw,48px);text-transform:uppercase;font-weight:700;}
.section-head h2::after{content:"";display:block;width:64px;height:5px;background:var(--orange);margin-top:12px;border-radius:3px;}
.section-head p{margin-top:16px;color:var(--slate);font-size:18px;}

/* services */
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;}
.card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:24px 22px;transition:transform .15s ease,box-shadow .15s ease;}
.card:hover{transform:translateY(-3px);box-shadow:0 14px 30px rgba(42,45,51,.10);}
.card .ico{font-size:28px;line-height:1;margin-bottom:14px;}
.card h3{font-size:23px;font-weight:700;text-transform:uppercase;margin-bottom:8px;}
.card p{font-size:15px;color:var(--slate);}
.card .flat{display:inline-block;margin-top:14px;font-family:var(--display);font-weight:600;font-size:14px;letter-spacing:.1em;text-transform:uppercase;color:var(--orange);border:1.5px solid var(--orange);border-radius:99px;padding:3px 12px;}
@media(max-width:980px){.svc-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:560px){.svc-grid{grid-template-columns:1fr;}}

/* how it works */
.how{background:var(--white);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;counter-reset:step;}
.step{position:relative;padding:26px 24px 24px;border:1px solid var(--line);border-radius:var(--radius);background:var(--bg);}
.step::before{counter-increment:step;content:counter(step);position:absolute;top:-20px;left:20px;width:40px;height:40px;border-radius:9px;background:var(--orange);color:#fff;font-family:var(--display);font-weight:700;font-size:24px;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 14px rgba(232,83,44,.35);}
.step h3{font-size:24px;text-transform:uppercase;margin:10px 0 8px;}
.step p{font-size:15.5px;color:var(--slate);}
@media(max-width:820px){.steps{grid-template-columns:1fr;gap:36px;}}

/* promise band */
.promise{background:var(--orange);color:#fff;padding:60px 0;}
.promise .container{display:flex;align-items:center;justify-content:space-between;gap:26px;flex-wrap:wrap;}
.promise h2{font-size:clamp(30px,4.4vw,46px);text-transform:uppercase;font-weight:700;max-width:560px;}
.promise .btn{background:#fff;color:var(--orange-dark);}
.promise .btn:hover{background:var(--ink);color:#fff;}

/* reviews */
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.review{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:26px 24px;display:flex;flex-direction:column;gap:14px;}
.stars{color:var(--orange);font-size:18px;letter-spacing:3px;}
.review p{font-size:15.5px;color:var(--ink);}
.review .who{font-family:var(--display);font-weight:600;font-size:17px;letter-spacing:.06em;text-transform:uppercase;color:var(--slate);}
@media(max-width:820px){.grid3{grid-template-columns:1fr;}}

/* area + quote */
.contact{background:var(--white);border-top:1px solid var(--line);}
.contact .container{display:grid;grid-template-columns:1fr 1.1fr;gap:48px;align-items:start;}
.area h3{font-size:26px;text-transform:uppercase;margin-bottom:10px;}
.area p{color:var(--slate);font-size:16px;margin-bottom:20px;}
.area ul{list-style:none;display:flex;flex-wrap:wrap;gap:10px;}
.area li{background:var(--bg);border:1px solid var(--line);border-radius:99px;padding:6px 16px;font-weight:600;font-size:14.5px;}
.bigcall{margin-top:30px;padding:22px;border-radius:var(--radius);background:var(--ink);color:#fff;}
.bigcall .lbl{font-family:var(--display);letter-spacing:.14em;text-transform:uppercase;font-size:14px;color:#B9BDC4;}
.bigcall a{font-family:var(--display);font-weight:700;font-size:38px;color:#fff;text-decoration:none;}
.bigcall a:hover{color:var(--orange);}
/* work-order form */
.workorder{background:var(--bg);border:2px dashed var(--slate);border-radius:14px;padding:30px;position:relative;}
.workorder .stamp{position:absolute;top:-16px;right:22px;background:var(--orange);color:#fff;font-family:var(--display);font-weight:700;letter-spacing:.12em;text-transform:uppercase;font-size:15px;padding:6px 16px;border-radius:6px;transform:rotate(2deg);box-shadow:0 6px 14px rgba(232,83,44,.35);}
.workorder h3{font-size:30px;text-transform:uppercase;margin-bottom:6px;}
.workorder .hint{font-size:15px;color:var(--slate);margin-bottom:22px;}
.field{margin-bottom:16px;}
.field label{display:block;font-family:var(--display);font-weight:600;letter-spacing:.1em;text-transform:uppercase;font-size:14px;color:var(--slate);margin-bottom:6px;}
.field input,.field textarea,.field select{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:8px;font-family:var(--body);font-size:16px;background:#fff;color:var(--ink);}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--orange);outline:none;box-shadow:0 0 0 3px rgba(232,83,44,.18);}
.workorder .btn{width:100%;border:none;cursor:pointer;font-size:21px;}
.formnote{font-size:13.5px;color:var(--slate);margin-top:12px;}
/* contact form 7 / wpforms friendly defaults inside the work order */
.workorder .wpcf7 input[type="text"],.workorder .wpcf7 input[type="tel"],.workorder .wpcf7 input[type="email"],.workorder .wpcf7 textarea{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:8px;font-family:var(--body);font-size:16px;background:#fff;}
.workorder .wpcf7 input[type="submit"]{width:100%;background:var(--orange);color:#fff;border:none;cursor:pointer;font-family:var(--display);font-weight:700;font-size:21px;letter-spacing:.04em;text-transform:uppercase;padding:12px 26px;border-radius:var(--radius);}
@media(max-width:880px){.contact .container{grid-template-columns:1fr;}}

/* footer */
footer.site-footer{background:var(--ink);color:#B9BDC4;padding:44px 0 30px;}
footer.site-footer .container{display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;align-items:center;}
footer .wordmark{font-family:var(--display);font-weight:700;font-size:26px;text-transform:uppercase;color:#fff;}
footer .wordmark span{color:var(--orange);}
footer.site-footer a{color:#fff;text-decoration:none;}
footer.site-footer a:hover{color:var(--orange);}
footer .fine{font-size:13.5px;width:100%;border-top:1px solid #3A3E45;margin-top:24px;padding-top:18px;}

/* blog/page fallback so regular pages look decent */
.entry{background:var(--white);}
.entry .container{max-width:760px;padding-top:60px;padding-bottom:80px;}
.entry h1.entry-title{font-size:clamp(36px,5vw,54px);text-transform:uppercase;margin-bottom:24px;}
.entry .entry-content p{margin-bottom:18px;}
.entry .entry-content h2,.entry .entry-content h3{margin:28px 0 12px;}
.entry .entry-content ul,.entry .entry-content ol{margin:0 0 18px 24px;}

@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  *{transition:none!important;animation:none!important;}
}
