:root{
  /* Light theme — kept for prefers-color-scheme:light users */
  --pt-bg:#f6f7fb;
  --pt-card:#ffffff;
  --pt-text:#0f172a;
  --pt-muted:#64748b;
  --pt-line:rgba(15,23,42,.08);
  --pt-soft:rgba(15,23,42,.05);
  --pt-shadow: 0 12px 35px rgba(15,23,42,.08);
  --pt-radius:18px;

  /* Brand : or sacré unifié avec qhp-homepage-hero */
  --pt-brand:#c9a961;
  --pt-brand-2:#d9bb73;
  --pt-brand-glow: rgba(201,169,97,.14);

  --pt-emerald:#10b981;
  --pt-emerald-glow: rgba(16,185,129,.14);

  --pt-pill:#f2f5f8;
  --pt-pill-hover:#e9eff5;

  --pt-focus: rgba(201,169,97,.18);

  /* Typographie unifiée */
  --pt-font-display: 'Cormorant Garamond','Apple Garamond','Georgia',serif;
  --pt-font-body: 'Inter Tight','Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  --pt-font-arabic: 'Amiri','Scheherazade','Traditional Arabic',serif;

  /* Astra sticky header offset — fallback, overridden by JS measurement */
  --pt-astra-header-offset: 96px;
}

html[data-pt-theme="dark"]{
  /* Dark cosmic — default visual identity */
  --pt-bg:#0b1220;
  --pt-card:#0f1b2f;
  --pt-text:#e6edf7;
  --pt-muted:#9db0c7;
  --pt-line:rgba(255,255,255,.10);
  --pt-soft:rgba(255,255,255,.06);
  --pt-shadow: 0 14px 45px rgba(0,0,0,.45);

  --pt-brand:#c9a961;
  --pt-brand-2:#d9bb73;
  --pt-brand-glow: rgba(201,169,97,.18);

  --pt-pill:#13233b;
  --pt-pill-hover:#1a2e4d;

  --pt-focus: rgba(201,169,97,.22);
}

/* Scroll offset so anchor links clear the sticky Astra header */
html{
  scroll-padding-top: var(--pt-astra-header-offset);
}

/* =========================================================
   Base layout
   ========================================================= */
.pt-page{
  background:var(--pt-bg);
  color:var(--pt-text);
  font-family: var(--pt-font-body);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  padding: calc(28px + var(--pt-astra-header-offset)) 0 60px;
}

.pt-wrap{
  width: min(1100px, calc(100% - 32px));
  margin: 0 auto;
}

@media (max-width: 782px){
  :root{ --pt-astra-header-offset: 80px; }
  .pt-page{
    padding-top: calc(20px + var(--pt-astra-header-offset));
  }
}

/* =========================================================
   Cards
   ========================================================= */
.pt-card{
  background:var(--pt-card);
  border: 1px solid var(--pt-line);
  border-radius: var(--pt-radius);
  box-shadow: var(--pt-shadow);
}

.pt-card-hero{
  padding: 28px;
  scroll-margin-top: var(--pt-astra-header-offset);
}

/* =========================================================
   Hero / Breadcrumbs / Titles
   ========================================================= */
.pt-hero-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  margin-bottom: 10px;
}

.pt-breadcrumbs,
.pt-breadcrumb{
  font-size: 13px;
  color: var(--pt-muted);
  display:flex;
  align-items:center;
  gap: 6px;
  flex-wrap:wrap;
  margin-bottom: 12px;
}

.pt-breadcrumbs a,
.pt-breadcrumb a{
  color: var(--pt-muted);
  text-decoration:none;
}
.pt-breadcrumbs a:hover,
.pt-breadcrumb a:hover{ color: var(--pt-text); }

.pt-icon-btn{
  appearance:none;
  border:1px solid var(--pt-line);
  background: var(--pt-pill);
  color: var(--pt-text);
  border-radius: 999px;
  padding: 8px 10px;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
}
.pt-icon-btn:hover{ background: var(--pt-pill-hover); }

/* =========================================================
   Language switcher — <details> pill dropdown
   ========================================================= */
.pt-lang{
  position: relative;
}
.pt-lang__btn{
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 7px 13px;
  background: var(--pt-pill);
  border: 1px solid var(--pt-line);
  border-radius: 999px;
  color: var(--pt-text);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  list-style: none;
  user-select: none;
}
.pt-lang__btn::-webkit-details-marker{ display: none; }
.pt-lang__btn:hover{ background: var(--pt-pill-hover); }
.pt-lang__btn svg{ flex-shrink: 0; opacity: 0.7; }

.pt-lang__menu{
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  min-width: 188px;
  background: var(--pt-card);
  border: 1px solid var(--pt-line);
  border-radius: 14px;
  padding: 5px;
  z-index: 200;
  box-shadow: 0 8px 32px rgba(0,0,0,.18);
  backdrop-filter: blur(20px);
}
.pt-lang__opt{
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  border-radius: 8px;
  color: var(--pt-text);
  font-size: 13px;
  text-decoration: none;
  transition: background 0.15s;
}
.pt-lang__opt:hover,
.pt-lang__opt.is-active{ background: var(--pt-soft); }
.pt-lang__opt.is-active{ font-weight: 600; }
.pt-lang__flag{ font-size: 16px; line-height: 1; flex-shrink: 0; }

/* Mobile <480px : hide label, show flag + globe only */
@media (max-width: 480px){
  .pt-lang__cur-label{ display: none; }
  .pt-lang__btn{ padding: 7px 10px; gap: 5px; }
}

.pt-h1{
  font-family: var(--pt-font-display);
  font-size: 28px;
  font-weight: 500;
  line-height: 1.15;
  margin: 0 0 6px;
  letter-spacing: -0.02em;
}
.pt-subtitle{
  margin: 0 0 18px;
  font-size: 14px;
  color: var(--pt-muted);
}

.pt-section{ margin-top: 18px; }
.pt-section-head{
  display:flex;
  align-items:baseline;
  justify-content:flex-start;
  gap: 10px;
  margin-bottom: 10px;
}
.pt-h2{
  font-family: var(--pt-font-display);
  margin:0;
  font-size: 18px;
  font-weight: 500;
  letter-spacing: -0.01em;
}
.pt-muted{ font-size: 12px; color: var(--pt-muted); }

/* =========================================================
   Buttons
   ========================================================= */
.pt-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding: 9px 12px;
  border-radius: 12px;
  border: 1px solid var(--pt-line);
  background: linear-gradient(135deg, var(--pt-brand), var(--pt-brand-2));
  color: #fff;
  text-decoration:none;
  font-size: 13px;
  font-weight: 600;
}
.pt-btn:hover{ filter: brightness(1.03); }

.pt-btn-ghost{
  background: transparent;
  color: var(--pt-text);
}
.pt-btn-ghost:hover{ background: var(--pt-pill-hover); }

/* =========================================================
   Search (single, clean)
   ========================================================= */
.pt-search{
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 14px;
  background: var(--pt-pill);
  border: 1px solid var(--pt-line);
  margin-top: 12px;
}
.pt-search svg{ color: var(--pt-muted); flex: 0 0 auto; }
.pt-search input{
  width:100%;
  border:0 !important;
  background:transparent !important;
  outline:none !important;
  color: var(--pt-text);
  font-size: 14px;
}
.pt-clear{
  border:0;
  background:transparent;
  color: var(--pt-muted);
  font-size: 18px;
  cursor:pointer;
  padding: 0 6px;
  opacity: .7;
}
.pt-clear:hover{ opacity: 1; }

/* =========================================================
   Generic grid
   ========================================================= */
.pt-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

/* =========================================================
   City cards (used in some blocks)
   ========================================================= */
.pt-city-card{
  display:block;
  padding: 12px;
  border-radius: 16px;
  border: 1px solid var(--pt-line);
  background: linear-gradient(180deg, var(--pt-card), rgba(0,0,0,0));
  text-decoration:none;
  color: var(--pt-text);
  transition: transform .12s ease, background .12s ease;
}
.pt-city-card:hover{
  transform: translateY(-1px);
  background: var(--pt-pill-hover);
}
.pt-city-card-top{ display:flex; justify-content:space-between; align-items:flex-start; gap:10px; }
.pt-city-name{ font-weight: 700; letter-spacing:-0.01em; }
.pt-city-tz{ font-size: 12px; color: var(--pt-muted); white-space:nowrap; }

.pt-city-meta-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
  margin-top: 8px;
}
.pt-city-meta{
  font-size: 12px;
  color: var(--pt-muted);
  min-height: 16px;
}
.pt-city-now{
  font-size: 12px;
  color: var(--pt-muted);
  border: 1px solid var(--pt-line);
  background: var(--pt-pill);
  padding: 5px 8px;
  border-radius: 999px;
  white-space: nowrap;
}

/* =========================================================
   Tables
   ========================================================= */
.pt-table-wrap{
  overflow:auto;
  border-radius: 14px;
  border: 1px solid var(--pt-line);
}

.pt-table{
  width:100%;
  border-collapse: collapse;
  min-width: 520px;
  background: var(--pt-card);
}

.pt-table thead th{
  font-size: 12px;
  color: var(--pt-muted);
  text-transform: uppercase;
  letter-spacing: .06em;
  padding: 12px 12px;
  background: var(--pt-soft);
  border-bottom: 1px solid var(--pt-line);
}

.pt-table td{
  padding: 12px 12px;
  border-bottom: 1px solid var(--pt-line);
  vertical-align: middle;
}

.pt-right{ text-align:right; }
.pt-rank{ color: var(--pt-muted); width: 48px; }
.pt-table-link{ color: var(--pt-text); text-decoration:none; font-weight: 700; }
.pt-table-link:hover{ text-decoration: underline; }
.pt-small{ font-size: 12px; color: var(--pt-muted); margin-top: 3px; }

/* Prayer table specifics */
.pt-table-prayers{ min-width: 0; }
.pt-table-prayers tbody tr.pt-is-next{ background: var(--pt-focus); }

.pt-prayer-cell{
  display:flex;
  align-items:center;
  gap: 10px;
}
.pt-prayer-ico{
  width: 32px;
  height: 32px;
  border-radius: 12px;
  background: var(--pt-soft);
  display:flex;
  align-items:center;
  justify-content:center;
  color: var(--pt-brand);
  border: 1px solid var(--pt-line);
}
.pt-prayer-name{ font-weight: 700; }
.pt-time{ font-weight: 900; letter-spacing: .02em; }

/* =========================================================
   Badges / footer note
   ========================================================= */
.pt-meta-row{
  display:flex;
  flex-wrap:wrap;
  gap: 8px;
  margin-top: 12px;
}

.pt-badge{
  font-size: 12px;
  color: var(--pt-muted);
  border: 1px solid var(--pt-line);
  background: var(--pt-pill);
  padding: 7px 10px;
  border-radius: 999px;
}

.pt-footer-note{
  margin-top: 14px;
  font-size: 12px;
  color: var(--pt-muted);
}

/* =========================================================
   All cities list (country page)
   ========================================================= */
