﻿
:root {
  --gold:#c9a84c; --gold-l:#e8c96a; --gold-d:#7a6230; --gold-bg:rgba(201,168,76,0.08);
  --d1:#090909; --d2:#101010; --d3:#171717; --d4:#202020; --d5:#2a2a2a;
  --t1:#e4ddd0; --t2:#7a7268; --t3:#3d3a35;
  --br:rgba(201,168,76,0.1); --brh:rgba(201,168,76,0.28);
  --sh:0 8px 40px rgba(0,0,0,0.6); --r:12px;
  --card-fs:0.98rem;
}
[data-theme=light]{
  --d1:#f5f0e8; --d2:#ede8dc; --d3:#e4ddd0; --d4:#d8d0bf; --d5:#cdc4b0;
  --t1:#1a1612; --t2:#5a5448; --t3:#9a9080;
  --br:rgba(120,90,30,0.15); --brh:rgba(120,90,30,0.35);
  --sh:0 8px 40px rgba(0,0,0,0.12);
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{background:var(--d1);color:var(--t1);font-family:'Tajawal',sans-serif;min-height:100vh;overflow-x:hidden;transition:background .3s,color .3s;}

/* BG */
.bg-l{position:fixed;inset:0;pointer-events:none;z-index:0;
  background:radial-gradient(ellipse 70% 50% at 10% 0%,rgba(201,168,76,.06),transparent 60%),
             radial-gradient(ellipse 50% 40% at 90% 100%,rgba(45,100,70,.04),transparent 60%);}
.bg-p{position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.2;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60'%3E%3Cpath d='M30 0L60 15L60 45L30 60L0 45L0 15Z' fill='none' stroke='%23c9a84c' stroke-width='0.4' opacity='0.2'/%3E%3Ccircle cx='30' cy='30' r='8' fill='none' stroke='%23c9a84c' stroke-width='0.3' opacity='0.15'/%3E%3C/svg%3E");}
[data-theme=light] .bg-p{opacity:.06;}

/* VIEWS */
.view{position:relative;z-index:1;display:none;}
.view.active{display:block;}

/* â”€â”€ LOADER â”€â”€ */
#loader{position:fixed;inset:0;background:var(--d1);z-index:999;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.2rem;transition:opacity .5s;}
#loader.out{opacity:0;pointer-events:none;}
.l-ring{width:46px;height:46px;border:2px solid var(--br);border-top-color:var(--gold);border-radius:50%;animation:spin .9s linear infinite;}
.l-txt{font-family:'Amiri',serif;color:var(--gold-d);font-size:1rem;}
.l-prog{width:180px;height:2px;background:var(--d4);border-radius:100px;overflow:hidden;}
.l-fill{height:100%;background:var(--gold);border-radius:100px;width:0%;transition:width .3s ease;}

/* â”€â”€ LANDING â”€â”€ */
.l-nav{display:flex;align-items:center;justify-content:space-between;padding:1.2rem 2.5rem;border-bottom:1px solid var(--br);}
.l-logo{display:flex;align-items:center;gap:.7rem;}
.l-logo-t h1{font-family:'Amiri',serif;font-size:.95rem;color:var(--gold);}
.l-logo-t span{font-size:.6rem;color:var(--t2);letter-spacing:.08em;}
.nav-acts{display:flex;gap:.6rem;align-items:center;}
/* Old .l-hero / .h-* removed — replaced by .hero / .hero-content. See below. */

/* ════════════════════════════════════════════════════════
   HERO — base shared styles (positioning, image, overlay)
   Sizes/layout per-viewport in desktop.css and mobile.css
   ════════════════════════════════════════════════════════ */
.hero{position:relative;overflow:hidden;isolation:isolate;}
.hero-image{position:absolute;inset:0;z-index:0;}
.hero-image img{width:100%;height:100%;object-fit:cover;display:block;animation:fadeIn 1.2s ease both;}
.hero-overlay{position:absolute;inset:0;z-index:1;pointer-events:none;}
.hero-content{position:relative;z-index:2;}

.hero-badge{
  display:inline-flex;align-items:center;gap:.55rem;
  font-size:.7rem;letter-spacing:.1em;color:var(--gold-l);
  border:1px solid rgba(201,168,76,.35);background:rgba(9,9,9,.45);
  backdrop-filter:blur(8px);padding:.42rem 1.1rem;border-radius:100px;
  animation:fadeUp .6s ease both;
}
.badge-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);animation:pulse 2s infinite;display:inline-block;}

