/* ============================================
   HarvestLoop Grow — SEO Pages Stylesheet
   Matches harvestloop.ai brand: Montserrat/Lato, gold CTAs, warm tones
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700;800&family=Lato:wght@300;400;700&display=swap');

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

:root{
  /* Brand colors — matched from harvestloop.ai */
  --green:#4caf50;--green-dark:#105634;--green-deep:#105634;--green-soft:#66bb6a;
  --gold:#E7A52D;--gold-hover:#d4940f;
  --blue:#188bf6;
  --beige:#f6ebe7;--beige-light:#fff3e0;--cream:#faf7f4;
  --white:#ffffff;
  --text:#333333;--text-mid:#4a4a4a;--text-light:#7a7a7a;--text-muted:#9e9e9e;
  --border:#e0ddd8;--border-light:#f0ede8;
  --card-shadow:0 2px 12px rgba(0,0,0,.06);
  --r:12px;--rs:8px;
}

html{font-family:'Lato','Helvetica Neue',Arial,sans-serif;font-size:16px;-webkit-font-smoothing:antialiased}
body{background:var(--cream);color:var(--text);min-height:100vh;line-height:1.7}
h1,h2,h3,h4,h5,h6{font-family:'Montserrat','Helvetica Neue',sans-serif;line-height:1.3}
a{color:var(--green-dark);text-decoration:none}
a:hover{color:var(--green);text-decoration:underline}
img{max-width:100%;height:auto}

/* ── TOPBAR ── */
.topbar{background:var(--white);padding:12px 24px;display:flex;align-items:center;gap:16px;position:sticky;top:0;z-index:100;box-shadow:0 1px 4px rgba(0,0,0,.08);border-bottom:1px solid var(--border-light)}
.topbar-logo{display:flex;align-items:center;gap:8px;text-decoration:none}
.topbar-logo img{height:36px;max-width:200px;object-fit:contain}
.topbar-logo span{font-family:'Montserrat';font-weight:700;font-size:18px;color:var(--green-dark)}
.topbar-nav{display:flex;gap:24px;margin-left:auto}
.topbar-nav a{color:var(--text-mid);font-size:14px;font-weight:500;padding:6px 0;border-bottom:2px solid transparent;transition:color .2s,border-color .2s}
.topbar-nav a:hover{color:var(--green-soft);border-bottom-color:var(--green-soft);text-decoration:none}
.topbar-hamburger{display:none;background:none;border:none;cursor:pointer;padding:6px;margin-left:auto}
.topbar-hamburger svg{width:24px;height:24px;color:var(--text)}
@media(max-width:640px){
  .topbar-nav{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;background:var(--white);box-shadow:0 4px 16px rgba(0,0,0,.1);border-top:1px solid var(--border-light)}
  .topbar-nav.open{display:flex}
  .topbar-nav a{font-size:15px;padding:14px 24px;border-bottom:1px solid var(--border-light);width:100%}
  .topbar-nav a:last-child{border-bottom:none}
  .topbar-hamburger{display:block}
}

/* ── BREADCRUMBS ── */
.breadcrumbs{padding:14px 24px;font-size:13px;color:var(--text-muted);max-width:1170px;margin:0 auto}
.breadcrumbs a{color:var(--text-light)}
.breadcrumbs a:hover{color:var(--green-dark)}
.breadcrumbs .sep{margin:0 6px;opacity:.4}

/* ── LAYOUT ── */
.page-wrap{max-width:1170px;margin:0 auto;padding:0 24px 60px;display:grid;grid-template-columns:1fr;gap:28px}
@media(min-width:768px){
  .page-wrap{grid-template-columns:1fr 300px}
}
.main-content{min-width:0}
.sidebar{display:flex;flex-direction:column;gap:16px}
@media(max-width:767px){
  .sidebar{order:10}
}

/* ── CARDS ── */
.card{background:var(--white);border-radius:var(--r);padding:28px;box-shadow:var(--card-shadow);border:1px solid var(--border-light);margin-bottom:24px}
.card-sm{padding:20px;margin-bottom:16px}