.pt-city-list{
  display:grid;
  gap: 10px;
  margin-top: 12px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
@media (max-width: 720px){
  .pt-city-list{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

.pt-city-pill{
  display:flex;
  align-items:center;
  gap: 6px;
  min-height: 46px;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid var(--pt-line);
  background: var(--pt-pill);
  text-decoration:none;
  color: var(--pt-text);
  font-weight: 600;
  font-size: 13px;
  line-height: 1.2;
  overflow:hidden;
  transition: border-color 0.2s, background 0.2s, color 0.2s;
}
.pt-city-pill:hover{
  background: rgba(201, 169, 97, 0.06);
  border-color: rgba(201, 169, 97, 0.30);
  color: var(--pt-brand);
}
.pt-city-pill-name{
  flex: 1;
  overflow:hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
}
.pt-city-pill-pop {
  font-size: 11px;
  font-weight: 400;
  color: var(--pt-muted);
  white-space: nowrap;
  flex-shrink: 0;
  letter-spacing: 0.01em;
}
.pt-city-pill-arrow {
  font-size: 12px;
  color: var(--pt-muted);
  flex-shrink: 0;
  opacity: 0;
  transform: translateX(-4px);
  transition: opacity 0.2s, transform 0.2s;
}
.pt-city-pill:hover .pt-city-pill-arrow {
  opacity: 1;
  transform: translateX(0);
  color: var(--pt-brand);
}
@media (prefers-reduced-motion: reduce) {
  .pt-city-pill { transition: none; }
  .pt-city-pill-arrow { transition: none; transform: none; opacity: 0.4; }
}

/* =========================================================
   Info grids (city page)
   ========================================================= */
.pt-info-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

@media (max-width: 900px){
  .pt-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .pt-info-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 640px){
  .pt-card-hero{ padding: 16px; }
  .pt-h1{ font-size: 22px; }
  .pt-grid{ grid-template-columns: 1fr; }
  .pt-info-grid{ grid-template-columns: 1fr; }
  .pt-table{ min-width: 0; }
}

.pt-info-card{
  border: 1px solid var(--pt-line);
  background: var(--pt-pill);
  border-radius: 16px;
  padding: 12px;
}

.pt-info-label{
  font-size: 12px;
  color: var(--pt-muted);
  text-transform: uppercase;
  letter-spacing: .08em;
}

.pt-info-value{
  margin-top: 6px;
  font-size: 14px;
  font-weight: 900;
  letter-spacing: -0.01em;
}
.pt-info-sub{
  margin-top: 6px;
  font-size: 12px;
  color: var(--pt-muted);
}

/* Local time premium */
.pt-info-card-time{
  background: linear-gradient(180deg, rgba(201,169,97,.10), var(--pt-pill));
  border-color: rgba(201,169,97,.25);
}
.pt-info-card-time .pt-info-value,
.pt-local-time{
  font-size: 40px;
  font-weight: 950;
  letter-spacing: .04em;
  font-variant-numeric: tabular-nums;
  line-height: 1.05;
}
@media (max-width: 640px){
  .pt-info-card-time .pt-info-value,
  .pt-local-time{ font-size: 34px; }
}

/* =========================================================
   Next prayer / countdown
   ========================================================= */
.pt-nextwrap{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 12px;
}
@media (max-width: 900px){
  .pt-nextwrap{ grid-template-columns: 1fr; }
}

.pt-nextcard, .pt-qibla-card{
  border: 1px solid var(--pt-line);
  background: var(--pt-pill);
  border-radius: 16px;
  padding: 12px;
}

.pt-next-title{
  font-size: 12px;
  color: var(--pt-muted);
  text-transform: uppercase;
  letter-spacing: .08em;
}
.pt-next-main{
  margin-top: 8px;
  font-size: 16px;
  font-weight: 900;
  letter-spacing: -0.01em;
  display:flex;
  align-items:baseline;
  gap: 8px;
  flex-wrap:wrap;
}
.pt-next-dot{ opacity:.6; }
.pt-next-sub{
  margin-top: 10px;
  font-size: 12px;
  color: var(--pt-muted);
}
.pt-next-countdown{
  margin-top: 6px;
  font-size: 22px;
  font-weight: 950;
  letter-spacing: .06em;
  font-variant-numeric: tabular-nums;
}

/* =========================================================
   Timeline
   ========================================================= */
.pt-timeline{
  margin-top: 14px;
  border: 1px solid var(--pt-line);
  background: var(--pt-card);
  border-radius: 16px;
  padding: 12px;
}
.pt-timeline-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom: 10px;
}
.pt-timeline-bar{
  height: 10px;
  border-radius: 999px;
  background: var(--pt-soft);
  border: 1px solid var(--pt-line);
  overflow:hidden;
}
.pt-timeline-fill{
  height: 100%;
  width: 0%;
  background: linear-gradient(135deg, var(--pt-brand), var(--pt-brand-2));
  border-radius: 999px;
  transition: width .25s ease;
}

/* Dots */
.pt-timeline-dots{
  margin-top: 10px;
  display:grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 8px;
}
@media (max-width: 640px){
  .pt-timeline-dots{ grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
.pt-dot{
  border: 1px solid var(--pt-line);
  background: var(--pt-pill);
  border-radius: 14px;
  padding: 8px;
  text-align:center;
}
.pt-dot .pt-dot-name{
  font-size: 12px;
  font-weight: 900;
}
.pt-dot .pt-dot-time{
  margin-top: 2px;
  font-size: 12px;
  color: var(--pt-muted);
  font-variant-numeric: tabular-nums;
}
.pt-dot.pt-dot-active{ background: var(--pt-focus); }

/* =========================================================
   Qibla compass (static)
   ========================================================= */
.pt-compass{
  position: relative;
  width: 110px;
  height: 110px;
  margin-top: 10px;
}
.pt-compass-ring{
  position:absolute; inset:0;
  border-radius: 999px;
  border: 2px solid var(--pt-line);
  background: radial-gradient(circle at 30% 30%, rgba(201,169,97,.18), transparent 60%);
}
.pt-compass-arrow{
  position:absolute;
  left: 50%;
  top: 50%;
  width: 4px;
  height: 42px;
  transform-origin: 50% 90%;
  background: linear-gradient(180deg, var(--pt-brand), var(--pt-brand-2));
  border-radius: 999px;
}
.pt-compass-arrow::after{
  content:"";
  position:absolute;
  top:-10px;
  left:50%;
  transform: translateX(-50%);
  width: 0; height: 0;
  border-left: 8px solid transparent;
  border-right: 8px solid transparent;
  border-bottom: 12px solid var(--pt-brand);
}
.pt-compass-center{
  position:absolute;
  left:50%; top:50%;
  width: 10px; height: 10px;
  transform: translate(-50%,-50%);
  border-radius: 999px;
  background: var(--pt-text);
  opacity: .8;
}
.pt-compass-n{
  position:absolute;
  left:50%;
  top: 6px;
  transform: translateX(-50%);
  font-size: 11px;
  color: var(--pt-muted);
  font-weight: 900;
}

/* =========================================================
   Date & Time block (city)
   ========================================================= */
.pt-dt{
  margin-top: 10px;
  border: 1px solid var(--pt-line);
  border-radius: 14px;
  background: rgba(255,255,255,.02);
  overflow:hidden;
}
.pt-dt-row{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  gap: 12px;
  padding: 10px 12px;
  border-top: 1px solid var(--pt-line);
}
.pt-dt-row:first-child{ border-top:0; }
.pt-dt-k{
  font-size: 12px;
  color: var(--pt-muted);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
  white-space: nowrap;
}
.pt-dt-v{
  font-size: 13px;
  font-weight: 900;
  text-align:right;
}
.pt-dt-time{
  font-size: 34px;
  font-weight: 950;
  font-variant-numeric: tabular-nums;
  letter-spacing: .04em;
  line-height: 1.05;
}
@media (max-width: 640px){
  .pt-dt-v{ font-size: 13px; }
  .pt-dt-time{ font-size: 30px; }
}

/* =========================================================
   Progress bar (city)
   ========================================================= */
.pt-progress{ margin-top: 14px; }
.pt-progress-label{
  font-size: 12px;
  color: var(--pt-muted);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.pt-progress-bar{
  margin-top: 8px;
  height: 10px;
  border-radius: 999px;
  background: var(--pt-soft);
  border: 1px solid var(--pt-line);
  overflow:hidden;
}
.pt-progress-fill{
  height: 100%;
  width: 0%;
  background: linear-gradient(135deg, var(--pt-brand), var(--pt-brand-2));
  border-radius: 999px;
  transition: width .25s ease;
}
.pt-progress-sub{ margin-top: 8px; }

/* =========================================================
   Qibla & Makkah stats
   ========================================================= */
.pt-qibla-stats{
  display:grid;
  gap: 10px;
  margin: 10px 0 8px;
}
.pt-qibla-stat{
  padding: 10px 12px;
  border: 1px solid var(--pt-line);
  border-radius: 14px;
  background: rgba(255,255,255,.02);
}
.pt-qibla-k{
  font-size: 12px;
  color: var(--pt-muted);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.pt-qibla-v{
  margin-top: 4px;
  font-size: 18px;
  font-weight: 950;
  font-variant-numeric: tabular-nums;
}
.pt-qibla-sub{
  margin-top: 2px;
  font-size: 12px;
  color: var(--pt-muted);
}

/* =========================================================
   Nearby cities + mosques (single, premium)
   ========================================================= */
.pt-grid-2{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  align-items: start;
}
@media (max-width: 900px){
  .pt-grid-2{ grid-template-columns: 1fr; }
}

.pt-list{
  list-style:none;
  margin: 10px 0 0;
  padding: 0;
}
.pt-list li{
  display:flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid var(--pt-line);
  transition: transform .12s ease, background .12s ease;
}
.pt-list li:last-child{ border-bottom:0; }

.pt-list li:hover{
  background: var(--pt-pill-hover);
  border-radius: 12px;
  padding-left: 10px;
  padding-right: 10px;
}

.pt-list a{
  flex: 1 1 auto;
  min-width: 140px;
  text-decoration:none;
  font-weight: 900;
  color: var(--pt-text);
}
.pt-list a:hover{ text-decoration: underline; }

.pt-pill{
  display:inline-flex;
  align-items:center;
  padding: 7px 10px;
  border-radius: 999px;
  font-size: 12px;
  line-height: 20px;
  font-weight: 950;
  font-variant-numeric: tabular-nums;
  background: var(--pt-pill);
  border: 1px solid var(--pt-line);
  white-space: nowrap;
}

/* =========================================================
   Countries index (premium)
   ========================================================= */
.pt-country-grid{
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 12px;
  margin-top: 12px;
}
.pt-country-card{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 14px;
  border-radius: 16px;
  border: 1px solid var(--pt-line);
  background: var(--pt-card);
  text-decoration:none !important;
  color: var(--pt-text);
  transition: transform .12s ease, background .12s ease, box-shadow .12s ease;
}
.pt-country-card:hover{
  transform: translateY(-1px);
  background: var(--pt-pill-hover);
  box-shadow: 0 10px 24px rgba(0,0,0,.08);
}
.pt-country-name{ font-weight: 700; letter-spacing: -0.01em; }
.pt-country-arrow{ opacity: .55; font-size: 18px; line-height: 1; }

/* =========================================================
   FAQ
   ========================================================= */
/* FAQ harmonisée design system — A4 */
.pt-faq { display: flex; flex-direction: column; gap: 0; }

.pt-faq__item {
  border-top: 1px solid var(--pt-line);
  margin: 0;
  padding: 0;
}
.pt-faq__item:last-child { border-bottom: 1px solid var(--pt-line); }

.pt-faq__q {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  padding: 16px 0;
  cursor: pointer;
  list-style: none;
  font-family: var(--pt-font-body);
  font-weight: 500;
  font-size: 15px;
  line-height: 1.45;
  color: var(--pt-text);
  transition: color 0.2s;
}
.pt-faq__q::-webkit-details-marker { display: none; }
.pt-faq__q::marker { content: ''; display: none; }
.pt-faq__q:hover { color: var(--pt-brand); }

.pt-faq__qText { flex: 1; }

.pt-faq__qIcon {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
  font-size: 20px;
  font-weight: 300;
  line-height: 1;
  color: var(--pt-brand);
  border: 1px solid var(--pt-line);
  border-radius: 50%;
  transition: transform 0.25s, border-color 0.2s, background 0.2s;
  padding-bottom: 2px;
}

.pt-faq__item[open] .pt-faq__qIcon {
  transform: rotate(45deg);
  background: rgba(201, 169, 97, 0.08);
  border-color: var(--pt-brand);
}

.pt-faq__item[open] .pt-faq__q { color: var(--pt-brand); }

.pt-faq__a {
  padding: 0 0 16px;
  animation: ptFaqReveal 0.3s ease-out;
}
.pt-faq__a p {
  margin: 0;
  font-size: 14px;
  line-height: 1.65;
  color: var(--pt-muted);
  font-weight: 300;
}

@keyframes ptFaqReveal {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}

@media (prefers-reduced-motion: reduce) {
  .pt-faq__qIcon { transition: none; }
  .pt-faq__item[open] .pt-faq__qIcon { transform: none; }
  .pt-faq__a { animation: none; }
}

/* Legacy selectors kept for backward compat */
.pt-faq details{ padding:0; border-top:1px solid var(--pt-line); }
.pt-faq details:first-child{ border-top:0; }
.pt-faq summary{ cursor:pointer; font-weight:500; }
.pt-faq p{ margin:10px 0 0; opacity:.9; }

/* Make FAQ full width inside the card (like Top cities) */
.pt-faq-wrap{
  max-width: none !important;
  width: 100% !important;
  margin: 0 !important;
}

/* HOME — Top countries as premium cards */
.pt-home-topcountries-grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 12px;
}
@media (min-width: 900px){
  .pt-home-topcountries-grid{
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
.pt-home-country-card{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 10px;
  padding: 14px;
  border-radius: 16px;
  border: 1px solid var(--pt-line);
  background: var(--pt-card);
  text-decoration:none !important;
  color: var(--pt-text);
  transition: transform .12s ease, background .12s ease, box-shadow .12s ease;
}
.pt-home-country-card:hover{
  transform: translateY(-1px);
  background: var(--pt-pill-hover);
  box-shadow: 0 10px 24px rgba(0,0,0,.08);
}
.pt-home-country-name{
  font-weight: 900;
}
.pt-home-country-meta{
  font-size: 12px;
  color: var(--pt-muted);
  white-space: nowrap;
}

.pt-home-actions .pt-btn{
  white-space: nowrap;
}
@media (max-width: 640px){
  .pt-home-actions .pt-btn{
    width: 100%;
    justify-content: center;
  }
}

/* =========================================================
   Premium polish additions (city / country / prayertimes home)
   ========================================================= */
.pt-hero-shell{
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at top right, rgba(201,169,97,.16), transparent 30%),
    radial-gradient(circle at top left, rgba(59,183,166,.12), transparent 24%),
    var(--pt-card);
}
.pt-hero-shell::after{
  content:"";
  position:absolute;
  inset:auto -10% -40% auto;
  width:240px;
  height:240px;
  border-radius:50%;
  background: radial-gradient(circle, rgba(201,169,97,.08), transparent 68%);
  pointer-events:none;
}
.pt-hero-metrics{
  display:grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap:12px;
  margin: 18px 0 0;
}
.pt-hero-metric{
  position:relative;
  z-index:1;
  padding:14px 16px;
  border-radius:16px;
  border:1px solid var(--pt-line);
  background: linear-gradient(180deg, rgba(255,255,255,.58), rgba(255,255,255,.18));
  backdrop-filter: blur(8px);
}
html[data-pt-theme="dark"] .pt-hero-metric{
  background: linear-gradient(180deg, rgba(19,35,59,.88), rgba(15,27,47,.72));
}
.pt-hero-metric strong{
  display:block;
  margin-top:6px;
  font-size:15px;
  line-height:1.3;
  letter-spacing:-.01em;
}
.pt-hero-metric-label{
  display:block;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:var(--pt-muted);
}
.pt-meta-row-hero{ margin-top: 14px; }
.pt-premium-tiles{
  display:grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap:12px;
  margin-bottom:18px;
}
.pt-premium-tiles-home{ margin-top: 0; }
.pt-premium-tile{
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  min-height:126px;
  padding:16px;
  border-radius:18px;
  text-decoration:none;
  color:var(--pt-text);
  border:1px solid var(--pt-line);
  background:
    linear-gradient(160deg, rgba(201,169,97,.14), rgba(201,169,97,0) 55%),
    linear-gradient(180deg, var(--pt-card), var(--pt-card));
  box-shadow: var(--pt-shadow);
  transition: transform .16s ease, border-color .16s ease, box-shadow .16s ease;
}
.pt-premium-tile:hover{
  transform: translateY(-2px);
  border-color: rgba(201,169,97,.28);
  box-shadow: 0 16px 40px rgba(15,23,42,.10);
}
.pt-premium-tile strong{
  font-size:16px;
  line-height:1.3;
  letter-spacing:-.01em;
}
.pt-premium-tile span{
  color:var(--pt-muted);
  font-size:12px;
}
.pt-premium-tile-kicker{
  display:inline-flex;
  align-self:flex-start;
  color:var(--pt-brand);
  font-size:11px !important;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.pt-city-hero .pt-h1,
.pt-country-hero .pt-h1,
.pt-home-hero .pt-h1{ max-width: 900px; }
@media (max-width: 980px){
  .pt-hero-metrics,
  .pt-premium-tiles{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 640px){
  .pt-hero-metrics,
  .pt-premium-tiles{ grid-template-columns: 1fr; }
  .pt-hero-metric,
  .pt-premium-tile{ min-height: unset; }
}


/* =========================================================
   Ultra premium layer (city / country / prayertimes home)
   ========================================================= */
.pt-page[data-pt-page="home"],
.pt-page[data-pt-page="country"],
.pt-page[data-pt-page="city"]{ position:relative; }
.pt-page[data-pt-page="home"]::before,
.pt-page[data-pt-page="country"]::before,
.pt-page[data-pt-page="city"]::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(circle at 0% 0%, rgba(201,169,97,.08), transparent 28%),
    radial-gradient(circle at 100% 0%, rgba(99,102,241,.06), transparent 26%),
    radial-gradient(circle at 50% 100%, rgba(15,118,110,.04), transparent 30%);
}
.pt-section-premium{ position:relative; }
.pt-surface-card,
.pt-table-shell,
.pt-list-card,
.pt-faq-card,
.pt-country-card,
.pt-city-pill,
.pt-hadith-box,
.pt-qibla-card,
.pt-nextcard,
.pt-info-card{ position:relative; overflow:hidden; }
.pt-surface-card::before,
.pt-table-shell::before,
.pt-list-card::before,
.pt-faq-card::before,
.pt-country-card::before,
.pt-city-pill::before,
.pt-hadith-box::before,
.pt-qibla-card::before,
.pt-nextcard::before,
.pt-info-card::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(255,255,255,.16), rgba(255,255,255,0) 38%);
  pointer-events:none;
}
html[data-pt-theme="dark"] .pt-surface-card::before,
html[data-pt-theme="dark"] .pt-table-shell::before,
html[data-pt-theme="dark"] .pt-list-card::before,
html[data-pt-theme="dark"] .pt-faq-card::before,
html[data-pt-theme="dark"] .pt-country-card::before,
html[data-pt-theme="dark"] .pt-city-pill::before,
html[data-pt-theme="dark"] .pt-hadith-box::before,
html[data-pt-theme="dark"] .pt-qibla-card::before,
html[data-pt-theme="dark"] .pt-nextcard::before,
html[data-pt-theme="dark"] .pt-info-card::before{
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,0) 30%);
}
.pt-hero-shell{
  border-radius:28px;
  border-color:rgba(201,169,97,.18);
  box-shadow:0 20px 60px rgba(15,23,42,.08), inset 0 1px 0 rgba(255,255,255,.55);
}
.pt-hero-shell::before{
  content:"";
  position:absolute;
  inset:1px;
  border-radius:27px;
  border:1px solid rgba(255,255,255,.45);
  pointer-events:none;
}
html[data-pt-theme="dark"] .pt-hero-shell{ box-shadow:0 20px 60px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.04); }
html[data-pt-theme="dark"] .pt-hero-shell::before{ border-color: rgba(255,255,255,.06); }
.pt-home-hero,
.pt-country-hero,
.pt-city-hero{
  background:
    linear-gradient(135deg, rgba(255,255,255,.82), rgba(255,255,255,.58)),
    radial-gradient(circle at top right, rgba(201,169,97,.18), transparent 28%),
    radial-gradient(circle at left center, rgba(59,183,166,.10), transparent 24%),
    var(--pt-card);
}
html[data-pt-theme="dark"] .pt-home-hero,
html[data-pt-theme="dark"] .pt-country-hero,
html[data-pt-theme="dark"] .pt-city-hero{
  background:
    linear-gradient(135deg, rgba(9,18,35,.95), rgba(12,25,47,.85)),
    radial-gradient(circle at top right, rgba(201,169,97,.22), transparent 28%),
    radial-gradient(circle at left center, rgba(201,169,97,.06), transparent 24%),
    var(--pt-card);
}

/* ── Hero 2-col layout — T6.2 ──────────────────────────────────────── */

.pt-hero-layout {
  display: grid !important;
  grid-template-columns: 1.15fr 1fr !important;
  gap: 32px 48px !important;
  align-items: start !important;
}
@media (max-width: 768px) {
  .pt-hero-layout {
    grid-template-columns: 1fr !important;
    gap: 24px !important;
  }
}

.pt-hero-right {
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
}

.pt-hero-metrics {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)) !important;
  gap: 16px !important;
  margin: 20px 0 !important;
}

.pt-hero-top {
  display: flex !important;
  justify-content: space-between !important;
  align-items: flex-start !important;
  gap: 16px !important;
  flex-wrap: wrap !important;
  margin-bottom: 20px !important;
}

.pt-hero-actions {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  flex-wrap: wrap !important;
}

/* Compact prayer row in hero right col */
.pt-prayer-compact {
  display: grid !important;
  grid-template-columns: 32px 1fr auto !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 9px 12px !important;
  border-radius: 10px !important;
  border: 1px solid transparent;
  transition: background 0.2s, border-color 0.2s;
}

.pt-prayer-compact:first-child { border-radius: 12px 12px 10px 10px; }
.pt-prayer-compact:last-child  { border-radius: 10px 10px 12px 12px; }

.pt-prayer-compact.is-current {
  background: rgba(201, 169, 97, 0.10);
  border-color: rgba(201, 169, 97, 0.28);
}

.pt-prayer-compact__ico {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: rgba(201, 169, 97, 0.08);
  color: var(--pt-brand);
  flex-shrink: 0;
}

.pt-prayer-compact__ico svg {
  width: 16px;
  height: 16px;
}

.pt-prayer-compact.is-current .pt-prayer-compact__ico {
  background: rgba(201, 169, 97, 0.18);
}

.pt-prayer-compact__name {
  font-family: var(--pt-font-body);
  font-size: 13px;
  font-weight: 500;
  color: var(--pt-text);
  letter-spacing: 0.01em;
}

.pt-prayer-compact.is-current .pt-prayer-compact__name {
  color: var(--pt-brand);
  font-weight: 600;
}

.pt-prayer-compact__time {
  font-family: var(--pt-font-body);
  font-size: 14px;
  font-weight: 500;
  color: var(--pt-muted);
  font-feature-settings: 'tnum' 1;
  letter-spacing: 0.01em;
  white-space: nowrap;
}

.pt-prayer-compact.is-current .pt-prayer-compact__time {
  color: var(--pt-brand);
}

/* Responsive: stack at 860px */
@media (max-width: 860px) {
  .pt-hero-layout {
    grid-template-columns: 1fr;
    gap: 24px;
  }
  .pt-hero-right {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 6px;
  }
  .pt-prayer-compact {
    flex: 1 1 calc(50% - 3px);
    min-width: 140px;
    border-radius: 10px !important;
  }
}

/* Country top cities — col droite du hero country (T6.2) */
.pt-country-top-label {
  font-size: 10px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--pt-brand);
  font-weight: 600;
  margin-bottom: 6px;
}

