/* ============================================================
   COUNTRY ROADS AG — GLOBAL STYLESHEET
   Colors: #344F1F (green), #BB6C24 (orange), #545454 (charcoal)
   Font: Montserrat (headings/nav), Source Sans 3 (body)
   ============================================================ */

:root {
  --green:       #344F1F;
  --green-dark:  #263A16;
  --green-light: #3d5c24;
  --orange:      #BB6C24;
  --orange-hover:#a55e1e;
  --white:       #FFFFFF;
  --charcoal:    #545454;
  --gray-light:  #F4F5F2;
  --gray-mid:    #E8E9E4;
  --border:      #d8dbd1;
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }

html { scroll-behavior: smooth; }

body {
  font-family: 'Source Sans 3', sans-serif;
  color: var(--charcoal);
  background: var(--white);
  font-size: 17px;
  line-height: 1.65;
}

h1,h2,h3,h4,h5,nav,.btn,.label,.stat-label,.section-label,
.footer-col h5, .nav-brand, .step-number { font-family: 'Montserrat', sans-serif; }

img { max-width:100%; display:block; }
a { text-decoration:none; }

/* ── BUTTONS ── */
.btn {
  display: inline-block;
  padding: 12px 26px;
  border-radius: 4px;
  font-family: 'Montserrat', sans-serif;
  font-size: 12.5px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 0.2s;
  border: 2px solid transparent;
}
.btn-orange  { background:var(--orange); color:var(--white); border-color:var(--orange); }
.btn-orange:hover { background:var(--orange-hover); border-color:var(--orange-hover); }
.btn-outline-white { background:transparent; color:var(--white); border-color:rgba(255,255,255,0.5); }
.btn-outline-white:hover { background:rgba(255,255,255,0.1); border-color:var(--white); }
.btn-outline-green { background:transparent; color:var(--green); border-color:var(--green); }
.btn-outline-green:hover { background:var(--green); color:var(--white); }
.btn-lg { padding:15px 38px; font-size:13px; }

/* ── NAVIGATION ── */
nav.main-nav {
  background: var(--green);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 56px;
  height: 72px;
  position: sticky;
  top: 0;
  z-index: 200;
  box-shadow: 0 2px 16px rgba(0,0,0,0.18);
}
.nav-logo { display:flex; align-items:center; gap:12px; }
.logo-placeholder {
  width: 44px; height: 44px;
  border: 2px dashed rgba(255,255,255,0.35);
  border-radius: 6px;
  display: flex; align-items:center; justify-content:center;
  color: rgba(255,255,255,0.4);
  font-size: 9px; font-weight:700; letter-spacing:0.05em;
  text-align:center; line-height:1.2; flex-shrink:0;
  font-family:'Montserrat',sans-serif;
}
.nav-brand {
  color:var(--white); font-size:13px; font-weight:700;
  letter-spacing:0.1em; text-transform:uppercase; line-height:1.2;
}
.nav-brand span { display:block; font-weight:400; letter-spacing:0.08em; opacity:0.65; font-size:10px; }
.nav-links { display:flex; align-items:center; gap:28px; list-style:none; }
.nav-links a {
  color: rgba(255,255,255,0.8); font-size:12px; font-weight:600;
  letter-spacing:0.08em; text-transform:uppercase; transition:color 0.2s;
  font-family:'Montserrat',sans-serif;
}
.nav-links a:hover, .nav-links a.active { color:var(--white); }

/* ── SECTION UTILITIES ── */
.section-label {
  font-size:11px; font-weight:700; letter-spacing:0.2em; text-transform:uppercase;
  color:var(--orange); margin-bottom:14px;
  display:flex; align-items:center; gap:10px;
}
.section-label::before { content:''; display:block; width:20px; height:2px; background:var(--orange); }
.section-label.center { justify-content:center; }
.section-label.center::before { display:none; }

.section-title { font-size:36px; font-weight:800; color:var(--green); line-height:1.18; letter-spacing:-0.02em; margin-bottom:16px; }
.section-title.white { color:var(--white); }
.section-sub { font-size:17px; color:var(--charcoal); max-width:560px; line-height:1.7; margin-bottom:44px; }
.section-sub.white { color:rgba(255,255,255,0.72); }

/* ── STATS BAR ── */
.stats-bar {
  background:var(--white); border-bottom:1px solid var(--border);
  padding:28px 64px; display:flex; align-items:center; justify-content:center; gap:60px;
}
.stat-item { text-align:center; }
.stat-number { font-family:'Montserrat',sans-serif; font-size:30px; font-weight:800; color:var(--green); letter-spacing:-0.02em; line-height:1; }
.stat-number .accent { color:var(--orange); }
.stat-label { font-size:11.5px; font-weight:600; letter-spacing:0.1em; text-transform:uppercase; color:var(--charcoal); opacity:0.65; margin-top:5px; }
.stat-divider { width:1px; height:40px; background:var(--border); }

