:root{
  --navy:#0f2a44;
  --navy-deep:#0a1f33;
  --navy-soft:#163b5c;
  --gold:#c9a227;
  --gold-soft:#e3c878;
  --cream:#f6f1e7;
  --paper:#fbf8f1;
  --ink:#23252b;
  --ink-soft:#5a5e68;
  --line:#e6dfcf;
  --shadow:0 6px 24px rgba(15,42,68,.12);
  --radius:18px;
  --tab-h:64px;
  --header-h:64px;
  --read-scale:1;
  font-size:16px;
}

/* ---------- Palettes de couleurs ---------- */
:root[data-theme="green"]{
  --navy:#1b4332;--navy-deep:#0f291e;--navy-soft:#2d6a4f;
  --gold:#c9a227;--gold-soft:#e3c878;
}
:root[data-theme="bordeaux"]{
  --navy:#4a1422;--navy-deep:#2e0c15;--navy-soft:#6e1f33;
  --gold:#d4af37;--gold-soft:#e9cf80;
}
:root[data-theme="slate"]{
  --navy:#33404d;--navy-deep:#1f2933;--navy-soft:#4a5b6b;
  --gold:#b89b6a;--gold-soft:#d8c4a0;
}
:root[data-theme="graphite"]{
  --navy:#222226;--navy-deep:#0c0c0e;--navy-soft:#3d3d42;
  --gold:#bcc0c8;--gold-soft:#e2e4e8;
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html,body{width:100%;max-width:100%;margin:0;padding:0;overflow-x:hidden;}
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--cream);
  color:var(--ink);
  min-height:100vh;
  min-height:100dvh;
  min-width:0;
  overflow-x:hidden;
}
button,input,select,textarea{font:inherit;min-width:0;}
img,svg,canvas{max-width:100%;}

/* ---------- Header ---------- */
.app-header{
  position:sticky;top:0;z-index:30;
  width:100%;height:var(--header-h);
  display:flex;align-items:center;gap:10px;
  padding:0 14px;
  padding-left:max(14px,env(safe-area-inset-left));
  padding-right:max(14px,env(safe-area-inset-right));
  padding-top:env(safe-area-inset-top);
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy-deep) 100%);
  color:var(--cream);
  box-shadow:0 2px 14px rgba(10,31,51,.35);
}
.header-titles{flex:1;min-width:0;text-align:center;line-height:1;}
.brand{
  font-family:'Marcellus',serif;
  font-size:1.4rem;margin:0;letter-spacing:.5px;color:#fff;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.brand-sub{
  font-family:'Frank Ruhl Libre',serif;
  margin:2px 0 0;font-size:1rem;color:var(--gold-soft);
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.header-btn{
  width:40px;height:40px;flex:0 0 40px;
  border:0;border-radius:12px;cursor:pointer;
  background:rgba(255,255,255,.08);
  color:var(--cream);font-size:1.5rem;line-height:1;
  display:flex;align-items:center;justify-content:center;
  transition:background .15s;
}
.header-btn:active{background:rgba(255,255,255,.2);}
.header-btn[hidden]{visibility:hidden;}
.header-btn.settings svg{width:22px;height:22px;}
.header-home{
  width:40px;height:40px;flex:0 0 40px;border:0;padding:3px;cursor:pointer;
  background:transparent;display:flex;align-items:center;justify-content:center;
}
.header-logo{
  width:36px;height:36px;border-radius:50%;object-fit:cover;background:var(--cream);
  box-shadow:0 2px 6px rgba(0,0,0,.3),0 0 0 1.5px rgba(227,200,120,.5);
}
.header-home:active .header-logo{transform:scale(.92);}

/* ---------- View / Layout ---------- */
.view{
  width:100%;min-width:0;
  padding:18px 16px calc(var(--tab-h) + 28px);
  padding-left:max(16px,env(safe-area-inset-left));
  padding-right:max(16px,env(safe-area-inset-right));
  max-width:760px;margin:0 auto;
  animation:fade .25s ease;
}
@keyframes fade{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:none;}}

.section-label{
  font-family:'Marcellus',serif;
  font-size:.8rem;letter-spacing:2px;text-transform:uppercase;
  color:var(--gold);margin:6px 0 12px;
}

/* ---------- Home hero ---------- */
.hero{
  position:relative;border-radius:var(--radius);overflow:hidden;
  background:
    linear-gradient(160deg,rgba(10,31,51,.62) 0%,rgba(10,31,51,.78) 55%,rgba(10,31,51,.92) 100%),
    url("../img/synagogue.jpg") center 22%/cover no-repeat;
  color:var(--cream);padding:34px 24px 30px;text-align:center;
  box-shadow:var(--shadow);
}
.hero::after{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(circle at 80% -10%,rgba(201,162,39,.22),transparent 45%),
    radial-gradient(circle at 10% 120%,rgba(201,162,39,.12),transparent 40%);
  pointer-events:none;
}
.hero-logo{
  position:relative;z-index:1;
  width:108px;height:108px;border-radius:50%;
  object-fit:cover;background:radial-gradient(circle at 38% 30%,#fff,var(--cream) 70%);
  padding:6px;
  box-shadow:
    0 18px 30px rgba(10,31,51,.45),
    0 6px 12px rgba(10,31,51,.35),
    0 0 0 3px rgba(227,200,120,.55),
    inset 0 3px 6px rgba(255,255,255,.9),
    inset 0 -6px 12px rgba(10,31,51,.18);
  margin-bottom:10px;
  animation:logoFloat 4.5s ease-in-out infinite;
}
@keyframes logoFloat{
  0%,100%{transform:translateY(0) rotate(-.5deg);}
  50%{transform:translateY(-6px) rotate(.5deg);}
}
@media (prefers-reduced-motion:reduce){.hero-logo{animation:none;}}
.hero .star{
  position:relative;z-index:1;display:inline-block;
  max-width:100%;padding:5px 14px;border:1px solid rgba(227,200,120,.6);border-radius:999px;
  background:rgba(10,31,51,.48);color:var(--gold-soft);
  font-family:'Marcellus',serif;font-size:.82rem;line-height:1.2;letter-spacing:1px;
  text-transform:uppercase;overflow-wrap:anywhere;
}
.hero h2{font-family:'Frank Ruhl Libre',serif;font-size:2rem;margin:8px 0 2px;font-weight:700;}
.hero .latin{font-family:'Marcellus',serif;letter-spacing:1px;margin:0;opacity:.92;}
.hero .greeting{margin:14px 0 0;font-size:.95rem;color:var(--gold-soft);}
.hebrew-date{margin:4px 0 0;font-size:.85rem;opacity:.8;}

/* ---------- Quick tiles ---------- */
.grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:18px;min-width:0;}
.grid > *{min-width:0;max-width:100%;}
.tile{
  position:relative;border:0;cursor:pointer;text-align:right;
  background:var(--paper);border-radius:var(--radius);
  padding:18px 16px;box-shadow:var(--shadow);
  border:1px solid var(--line);
  transition:transform .12s ease, box-shadow .12s;
  display:flex;flex-direction:column;gap:4px;min-width:0;max-width:100%;min-height:104px;justify-content:flex-end;
}
.tile:active{transform:scale(.97);}
.tile .tile-ico{position:absolute;top:14px;left:16px;font-size:1.5rem;}
.tile .he{font-family:'Frank Ruhl Libre',serif;font-size:1.5rem;color:var(--navy);font-weight:700;line-height:1;overflow-wrap:anywhere;}
.tile .fr{font-size:.85rem;color:var(--ink-soft);overflow-wrap:anywhere;}
.tile.wide{grid-column:1 / -1;min-height:auto;flex-direction:row;align-items:center;justify-content:space-between;gap:12px;}
.tile.wide .he{font-size:1.3rem;}
.tile.wide .he,.tile.wide .fr{min-width:0;}
.tile.wide .fr{flex:1;text-align:end;}