.pt-hero-right--cities {
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.pt-country-top-city {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 9px 14px;
  border-radius: 10px;
  border: 1px solid var(--pt-line);
  background: var(--pt-soft);
  text-decoration: none;
  color: var(--pt-text);
  font-family: var(--pt-font-body);
  font-size: 14px;
  transition: border-color 0.2s, background 0.2s;
}

.pt-country-top-city:hover {
  background: rgba(201, 169, 97, 0.06);
  border-color: rgba(201, 169, 97, 0.28);
  color: var(--pt-brand);
}

.pt-country-top-city__name {
  font-weight: 500;
  flex: 1;
}

.pt-country-top-city__pop {
  font-size: 12px;
  color: var(--pt-muted);
  font-feature-settings: 'tnum' 1;
  white-space: nowrap;
}

@media (max-width: 860px) {
  .pt-hero-right--cities {
    flex-direction: row;
    flex-wrap: wrap;
  }
  .pt-country-top-city {
    flex: 1 1 calc(50% - 4px);
  }
}

.pt-hero-top,
.pt-section-head-premium,
.pt-section-head-tight,
.pt-home-actions,
.pt-grid,
.pt-grid-2,
.pt-premium-tiles,
.pt-country-grid,
.pt-city-list,
.pt-library-grid,
.pt-info-grid,
.pt-nextwrap,
.pt-faq-wrap,
.pt-table-wrap,
.pt-footer-note,
.pt-meta-row,
.pt-timeline,
.pt-progress,
.pt-list,
.pt-card > *{ position:relative; z-index:1; }
.pt-section-head-premium{ align-items:flex-end; gap:16px; margin-bottom:14px; }
.pt-section-head-tight{ margin-bottom:12px; }
.pt-section-kicker{
  display:inline-flex;
  margin-bottom:7px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(201,169,97,.18);
  background:rgba(201,169,97,.08);
  color:var(--pt-brand);
  font-size:11px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}
html[data-pt-theme="dark"] .pt-section-kicker{ background:rgba(201,169,97,.12); border-color:rgba(201,169,97,.28); }
.pt-home-actions .pt-btn,
.pt-section-head .pt-btn,
.pt-btn.pt-btn-ghost{ border-radius:14px; box-shadow:0 10px 25px rgba(15,23,42,.06); }
.pt-search{
  border-radius:18px;
  border-color:rgba(15,23,42,.08);
  background:linear-gradient(180deg, rgba(255,255,255,.72), rgba(255,255,255,.52));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.62), 0 12px 35px rgba(15,23,42,.05);
}
html[data-pt-theme="dark"] .pt-search{
  border-color:rgba(255,255,255,.08);
  background:linear-gradient(180deg, rgba(19,35,59,.92), rgba(15,27,47,.84));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05), 0 16px 40px rgba(0,0,0,.24);
}
.pt-hero-metric,
.pt-info-card,
.pt-country-card,
.pt-city-pill,
.pt-hadith-box,
.pt-nextcard,
.pt-qibla-card,
.pt-city-card,
.pt-table-shell,
.pt-list-card,
.pt-faq-card{
  border-radius:20px;
  border-color:rgba(15,23,42,.06);
  box-shadow:0 18px 40px rgba(15,23,42,.06), inset 0 1px 0 rgba(255,255,255,.55);
}
html[data-pt-theme="dark"] .pt-hero-metric,
html[data-pt-theme="dark"] .pt-info-card,
html[data-pt-theme="dark"] .pt-country-card,
html[data-pt-theme="dark"] .pt-city-pill,
html[data-pt-theme="dark"] .pt-hadith-box,
html[data-pt-theme="dark"] .pt-nextcard,
html[data-pt-theme="dark"] .pt-qibla-card,
html[data-pt-theme="dark"] .pt-city-card,
html[data-pt-theme="dark"] .pt-table-shell,
html[data-pt-theme="dark"] .pt-list-card,
html[data-pt-theme="dark"] .pt-faq-card{
  border-color:rgba(255,255,255,.06);
  box-shadow:0 18px 40px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.04);
}
.pt-premium-tile,
.pt-country-card,
.pt-city-card,
.pt-city-pill,
.pt-hadith-box{ transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease; }
.pt-premium-tile:hover,
.pt-country-card:hover,
.pt-city-card:hover,
.pt-city-pill:hover,
.pt-hadith-box:hover{ transform:translateY(-4px); box-shadow:0 22px 55px rgba(15,23,42,.12); }
.pt-country-grid,
.pt-major-cities-grid,
.pt-grid-2-premium,
.pt-info-grid-premium,
.pt-nextwrap-premium{ gap:14px; }
.pt-country-card,
.pt-city-card,
.pt-hadith-box{
  background:
    linear-gradient(145deg, rgba(201,169,97,.10), rgba(201,169,97,0) 40%),
    linear-gradient(180deg, var(--pt-card), var(--pt-card));
}
.pt-country-name,
.pt-city-pill-name,
.pt-prayer-name,
.pt-info-value,
.pt-next-countdown,
.pt-next-main,
.pt-h2,
.pt-h1{ letter-spacing:-.02em; }
.pt-city-list{ gap:10px; }
.pt-city-pill{
  padding:12px 14px;
  border-radius:16px;
  background:
    linear-gradient(145deg, rgba(201,169,97,.08), rgba(201,169,97,0) 44%),
    linear-gradient(180deg, var(--pt-card), var(--pt-card));
}
.pt-info-card{
  min-height:156px;
  background:
    linear-gradient(145deg, rgba(201,169,97,.10), rgba(201,169,97,0) 46%),
    linear-gradient(180deg, var(--pt-card), var(--pt-card));
}
.pt-info-label{ font-size:11px; letter-spacing:.08em; text-transform:uppercase; }
.pt-info-value{ font-size:24px; }
.pt-countdown-card,
.pt-library-side-card{
  background:
    linear-gradient(145deg, rgba(201,169,97,.12), rgba(201,169,97,0) 42%),
    linear-gradient(180deg, var(--pt-card), var(--pt-card));
}
.pt-next-countdown{ font-size:clamp(34px, 4vw, 52px); line-height:1; margin-top:10px; }
.pt-progress-bar{ height:10px; border-radius:999px; overflow:hidden; }
.pt-progress-fill{ border-radius:999px; box-shadow:0 8px 20px rgba(201,169,97,.25); }
.pt-timeline-dots{ gap:10px; }
.pt-dot{
  border-radius:18px;
  border:1px solid var(--pt-line);
  background:linear-gradient(180deg, rgba(255,255,255,.6), rgba(255,255,255,.3));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.7);
}
html[data-pt-theme="dark"] .pt-dot{
  background:linear-gradient(180deg, rgba(19,35,59,.94), rgba(15,27,47,.82));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
}
.pt-prayer-cell{ gap:14px; }
.pt-prayer-ico{ width:42px; height:42px; border-radius:14px; background:linear-gradient(180deg, rgba(201,169,97,.12), rgba(201,169,97,.04)); }
.pt-table-shell{
  padding:10px;
  background:
    linear-gradient(145deg, rgba(201,169,97,.08), rgba(201,169,97,0) 42%),
    linear-gradient(180deg, var(--pt-card), var(--pt-card));
}
.pt-table thead th{ font-size:11px; letter-spacing:.08em; text-transform:uppercase; }
.pt-table tbody tr{ transition:background .14s ease, transform .14s ease; }
.pt-table tbody tr:hover{ background:rgba(201,169,97,.06); }
.pt-list-card{
  padding:18px;
  background:
    linear-gradient(145deg, rgba(201,169,97,.09), rgba(201,169,97,0) 44%),
    linear-gradient(180deg, var(--pt-card), var(--pt-card));
}
.pt-list li{ padding:12px 0; border-top:1px solid rgba(15,23,42,.06); }
html[data-pt-theme="dark"] .pt-list li{ border-top-color:rgba(255,255,255,.06); }
.pt-faq details{ padding:14px 0; }
.pt-faq summary{ list-style:none; position:relative; padding-right:28px; }
.pt-faq summary::after{
  content:"+";
  position:absolute;
  right:0;
  top:0;
  color:var(--pt-brand);
  font-size:20px;
  line-height:1;
}
.pt-faq details[open] summary::after{ content:"–"; }
.pt-footer-note{
  margin-top:14px;
  padding:12px 14px;
  border-radius:16px;
  background:rgba(201,169,97,.06);
  border:1px solid rgba(201,169,97,.10);
}
html[data-pt-theme="dark"] .pt-footer-note{ background:rgba(201,169,97,.08); border-color:rgba(201,169,97,.16); }
@media (max-width: 980px){
  .pt-hero-shell{ border-radius:24px; }
  .pt-hero-shell::before{ border-radius:23px; }
}
@media (max-width: 640px){
  .pt-hero-shell{ border-radius:22px; }
  .pt-hero-shell::before{ border-radius:21px; }
  .pt-section-head-premium{ align-items:flex-start; }
  .pt-info-card{ min-height:unset; }
  .pt-next-countdown{ font-size:34px; }
  .pt-search{ border-radius:16px; }
  .pt-hero-metric,
  .pt-info-card,
  .pt-country-card,
  .pt-city-pill,
  .pt-hadith-box,
  .pt-nextcard,
  .pt-qibla-card,
  .pt-city-card,
  .pt-table-shell,
  .pt-list-card,
  .pt-faq-card{ border-radius:18px; }
}


/* =========================================================
   Qibla compass modal
   ========================================================= */
.pt-hero-metric-value-row{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
.pt-qibla-open{
  appearance:none;
  border:1px solid var(--pt-line);
  background:var(--pt-pill);
  color:var(--pt-text);
  border-radius:999px;
  padding:5px 10px;
  cursor:pointer;
  font-size:12px;
  font-weight:700;
  line-height:1;
}
.pt-qibla-open:hover{ background:var(--pt-pill-hover); }

body.pt-modal-open{ overflow:hidden; }
.pt-qibla-modal[hidden]{ display:none !important; }
.pt-qibla-modal{
  position:fixed;
  inset:0;
  z-index:99999;
}
.pt-qibla-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(2,6,23,.58);
  backdrop-filter:blur(4px);
}
.pt-qibla-modal-dialog{
  position:relative;
  width:min(520px, calc(100% - 24px));
  margin: max(24px, env(safe-area-inset-top, 0px)) auto 24px;
  background:var(--pt-card);
  color:var(--pt-text);
  border:1px solid var(--pt-line);
  border-radius:22px;
  box-shadow:0 26px 70px rgba(15,23,42,.25);
  padding:18px;
}
.pt-qibla-modal-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}
.pt-qibla-live{
  margin-top:14px;
}
.pt-compass-live{
  width:160px;
  height:160px;
  margin:0 auto;
}
.pt-compass-live .pt-compass-ring{
  border-width:3px;
  background:radial-gradient(circle at 50% 50%, rgba(201,169,97,.16), transparent 58%), radial-gradient(circle at 30% 30%, rgba(201,169,97,.12), transparent 64%);
  box-shadow: inset 0 0 0 10px rgba(255,255,255,.02);
}
.pt-compass-arrow{
  transform:translate(-50%, -88%) rotate(0deg);
  transition:transform .12s linear;
}
.pt-compass-cardinal{
  position:absolute;
  font-size:11px;
  font-weight:900;
  color:var(--pt-muted);
  letter-spacing:.08em;
}
.pt-compass-cardinal-n{ left:50%; top:8px; transform:translateX(-50%); }
.pt-compass-cardinal-e{ right:10px; top:50%; transform:translateY(-50%); }
.pt-compass-cardinal-s{ left:50%; bottom:8px; transform:translateX(-50%); }
.pt-compass-cardinal-w{ left:10px; top:50%; transform:translateY(-50%); }
.pt-compass-destination{
  position:absolute;
  left:50%;
  top:8px;
  transform:translateX(-50%);
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:4px;
  z-index:3;
  pointer-events:none;
}
.pt-compass-destination-kaaba{
  position:relative;
  width:16px;
  height:18px;
  display:block;
  filter:drop-shadow(0 4px 10px rgba(0,0,0,.18));
}
.pt-compass-destination-label{
  padding:3px 8px;
  border-radius:999px;
  background:rgba(22,163,74,.95);
  color:#fff;
  font-size:10px;
  font-weight:800;
  letter-spacing:.02em;
  line-height:1.2;
  box-shadow:0 8px 18px rgba(22,163,74,.18);
}

.pt-qibla-stats-live{
  grid-template-columns:repeat(2, minmax(0, 1fr));
  margin-top:14px;
}
.pt-qibla-status{
  margin-top:12px;
  border:1px solid var(--pt-line);
  border-radius:14px;
  padding:12px 14px;
  background:rgba(255,255,255,.02);
  font-size:13px;
  color:var(--pt-text);
}
.pt-qibla-status[data-state="ok"]{
  border-color:rgba(201,169,97,.32);
  background:rgba(201,169,97,.10);
}
.pt-qibla-status[data-state="warn"]{
  border-color:rgba(245,158,11,.28);
  background:rgba(245,158,11,.08);
}
.pt-qibla-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:14px;
}
@media (max-width: 640px){
  .pt-qibla-modal-dialog{
    width:calc(100% - 16px);
    margin:12px auto;
    padding:14px;
    border-radius:18px;
  }
  .pt-compass-live{
    width:144px;
    height:144px;
  }
  .pt-qibla-stats-live{
    grid-template-columns:1fr;
  }
  .pt-qibla-actions .pt-btn{ flex:1 1 auto; }
}

/* Qibla quick link in hero */
.pt-hero-actions{
  display:flex;
  align-items:center;
  gap:10px;
}
.pt-quick-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:40px;
  padding:0 14px;
  border-radius:999px;
  border:1px solid var(--pt-border);
  background:var(--pt-surface-2);
  color:var(--pt-text);
  text-decoration:none;
  font-weight:700;
  font-size:14px;
  white-space:nowrap;
}
.pt-quick-link:hover{
  background:var(--pt-pill-hover);
}

/* Makkah marker on compass */
.pt-compass-mecca{
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:3;
}
.pt-compass-mecca-node{
  position:absolute;
  top:16px;
  left:50%;
  width:12px;
  height:12px;
  border-radius:50%;
  background:#16a34a;
  box-shadow:0 0 0 4px rgba(22,163,74,.16);
  transform:translateX(-50%);
}
.pt-compass-mecca-label{
  position:absolute;
  top:32px;
  left:50%;
  transform:translateX(-50%);
  padding:4px 8px;
  border-radius:999px;
  background:#16a34a;
  color:#fff;
  font-size:11px;
  font-weight:800;
  letter-spacing:.02em;
  box-shadow:0 10px 20px rgba(22,163,74,.18);
}

/* Standalone qibla page */
.pt-qibla-page-card{
  overflow:hidden;
}
.pt-qibla-live-page{
  gap:24px;
}
.pt-compass-page{
  width:min(100%, 360px);
  height:auto;
  aspect-ratio:1 / 1;
  margin-inline:auto;
}

/* ── Gold halo — T6.3 ──────────────────────────────────────────────── */

/* Halo animé autour de la grande compass Qibla */
.pt-compass-page.pt-compass-live {
  position: relative;
}

.pt-compass-page.pt-compass-live::before,
.pt-compass-page.pt-compass-live::after {
  content: "";
  position: absolute;
  inset: -18px;
  border-radius: 50%;
  pointer-events: none;
}

/* Halo extérieur — pulse lent */
.pt-compass-page.pt-compass-live::before {
  background: radial-gradient(circle, rgba(201, 169, 97, 0.12) 0%, transparent 65%);
  animation: ptQiblaHaloOuter 3.5s ease-in-out infinite;
}

/* Halo intérieur — bordure or fine */
.pt-compass-page.pt-compass-live::after {
  inset: -6px;
  border: 1px solid rgba(201, 169, 97, 0.22);
  background: transparent;
  animation: ptQiblaHaloInner 3.5s ease-in-out infinite 0.4s;
}

@keyframes ptQiblaHaloOuter {
  0%, 100% { opacity: 0.6; transform: scale(1);    }
  50%       { opacity: 1;   transform: scale(1.04); }
}

@keyframes ptQiblaHaloInner {
  0%, 100% { opacity: 0.4; }
  50%       { opacity: 0.9; }
}

/* Ring de la compass page — or */
.pt-compass-page .pt-compass-ring {
  border-color: rgba(201, 169, 97, 0.30);
  box-shadow:
    0 0 0 1px rgba(201, 169, 97, 0.10),
    inset 0 0 40px rgba(201, 169, 97, 0.05);
}

/* Active (compass on) : halo plus intense */
.pt-compass-page.is-active::before {
  background: radial-gradient(circle, rgba(201, 169, 97, 0.22) 0%, transparent 62%);
}

.pt-compass-page.is-active::after {
  border-color: rgba(201, 169, 97, 0.45);
}

@media (prefers-reduced-motion: reduce) {
  .pt-compass-page.pt-compass-live::before,
  .pt-compass-page.pt-compass-live::after {
    animation: none;
  }
}

@media (max-width: 640px){
  .pt-hero-actions{
    width:100%;
    justify-content:space-between;
  }
  .pt-quick-link{
    flex:1 1 auto;
    min-width:0;
    padding-inline:12px;
  }
}


