/* ============================================================
   Cherrypicker for Hire - public site styles
   (original one-pager design, extended for multi-page CMS)
   ============================================================ */
body{margin:0;font-family:Arial,Helvetica,sans-serif;color:#111827}
a{text-decoration:none;color:inherit}
.container{width:92%;max-width:1180px;margin:auto}
.top{background:#111;color:#fff;padding:9px 0;font-size:14px}
.top .container{display:flex;justify-content:space-between;gap:15px;flex-wrap:wrap}
header{background:#fff;box-shadow:0 4px 20px #0002;position:sticky;top:0;z-index:20}
.nav{height:76px;display:flex;justify-content:space-between;align-items:center}
.logo{font-size:26px;font-weight:900}
.logo span{color:#f5b301}
nav a{margin-left:28px;font-weight:700;font-size:14px}
.btn{background:#f5b301;color:#111;padding:14px 24px;border-radius:6px;font-weight:900;display:inline-block;border:0;cursor:pointer}
.hero{background:linear-gradient(90deg,#000c,#0008,#0002),url("../cherrypicker-for-hire.jpg") center/cover;min-height:620px;color:#fff;display:flex;align-items:center}
.hero h1{font-size:64px;line-height:1;margin:15px 0;text-transform:uppercase}
.hero p{font-size:20px;max-width:620px}
.hero-buttons{display:flex;gap:15px;margin-top:28px;flex-wrap:wrap}
.outline{border:1px solid #fff;padding:14px 24px;border-radius:6px;font-weight:900}
.features{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:55px}
.feature{border-left:1px solid #ffffff55;padding-left:18px;font-weight:800}
section{padding:70px 0}
.heading{text-align:center;margin-bottom:40px}
.heading h2{font-size:34px;margin:0;text-transform:uppercase}
.heading:after,.card h3:after{content:"";display:block;width:45px;height:4px;background:#f5b301;margin:10px auto}
.services{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card{border:1px solid #ddd;border-radius:6px;overflow:hidden;background:#fff;box-shadow:0 8px 25px #0001}
.card img{width:100%;height:210px;object-fit:cover}
.card div{padding:22px}
.card h3{text-transform:uppercase;margin:0 0 10px}
.card h3:after{margin:8px 0}
.grey{background:#f6f6f6}
.split{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.split img{width:100%;border-radius:8px}

/* tick list - scoped so blog/page content lists stay normal */
.ticks{padding-left:0;list-style:none}
.ticks li{margin-bottom:12px}
.ticks li:before{content:"\2713";color:#f5b301;font-weight:900;margin-right:8px}

.gallery{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.gallery img{width:100%;height:135px;object-fit:cover;border-radius:4px}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.step{display:flex;gap:15px}
.number{background:#f5b301;border-radius:50%;width:42px;height:42px;display:grid;place-items:center;font-weight:900;flex:0 0 42px}
.cta{background:#111;color:#fff;padding:35px 0}
.cta .container{display:flex;justify-content:space-between;align-items:center;gap:20px}
.contact{display:grid;grid-template-columns:1fr 1.4fr;gap:50px}
input,textarea{width:100%;padding:13px;margin-bottom:12px;border:1px solid #ccc;box-sizing:border-box;font-family:inherit;font-size:15px}
textarea{height:100px}
.hp{position:absolute;left:-9999px;top:-9999px}
footer{background:#090909;color:#ccc;padding:18px 0;font-size:13px}

/* ---- inner pages (About / Services / Case Studies / generic CMS pages) ---- */
.page-inner{padding:60px 0;min-height:50vh}
.breadcrumb{font-size:12px;color:#999;margin-bottom:14px;text-transform:uppercase;letter-spacing:.6px}
.page-inner h1{font-size:40px;text-transform:uppercase;margin:0 0 6px}
.page-inner h1:after{content:"";display:block;width:45px;height:4px;background:#f5b301;margin:16px 0}
.prose{font-size:17px;line-height:1.7;color:#333;max-width:840px}
.prose h2{font-size:27px;margin:34px 0 12px}
.prose h3{font-size:21px;margin:26px 0 10px}
.prose p{margin:0 0 16px}
.prose img{max-width:100%;height:auto;border-radius:6px}
.prose ul,.prose ol{padding-left:22px;margin:0 0 16px}
.prose a{color:#b07d00;text-decoration:underline}

/* ---- blog ---- */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.post-card{border:1px solid #ddd;border-radius:6px;overflow:hidden;background:#fff;box-shadow:0 8px 25px #0001;display:flex;flex-direction:column}
.post-card img{width:100%;height:190px;object-fit:cover}
.post-card .body{padding:20px;display:flex;flex-direction:column;flex:1}
.post-card h3{margin:0 0 8px;font-size:19px}
.post-card .date{font-size:12px;color:#999;text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}
.post-card p{color:#555;font-size:15px;line-height:1.5;flex:1}
.post-card a.more{font-weight:900;color:#b07d00;margin-top:12px}
.post-hero img{width:100%;max-height:420px;object-fit:cover;border-radius:8px;margin-bottom:24px}

/* ---- testimonials ---- */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.testi{background:#fff;border:1px solid #eee;border-radius:8px;padding:26px;box-shadow:0 8px 25px #0001}
.testi .stars{color:#f5b301;font-size:18px;letter-spacing:2px;margin-bottom:10px}
.testi blockquote{margin:0 0 14px;font-style:italic;color:#333;line-height:1.6}
.testi .who{font-weight:900;text-transform:uppercase;font-size:14px}
.testi .co{color:#888;font-size:13px}

/* ---- mobile menu ---- */
.menu-toggle{display:none;background:none;border:0;font-size:28px;cursor:pointer;line-height:1;padding:6px}
@media(max-width:850px){
  .menu-toggle{display:block}
  nav{position:absolute;top:76px;left:0;right:0;background:#fff;flex-direction:column;align-items:flex-start;
      padding:10px 20px 20px;box-shadow:0 12px 24px #0003;display:none}
  nav.open{display:flex}
  nav a{margin:10px 0}
  .hero{min-height:520px}
  .hero h1{font-size:42px}
  .features,.services,.split,.steps,.contact,.gallery,.blog-grid,.testi-grid{grid-template-columns:1fr}
  .cta .container{display:block}
  .page-inner h1{font-size:32px}
}

/* ---- flash / form response ---- */
.flash{padding:12px 16px;border-radius:6px;margin-bottom:16px;font-size:14px}
.flash-ok{background:#def7ec;color:#03543f}
.flash-error{background:#fde8e8;color:#9b1c1c}