/* ── IMAGE PLACEHOLDERS ── */
.img-ph {
  background:var(--gray-mid); border:2px dashed var(--border); border-radius:8px;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:10px; color:var(--charcoal);
}
.img-ph svg { opacity:0.18; }
.img-ph-label {
  font-family:'Montserrat',sans-serif; font-size:10px; font-weight:700;
  letter-spacing:0.15em; text-transform:uppercase; opacity:0.35;
}
.img-ph.dark { background:rgba(255,255,255,0.06); border-color:rgba(255,255,255,0.18); }
.img-ph.dark .img-ph-label { color:var(--white); }
.img-ph.dark svg { opacity:0.2; stroke:white; }

/* ── SERVICE CARDS ── */
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; max-width:1100px; margin:0 auto; }
.service-card {
  background:var(--white); border-radius:8px; overflow:hidden;
  box-shadow:0 2px 12px rgba(0,0,0,0.06); display:flex; flex-direction:column;
  transition: transform 0.2s, box-shadow 0.2s;
}
.service-card:hover { transform:translateY(-4px); box-shadow:0 8px 32px rgba(52,79,31,0.12); }
.service-card-img { width:100%; height:180px; }
.service-card-body { padding:28px; flex:1; display:flex; flex-direction:column; }
.service-icon {
  width:44px; height:44px; background:rgba(52,79,31,0.08); border-radius:8px;
  display:flex; align-items:center; justify-content:center; margin-bottom:16px; color:var(--green);
}
.service-card h3 { font-size:18px; font-weight:800; color:var(--green); margin-bottom:10px; letter-spacing:-0.01em; }
.service-card p { font-size:15px; color:var(--charcoal); line-height:1.65; flex:1; margin-bottom:20px; }
.service-link {
  font-family:'Montserrat',sans-serif; font-size:12px; font-weight:700;
  letter-spacing:0.1em; text-transform:uppercase; color:var(--orange);
  display:flex; align-items:center; gap:6px; transition:gap 0.2s;
}
.service-link:hover { gap:10px; }

/* ── PROCESS STEPS ── */
.process-steps { display:grid; grid-template-columns:repeat(4,1fr); gap:0; max-width:1100px; margin:0 auto; position:relative; }
.process-steps::before { content:''; position:absolute; top:28px; left:10%; right:10%; height:2px; background:var(--border); z-index:0; }
.process-step { text-align:center; padding:0 20px; position:relative; z-index:1; }
.step-number {
  width:56px; height:56px; background:var(--green); color:var(--white); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:18px; font-weight:800; margin:0 auto 20px;
}
.process-step h4 { font-size:15px; font-weight:800; color:var(--green); margin-bottom:10px; }
.process-step p { font-size:14px; color:var(--charcoal); line-height:1.6; opacity:0.8; }

/* ── AUDIENCE CARDS ── */
.audience-card {
  background:var(--white); border-radius:8px; padding:20px 24px;
  display:flex; align-items:flex-start; gap:18px;
  box-shadow:0 1px 6px rgba(0,0,0,0.05); border-left:4px solid transparent;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.audience-card:hover { border-left-color:var(--orange); box-shadow:0 4px 16px rgba(0,0,0,0.08); }
.audience-icon {
  width:40px; height:40px; background:rgba(52,79,31,0.08); border-radius:8px;
  display:flex; align-items:center; justify-content:center; flex-shrink:0; color:var(--green); margin-top:2px;
}
.audience-card h4 { font-size:15px; font-weight:700; color:var(--green); margin-bottom:4px; }
.audience-card p { font-size:13.5px; color:var(--charcoal); line-height:1.5; opacity:0.8; }

/* ── VALUE GRID ── */
.values-grid { display:grid; grid-template-columns:1fr 1fr; gap:24px; margin-top:36px; }
.value-item { padding:24px; background:rgba(255,255,255,0.06); border-radius:8px; border:1px solid rgba(255,255,255,0.08); }
.value-number { font-size:11px; font-weight:700; color:var(--orange); letter-spacing:0.15em; margin-bottom:8px; font-family:'Montserrat',sans-serif; }
.value-item h4 { font-size:15px; font-weight:700; color:var(--white); margin-bottom:8px; }
.value-item p { font-size:14px; color:rgba(255,255,255,0.6); line-height:1.6; }

/* ── PROOF/TESTIMONIAL BLOCKS ── */
.proof-block {
  background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.1);
  border-left:4px solid var(--orange); border-radius:8px; padding:28px; margin-bottom:24px;
}
.proof-block .big-num { font-family:'Montserrat',sans-serif; font-size:48px; font-weight:800; color:var(--white); letter-spacing:-0.03em; line-height:1; margin-bottom:8px; }
.proof-block .big-num .accent { color:var(--orange); }
.proof-block p { font-size:15px; color:rgba(255,255,255,0.65); line-height:1.6; }
.testimonial-ph {
  background:rgba(255,255,255,0.04); border:2px dashed rgba(255,255,255,0.15);
  border-radius:8px; padding:28px; text-align:center;
}
.testimonial-ph p { font-size:12px; color:rgba(255,255,255,0.3); font-family:'Montserrat',sans-serif; font-weight:600; letter-spacing:0.12em; text-transform:uppercase; margin-top:10px; }