/* Premium Kaaba center + fullscreen mobile qibla */
.pt-compass-center{
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%, -50%);
  width:34px;
  height:34px;
  border-radius:50%;
  z-index:4;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,255,255,.95);
  box-shadow:0 8px 20px rgba(15,23,42,.18), 0 0 0 6px rgba(255,255,255,.16);
}
html[data-pt-theme="dark"] .pt-compass-center{
  background:rgba(15,23,42,.92);
  box-shadow:0 8px 20px rgba(0,0,0,.35), 0 0 0 6px rgba(255,255,255,.08);
}
.pt-compass-kaaba{
  position:relative;
  width:18px;
  height:20px;
  display:block;
  filter:drop-shadow(0 2px 4px rgba(0,0,0,.16));
}
.pt-compass-kaaba-top{
  position:absolute;
  left:1px;
  top:1px;
  width:16px;
  height:3px;
  border-radius:2px 2px 0 0;
  background:linear-gradient(90deg,#d4af37,#f8d66d,#c99a15);
}
.pt-compass-kaaba-body{
  position:absolute;
  left:2px;
  top:4px;
  width:14px;
  height:14px;
  border-radius:2px;
  background:linear-gradient(180deg,#2f3338 0%, #0f1114 100%);
}
.pt-compass-kaaba-gold{
  position:absolute;
  left:2px;
  top:8px;
  width:14px;
  height:2px;
  border-radius:2px;
  background:linear-gradient(90deg,#d4af37,#f7dc85,#c89d1d);
}
.pt-compass-page .pt-compass-center{
  width:48px;
  height:48px;
}
.pt-compass-page .pt-compass-kaaba{
  width:24px;
  height:26px;
}
.pt-compass-page .pt-compass-kaaba-top{ left:1px; top:1px; width:22px; height:4px; }
.pt-compass-page .pt-compass-kaaba-body{ left:3px; top:5px; width:18px; height:18px; }
.pt-compass-page .pt-compass-kaaba-gold{ left:3px; top:11px; width:18px; height:2px; }

.pt-qibla-live-page .pt-compass-page{
  position:relative;
  background:radial-gradient(circle at 50% 50%, rgba(201,169,97,.10), rgba(201,169,97,0) 56%);
}
.pt-qibla-live-page .pt-compass-page::after{ content:none; }

@media (max-width: 640px){
  [data-pt-page="qibla"] .pt-wrap{
    width:100%;
    max-width:none;
    padding-inline:0;
  }
  [data-pt-page="qibla"] .pt-card-hero:first-child{
    border-radius:0 0 24px 24px;
  }
  .pt-qibla-page-card{
    border-radius:28px 28px 0 0;
    min-height:calc(100svh - 108px);
    margin-bottom:0;
    padding-bottom:max(18px, env(safe-area-inset-bottom, 0px));
  }
  .pt-qibla-live-page{
    min-height:calc(100svh - 220px);
    display:flex;
    flex-direction:column;
    justify-content:space-between;
    gap:18px;
  }
  .pt-compass-page{
    width:min(100%, 86vw);
  }
  .pt-qibla-live-page .pt-compass-page{
    margin-top:8px;
  }
  .pt-qibla-actions{
    position:sticky;
    bottom:max(8px, env(safe-area-inset-bottom, 0px));
    z-index:6;
    padding:10px;
    border-radius:18px;
    background:rgba(255,255,255,.88);
    backdrop-filter:blur(12px);
    box-shadow:0 12px 32px rgba(15,23,42,.10);
  }
  html[data-pt-theme="dark"] .pt-qibla-actions{
    background:rgba(15,23,42,.82);
    box-shadow:0 12px 32px rgba(0,0,0,.28);
  }
}

.pt-compass-cardinal-n{ display:none; }
.pt-compass-page .pt-compass-destination{ top:12px; }
.pt-compass-page .pt-compass-destination-kaaba{ width:20px; height:22px; }
.pt-compass-page .pt-compass-destination-label{ font-size:11px; padding:4px 10px; }


/* v2.1.8 premium qibla marker polish */
.pt-compass-destination{top:10px;}
.pt-compass-destination-label{font-size:11px;padding:5px 12px;border:1px solid rgba(255,255,255,.18);background:linear-gradient(135deg,#22c55e,#16a34a);box-shadow:0 12px 24px rgba(22,163,74,.22);}
.pt-qibla-v{min-height:1.35em;}


/* =========================================================
   v2.2.0 — premium visual pass (global)
   ========================================================= */
:root{
  --pt-gold:#d4b062;
  --pt-gold-soft:rgba(212,176,98,.16);
  --pt-emerald:#2fd5c4;
  --pt-navy:#08162e;
}

.pt-page{
  background:
    radial-gradient(circle at top left, rgba(201,169,97,.14), transparent 22%),
    radial-gradient(circle at top right, rgba(212,176,98,.12), transparent 18%),
    linear-gradient(180deg, rgba(255,255,255,.96), rgba(242,247,255,.94));
}
html[data-pt-theme="dark"] .pt-page{
  background:
    radial-gradient(circle at top left, rgba(47,213,196,.10), transparent 24%),
    radial-gradient(circle at top right, rgba(212,176,98,.08), transparent 18%),
    linear-gradient(180deg, #071122 0%, #09172f 100%);
}

.pt-wrap{
  width:min(1180px, calc(100% - 28px));
}

.pt-card,
.pt-hero-metric,
.pt-info-card,
.pt-country-card,
.pt-city-pill,
.pt-city-card,
.pt-nextcard,
.pt-qibla-card,
.pt-list-card,
.pt-table-shell,
.pt-faq-card,
.pt-hadith-box,
.pt-qibla-page-card{
  box-shadow:0 18px 50px rgba(8,22,46,.08), inset 0 1px 0 rgba(255,255,255,.72);
}
html[data-pt-theme="dark"] .pt-card,
html[data-pt-theme="dark"] .pt-hero-metric,
html[data-pt-theme="dark"] .pt-info-card,
html[data-pt-theme="dark"] .pt-country-card,
html[data-pt-theme="dark"] .pt-city-pill,
html[data-pt-theme="dark"] .pt-city-card,
html[data-pt-theme="dark"] .pt-nextcard,
html[data-pt-theme="dark"] .pt-qibla-card,
html[data-pt-theme="dark"] .pt-list-card,
html[data-pt-theme="dark"] .pt-table-shell,
html[data-pt-theme="dark"] .pt-faq-card,
html[data-pt-theme="dark"] .pt-hadith-box,
html[data-pt-theme="dark"] .pt-qibla-page-card{
  box-shadow:0 26px 70px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.04);
}

.pt-hero-shell,
.pt-home-hero,
.pt-country-hero,
.pt-city-hero,
.pt-card-hero:first-child{
  position:relative;
  overflow:hidden;
}
.pt-home-hero,
.pt-country-hero,
.pt-city-hero,
.pt-qibla-page-card{
  background:
    radial-gradient(circle at top right, rgba(47,213,196,.18), transparent 28%),
    radial-gradient(circle at top left, rgba(212,176,98,.12), transparent 18%),
    linear-gradient(135deg, rgba(255,255,255,.92), rgba(247,250,255,.82));
}
html[data-pt-theme="dark"] .pt-home-hero,
html[data-pt-theme="dark"] .pt-country-hero,
html[data-pt-theme="dark"] .pt-city-hero,
html[data-pt-theme="dark"] .pt-qibla-page-card{
  background:
    radial-gradient(circle at top right, rgba(47,213,196,.18), transparent 28%),
    radial-gradient(circle at top left, rgba(212,176,98,.10), transparent 18%),
    linear-gradient(135deg, rgba(6,16,33,.96), rgba(10,24,49,.90));
}
.pt-hero-shell::after,
.pt-card-hero:first-child::after{
  content:"";
  position:absolute;
  inset:auto -10% -28% auto;
  width:280px;
  height:280px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(212,176,98,.10), transparent 68%);
  pointer-events:none;
}
.pt-card-hero:first-child{ border-radius:30px; }
.pt-card-hero:first-child::before{
  content:"";
  position:absolute;
  inset:1px;
  border-radius:29px;
  border:1px solid rgba(255,255,255,.55);
  pointer-events:none;
}
html[data-pt-theme="dark"] .pt-card-hero:first-child::before{ border-color:rgba(255,255,255,.06); }

.pt-breadcrumbs{
  font-size:13px;
  font-weight:700;
  letter-spacing:.01em;
}
.pt-breadcrumbs a{ color:var(--pt-brand); }
.pt-h1{
  font-size:clamp(34px, 4.2vw, 56px);
  line-height:1.02;
  font-weight:950;
  max-width:900px;
}
.pt-subtitle{
  max-width:860px;
  font-size:clamp(15px, 1.5vw, 19px);
  line-height:1.7;
}

.pt-icon-btn,
.pt-quick-link,
.pt-qibla-open{
  min-height:42px;
  border-radius:999px;
  backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.48);
  background:linear-gradient(180deg, rgba(255,255,255,.80), rgba(255,255,255,.58));
  box-shadow:0 12px 26px rgba(8,22,46,.08);
}
html[data-pt-theme="dark"] .pt-icon-btn,
html[data-pt-theme="dark"] .pt-quick-link,
html[data-pt-theme="dark"] .pt-qibla-open{
  border-color:rgba(255,255,255,.06);
  background:linear-gradient(180deg, rgba(16,31,57,.90), rgba(9,22,44,.82));
  box-shadow:0 14px 28px rgba(0,0,0,.24);
}
.pt-quick-link{
  color:var(--pt-text);
  font-weight:800;
  padding:0 16px;
}

.pt-btn{
  min-height:48px;
  padding:0 18px;
  border:0;
  border-radius:16px;
  background:linear-gradient(135deg, var(--pt-brand), var(--pt-brand-2));
  box-shadow:0 18px 38px rgba(201,169,97,.22);
}
.pt-btn.pt-btn-ghost{
  background:linear-gradient(180deg, rgba(255,255,255,.88), rgba(255,255,255,.62));
  color:var(--pt-text);
  border:1px solid rgba(15,23,42,.08);
  box-shadow:0 14px 32px rgba(8,22,46,.06);
}
html[data-pt-theme="dark"] .pt-btn.pt-btn-ghost{
  background:linear-gradient(180deg, rgba(16,31,57,.90), rgba(9,22,44,.82));
  border-color:rgba(255,255,255,.06);
  box-shadow:0 16px 34px rgba(0,0,0,.24);
}

.pt-search{
  min-height:64px;
  padding:14px 16px;
  border-radius:20px;
}
.pt-search input{ font-size:16px; }

.pt-badge{
  padding:9px 12px;
  background:linear-gradient(180deg, rgba(255,255,255,.78), rgba(255,255,255,.62));
  border:1px solid rgba(15,23,42,.08);
  color:var(--pt-text);
  font-weight:700;
}
html[data-pt-theme="dark"] .pt-badge{
  background:linear-gradient(180deg, rgba(16,31,57,.94), rgba(9,22,44,.84));
  border-color:rgba(255,255,255,.06);
}

.pt-hero-metric{
  padding:18px;
  border-radius:20px;
  background:
    linear-gradient(145deg, rgba(201,169,97,.10), rgba(47,213,196,0) 45%),
    linear-gradient(180deg, rgba(255,255,255,.90), rgba(255,255,255,.70));
}
html[data-pt-theme="dark"] .pt-hero-metric{
  background:
    linear-gradient(145deg, rgba(201,169,97,.14), rgba(47,213,196,0) 45%),
    linear-gradient(180deg, rgba(13,29,54,.96), rgba(9,21,44,.86));
}
.pt-hero-metric strong{
  font-size:20px;
  font-weight:950;
}

.pt-premium-tile{
  min-height:150px;
  padding:18px;
  border-radius:24px;
  background:
    linear-gradient(145deg, rgba(201,169,97,.14), rgba(47,213,196,0) 48%),
    linear-gradient(180deg, rgba(255,255,255,.94), rgba(247,250,255,.84));
}
html[data-pt-theme="dark"] .pt-premium-tile{
  background:
    linear-gradient(145deg, rgba(201,169,97,.16), rgba(47,213,196,0) 48%),
    linear-gradient(180deg, rgba(13,29,54,.96), rgba(9,21,44,.88));
}
.pt-premium-tile-kicker,
.pt-section-kicker{
  color:var(--pt-gold);
  border-color:rgba(212,176,98,.24);
  background:rgba(212,176,98,.10);
}

.pt-country-card,
.pt-city-card,
.pt-city-pill,
.pt-hadith-box,
.pt-info-card,
.pt-nextcard,
.pt-list-card,
.pt-table-shell,
.pt-faq-card,
.pt-qibla-card,
.pt-qibla-stat{
  background:
    linear-gradient(145deg, rgba(201,169,97,.08), rgba(47,213,196,0) 46%),
    linear-gradient(180deg, rgba(255,255,255,.94), rgba(247,250,255,.84));
}
html[data-pt-theme="dark"] .pt-country-card,
html[data-pt-theme="dark"] .pt-city-card,
html[data-pt-theme="dark"] .pt-city-pill,
html[data-pt-theme="dark"] .pt-hadith-box,
html[data-pt-theme="dark"] .pt-info-card,
html[data-pt-theme="dark"] .pt-nextcard,
html[data-pt-theme="dark"] .pt-list-card,
html[data-pt-theme="dark"] .pt-table-shell,
html[data-pt-theme="dark"] .pt-faq-card,
html[data-pt-theme="dark"] .pt-qibla-card,
html[data-pt-theme="dark"] .pt-qibla-stat{
  background:
    linear-gradient(145deg, rgba(201,169,97,.10), rgba(47,213,196,0) 46%),
    linear-gradient(180deg, rgba(13,29,54,.96), rgba(9,21,44,.86));
}

.pt-table-wrap,
.pt-table-shell{ border-radius:22px; overflow:hidden; }
.pt-table{ background:transparent; }
.pt-table thead th{ background:rgba(8,22,46,.04); }
html[data-pt-theme="dark"] .pt-table thead th{ background:rgba(255,255,255,.03); }

.pt-home-suggest{
  margin-top:10px;
  display:grid;
  gap:10px;
}
.pt-suggest-item{
  display:block;
  padding:14px 16px;
  border-radius:18px;
  border:1px solid var(--pt-line);
  text-decoration:none;
  color:var(--pt-text);
  background:linear-gradient(180deg, rgba(255,255,255,.92), rgba(247,250,255,.84));
  box-shadow:0 12px 28px rgba(8,22,46,.06);
}
.pt-suggest-item:hover{ transform:translateY(-1px); }
html[data-pt-theme="dark"] .pt-suggest-item{
  background:linear-gradient(180deg, rgba(13,29,54,.96), rgba(9,21,44,.86));
  box-shadow:0 16px 34px rgba(0,0,0,.22);
}
.pt-suggest-type{
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:var(--pt-gold);
  font-weight:900;
}
.pt-suggest-label{
  margin-top:4px;
  font-size:15px;
  font-weight:850;
}

.pt-home-glance-grid,
.pt-directory-glance-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:14px;
  margin-top:16px;
}
.pt-glance-card{
  padding:18px;
  border-radius:22px;
  border:1px solid var(--pt-line);
  background:
    linear-gradient(145deg, rgba(212,176,98,.10), rgba(212,176,98,0) 44%),
    linear-gradient(180deg, rgba(255,255,255,.94), rgba(247,250,255,.84));
}
html[data-pt-theme="dark"] .pt-glance-card{
  background:
    linear-gradient(145deg, rgba(212,176,98,.12), rgba(212,176,98,0) 44%),
    linear-gradient(180deg, rgba(13,29,54,.96), rgba(9,21,44,.86));
}
.pt-glance-kicker{
  display:block;
  font-size:11px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--pt-gold);
  font-weight:900;
}
.pt-glance-value{
  margin-top:10px;
  font-size:24px;
  font-weight:950;
  letter-spacing:-.03em;
}
.pt-glance-copy{
  margin-top:8px;
  font-size:13px;
  line-height:1.65;
  color:var(--pt-muted);
}

.pt-country-directory-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:14px;
  margin-top:16px;
}
.pt-country-directory-card{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  padding:18px;
  border-radius:22px;
  border:1px solid var(--pt-line);
  text-decoration:none;
  color:var(--pt-text);
  background:
    linear-gradient(145deg, rgba(201,169,97,.10), rgba(47,213,196,0) 44%),
    linear-gradient(180deg, rgba(255,255,255,.94), rgba(247,250,255,.84));
  box-shadow:0 14px 34px rgba(8,22,46,.06);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.pt-country-directory-card:hover{
  transform:translateY(-3px);
  box-shadow:0 16px 40px rgba(8,22,46,.12);
  border-color:rgba(201,169,97,.35);
  color: var(--pt-brand);
}

/* ── Continent filter pills — A5 ───────────────────────────────────── */
.pt-continent-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 14px 0 0;
}

.pt-continent-btn {
  appearance: none;
  padding: 6px 16px;
  border-radius: 999px;
  border: 1px solid var(--pt-line);
  background: var(--pt-pill);
  color: var(--pt-muted);
  font-family: var(--pt-font-body);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: border-color 0.18s, background 0.18s, color 0.18s;
  line-height: 1.3;
}

.pt-continent-btn:hover {
  border-color: rgba(201, 169, 97, 0.3);
  color: var(--pt-brand);
  background: rgba(201, 169, 97, 0.06);
}

.pt-continent-btn.is-active {
  background: rgba(201, 169, 97, 0.12);
  border-color: rgba(201, 169, 97, 0.45);
  color: var(--pt-brand);
  font-weight: 600;
}

@media (prefers-reduced-motion: reduce) {
  .pt-continent-btn { transition: none; }
}
html[data-pt-theme="dark"] .pt-country-directory-card{
  background:
    linear-gradient(145deg, rgba(201,169,97,.12), rgba(47,213,196,0) 44%),
    linear-gradient(180deg, rgba(13,29,54,.96), rgba(9,21,44,.86));
  box-shadow:0 18px 40px rgba(0,0,0,.24);
}
.pt-country-directory-meta{ display:flex; flex-direction:column; gap:6px; }
.pt-country-directory-name{ font-size:18px; font-weight:900; letter-spacing:-.02em; }
.pt-country-directory-sub{ font-size:13px; color:var(--pt-muted); }
.pt-country-directory-iso{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:48px;
  height:40px;
  padding:0 12px;
  border-radius:999px;
  background:var(--pt-gold-soft);
  color:var(--pt-gold);
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.pt-section-copy{
  max-width:760px;
  font-size:15px;
  line-height:1.7;
  color:var(--pt-muted);
}
.pt-home-utility-bar{
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:12px;
  margin-top:18px;
}
.pt-utility-pill{
  padding:14px 16px;
  border-radius:18px;
  border:1px solid var(--pt-line);
  background:linear-gradient(180deg, rgba(255,255,255,.90), rgba(247,250,255,.82));
  box-shadow:0 12px 30px rgba(8,22,46,.05);
}
.pt-utility-pill strong{ display:block; font-size:14px; font-weight:900; }
.pt-utility-pill span{ display:block; margin-top:6px; font-size:12px; color:var(--pt-muted); }
html[data-pt-theme="dark"] .pt-utility-pill{ background:linear-gradient(180deg, rgba(13,29,54,.96), rgba(9,21,44,.86)); }

.pt-home-cta-row,
.pt-directory-cta-row{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
  margin-top:18px;
}

.pt-page[data-pt-page="qibla"] .pt-hero-metric strong,
.pt-page[data-pt-page="city"] .pt-hero-metric strong,
.pt-page[data-pt-page="country"] .pt-hero-metric strong,
.pt-page[data-pt-page="home"] .pt-hero-metric strong{ display:block; }

.pt-qibla-page-card .pt-section-head,
.pt-city-hero .pt-section-head,
.pt-country-hero .pt-section-head,
.pt-home-hero .pt-section-head{ margin-bottom:16px; }

.pt-info-card-time{
  background:
    radial-gradient(circle at top right, rgba(47,213,196,.14), transparent 42%),
    linear-gradient(180deg, rgba(255,255,255,.94), rgba(247,250,255,.84));
}
html[data-pt-theme="dark"] .pt-info-card-time{
  background:
    radial-gradient(circle at top right, rgba(47,213,196,.16), transparent 42%),
    linear-gradient(180deg, rgba(13,29,54,.96), rgba(9,21,44,.86));
}

.pt-qibla-page-card .pt-qibla-status,
.pt-qibla-modal .pt-qibla-status{
  line-height:1.75;
  font-size:14px;
}

@media (max-width: 980px){
  .pt-home-glance-grid,
  .pt-directory-glance-grid,
  .pt-country-directory-grid,
  .pt-home-utility-bar{ grid-template-columns:repeat(2, minmax(0,1fr)); }
}
@media (max-width: 640px){
  .pt-wrap{ width:min(100%, calc(100% - 18px)); }
  .pt-page{ padding:18px 0 34px; }
  .pt-card-hero:first-child{ border-radius:24px; }
  .pt-card-hero:first-child::before{ border-radius:23px; }
  .pt-h1{ font-size:34px; line-height:1.06; }
  .pt-subtitle{ font-size:16px; line-height:1.65; }
  .pt-home-glance-grid,
  .pt-directory-glance-grid,
  .pt-country-directory-grid,
  .pt-home-utility-bar{ grid-template-columns:1fr; }
  .pt-hero-actions{ width:100%; }
  .pt-quick-link, .pt-icon-btn{ flex:1 1 auto; }
  .pt-icon-btn{ max-width:60px; }
  .pt-hero-metric{ padding:16px; }
  .pt-glance-card,
  .pt-country-directory-card,
  .pt-utility-pill{ padding:16px; border-radius:18px; }
}


/* =========================================================
   v2.2.2 — visual refinement only
   ========================================================= */
:root{
  --pt-luxe-bg-1: rgba(15, 38, 76, .16);
  --pt-luxe-bg-2: rgba(42, 161, 152, .12);
  --pt-luxe-bg-3: rgba(212, 176, 98, .10);
  --pt-luxe-edge: rgba(255,255,255,.52);
  --pt-luxe-edge-dark: rgba(255,255,255,.08);
  --pt-luxe-shadow: 0 24px 80px rgba(8,22,46,.10);
  --pt-luxe-shadow-dark: 0 28px 90px rgba(0,0,0,.34);
}

.pt-page{
  position:relative;
  isolation:isolate;
  background:
    radial-gradient(circle at 12% 0%, var(--pt-luxe-bg-2), transparent 28%),
    radial-gradient(circle at 100% 18%, var(--pt-luxe-bg-3), transparent 26%),
    radial-gradient(circle at 50% 100%, var(--pt-luxe-bg-1), transparent 34%),
    var(--pt-bg);
}
.pt-page::before{
  content:"";
  position:fixed;
  inset:0;
  z-index:-1;
  pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.015), rgba(255,255,255,0)),
    radial-gradient(circle at 1px 1px, rgba(255,255,255,.05) 1px, transparent 0);
  background-size:100% 100%, 18px 18px;
  opacity:.55;
}
html[data-pt-theme="dark"] .pt-page::before{ opacity:.34; }

.pt-wrap{ width:min(1160px, calc(100% - 28px)); }

.pt-card,
.pt-hero-shell,
.pt-surface-card,
.pt-table-shell,
.pt-qibla-page-card,
.pt-list-card,
.pt-faq-card,
.pt-country-directory-card,
.pt-country-card,
.pt-city-card,
.pt-city-pill,
.pt-hadith-box,
.pt-nextcard,
.pt-qibla-card,
.pt-hero-metric,
.pt-info-card,
.pt-glance-card,
.pt-utility-pill,
.pt-premium-tile,
.pt-suggest-item{
  backdrop-filter: blur(18px) saturate(135%);
  -webkit-backdrop-filter: blur(18px) saturate(135%);
}