/* ── HERO ── */
.hero{background:linear-gradient(145deg,#105634,#1a7a42);padding:40px 32px 36px;color:#fff;border-radius:var(--r);margin-bottom:28px;position:relative;overflow:hidden}
.hero::after{content:'';position:absolute;bottom:-50%;right:-15%;width:400px;height:400px;background:radial-gradient(circle,rgba(76,175,80,.15),transparent 70%);border-radius:50%}
.hero-label{font-family:'Montserrat';font-size:11px;text-transform:uppercase;letter-spacing:3px;opacity:.5;margin-bottom:8px}
.hero h1{font-size:32px;font-weight:800;margin-bottom:10px;color:#fff}
.hero .tagline{font-size:15px;opacity:.8;line-height:1.6;max-width:640px}
.hero-badges{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
@media(min-width:768px){
  .hero{padding:48px 40px 40px}
  .hero h1{font-size:42px}
}

/* ── BADGES ── */
.badge{display:inline-flex;align-items:center;gap:4px;font-family:'Montserrat';font-size:11px;font-weight:700;padding:5px 12px;border-radius:20px;text-transform:uppercase;letter-spacing:.4px;white-space:nowrap}
.badge-white{background:rgba(255,255,255,0.15);color:#fff}
.badge-spring{background:#e8f5e9;color:#2e7d32}
.badge-summer{background:#fff8e1;color:#f57f17}
.badge-fall{background:#fff3e0;color:#e65100}
.badge-winter{background:#e3f2fd;color:#1565c0}
.badge-cool{background:#e0f7fa;color:#00695c}
.badge-warm{background:#fce4ec;color:#c62828}
.badge-zone{background:var(--beige);color:var(--green-dark);font-size:13px;padding:6px 14px}
.badge-gold{background:var(--beige-light);color:var(--gold)}
.badge-premium{background:#f3e8ff;color:#7c3aed}

/* ── SECTION HEADERS ── */
.section-title{font-size:22px;font-weight:700;color:var(--green-dark);margin-bottom:16px}
.section-title-sm{font-size:17px;font-weight:700;color:var(--text);margin-bottom:12px}
.section-desc{font-size:15px;color:var(--text-mid);line-height:1.8;margin-bottom:18px}

/* ── PLANT GRID ── */
.plant-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
@media(min-width:640px){.plant-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:900px){.plant-grid{grid-template-columns:repeat(4,1fr)}}
.plant-card{background:var(--white);border:1px solid var(--border);border-radius:var(--rs);padding:16px 14px;text-align:center;transition:all .2s}
.plant-card:hover{border-color:var(--green-soft);box-shadow:0 4px 16px rgba(55,202,55,.1);text-decoration:none;transform:translateY(-2px)}
.plant-card-icon{font-size:32px;margin-bottom:8px;display:block}
.plant-card-name{font-family:'Montserrat';font-size:13px;font-weight:600;color:var(--text);display:block}
.plant-card-meta{font-size:11px;color:var(--text-muted);margin-top:4px}

/* ── KIT GRID ── */
.kit-grid{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:640px){.kit-grid{grid-template-columns:repeat(2,1fr)}}
.kit-card{background:var(--white);border:1px solid var(--border);border-radius:var(--rs);padding:20px;display:flex;gap:14px;align-items:flex-start;transition:all .2s}
.kit-card:hover{border-color:var(--gold);box-shadow:0 4px 16px rgba(231,165,45,.1);text-decoration:none;transform:translateY(-1px)}
.kit-card-icon{font-size:36px;flex-shrink:0}
.kit-card-name{font-family:'Montserrat';font-size:15px;font-weight:600;color:var(--text)}
.kit-card-desc{font-size:13px;color:var(--text-light);margin-top:3px;line-height:1.5}
.kit-card-count{font-size:11px;color:var(--text-muted);margin-top:6px}
.kit-card-badge{display:inline-block;font-size:9px;font-weight:700;padding:2px 8px;border-radius:4px;margin-top:4px;text-transform:uppercase;letter-spacing:.5px}
.kit-card-badge-premium{background:#f3e8ff;color:#7c3aed}
.kit-card-badge-standard{background:var(--beige);color:var(--text-light)}

/* ── QUICK STATS ── */
.stats-row{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:20px}
@media(min-width:480px){.stats-row{grid-template-columns:repeat(4,1fr)}}
.stat-box{background:var(--beige);border-radius:var(--rs);padding:14px;text-align:center}
.stat-label{font-size:10px;color:var(--text-light);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-family:'Montserrat';font-weight:500}
.stat-value{font-size:18px;font-weight:700;color:var(--green-dark);font-family:'Montserrat'}

/* ── PLANTING CALENDAR ── */
.cal-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:4px}
@media(min-width:640px){.cal-grid{grid-template-columns:repeat(6,1fr)}}
@media(min-width:900px){.cal-grid{grid-template-columns:repeat(12,1fr)}}
.cal-month{padding:10px 4px;text-align:center;border-radius:6px;font-size:11px;font-weight:600}
.cal-month-label{display:block;margin-bottom:3px;font-size:9px;color:var(--text-muted);text-transform:uppercase;font-family:'Montserrat'}
.cal-sow{background:#dcfce7;color:#166534}
.cal-trans{background:#fef9c3;color:#854d0e}
.cal-harvest{background:#fce7f3;color:#9d174d}
.cal-rest{background:#f5f3f0;color:#bbb}
.cal-active{background:var(--beige);color:var(--green-dark)}

/* ── PLANTING WINDOWS ── */
.window-list{display:flex;flex-direction:column;gap:12px}
.window-item{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--beige);border-radius:var(--rs)}
.window-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.window-icon-indoor{background:#fef3c7;color:var(--gold)}
.window-icon-transplant{background:#dbeafe;color:var(--blue)}
.window-icon-sow{background:#dcfce7;color:#16a34a}
.window-label{font-family:'Montserrat';font-size:11px;font-weight:600;color:var(--text-light);text-transform:uppercase;letter-spacing:.3px}
.window-dates{font-size:15px;font-weight:700;color:var(--text)}

/* ── CALLOUT BOXES ── */
.callout{border-radius:var(--rs);padding:16px 18px;margin-bottom:14px;font-size:14px;line-height:1.7}
.callout-title{font-family:'Montserrat';font-weight:700;margin-bottom:4px;font-size:14px}
.callout-green{background:#dcfce7;border-left:4px solid var(--green)}
.callout-amber{background:#fef3c7;border-left:4px solid var(--gold)}
.callout-red{background:#fee2e2;border-left:4px solid #ef4444}
.callout-blue{background:#dbeafe;border-left:4px solid var(--blue)}
.callout-teal{background:#ccfbf1;border-left:4px solid #0d9488}

/* ── FAQ ACCORDION ── */
.faq-list{display:flex;flex-direction:column;gap:8px}
.faq-item{border:1px solid var(--border);border-radius:var(--rs);overflow:hidden}
.faq-q{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;cursor:pointer;font-family:'Montserrat';font-weight:600;font-size:14px;color:var(--text);background:var(--white);transition:background .15s}
.faq-q:hover{background:var(--beige)}
.faq-q::after{content:'+';font-size:20px;color:var(--text-muted);font-weight:400;transition:transform .2s}
.faq-item.open .faq-q::after{content:'\2212'}
.faq-a{padding:0 18px;max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease;font-size:14px;color:var(--text-mid);line-height:1.8}
.faq-item.open .faq-a{max-height:600px;padding:0 18px 18px}

/* ── CTA SECTIONS ── */
.cta-slot{margin:28px 0}
.cta-banner{background:linear-gradient(135deg,#105634,#1a7a42);border-radius:var(--r);padding:32px;text-align:center;color:#fff}
.cta-banner h3{font-family:'Montserrat';font-size:22px;font-weight:700;margin-bottom:8px;color:#fff}
.cta-banner p{font-size:14px;opacity:.85;margin-bottom:20px;line-height:1.6}
.cta-btn{display:inline-block;padding:14px 32px;border-radius:var(--rs);font-family:'Montserrat';font-size:15px;font-weight:600;text-decoration:none;border:none;cursor:pointer;transition:all .2s}
.cta-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.15);text-decoration:none}
.cta-btn-gold{background:var(--gold);color:#fff}
.cta-btn-gold:hover{background:var(--gold-hover);color:#fff}
.cta-btn-white{background:#fff;color:var(--green-dark)}
.cta-btn-green{background:var(--green);color:#fff}
.cta-btn-outline{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.5)}
.cta-btn-outline:hover{border-color:#fff;background:rgba(255,255,255,.1)}
.cta-inline{background:var(--beige);border:1px solid #e8dcd4;border-radius:var(--rs);padding:20px;text-align:center}
.cta-inline h4{font-family:'Montserrat';font-size:17px;font-weight:700;color:var(--green-dark);margin-bottom:6px}
.cta-inline p{font-size:13px;color:var(--text-light);margin-bottom:14px}

/* ── SIDEBAR ── */
.sidebar-card{background:var(--white);border-radius:var(--rs);padding:18px;box-shadow:0 2px 8px rgba(0,0,0,.04);border:1px solid var(--border)}
.sidebar-title{font-family:'Montserrat';font-size:12px;font-weight:700;color:var(--green-dark);text-transform:uppercase;letter-spacing:.8px;margin-bottom:12px;padding-bottom:10px;border-bottom:2px solid var(--beige)}
.sidebar-links{list-style:none;display:flex;flex-direction:column;gap:4px}
.sidebar-links li a{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-mid);padding:8px 10px;border-radius:6px;transition:all .15s}
.sidebar-links li a:hover{background:var(--beige);color:var(--green-dark);text-decoration:none}
.sidebar-links li a .sl-icon{font-size:16px;flex-shrink:0}

.sidebar-dynamic{min-height:40px}
.sidebar-dynamic.loading::after{content:'Loading...';font-size:11px;color:var(--text-muted);display:block;text-align:center;padding:12px}

/* ── ZONE GRID ── */
.zone-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
@media(min-width:480px){.zone-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:640px){.zone-grid{grid-template-columns:repeat(4,1fr)}}
.zone-cell{display:flex;flex-direction:column;align-items:center;padding:14px 10px;border:1px solid var(--border);border-radius:var(--rs);font-size:13px;text-align:center;transition:all .2s}
.zone-cell:hover{border-color:var(--green);box-shadow:0 4px 12px rgba(55,202,55,.08);text-decoration:none;transform:translateY(-1px)}
.zone-cell-num{font-family:'Montserrat';font-size:20px;font-weight:800;color:var(--green-dark);margin-bottom:4px}
.zone-cell-temps{display:flex;flex-direction:column;gap:2px;font-size:10px;color:var(--text-muted);line-height:1.4}
.zone-cell-temps .label{font-weight:600;color:var(--text-mid)}
.zone-cell-temp{font-size:10px;color:var(--text-muted)}
.zone-cell-viable{background:var(--beige);border-color:var(--gold)}
.zone-cell-not{opacity:.45;background:#f9f7f5}

/* ── PEST & COMPANION ── */
.pest-list{display:flex;flex-wrap:wrap;gap:6px}
.pest-tag{font-size:12px;padding:5px 12px;background:var(--beige);border:1px solid var(--border);border-radius:20px;color:var(--text-mid)}
.companion-list{display:flex;flex-wrap:wrap;gap:6px}
.companion-chip{font-size:12px;padding:6px 14px;background:#dcfce7;border-radius:20px;color:#166534;font-weight:500}
.companion-chip:hover{text-decoration:none;background:#bbf7d0}
.pest-tag a,.pest-tag-link{font-size:12px;padding:5px 12px;background:var(--beige);border:1px solid var(--border);border-radius:20px;color:var(--text-mid);text-decoration:none;display:inline-block;transition:all .2s}
.pest-tag a:hover,.pest-tag-link:hover{background:#fef3c7;border-color:var(--gold);color:var(--green-dark);text-decoration:none;transform:translateY(-1px)}

/* ── PEST PAGE ── */
.id-checklist{display:flex;flex-direction:column;gap:8px}
.id-item{display:flex;gap:10px;align-items:flex-start;font-size:14px;line-height:1.7;color:var(--text-mid);padding:10px 14px;background:var(--beige);border-radius:var(--rs)}
.id-icon{font-size:16px;flex-shrink:0;margin-top:2px}
.treatment-list{display:flex;flex-direction:column;gap:8px}
.treatment-item{display:flex;gap:10px;align-items:flex-start;font-size:14px;line-height:1.7;color:var(--text-mid);padding:12px 16px;border-radius:var(--rs);border-left:3px solid transparent}
.treatment-prevent{background:#dcfce7;border-left-color:#16a34a}
.treatment-cure{background:#fef3c7;border-left-color:var(--gold)}
.treatment-icon{font-size:16px;flex-shrink:0;margin-top:2px}

/* ── TABLE ── */
.data-table{width:100%;border-collapse:collapse;font-size:13px}
.data-table th{background:var(--beige);padding:12px 14px;text-align:left;font-family:'Montserrat';font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.3px;color:var(--text-light);border-bottom:2px solid var(--border)}
.data-table td{padding:12px 14px;border-bottom:1px solid var(--border-light)}
.data-table tr:hover{background:var(--beige)}

/* ── SEARCH BAR ── */
.search-wrap{position:relative;margin-left:auto;margin-right:8px}
.search-input{font-size:13px;padding:7px 12px 7px 32px;border:1px solid var(--border);border-radius:20px;outline:none;width:180px;background:var(--beige) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%23888' stroke-width='2' stroke-linecap='round'%3E%3Ccircle cx='7' cy='7' r='5'/%3E%3Cline x1='11' y1='11' x2='15' y2='15'/%3E%3C/svg%3E") 10px center no-repeat;transition:border-color .2s,width .2s}
.search-input:focus{border-color:var(--green);width:240px}
.search-input::placeholder{color:var(--text-light);font-size:12px}
.search-results{display:none;position:absolute;top:calc(100% + 6px);left:0;right:0;min-width:280px;max-height:400px;overflow-y:auto;background:var(--white);border:1px solid var(--border);border-radius:var(--rs);box-shadow:0 8px 24px rgba(0,0,0,.12);z-index:200}
.search-group-header{font-family:'Montserrat';font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-light);padding:10px 14px 4px;background:var(--beige)}
.search-result-item{display:flex;flex-direction:column;padding:10px 14px;text-decoration:none;color:var(--text);border-bottom:1px solid var(--border-light);transition:background .15s}
.search-result-item:hover,.search-result-item.active{background:var(--beige);text-decoration:none}
.search-result-title{font-size:13px;font-weight:500;color:var(--text)}
.search-result-meta{font-size:11px;color:var(--text-muted);margin-top:2px}
@media(max-width:640px){
  .search-wrap{width:100%;margin:0;order:10}
  .search-input{width:100%;box-sizing:border-box}
  .search-input:focus{width:100%}
  .search-results{min-width:100%}
}

/* ── FOOTER ── */
.footer{background:var(--green-deep);color:rgba(255,255,255,.7);padding:48px 24px;text-align:center;font-size:13px;line-height:1.8}
.footer a{color:rgba(255,255,255,.9)}
.footer a:hover{color:var(--gold)}
.footer-links{display:flex;flex-wrap:wrap;justify-content:center;gap:20px;margin-bottom:20px}
.footer-brand{font-family:'Montserrat';font-size:16px;font-weight:700;color:#fff;margin-bottom:10px}
.footer-tagline{font-size:13px;opacity:.6;margin-bottom:20px}
.footer-copy{font-size:11px;opacity:.4;margin-top:16px}

/* ── UTILITIES ── */
.text-center{text-align:center}
.mb-0{margin-bottom:0}
.mb-8{margin-bottom:8px}
.mb-16{margin-bottom:16px}
.mb-24{margin-bottom:24px}
.mt-16{margin-top:16px}
.mt-24{margin-top:24px}
.hidden{display:none}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* ── SHARE BAR ── */
.share-bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:16px 0;margin-top:24px;border-top:1px solid var(--border)}
.share-bar-label{font-family:'Montserrat';font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-light)}
.share-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:1px solid var(--border);background:var(--white);color:var(--text-mid);font-size:16px;cursor:pointer;transition:all .2s;text-decoration:none;overflow:hidden;flex-shrink:0}
.share-btn:hover{border-color:var(--green);color:var(--green-dark);background:var(--beige);text-decoration:none;transform:translateY(-1px)}
.share-btn svg{width:16px;height:16px;min-width:16px;min-height:16px;max-width:16px;max-height:16px;fill:currentColor}
.share-btn-native{background:var(--green);color:#fff;border-color:var(--green)}
.share-btn-native:hover{background:var(--green-dark);color:#fff;border-color:var(--green-dark)}
.share-toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--green-dark);color:#fff;padding:10px 24px;border-radius:var(--rs);font-size:13px;font-family:'Montserrat';font-weight:500;z-index:999;opacity:0;transition:opacity .3s;pointer-events:none}
.share-toast.show{opacity:1}