/* ── FAQ ── */
.faq-item { border-bottom:1px solid var(--border); padding:24px 0; }
.faq-question { font-family:'Montserrat',sans-serif; font-size:16px; font-weight:700; color:var(--green); margin-bottom:10px; }
.faq-answer { font-size:16px; color:var(--charcoal); line-height:1.7; }

/* ── FORM ── */
.form-group { margin-bottom:20px; }
.form-group label { display:block; font-family:'Montserrat',sans-serif; font-size:11.5px; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:var(--green); margin-bottom:8px; }
.form-group input, .form-group select, .form-group textarea {
  width:100%; padding:13px 16px; border:1.5px solid var(--border); border-radius:4px;
  font-family:'Source Sans 3',sans-serif; font-size:16px; color:var(--charcoal);
  background:var(--white); transition:border-color 0.2s; outline:none;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color:var(--green); }
.form-group textarea { resize:vertical; min-height:120px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:20px; }

/* ── PAGE HERO (inner pages) ── */
.page-hero { background:var(--green); padding:80px 64px; }
.page-hero-eyebrow { font-family:'Montserrat',sans-serif; font-size:11px; font-weight:700; letter-spacing:0.2em; text-transform:uppercase; color:var(--orange); margin-bottom:18px; display:flex; align-items:center; gap:10px; }
.page-hero-eyebrow::before { content:''; display:block; width:24px; height:2px; background:var(--orange); }
.page-hero h1 { font-size:42px; font-weight:800; color:var(--white); line-height:1.15; letter-spacing:-0.02em; margin-bottom:20px; max-width:700px; }
.page-hero p { font-size:18px; color:rgba(255,255,255,0.75); max-width:600px; line-height:1.7; margin-bottom:32px; }

/* ── FOOTER ── */
footer.main-footer { background:var(--green-dark); padding:56px 64px 32px; color:rgba(255,255,255,0.6); }
.footer-top { display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:48px; padding-bottom:48px; border-bottom:1px solid rgba(255,255,255,0.1); margin-bottom:32px; }
.footer-brand p { font-size:14px; line-height:1.65; color:rgba(255,255,255,0.5); max-width:240px; margin-top:14px; }
.footer-logo-ph { width:52px; height:52px; border:2px dashed rgba(255,255,255,0.3); border-radius:6px; display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,0.35); font-size:9px; font-weight:700; letter-spacing:0.05em; font-family:'Montserrat',sans-serif; margin-bottom:14px; }
.footer-brand-name { font-family:'Montserrat',sans-serif; font-size:13px; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:var(--white); line-height:1.2; margin-bottom:4px; }
.footer-brand-sub { font-family:'Montserrat',sans-serif; font-size:10px; font-weight:400; letter-spacing:0.08em; color:rgba(255,255,255,0.5); }
.footer-col h5 { font-size:11px; font-weight:700; letter-spacing:0.15em; text-transform:uppercase; color:var(--white); margin-bottom:16px; }
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:10px; }
.footer-col ul a { color:rgba(255,255,255,0.5); font-size:14px; transition:color 0.2s; }
.footer-col ul a:hover { color:var(--white); }
.footer-contact-item { font-size:14px; color:rgba(255,255,255,0.5); margin-bottom:10px; display:flex; align-items:flex-start; gap:8px; }
.footer-contact-item svg { flex-shrink:0; margin-top:2px; }
.contact-ph { font-style:italic; opacity:0.45; font-size:13px; }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; font-size:13px; }
.footer-bottom a { color:rgba(255,255,255,0.4); }
.footer-bottom a:hover { color:var(--white); }
.footer-legal { display:flex; gap:24px; }