/* ---------- List cards ---------- */
.card-list{display:flex;flex-direction:column;gap:10px;margin-top:6px;}
.row{
  position:relative;display:flex;align-items:center;gap:14px;cursor:pointer;
  background:var(--paper);border:1px solid var(--line);
  border-radius:14px;padding:14px 16px;box-shadow:0 2px 10px rgba(15,42,68,.06);
  transition:transform .12s, border-color .12s;
  text-align:left;width:100%;min-width:0;max-width:100%;
}
.row:active{transform:scale(.985);}
.row .row-badge{
  width:44px;height:44px;flex:0 0 44px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--navy),var(--navy-soft));
  color:var(--gold-soft);font-family:'Frank Ruhl Libre',serif;font-weight:700;font-size:1.1rem;
}
.row .row-main{flex:1;min-width:0;}
.row .row-he{font-family:'Frank Ruhl Libre',serif;font-size:1.25rem;color:var(--navy);font-weight:700;direction:rtl;text-align:right;}
.row .row-fr{font-size:.85rem;color:var(--ink-soft);margin-top:2px;}
.row .row-chev{color:var(--gold);font-size:1.4rem;}

/* Cadenas sur les tuiles/lignes non incluses dans la formule en cours */
.lock-badge{
  position:absolute;top:8px;right:8px;width:22px;height:22px;
  display:flex;align-items:center;justify-content:center;
  background:var(--cream);border:1px solid var(--gold);border-radius:8px;
  font-size:.8rem;line-height:1;z-index:1;
}
[dir="rtl"] .lock-badge{right:auto;left:8px;}
.toc-row{width:auto;margin-inline-start:calc(var(--toc-level) * 10px);}
.toc-row[data-level="0"]{border-color:rgba(201,162,39,.55);}
.toc-row .row-badge{font-family:Inter,sans-serif;font-size:.78rem;}
.toc-row .toc-title{display:block;color:var(--navy);font-weight:700;font-size:.95rem;line-height:1.35;}

.searchbar{
  display:flex;align-items:center;gap:8px;margin:2px 0 14px;
  background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:10px 14px;
}
.searchbar input{border:0;outline:0;background:transparent;flex:1;min-width:0;font-size:1rem;color:var(--ink);}
.searchbar .mag{color:var(--gold);}

/* ---------- Reader (prayer text) ---------- */
.reader-head{
  position:relative;
  background:linear-gradient(135deg,var(--navy),var(--navy-deep));
  color:var(--cream);border-radius:var(--radius);padding:18px 20px;margin-bottom:16px;box-shadow:var(--shadow);
}
.reader-head .he{font-family:'Frank Ruhl Libre',serif;font-size:1.7rem;font-weight:700;direction:rtl;text-align:right;}
.reader-head .fr{opacity:.85;margin-top:4px;font-size:.92rem;}
.reader-head .intro{margin-top:10px;font-size:.85rem;opacity:.8;line-height:1.5;border-top:1px solid rgba(255,255,255,.15);padding-top:10px;}

.passage{
  background:var(--paper);border:1px solid var(--line);border-radius:14px;
  padding:18px 18px;margin-bottom:14px;box-shadow:0 2px 10px rgba(15,42,68,.05);
}
.passage .p-title{
  font-family:'Marcellus',serif;color:var(--gold);font-size:.82rem;letter-spacing:1.5px;
  text-transform:uppercase;margin:0 0 10px;border-bottom:1px solid var(--line);padding-bottom:8px;
}
.passage .he{
  font-family:'Frank Ruhl Libre',serif;direction:rtl;text-align:right;
  font-size:calc(1.55rem * var(--read-scale));line-height:2.1;color:var(--ink);font-weight:500;
}
.passage .he.center{text-align:center;}
.passage .ph{
  font-style:italic;color:var(--navy-soft);margin-top:10px;
  font-size:calc(1rem * var(--read-scale));line-height:1.6;
}
.passage .tr{
  color:var(--ink-soft);margin-top:8px;font-size:calc(.98rem * var(--read-scale));line-height:1.6;
  border-top:1px dashed var(--line);padding-top:8px;
}
body.hide-ph .passage .ph{display:none;}
body.hide-fr .passage .tr{display:none;}
html:not([lang="fr"]) .translation-setting{display:none;}
html[lang="he"] .hero .latin,
html[lang="he"] .tile .fr,
html[lang="he"] .chip-fr,
html[lang="he"] .row-fr,
html[lang="he"] .passage .p-title,
html[lang="he"] .passage .ph,
html[lang="he"] .passage .tr,
html[lang="he"] .prof-fr,
html[lang="he"] .prof-hal-text{display:none;}

.note{
  text-align:center;color:var(--gold);font-family:'Marcellus',serif;
  font-size:.85rem;letter-spacing:1px;margin:18px 0;text-transform:uppercase;
}

/* ---------- Zmanim ---------- */
.loc-card{
  background:linear-gradient(135deg,var(--navy),var(--navy-soft));color:var(--cream);
  border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow);text-align:center;
}
.loc-card .city{font-family:'Marcellus',serif;font-size:1.2rem;}
.loc-card .date{opacity:.85;font-size:.85rem;margin-top:2px;}
.loc-actions{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-top:12px;}
.loc-actions .loc-btn{
  background:rgba(255,255,255,.15);color:var(--cream);border:0;border-radius:10px;
  padding:9px 16px;font-weight:600;cursor:pointer;font-size:.9rem;
}
.loc-actions .loc-btn.primary{background:var(--gold);color:var(--navy-deep);}
.zman-list{margin-top:14px;display:flex;flex-direction:column;gap:8px;}
.zman{
  display:flex;align-items:center;justify-content:space-between;
  background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:13px 16px;
}
.zman .z-name{display:flex;flex-direction:column;}
.zman .z-fr{font-weight:600;color:var(--navy);}
.zman .z-he{font-family:'Frank Ruhl Libre',serif;color:var(--ink-soft);font-size:.95rem;direction:rtl;}
.zman .z-time{font-family:'Marcellus',serif;font-size:1.25rem;color:var(--gold);}
.zman.hl{border-color:var(--gold);box-shadow:0 0 0 2px rgba(201,162,39,.25);}
.zman-datebar{display:flex;align-items:center;gap:8px;margin-top:14px;}
.zd-nav{width:38px;height:46px;flex:0 0 38px;border:1px solid var(--line);background:var(--paper);
  border-radius:10px;cursor:pointer;font-size:1.25rem;line-height:1;color:var(--navy);}
.zd-label{flex:1;text-align:center;font-weight:600;color:var(--navy);font-size:.92rem;line-height:1.35;}
.zd-heb{font-size:.78rem;font-weight:400;color:var(--ink-soft);}
.zd-today{border:1px solid var(--gold);background:var(--paper);border-radius:10px;padding:8px 10px;
  font-size:.78rem;cursor:pointer;color:var(--navy);font-family:inherit;font-weight:600;}
.share-btn{display:block;width:100%;margin-top:12px;border:1px solid var(--line);background:var(--paper);
  color:var(--navy);border-radius:12px;padding:11px;font-weight:600;font-size:.9rem;cursor:pointer;font-family:inherit;}

/* ---------- Prochain horaire (accueil) ---------- */
.next-zman{display:flex;align-items:center;gap:12px;width:100%;text-align:start;cursor:pointer;
  background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:14px 16px;
  margin-top:12px;box-shadow:0 2px 10px rgba(15,42,68,.05);font-family:inherit;}
