/* ================================================================
   BhumiAI — shared.css
   Design tokens, nav, footer, and utility styles shared across
   all pages: index, pest-advisor, schemes (and future pages).
   NOTE: Google Fonts are loaded via <link> tags in each HTML
   <head> (not @import) for better performance.
   ================================================================ */

/* ── DESIGN TOKENS ─────────────────────────────────────────────── */
:root {
  --green:      #1B8C3E;
  --green-dark: #0f5a27;
  --green-mid:  #22a84b;
  --green-lite: #e8f5ec;
  --saffron:    #D96C28;
  --saffron-lt: #F59732;
  --gold:       #C8902A;
  --sky:        #0077B6;
  --soil:       #2C1A0E;
  --cream:      #faf7f0;
  --warm:       #FFF9F0;
  --muted:      #7a6040;
  --border:     rgba(44,26,14,.12);
  --shadow:     rgba(27,140,62,.15);
}

/* ── RESET & BASE ───────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;background:var(--cream);color:var(--soil);overflow-x:hidden;line-height:1.6}

/* ── CONTAINER ──────────────────────────────────────────────────── */
/* All page content is capped at 1280px and centred.               */
/* Full-bleed sections keep their background colour via padding on  */
/* the <section>, but content sits inside a .container div.         */
.container{width:100%;max-width:1280px;margin-left:auto;margin-right:auto;padding-left:80px;padding-right:80px}
@media(max-width:1024px){.container{padding-left:40px;padding-right:40px}}
@media(max-width:600px) {.container{padding-left:20px;padding-right:20px}}

/* ── TYPOGRAPHY HELPERS ─────────────────────────────────────────── */
.section-tag{display:inline-flex;align-items:center;gap:6px;background:rgba(27,140,62,.1);color:var(--green);font-size:.68rem;font-weight:800;padding:5px 14px;border-radius:50px;text-transform:uppercase;letter-spacing:.12em;margin-bottom:16px}
.section-title{font-family:'Fraunces',serif;font-size:clamp(2rem,3.5vw,3rem);font-weight:900;line-height:1.12;color:var(--soil);margin-bottom:16px}
.section-title em{font-style:italic;color:var(--green)}
.section-sub{font-size:1rem;line-height:1.85;color:var(--muted);max-width:580px}
.center{text-align:center}
.center .section-sub{margin:0 auto}

/* ── BUTTONS ────────────────────────────────────────────────────── */
.btn-primary{background:var(--green);color:#fff;padding:15px 32px;border-radius:8px;font-family:'DM Sans',sans-serif;font-size:.95rem;font-weight:700;text-decoration:none;display:inline-flex;align-items:center;gap:8px;box-shadow:0 8px 28px var(--shadow);transition:background .2s,transform .2s;border:none;cursor:pointer}
.btn-primary:hover{background:var(--green-dark);transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--soil);padding:14px 28px;border-radius:8px;font-size:.95rem;font-weight:600;text-decoration:none;border:2px solid var(--border);display:inline-flex;align-items:center;gap:8px;transition:all .2s}
.btn-outline:hover{border-color:var(--green);color:var(--green)}

/* ── NAV ────────────────────────────────────────────────────────── */
nav{position:fixed;top:0;left:0;right:0;z-index:300;background:rgba(250,247,240,.95);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);transition:box-shadow .3s}
.nav-inner{max-width:1280px;margin:0 auto;padding:14px 80px;display:flex;align-items:center;justify-content:space-between}
nav.scrolled{box-shadow:0 4px 32px var(--shadow)}
.nav-logo{display:flex;align-items:center;text-decoration:none;background:none}
.nav-logo img{height:60px;width:auto;display:block;mix-blend-mode:multiply}
.nav-links{display:flex;align-items:center;gap:24px}
.nav-links a{font-size:.85rem;font-weight:500;color:var(--muted);text-decoration:none;letter-spacing:.01em;transition:color .2s}
.nav-links a:hover,.nav-links a.active{color:var(--green);font-weight:700}
.nav-cta{background:var(--saffron);color:#fff;border:none;padding:10px 22px;border-radius:6px;font-family:'DM Sans',sans-serif;font-size:.85rem;font-weight:700;cursor:pointer;letter-spacing:.02em;transition:background .2s,transform .15s;box-shadow:0 4px 16px rgba(217,108,40,.3);text-decoration:none;display:inline-block}
.nav-cta:hover{background:var(--saffron-lt);transform:translateY(-1px)}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px}
.hamburger span{display:block;width:24px;height:2px;background:var(--soil);border-radius:2px;transition:.3s}
.mobile-menu{display:none;position:fixed;top:74px;left:0;right:0;background:var(--cream);padding:24px 32px 32px;z-index:299;border-bottom:2px solid var(--green);box-shadow:0 8px 32px rgba(0,0,0,.1)}
.mobile-menu.open{display:flex;flex-direction:column;gap:20px}
.mobile-menu a{font-weight:600;font-size:1.05rem;color:var(--soil);text-decoration:none;padding:8px 0;border-bottom:1px solid var(--border)}
.mobile-menu .nav-cta{margin-top:8px;text-align:center;justify-content:center}