.pt-card-hero,
.pt-surface-card,
.pt-table-shell,
.pt-qibla-page-card,
.pt-list-card,
.pt-faq-card{
  box-shadow: var(--pt-luxe-shadow);
}
html[data-pt-theme="dark"] .pt-card-hero,
html[data-pt-theme="dark"] .pt-surface-card,
html[data-pt-theme="dark"] .pt-table-shell,
html[data-pt-theme="dark"] .pt-qibla-page-card,
html[data-pt-theme="dark"] .pt-list-card,
html[data-pt-theme="dark"] .pt-faq-card{
  box-shadow: var(--pt-luxe-shadow-dark);
}

.pt-hero-shell{
  overflow:hidden;
  position:relative;
}
.pt-hero-shell::after{
  content:"";
  position:absolute;
  inset:-1px;
  pointer-events:none;
  border-radius:inherit;
  background:
    radial-gradient(circle at top right, rgba(212,176,98,.16), transparent 22%),
    radial-gradient(circle at left center, rgba(201,169,97,.14), transparent 22%);
  mix-blend-mode:screen;
  opacity:.9;
}
html[data-pt-theme="dark"] .pt-hero-shell::after{ opacity:.6; }

.pt-card-hero{ padding:34px; }
.pt-hero-top{ margin-bottom:16px; }
.pt-breadcrumbs, .pt-breadcrumb{ font-size:13px; gap:8px; }
.pt-breadcrumbs a, .pt-breadcrumb a{ opacity:.88; }
.pt-breadcrumbs a:hover, .pt-breadcrumb a:hover{ opacity:1; }

.pt-h1{
  font-size: clamp(34px, 4.3vw, 58px);
  line-height:1.02;
  font-weight:900;
  margin-bottom:10px;
  max-width:12ch;
  text-wrap:balance;
}
.pt-city-hero .pt-h1,
.pt-country-hero .pt-h1{ max-width:16ch; }
.pt-subtitle{
  max-width:74ch;
  font-size:16px;
  line-height:1.75;
  margin-bottom:20px;
}

.pt-section-kicker,
.pt-premium-tile-kicker,
.pt-glance-kicker,
.pt-next-title,
.pt-info-label,
.pt-qibla-k,
.pt-table thead th{
  font-size:11px;
  letter-spacing:.12em;
  text-transform:uppercase;
}

.pt-quick-link,
.pt-icon-btn,
.pt-btn,
.pt-btn.pt-btn-ghost,
.pt-qibla-open{
  min-height:44px;
  border-radius:15px;
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease, background .16s ease;
}
.pt-quick-link:hover,
.pt-icon-btn:hover,
.pt-btn:hover,
.pt-btn.pt-btn-ghost:hover,
.pt-qibla-open:hover{
  transform: translateY(-1px);
}
.pt-quick-link,
.pt-btn.pt-btn-ghost,
.pt-qibla-open{
  border:1px solid rgba(201,169,97,.16);
  background:linear-gradient(180deg, rgba(255,255,255,.82), rgba(247,250,255,.70));
  box-shadow:0 12px 28px rgba(8,22,46,.05);
}
html[data-pt-theme="dark"] .pt-quick-link,
html[data-pt-theme="dark"] .pt-btn.pt-btn-ghost,
html[data-pt-theme="dark"] .pt-qibla-open{
  background:linear-gradient(180deg, rgba(15,29,54,.92), rgba(10,22,42,.84));
  box-shadow:0 14px 32px rgba(0,0,0,.18);
  border-color:rgba(255,255,255,.08);
}
.pt-btn{
  box-shadow:0 14px 34px rgba(201,169,97,.22);
}

.pt-home-glance-grid,
.pt-directory-glance-grid,
.pt-info-grid,
.pt-nextwrap,
.pt-grid-2,
.pt-country-grid,
.pt-country-directory-grid,
.pt-premium-tiles,
.pt-library-grid{ gap:16px; }

.pt-glance-card,
.pt-utility-pill,
.pt-hero-metric,
.pt-info-card,
.pt-nextcard,
.pt-qibla-card,
.pt-country-card,
.pt-city-card,
.pt-hadith-box,
.pt-list-card,
.pt-faq-card,
.pt-table-shell,
.pt-country-directory-card{
  position:relative;
  overflow:hidden;
}
.pt-glance-card::before,
.pt-utility-pill::before,
.pt-hero-metric::before,
.pt-info-card::before,
.pt-nextcard::before,
.pt-qibla-card::before,
.pt-country-card::before,
.pt-city-card::before,
.pt-hadith-box::before,
.pt-list-card::before,
.pt-faq-card::before,
.pt-table-shell::before,
.pt-country-directory-card::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  border-radius:inherit;
  border:1px solid rgba(255,255,255,.42);
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask-composite: exclude;
  -webkit-mask-composite: xor;
  padding:1px;
  opacity:.45;
}
html[data-pt-theme="dark"] .pt-glance-card::before,
html[data-pt-theme="dark"] .pt-utility-pill::before,
html[data-pt-theme="dark"] .pt-hero-metric::before,
html[data-pt-theme="dark"] .pt-info-card::before,
html[data-pt-theme="dark"] .pt-nextcard::before,
html[data-pt-theme="dark"] .pt-qibla-card::before,
html[data-pt-theme="dark"] .pt-country-card::before,
html[data-pt-theme="dark"] .pt-city-card::before,
html[data-pt-theme="dark"] .pt-hadith-box::before,
html[data-pt-theme="dark"] .pt-list-card::before,
html[data-pt-theme="dark"] .pt-faq-card::before,
html[data-pt-theme="dark"] .pt-table-shell::before,
html[data-pt-theme="dark"] .pt-country-directory-card::before{
  border-color:rgba(255,255,255,.08);
  opacity:.7;
}

.pt-hero-metrics{
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:14px;
  margin-top:18px;
}
.pt-hero-metric{
  min-height:114px;
  padding:18px 18px 16px;
  background:
    radial-gradient(circle at top right, rgba(201,169,97,.16), transparent 36%),
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(247,250,255,.84));
}
html[data-pt-theme="dark"] .pt-hero-metric{
  background:
    radial-gradient(circle at top right, rgba(201,169,97,.18), transparent 38%),
    linear-gradient(180deg, rgba(14,29,55,.98), rgba(10,22,44,.88));
}
.pt-hero-metric-label{ display:block; margin-bottom:10px; font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--pt-muted); }
.pt-hero-metric strong{ font-size:22px; line-height:1.18; }
.pt-hero-metric-value-row{ align-items:flex-end; justify-content:space-between; }

.pt-meta-row{ gap:10px; }
.pt-badge{
  padding:8px 12px;
  border-radius:999px;
  background:linear-gradient(180deg, rgba(255,255,255,.82), rgba(248,250,255,.68));
  box-shadow:0 10px 24px rgba(8,22,46,.04);
}
html[data-pt-theme="dark"] .pt-badge{
  background:linear-gradient(180deg, rgba(15,29,54,.92), rgba(10,22,42,.84));
  box-shadow:0 12px 28px rgba(0,0,0,.16);
}

.pt-info-card{ padding:18px; min-height:180px; }
.pt-info-value{ font-size:28px; line-height:1.15; }
.pt-info-sub{ line-height:1.65; }
.pt-info-card-time .pt-info-value,
.pt-local-time{ font-size:clamp(42px, 4vw, 64px); letter-spacing:.06em; }

.pt-countdown-card{
  padding:22px;
  min-height:100%;
}
.pt-next-main{ font-size:18px; }
.pt-next-countdown{ font-size:clamp(42px, 5vw, 72px); }
.pt-progress-bar{ height:12px; border-radius:999px; }
.pt-progress-fill{
  background:linear-gradient(90deg, rgba(201,169,97,.90), rgba(212,176,98,.86));
  box-shadow:0 10px 24px rgba(201,169,97,.28);
}
.pt-dot{
  min-height:74px;
  padding:0 14px;
  font-size:15px;
  font-weight:800;
  display:flex;
  align-items:center;
  justify-content:center;
}
.pt-dot:hover{ transform:translateY(-1px); }

.pt-table-wrap{ padding:0; overflow:visible; }
.pt-table-shell{ padding:12px; }
.pt-table{ border-collapse:separate; border-spacing:0 10px; }
.pt-table thead th{
  padding:0 18px 6px;
  border:0;
  background:transparent !important;
}
.pt-table tbody tr{
  box-shadow:0 8px 22px rgba(8,22,46,.05);
}
.pt-table td{
  padding:16px 18px;
  border-top:1px solid rgba(15,23,42,.06);
  border-bottom:1px solid rgba(15,23,42,.06);
  background:linear-gradient(180deg, rgba(255,255,255,.88), rgba(248,250,255,.78));
}
.pt-table td:first-child{
  border-left:1px solid rgba(15,23,42,.06);
  border-top-left-radius:16px;
  border-bottom-left-radius:16px;
}
.pt-table td:last-child{
  border-right:1px solid rgba(15,23,42,.06);
  border-top-right-radius:16px;
  border-bottom-right-radius:16px;
}
html[data-pt-theme="dark"] .pt-table td{
  background:linear-gradient(180deg, rgba(15,29,54,.94), rgba(10,22,42,.88));
  border-color:rgba(255,255,255,.06);
}
html[data-pt-theme="dark"] .pt-table td:first-child,
html[data-pt-theme="dark"] .pt-table td:last-child{ border-color:rgba(255,255,255,.06); }
.pt-table tbody tr.pt-is-next td{
  background:
    radial-gradient(circle at top right, rgba(212,176,98,.16), transparent 46%),
    linear-gradient(180deg, rgba(201,169,97,.12), rgba(255,255,255,.90));
}
html[data-pt-theme="dark"] .pt-table tbody tr.pt-is-next td{
  background:
    radial-gradient(circle at top right, rgba(212,176,98,.14), transparent 46%),
    linear-gradient(180deg, rgba(26,66,73,.62), rgba(12,27,48,.94));
}

.pt-prayer-ico{
  width:46px;
  height:46px;
  border-radius:16px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.52), 0 8px 18px rgba(201,169,97,.10);
}
html[data-pt-theme="dark"] .pt-prayer-ico{
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06), 0 8px 18px rgba(0,0,0,.18);
}
.pt-prayer-name{ font-size:15px; }

.pt-city-pill,
.pt-country-card,
.pt-country-directory-card,
.pt-premium-tile,
.pt-hadith-box{
  min-height:100px;
}
.pt-premium-tile strong,
.pt-country-directory-name,
.pt-country-name,
.pt-city-name{ font-size:20px; }
.pt-premium-tile span:last-child,
.pt-country-directory-sub,
.pt-glance-copy,
.pt-section-copy,
.pt-utility-pill span,
.pt-hadith-box .pt-muted,
.pt-city-meta,
.pt-footer-note{ line-height:1.7; }

.pt-country-directory-card,
.pt-country-card,
.pt-premium-tile,
.pt-hadith-box,
.pt-city-card,
.pt-city-pill{
  box-shadow:0 18px 42px rgba(8,22,46,.08);
}
html[data-pt-theme="dark"] .pt-country-directory-card,
html[data-pt-theme="dark"] .pt-country-card,
html[data-pt-theme="dark"] .pt-premium-tile,
html[data-pt-theme="dark"] .pt-hadith-box,
html[data-pt-theme="dark"] .pt-city-card,
html[data-pt-theme="dark"] .pt-city-pill{
  box-shadow:0 18px 42px rgba(0,0,0,.24);
}
.pt-country-directory-card:hover,
.pt-country-card:hover,
.pt-premium-tile:hover,
.pt-hadith-box:hover,
.pt-city-card:hover,
.pt-city-pill:hover{
  transform:translateY(-5px);
  border-color:rgba(201,169,97,.18);
}

.pt-qibla-page-card,
.pt-qibla-modal-dialog{
  background:
    radial-gradient(circle at top right, rgba(212,176,98,.12), transparent 28%),
    radial-gradient(circle at left center, rgba(201,169,97,.12), transparent 26%),
    linear-gradient(180deg, rgba(255,255,255,.95), rgba(247,250,255,.86));
}
html[data-pt-theme="dark"] .pt-qibla-page-card,
html[data-pt-theme="dark"] .pt-qibla-modal-dialog{
  background:
    radial-gradient(circle at top right, rgba(212,176,98,.10), transparent 28%),
    radial-gradient(circle at left center, rgba(201,169,97,.12), transparent 26%),
    linear-gradient(180deg, rgba(10,22,42,.97), rgba(9,20,40,.92));
}

@media (max-width: 1080px){
  .pt-hero-metrics{ grid-template-columns:repeat(2, minmax(0,1fr)); }
}
@media (max-width: 640px){
  .pt-wrap{ width:min(100%, calc(100% - 16px)); }
  .pt-card-hero{ padding:22px; }
  .pt-h1{ font-size:40px; max-width:100%; }
  .pt-subtitle{ font-size:15px; line-height:1.7; }
  .pt-hero-actions{ width:100%; }
  .pt-quick-link, .pt-icon-btn, .pt-btn, .pt-btn.pt-btn-ghost{ width:100%; justify-content:center; }
  .pt-icon-btn{ max-width:none; }
  .pt-hero-metrics{ grid-template-columns:1fr; gap:12px; }
  .pt-hero-metric{ min-height:auto; padding:16px; }
  .pt-info-card{ min-height:auto; padding:16px; }
  .pt-table-shell{ padding:10px; }
  .pt-table{ border-spacing:0 8px; }
  .pt-table td{ padding:14px 12px; }
  .pt-prayer-ico{ width:40px; height:40px; border-radius:14px; }
  .pt-dot{ min-height:64px; font-size:14px; }
  .pt-premium-tile strong,
  .pt-country-directory-name,
  .pt-country-name,
  .pt-city-name{ font-size:18px; }
}


/* =========================================================
   v2.2.2 — high-end polish + weekly timetable mobile
   ========================================================= */
.pt-page{
  background:
    radial-gradient(circle at top left, rgba(201,169,97,.07), transparent 24%),
    radial-gradient(circle at top right, rgba(212,176,98,.06), transparent 22%),
    var(--pt-bg);
}

.pt-card,
.pt-surface-card,
.pt-table-shell,
.pt-list-card,
.pt-faq-card,
.pt-nextcard,
.pt-qibla-card,
.pt-info-card,
.pt-country-card,
.pt-city-card,
.pt-premium-tile{
  border-color: rgba(255,255,255,.10);
  box-shadow:
    0 22px 52px rgba(7,18,36,.14),
    inset 0 1px 0 rgba(255,255,255,.06);
}
html[data-pt-theme="dark"] .pt-card,
html[data-pt-theme="dark"] .pt-surface-card,
html[data-pt-theme="dark"] .pt-table-shell,
html[data-pt-theme="dark"] .pt-list-card,
html[data-pt-theme="dark"] .pt-faq-card,
html[data-pt-theme="dark"] .pt-nextcard,
html[data-pt-theme="dark"] .pt-qibla-card,
html[data-pt-theme="dark"] .pt-info-card,
html[data-pt-theme="dark"] .pt-country-card,
html[data-pt-theme="dark"] .pt-city-card,
html[data-pt-theme="dark"] .pt-premium-tile{
  border-color: rgba(255,255,255,.08);
  box-shadow:
    0 26px 60px rgba(0,0,0,.32),
    inset 0 1px 0 rgba(255,255,255,.05);
}

.pt-card-hero,
.pt-hero-shell{
  border-radius: 26px;
}
.pt-city-hero,
.pt-country-hero,
.pt-home-hero{
  background:
    radial-gradient(circle at top right, rgba(201,169,97,.18), transparent 28%),
    radial-gradient(circle at top left, rgba(212,176,98,.10), transparent 24%),
    linear-gradient(180deg, rgba(14,29,55,.98), rgba(9,20,40,.94));
}
.pt-city-hero .pt-h1,
.pt-country-hero .pt-h1,
.pt-home-hero .pt-h1{
  font-size: clamp(34px, 5vw, 60px);
  line-height: 1.02;
  letter-spacing: -.035em;
}
.pt-subtitle{
  max-width: 920px;
  font-size: 16px;
  line-height: 1.8;
}

.pt-section-kicker{
  letter-spacing: .14em;
  font-size: 11px;
  padding: 9px 14px;
  border-radius: 999px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.10);
}

.pt-info-card{
  border-radius: 24px;
  padding: 22px;
}
.pt-info-label,
.pt-next-title,
.pt-progress-label,
.pt-dt-k,
.pt-qibla-k{
  letter-spacing: .14em;
}
.pt-info-value{
  font-size: clamp(28px, 3vw, 40px);
}
.pt-nextcard,
.pt-qibla-card{
  border-radius: 24px;
  padding: 18px;
}
.pt-next-countdown{
  font-size: clamp(46px, 6vw, 84px);
  line-height: .96;
  margin-top: 10px;
}
.pt-next-main{
  font-size: 20px;
}
.pt-dot{
  min-height: 86px;
  border-radius: 18px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.02)),
    var(--pt-pill);
}
html[data-pt-theme="dark"] .pt-dot{
  background:
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,0)),
    var(--pt-pill);
}
.pt-dot.pt-dot-active{
  box-shadow: 0 0 0 1px rgba(201,169,97,.22), 0 14px 28px rgba(201,169,97,.16);
}

.pt-table-wrap{
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: rgba(201,169,97,.45) transparent;
}
.pt-table-wrap::-webkit-scrollbar{ height: 10px; }
.pt-table-wrap::-webkit-scrollbar-thumb{
  background: linear-gradient(90deg, rgba(201,169,97,.55), rgba(212,176,98,.45));
  border-radius: 999px;
}
.pt-table-wrap::-webkit-scrollbar-track{ background: transparent; }

.pt-table-shell{
  border-radius: 24px;
  padding: 14px;
}
.pt-table{
  min-width: 100%;
}
.pt-table thead th{
  font-size: 11px;
  letter-spacing: .14em;
}
.pt-table td{
  font-variant-numeric: tabular-nums;
}
.pt-table-week thead th:first-child,
.pt-table-week tbody td:first-child{
  position: sticky;
  left: 0;
  z-index: 2;
}
.pt-table-week tbody td:first-child{
  font-weight: 900;
}
.pt-table-week tbody td:first-child,
.pt-table-week thead th:first-child{
  box-shadow: 8px 0 18px rgba(6,16,32,.08);
}
html[data-pt-theme="dark"] .pt-table-week tbody td:first-child,
html[data-pt-theme="dark"] .pt-table-week thead th:first-child{
  box-shadow: 8px 0 18px rgba(0,0,0,.22);
}

.pt-list li{
  border-radius: 18px;
  padding: 14px 14px;
}
.pt-list li:hover{
  padding-left: 14px;
  padding-right: 14px;
  transform: translateY(-1px);
}

.pt-city-card,
.pt-country-card,
.pt-premium-tile,
.pt-city-pill{
  border-radius: 20px;
}
.pt-city-card-top,
.pt-country-card{
  gap: 14px;
}
.pt-city-name,
.pt-country-name{
  font-size: 21px;
  line-height: 1.15;
}
.pt-city-meta,
.pt-footer-note,
.pt-small,
.pt-muted{
  line-height: 1.75;
}

