/* ZakatApps — Styles principaux */
/* Wattson Consulting · v1.4.0 */


/* ── RESET & BASE ─────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  /* ── Palette extraite du logo Zakat Calculator ── */
  --em:#0d5c35;--em-l:#1a7a4a;--em-d:#04311d;
  --gold:#d6a02f;--gold-l:#e5b341;--gold-r:#ca9226;--gold-dim:rgba(214,160,47,.18);
  --pro:#1a6e4a;--pro-d:#0d4a2e;
  --bg:#f5f0e8;--card:#fffdf7;--bd:rgba(214,160,47,.22);
  --text:#04311d;--muted:#4a6b54;
  --inbg:#faf7ee;--inbd:rgba(214,160,47,.28);
  --nav:#fffdf7;--sh:0 4px 20px rgba(4,49,29,.12);
  --probg:#f0f7ed;--probd:rgba(13,92,53,.22);
}
body.dark{
  --bg:#021a0e;--card:#042518;--bd:rgba(214,160,47,.20);
  --text:#f0e8c8;--muted:#8aaa78;
  --inbg:#052e1c;--inbd:rgba(214,160,47,.25);
  --nav:#021a0e;--sh:0 4px 20px rgba(0,0,0,.5);
  --probg:#042518;--probd:rgba(214,160,47,.25);
}
body{font-family:'Georgia',serif;background:var(--bg);color:var(--text);min-height:100vh;display:flex;justify-content:center;transition:background .3s,color .3s}
@media(min-width:500px){
  body{background:#1a1a2e;align-items:flex-start;padding:0}
  #app{box-shadow:0 0 40px rgba(0,0,0,.4);border-radius:0;min-height:100vh}
  .nav{border-radius:0}
}
@media(min-width:800px){
  body{align-items:flex-start;padding:20px 0}
  #app{border-radius:16px;min-height:calc(100vh - 40px);box-shadow:0 8px 48px rgba(0,0,0,.5)}
}
body.rtl{direction:rtl;font-family:'Noto Naskh Arabic','Amiri',Georgia,serif}
#app{width:100%;max-width:430px;min-height:100vh;display:flex;flex-direction:column;overflow-x:hidden}
::-webkit-scrollbar{width:3px}::-webkit-scrollbar-thumb{background:rgba(26,122,94,.35);border-radius:4px}
input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
input[type=number]{-moz-appearance:textfield}
input:focus,textarea:focus{border-color:var(--gold)!important;box-shadow:0 0 0 3px rgba(26,122,94,.14);outline:none}
button{-webkit-tap-highlight-color:transparent;cursor:pointer;font-family:inherit}
button:active:not(:disabled){opacity:.82;transform:scale(.97)}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}
@keyframes bounce{0%,80%,100%{transform:scale(.8)}40%{transform:scale(1.2)}}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.pulse{animation:pulse 2s infinite}.fadeIn{animation:fadeIn .4s ease}

/* ── LAYOUT ───────────────────────────────────────────────────────── */
.page{flex:1;overflow-y:auto;padding-bottom:96px}
.tab{display:none}.tab.active{display:block}

/* ── CARDS ────────────────────────────────────────────────────────── */
.card{background:var(--card);border:1px solid var(--bd);border-radius:18px;padding:18px 20px;margin-bottom:14px;box-shadow:var(--sh);transition:background .3s,border-color .3s}
.card-pro{background:var(--probg);border:2px solid var(--probd);border-radius:18px;padding:18px 20px;margin-bottom:14px;box-shadow:var(--sh)}
.card-sm{background:var(--card);border:1px solid var(--bd);border-radius:18px;padding:14px 12px;text-align:center;box-shadow:var(--sh)}