.hero-title{
  font-family:'Amiri',serif;color:var(--t1);
  display:flex;flex-direction:column;gap:.1em;align-items:center;
  line-height:1.15;animation:fadeUp .6s ease .1s both;
  text-shadow:0 2px 24px rgba(0,0,0,.6);
  text-align:center;
}
.hero-title .ht-1{font-size:.5em;color:rgba(228,221,208,.78);font-weight:400;letter-spacing:.04em;}
.hero-title .ht-2{font-size:.65em;color:#f5edd9;font-weight:500;}
.hero-title .ht-3{font-size:1em;color:var(--gold-l);font-weight:700;letter-spacing:-.01em;}
.hero-title .ht-4{font-size:.4em;color:rgba(228,221,208,.7);font-style:italic;font-weight:400;font-family:'Tajawal',sans-serif;}

.hero-sub{
  color:rgba(228,221,208,.85);line-height:1.85;max-width:720px;
  margin:0 auto;text-align:center;
  animation:fadeUp .6s ease .15s both;text-shadow:0 1px 8px rgba(0,0,0,.5);
}

.hero-stats{
  display:flex;align-items:center;justify-content:center;gap:.55rem;flex-wrap:wrap;
  font-size:.78rem;color:rgba(228,221,208,.78);
  animation:fadeUp .6s ease .2s both;
}
.hero-stats strong{color:var(--gold-l);font-size:1rem;font-weight:700;}
.hero-stats .stat-dot{color:var(--gold-d);opacity:.6;}

.hero-cta{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center;animation:fadeUp .6s ease .25s both;}

/* Inline elegant features list (replaces CTA buttons) */
.hero-features{
  display:flex;align-items:center;justify-content:center;
  gap:.6rem;flex-wrap:wrap;
  font-size:.78rem;
  color:rgba(228,221,208,.85);
  animation:fadeUp .6s ease .25s both;
  letter-spacing:.01em;
}
.hero-feature{
  display:inline-flex;align-items:center;gap:.4rem;
  padding:.35rem .65rem;
  border-radius:100px;
  background:rgba(9,9,9,.35);
  border:1px solid rgba(201,168,76,.18);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.hero-feature svg{color:var(--gold-l);opacity:.85;flex-shrink:0;}
.hero-feature-dot{
  color:var(--gold-d);opacity:.5;font-size:.9em;
  margin:0 -.15rem;
}

[data-theme=light] .hero-features{color:rgba(26,22,18,.85);}
[data-theme=light] .hero-feature{
  background:rgba(255,255,255,.65);
  border-color:rgba(120,90,30,.25);
}
[data-theme=light] .hero-feature svg{color:var(--gold-d);opacity:1;}
[data-theme=light] .hero-feature-dot{color:var(--gold-d);}

.hero-disclaimer{
  font-size:.7rem;color:rgba(228,221,208,.6);line-height:1.6;
  text-align:center;
  animation:fadeUp .6s ease .3s both;
}
.hero-disclaimer strong{color:var(--gold-l);}

/* Light theme: invert overlay direction with cream tones */
[data-theme=light] .hero-badge{background:rgba(245,240,232,.7);color:var(--gold-d);}
[data-theme=light] .hero-title{color:var(--t1);text-shadow:0 2px 16px rgba(255,255,255,.85), 0 0 4px rgba(255,255,255,.6);}
[data-theme=light] .hero-title .ht-1{color:#3a2c1a;font-weight:500;}
[data-theme=light] .hero-title .ht-2{color:#2a1f12;font-weight:600;}
[data-theme=light] .hero-title .ht-3{color:var(--gold-d);}
[data-theme=light] .hero-title .ht-4{color:rgba(58,44,26,.85);}
[data-theme=light] .hero-sub{color:rgba(26,22,18,.78);text-shadow:none;}
[data-theme=light] .hero-stats{color:rgba(26,22,18,.78);}
[data-theme=light] .hero-stats strong{color:var(--gold-d);}
[data-theme=light] .hero-disclaimer{color:rgba(26,22,18,.65);}
[data-theme=light] .hero-disclaimer strong{color:var(--gold-d);}

/* ════════════════════════════════════════════════════════
   TRUST STRIP — 3 cards under hero
   ════════════════════════════════════════════════════════ */
.hero-strip{
  background:var(--d2);border-top:1px solid var(--br);border-bottom:1px solid var(--br);
  padding:2rem 1.5rem;
}
.strip-tagline{
  text-align:center;font-family:'Amiri',serif;font-size:1rem;
  color:var(--gold);letter-spacing:.02em;margin-bottom:1.4rem;
}
.strip-grid{
  display:grid;gap:1rem;max-width:1200px;margin:0 auto;
  grid-template-columns:repeat(3,1fr);
}
.strip-card{
  background:var(--d3);border:1px solid var(--br);border-radius:14px;
  padding:1.2rem 1.3rem;transition:border-color .2s,transform .2s;
}
.strip-card:hover{border-color:var(--brh);transform:translateY(-2px);}
.strip-icon{
  width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;
  background:var(--gold-bg);color:var(--gold);margin-bottom:.85rem;
}
.strip-card h3{font-family:'Amiri',serif;font-size:1.05rem;color:var(--t1);margin-bottom:.35rem;font-weight:700;}
.strip-card p{font-size:.8rem;color:var(--t2);line-height:1.7;}

/* ════════════════════════════════════════════════════════
   FOTD section wrapper
   ════════════════════════════════════════════════════════ */
.fotd-section{padding:2.2rem 1.5rem 1rem;max-width:760px;margin:0 auto;}

@keyframes fadeIn{from{opacity:0}to{opacity:1}}
/* ظپطھظˆظ‰ ط§ظ„ظٹظˆظ… */
.fotd{max-width:620px;width:100%;margin-bottom:2rem;background:var(--d2);border:1px solid var(--br);border-radius:14px;overflow:hidden;animation:fadeUp .6s ease .25s both;cursor:pointer;transition:border-color .2s,box-shadow .2s;}
.fotd:hover{border-color:var(--brh);box-shadow:0 8px 32px rgba(0,0,0,.4);}
.fotd-hd{padding:.55rem 1.2rem;background:var(--gold-bg);border-bottom:1px solid var(--br);display:flex;align-items:center;justify-content:space-between;}
.fotd-lbl{font-size:.7rem;color:var(--gold);letter-spacing:.08em;display:flex;align-items:center;gap:.4rem;}
.fotd-date{font-size:.63rem;color:var(--t3);}
.fotd-body{padding:1.1rem 1.3rem;}
.fotd-q{font-family:'Amiri',serif;font-size:1.02rem;line-height:1.7;color:var(--t1);margin-bottom:.6rem;}
.fotd-a{font-size:.8rem;color:var(--t2);line-height:1.7;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.fotd-ft{padding:.55rem 1.3rem;border-top:1px solid var(--br);font-size:.68rem;color:var(--gold-d);display:flex;align-items:center;gap:.3rem;}

.h-cta{display:flex;gap:.8rem;flex-wrap:wrap;justify-content:center;animation:fadeUp .6s ease .3s both;}
.cbtn{display:inline-flex;align-items:center;gap:.55rem;padding:.8rem 1.8rem;border-radius:10px;font-family:'Tajawal',sans-serif;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;border:none;}
.cbtn.pri{background:var(--gold);color:#080808;}
.cbtn.pri:hover{background:var(--gold-l);transform:translateY(-1px);box-shadow:0 8px 24px rgba(201,168,76,.3);}
.cbtn.sec{background:var(--d3);color:var(--t1);border:1px solid var(--br);}
.cbtn.sec:hover{border-color:var(--brh);transform:translateY(-1px);}

.l-topics{padding:2rem 2.5rem;border-top:1px solid var(--br);}
.tp-lbl{text-align:center;font-size:.7rem;color:var(--t3);margin-bottom:1.2rem;letter-spacing:.1em;}
.tp-grid{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;max-width:860px;margin:0 auto;}
.tp-pill{display:flex;align-items:center;gap:.45rem;padding:.45rem .9rem;border-radius:100px;background:var(--d3);border:1px solid var(--br);font-size:.78rem;color:var(--t2);cursor:pointer;transition:all .2s;}
.tp-pill:hover{border-color:var(--gold);color:var(--gold);background:var(--gold-bg);}
.tp-pill .pc{font-size:.62rem;color:var(--t3);}

/* Main sections */
.main-sec-strip{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center;align-items:center;}
.landing-strip{margin-top:1.1rem;}
.app-strip{padding:0 1.5rem .55rem;max-width:1400px;margin:0 auto;}
.sec-nav-btn{
  border:1px solid var(--br);
  background:var(--d3);
  color:var(--t2);
  border-radius:999px;
  padding:.42rem .9rem;
  font-size:.74rem;
  font-family:'Tajawal',sans-serif;
  cursor:pointer;
  transition:all .2s;
}
.sec-nav-btn:hover{border-color:var(--brh);color:var(--t1);}
.sec-nav-btn.on{border-color:var(--gold);background:var(--gold-bg);color:var(--gold);}

/* â”€â”€ APP HEADER â”€â”€ */
.app-hd{position:sticky;top:0;z-index:100;background:rgba(9,9,9,.94);backdrop-filter:blur(24px);border-bottom:1px solid var(--br);transition:background .3s;}
[data-theme=light] .app-hd{background:rgba(245,240,232,.94);}
.hd-r1{max-width:1400px;margin:0 auto;display:flex;align-items:center;gap:1rem;padding:.75rem 1.5rem;}
.hd-logo{display:flex;align-items:center;gap:.65rem;cursor:pointer;flex-shrink:0;}
.hd-logo-t h2{font-family:'Amiri',serif;font-size:.88rem;color:var(--gold);}
.hd-logo-t span{font-size:.56rem;color:var(--t2);display:block;}







/* Keyboard focus */
:focus-visible{
  outline:2px solid var(--gold);
  outline-offset:2px;
}

/* Logo image — iOS-style rounded square portrait */
.logo-img-wrap{
  width:40px;height:40px;border-radius:10px;overflow:hidden;
  border:1.5px solid rgba(201,168,76,.55);
  flex-shrink:0;display:flex;align-items:center;justify-content:center;
  background:var(--d3);
  box-shadow:0 2px 10px rgba(0,0,0,.4);
}
.logo-img{width:100%;height:100%;object-fit:cover;object-position:center 18%;}

/* Mobile floating font size buttons */
/* â”€â”€ FAB SEARCH â”€â”€ */
.fab-srch{position:fixed;bottom:2rem;left:1rem;z-index:150;width:56px;height:56px;border-radius:50%;display:none;align-items:center;justify-content:center;background:var(--gold);color:#080808;box-shadow:0 4px 24px rgba(201,168,76,.4);border:none;cursor:pointer;transition:transform .2s;-webkit-tap-highlight-color:transparent;}
.fab-srch:active{transform:scale(.92);}
.fab-srch.is-hidden{display:none!important;}
/* .fab-srch{display:flex} on mobile — moved to mobile.css */

/* Back-to-top FAB — hidden by default; desktop.css enables it */
.fab-top{display:none;}

/* â”€â”€ SEARCH MODAL â”€â”€ */
.srch-modal{position:fixed;inset:0;z-index:400;display:none;flex-direction:column;background:var(--d1);}
.srch-modal.show{display:flex!important;}
.srch-modal-hd{display:flex;align-items:center;gap:.8rem;padding:.9rem 1rem;border-bottom:1px solid var(--br);background:var(--d2);}
.srch-modal-inp{flex:1;background:var(--d3);border:1.5px solid var(--gold-d);border-radius:12px;padding:.75rem 1.1rem;color:var(--t1);font-family:'Tajawal',sans-serif;font-size:1rem;direction:rtl;}
.srch-modal-inp::placeholder{color:var(--t3);}
.srch-modal-inp:focus-visible{border-color:var(--gold);}
.srch-modal-close{background:none;border:none;color:var(--t2);cursor:pointer;padding:.3rem;flex-shrink:0;display:flex;align-items:center;}
.srch-modal-body{flex:1;overflow-y:auto;padding:1rem;}
.srch-suggest-lbl{font-size:.7rem;color:var(--t3);letter-spacing:.08em;margin-bottom:.7rem;padding-bottom:.4rem;border-bottom:1px solid var(--br);}
.srch-result-item{background:var(--d2);border:1px solid var(--br);border-radius:10px;padding:.9rem 1rem;margin-bottom:.55rem;cursor:pointer;transition:border-color .18s;direction:rtl;}
.srch-result-item:active{border-color:var(--gold);}
.srch-result-item:focus-visible{border-color:var(--gold);}
.srch-result-q{font-family:'Amiri',serif;font-size:.98rem;line-height:1.6;color:var(--t1);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.srch-result-a{font-size:.78rem;color:var(--t2);margin-top:.3rem;line-height:1.5;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;}
.srch-result-item mark{background:rgba(201,168,76,.25);color:var(--gold-l);border-radius:2px;padding:0 2px;}

/* â”€â”€ SETTINGS MODAL â”€â”€ */
.settings-modal{position:fixed;inset:0;z-index:9999;display:none;align-items:flex-end;background:rgba(0,0,0,.7);backdrop-filter:blur(6px);isolation:isolate;}
.settings-modal.show{display:flex!important;}
.settings-sheet{width:100%;max-height:85vh;background:var(--d2);border-radius:20px 20px 0 0;overflow-y:auto;overflow-x:hidden;padding:1.4rem 1.4rem 4rem;animation:slideUp .3s ease;direction:rtl;text-align:right;box-sizing:border-box;}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.settings-sheet h3{font-family:'Amiri',serif;font-size:1.1rem;color:var(--gold);margin-bottom:1.5rem;text-align:center;padding-bottom:.8rem;border-bottom:1px solid var(--br);}
.sett-section{margin-bottom:1.6rem;}
.sett-lbl{font-size:.7rem;color:var(--t3);letter-spacing:.1em;margin-bottom:.7rem;display:block;}




.font-opts{display:flex;flex-direction:column;gap:.6rem;width:100%;}
.font-opt{padding:.85rem 1rem;background:var(--d3);border:1.5px solid var(--br);border-radius:12px;cursor:pointer;transition:all .2s;text-align:right;-webkit-tap-highlight-color:transparent;width:100%;box-sizing:border-box;}
.font-opt.active{border-color:var(--gold);background:var(--gold-bg);}
.fo-name{font-size:.75rem;color:var(--t2);margin-bottom:.25rem;}
.fo-prev{font-size:1.05rem;color:var(--t1);line-height:1.5;}
.fs-slider{width:100%;-webkit-appearance:none;height:5px;border-radius:100px;background:var(--d4);margin:.6rem 0;direction:ltr;}
.fs-slider::-webkit-slider-thumb{-webkit-appearance:none;width:26px;height:26px;border-radius:50%;background:var(--gold);cursor:pointer;border:2px solid var(--d2);box-shadow:0 2px 8px rgba(0,0,0,.3);}
.fs-labels{display:flex;justify-content:space-between;font-size:.65rem;color:var(--t3);direction:ltr;}
.sett-close{width:100%;padding:.85rem;background:var(--d3);border:1px solid var(--br);border-radius:10px;color:var(--t1);font-family:'Tajawal',sans-serif;font-size:.9rem;cursor:pointer;margin-top:.5rem;transition:all .2s;}
.sett-close:active{background:var(--d4);}

.hd-tools{display:flex;gap:.4rem;flex-shrink:0;}
.tbtn{width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:var(--d3);border:1px solid var(--br);color:var(--t2);cursor:pointer;transition:all .2s;font-size:.8rem;}
.tbtn:hover{border-color:var(--brh);color:var(--t1);}
.tbtn.on{border-color:var(--gold);color:var(--gold);background:var(--gold-bg);}
.hd-cnt{font-size:.7rem;color:var(--t2);text-align:center;line-height:1.5;flex-shrink:0;}
.hd-cnt strong{display:block;font-size:.95rem;color:var(--gold);font-weight:700;}

/* Filter bar */
.flt-bar{max-width:1400px;margin:0 auto;display:flex;align-items:center;gap:.45rem;padding:.5rem 1.5rem;overflow-x:auto;scrollbar-width:none;border-top:1px solid rgba(201,168,76,.05);}
.flt-bar::-webkit-scrollbar{display:none;}
.flt-lbl{font-size:.68rem;color:var(--t3);white-space:nowrap;flex-shrink:0;}
.fchip{display:inline-flex;align-items:center;gap:.32rem;padding:.3rem .8rem;border-radius:100px;background:var(--d3);border:1px solid var(--br);color:var(--t2);font-family:'Tajawal',sans-serif;font-size:.74rem;cursor:pointer;white-space:nowrap;transition:all .18s;flex-shrink:0;}
.fchip:hover{border-color:var(--brh);color:var(--t1);}
.fchip.on{background:var(--gold-bg);border-color:var(--gold);color:var(--gold);}
.fchip .cnt{font-size:.6rem;opacity:.65;background:rgba(255,255,255,.07);padding:.04rem .32rem;border-radius:100px;}

/* â”€â”€ MAIN â”€â”€ */
.app-main{max-width:1400px;margin:0 auto;padding:1.2rem 1.5rem 5rem;}
.res-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem;}
.res-txt{font-size:.78rem;color:var(--t2);}
.res-txt strong{color:var(--gold);}
.view-tog{display:flex;gap:.3rem;}
.vtbtn{width:30px;height:30px;border-radius:6px;display:flex;align-items:center;justify-content:center;background:var(--d3);border:1px solid var(--br);color:var(--t3);cursor:pointer;transition:all .2s;}
.vtbtn.on{border-color:var(--gold);color:var(--gold);}

/* ════════════════════════════════════════════════════════
   FATWA CARDS — Editorial layout
   ════════════════════════════════════════════════════════ */
.fc{
  background:var(--d2);
  border:1px solid var(--br);
  border-radius:14px;
  cursor:pointer;
  transition:transform .2s ease, border-color .2s ease, box-shadow .2s ease;
  animation:fadeUp .3s ease both;
  display:flex;
  flex-direction:column;
  padding:1.4rem 1.5rem 1.1rem;
  position:relative;
}
.fc:hover{
  transform:translateY(-3px);
  border-color:var(--brh);
  box-shadow:0 12px 32px rgba(0,0,0,.45);
}
.fc:focus-visible{border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,168,76,.22);outline:none;}

/* Header row: favorite (right) + meta (left) */
.fc-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:1rem;
}
.fc-fav-btn{
  width:32px;height:32px;
  display:inline-flex;align-items:center;justify-content:center;
  border:1px solid var(--br);
  background:transparent;
  color:var(--t3);
  border-radius:50%;
  cursor:pointer;
  transition:all .18s ease;
}
.fc-fav-btn:hover{
  border-color:var(--gold);
  color:var(--gold);
  transform:scale(1.08);
}
.fc-fav-btn.on{
  background:var(--gold-bg);
  border-color:var(--gold);
  color:var(--gold);
}
.fc-meta{
  display:flex;align-items:center;gap:.4rem;
  font-size:.7rem;color:var(--t3);letter-spacing:.02em;
}
.fc-topic{
  color:var(--gold-d);
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:.66rem;
}
.fc-meta-dot{opacity:.5;}
.fc-idx{
  font-family:'Tajawal',sans-serif;
  color:var(--t3);
  direction:ltr;
}

/* Question — styled like an article headline */
.fc-body{flex:1;display:flex;flex-direction:column;gap:.85rem;}
.fc-q{
  font-family:var(--arabic-font,'Amiri',serif);
  font-size:1.15rem;
  line-height:1.65;
  color:var(--t1);
  font-weight:700;
  margin:0;
}

/* Answer preview — supporting text, 3 lines */
.fc-a{
  font-family:'Tajawal',sans-serif;
  font-size:.85rem;
  color:var(--t2);
  line-height:1.85;
  margin:0;
  display:-webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

/* Separator */
.fc-sep{
  height:1px;
  background:linear-gradient(90deg,transparent,var(--br) 25%,var(--br) 75%,transparent);
  margin:1.1rem 0 .9rem;
}

/* CTA row — gold accent */
.fc-cta{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:.4rem;
  font-size:.78rem;
  color:var(--gold-d);
  font-weight:600;
  font-family:'Tajawal',sans-serif;
  transition:gap .18s ease, color .18s ease;
}
.fc:hover .fc-cta{
  color:var(--gold);
  gap:.6rem;
}
.fc-cta svg{transition:transform .18s ease;}
.fc:hover .fc-cta svg{transform:translateX(-3px);}

/* Favorite-card subtle accent */
.fc.is-fav{
  border-color:rgba(201,168,76,.32);
  background:linear-gradient(180deg, rgba(201,168,76,.04), var(--d2) 60%);
}

/* Grid / List */
.fc-wrap.gv{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1rem;}
.fc-wrap.lv{display:flex;flex-direction:column;gap:.5rem;}
.fc-wrap.lv .fc{
  padding:.85rem 1.1rem;
  border-radius:10px;
  flex-direction:row;
  align-items:center;
  gap:1rem;
}
.fc-wrap.lv .fc-head{margin-bottom:0;flex-shrink:0;flex-direction:row-reverse;gap:.6rem;}
.fc-wrap.lv .fc-fav-btn{width:28px;height:28px;}
.fc-wrap.lv .fc-meta{flex-direction:row;}
.fc-wrap.lv .fc-body{flex:1;gap:.25rem;}
.fc-wrap.lv .fc-q{font-size:1rem;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;}
.fc-wrap.lv .fc-a,
.fc-wrap.lv .fc-sep,
.fc-wrap.lv .fc-cta{display:none;}

/* Empty */
.empty{grid-column:1/-1;text-align:center;padding:5rem 2rem;color:var(--t3);}

/* Scroll sentinel */
#sentinel{height:50px;display:flex;align-items:center;justify-content:center;}
.spin-sm{width:28px;height:28px;border:2px solid var(--br);border-top-color:var(--gold);border-radius:50%;animation:spin .8s linear infinite;display:none;}

/* â”€â”€ DETAIL VIEW â”€â”€ */
.dt-hd{position:sticky;top:0;z-index:100;background:rgba(9,9,9,.94);backdrop-filter:blur(24px);border-bottom:1px solid var(--br);padding:.7rem 1.5rem;display:flex;align-items:center;gap:.8rem;transition:background .3s;}
[data-theme=light] .dt-hd{background:rgba(245,240,232,.94);}
.back-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem .9rem;border-radius:7px;background:var(--d3);border:1px solid var(--br);color:var(--t2);font-family:'Tajawal',sans-serif;font-size:.78rem;cursor:pointer;transition:all .2s;}
.back-btn:hover{color:var(--gold);border-color:var(--gold-d);}
.dt-bc{font-size:.72rem;color:var(--t3);flex:1;}
.dt-bc span{color:var(--t2);}
.dt-acts-top{display:flex;gap:.35rem;}

.dt-wrap{max-width:880px;margin:0 auto;padding:2rem 1.5rem 5rem;touch-action:pan-y;}

/* ════════════════════════════════════════════════════════
   DETAIL — Editorial fatwa card (redesigned)
   ════════════════════════════════════════════════════════ */
.dt-card{
  background:var(--d2);
  border:1px solid var(--br);
  border-radius:16px;
  box-shadow:var(--sh);
  padding:2rem 2.2rem 1.6rem;
}

/* Header: favorite + meta line */
.dt-head{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:1.6rem;
  padding-bottom:1.2rem;
  border-bottom:1px dashed var(--br);
}
.dt-fav-btn{
  width:42px;height:42px;
  border-radius:50%;
  background:var(--d3);
  border:1.5px solid var(--brh);
  color:var(--gold-d);
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all .2s ease;
  padding:0;
}
.dt-fav-btn:hover{
  border-color:var(--gold);
  color:var(--gold);
  background:var(--gold-bg);
  transform:scale(1.08);
  box-shadow:0 0 0 4px rgba(201,168,76,.12);
}
.dt-fav-btn.on{
  background:var(--gold);
  border-color:var(--gold);
  color:#080808;
  box-shadow:0 4px 14px rgba(201,168,76,.35);
}
.dt-fav-btn.on:hover{
  background:var(--gold-l);
}
.dt-meta-line{
  display:flex;align-items:center;gap:.55rem;
  font-size:.78rem;color:var(--t3);
}
.dt-topic{
  color:var(--gold-d);font-weight:700;
  text-transform:uppercase;letter-spacing:.1em;
  font-size:.7rem;
}
.dt-meta-dot{opacity:.45;}
.dt-idx{
  color:var(--t3);direction:ltr;
  font-family:'Tajawal',sans-serif;font-weight:500;
}

/* Section labels (السؤال / الجواب الشرعي) */
.dt-section-label{
  display:flex;align-items:center;gap:.65rem;
  font-size:.72rem;letter-spacing:.16em;
  color:var(--gold-d);font-weight:700;
  text-transform:uppercase;
  margin-bottom:.9rem;
}
.dt-section-label::after{
  content:'';flex:1;height:1px;
  background:linear-gradient(90deg,var(--br),transparent);
}

/* Question block */
.dt-question-block{margin-bottom:2rem;}
.dt-q{
  font-family:var(--arabic-font,'Amiri',serif);
  font-size:1.7rem;line-height:1.7;
  color:var(--t1);font-weight:700;
  margin:0;
}

/* Answer block — readable typography */
.dt-answer-block{margin-bottom:2rem;}
.dt-a{
  font-family:var(--arabic-font,'Amiri',serif);
  font-size:1.22rem;line-height:2.15;
  color:var(--t1);
  max-width:65ch;
}
.dt-a p{margin:0 0 1em;}
.dt-a p:last-child{margin-bottom:0;}
.dt-a.clamp{max-height:18em;overflow:hidden;position:relative;}
.dt-a.clamp::after{
  content:'';position:absolute;inset:auto 0 0 0;height:5em;
  background:linear-gradient(to bottom,rgba(16,16,16,0),var(--d2));
  pointer-events:none;
}
[data-theme=light] .dt-a.clamp::after{background:linear-gradient(to bottom,rgba(237,232,220,0),var(--d2));}
.ans-more{
  margin-top:1rem;padding:.5rem .9rem;
  border:1px solid var(--br);border-radius:8px;
  background:var(--d3);color:var(--gold-d);
  font-family:'Tajawal',sans-serif;font-size:.78rem;cursor:pointer;
  transition:all .2s;
}
.ans-more:hover{border-color:var(--gold);color:var(--gold);background:var(--gold-bg);}

/* Actions row — icons + labels */
.dt-actions{
  display:flex;flex-wrap:wrap;gap:.6rem;
  padding-top:1.4rem;
  border-top:1px solid var(--br);
  margin-bottom:1rem;
}
.dt-act{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.65rem 1.1rem;
  background:var(--d3);
  border:1px solid var(--br);
  border-radius:10px;
  color:var(--t1);
  font-family:'Tajawal',sans-serif;
  font-size:.85rem;font-weight:500;
  cursor:pointer;text-decoration:none;
  transition:all .18s ease;
}
.dt-act:hover{
  border-color:var(--gold);
  color:var(--gold);
  background:var(--gold-bg);
  transform:translateY(-1px);
}
.dt-act svg{color:var(--gold-d);transition:color .18s;flex-shrink:0;}
.dt-act:hover svg{color:var(--gold);}
.dt-act-source{
  background:var(--gold-bg);
  border-color:rgba(201,168,76,.3);
  color:var(--gold-l);
}

/* Source line (fatwa ID) */
.dt-source-line{
  font-size:.74rem;color:var(--t3);
  margin-top:.6rem;
}
.dt-source-line code{
  direction:ltr;font-family:monospace;
  background:var(--d3);padding:.18rem .45rem;
  border-radius:5px;color:var(--t2);
  font-size:.88em;
}

/* ════════════════════════════════════════════════════════
   PREV / NEXT NAVIGATION
   ════════════════════════════════════════════════════════ */
.dt-nav{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1rem;
  margin-top:1.5rem;
}
.dt-nav-spacer{display:block;}
.dt-nav-card{
  display:flex;align-items:center;gap:1rem;
  padding:1.1rem 1.3rem;
  background:var(--d2);
  border:1px solid var(--br);
  border-radius:12px;
  color:var(--t1);
  font-family:'Tajawal',sans-serif;
  cursor:pointer;
  transition:all .2s ease;
  text-align:right;
  min-width:0;
}
.dt-nav-card:hover{
  border-color:var(--gold);
  background:var(--gold-bg);
  transform:translateY(-2px);
  box-shadow:0 6px 18px rgba(0,0,0,.3);
}
.dt-nav-arrow{
  font-size:1.6rem;color:var(--gold-d);font-weight:700;
  flex-shrink:0;
  transition:transform .2s, color .2s;
  line-height:1;
}
.dt-nav-card:hover .dt-nav-arrow{color:var(--gold);}
/* prev (HTML order: arrow first → in RTL appears on the RIGHT, points right) */
.dt-nav-card.prev:hover .dt-nav-arrow{transform:translateX(4px);}
/* next (HTML order: arrow first → in RTL natural; we keep arrow first so it appears RIGHT,
   but for "next" we want arrow on LEFT pointing left. Use row-reverse to flip. */
.dt-nav-card.next{flex-direction:row-reverse;}
.dt-nav-card.next:hover .dt-nav-arrow{transform:translateX(-4px);}
.dt-nav-content{
  flex:1;display:flex;flex-direction:column;gap:.3rem;min-width:0;
}
.dt-nav-label{
  font-size:.7rem;color:var(--gold-d);
  letter-spacing:.08em;font-weight:700;text-transform:uppercase;
}
.dt-nav-q{
  font-family:var(--arabic-font,'Amiri',serif);
  font-size:.95rem;color:var(--t1);line-height:1.55;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;
  overflow:hidden;
}
.dt-nav-q-empty{color:var(--t3);font-style:italic;font-size:.82rem;}

/* ════════════════════════════════════════════════════════
   RELATED FATWAS
   ════════════════════════════════════════════════════════ */
.dt-related{
  margin-top:2rem;
}
.dt-related-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:.8rem;
}
.dt-rel-card{
  display:flex;flex-direction:column;gap:.45rem;
  padding:1rem 1.2rem;
  background:var(--d2);
  border:1px solid var(--br);
  border-radius:11px;
  cursor:pointer;
  font-family:'Tajawal',sans-serif;
  text-align:right;
  transition:all .18s ease;
  min-height:84px;
}
.dt-rel-card:hover{
  border-color:var(--gold);
  background:var(--gold-bg);
  transform:translateY(-2px);
}
.dt-rel-meta{
  font-size:.68rem;color:var(--gold-d);
  font-weight:700;letter-spacing:.04em;direction:ltr;
}
.dt-rel-q{
  font-family:var(--arabic-font,'Amiri',serif);
  font-size:.95rem;line-height:1.6;color:var(--t1);
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;
  overflow:hidden;
}

/* Related */
.rel-wrap{margin-top:1.3rem;}
.rel-ttl{font-size:.76rem;color:var(--t2);margin-bottom:.7rem;padding-bottom:.45rem;border-bottom:1px solid var(--br);}
.rel-grid{display:grid;grid-template-columns:1fr 1fr;gap:.55rem;}
.rel-c{background:var(--d3);border:1px solid var(--br);border-radius:8px;padding:.8rem;cursor:pointer;transition:all .2s;}
.rel-c:hover{border-color:var(--brh);}
.rel-c:focus-visible{border-color:var(--gold);}
.rel-q{font-family:'Amiri',serif;font-size:.83rem;line-height:1.5;color:var(--t2);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}

/* Swipe hint */
.swipe-hint{
  text-align:center;
  font-size:.98rem;
  color:var(--gold);
  margin-top:1rem;
  opacity:1;
  font-weight:700;
  background:var(--gold-bg);
  border:1px solid var(--brh);
  border-radius:10px;
  padding:.7rem .95rem;
}

/* Content sections (biography + books) */
.sec-hd{
  position:sticky;
  top:0;
  z-index:100;
  background:rgba(9,9,9,.94);
  backdrop-filter:blur(24px);
  border-bottom:1px solid var(--br);
  padding:.7rem 1.5rem;
  display:flex;
  align-items:center;
  gap:.8rem;
}
[data-theme=light] .sec-hd{background:rgba(245,240,232,.94);}
.sec-bc{font-size:.74rem;color:var(--t3);flex:1;}
.sec-bc span{color:var(--t2);}
.sec-wrap{max-width:980px;margin:0 auto;padding:1.25rem 1rem 4.5rem;}
.sec-card{
  margin-top:1rem;
  background:var(--d2);
  border:1px solid var(--br);
  border-radius:14px;
  box-shadow:var(--sh);
  padding:1.2rem;
}
.sec-title{
  font-family:'Amiri',serif;
  font-size:1.45rem;
  color:var(--gold);
  line-height:1.6;
  margin-bottom:.5rem;
}
.sec-note{
  color:var(--t2);
  font-size:.8rem;
  margin-bottom:1rem;
}
/* ════════════════════════════════════════════════════════
   BIOGRAPHY — Editorial article layout
   ════════════════════════════════════════════════════════ */
.bio-article{
  background:var(--d2);
  border:1px solid var(--br);
  border-radius:18px;
  box-shadow:var(--sh);
  padding:2.2rem 2.5rem 2rem;
  max-width:820px;
  margin:0 auto;
}

/* Hero header: avatar + title */
.bio-hero{
  display:flex;align-items:center;gap:1.5rem;
  padding-bottom:1.6rem;
  margin-bottom:2rem;
  border-bottom:1px solid var(--br);
}
.bio-hero-avatar{
  width:96px;height:96px;
  border-radius:50%;
  overflow:hidden;
  flex-shrink:0;
  border:2px solid rgba(201,168,76,.4);
  box-shadow:0 4px 16px rgba(0,0,0,.4);
  background:var(--d3);
}
.bio-hero-avatar img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:center 25%;
  display:block;
}
.bio-hero-text{flex:1;min-width:0;}
.bio-kicker{
  font-size:.74rem;letter-spacing:.16em;
  color:var(--gold-d);text-transform:uppercase;
  font-weight:700;margin-bottom:.45rem;
}
.bio-title{
  font-family:'Amiri',serif;
  font-size:1.55rem;line-height:1.5;
  color:var(--t1);font-weight:700;
  margin:0 0 .55rem;
}
.bio-meta{
  font-size:.82rem;color:var(--t2);
  margin:0;line-height:1.7;
}
.bio-meta-dot{color:var(--gold-d);opacity:.5;margin:0 .35rem;}

/* Content area — clean flowing prose */
.bio-content{
  display:flex;
  flex-direction:column;
  gap:0;
}
.bio-para{
  margin:0 0 1.05em;
  font-family:var(--arabic-font,'Amiri',serif);
  font-size:1.12rem;
  line-height:2.05;
  color:var(--t1);
  text-align:justify;
  text-justify:inter-word;
  word-spacing:.02em;
}

/* Special: Bismillah (centered, decorative) */
.bio-bismillah{
  text-align:center;
  font-family:'Amiri',serif;
  font-size:1.45rem;
  color:var(--gold);
  margin:.6rem 0 1.8rem;
  position:relative;
  letter-spacing:.02em;
}
.bio-bismillah::before,
.bio-bismillah::after{
  content:'';
  display:block;
  width:60px;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold-d),transparent);
  margin:.5rem auto;
}

/* Drop cap on first substantive paragraph */
.bio-dropcap .bio-cap{
  float:right;
  font-family:'Amiri',serif;
  font-size:3.4em;
  line-height:.85;
  color:var(--gold);
  margin:.05em .2em -.1em 0;
  font-weight:700;
}

/* Section headings */
.bio-heading{
  font-family:'Amiri',serif;
  font-size:1.65rem;
  color:var(--gold);
  font-weight:700;
  line-height:1.5;
  margin:2.4rem 0 1.1rem;
  padding:.7rem 0 .85rem;
  border-top:1px solid var(--brh);
  border-bottom:1px solid var(--brh);
  text-align:center;
  letter-spacing:.01em;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:.7rem;
  position:relative;
}
.bio-heading::before,
.bio-heading::after{
  content:'';
  flex:1;
  max-width:50px;
  height:1px;
  background:linear-gradient(90deg,transparent,var(--gold-d),transparent);
}
.bio-heading-mark{
  color:var(--gold-d);
  font-size:.75em;
  opacity:.85;
}

/* Figures (images between paragraphs) — smaller */
.bio-figure{
  margin:1.8rem auto;
  text-align:center;
  max-width:420px;
}
.bio-figure img{
  width:100%;
  height:auto;
  border-radius:12px;
  border:2px solid rgba(201,168,76,.25);
  box-shadow:0 6px 20px rgba(0,0,0,.4);
  display:block;
  transition:transform .3s ease;
}
.bio-figure img:hover{
  transform:scale(1.01);
  border-color:var(--gold-d);
}

/* Footer of bio article */
.bio-footer{
  margin-top:2rem;
  padding-top:1.5rem;
  border-top:1px dashed var(--br);
  text-align:center;
}
.bio-end{
  font-size:1.2rem;
  color:var(--gold-d);
  letter-spacing:.6em;
  margin-bottom:1rem;
}
.bio-source{
  font-size:.78rem;
  color:var(--t3);
  margin:0;
}
.bio-source a{
  color:var(--gold-d);
  text-decoration:none;
  border-bottom:1px dotted var(--gold-d);
  direction:ltr;
  display:inline-block;
}
.bio-source a:hover{color:var(--gold);}

.bio-empty{
  text-align:center;
  color:var(--t3);
  padding:1.4rem .8rem;
}

.books-tools{display:flex;flex-direction:column;gap:.8rem;margin-bottom:.85rem;}
.books-search{
  width:100%;
  border:1.5px solid var(--gold-d);
  border-radius:12px;
  background:var(--d3);
  color:var(--t1);
  font-family:'Tajawal',sans-serif;
  font-size:.93rem;
  padding:.7rem .9rem;
}
.books-search::placeholder{color:var(--t3);}
.books-search:focus-visible{border-color:var(--gold);}
.books-list{display:flex;flex-direction:column;gap:.7rem;}
.book-item{
  border:1px solid var(--br);
  border-radius:12px;
  background:var(--d3);
  overflow:hidden;
}
.book-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:.65rem;
  padding:.78rem .85rem;
}
.book-title{
  color:var(--t1);
  font-family:'Amiri',serif;
  font-size:1.02rem;
  line-height:1.65;
  text-decoration:none;
}
.book-title:hover{color:var(--gold);}
.book-toggle{
  flex-shrink:0;
  border:1px solid var(--br);
  background:var(--d2);
  color:var(--gold-d);
  border-radius:999px;
  padding:.35rem .72rem;
  font-size:.72rem;
  font-family:'Tajawal',sans-serif;
  cursor:pointer;
}
.book-toggle:hover{border-color:var(--gold);color:var(--gold);}
.book-chapters{
  border-top:1px solid var(--br);
  padding:.55rem;
  display:flex;
  flex-direction:column;
  gap:.45rem;
}
.book-chapter{
  display:flex;
  align-items:flex-start;
  gap:.55rem;
  border:1px solid var(--br);
  border-radius:10px;
  padding:.5rem .62rem;
  background:var(--d2);
  color:var(--t2);
  text-decoration:none;
}
.book-chapter:hover{border-color:var(--brh);color:var(--t1);}
.book-ch-no{
  min-width:1.5rem;
  text-align:center;
  color:var(--gold-d);
  font-size:.71rem;
  font-weight:700;
}
.book-ch-title{
  font-size:.85rem;
  line-height:1.6;
  color:inherit;
}