@media (max-width: 768px){
  .pt-wrap{ width: min(100%, calc(100% - 14px)); }
  .pt-card-hero{ padding: 18px; }
  .pt-city-hero .pt-h1,
  .pt-country-hero .pt-h1,
  .pt-home-hero .pt-h1{
    font-size: clamp(28px, 9vw, 42px);
  }
  .pt-nextcard,
  .pt-qibla-card,
  .pt-info-card{
    padding: 16px;
    border-radius: 20px;
  }
  .pt-next-countdown{
    font-size: clamp(38px, 11vw, 60px);
  }
  .pt-dot{
    min-height: 74px;
  }
}

/* Weekly timetable fully responsive on mobile */
@media (max-width: 640px){
  .pt-table-week{
    min-width: 0;
    border-spacing: 0;
  }
  .pt-table-week thead{
    display: none;
  }
  .pt-table-week tbody{
    display: grid;
    gap: 12px;
  }
  .pt-table-week tbody tr{
    display: grid;
    grid-template-columns: repeat(2, minmax(0,1fr));
    gap: 10px;
    padding: 12px;
    border: 1px solid var(--pt-line);
    border-radius: 18px;
    background:
      radial-gradient(circle at top right, rgba(201,169,97,.10), transparent 42%),
      linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
    box-shadow: 0 14px 28px rgba(7,18,36,.10);
  }
  html[data-pt-theme="dark"] .pt-table-week tbody tr{
    background:
      radial-gradient(circle at top right, rgba(201,169,97,.12), transparent 42%),
      linear-gradient(180deg, rgba(15,29,54,.94), rgba(10,22,42,.88));
    box-shadow: 0 18px 34px rgba(0,0,0,.24);
  }
  .pt-table-week tbody td{
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    width: 100%;
    min-height: 52px;
    padding: 12px 14px;
    border: 1px solid var(--pt-line) !important;
    border-radius: 14px !important;
    background: rgba(255,255,255,.04);
    text-align: right;
  }
  html[data-pt-theme="dark"] .pt-table-week tbody td{
    background: rgba(255,255,255,.03);
  }
  .pt-table-week tbody td::before{
    content: attr(data-label);
    color: var(--pt-muted);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .12em;
    text-transform: uppercase;
    text-align: left;
    flex: 0 0 auto;
  }
  .pt-table-week tbody td:first-child{
    grid-column: 1 / -1;
    position: static;
    box-shadow: none;
    background:
      linear-gradient(135deg, rgba(201,169,97,.16), rgba(212,176,98,.10)),
      rgba(255,255,255,.04);
    font-size: 15px;
    font-weight: 900;
  }
  .pt-table-week tbody td:first-child::before{
    content: "Date";
  }
  .pt-table-week tbody td.pt-right{
    text-align: right;
  }
  .pt-table-shell{
    padding: 10px;
  }
}


/* v2.2.6 — refined visual pass, sober editorial look */
:root{
  --pt-surface-2: #f7f8fb;
  --pt-panel: rgba(255,255,255,.78);
  --pt-panel-strong: rgba(255,255,255,.92);
  --pt-shadow-soft: 0 18px 40px rgba(15, 23, 42, .08);
  --pt-shadow-mid: 0 24px 54px rgba(15, 23, 42, .12);
  --pt-shadow-strong: 0 32px 72px rgba(2, 8, 23, .14);
}
html[data-pt-theme="dark"]{
  --pt-panel: rgba(10,18,32,.82);
  --pt-panel-strong: rgba(12,20,36,.94);
  --pt-shadow-soft: 0 22px 52px rgba(0,0,0,.28);
  --pt-shadow-mid: 0 28px 60px rgba(0,0,0,.34);
  --pt-shadow-strong: 0 34px 76px rgba(0,0,0,.42);
}

.pt-page{
  background:
    radial-gradient(circle at top left, rgba(201,169,97,.08), transparent 32%),
    radial-gradient(circle at top right, rgba(212,176,98,.10), transparent 26%),
    linear-gradient(180deg, rgba(250,251,254,.95), rgba(244,247,251,.98));
}
html[data-pt-theme="dark"] .pt-page{
  background:
    radial-gradient(circle at top left, rgba(201,169,97,.10), transparent 34%),
    radial-gradient(circle at top right, rgba(212,176,98,.10), transparent 26%),
    linear-gradient(180deg, rgba(6,12,22,.98), rgba(7,15,28,1));
}
.pt-wrap{ max-width: 1240px; }
.pt-card,
.pt-surface-card,
.pt-country-card,
.pt-premium-tile,
.pt-hadith-box,
.pt-glance-card,
.pt-utility-pill,
.pt-qibla-stat,
.pt-info-card,
.pt-table-shell,
.pt-country-directory-item{
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.pt-card,
.pt-surface-card,
.pt-table-shell,
.pt-hadith-box,
.pt-country-card,
.pt-country-directory-item{
  border-radius: 24px;
  border: 1px solid rgba(148,163,184,.18);
  background: var(--pt-panel-strong);
  box-shadow: var(--pt-shadow-soft);
}
html[data-pt-theme="dark"] .pt-card,
html[data-pt-theme="dark"] .pt-surface-card,
html[data-pt-theme="dark"] .pt-table-shell,
html[data-pt-theme="dark"] .pt-hadith-box,
html[data-pt-theme="dark"] .pt-country-card,
html[data-pt-theme="dark"] .pt-country-directory-item{
  border-color: rgba(148,163,184,.14);
  background: var(--pt-panel-strong);
}
.pt-hero-shell{
  position: relative;
  overflow: hidden;
  border-radius: 30px;
  padding: 28px;
  background:
    linear-gradient(135deg, rgba(255,255,255,.92), rgba(247,250,253,.86)),
    radial-gradient(circle at top right, rgba(212,176,98,.16), transparent 24%),
    radial-gradient(circle at left top, rgba(201,169,97,.12), transparent 30%);
  box-shadow: var(--pt-shadow-strong);
}
.pt-hero-shell::before{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius:inherit;
  padding:1px;
  background: linear-gradient(135deg, rgba(212,176,98,.24), rgba(255,255,255,.4), rgba(201,169,97,.18));
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  pointer-events:none;
}
html[data-pt-theme="dark"] .pt-hero-shell{
  background:
    linear-gradient(135deg, rgba(11,19,34,.96), rgba(10,18,32,.88)),
    radial-gradient(circle at top right, rgba(212,176,98,.12), transparent 24%),
    radial-gradient(circle at left top, rgba(201,169,97,.12), transparent 30%);
}
.pt-hero-top,
.pt-section-head{
  margin-bottom: 18px;
}
.pt-breadcrumbs,
.pt-breadcrumbs a{
  font-size: 13px;
  letter-spacing: .02em;
}
.pt-section-kicker,
.pt-glance-kicker,
.pt-qibla-k,
.pt-hero-metric-label{
  letter-spacing: .14em;
}
.pt-h1{
  max-width: 14ch;
  font-size: clamp(2rem, 4vw, 3.65rem);
  line-height: 1.02;
  letter-spacing: -.04em;
}
.pt-subtitle,
.pt-section-copy,
.pt-muted,
.pt-glance-copy,
.pt-utility-pill span{
  max-width: 70ch;
  line-height: 1.7;
}
.pt-home-glance-grid,
.pt-hero-metrics,
.pt-info-grid,
.pt-grid-2,
.pt-library-grid,
.pt-country-grid,
.pt-premium-tiles{
  gap: 16px;
}
.pt-glance-card,
.pt-utility-pill,
.pt-hero-metric,
.pt-info-card,
.pt-qibla-stat{
  border-radius: 22px;
  border: 1px solid rgba(148,163,184,.16);
  background: var(--pt-panel);
  box-shadow: var(--pt-shadow-soft);
}
.pt-glance-card,
.pt-utility-pill{
  padding: 18px 18px;
}
.pt-glance-value,
.pt-hero-metric strong{
  font-size: clamp(1.05rem, 1.8vw, 1.35rem);
  line-height: 1.2;
}
.pt-btn,
.pt-btn-ghost,
.pt-quick-link,
.pt-city-pill,
.pt-premium-tile,
.pt-country-card,
.pt-country-directory-item,
.pt-hadith-box{
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease, background .22s ease;
}
.pt-btn,
.pt-btn-ghost,
.pt-quick-link{
  border-radius: 999px;
  min-height: 46px;
  padding-inline: 18px;
  box-shadow: 0 10px 24px rgba(15,23,42,.08);
}
.pt-btn:hover,
.pt-btn-ghost:hover,
.pt-quick-link:hover,
.pt-city-pill:hover,
.pt-premium-tile:hover,
.pt-country-card:hover,
.pt-country-directory-item:hover,
.pt-hadith-box:hover{
  transform: translateY(-2px);
  box-shadow: var(--pt-shadow-mid);
}
.pt-premium-tile,
.pt-country-card,
.pt-country-directory-item,
.pt-hadith-box{
  border: 1px solid rgba(148,163,184,.16);
  background:
    linear-gradient(180deg, rgba(255,255,255,.96), rgba(246,248,252,.92));
}
html[data-pt-theme="dark"] .pt-premium-tile,
html[data-pt-theme="dark"] .pt-country-card,
html[data-pt-theme="dark"] .pt-country-directory-item,
html[data-pt-theme="dark"] .pt-hadith-box{
  background:
    linear-gradient(180deg, rgba(13,22,39,.98), rgba(10,18,32,.92));
}
.pt-premium-tile strong,
.pt-country-name,
.pt-h2{
  letter-spacing: -.02em;
}
.pt-table-shell{
  padding: 14px;
}
.pt-table-week,
.pt-table-today{
  overflow: hidden;
  border-radius: 20px;
}
.pt-table-week th,
.pt-table-week td,
.pt-table-today th,
.pt-table-today td{
  padding-top: 14px;
  padding-bottom: 14px;
}
.pt-nextwrap,
.pt-info-grid,
.pt-grid-2{
  align-items: stretch;
}
.pt-next-card,
.pt-info-card,
.pt-qibla-page-card{
  border-radius: 24px;
}
.pt-qibla-page-card .pt-compass{
  box-shadow: inset 0 0 0 1px rgba(148,163,184,.16), var(--pt-shadow-mid);
}
.pt-qibla-status{
  border-radius: 18px;
  border: 1px solid rgba(148,163,184,.16);
  background: var(--pt-panel);
}
.pt-faq details,
.pt-faq-wrap,
.pt-city-pill{
  border-radius: 18px;
}
.pt-city-pill{
  border: 1px solid rgba(148,163,184,.16);
  background: rgba(255,255,255,.8);
}
html[data-pt-theme="dark"] .pt-city-pill{
  background: rgba(255,255,255,.04);
}
.pt-footer-note{
  opacity: .88;
}

@media (max-width: 900px){
  .pt-hero-shell{ padding: 22px; border-radius: 26px; }
  .pt-home-glance-grid,
  .pt-hero-metrics,
  .pt-library-grid,
  .pt-grid-2,
  .pt-info-grid,
  .pt-country-grid{ grid-template-columns: 1fr; }
}
@media (max-width: 640px){
  .pt-wrap{ padding-inline: 14px; }
  .pt-hero-shell,
  .pt-card,
  .pt-surface-card,
  .pt-table-shell,
  .pt-qibla-page-card{ border-radius: 22px; }
  .pt-h1{ max-width: none; }
  .pt-home-cta-row,
  .pt-hero-actions,
  .pt-meta-row,
  .pt-home-utility-bar{ gap: 10px; }
  .pt-btn,
  .pt-btn-ghost,
  .pt-quick-link{ width: 100%; justify-content: center; }
  .pt-hero-actions{ width: 100%; }
  .pt-hero-actions > *{ flex: 1 1 auto; }
  .pt-glance-card,
  .pt-utility-pill,
  .pt-qibla-stat,
  .pt-hero-metric{ padding: 16px; }
}

/* =========================================================================
   PDF CALENDAR — T5.1 (mai 2026)
   ─────────────────────────────────────────────────────────────────────────
   Section téléchargement PDF mensuel sur la page ville.
   Boutons : mois courant + mois suivant + choix libre (modal <dialog>).
   ========================================================================= */

.pt-pdf-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 16px;
  align-items: center;
}

.pt-pdf-actions .pt-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

/* Modal <dialog> natif */
.pt-pdf-modal {
  padding: 0;
  border: 1px solid rgba(232, 230, 223, 0.12);
  border-radius: 18px;
  background: #111827;
  color: #e8e6df;
  max-width: 420px;
  width: calc(100% - 32px);
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.55);
}

.pt-pdf-modal::backdrop {
  background: rgba(7, 11, 20, 0.72);
  backdrop-filter: blur(3px);
}

.pt-pdf-modal__inner {
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.pt-pdf-modal__title {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 24px;
  font-weight: 500;
  margin: 0;
  color: #e8e6df;
  letter-spacing: -0.01em;
}

.pt-pdf-modal__input {
  width: 100%;
  padding: 10px 14px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(232, 230, 223, 0.14);
  border-radius: 10px;
  color: #e8e6df;
  font-family: 'Inter Tight', 'Inter', sans-serif;
  font-size: 15px;
  box-sizing: border-box;
  cursor: pointer;
  transition: border-color 0.2s;
}

.pt-pdf-modal__input:focus {
  outline: none;
  border-color: #c9a961;
}

/* Correction colorimétrique du picker natif sur fond sombre */
.pt-pdf-modal__input::-webkit-calendar-picker-indicator {
  filter: invert(1) opacity(0.6);
  cursor: pointer;
}

.pt-pdf-modal__actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.pt-pdf-modal__actions .pt-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

@media (max-width: 540px) {
  .pt-pdf-actions { flex-direction: column; }
  .pt-pdf-actions .pt-btn { width: 100%; justify-content: center; }
  .pt-pdf-modal__actions { flex-direction: column; }
  .pt-pdf-modal__actions .pt-btn { width: 100%; justify-content: center; }
}

/* =========================================================================
   MORE TO EXPLORE — A6 (v3.1)
   ─────────────────────────────────────────────────────────────────────────
   Grille 3 col desktop / 2 col tablette / 1 col mobile
   Chaque card : icône SVG + kicker + titre + sous-titre
   ========================================================================= */

.pt-explore-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin-top: 16px;
}

.pt-explore-card {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 20px;
  border-radius: 16px;
  border: 1px solid var(--pt-line);
  background: var(--pt-soft);
  text-decoration: none;
  color: var(--pt-text);
  transition: border-color 0.2s, background 0.2s, transform 0.2s;
}

.pt-explore-card:hover {
  background: rgba(201, 169, 97, 0.06);
  border-color: rgba(201, 169, 97, 0.30);
  transform: translateY(-2px);
}

.pt-explore-card:active {
  transform: translateY(0);
}

.pt-explore-card__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  background: rgba(201, 169, 97, 0.08);
  border: 1px solid rgba(201, 169, 97, 0.15);
  border-radius: 10px;
  color: var(--pt-brand);
  flex-shrink: 0;
  margin-bottom: 4px;
}

.pt-explore-card__icon svg {
  width: 20px;
  height: 20px;
}

.pt-explore-card__kicker {
  font-size: 10px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--pt-brand);
  font-weight: 600;
  line-height: 1;
}

.pt-explore-card__title {
  font-family: var(--pt-font-display);
  font-size: 17px;
  font-weight: 500;
  color: var(--pt-text);
  line-height: 1.25;
  letter-spacing: -0.01em;
}

.pt-explore-card__sub {
  font-size: 13px;
  color: var(--pt-muted);
  line-height: 1.45;
  font-weight: 300;
}

@media (max-width: 900px) {
  .pt-explore-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 540px) {
  .pt-explore-grid { grid-template-columns: 1fr; gap: 10px; }
  .pt-explore-card { padding: 16px; }
}

@media (prefers-reduced-motion: reduce) {
  .pt-explore-card { transition: none; }
  .pt-explore-card:hover { transform: none; }
}

/* =========================================================
   A1 — City names cliquables avec underline or (country.php)
   ========================================================= */
.pt-table-link--city {
  text-decoration: none;
  color: var(--pt-text);
  transition: color .15s;
}
.pt-table-link--city:hover {
  color: var(--pt-brand-2);
  text-decoration: underline;
  text-decoration-color: var(--pt-brand);
  text-underline-offset: 4px;
}
tr:hover .pt-rank {
  transform: translateX(4px);
  transition: transform .15s;
}

/* =========================================================
   A2 — City pills enrichies (pop + distance)
   ========================================================= */
.pt-city-pill-meta {
  display: block;
  font-size: 11px;
  color: var(--pt-muted);
  margin-top: 2px;
  font-weight: 400;
}

/* =========================================================
   A4 — FAQ mini-tableau des heures de priere
   ========================================================= */
.pt-faq-times-table {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin: 8px 0 4px;
}
.pt-faq-times-row {
  display: flex;
  flex-direction: column;
  padding: 10px 12px;
  border: 1px solid var(--pt-line);
  border-radius: 10px;
  background: rgba(255,255,255,.02);
  gap: 2px;
}
.pt-faq-times-row.is-current {
  border-color: rgba(201,169,97,.4);
  background: rgba(201,169,97,.08);
}
.pt-faq-times-name {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--pt-muted);
}
.pt-faq-times-time {
  font-size: 16px;
  font-weight: 900;
  font-variant-numeric: tabular-nums;
  color: var(--pt-text);
}
.pt-faq-times-row.is-current .pt-faq-times-time {
  color: var(--pt-brand);
}
@media (max-width: 640px) {
  .pt-faq-times-table { grid-template-columns: repeat(2, 1fr); }
}

/* =========================================================
   A8 — CTA row PDF + fav city
   ========================================================= */
.pt-city-cta-row {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin: 6px 0 0;
  padding: 16px 0 0;
  border-top: 1px solid var(--pt-line);
}
.pt-fav-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

/* =========================================================
   T6.3 — Qibla page gold halo redesign
   ========================================================= */
@keyframes pt-qibla-halo-move {
  0%   { transform: translate(-10%, -10%) scale(1); }
  50%  { transform: translate(10%, 10%) scale(1.08); }
  100% { transform: translate(-10%, -10%) scale(1); }
}
@keyframes pt-qibla-orb-pulse {
  0%,100% { box-shadow: 0 0 0 0 rgba(201,169,97,.25); }
  50%      { box-shadow: 0 0 0 18px rgba(201,169,97,0); }
}

.pt-qibla-hero {
  position: relative;
  overflow: hidden;
}
.pt-qibla-halo {
  position: absolute;
  width: 600px;
  height: 600px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(201,169,97,.18) 0%, transparent 70%);
  top: -180px;
  right: -100px;
  pointer-events: none;
  animation: pt-qibla-halo-move 20s ease-in-out infinite;
}
.pt-qibla-pattern {
  position: absolute;
  bottom: 20px;
  left: 20px;
  width: 140px;
  height: 140px;
  color: var(--pt-brand);
  opacity: .1;
  pointer-events: none;
}
.pt-qibla-hero-body {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 48px;
  align-items: center;
  padding: 16px 0 8px;
}
.pt-qibla-hero-left { position: relative; z-index: 1; }