/* ── FORM ─────────────────────────────────────────────────────────── */
.field{margin-bottom:14px}
.field label{display:block;font-size:12.5px;font-weight:600;color:var(--muted);margin-bottom:6px}
.field label.pro{color:var(--pro)}
.field input{width:100%;padding:12px 14px;border-radius:11px;border:1.5px solid var(--inbd);background:var(--inbg);color:var(--text);font-size:15px;font-family:inherit;outline:none;transition:border-color .2s}
.field input.pro{border-color:rgba(37,99,235,.35)}
.field input:invalid{border-color:#ef4444}

/* ── BUTTONS ──────────────────────────────────────────────────────── */
.btn-p{display:flex;align-items:center;justify-content:center;width:100%;padding:15px 24px;border-radius:14px;border:none;font-size:15px;font-weight:700;color:#fff;background:linear-gradient(135deg,#d6a02f,#9a6e15);box-shadow:0 6px 18px rgba(214,160,47,.40);margin-bottom:10px}
.btn-g{display:flex;align-items:center;justify-content:center;width:100%;padding:14px 24px;border-radius:14px;border:none;font-size:14px;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--gold),#9a7810);box-shadow:0 6px 18px rgba(201,162,39,.44);margin-bottom:10px;min-height:52px}
.btn-s{display:flex;align-items:center;justify-content:center;width:100%;padding:13px 24px;border-radius:14px;border:1.5px solid var(--inbd);font-size:14px;font-weight:600;color:var(--muted);background:var(--inbg);margin-bottom:10px}

/* ── MODE BUTTONS ─────────────────────────────────────────────────── */
.mode-btn{padding:16px 10px;border-radius:14px;border:2px solid var(--bd);background:transparent;text-align:center;width:100%;transition:all .2s;min-height:80px}
.mode-btn.active-p{border-color:var(--em);background:rgba(214,160,47,.08)}
.mode-btn.active-e{border-color:var(--pro);background:rgba(37,99,235,.08)}
.mode-btn.active-f{border-color:#16a34a;background:rgba(22,163,74,.08)}
.agri-sel{display:flex;flex-direction:column;gap:6px}
.agri-sel label{display:flex;align-items:center;gap:10px;padding:11px 14px;border-radius:12px;border:1.5px solid var(--bd);cursor:pointer;font-size:13px;transition:all .2s}
.agri-sel label:has(input:checked){border-color:#16a34a;background:rgba(22,163,74,.08)}
.agri-sel label input{accent-color:#16a34a}
.irrig-rate{font-size:11px;font-weight:700;color:#16a34a;margin-left:auto}
.livestock-row{display:grid;grid-template-columns:1fr 80px;align-items:center;gap:10px;margin-bottom:10px}
.livestock-row label{font-size:13px;color:var(--text)}
.agri-nisab-info{margin-top:10px;padding:10px 13px;border-radius:10px;background:rgba(22,163,74,.07);border:1px solid rgba(22,163,74,.2);font-size:11.5px;color:#16a34a;font-weight:600}
.sec-label.agri-l{background:rgba(22,163,74,.08);border:1px solid rgba(22,163,74,.2);color:#16a34a}
.formula-box.agri-f{background:rgba(22,163,74,.07);border-color:rgba(22,163,74,.28)}
.card-agri{background:rgba(22,163,74,.04);border:2px solid rgba(22,163,74,.18);border-radius:18px;padding:18px 20px;margin-bottom:14px}
.mode-bar{width:20px;height:3px;border-radius:2px;margin:8px auto 0}

/* ── RESULT ───────────────────────────────────────────────────────── */
.result-ok{background:linear-gradient(140deg,var(--em-d),var(--em));border-radius:20px;padding:22px 20px;color:#fff;margin-top:22px;animation:fadeIn .4s ease}
.result-low{background:linear-gradient(140deg,#7a3535,#b04040);border-radius:20px;padding:22px 20px;color:#fff;margin-top:22px;animation:fadeIn .4s ease}

/* ── NAV ──────────────────────────────────────────────────────────── */
.nav{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:430px;background:var(--nav);border-top:1.5px solid var(--bd);display:flex;z-index:100;box-shadow:0 -4px 24px rgba(4,49,29,.13);padding-bottom:env(safe-area-inset-bottom,0px)}
.nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:10px 2px 10px;border:none;background:transparent;color:var(--muted);font-size:9.5px;font-weight:500;font-family:inherit;cursor:pointer;transition:all .18s;min-height:62px;position:relative;letter-spacing:.01em}
.nav-btn:active{transform:scale(.93)}
.nav-btn.active{color:var(--gold);font-weight:700}
.nav-btn .nav-ico{font-size:24px;line-height:1;transition:transform .18s}
.nav-btn.active .nav-ico{transform:scale(1.12)}
.nav-dot{width:20px;height:3px;border-radius:2px;background:linear-gradient(90deg,var(--gold),var(--gold-l));margin-top:2px;transition:opacity .2s}
.nav-btn:not(.active) .nav-dot{opacity:0}

/* ── LABELS & MISC ────────────────────────────────────────────────── */
.sec-label{display:flex;align-items:center;gap:8px;margin-bottom:12px;padding:8px 12px;border-radius:10px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.8px}
.sec-label.perso{background:rgba(214,160,47,.08);border:1px solid var(--bd);color:var(--em)}
.sec-label.pro-l{background:rgba(37,99,235,.08);border:1px solid var(--probd);color:var(--pro)}
.price-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}
.pi{border-radius:11px;padding:11px 12px}
.pi.gh{background:#fffbf0;border:1px solid rgba(201,162,39,.4)}
.pi.gn{background:rgba(214,160,47,.06);border:1px solid var(--bd)}
body.dark .pi.gh{background:rgba(201,162,39,.12);border-color:rgba(201,162,39,.3)}
body.dark .pi.gn{background:rgba(214,160,47,.09)}
.hist-item{display:flex;align-items:center;gap:14px}
.hi-icon{width:44px;height:44px;border-radius:12px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:20px}
.hi-icon.p{background:linear-gradient(135deg,#d6a02f,#9a6e15)}
.hi-icon.e{background:linear-gradient(135deg,var(--pro),var(--pro-d))}
.faq-btn{background:none;border:none;width:100%;text-align:left;cursor:pointer;display:flex;justify-content:space-between;align-items:center;padding:0;color:var(--text);font-size:13.5px;font-weight:700;line-height:1.4}
body.rtl .faq-btn{text-align:right}
.faq-arrow{color:var(--muted);transition:transform .25s;font-size:14px;flex-shrink:0;margin-left:8px}
body.rtl .faq-arrow{margin-left:0;margin-right:8px}
.faq-arrow.open{transform:rotate(180deg)}
.faq-body{color:var(--muted);font-size:13px;line-height:1.75;margin-top:12px;padding-top:12px;border-top:1px solid var(--bd)}
.formula-box{padding:12px 14px;border-radius:12px;background:rgba(214,160,47,.06);border:1.5px solid var(--bd)}
.formula-box.pro-f{background:rgba(37,99,235,.07);border-color:rgba(37,99,235,.28)}
.nisab-sel-wrap{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}
.nisab-sel-opt{position:relative;cursor:pointer}
.nisab-sel-opt input[type=radio]{position:absolute;opacity:0;width:0;height:0}
.nisab-sel-card{background:var(--inbg);border:2px solid var(--inbd);border-radius:12px;padding:13px 10px;text-align:center;transition:all .2s;cursor:pointer;user-select:none}
.nisab-sel-opt.gold-opt input:checked + .nisab-sel-card{border-color:var(--gold);background:rgba(201,162,39,.08);box-shadow:0 0 14px rgba(201,162,39,.15)}
.nisab-sel-opt.silver-opt input:checked + .nisab-sel-card{border-color:#90a8c0;background:rgba(144,168,192,.08);box-shadow:0 0 14px rgba(144,168,192,.12)}
.nisab-sel-card:hover{transform:translateY(-1px)}
.nisab-sel-check{display:none;position:absolute;top:6px;right:6px;width:16px;height:16px;border-radius:50%;font-size:9px;align-items:center;justify-content:center;color:#fff;font-weight:800}
.nisab-sel-opt.gold-opt .nisab-sel-check{background:var(--gold)}
.nisab-sel-opt.silver-opt .nisab-sel-check{background:#90a8c0}
.nisab-sel-opt input:checked ~ .nisab-sel-check{display:flex}
.nisab-sel-info{font-size:11.5px;color:var(--muted);padding:9px 12px;border-radius:10px;background:rgba(201,162,39,.06);border-left:3px solid var(--gold);line-height:1.6;margin-bottom:10px;transition:border-color .2s}
.nisab-sel-info.silver-mode{background:rgba(144,168,192,.06);border-left-color:#90a8c0}
[dir=rtl] .nisab-sel-info{border-left:none;border-right:3px solid var(--gold)}
[dir=rtl] .nisab-sel-info.silver-mode{border-right-color:#90a8c0}


body.dark .nisab-item{background:rgba(201,162,39,.09);border-color:rgba(201,162,39,.22)}
.nisab-note{font-size:11px;color:var(--muted);font-style:italic;padding:8px 10px;border-radius:8px;background:rgba(214,160,47,.06);border:1px solid var(--bd)}
.sig{display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 0 4px;border-top:1px solid var(--bd);margin-top:8px;font-size:10px;color:var(--muted);font-style:italic}

/* ── AI ───────────────────────────────────────────────────────────── */
/* ── AI TAB FULL SCREEN ─────────────────────────── */
#tab-ai{display:none!important}
#tab-ai.active{display:flex!important;flex-direction:column;position:fixed;inset:0;z-index:90;background:var(--bg);overflow:hidden}
#ai-quick-wrap{overflow-x:auto;scrollbar-width:none;padding:8px 12px 4px}
#ai-quick-wrap::-webkit-scrollbar{display:none}
#ai-quick-wrap #ai-suggestions{display:flex;flex-wrap:wrap;gap:6px}
#ai-quick-wrap{border-top:1px solid var(--bd);flex-shrink:0;padding:8px 12px}
#ai-quick-wrap #ai-suggestions{display:flex;flex-wrap:wrap;gap:6px}
.msg-u{max-width:78%;padding:12px 16px;border-radius:18px 18px 4px 18px;background:linear-gradient(135deg,#d6a02f,#9a6e15);color:#fff;font-size:13.5px;line-height:1.7;word-break:break-word;align-self:flex-end}
body.rtl .msg-u{border-radius:18px 18px 18px 4px}
.msg-a{max-width:78%;padding:12px 16px;border-radius:18px 18px 18px 4px;background:var(--card);border:1px solid var(--bd);color:var(--text);font-size:13.5px;line-height:1.7;word-break:break-word}
body.rtl .msg-a{border-radius:4px 18px 18px 18px}
.msg-row{display:flex;align-items:flex-end;gap:8px}
.ai-av{width:32px;height:32px;border-radius:10px;flex-shrink:0;background:linear-gradient(135deg,#d6a02f,#9a6e15);display:flex;align-items:center;justify-content:center;font-size:15px}
body.rtl .dots{display:flex;gap:6px;align-items:center}
.dot{width:7px;height:7px;border-radius:50%;background:var(--em)}
.dot:nth-child(1){animation:bounce 1.1s 0s infinite}
.dot:nth-child(2){animation:bounce 1.1s .18s infinite}
.dot:nth-child(3){animation:bounce 1.1s .36s infinite}

/* ── HERO ─────────────────────────────────────────────────────────── */
.hero{background:linear-gradient(155deg,#021a0e 0%,#04311d 40%,#063a22 75%,#0d5c35 100%);padding:48px 22px 34px;position:relative;overflow:hidden}
.hero-pat{position:absolute;inset:0;width:100%;height:100%;opacity:.07;pointer-events:none}

/* ── COUNTRY SELECTOR ─────────────────────────────────────────────── */
.country-sel{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--inbg);border:1.5px solid var(--inbd);border-radius:12px;margin-bottom:14px;cursor:pointer;transition:border-color .2s}
.country-sel:hover{border-color:var(--em)}
.country-flag{font-size:20px;flex-shrink:0}
.country-name{flex:1;font-size:13px;font-weight:600;color:var(--text)}
.country-cur{font-size:11px;color:var(--muted);font-weight:500}
.country-dropdown{position:fixed;inset:0;z-index:200;display:none;align-items:flex-end}
.country-dropdown.open{display:flex}
.country-overlay{position:absolute;inset:0;background:rgba(0,0,0,.5)}
.country-sheet{position:relative;z-index:1;background:var(--card);border-radius:20px 20px 0 0;padding:20px 16px 40px;width:100%;max-width:430px;margin:0 auto;max-height:70vh;overflow-y:auto}
.country-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:12px;cursor:pointer;transition:background .15s;border:none;background:transparent;width:100%;text-align:left}
body.rtl .country-item{text-align:right}
.country-item:hover,.country-item.selected{background:rgba(214,160,47,.08)}
.country-item.selected{border:1.5px solid var(--em)}

/* ── PROMO LIVE BADGE ─────────────────────────────────────────────── */
.live-badge{display:flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px}
.live-badge.on{background:rgba(34,197,94,.12);border:1px solid rgba(34,197,94,.35)}
.live-badge.off{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3)}
.live-dot{width:6px;height:6px;border-radius:50%}

/* ── CALENDRIER HIJRI ───────────────────────────────────────────── */
.hcal-day {
  aspect-ratio:1;border:none;border-radius:8px;font-size:12px;font-weight:600;
  cursor:pointer;background:transparent;color:var(--text);display:flex;
  align-items:center;justify-content:center;flex-direction:column;
  transition:background .15s;font-family:inherit;padding:0;line-height:1.1;
}
.hcal-day:hover:not(:disabled) { background:rgba(124,58,237,.12); }
.hcal-day.today { background:rgba(124,58,237,.08);border:1px solid rgba(124,58,237,.3); }
.hcal-day.selected { background:#7c3aed !important;color:#fff !important;font-weight:800; }
.hcal-day.other-month { color:var(--muted);opacity:.4; }
.hcal-day:disabled { cursor:not-allowed;opacity:.25; }
.hcal-day .greg-sub { font-size:8px;opacity:.6;font-weight:400; }
.hcal-dow-cell {
  font-size:9px;font-weight:700;color:#9333ea;text-align:center;
  padding:4px 0;text-transform:uppercase;letter-spacing:.5px;
}
.hawl-ok   { background:rgba(34,197,94,.1); border:1.5px solid rgba(34,197,94,.35); }
.hawl-prog { background:rgba(124,58,237,.08); border:1.5px solid rgba(124,58,237,.3); }
.hawl-due  { background:rgba(239,68,68,.1);  border:1.5px solid rgba(239,68,68,.3); }
.hawl-bar-bg { background:rgba(124,58,237,.15); border-radius:6px; height:8px; overflow:hidden; margin:8px 0 4px; }
.hawl-bar-fill { height:100%; border-radius:6px; transition:width .6s ease; background:linear-gradient(90deg,#7c3aed,#a855f7); }
body.dark input[type=date] { color-scheme:dark; }

[dir=ltr].num{direction:ltr;unicode-bidi:embed;display:inline-block;font-weight:inherit}

/* ── AI CHAT ─────────────────────────────────────── */
.ai-wrap{display:flex;flex-direction:column;height:calc(100dvh - 84px)}
.ai-bar{padding:12px 16px 14px;flex-shrink:0;border-top:1px solid var(--bd);background:var(--nav);display:flex;gap:10px;align-items:flex-end}
.ai-msgs{flex:1;overflow-y:auto;padding:0 16px;display:flex;flex-direction:column;gap:12px}
.ai-ta{flex:1;padding:12px 42px 12px 14px;border-radius:14px;border:1.5px solid var(--inbd);background:var(--inbg);color:var(--text);font-size:14px;resize:none;outline:none;min-height:48px;width:100%}
body.rtl .ai-ta{padding:12px 14px 12px 42px}
.ai-send{width:50px;height:50px;border-radius:14px;border:none;background:linear-gradient(135deg,#d6a02f,#9a6e15);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:18px}