/* â”€â”€ READING MODE â”€â”€ */
#readMode{position:fixed;inset:0;background:var(--d1);z-index:500;display:none;overflow-y:auto;}
#readMode.show{display:block;}
.rm-bar{display:flex;align-items:center;justify-content:space-between;padding:.8rem 2rem;border-bottom:1px solid var(--br);position:sticky;top:0;background:var(--d1);}
.rm-title{font-size:.75rem;color:var(--gold-d);letter-spacing:.08em;}
.rm-close{background:none;border:1px solid var(--br);color:var(--t2);padding:.4rem .9rem;border-radius:6px;font-family:'Tajawal',sans-serif;font-size:.78rem;cursor:pointer;transition:all .2s;}
.rm-close:hover{border-color:var(--brh);color:var(--t1);}
.rm-content{max-width:680px;margin:0 auto;padding:3rem 2rem 6rem;}
.rm-q{font-family:'Amiri',serif;font-size:1.5rem;line-height:1.8;color:var(--t1);margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--br);}
.rm-a{font-family:'Amiri',serif;font-size:1.25rem;line-height:2.2;color:var(--t1);}




/* â”€â”€ KEYBOARD HINT â”€â”€ */
.kb-hint{position:fixed;bottom:1.5rem;left:50%;transform:translateX(-50%);background:var(--d3);border:1px solid var(--br);border-radius:8px;padding:.5rem 1rem;font-size:.68rem;color:var(--t3);z-index:50;pointer-events:none;opacity:0;transition:opacity .3s;}
.kb-hint.show{opacity:1;}
kbd{background:var(--d4);border:1px solid var(--br);border-radius:4px;padding:.1rem .35rem;font-family:monospace;font-size:.65rem;color:var(--t2);}