/* Bearing large */
.pt-qibla-bearing-wrap {
  margin: 20px 0 12px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.pt-qibla-bearing-label {
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--pt-muted);
}
.pt-qibla-bearing-value {
  font-family: var(--pt-font-display);
  font-size: clamp(48px, 8vw, 80px);
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  letter-spacing: -.03em;
  color: var(--pt-brand);
  line-height: 1;
}

/* Coords row */
.pt-qibla-coords-row {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 12px;
  font-size: 12px;
  color: var(--pt-muted);
}

/* Orbe + boussole grande page */
.pt-qibla-hero-right {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  z-index: 1;
}
.pt-qibla-orb {
  position: relative;
  width: 260px;
  height: 260px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.pt-qibla-orb-ring {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(201,169,97,.14) 0%, rgba(201,169,97,.04) 50%, transparent 70%);
  border: 1px solid rgba(201,169,97,.22);
  animation: pt-qibla-orb-pulse 2.4s ease-in-out infinite;
}
.pt-qibla-orb > .pt-compass {
  width: 200px;
  height: 200px;
  position: relative;
  z-index: 2;
}
.pt-qibla-orb .pt-compass-ring {
  border: 2px solid rgba(201,169,97,.45);
  background:
    radial-gradient(circle at 50% 50%, rgba(201,169,97,.18), transparent 55%),
    radial-gradient(circle at 30% 25%, rgba(201,169,97,.10), transparent 60%);
  box-shadow:
    0 0 0 6px rgba(201,169,97,.06),
    0 0 40px rgba(201,169,97,.12);
}
.pt-qibla-orb .pt-compass-arrow {
  background: linear-gradient(180deg, var(--pt-brand) 0%, var(--pt-brand-2) 100%);
  box-shadow: 0 0 8px rgba(201,169,97,.45);
  width: 5px;
  height: 55px;
}
.pt-qibla-orb .pt-compass-arrow::after {
  border-bottom-color: var(--pt-brand-2);
  border-left-width: 9px;
  border-right-width: 9px;
  border-bottom-width: 14px;
  filter: drop-shadow(0 -2px 4px rgba(201,169,97,.5));
}
.pt-qibla-orb .pt-compass-center {
  width: 14px;
  height: 14px;
  background: var(--pt-brand);
  box-shadow: 0 0 8px rgba(201,169,97,.6);
}

/* Gold button variant */
.pt-btn-gold {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: linear-gradient(135deg, var(--pt-brand), var(--pt-brand-2));
  color: #0a0e1a;
  font-weight: 700;
  border: none;
  box-shadow: 0 4px 18px rgba(201,169,97,.35);
  transition: transform .15s, box-shadow .15s;
}
.pt-btn-gold:hover {
  transform: translateY(-1px);
  box-shadow: 0 8px 28px rgba(201,169,97,.45);
}

/* Info grid */
.pt-qibla-info-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 12px;
}
.pt-qibla-info-item {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  padding: 16px;
  border: 1px solid var(--pt-line);
  border-radius: var(--pt-radius);
  background: rgba(255,255,255,.02);
}
.pt-qibla-info-item svg { flex-shrink: 0; margin-top: 2px; }
.pt-qibla-info-item strong { display: block; font-size: 14px; margin-bottom: 4px; }
.pt-qibla-info-item p { font-size: 13px; color: var(--pt-muted); margin: 0; line-height: 1.5; }

/* Responsive */
@media (max-width: 900px) {
  .pt-qibla-hero-body { grid-template-columns: 1fr; gap: 28px; }
  .pt-qibla-hero-right { order: -1; }
  .pt-qibla-orb { width: 200px; height: 200px; }
  .pt-qibla-orb > .pt-compass { width: 160px; height: 160px; }
  .pt-qibla-info-grid { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .pt-qibla-halo { width: 300px; height: 300px; top: -80px; right: -60px; }
  .pt-qibla-bearing-value { font-size: 56px; }
  .pt-qibla-orb { width: 170px; height: 170px; }
  .pt-qibla-orb > .pt-compass { width: 140px; height: 140px; }
}
@media (prefers-reduced-motion: reduce) {
  .pt-qibla-halo { animation: none; }
  .pt-qibla-orb-ring { animation: none; }
}

/* =========================================================
   A7 — Mini-horloge sticky dans pt-hero-actions
   ========================================================= */
.pt-mini-clock {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid var(--pt-line);
  background: rgba(255,255,255,.04);
  font-size: 13px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--pt-brand);
  letter-spacing: .04em;
  white-space: nowrap;
}
.pt-mini-clock svg { opacity: .7; }
@media (max-width: 640px) {
  /* sur mobile : secondes masquees via JS (data-pt-clock-seconds) */
  .pt-mini-clock { padding: 5px 10px; font-size: 12px; }
}

/* =========================================================
   A8 — Bouton PDF sur city page
   ========================================================= */
.pt-pdf-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 16px 0 0;
  padding: 13px 24px;
  border-radius: var(--pt-radius);
  background: linear-gradient(135deg, var(--pt-brand), var(--pt-brand-2));
  color: #0a0e1a;
  font-weight: 700;
  font-size: 14px;
  text-decoration: none;
  box-shadow: 0 4px 18px rgba(201,169,97,.30);
  transition: transform .15s, box-shadow .15s;
}
.pt-pdf-btn:hover {
  transform: translateY(-1px) scale(1.02);
  box-shadow: 0 8px 28px rgba(201,169,97,.42);
  color: #0a0e1a;
  text-decoration: none;
}
@media (max-width: 768px) {
  .pt-pdf-btn { width: 100%; justify-content: center; }
}

/* =========================================================
   T7 — prefers-reduced-motion global (toutes animations)
   ========================================================= */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
  }
}

/* =========================================================
   T7 — Mode TV (?display=tv)
   ========================================================= */
.pt-page[data-tv-mode="1"] {
  position: fixed;
  inset: 0;
  z-index: 99999;
  overflow: auto;
}
.pt-page[data-tv-mode="1"] .pt-hero-top,
.pt-page[data-tv-mode="1"] .pt-meta-row,
.pt-page[data-tv-mode="1"] .pt-section,
body.pt-tv-mode #wpadminbar,
body.pt-tv-mode .ast-above-header-bar,
body.pt-tv-mode .site-footer { display: none !important; }

.pt-page[data-tv-mode="1"] .pt-clock-tv {
  font-family: var(--pt-font-display);
  font-size: clamp(80px, 18vw, 180px);
  font-variant-numeric: tabular-nums;
  color: var(--pt-brand);
  text-align: center;
  letter-spacing: -.04em;
  line-height: 1;
  padding: 40px 20px 10px;
}
.pt-page[data-tv-mode="1"] .pt-city-tv {
  text-align: center;
  font-size: clamp(20px, 4vw, 36px);
  color: var(--pt-muted);
  font-family: var(--pt-font-display);
  padding-bottom: 20px;
}
.pt-tv-exit {
  position: fixed;
  top: 16px;
  right: 16px;
  z-index: 100000;
  background: rgba(255,255,255,.08);
  border: 1px solid var(--pt-line);
  border-radius: 999px;
  padding: 6px 14px;
  font-size: 13px;
  color: var(--pt-muted);
  cursor: pointer;
  display: none;
}
body.pt-tv-mode .pt-tv-exit { display: block; }

/* =========================================================================
   B2 — Quick shortcut chips (home.php hero)
   ========================================================================= */
.pt-quick-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 14px 0 6px;
}
.pt-quick-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 6px 14px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.15);
  background: rgba(255,255,255,.04);
  color: var(--pt-muted, rgba(220,215,200,.7));
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  transition: border-color .15s, background .15s, color .15s;
  font-family: inherit;
}
.pt-quick-chip:hover {
  border-color: var(--pt-brand, #c9a961);
  background: rgba(201,169,97,.12);
  color: var(--pt-brand, #c9a961);
}

/* =========================================================================
   B3 — FAQ accordion animation (details/summary)
   ========================================================================= */
.pt-faq__item > .pt-faq__a { animation: none; }
.pt-faq__item[open] > .pt-faq__a {
  animation: ptFaqOpen .24s ease;
}
@keyframes ptFaqOpen {
  from { opacity: 0; transform: translateY(-5px); }
  to   { opacity: 1; transform: translateY(0); }
}
.pt-faq__qIcon {
  display: inline-block;
  transition: transform .22s ease;
  flex-shrink: 0;
}
.pt-faq__item[open] .pt-faq__qIcon { transform: rotate(45deg); }

/* Astra theme compatibility */
.entry-content { overflow: visible; }
.ast-article-post { overflow: visible; }
.site-main .hentry { overflow: visible; }

/* =============================================================================
   PTE v2.3.7 — HERO COSMIQUE (Variante F : Diptyque) + harmonisation page ville
   Charte : nuit cosmique #0a0e1a -> #0f1628 -> #1a2238, or #c9a961 / soft #e6c177,
   emeraude prière courante #34d399, texte #e8e6df.
   Typo : Cormorant Garamond display, Inter Tight body.
   ============================================================================= */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;500;600;700&family=Inter+Tight:wght@300;400;500;600;700&display=swap');

/* Variables locales scope page ville */
.pt-page-cosmic {
  --ptc-bg-top: #1a2238;
  --ptc-bg-mid: #0f1628;
  --ptc-bg-bot: #0a0e1a;
  --ptc-fg: #e8e6df;
  --ptc-fg-muted: rgba(232,230,223,0.65);
  --ptc-fg-dim: rgba(232,230,223,0.45);
  --ptc-gold: #c9a961;
  --ptc-gold-soft: #e6c177;
  --ptc-emerald: #34d399;
  --ptc-border: rgba(232,230,223,0.10);
  --ptc-border-gold: rgba(201,169,97,0.30);
  --ptc-surface: rgba(10,14,26,0.55);
  --ptc-radius: 14px;
  --ptc-font-display: 'Cormorant Garamond', Georgia, serif;
  --ptc-font-body: 'Inter Tight', -apple-system, system-ui, sans-serif;
}

/* Fond cosmique global sur toute la page ville */
.pt-page-cosmic {
  background:
    radial-gradient(ellipse at top, var(--ptc-bg-top) 0%, var(--ptc-bg-mid) 45%, var(--ptc-bg-bot) 100%) !important;
  color: var(--ptc-fg);
  font-family: var(--ptc-font-body);
  min-height: 100vh;
  padding: 24px 0 60px;
  position: relative;
  overflow: hidden;
}
/* Trame d'etoiles globale page */
.pt-page-cosmic::before {
  content: '';
  position: absolute; inset: 0;
  background-image:
    radial-gradient(1.5px 1.5px at 8% 12%, rgba(255,255,255,.32) 0%, transparent 100%),
    radial-gradient(1px 1px at 18% 28%, rgba(255,255,255,.22) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at 28% 6%, rgba(255,255,255,.38) 0%, transparent 100%),
    radial-gradient(1px 1px at 38% 20%, rgba(255,255,255,.20) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at 48% 9%, rgba(255,255,255,.30) 0%, transparent 100%),
    radial-gradient(1px 1px at 58% 17%, rgba(255,255,255,.24) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at 68% 11%, rgba(255,255,255,.36) 0%, transparent 100%),
    radial-gradient(1px 1px at 78% 24%, rgba(255,255,255,.20) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at 88% 5%, rgba(255,255,255,.40) 0%, transparent 100%),
    radial-gradient(1px 1px at 95% 19%, rgba(255,255,255,.26) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at 4% 88%, rgba(255,255,255,.28) 0%, transparent 100%);
  pointer-events: none;
  z-index: 0;
}
.pt-page-cosmic .pt-wrap {
  position: relative;
  z-index: 1;
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 20px;
}

/* =============================================================================
   HERO V237 — Diptyque
   ============================================================================= */
.pt-v237-hero {
  position: relative;
  padding: 30px 32px 28px;
  margin-bottom: 24px;
  border-radius: var(--ptc-radius);
  background: linear-gradient(180deg, rgba(26,34,56,0.45), rgba(10,14,26,0.30));
  border: 1px solid var(--ptc-border-gold);
  overflow: hidden;
  isolation: isolate;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
/* Halo dore central pulse */
.pt-v237-hero::before {
  content: '';
  position: absolute;
  top: 45%; left: 50%;
  width: 580px; height: 580px;
  transform: translate(-50%, -50%);
  background: radial-gradient(circle, rgba(201,169,97,0.28) 0%, rgba(201,169,97,0.08) 32%, transparent 65%);
  filter: blur(50px);
  z-index: 0;
  pointer-events: none;
  animation: ptcGlowPulse 7s ease-in-out infinite alternate;
}
@keyframes ptcGlowPulse {
  0%   { opacity: 0.72; transform: translate(-50%, -50%) scale(0.94); }
  100% { opacity: 1;    transform: translate(-50%, -50%) scale(1.10); }
}
/* Trame Khatim (etoiles 8 branches) en pattern SVG */
.pt-v237-hero::after {
  content: '';
  position: absolute; inset: 0;
  opacity: 0.16;
  pointer-events: none;
  z-index: 0;
  background-repeat: repeat;
  background-size: 180px 180px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 180 180'><g fill='none' stroke='%23c9a961' stroke-width='0.7' opacity='0.65'><g transform='translate(90 90)'><polygon points='0,-14 4,-4 14,0 4,4 0,14 -4,4 -14,0 -4,-4'/><polygon points='0,-14 4,-4 14,0 4,4 0,14 -4,4 -14,0 -4,-4' transform='rotate(45)'/></g></g></svg>");
}
.pt-v237-hero > * { position: relative; z-index: 2; }

/* Top bar : breadcrumbs + actions */
.pt-v237-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 22px;
}
.pt-v237-crumbs {
  font-size: 11.5px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ptc-fg-dim);
  font-weight: 600;
}
.pt-v237-crumbs a {
  color: var(--ptc-fg-muted);
  text-decoration: none;
  transition: color .15s;
}
.pt-v237-crumbs a:hover { color: var(--ptc-gold-soft); }
.pt-v237-crumbs .sep { color: rgba(201,169,97,0.4); margin: 0 6px; }
.pt-v237-crumbs .cur { color: var(--ptc-fg); }
.pt-v237-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.pt-v237-quick {
  font-size: 12.5px;
  padding: 6px 13px;
  border-radius: 999px;
  border: 1px solid var(--ptc-border);
  background: rgba(10,14,26,0.50);
  color: var(--ptc-fg);
  text-decoration: none;
  transition: .15s;
}
.pt-v237-quick:hover {
  border-color: var(--ptc-gold);
  color: var(--ptc-gold-soft);
}
.pt-v237-mini-clock {
  font-family: var(--ptc-font-display);
  font-size: 18px;
  color: var(--ptc-gold-soft);
  font-variant-numeric: tabular-nums;
  padding: 4px 12px;
  border-radius: 999px;
  background: rgba(10,14,26,0.50);
  border: 1px solid var(--ptc-border);
}

/* Bloc titre */
.pt-v237-title-block {
  text-align: center;
  margin-bottom: 28px;
}
.pt-v237-h1 {
  font-family: var(--ptc-font-display);
  font-size: clamp(34px, 5vw, 52px);
  line-height: 1.05;
  font-weight: 400;
  letter-spacing: -0.015em;
  color: var(--ptc-fg);
  margin: 0 0 8px;
}
.pt-v237-h1 em {
  font-style: italic;
  color: var(--ptc-gold-soft);
  font-weight: 500;
}
.pt-v237-meta {
  font-size: 13px;
  color: var(--ptc-fg-muted);
  margin: 0;
  display: inline-flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
  align-items: center;
}
.pt-v237-meta .dot { color: rgba(201,169,97,0.4); }

/* Diptyque : 2 colonnes */
.pt-v237-diptych {
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  gap: 18px;
  align-items: stretch;
  margin-bottom: 22px;
}
@media (max-width: 760px) {
  .pt-v237-diptych { grid-template-columns: 1fr; }
}

/* Bloc gauche : prochaine priere */
.pt-v237-next {
  padding: 24px 26px;
  background: linear-gradient(160deg, rgba(52,211,153,0.12), rgba(10,14,26,0.45));
  border: 1px solid rgba(52,211,153,0.35);
  border-radius: var(--ptc-radius);
  position: relative;
  overflow: hidden;
}
.pt-v237-next::after {
  content: '';
  position: absolute;
  bottom: -30px; right: -30px;
  width: 160px; height: 160px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(52,211,153,0.28), transparent 65%);
  pointer-events: none;
}
.pt-v237-next-lbl {
  font-size: 11px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--ptc-emerald);
  font-weight: 700;
}
.pt-v237-next-name {
  font-family: var(--ptc-font-display);
  font-size: 52px;
  line-height: 1;
  font-weight: 500;
  color: var(--ptc-fg);
  margin: 10px 0 4px;
}
.pt-v237-next-time {
  font-size: 40px;
  font-weight: 300;
  color: var(--ptc-emerald);
  font-variant-numeric: tabular-nums;
  line-height: 1.05;
  letter-spacing: -0.01em;
}
.pt-v237-next-cd-row {
  display: flex;
  align-items: baseline;
  gap: 10px;
  margin-top: 18px;
  padding-top: 16px;
  border-top: 1px solid rgba(52,211,153,0.20);
  position: relative;
  z-index: 2;
}
.pt-v237-next-cd-lbl {
  font-size: 11.5px;
  color: var(--ptc-fg-muted);
  letter-spacing: 0.08em;
  text-transform: lowercase;
}
.pt-v237-next-cd-val {
  font-size: 22px;
  font-weight: 500;
  color: var(--ptc-gold-soft);
  font-variant-numeric: tabular-nums;
}

/* Bloc droit : timeline 6 prieres */
.pt-v237-timeline {
  background: var(--ptc-surface);
  border: 1px solid var(--ptc-border);
  border-radius: var(--ptc-radius);
  padding: 12px 18px;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.pt-v237-tl-row {
  display: grid;
  grid-template-columns: 18px 1fr auto;
  align-items: center;
  gap: 14px;
  padding: 11px 0;
  font-size: 14px;
  border-bottom: 1px dashed rgba(232,230,223,0.06);
  color: var(--ptc-fg);
  transition: .15s;
}
.pt-v237-tl-row:last-child { border-bottom: none; }
.pt-v237-tl-row .mk {
  width: 9px; height: 9px;
  border-radius: 50%;
  background: rgba(201,169,97,0.55);
  margin: 0 auto;
}
.pt-v237-tl-row .nm {
  font-weight: 500;
  display: flex;
  align-items: baseline;
  gap: 10px;
  flex-wrap: wrap;
}
.pt-v237-tl-row .nm small {
  font-size: 11px;
  font-weight: 400;
  color: var(--ptc-fg-dim);
  letter-spacing: 0.04em;
  font-style: italic;
}
.pt-v237-tl-row .tm {
  font-variant-numeric: tabular-nums;
  font-weight: 500;
  color: var(--ptc-fg);
}
.pt-v237-tl-row.passed {
  opacity: 0.45;
}
.pt-v237-tl-row.passed .mk { background: rgba(232,230,223,0.25); }
.pt-v237-tl-row.next {
  color: var(--ptc-emerald);
}
.pt-v237-tl-row.next .mk {
  background: var(--ptc-emerald);
  box-shadow: 0 0 0 4px rgba(52,211,153,0.18);
  animation: ptcMkPulse 2.2s ease-in-out infinite;
}
.pt-v237-tl-row.next .tm { color: var(--ptc-emerald); }
.pt-v237-tl-row.next .nm small { color: rgba(52,211,153,0.7); }
@keyframes ptcMkPulse {
  0%, 100% { box-shadow: 0 0 0 4px rgba(52,211,153,0.18); }
  50%      { box-shadow: 0 0 0 7px rgba(52,211,153,0.05); }
}

/* Pilules meta sous le diptyque */
.pt-v237-meta-pills {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 6px;
}
.pt-v237-pill {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 6px 13px;
  border-radius: 999px;
  font-size: 12px;
  background: rgba(10,14,26,0.55);
  border: 1px solid var(--ptc-border);
  color: var(--ptc-fg);
  backdrop-filter: blur(6px);
  font-family: var(--ptc-font-body);
}
.pt-v237-pill.is-clickable {
  cursor: pointer;
  transition: .15s;
}
.pt-v237-pill.is-clickable:hover {
  border-color: var(--ptc-gold);
  color: var(--ptc-gold-soft);
}
.pt-v237-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--ptc-gold);
  display: inline-block;
}