/* MORE DROPDOWN */
.nav-more{position:relative}
.nav-more-btn{background:none;border:none;font-family:'DM Sans',sans-serif;font-size:.85rem;font-weight:500;color:var(--muted);cursor:pointer;display:flex;align-items:center;gap:5px;padding:0;letter-spacing:.01em;transition:color .2s}
.nav-more-btn:hover{color:var(--green)}
.nav-more-btn svg{transition:transform .2s}
.nav-more.open .nav-more-btn svg{transform:rotate(180deg)}
.nav-dropdown{display:none;position:absolute;top:calc(100% + 14px);right:0;background:#fff;border:1px solid var(--border);border-radius:12px;padding:8px;min-width:200px;box-shadow:0 12px 40px rgba(44,26,14,.12);z-index:400}
.nav-more.open .nav-dropdown{display:flex;flex-direction:column;gap:2px;animation:fadeUp .15s ease both}
.nav-dropdown a{font-size:.85rem;font-weight:500;color:var(--muted);text-decoration:none;padding:9px 14px;border-radius:8px;transition:all .15s;display:block}
.nav-dropdown a:hover{background:var(--green-lite);color:var(--green)}

/* ── FOOTER ─────────────────────────────────────────────────────── */
footer{background:var(--soil);color:#fff;padding:64px 0 32px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.footer-logo{display:inline-block;margin-bottom:14px}
.footer-logo img{height:44px;width:auto;display:block;mix-blend-mode:screen;filter:brightness(2)}
.footer-tagline{font-size:.83rem;line-height:1.8;color:rgba(255,255,255,.45);max-width:260px;margin-bottom:20px}
.footer-socials{display:flex;gap:10px}
.soc{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;font-size:1rem;text-decoration:none;color:#fff;transition:background .2s}
.soc:hover{background:var(--green)}
.footer-col h4{font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:var(--gold);margin-bottom:18px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-col ul li a{color:rgba(255,255,255,.45);font-size:.83rem;text-decoration:none;transition:color .2s}
.footer-col ul li a:hover{color:#fff}
.footer-contact{margin-top:18px;padding-top:18px;border-top:1px solid rgba(255,255,255,.08)}
.footer-contact strong{display:block;font-size:.8rem;color:rgba(255,255,255,.7);margin-bottom:2px}
.footer-contact a{font-size:.8rem;color:var(--green-mid);text-decoration:none}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:28px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.footer-bottom p{font-size:.75rem;color:rgba(255,255,255,.35)}

/* ── SIGNUP NUDGE ────────────────────────────────────────────────── */
.signup-nudge{background:linear-gradient(135deg,#0f5a27 0%,#1B8C3E 100%);color:#fff;position:sticky;top:74px;z-index:200;box-shadow:0 4px 20px rgba(15,90,39,.3)}
.nudge-inner{max-width:1280px;margin:0 auto;padding:14px 80px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.nudge-left{display:flex;align-items:center;gap:12px;flex:1;min-width:200px}
.nudge-icon{font-size:1.4rem;flex-shrink:0}
.nudge-text{display:flex;flex-direction:column;gap:2px}
.nudge-text span{font-size:.88rem;line-height:1.5;color:rgba(255,255,255,.95)}
.nudge-sub{font-size:.72rem;color:rgba(255,255,255,.55)!important}
.nudge-right{display:flex;align-items:center;gap:10px;flex-shrink:0}
.nudge-cta{background:#fff;color:var(--green-dark);border:none;padding:9px 20px;border-radius:6px;font-family:'DM Sans',sans-serif;font-size:.82rem;font-weight:800;cursor:pointer;transition:all .2s;white-space:nowrap}
.nudge-cta:hover{background:var(--saffron-lt);color:#fff;transform:translateY(-1px)}
.nudge-dismiss{background:none;border:none;color:rgba(255,255,255,.45);font-size:1rem;cursor:pointer;padding:4px 8px;line-height:1;transition:color .2s;flex-shrink:0}
.nudge-dismiss:hover{color:#fff}
.nudge-form{padding:14px 0 4px;border-top:1px solid rgba(255,255,255,.15);margin-top:10px}
.nudge-fields{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.nudge-input{background:rgba(255,255,255,.12);border:1.5px solid rgba(255,255,255,.25);border-radius:8px;padding:9px 14px;font-family:'DM Sans',sans-serif;font-size:.85rem;color:#fff;outline:none;transition:border-color .2s;min-width:140px;flex:1}
.nudge-input::placeholder{color:rgba(255,255,255,.5)}
.nudge-input:focus{border-color:rgba(255,255,255,.7);background:rgba(255,255,255,.18)}
.nudge-select{cursor:pointer}
.nudge-select option{background:#0f5a27;color:#fff}
.nudge-submit{background:var(--saffron);color:#fff;border:none;padding:9px 20px;border-radius:8px;font-family:'DM Sans',sans-serif;font-size:.85rem;font-weight:700;cursor:pointer;transition:all .2s;white-space:nowrap;flex-shrink:0}
.nudge-submit:hover{background:var(--saffron-lt);transform:translateY(-1px)}
.nudge-submit:disabled{opacity:.6;cursor:not-allowed;transform:none}
.nudge-welcome{background:linear-gradient(135deg,#0a3d1e 0%,#1B8C3E 100%)}
.nudge-phone-wrap{display:flex;align-items:center;gap:0;flex:1;min-width:160px}
.nudge-dial{background:rgba(255,255,255,.15);border:1.5px solid rgba(255,255,255,.25);border-right:none;border-radius:8px 0 0 8px;padding:9px 10px;font-size:.85rem;font-weight:700;color:#fff;white-space:nowrap;flex-shrink:0}
.nudge-phone{border-radius:0 8px 8px 0!important;min-width:120px}
.nudge-otp-field{max-width:140px;letter-spacing:.2em;font-weight:700;text-align:center}
.nudge-otp-hint{font-size:.78rem;color:rgba(255,255,255,.65);margin-bottom:8px}
.nudge-error{font-size:.78rem;color:#fca5a5;margin-top:6px;padding:4px 0}
.nudge-resend{background:none;border:none;color:rgba(255,255,255,.55);font-size:.78rem;cursor:pointer;text-decoration:underline;margin-top:6px;padding:0;font-family:'DM Sans',sans-serif}
.nudge-resend:hover{color:#fff}

@media(max-width:600px){
  .nudge-inner{padding:12px 20px;top:64px}
  .nudge-fields{flex-direction:column;align-items:stretch}
  .nudge-input{min-width:unset;width:100%}
}

/* ── LANGUAGE FONT OVERRIDES ────────────────────────────────────── */
/* Driven by <html lang="..."> set by bhumai_translate.js */
html[lang="te"]{font-family:'Noto Sans Telugu','DM Sans',sans-serif}
html[lang="hi"]{font-family:'Noto Sans Devanagari','DM Sans',sans-serif}
html[lang="kn"]{font-family:'Noto Sans Kannada','DM Sans',sans-serif}
html[lang="ta"]{font-family:'Noto Sans Tamil','DM Sans',sans-serif}
/* Always render emojis with system emoji font regardless of language */
.pill-emoji,.cat-emoji,.feat-icon,.story-quote,.ticker-dot,
.w-weather-icon,.w-hour-icon,.w-day-icon,.w-dh-icon,
.ty-icon,.founder-avatar,.soc{font-family:'Segoe UI Emoji','Apple Color Emoji','Noto Color Emoji',sans-serif!important}

/* ── CROP ICONS (rendered by getCropVisual in components.js) ─────── */
/* In .crop-pill (inline-flex pill), keep the icon flush and prevent
   shrink. In .crop-card (centred card), behave like the old .crop-em
   block element with consistent bottom spacing. */
.crop-icon{vertical-align:middle;flex-shrink:0}
.crop-card .crop-icon{display:block;margin:0 auto 5px}

/* ── ANIMATIONS ─────────────────────────────────────────────────── */
@keyframes fadeUp{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* ── RESPONSIVE NAV ─────────────────────────────────────────────── */
@media(max-width:1024px){
  .nav-inner{padding:14px 24px}
  .nav-links{display:none}
  .hamburger{display:flex}
  footer{padding:48px 0 24px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
}
@media(max-width:600px){
  .nav-inner{padding:12px 20px}
  footer{padding:48px 0 24px}
  .footer-grid{grid-template-columns:1fr}
}