/* Toast */
.toast{position:fixed;bottom:2rem;left:50%;transform:translateX(-50%) translateY(10px);background:var(--d4);border:1px solid var(--br);border-radius:10px;padding:.7rem 1.3rem;font-size:.8rem;color:var(--t1);opacity:0;pointer-events:none;transition:all .3s;box-shadow:var(--sh);z-index:999;}
.toast.show{opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0);}

/* Print */
@media print{
  #loader,.app-hd,.dt-hd,.dt-acts,.rel-wrap,#readMode .rm-bar{display:none!important;}
  .dt-card{border:none;box-shadow:none;}
  body{background:#fff!important;color:#000!important;}
  .dt-q,.dt-a{color:#000!important;}
}

/* Animations */
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}

@media (prefers-reduced-motion: reduce){
  *{
    animation:none!important;
    transition:none!important;
    scroll-behavior:auto!important;
  }
}

/* Responsive overrides moved to mobile.css and desktop.css */

/* â”€â”€ READING MODE FABS â”€â”€ */
.rm-fab-wrap{position:fixed;bottom:2rem;left:1rem;z-index:1001;display:flex;flex-direction:column;gap:.5rem;}
.rm-fab{width:50px;height:50px;border-radius:50%;border:none;background:rgba(201,168,76,.9);color:#080808;font-family:'Tajawal',sans-serif;font-size:1rem;font-weight:900;cursor:pointer;box-shadow:0 4px 16px rgba(0,0,0,.4);-webkit-tap-highlight-color:transparent;}
.rm-fab:active{transform:scale(.92);}

/* Enhancements: favorites + continue reading */
.continue-btn{margin-inline-start:.5rem;}
.fchip.fav-chip{border-color:rgba(201,168,76,.35);}
.fchip.fav-chip.on{border-color:var(--gold);box-shadow:0 0 0 1px rgba(201,168,76,.3) inset;}
.fc.is-fav{border-color:rgba(201,168,76,.45);}
.fc-fav{display:inline-flex;align-items:center;justify-content:center;width:1.4rem;height:1.4rem;border-radius:50%;font-size:.85rem;color:var(--gold-d);background:rgba(201,168,76,.12);margin-inline-start:.4rem;}
.abt.fav-act.on{border-color:var(--gold);color:var(--gold);}

/* Smart search info */
.smart-note{font-size:.68rem;color:var(--gold-d);margin-top:.25rem;}

/* Skeleton loading */
.fc.skel{pointer-events:none;cursor:default;}
.skel-box{position:relative;overflow:hidden;background:var(--d3);border-radius:8px;}
.skel-box::after{
  content:"";
  position:absolute;
  inset:0;
  transform:translateX(-100%);
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent);
  animation:shimmer 1.2s infinite;
}
.skel-line{height:12px;margin-bottom:10px;}
.skel-line.lg{height:16px;width:85%;}
.skel-line.md{width:72%;}
.skel-line.sm{width:58%;margin-bottom:0;}
@keyframes shimmer{100%{transform:translateX(100%)}}

/* Onboarding */
.onboard{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.68);
  backdrop-filter:blur(4px);
  z-index:700;
  display:none;
  align-items:flex-end;
}
.onboard.show{display:flex!important;}
.onboard-sheet{
  width:min(560px,100%);
  margin:0 auto;
  background:var(--d2);
  border:1px solid var(--brh);
  border-radius:16px 16px 0 0;
  padding:1rem 1rem 1.2rem;
}
.onboard-head{display:flex;align-items:center;justify-content:space-between;font-size:.9rem;color:var(--gold);}
.onboard-lead{font-size:.76rem;color:var(--t2);margin:.5rem 0 .7rem;}
.onboard-steps{display:flex;flex-direction:column;gap:.45rem;margin-bottom:.7rem;}
.onboard-step{font-size:.75rem;color:var(--t1);line-height:1.7;background:var(--d3);border:1px solid var(--br);border-radius:10px;padding:.55rem .65rem;}
.onboard-step span{display:inline-flex;width:18px;height:18px;align-items:center;justify-content:center;border-radius:50%;background:var(--gold-bg);color:var(--gold);font-size:.66rem;margin-inline-start:.25rem;}
.onboard-prog{height:6px;background:var(--d4);border-radius:999px;overflow:hidden;margin-bottom:.65rem;}
#onboardFill{height:100%;width:0%;background:var(--gold);transition:width .25s linear;}
.onboard-actions{display:flex;gap:.5rem;justify-content:flex-end;}

/* Micro interactions */
.tap-pop{animation:tapPop .18s ease;}
@keyframes tapPop{0%{transform:scale(.98)}100%{transform:scale(1)}}