/* =============================================================================
   HARMONISATION CHARTE COSMIQUE pour TOUTES les sections du bas
   (info-grid, weekly, mosques, FAQ, etc.)
   ============================================================================= */

/* Reset des cards : fond surface cosmique au lieu du fond clair par defaut */
.pt-page-cosmic .pt-card,
.pt-page-cosmic .pt-surface-card,
.pt-page-cosmic .pt-info-card,
.pt-page-cosmic .pt-nextcard,
.pt-page-cosmic .pt-list-card,
.pt-page-cosmic .pt-faq-card {
  background: var(--ptc-surface) !important;
  border: 1px solid var(--ptc-border) !important;
  color: var(--ptc-fg);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-radius: var(--ptc-radius) !important;
  box-shadow: none !important;
}

/* Sections wrappers */
.pt-page-cosmic .pt-section,
.pt-page-cosmic .pt-section-premium {
  margin-top: 22px;
}

/* Headings de sections */
.pt-page-cosmic .pt-section-kicker {
  color: var(--ptc-gold-soft) !important;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 600;
}
.pt-page-cosmic .pt-h2,
.pt-page-cosmic .pt-section-title,
.pt-page-cosmic .pt-section-head h2,
.pt-page-cosmic .pt-section-head h3 {
  font-family: var(--ptc-font-display) !important;
  color: var(--ptc-fg) !important;
  font-weight: 500 !important;
}

/* Labels / valeurs dans les info-cards */
.pt-page-cosmic .pt-info-label {
  color: var(--ptc-gold-soft) !important;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 600;
}
.pt-page-cosmic .pt-info-value {
  color: var(--ptc-fg) !important;
  font-family: var(--ptc-font-display);
  font-weight: 500;
}
.pt-page-cosmic .pt-info-sub,
.pt-page-cosmic .pt-muted {
  color: var(--ptc-fg-muted) !important;
}

/* Date/heure rows */
.pt-page-cosmic .pt-dt-k {
  color: var(--ptc-fg-dim) !important;
  font-size: 11.5px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.pt-page-cosmic .pt-dt-v {
  color: var(--ptc-fg) !important;
}
.pt-page-cosmic .pt-dt-time {
  font-variant-numeric: tabular-nums;
  color: var(--ptc-gold-soft) !important;
  font-family: var(--ptc-font-display);
  font-size: 22px;
}

/* Countdown card en bas */
.pt-page-cosmic .pt-next-title {
  color: var(--ptc-emerald) !important;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 700;
}
.pt-page-cosmic .pt-next-countdown {
  color: var(--ptc-emerald) !important;
  font-family: var(--ptc-font-display);
  font-variant-numeric: tabular-nums;
}
.pt-page-cosmic .pt-next-sub {
  color: var(--ptc-fg-muted) !important;
}
.pt-page-cosmic .pt-next-main {
  color: var(--ptc-fg) !important;
}
.pt-page-cosmic .pt-next-dot { color: var(--ptc-gold) !important; }

/* Barre de progression */
.pt-page-cosmic .pt-progress-bar {
  background: rgba(232,230,223,0.08) !important;
  border-radius: 999px;
  height: 5px;
  overflow: hidden;
}
.pt-page-cosmic .pt-progress-fill {
  background: linear-gradient(90deg, var(--ptc-gold), var(--ptc-gold-soft)) !important;
  height: 100%;
}

/* Tableau hebdo */
.pt-page-cosmic .pt-week,
.pt-page-cosmic table.pt-week-table,
.pt-page-cosmic .pt-week-table {
  background: transparent !important;
  color: var(--ptc-fg);
}
.pt-page-cosmic .pt-week th,
.pt-page-cosmic .pt-week-table th {
  color: var(--ptc-gold-soft) !important;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-weight: 600;
  border-bottom: 1px solid var(--ptc-border-gold) !important;
}
.pt-page-cosmic .pt-week td,
.pt-page-cosmic .pt-week-table td {
  color: var(--ptc-fg) !important;
  border-bottom: 1px solid var(--ptc-border) !important;
  font-variant-numeric: tabular-nums;
}
.pt-page-cosmic .pt-week tr.is-today td,
.pt-page-cosmic .pt-week-table tr.is-today td {
  background: rgba(52,211,153,0.06) !important;
  color: var(--ptc-emerald) !important;
}

/* Liste villes proches / mosquees */
.pt-page-cosmic .pt-list-item,
.pt-page-cosmic .pt-mosque-item,
.pt-page-cosmic .pt-nearby-item {
  color: var(--ptc-fg) !important;
  border-bottom: 1px solid var(--ptc-border) !important;
}
.pt-page-cosmic .pt-list-item:hover,
.pt-page-cosmic .pt-mosque-item:hover {
  background: rgba(201,169,97,0.06) !important;
}
.pt-page-cosmic a {
  color: var(--ptc-gold-soft);
}
.pt-page-cosmic a:hover {
  color: var(--ptc-gold);
}

/* Badges */
.pt-page-cosmic .pt-badge {
  background: rgba(10,14,26,0.55) !important;
  border: 1px solid var(--ptc-border) !important;
  color: var(--ptc-fg) !important;
  font-size: 12px;
  padding: 5px 12px;
  border-radius: 999px;
}

/* FAQ */
.pt-page-cosmic .pt-faq-q,
.pt-page-cosmic .pt-faq-card details summary {
  color: var(--ptc-fg) !important;
  font-family: var(--ptc-font-display);
  font-size: 17px;
  font-weight: 500;
}
.pt-page-cosmic .pt-faq-a,
.pt-page-cosmic .pt-faq-card details > div,
.pt-page-cosmic .pt-faq-card details p {
  color: var(--ptc-fg-muted) !important;
}
.pt-page-cosmic .pt-faq-card details {
  border-bottom: 1px solid var(--ptc-border) !important;
}

/* Tous les boutons CTA */
.pt-page-cosmic .pt-btn {
  background: rgba(201,169,97,0.12) !important;
  border: 1px solid var(--ptc-border-gold) !important;
  color: var(--ptc-gold-soft) !important;
  border-radius: 999px;
  padding: 9px 18px;
  font-weight: 500;
  font-family: var(--ptc-font-body);
  transition: .15s;
}
.pt-page-cosmic .pt-btn:hover {
  background: rgba(201,169,97,0.22) !important;
  border-color: var(--ptc-gold) !important;
}
.pt-page-cosmic .pt-btn-ghost {
  background: transparent !important;
  color: var(--ptc-fg-muted) !important;
}

/* Modal Qibla — fond cosmique */
.pt-page-cosmic .pt-qibla-modal-dialog {
  background: linear-gradient(180deg, var(--ptc-bg-mid), var(--ptc-bg-bot)) !important;
  border: 1px solid var(--ptc-border-gold) !important;
  color: var(--ptc-fg) !important;
}
.pt-page-cosmic .pt-qibla-k,
.pt-page-cosmic .pt-qibla-sub {
  color: var(--ptc-fg-muted) !important;
}
.pt-page-cosmic .pt-qibla-v {
  color: var(--ptc-gold-soft) !important;
  font-family: var(--ptc-font-display);
}

/* Texte d intro section */
.pt-page-cosmic .pt-section p {
  color: var(--ptc-fg-muted);
}

/* Lang switcher dans le top (gold border like home) */
.pt-page-cosmic .pt-lang__btn,
.pt-page-cosmic .pt-lang summary {
  background: rgba(10,14,26,0.50) !important;
  border: 1px solid var(--ptc-border) !important;
  color: var(--ptc-fg) !important;
  font-family: var(--ptc-font-body) !important;
  font-size: 12.5px !important;
  padding: 6px 13px !important;
  border-radius: 999px !important;
}
.pt-page-cosmic .pt-lang__btn:hover,
.pt-page-cosmic .pt-lang summary:hover {
  border-color: var(--ptc-gold) !important;
  color: var(--ptc-gold-soft) !important;
}
.pt-page-cosmic .pt-lang__menu {
  background: #0a0e1a !important;
  border: 1px solid var(--ptc-gold) !important;
  z-index: 99999 !important;
}
.pt-page-cosmic .pt-lang__opt {
  color: var(--ptc-fg) !important;
}
.pt-page-cosmic .pt-lang__opt:hover {
  background: rgba(201,169,97,0.10) !important;
  color: var(--ptc-gold-soft) !important;
}

/* Responsive : reduire padding sur mobile */
@media (max-width: 640px) {
  .pt-v237-hero { padding: 22px 18px; }
  .pt-v237-next { padding: 20px 18px; }
  .pt-v237-next-name { font-size: 40px; }
  .pt-v237-next-time { font-size: 32px; }
  .pt-v237-h1 { font-size: 32px; }
  .pt-v237-top { gap: 10px; }
  .pt-v237-mini-clock { font-size: 16px; }
}

/* =============================================================================
   PTE v2.3.8 — FIX 3 points (langues sur pages ville/pays, largeur, espace top)
   ============================================================================= */

/* 1. Bug langues sur pages ville/pays : la top bar est maintenant en dehors
   du hero (sortie du DOM dans city.php v2.3.8). On peut garder overflow:hidden
   sur le hero pour conserver les decoratifs clippes. */
.pt-page-cosmic .pt-v237-hero {
  overflow: hidden !important;
  isolation: isolate !important;
}

/* Top bar SORTIE du hero — stylisee comme un header de page autonome */
.pt-page-cosmic .pt-v237-top-outside {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
  margin: 0 0 18px;
  padding: 14px 18px;
  border-radius: var(--ptc-radius);
  background: rgba(10,14,26,0.50);
  border: 1px solid var(--ptc-border);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  position: relative;
  z-index: 1000;
}
/* Le menu langues sort librement de la top bar */
.pt-page-cosmic .pt-v237-top-outside .pt-lang {
  position: relative;
  z-index: 99999;
}
.pt-page-cosmic .pt-v237-top-outside .pt-lang__menu {
  position: absolute !important;
  top: calc(100% + 8px) !important;
  right: 0 !important;
  left: auto !important;
  z-index: 99999 !important;
  background: #0a0e1a !important;
  border: 1px solid var(--ptc-gold) !important;
  border-radius: 12px !important;
  padding: 6px !important;
  min-width: 200px;
  max-width: 240px;
  max-height: 360px;
  overflow-y: auto;
  box-shadow: 0 20px 60px rgba(0,0,0,0.85), 0 0 0 1px rgba(201,169,97,0.2);
}

/* 2. Largeur : elargir tout le conteneur de la page ville/pays */
.pt-page-cosmic .pt-wrap {
  max-width: min(1480px, 96vw) !important;
}
/* En tres grands ecrans, on tolere encore plus large */
@media (min-width: 1700px) {
  .pt-page-cosmic .pt-wrap {
    max-width: min(1600px, 92vw) !important;
  }
}

/* 3. Espace blanc en haut : reduire le padding-top de la page et neutraliser
   les marges par defaut du theme/Astra qui ajoutent un blanc */
.pt-page-cosmic {
  padding-top: 0 !important;
}
/* Le main pt-page-cosmic est dans .site-content / .entry-content Astra qui
   peut avoir des paddings. On les neutralise UNIQUEMENT quand la page contient
   notre hero cosmique. */
body:has(.pt-page-cosmic) .site-content,
body:has(.pt-page-cosmic) .ast-container,
body:has(.pt-page-cosmic) .entry-content,
body:has(.pt-page-cosmic) #primary,
body:has(.pt-page-cosmic) .ast-no-sidebar .entry-content {
  padding-top: 0 !important;
  margin-top: 0 !important;
}
/* La page elle-meme commence avec son propre padding interne */
.pt-page-cosmic {
  padding: 18px 0 60px !important;
}
/* Empecher Astra de mettre un fond clair derriere la page */
body:has(.pt-page-cosmic),
body:has(.pt-page-cosmic) .site-content,
body:has(.pt-page-cosmic) .ast-container {
  background-color: #0a0e1a !important;
}

/* Le hero V237 lui-meme : reduire son margin-top a 0 quand il est le premier
   enfant pour coller au top */
.pt-page-cosmic .pt-v237-hero {
  margin-top: 0 !important;
}

/* Fallback pour navigateurs sans :has() (Firefox < 121) : on cible le main
   directement et on pousse des regles via une classe ajoutee cote PHP */
.pt-page-cosmic-host {
  background-color: #0a0e1a !important;
  padding-top: 0 !important;
  margin-top: 0 !important;
}

/* v2.3.8 — Force overflow visible sur tous les hero-shell pour que le menu
   langues (en position absolute) puisse depasser. Les decoratifs internes
   sont bornes naturellement par leur propre inset. */
.pt-hero-shell {
  overflow: visible !important;
}
/* Mais garder le clipping visuel via clip-path sur les pseudo-elements
   decoratifs uniquement (le menu langues n est pas un pseudo-element) */
.pt-hero-shell::before,
.pt-hero-shell::after {
  clip-path: inset(0 round 28px);
}
/* Forcer le menu langues a passer par-dessus tout dans le hero */
.pt-hero-shell .pt-lang {
  position: relative !important;
  z-index: 99999 !important;
}
.pt-hero-shell .pt-lang__menu {
  position: absolute !important;
  z-index: 99999 !important;
  top: calc(100% + 8px) !important;
  right: 0 !important;
  left: auto !important;
}

/* =============================================================================
   PTE v2.3.9 — HERO COSMIQUE PAYS (analogue Variante F mais pour /prayertimes/{iso2}/)
   ============================================================================= */

/* Diptyque pays : stats a gauche / top villes a droite */
.pt-v239-country-diptych {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  align-items: stretch;
  margin-bottom: 18px;
}
@media (max-width: 760px) {
  .pt-v239-country-diptych { grid-template-columns: 1fr; }
}

/* BLOC GAUCHE : metriques pays en grille 2x2 */
.pt-page-cosmic .pt-v239-country-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  padding: 22px;
  background: linear-gradient(160deg, rgba(201,169,97,0.10), rgba(10,14,26,0.45));
  border: 1px solid var(--ptc-border-gold);
  border-radius: var(--ptc-radius);
  position: relative;
  overflow: hidden;
}
.pt-page-cosmic .pt-v239-country-stats::after {
  content: '';
  position: absolute;
  bottom: -40px; left: -40px;
  width: 180px; height: 180px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(201,169,97,0.22), transparent 65%);
  pointer-events: none;
}
.pt-page-cosmic .pt-v239-stat {
  position: relative;
  z-index: 2;
  padding: 14px 16px;
  background: rgba(10,14,26,0.50);
  border: 1px solid var(--ptc-border);
  border-radius: 10px;
  backdrop-filter: blur(6px);
}
.pt-page-cosmic .pt-v239-stat-lbl {
  font-size: 10.5px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ptc-gold-soft);
  font-weight: 600;
  margin-bottom: 8px;
}
.pt-page-cosmic .pt-v239-stat-val {
  font-family: var(--ptc-font-display);
  font-size: 36px;
  font-weight: 500;
  color: var(--ptc-fg);
  line-height: 1;
  letter-spacing: -0.01em;
  font-variant-numeric: tabular-nums;
}
.pt-page-cosmic .pt-v239-stat-val--text {
  font-size: 26px;
  font-variant-numeric: normal;
}

/* BLOC DROIT : liste top villes */
.pt-page-cosmic .pt-v239-top-cities {
  background: var(--ptc-surface);
  border: 1px solid var(--ptc-border);
  border-radius: var(--ptc-radius);
  padding: 14px 18px;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.pt-page-cosmic .pt-v239-top-cities-lbl {
  font-size: 10.5px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--ptc-gold-soft);
  font-weight: 600;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--ptc-border-gold);
  margin-bottom: 4px;
}
.pt-page-cosmic .pt-v239-top-city {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 11px 4px;
  text-decoration: none;
  border-bottom: 1px dashed rgba(232,230,223,0.06);
  transition: .15s;
}
.pt-page-cosmic .pt-v239-top-city:last-child {
  border-bottom: none;
}
.pt-page-cosmic .pt-v239-top-city:hover {
  padding-left: 8px;
  border-bottom-color: var(--ptc-gold);
}
.pt-page-cosmic .pt-v239-top-city-name {
  font-size: 15px;
  color: var(--ptc-fg);
  font-weight: 500;
  transition: color .15s;
}
.pt-page-cosmic .pt-v239-top-city:hover .pt-v239-top-city-name {
  color: var(--ptc-gold-soft);
}
.pt-page-cosmic .pt-v239-top-city-pop {
  font-size: 12.5px;
  color: var(--ptc-fg-muted);
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.02em;
}

/* Intro texte sous le diptyque */
.pt-page-cosmic .pt-v239-country-intro {
  margin: 18px 0 0;
  font-size: 14.5px;
  line-height: 1.7;
  color: var(--ptc-fg-muted);
  text-align: center;
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
}

/* Harmonisation des "ville en vedette" et "directory" cards en bas */
.pt-page-cosmic .pt-premium-tile {
  background: var(--ptc-surface) !important;
  border: 1px solid var(--ptc-border) !important;
  color: var(--ptc-fg) !important;
  border-radius: var(--ptc-radius) !important;
  backdrop-filter: blur(8px);
  transition: .15s;
}
.pt-page-cosmic .pt-premium-tile:hover {
  border-color: var(--ptc-gold) !important;
  background: rgba(201,169,97,0.06) !important;
}
.pt-page-cosmic .pt-premium-tile-kicker {
  color: var(--ptc-gold-soft) !important;
  font-size: 10.5px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 600;
}
.pt-page-cosmic .pt-premium-tile strong {
  font-family: var(--ptc-font-display);
  color: var(--ptc-fg) !important;
  font-weight: 500;
}
.pt-page-cosmic .pt-premium-tile span {
  color: var(--ptc-fg-muted) !important;
}
