
/* Core styles for Idle Home & Yard Services */
:root {
  --primary: #1e7a3f;
  --primary-dark: #13552b;
  --accent: #8ecf97;
  --ink: #102317;
  --muted-ink: #44554b;
  --bg: #f5f7f5;
  --white: #ffffff;
  --border: #e1e8e2;
  --radius: 14px;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; background: var(--bg); color: var(--ink); font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; font-size: 16px; line-height: 1.6; }
img { max-width: 100%; height: auto; display: block; }
a { color: var(--primary-dark); text-decoration: none; }
a:hover { text-decoration: underline; }
.container { width: min(1200px, 92%); margin: 0 auto; }

header.site-header {
  position: sticky; top: 0; z-index: 50; background: rgba(255,255,255,0.9); backdrop-filter: saturate(180%) blur(10px);
  border-bottom: 1px solid var(--border);
}
.navbar { display: flex; align-items: center; justify-content: space-between; padding: 12px 0; }
.brand { display: flex; align-items: center; gap: 12px; }
.brand img { width: 140px; }
nav ul { list-style: none; display: flex; gap: 18px; padding: 0; margin: 0; align-items: center; }
nav li { position: relative; }
nav li ul.submenu { position: absolute; left: 0; top: 100%; background: var(--white); padding: 8px 0; border: 1px solid var(--border); border-radius: 12px; display: none; min-width: 220px; box-shadow: 0 16px 40px rgba(16,35,23,0.12); }
nav li:hover ul.submenu { display: block; }
nav li ul.submenu li a { display: block; padding: 10px 14px; }
.cta { background: var(--primary); color: var(--white); padding: 10px 16px; border-radius: 999px; border: 1px solid var(--primary); transition: transform .08s ease, box-shadow .2s ease; display: inline-block; }
.cta:hover { text-decoration: none; transform: translateY(-1px); box-shadow: 0 10px 24px rgba(30,122,63,.24); }
.cta-outline { background: var(--white); color: var(--primary-dark); border: 1px solid var(--primary); }

.hero { background: radial-gradient(1200px 800px at 10% 10%, var(--accent), var(--primary)); color: var(--white); }
.hero-inner { display: grid; grid-template-columns: repeat(12, 1fr); gap: 24px; padding: 64px 0; align-items: center; }
.hero-copy { grid-column: span 6; }
.hero-media { grid-column: span 6; }
h1 { font-size: clamp(32px, 4vw, 48px); line-height: 1.1; margin: 0 0 12px 0; }
h2 { font-size: clamp(24px, 3vw, 32px); line-height: 1.2; margin: 40px 0 16px; }
h3 { font-size: 20px; margin: 24px 0 12px; }
.lead { font-size: 18px; color: rgba(255,255,255,0.9); }
.buttons { display: flex; gap: 12px; margin-top: 16px; flex-wrap: wrap; }

.section { padding: 56px 0; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }
.card { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius); padding: 20px; box-shadow: 0 8px 24px rgba(16,35,23,0.06); }
.card:hover { box-shadow: 0 16px 40px rgba(16,35,23,0.12); }
.kbd { background: #eef5ef; padding: 2px 8px; border-radius: 999px; font-size: 12px; border: 1px solid var(--border); }

.list-check li { margin: 6px 0; padding-left: 26px; position: relative; }
.list-check li:before { content: "✓"; position: absolute; left: 0; color: var(--primary); font-weight: 700; }

footer { background: var(--ink); color: #e9f0ea; padding: 40px 0; }
.footer-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.footer-grid a { color: #d3e4d8; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,0.1); margin-top: 24px; padding-top: 16px; display: flex; justify-content: space-between; flex-wrap: wrap; gap: 12px; font-size: 14px; }

.badge { display:inline-flex; align-items:center; gap:8px; padding:6px 10px; border:1px solid var(--border); border-radius:999px; background:#fff; }
.badge .dot { width:8px; height:8px; border-radius:50%; background:var(--primary); }

.notice { background:#fff8e6; border:1px solid #ffe4a3; color:#6a4b00; padding:12px 14px; border-radius:12px; }

.table { width:100%; border-collapse: collapse; background: var(--white); border-radius: 12px; overflow: hidden; }
.table th, .table td { padding: 12px 14px; border-bottom: 1px solid var(--border); text-align:left; }
.table th { background:#f3f7f4; font-weight:600; }

blockquote { margin: 0; padding: 16px 20px; border-left: 4px solid var(--accent); background:#f4fbf5; border-radius: 8px; }

@media (max-width: 900px) {
  .grid-3 { grid-template-columns: 1fr; }
  .grid-2 { grid-template-columns: 1fr; }
  .hero-inner { grid-template-columns: 1fr; }
  .hero-copy, .hero-media { grid-column: span 1; }
  nav ul { gap: 12px; }
}

/* Animations */
.fade-up { opacity: 0; transform: translateY(10px); animation: fadeUp .6s ease forwards; }
@keyframes fadeUp { to { opacity:1; transform: translateY(0); } }
.pulse { animation: pulse 2s ease-in-out infinite; }
@keyframes pulse { 0% { transform: scale(1); } 50% { transform: scale(1.02); } 100% { transform: scale(1); } }

/* Cookie banner */
.cc-banner { position: fixed; inset: auto 12px 12px 12px; background: var(--white); border:1px solid var(--border); border-radius: 14px; padding:16px; box-shadow: 0 22px 60px rgba(16,35,23,.22); max-width: 860px; z-index: 1000; }
.cc-actions { display:flex; gap:10px; flex-wrap:wrap; }
.cc-actions button { padding:10px 14px; border-radius:10px; border:1px solid var(--border); background:#fff; cursor:pointer; }
.cc-actions .primary { background: var(--primary); border-color: var(--primary); color: #fff; }

/* Forms */
.input, select, textarea { width: 100%; padding: 12px 14px; border-radius: 12px; border:1px solid var(--border); background:#fff; }
label { display:block; font-weight:600; margin: 12px 0 6px; }
.form-grid { display:grid; grid-template-columns: repeat(2,1fr); gap: 14px; }
.form-grid-1 { grid-template-columns: 1fr; }
.help { color: var(--muted-ink); font-size: 14px; }
.error { color: #9b2c2c; }
.success { color: #1a7f3c; }

/* Utilities */
.mt-0 { margin-top:0; }
.mt-2 { margin-top:8px; }
.mt-3 { margin-top:12px; }
.mt-4 { margin-top:16px; }
.mt-6 { margin-top:24px; }
.mt-8 { margin-top:32px; }
.center { text-align:center; }
.hidden { display:none; }
.flex { display:flex; gap:12px; align-items:center; }
.justify-between { justify-content: space-between; }
.badges { display:flex; gap:8px; flex-wrap:wrap; }
.small { font-size: 14px; }
code.inline { background:#eef5ef; padding:2px 6px; border-radius:6px; border:1px solid var(--border); }