.nz-ico{font-size:1.5rem;line-height:1;}
.nz-text{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0;}
.nz-lbl{font-size:.68rem;text-transform:uppercase;letter-spacing:1px;color:var(--ink-soft);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.nz-name{font-family:'Frank Ruhl Libre',serif;font-weight:700;color:var(--navy);font-size:1rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.nz-in{flex:0 0 auto;font-size:1.3rem;font-weight:800;color:var(--gold);white-space:nowrap;
  font-variant-numeric:tabular-nums;letter-spacing:.2px;line-height:1.05;text-align:right;}

/* ---------- Widget Chabbat (accueil) ---------- */
.shabbat-card{
  display:block;width:100%;border:0;cursor:pointer;text-align:center;font-family:inherit;
  background:linear-gradient(135deg,var(--navy),var(--navy-soft) 60%,var(--navy-deep));
  color:var(--cream);border-radius:var(--radius);padding:16px 18px;margin-top:14px;
  box-shadow:var(--shadow);
}
.sh-title{font-family:'Marcellus',serif;font-size:1.05rem;letter-spacing:.5px;}
.sh-times{display:flex;align-items:center;justify-content:center;gap:14px;margin-top:10px;}
.sh-time{display:flex;flex-direction:column;align-items:center;gap:2px;}
.sh-lbl{font-size:.7rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold-soft);}
.sh-val{font-family:'Marcellus',serif;font-size:1.4rem;color:var(--gold);}
.sh-d{font-size:.72rem;opacity:.75;text-transform:capitalize;}
.sh-sep{width:1px;height:34px;background:rgba(255,255,255,.18);}

/* ---------- Compteur du Omer (accueil) ---------- */
.omer-card{
  margin-top:10px;background:var(--paper);border:1px solid var(--line);border-radius:14px;
  padding:12px 16px;display:flex;flex-direction:column;gap:4px;box-shadow:0 2px 10px rgba(15,42,68,.05);
}
.omer-day{font-weight:600;color:var(--navy);}
.omer-week{font-weight:400;color:var(--ink-soft);font-size:.85rem;}
.omer-sefira{font-size:.85rem;color:var(--ink-soft);}
.omer-sefira .he{font-family:'Frank Ruhl Libre',serif;color:var(--navy);direction:rtl;font-size:1rem;}

/* ---------- Favoris ---------- */
.fav-btn{
  position:absolute;top:14px;left:16px;width:36px;height:36px;border:0;border-radius:10px;
  background:rgba(255,255,255,.1);color:var(--gold-soft);font-size:1.3rem;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s;
}
.fav-btn.active{color:var(--gold);background:rgba(255,255,255,.18);}
.fav-btn:active{transform:scale(.9);}

/* ---------- Settings sheet ---------- */
.sheet-backdrop{position:fixed;inset:0;background:rgba(10,31,51,.45);z-index:40;animation:fade .2s;}
.settings-sheet{
  position:fixed;left:0;right:0;bottom:0;z-index:50;
  background:var(--paper);border-radius:22px 22px 0 0;
  padding:10px 22px calc(24px + env(safe-area-inset-bottom));
  box-shadow:0 -8px 30px rgba(10,31,51,.3);
  width:100%;max-width:760px;max-height:92vh;max-height:92dvh;margin:0 auto;overflow-y:auto;
  animation:slideUp .25s ease;
}
@keyframes slideUp{from{transform:translateY(100%);}to{transform:none;}}
.sheet-handle{width:44px;height:5px;border-radius:3px;background:var(--line);margin:6px auto 14px;}
.sheet-title{font-family:'Marcellus',serif;color:var(--navy);margin:0 0 16px;font-size:1.3rem;}
.setting-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 0;border-bottom:1px solid var(--line);}
.setting-row label{color:var(--ink);font-weight:500;}
.seg{display:flex;background:var(--cream);border:1px solid var(--line);border-radius:10px;overflow:hidden;}
.seg button{
  border:0;background:transparent;padding:8px 14px;cursor:pointer;color:var(--ink-soft);font-weight:600;
  transition:background .15s,color .15s;
}
.seg button:not(:last-child){border-right:1px solid var(--line);}
.seg button.active{background:var(--navy);color:var(--gold-soft);}
#fontSizeSeg button[data-size="sm"]{font-size:.85rem;}
#fontSizeSeg button[data-size="md"]{font-size:1rem;}
#fontSizeSeg button[data-size="lg"]{font-size:1.2rem;}
#fontSizeSeg button[data-size="xl"]{font-size:1.45rem;}

.theme-swatches{display:flex;gap:10px;}
.theme-swatch{
  width:30px;height:30px;border-radius:50%;border:2px solid transparent;
  cursor:pointer;padding:0;background:var(--sw);
  background:linear-gradient(135deg,var(--sw-navy) 0%,var(--sw-gold) 100%);
  transition:border-color .15s,transform .15s;
}
.theme-swatch.active{border-color:var(--ink);transform:scale(1.12);}
.theme-swatch[data-theme="navy"]{--sw-navy:#0f2a44;--sw-gold:#c9a227;}
.theme-swatch[data-theme="green"]{--sw-navy:#1b4332;--sw-gold:#c9a227;}
.theme-swatch[data-theme="bordeaux"]{--sw-navy:#4a1422;--sw-gold:#d4af37;}
.theme-swatch[data-theme="slate"]{--sw-navy:#33404d;--sw-gold:#b89b6a;}
.theme-swatch[data-theme="graphite"]{--sw-navy:#222226;--sw-gold:#bcc0c8;}

.switch{appearance:none;width:48px;height:28px;border-radius:20px;background:var(--line);position:relative;cursor:pointer;transition:background .2s;}
.switch::after{content:"";position:absolute;top:3px;left:3px;width:22px;height:22px;border-radius:50%;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.25);transition:transform .2s;}
.switch:checked{background:var(--gold);}
.switch:checked::after{transform:translateX(20px);}
.sheet-foot{text-align:center;color:var(--ink-soft);font-size:.8rem;margin:18px 0 0;line-height:1.5;}

/* ---------- Rappels de prière (réglages) ---------- */
.setting-group{border-top:1px solid var(--line);margin-top:14px;padding-top:6px;}
.notif-offices{margin:4px 0 6px;padding:8px 12px;background:var(--cream);border-radius:12px;border:1px solid var(--line);}
.notif-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;}
.notif-row + .notif-row{border-top:1px solid var(--line);}
.notif-row label{font-size:.95rem;color:var(--ink);}
.notif-hint{font-size:.78rem;color:var(--ink-soft);margin:6px 2px 0;line-height:1.4;}

/* Boutons d'action génériques (boussole, miroir) hors .loc-actions */
.compass-wrap .loc-btn,.mirror-actions .loc-btn,.compass-empty .loc-btn{
  background:var(--navy);color:var(--cream);border:0;border-radius:12px;
  padding:12px 22px;font-weight:600;cursor:pointer;font-size:.95rem;
  box-shadow:0 2px 10px rgba(15,42,68,.18);transition:transform .12s,filter .12s;
}
.compass-wrap .loc-btn:active,.mirror-actions .loc-btn:active{transform:scale(.97);}
.compass-wrap .loc-btn.primary,.mirror-actions .loc-btn.primary,.compass-empty .loc-btn.primary{
  background:var(--gold);color:var(--navy-deep);
}

/* Polish : tuiles larges (accès rapides) plus lisibles */
.tile.wide{
  background:linear-gradient(120deg,var(--paper) 0%,var(--cream) 100%);
}
.tile.wide .he{display:flex;align-items:center;gap:8px;}

/* ---------- Boussole (Mizrah) ---------- */
.compass-head{margin-bottom:8px;}
.compass-wrap{display:flex;flex-direction:column;align-items:center;gap:14px;padding:8px 0 4px;}
.compass-dial{
  position:relative;width:min(78vw,300px);aspect-ratio:1;border-radius:50%;
  overflow:hidden;
  background:radial-gradient(circle at 50% 38%,var(--navy-soft),var(--navy-deep));
  box-shadow:var(--shadow),inset 0 0 0 2px rgba(227,200,120,.35);
  display:flex;align-items:center;justify-content:center;
}
.compass-rose{position:absolute;inset:0;transition:transform .12s linear;}
.compass-rose span{
  position:absolute;left:50%;transform:translateX(-50%);
  font-family:'Marcellus',serif;font-size:1rem;color:var(--gold-soft);font-weight:700;
}
.compass-rose .rose-n{top:10px;color:#fff;}
.compass-rose .rose-s{bottom:10px;}
.compass-rose .rose-e{top:50%;right:12px;left:auto;transform:translateY(-50%);}
.compass-rose .rose-w{top:50%;left:12px;transform:translateY(-50%);}
.compass-ticks{position:absolute;inset:14px;border-radius:50%;
  background:repeating-conic-gradient(rgba(227,200,120,.45) 0deg 1deg,transparent 1deg 30deg);
  -webkit-mask:radial-gradient(circle,transparent 0 46%,#000 46% 50%,transparent 50%);
          mask:radial-gradient(circle,transparent 0 46%,#000 46% 50%,transparent 50%);}
.compass-needle{position:absolute;inset:0;display:flex;align-items:flex-start;justify-content:center;transition:transform .12s linear;}
.needle-arrow{
  width:0;height:0;margin-top:30px;
  border-left:10px solid transparent;border-right:10px solid transparent;
  border-bottom:108px solid var(--gold);
  filter:drop-shadow(0 2px 4px rgba(0,0,0,.4));
}
.needle-star{position:absolute;top:6px;left:50%;transform:translateX(-50%);color:#fff;font-size:1.5rem;text-shadow:0 1px 4px rgba(0,0,0,.5);}
.compass-center{width:16px;height:16px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 4px var(--navy-deep);z-index:2;}
.compass-readout{text-align:center;}
.compass-deg{font-family:'Marcellus',serif;font-size:2.4rem;color:var(--navy);line-height:1;}
.compass-sub{font-size:.9rem;color:var(--ink);margin-top:4px;}
.compass-dist{font-size:.82rem;color:var(--ink-soft);margin-top:2px;}
.compass-status{font-size:.82rem;color:var(--ink-soft);text-align:center;margin:0;max-width:280px;}
.compass-status.live{color:var(--navy);font-weight:600;}
.compass-empty{text-align:center;padding:40px 16px;color:var(--ink-soft);}
.compass-empty .big{font-size:3rem;margin-bottom:10px;}

/* ---------- Miroir Téfilline ---------- */
.mirror-wrap{display:flex;flex-direction:column;align-items:center;gap:14px;}
.mirror-stage{
  position:relative;width:100%;max-width:420px;aspect-ratio:3/4;
  border-radius:var(--radius);overflow:hidden;background:var(--navy-deep);
  box-shadow:var(--shadow);
}
.mirror-video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1);display:block;}
.mirror-guide{position:absolute;inset:0;pointer-events:none;opacity:0;transition:opacity .3s;}
.mirror-stage.live .mirror-guide{opacity:1;}
.guide-line{position:absolute;left:12%;right:12%;height:2px;background:rgba(227,200,120,.7);}
.guide-eyes{top:42%;}
.guide-dot{position:absolute;top:26%;left:50%;width:30px;height:30px;border:2px solid var(--gold-soft);border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 0 0 9999px rgba(10,31,51,.04);}
.guide-label{position:absolute;font-size:.72rem;color:var(--gold-soft);background:rgba(10,31,51,.55);padding:2px 7px;border-radius:8px;}
.guide-label-head{top:18%;left:50%;transform:translateX(-50%);}
.mirror-placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--cream);text-align:center;padding:24px;}
.mirror-placeholder .big{font-size:3rem;}
.mirror-tip{font-size:.85rem;color:var(--ink-soft);text-align:center;line-height:1.5;max-width:380px;margin:0;}
.mirror-actions{display:flex;gap:10px;}
.mirror-status{font-size:.82rem;color:#b3261e;text-align:center;margin:0;min-height:1em;}

/* ---------- Synagogues à proximité ---------- */
.syn-map{width:100%;height:300px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);background:#dfe6e9;}
.syn-map .leaflet-container{font-family:inherit;}
.syn-status{text-align:center;font-size:.85rem;color:var(--ink-soft);margin:12px 0;}
.syn-list{display:flex;flex-direction:column;gap:10px;}
.syn-item{
  display:flex;align-items:center;gap:12px;cursor:pointer;
  background:var(--paper);border:1px solid var(--line);border-radius:14px;
  padding:12px 14px;box-shadow:0 2px 10px rgba(15,42,68,.06);transition:transform .12s;
}
.syn-item:active{transform:scale(.99);}
.syn-pin{font-size:1.5rem;flex:0 0 auto;}
.syn-main{flex:1;min-width:0;}
.syn-name{font-weight:600;color:var(--navy);font-size:.98rem;}
.syn-sub{font-size:.82rem;color:var(--ink-soft);margin-top:2px;}
.syn-go{
  flex:0 0 auto;text-decoration:none;background:var(--gold);color:var(--navy-deep);
  font-weight:600;font-size:.82rem;padding:8px 14px;border-radius:20px;white-space:nowrap;
}
.syn-empty{text-align:center;padding:40px 16px;color:var(--ink-soft);}
.syn-empty .big{font-size:3rem;margin-bottom:10px;}
.syn-empty .loc-btn{background:var(--navy);color:var(--cream);border:0;border-radius:12px;padding:12px 22px;font-weight:600;cursor:pointer;margin-top:8px;}
.syn-empty .loc-btn.primary{background:var(--gold);color:var(--navy-deep);}

/* ---------- Carte Luach (notes de prière du jour) ---------- */
.luach-card{
  margin-top:14px;background:var(--paper);border:1px solid var(--line);
  border-radius:16px;padding:14px 16px;box-shadow:0 2px 10px rgba(15,42,68,.06);
}
.luach-card.is-rc{border-color:var(--gold);box-shadow:0 0 0 1px var(--gold),0 6px 18px rgba(201,162,39,.22);}
.luach-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px;}
.luach-title{font-family:'Marcellus',serif;font-size:.92rem;color:var(--navy);letter-spacing:.3px;}
.luach-rc{
  font-weight:700;font-size:.82rem;padding:5px 12px;border-radius:20px;white-space:nowrap;
  background:var(--gold);color:var(--navy-deep);
}
.luach-rc.on{animation:rcGlow 1.6s ease-in-out infinite;}
@keyframes rcGlow{
  0%,100%{box-shadow:0 0 0 0 rgba(201,162,39,.55);filter:brightness(1);}
  50%{box-shadow:0 0 14px 4px rgba(201,162,39,.85);filter:brightness(1.12);}
}
@media (prefers-reduced-motion:reduce){.luach-rc.on{animation:none;}}
.luach-notes{display:flex;flex-wrap:wrap;gap:8px;}
.luach-note{
  font-size:.82rem;font-weight:600;padding:6px 11px;border-radius:10px;
  background:var(--cream);color:var(--ink);border:1px solid var(--line);
}
.luach-note.add{background:rgba(27,67,50,.1);color:#1b4332;border-color:rgba(27,67,50,.25);}
.luach-note.skip{background:rgba(74,20,34,.08);color:#6e1f33;border-color:rgba(110,31,51,.22);}
.luach-disc{font-size:.72rem;color:var(--ink-soft);margin:10px 0 0;line-height:1.4;}

/* ---------- Carte commande WhatsApp ---------- */
.order-card{
  display:flex;align-items:center;gap:12px;margin-top:14px;text-decoration:none;
  background:linear-gradient(135deg,#0b8a4f,#0d9f5b);color:#fff;
  border-radius:16px;padding:14px 16px;box-shadow:0 6px 18px rgba(11,138,79,.32);
  transition:transform .12s;
}
.order-card:active{transform:scale(.985);}
.order-ico{font-size:1.7rem;flex:0 0 auto;width:46px;height:46px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.18);border-radius:12px;}
.order-main{flex:1;min-width:0;display:flex;flex-direction:column;}
.order-main strong{font-family:'Marcellus',serif;font-size:1.05rem;font-weight:400;}
.order-main span{font-size:.8rem;opacity:.9;}
.order-wa{flex:0 0 auto;background:rgba(255,255,255,.2);border-radius:20px;padding:8px 13px;font-weight:700;font-size:.82rem;white-space:nowrap;}

/* ---------- Salon d'accueil : puces d'accès rapide ---------- */
.offices-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;}
.offices-grid .tile{min-height:96px;padding:14px 12px;}
.offices-grid .tile .he{font-size:1.2rem;}
.offices-grid .tile .tile-ico{font-size:1.2rem;top:10px;left:12px;}
.chip-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;min-width:0;}
.chip-grid > *{min-width:0;max-width:100%;}
.chip{
  position:relative;display:flex;align-items:center;gap:10px;cursor:pointer;text-align:left;
  background:var(--paper);border:1px solid var(--line);border-radius:14px;
  min-width:0;max-width:100%;overflow:hidden;
  padding:12px 14px;box-shadow:0 2px 10px rgba(15,42,68,.06);transition:transform .12s,box-shadow .12s;
}
.chip:active{transform:scale(.98);}
.chip-ico{font-size:1.35rem;flex:0 0 auto;width:34px;height:34px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--navy),var(--navy-soft));border-radius:10px;}
.chip-he{font-family:'Frank Ruhl Libre',serif;font-weight:700;color:var(--navy);font-size:1.02rem;direction:rtl;}
.chip-fr{display:block;font-size:.72rem;color:var(--ink-soft);}
.chip > span:not(.chip-ico){display:flex;flex-direction:column;min-width:0;}
.chip .chip-he,.chip .chip-fr{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;}

/* ---------- Sélecteur de mode Tehilim ---------- */
.tehilim-seg{width:100%;margin-bottom:12px;}
.tehilim-seg button{flex:1;}

/* ---------- Accordéon Tehilim par jour ---------- */
.accordion{display:flex;flex-direction:column;gap:10px;}
.acc-item{background:var(--paper);border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:0 2px 10px rgba(15,42,68,.06);}
.acc-head{
  width:100%;display:flex;align-items:center;gap:10px;cursor:pointer;border:0;background:transparent;
  padding:14px 16px;text-align:left;color:var(--navy);
}
.acc-title{flex:1;font-family:'Marcellus',serif;font-size:1rem;display:flex;align-items:center;gap:8px;}
.acc-today{font-family:'Inter',sans-serif;font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;
  background:var(--gold);color:var(--navy-deep);padding:2px 7px;border-radius:10px;}
.acc-range{font-family:'Frank Ruhl Libre',serif;color:var(--ink-soft);font-size:.95rem;direction:rtl;}
.acc-chev{font-size:1.1rem;color:var(--gold);transition:transform .2s;}
.acc-item.open .acc-chev{transform:rotate(180deg);}
.acc-body{display:none;padding:0 14px 14px;}
.acc-item.open .acc-body{display:block;animation:fade .2s ease;}
.acc-body .grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:4px;}
.psalm-tile{min-height:auto !important;align-items:center;text-align:center;padding:12px 8px;justify-content:center;}
.psalm-tile .he{font-size:1.25rem;}
.psalm-tile .fr{font-size:.68rem;}

/* ---------- Tabbar flottante arrondie ---------- */
.tabbar{
  position:fixed;left:12px;right:12px;z-index:35;
  bottom:calc(env(safe-area-inset-bottom) + 10px);
  height:var(--tab-h);
  display:flex;align-items:stretch;
  background:rgba(251,248,241,.86);
  -webkit-backdrop-filter:saturate(180%) blur(18px);
          backdrop-filter:saturate(180%) blur(18px);
  border:1px solid rgba(255,255,255,.5);
  border-radius:30px;
  box-shadow:0 10px 30px rgba(15,42,68,.22),0 2px 6px rgba(15,42,68,.12);
  max-width:520px;margin:0 auto;
  padding:6px;
}
.tab{
  flex:1;min-width:0;border:0;background:transparent;cursor:pointer;position:relative;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
  color:var(--ink-soft);font-size:.62rem;font-weight:600;transition:color .18s,transform .18s;
  border-radius:24px;white-space:nowrap;letter-spacing:-.1px;
}
.tab > span:last-child{display:block;max-width:100%;overflow:hidden;text-overflow:ellipsis;}
.tab .tab-ico{display:flex;align-items:center;justify-content:center;transition:transform .18s;}
.tab .tab-ico svg{width:24px;height:24px;display:block;}
.tab .he{font-family:'Frank Ruhl Libre',serif;font-size:.85rem;}
.tab.active{color:var(--navy);background:rgba(15,42,68,.10);}
.tab.active .tab-ico{transform:translateY(-1px);}
.tab.active .tab-ico svg{stroke:var(--navy);}
/* la vue laisse de la place à la barre flottante */
.view{padding-bottom:calc(var(--tab-h) + 42px);}

.empty{text-align:center;color:var(--ink-soft);padding:40px 20px;}
.empty .big{font-size:2.5rem;}

/* ---------- Lecteur PDF ---------- */
.pdf-actions{display:flex;gap:10px;margin-bottom:12px;}
.pdf-btn{flex:1;text-align:center;text-decoration:none;background:var(--navy);color:var(--gold-soft);
  padding:11px;border-radius:12px;font-weight:600;font-size:.9rem;
  border:0;cursor:pointer;font-family:inherit;}
.pdf-btn.ghost{background:var(--paper);color:var(--navy);border:1px solid var(--line);}
.pdf-frame{position:relative;border-radius:14px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);background:#fff;-webkit-touch-callout:none;user-select:none;}
.pdf-pages{position:relative;height:78vh;overflow-y:auto;-webkit-overflow-scrolling:touch;background:#494c4e;}
.pdf-page{position:relative;width:100%;background:#fff;margin-bottom:6px;}
.pdf-page canvas{position:absolute;inset:0;width:100%;height:100%;display:block;-webkit-touch-callout:none;user-select:none;pointer-events:none;}
.pdf-loading{display:flex;align-items:center;justify-content:center;height:78vh;padding:24px;text-align:center;color:var(--navy);font-size:.95rem;}
.pdf-privacy-shield{position:absolute;inset:0;z-index:5;display:none;align-items:center;justify-content:center;flex-direction:column;gap:8px;padding:24px;text-align:center;background:var(--navy);color:var(--gold-soft);}
.pdf-privacy-shield strong{font-family:'Frank Ruhl Libre',serif;font-size:1.5rem;}
.pdf-privacy-shield span{max-width:360px;font-size:.9rem;line-height:1.5;opacity:.9;}
body.pdf-protected.privacy-hidden .pdf-frame .pdf-doc{visibility:hidden;}
body.pdf-protected.privacy-hidden .pdf-privacy-shield{display:flex;}
.pdf-frame:fullscreen{border-radius:0;border:0;}
.pdf-frame:fullscreen .pdf-pages,.pdf-frame:fullscreen .pdf-loading{height:100vh;}
.pdf-frame:fullscreen .pdf-doc{height:100vh;overflow-y:auto;-webkit-overflow-scrolling:touch;}
/* Un Tehilim = une feuille continue, composée des bandes exactes du livre. */
.psalm-nav{
  position:sticky;top:calc(var(--header-h) + 6px);z-index:20;
  display:flex;align-items:center;justify-content:center;gap:12px;
  max-width:600px;margin:0 auto 10px;padding:4px 0;
  background:rgba(255,255,255,.96);
}
.psalm-nav-btn{
  width:44px;height:40px;border:1px solid var(--line);border-radius:12px;
  background:var(--paper);color:var(--navy);font-size:1.8rem;line-height:1;
  cursor:pointer;font-family:inherit;
}
.psalm-nav-btn.expand{font-size:1.2rem;}
.psalm-nav-spacer{width:44px;height:40px;}
.psalm-nav .fav-btn{
  position:static;width:44px;height:40px;border:1px solid var(--line);
  background:var(--paper);color:var(--gold);font-size:1.35rem;
}
.psalm-nav .fav-btn.active{background:var(--navy);color:var(--gold-soft);}
.psalm-frame{max-width:600px;margin:0 auto;background:#fff;}
.psalm-doc{background:#fff;}
body.psalm-reading{background:#fff;}
body.psalm-reading .tabbar{display:none;}
body.psalm-reading .view{padding-bottom:24px;}
.tehilim-book-pages{display:block;padding:0;background:#fff;}
.tehilim-book-page{display:block;margin:0;overflow:hidden;background:#fff;line-height:0;}
.tehilim-book-page img{
  display:block;width:100%;height:auto;margin:-1px 0 0;background:#fff;
  -webkit-touch-callout:none;user-select:none;pointer-events:none;
}
.tehilim-book-page img:first-child{margin-top:0;}
.psalm-bottom-nav{display:flex;gap:10px;max-width:600px;margin:14px auto 0;}

/* ---------- Téléphone : la lecture occupe toute la largeur de l'écran ---------- */
@media (max-width:640px){
  .reader-head{margin-left:-16px;margin-right:-16px;border-radius:0;}
  .passage{margin-left:-16px;margin-right:-16px;border-radius:0;border-left:0;border-right:0;padding:16px 12px;}
  .pdf-frame{margin-left:-16px;margin-right:-16px;border-radius:0;border-left:0;border-right:0;}
  .psalm-nav{margin-top:-8px;}
  .psalm-frame{margin-left:-16px;margin-right:-16px;}
  .psalm-bottom-nav{margin-left:-8px;margin-right:-8px;}
}
@media print{
  body.pdf-protected .pdf-frame,
  body.pdf-protected .pdf-actions{display:none!important;}
}

/* ---------- Haskamot (pages protégées : canvas, pas d'image enregistrable) ---------- */
.haskamot-list{display:flex;flex-direction:column;gap:14px;
  -webkit-user-select:none;user-select:none;-webkit-touch-callout:none;}
.haskama-page{background:#fff;border-radius:14px;overflow:hidden;
  border:1px solid var(--line);box-shadow:var(--shadow);
  min-height:120px;opacity:0;transition:opacity .25s;}
.haskama-page.loaded{opacity:1;}
.haskama-page canvas{display:block;width:100%;height:auto;pointer-events:none;}

/* ---------- Paracha de la semaine ---------- */
.parasha-card{display:flex;align-items:center;gap:10px;background:var(--paper);
  border:1px solid var(--line);border-radius:12px;padding:10px 14px;margin-top:12px;
  box-shadow:0 2px 10px rgba(15,42,68,.05);}
.par-ico{font-size:1.3rem;line-height:1;}
.par-text{display:flex;flex-direction:column;gap:1px;}
.par-lbl{font-size:.68rem;text-transform:uppercase;letter-spacing:1px;color:var(--ink-soft);}
.par-name{font-family:'Frank Ruhl Libre',serif;font-weight:700;color:var(--navy);font-size:1rem;}

/* ---------- Calendrier ---------- */
.cal-head{display:flex;align-items:center;justify-content:space-between;gap:10px;
  background:linear-gradient(135deg,var(--navy),var(--navy-soft));color:var(--cream);
  border-radius:var(--radius);padding:14px 14px;box-shadow:var(--shadow);}
.cal-nav{width:40px;height:40px;flex:0 0 40px;border:0;border-radius:11px;cursor:pointer;
  background:rgba(255,255,255,.1);color:var(--cream);font-size:1.4rem;line-height:1;}
.cal-title{text-align:center;line-height:1.25;flex:1;}
.cal-greg{font-family:'Marcellus',serif;font-size:1.15rem;text-transform:capitalize;}
.cal-hebr{font-family:'Frank Ruhl Libre',serif;color:var(--gold-soft);font-size:1rem;}
.cal-today{display:block;margin:10px auto 0;background:var(--gold);color:var(--navy-deep);border:0;
  border-radius:9px;padding:7px 16px;font-weight:600;font-size:.85rem;cursor:pointer;}
.cal-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:4px;margin-top:12px;}
.cal-wd{text-align:center;font-size:.68rem;font-weight:700;color:var(--ink-soft);padding:4px 0;text-transform:uppercase;}
.cal-wd.sat{color:var(--gold);}
.cal-cell{min-width:0;min-height:52px;border:1px solid var(--line);border-radius:10px;background:var(--paper);
  padding:4px 2px;display:flex;flex-direction:column;align-items:center;gap:1px;cursor:pointer;position:relative;}
.cal-cell.empty{background:transparent;border:0;cursor:default;}
.cal-cell .g{font-weight:700;color:var(--ink);font-size:.95rem;line-height:1;}
.cal-cell .h{font-family:'Frank Ruhl Libre',serif;color:var(--ink-soft);font-size:.78rem;line-height:1;}
.cal-cell.sat{background:#efe9d9;}
.cal-cell.today{border-color:var(--gold);box-shadow:0 0 0 2px rgba(201,162,39,.4);}
.cal-cell.sel{background:var(--navy);border-color:var(--navy);}
.cal-cell.sel .g,.cal-cell.sel .h{color:var(--cream);}
.cal-dots{display:flex;gap:2px;margin-top:1px;height:6px;}
.cal-dot{width:5px;height:5px;border-radius:50%;}
.cal-dot.hol{background:var(--gold);}
.cal-dot.rc{background:#3b7dd8;}
.cal-dot.par{background:#4a9d5b;}
.cal-dot.fast{background:#9a9a9a;}
.cal-detail{margin-top:14px;background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:14px 16px;box-shadow:0 2px 10px rgba(15,42,68,.05);}
.cal-detail h3{margin:0 0 2px;font-family:'Marcellus',serif;color:var(--navy);font-size:1.05rem;text-transform:capitalize;}
.cal-detail .he-date{font-family:'Frank Ruhl Libre',serif;color:var(--gold);direction:rtl;margin-bottom:8px;}
.ev{display:flex;gap:10px;align-items:flex-start;padding:9px 0;border-bottom:1px solid var(--line);}
.ev:last-child{border-bottom:0;}
.ev-ico{font-size:1.1rem;line-height:1.3;}
.ev-main{flex:1;min-width:0;}
.ev-t{font-weight:600;color:var(--navy);}
.ev-d{font-size:.76rem;color:var(--ink-soft);text-transform:capitalize;}
.ev-h{font-family:'Frank Ruhl Libre',serif;color:var(--ink-soft);direction:rtl;font-size:.95rem;}
.cal-legend{display:flex;flex-wrap:wrap;gap:12px;margin:12px 2px 0;font-size:.72rem;color:var(--ink-soft);}
.cal-legend span{display:inline-flex;align-items:center;gap:5px;}
.cal-note{text-align:center;color:var(--ink-soft);font-size:.78rem;margin:12px 0 0;}
.cal-modes{display:flex;gap:6px;margin:12px auto 0;max-width:260px;background:var(--cream);border:1px solid var(--line);border-radius:11px;padding:3px;}
.cal-modes button{flex:1;border:0;background:transparent;padding:8px;border-radius:9px;font-weight:600;color:var(--ink-soft);cursor:pointer;}
.cal-modes button.active{background:var(--navy);color:var(--gold-soft);}
.cal-yearjump{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:10px;font-size:.85rem;color:var(--ink-soft);}
.cal-yearjump input{width:96px;padding:8px 10px;border:1px solid var(--line);border-radius:9px;background:var(--paper);font-size:1rem;color:var(--ink);text-align:center;}
.cal-filters{display:flex;gap:8px;margin:14px 0 4px;flex-wrap:wrap;}
.cal-filters button{border:1px solid var(--line);background:var(--paper);color:var(--ink-soft);border-radius:20px;padding:7px 14px;font-weight:600;font-size:.82rem;cursor:pointer;}
.cal-filters button.active{background:var(--navy);color:var(--gold-soft);border-color:var(--navy);}

@media(min-width:560px){
  .grid{grid-template-columns:repeat(3,minmax(0,1fr));}
}

/* ---------- Comptes, essai gratuit & Premium ---------- */
.auth-gate{
  position:fixed;inset:0;z-index:100;overflow-y:auto;
  background:linear-gradient(160deg,var(--navy) 0%,var(--navy-soft) 55%,var(--navy-deep) 100%);
  display:flex;align-items:flex-start;justify-content:center;
  padding:28px 18px calc(28px + env(safe-area-inset-bottom));
}
.auth-card{
  width:100%;max-width:420px;margin:auto;background:var(--paper);
  border-radius:var(--radius);box-shadow:0 18px 50px rgba(0,0,0,.35);
  padding:26px 24px;position:relative;animation:fade .25s ease;
}
.auth-brand{text-align:center;margin-bottom:16px;}
.auth-star{font-size:1.7rem;color:var(--gold);}
.auth-brand h2{font-family:'Marcellus',serif;color:var(--navy);margin:6px 0 0;font-size:1.45rem;}
.auth-he{font-family:'Frank Ruhl Libre',serif;color:var(--gold);margin:2px 0 0;}
.auth-tagline{color:var(--ink-soft);font-size:.85rem;margin:8px 0 0;}
.auth-tabs{display:flex;background:var(--cream);border:1px solid var(--line);border-radius:11px;padding:3px;margin-bottom:14px;}
.auth-tabs button{flex:1;border:0;background:transparent;padding:9px;border-radius:8px;font-weight:600;color:var(--ink-soft);cursor:pointer;font-family:inherit;font-size:.9rem;}
.auth-tabs button.active{background:var(--navy);color:var(--gold-soft);}
.auth-offer{text-align:center;color:var(--gold);font-weight:700;font-size:.85rem;margin:0 0 12px;}
.auth-card form{display:flex;flex-direction:column;gap:10px;}
.auth-card input{border:1px solid var(--line);background:#fff;border-radius:11px;padding:12px 14px;font-size:1rem;color:var(--ink);font-family:inherit;outline:none;}
.auth-card input:focus{border-color:var(--gold);}
.auth-submit{
  border:0;border-radius:12px;background:linear-gradient(135deg,var(--gold),#b8901f);
  color:var(--navy-deep);font-weight:700;font-size:1rem;padding:13px;cursor:pointer;
  font-family:inherit;margin-top:4px;
}
.auth-submit:disabled{opacity:.6;cursor:default;}
.auth-link{display:block;margin:14px auto 0;border:0;background:none;color:var(--navy-soft);text-decoration:underline;cursor:pointer;font-size:.85rem;font-family:inherit;}
.auth-error{margin:0;font-size:.85rem;color:#b03030;text-align:center;line-height:1.45;}
.auth-error.ok{color:#2e7d44;}
.auth-notice{margin:0;font-size:.85rem;color:var(--ink-soft);text-align:center;}
.auth-msg{color:var(--ink);text-align:center;line-height:1.55;}

/* Paywall (3 formules) */
.paywall-close{
  position:absolute;top:12px;right:12px;width:32px;height:32px;border:0;border-radius:10px;
  background:var(--cream);color:var(--ink-soft);font-size:1rem;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
}
.auth-card.paywall .auth-submit{width:100%;}
.paywall-note{text-align:center;color:var(--ink-soft);font-size:.78rem;margin:10px 0 0;}

/* Cartes de sélection de formule (Sidour / Tehilim / Sidour + Tehilim) */
.plan-cards{display:flex;flex-direction:column;gap:10px;margin:4px 0 14px;}
.plan-card{
  position:relative;display:flex;flex-direction:column;gap:4px;
  border:2px solid var(--line);border-radius:14px;padding:12px 14px;
  cursor:pointer;background:var(--paper);transition:border-color .12s,background .12s;
}
.plan-card input{position:absolute;opacity:0;pointer-events:none;}
.plan-card.selected{border-color:var(--gold);background:var(--cream);}
.plan-card-head{display:flex;align-items:baseline;justify-content:space-between;gap:8px;}
.plan-card-name{font-family:'Marcellus',serif;font-size:1.05rem;color:var(--navy);}
.plan-card-price{font-weight:700;color:var(--navy);white-space:nowrap;}
.plan-card-price small{font-weight:400;color:var(--ink-soft);font-size:.75rem;}
.plan-card-feat{font-size:.82rem;color:var(--ink-soft);}
.plan-card-badge{
  position:absolute;top:-9px;right:14px;background:var(--navy);color:var(--gold-soft);
  font-size:.68rem;font-weight:700;border-radius:20px;padding:2px 10px;
}
[dir="rtl"] .plan-card-badge{right:auto;left:14px;}

/* Bandeau « essai gratuit : X jours restants » */
.trial-banner{
  display:block;width:100%;border:0;cursor:pointer;font-family:inherit;
  background:linear-gradient(90deg,var(--gold),#b8901f);color:var(--navy-deep);
  font-weight:700;font-size:.85rem;padding:9px 14px;text-align:center;
}

/* Bloc compte (panneau réglages) */
.account-box{margin-top:16px;border-top:1px solid var(--line);padding-top:14px;}
.account-id{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;}
.account-name{font-weight:700;color:var(--navy);}
.account-email{font-size:.8rem;color:var(--ink-soft);word-break:break-all;}
.account-badge{background:var(--cream);border:1px solid var(--gold);color:var(--navy);border-radius:20px;padding:4px 12px;font-size:.74rem;font-weight:700;white-space:nowrap;}
.account-badge.premium{background:var(--navy);color:var(--gold-soft);border-color:var(--navy);}
.account-actions{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap;}
.account-actions .pdf-btn{flex:1;min-width:130px;}

/* ---------- Dashboard admin ---------- */
.adm-hero{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;}
@media(min-width:560px){.adm-hero{grid-template-columns:repeat(4,minmax(0,1fr));}}
.adm-hero-card{background:linear-gradient(135deg,var(--navy),var(--navy-soft));border-radius:16px;padding:14px 16px;display:flex;flex-direction:column;gap:3px;box-shadow:var(--shadow);}
.adm-hero-card .adm-ico{font-size:1.2rem;}
.adm-hero-card .adm-val{font-family:'Marcellus',serif;font-size:1.5rem;color:var(--gold-soft);line-height:1.2;}
.adm-hero-card .adm-lbl{font-size:.68rem;color:rgba(255,255,255,.75);text-transform:uppercase;letter-spacing:.5px;}

.adm-grid2{display:grid;grid-template-columns:minmax(0,1fr);gap:12px;margin-top:14px;}
@media(min-width:720px){.adm-grid2{grid-template-columns:repeat(2,minmax(0,1fr));}}
.adm-panel{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:14px 16px;box-shadow:0 2px 10px rgba(15,42,68,.05);}
.adm-panel .section-label{margin:0 0 12px;}

.adm-donut-wrap{display:flex;align-items:center;gap:18px;flex-wrap:wrap;}
.adm-donut{width:104px;height:104px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.adm-donut-center{width:68px;height:68px;border-radius:50%;background:var(--paper);display:flex;flex-direction:column;align-items:center;justify-content:center;font-family:'Marcellus',serif;font-size:1.15rem;color:var(--navy);line-height:1.2;}
.adm-donut-center small{font-size:.6rem;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.5px;font-family:'Inter',sans-serif;font-weight:600;}

.adm-legend{display:flex;flex-direction:column;gap:7px;flex:1;min-width:140px;}
.adm-legend-row{display:flex;align-items:center;gap:8px;font-size:.82rem;}
.adm-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;}
.adm-legend-lbl{flex:1;color:var(--ink);}
.adm-legend-val{color:var(--ink-soft);font-weight:600;font-size:.78rem;}

.adm-bars{display:flex;flex-direction:column;gap:13px;}
.adm-bar-row{display:flex;align-items:center;gap:10px;font-size:.82rem;}
.adm-bar-label{width:110px;flex-shrink:0;color:var(--ink);}
.adm-bar-track{flex:1;height:8px;background:var(--cream);border-radius:6px;overflow:hidden;}
.adm-bar-fill{display:block;height:100%;background:var(--gold);border-radius:6px;}
.adm-bar-val{flex-shrink:0;color:var(--ink-soft);font-weight:600;font-size:.78rem;min-width:64px;text-align:right;}

.adm-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:14px;}
@media(min-width:560px){.adm-stats{grid-template-columns:repeat(4,minmax(0,1fr));}}
.adm-stat{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:12px 14px;display:flex;flex-direction:column;gap:2px;box-shadow:0 2px 10px rgba(15,42,68,.05);}
.adm-ico{font-size:1.1rem;}
.adm-val{font-family:'Marcellus',serif;font-size:1.4rem;color:var(--navy);line-height:1.15;}
.adm-lbl{font-size:.68rem;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.5px;}
.adm-toolbar{display:flex;gap:8px;margin:22px 0 10px;align-items:stretch;}
.adm-user{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:12px 14px;box-shadow:0 2px 10px rgba(15,42,68,.05);}
.adm-user-head{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap;}
.adm-name{font-weight:700;color:var(--navy);}
.adm-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:#c4c4c4;margin-right:7px;vertical-align:1px;}
.adm-dot.on{background:#2ecc71;box-shadow:0 0 0 3px rgba(46,204,113,.18);}
.adm-sub{font-size:.78rem;color:var(--ink-soft);margin-top:3px;line-height:1.5;word-break:break-word;}
.adm-actions{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap;}
.adm-btn{border:1px solid var(--line);background:var(--cream);color:var(--navy);border-radius:9px;padding:8px 12px;font-size:.78rem;font-weight:600;cursor:pointer;font-family:inherit;}
.adm-btn.gold{background:var(--gold);border-color:var(--gold);color:var(--navy-deep);}
.adm-btn.danger{color:#b03030;border-color:#e2b8b8;}
.adm-badge{border-radius:20px;padding:3px 10px;font-size:.72rem;font-weight:700;white-space:nowrap;}
.adm-badge.st-premium{background:var(--navy);color:var(--gold-soft);}
.adm-badge.st-trial{background:#fdf3d7;color:#8a6d1a;border:1px solid var(--gold-soft);}
.adm-badge.st-expired{background:#f3e0e0;color:#b03030;}
.adm-badge.st-pending{background:#fdf3d7;color:#8a6d1a;}
.adm-badge.st-paid{background:#e2f3e7;color:#2e7d44;}
.adm-badge.st-failed{background:#f3e0e0;color:#b03030;}
.adm-badge.st-refunded{background:#ececec;color:#666;}
.adm-pay{display:flex;align-items:center;gap:10px;background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:10px 14px;flex-wrap:wrap;}
.adm-pay-ico{font-size:1.2rem;}
.adm-pay-main{flex:1;min-width:180px;display:flex;flex-direction:column;}
.adm-pay-t{font-weight:600;color:var(--navy);font-size:.9rem;}
@media (max-width:360px){
  .adm-toolbar{flex-wrap:wrap;}
  .adm-toolbar .searchbar{flex:1 0 100%!important;}
  .adm-toolbar .adm-btn{flex:1;min-width:0;}
}

/* ---------- RTL (hébreu) ---------- */
[dir="rtl"] #backBtn,
[dir="rtl"] .row-chev,
[dir="rtl"] .cal-nav,[dir="rtl"] .zd-nav{transform:scaleX(-1);}
[dir="rtl"] .ev-d,
[dir="rtl"] .cal-greg,
[dir="rtl"] .cal-detail h3,
[dir="rtl"] .cal-wd,
[dir="rtl"] .row-fr,
[dir="rtl"] .ev-t{text-transform:none;}

/* ---------- Responsive : petits téléphones, paysage et cadres étroits ---------- */
@media (max-width:420px){
  :root{--radius:15px;}

  .view{
    padding-top:14px;
    padding-left:max(12px,env(safe-area-inset-left));
    padding-right:max(12px,env(safe-area-inset-right));
  }
  .hero{padding:28px 16px 24px;}
  .hero-logo{width:92px;height:92px;}
  .hero h2{font-size:1.7rem;}
  .reader-head{margin-left:-12px;margin-right:-12px;}
  .passage{margin-left:-12px;margin-right:-12px;}
  .pdf-frame{margin-left:-12px;margin-right:-12px;}
  .psalm-frame{margin-left:-12px;margin-right:-12px;}

  .tile{padding:15px 12px;}
  .tile.wide{flex-wrap:wrap;}
  .tile.wide .fr{flex-basis:120px;}
  .row{gap:10px;padding:12px;}
  .row .row-badge{width:40px;height:40px;flex-basis:40px;}

  .next-zman{gap:9px;padding:12px;}
  .nz-in{font-size:1.05rem;}

  .order-card{padding:12px;gap:9px;}
  .order-ico{width:40px;height:40px;font-size:1.35rem;}
  .order-wa{padding:7px 10px;font-size:.74rem;}

  .settings-sheet{padding-left:16px;padding-right:16px;}
  .setting-row{align-items:flex-start;flex-wrap:wrap;}
  .setting-row > label{flex:1 1 120px;}
  .setting-row > .seg,.setting-row > .theme-swatches{max-width:100%;margin-inline-start:auto;}
  .theme-swatches{flex-wrap:wrap;justify-content:flex-end;}

  .cal-grid{gap:2px;}
  .cal-cell{min-height:48px;border-radius:8px;}
  .cal-cell .g{font-size:.86rem;}
  .cal-cell .h{font-size:.68rem;}
}

@media (max-width:380px){
  .app-header{gap:6px;}
  .header-btn,.header-home{width:36px;height:36px;flex-basis:36px;}
  .header-logo{width:32px;height:32px;}
  .brand{font-size:1.15rem;}
  .brand-sub{font-size:.88rem;}

  .offices-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .offices-grid .tile:last-child{grid-column:1 / -1;}

  .next-zman{flex-wrap:wrap;}
  .next-zman .nz-in{width:100%;padding-inline-start:calc(1.5rem + 9px);text-align:start;white-space:normal;}

  .tabbar{left:6px;right:6px;padding:4px;}
  .tab{font-size:.52rem;letter-spacing:-.25px;}
  .tab .tab-ico svg{width:21px;height:21px;}

  .prof-stats{gap:6px;}
}

@media (max-width:340px){
  .chip-grid{grid-template-columns:minmax(0,1fr);}
  .order-wa{font-size:0;}
  .order-wa-ico{font-size:1rem;}
  .sh-times{gap:8px;}
  .sh-val{font-size:1.2rem;}
  .section-label{letter-spacing:1.4px;}
}

@media (orientation:landscape) and (max-height:520px){
  .hero{padding:20px 18px;}
  .hero-logo{width:74px;height:74px;}
  .hero .star{font-size:.72rem;}
  .hero h2{font-size:1.5rem;margin-top:4px;}
  .hero .greeting{margin-top:8px;}
  .settings-sheet{max-height:96vh;max-height:96dvh;}
}
