/* =========================
   Qibla Page
========================= */

.qibla-hero{
  position:relative;
  width:100vw;
  margin:0 calc(50% - 50vw) 12px;
  background:
    radial-gradient(circle at 20% 18%, rgba(255,255,255,.10), transparent 30%),
    linear-gradient(135deg, #2b8752 0%, #247a49 48%, #19643b 100%);
  color:#fff;
  overflow:hidden;
}

.qibla-hero::after{
  content:"";
  position:absolute;
  inset:auto 0 0;
  height:1px;
  background:rgba(217,169,40,.65);
}

.qibla-hero-inner{
  max-width:1180px;
  margin:0 auto;
  padding:36px 16px 40px;
  text-align:center;
}

.qibla-hero h1{
  color:#fff;
  font-size:2.25rem;
  line-height:1.35;
  margin:0 0 10px;
  font-weight:900;
}

.qibla-hero .qibla-intro{
  max-width:820px;
  margin:0 auto;
  color:rgba(255,255,255,.94);
  font-size:1rem;
  line-height:1.85;
}

/* Containers */
.qibla-container{
  width:calc(100% - 32px);
  max-width:1220px;
  margin:0 auto 8px;
}

/* Cards */
.qibla-card{
  background:var(--color-surface);
  border:1px solid rgba(22,101,52,.10);
  border-radius:20px;
  padding:22px 28px;
  box-shadow:0 7px 20px var(--color-shadow);
}

.qibla-main-card{
  background:#f8faf6;
  border-color:rgba(22,101,52,.16);
}

.qibla-card h2,
.qibla-title{
  position:relative;
  color:#111827;
  font-size:1.22rem;
  line-height:1.55;
  margin:0 0 12px;
  padding-right:16px;
  font-weight:800;
}

.qibla-card h2::before,
.qibla-title::before{
  content:"";
  position:absolute;
  right:0;
  top:.55em;
  width:5px;
  height:1.18em;
  border-radius:999px;
  background:var(--color-primary);
}

.qibla-card p{
  color:#374151;
  font-size:1.03rem;
  line-height:2;
  margin:0;
}

.qibla-kaaba-content{
  display:grid;
  gap:10px;
}

.qibla-kaaba-content h3{
  margin:0;
  color:#166534;
  font-size:1.02rem;
  line-height:1.7;
  font-weight:900;
}

.qibla-kaaba-content p{
  max-width:980px;
}

.qibla-kaaba-coords{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:8px;
  margin-top:4px;
  padding:12px 14px;
  border-radius:16px;
  background:#f8faf6;
  border:1px solid rgba(22,101,52,.12);
  color:#374151;
  font-size:.98rem;
  line-height:1.8;
}

.qibla-kaaba-coords span{
  color:#166534;
  font-weight:900;
}

.qibla-kaaba-coords strong{
  color:#111827;
  font-weight:900;
}

/* Major Qibla Cities Table */
.qibla-major-cities-card{
  display:grid;
  gap:14px;
}

.qibla-major-table-wrap{
  width:100%;
  overflow-x:auto;
  border:1px solid rgba(22,101,52,.12);
  border-radius:18px;
  background:#fffdf7;
}

.qibla-major-table{
  width:100%;
  min-width:620px;
  border-collapse:collapse;
  font-size:.96rem;
}

.qibla-major-table th,
.qibla-major-table td{
  padding:12px 14px;
  border-bottom:1px solid rgba(22,101,52,.10);
  text-align:right;
  vertical-align:middle;
}

.qibla-major-table th{
  color:#166534;
  background:#f8faf6;
  font-weight:900;
  white-space:nowrap;
}

.qibla-major-table tbody tr:last-child td{
  border-bottom:0;
}

.qibla-major-table a{
  color:#14532d;
  font-weight:900;
  text-decoration:none;
}

.qibla-major-table a:hover{
  text-decoration:none;
}

.qibla-number-ltr{
  direction:ltr;
  unicode-bidi:embed;
  display:inline-block;
  color:#111827;
  font-weight:800;
  white-space:nowrap;
}

.qibla-distance-value{
  direction:rtl;
  unicode-bidi:isolate;
  display:inline-flex;
  align-items:baseline;
  gap:4px;
  color:#111827;
  font-weight:800;
  white-space:nowrap;
}

.qibla-distance-unit{
  direction:rtl;
  unicode-bidi:isolate;
}

.qibla-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:10px;
}

.qibla-status{
  margin-top:14px;
  padding:10px 12px;
  border-radius:14px;
  background:#eefbe0;
  border:1px solid rgba(22,101,52,.16);
  color:#166534;
  font-size:.95rem;
  line-height:1.7;
  font-weight:800;
}

/* Qibla Tool */
.qibla-tool-card{
  background:#f8faf6;
  border-color:rgba(22,101,52,.16);
}

.qibla-summary-layout{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
  margin-bottom:18px;
}

.qibla-summary-content{
  display:contents;
}

.qibla-summary-content .qibla-title{
  grid-column:1 / -1;
}

.qibla-summary-text{
  grid-column:1 / -1;
  margin:8px 0 6px;
  color:#374151;
  font-size:1rem;
  line-height:2;
}

.qibla-summary-text strong{
  color:#111827;
  font-weight:900;
}

.qibla-summary-panel{
  display:grid;
  grid-template-columns:minmax(0, 1fr) 220px;
  gap:22px;
  align-items:center;
  padding:18px 20px;
  border-radius:20px;
  background:#fff;
  border:1px solid rgba(22,101,52,.11);
}

.qibla-summary-details{
  display:grid;
  gap:9px;
  padding:0;
  border-radius:0;
  background:transparent;
  border:0;
}

.qibla-summary-details div{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:8px;
  color:#374151;
  font-size:.96rem;
  line-height:1.8;
}

.qibla-summary-details span{
  color:#166534;
  font-weight:900;
}

.qibla-summary-details strong{
  color:#111827;
  font-weight:900;
}

.qibla-summary-compass{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:150px;
}

.qibla-summary-compass .qibla-compass{
  position:relative;
  width:175px;
  height:205px;
  margin:-14px auto -20px;
  background:url('/layout/images/qibla/compass-rose-base.svg') center center / contain no-repeat;
  border:0;
  box-shadow:none;
  overflow:visible;
}

.qibla-summary-compass .qibla-compass-arrow{
  position:absolute;
  z-index:2;
  left:50%;
  top:61px;
  width:8px;
  height:61px;
  margin-left:-4px;
  border-radius:999px;
  background:#dc2626;
  transform-origin:50% 54px;
  transform:rotate(0deg);
  box-shadow:0 3px 8px rgba(15,23,42,.18);
}

.qibla-summary-compass .qibla-compass-arrow::before{
  content:"";
  position:absolute;
  left:50%;
  top:-11px;
  margin-left:-9px;
  border-right:9px solid transparent;
  border-left:9px solid transparent;
  border-bottom:15px solid #dc2626;
}

.qibla-summary-compass .qibla-compass-center{
  position:absolute;
  z-index:3;
  left:50%;
  top:115px;
  width:14px;
  height:14px;
  margin:-7px 0 0 -7px;
  border-radius:50%;
  background:#166534;
  border:3px solid #fffef8;
  box-shadow:0 2px 8px rgba(15,23,42,.18);
}

.qibla-panel-search{
  grid-column:1 / -1;
  position:relative;
  margin:12px 0 2px;
  padding-top:2px;
}

.qibla-panel-search-input{
  width:100%;
  height:38px;
  border-radius:18px;
  border:1px solid rgba(22,101,52,.18);
  background:rgba(255,255,255,.96);
  box-shadow:0 12px 30px rgba(15,23,42,.08);
  padding:0 18px;
  color:#111827;
  font-family:inherit;
  font-size:16px;
  line-height:38px;
  outline:none;
  direction:rtl;
  text-align:right;
}

.qibla-panel-search-input:focus{
  border-color:var(--color-primary);
  box-shadow:
    0 12px 30px rgba(15,23,42,.08),
    0 0 0 4px rgba(22,101,52,.13);
}

.qibla-panel-search-results{
  position:absolute;
  z-index:9999;
  top:calc(100% + 8px);
  right:0;
  left:0;
  max-height:320px;
  overflow-y:auto;
  border-radius:16px;
  background:#fff;
  border:1px solid rgba(22,101,52,.14);
  box-shadow:0 18px 45px rgba(15,23,42,.16);
}

.qibla-panel-search-message{
  margin-top:8px;
  color:#6b7280;
  font-size:.9rem;
  line-height:1.7;
}

.qibla-panel-search-results .search-item{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:10px 12px;
  border:0;
  border-bottom:1px solid var(--color-border);
  background:#fff;
  color:inherit;
  font-family:inherit;
  text-align:right;
  cursor:pointer;
}

.qibla-panel-search-results .search-item:last-child{
  border-bottom:0;
}

.qibla-panel-search-results .search-item:hover,
.qibla-panel-search-results .search-item:focus{
  background:var(--color-surface-alt);
  outline:none;
}

.qibla-panel-search-results .s-col{
  display:flex;
  flex-direction:column;
  gap:3px;
}

.qibla-panel-search-results .s-name{
  font-weight:700;
}

.qibla-panel-search-results .s-country-name{
  font-size:12px;
  opacity:.75;
}

.qibla-panel-search-results .s-badge{
  margin-top:2px;
  width:fit-content;
  font-size:11px;
  padding:2px 8px;
  border-radius:999px;
}

.qibla-panel-search-results .s-city{
  background:var(--color-surface-alt);
  color:var(--color-text-light);
}

.qibla-panel-search-results .s-flag{
  width:26px;
  height:18px;
  object-fit:cover;
  border:1px solid var(--color-border);
  border-radius:4px;
}

.qibla-tool-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:18px;
  margin-bottom:16px;
}

.qibla-locate-btn{
  flex:0 0 auto;
  border:0;
  border-radius:999px;
  background:var(--color-primary);
  color:#fff;
  padding:11px 20px;
  font-family:inherit;
  font-size:.96rem;
  font-weight:800;
  line-height:1.4;
  cursor:pointer;
}

.qibla-locate-btn:hover{
  background:#14532d;
}

.qibla-info-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:10px;
  margin:16px 0;
}

.qibla-info-box{
  min-height:122px;
  padding:16px;
  border-radius:18px;
  background:#fff;
  border:1px solid rgba(22,101,52,.11);
}

.qibla-info-label{
  display:block;
  margin-bottom:8px;
  color:#166534;
  font-size:.86rem;
  font-weight:900;
}

.qibla-info-box strong{
  display:block;
  color:#111827;
  font-size:1.04rem;
  line-height:1.7;
  font-weight:900;
}

.qibla-info-box small{
  display:block;
  margin-top:5px;
  color:#6b7280;
  font-size:.86rem;
  line-height:1.6;
}


.qibla-compass{
  position:relative;
  width:86px;
  height:86px;
  margin:4px auto 8px;
  border-radius:50%;
  background:
    radial-gradient(circle at center, #fffef8 0 36%, rgba(255,255,255,.92) 37% 58%, transparent 59%),
    repeating-conic-gradient(from 0deg, rgba(22,101,52,.26) 0deg 2deg, transparent 2deg 15deg),
    conic-gradient(from 0deg, rgba(22,101,52,.10), rgba(217,169,40,.20), rgba(22,101,52,.10));
  border:1px solid rgba(22,101,52,.22);
  box-shadow:inset 0 0 0 7px rgba(255,255,255,.72), 0 10px 24px rgba(15,23,42,.08);
}






.qibla-map-wrap{
  position:relative;
  overflow:hidden;
  border-radius:20px;
  border:1px solid rgba(22,101,52,.14);
  background:#eefbe0;
}

.qibla-map{
  width:100%;
  height:540px;
  min-height:360px;
}








/* Qibla coordinates direction fix */
#js-qibla-user-coords,
#js-qibla-map-coords,
.qibla-coords-ltr{
  direction:ltr;
  unicode-bidi:embed;
}

/* Responsive */
@media (max-width:768px){
  .qibla-hero{
    margin-bottom:10px;
  }

  .qibla-hero-inner{
    padding:24px 14px 24px;
  }

  .qibla-hero h1{
    font-size:1.10rem;
    line-height:1.24;
    margin-bottom:7px;
  }

  .qibla-hero .qibla-intro{
    font-size:.91rem;
    line-height:1.58;
  }

  .qibla-container{
    width:calc(100% - 20px);
    margin-bottom:10px;
  }

  .qibla-card{
    border-radius:18px;
    padding:19px 16px;
  }

  .qibla-card h2,
  .qibla-title{
    font-size:1.12rem;
    margin-bottom:10px;
  }

  .qibla-card p{
    font-size:.96rem;
    line-height:1.9;
  }

    .qibla-major-cities-card{
      gap:8px;
    }

    .qibla-major-cities-card h2{
      margin-bottom:0;
    }

    .qibla-major-cities-card > p{
      margin:0;
    }

    .qibla-major-table-wrap{
      overflow-x:hidden;
    }

    .qibla-major-table{
      min-width:0;
      width:100%;
      table-layout:fixed;
      font-size:.86rem;
    }

    .qibla-major-table th,
    .qibla-major-table td{
      padding:10px 6px;
      white-space:normal;
      word-break:normal;
    }

    .qibla-major-table th{
      font-size:.82rem;
      line-height:1.45;
    }

    .qibla-kaaba-coords{
      display:grid;
      grid-template-columns:repeat(2, max-content);
      justify-content:center;
      align-items:center;
      column-gap:34px;
      text-align:center;
    }

    .qibla-kaaba-coords div{
      display:grid;
      gap:4px;
      justify-items:center;
      text-align:center;
    }


  .qibla-grid{
    grid-template-columns:1fr;
  }

  .qibla-tool-head{
    display:grid;
    grid-template-columns:1fr;
    gap:12px;
    text-align:center;
  }

  .qibla-locate-btn{
    width:100%;
    justify-content:center;
    padding:10px 18px;
  }

  .qibla-info-grid{
    grid-template-columns:1fr;
    gap:8px;
    margin:14px 0;
  }

  .qibla-info-box{
    min-height:auto;
    padding:14px;
    text-align:center;
  }
    .qibla-summary-panel{
      grid-template-columns:1fr;
      gap:12px;
      padding:14px 12px;
      text-align:right;
    }

    .qibla-summary-details{
      display:grid;
      grid-template-columns:1fr;
      gap:0;
      justify-items:stretch;
      text-align:right;
    }

    .qibla-summary-details h3{
      text-align:center;
      margin:0 0 10px;
      font-size:1.08rem;
    }

    .qibla-summary-details div{
      display:grid;
      grid-template-columns:minmax(118px, auto) 1fr;
      align-items:center;
      gap:10px;
      padding:8px 0;
      border-bottom:1px solid rgba(22,101,52,.10);
      font-size:.92rem;
      line-height:1.55;
      text-align:right;
    }

    .qibla-summary-details div:last-child{
      border-bottom:0;
    }

    .qibla-summary-details div span{
      color:#166534;
      font-weight:800;
    }

    .qibla-summary-details div strong{
      direction:ltr;
      unicode-bidi:embed;
      justify-self:end;
      text-align:left;
      font-weight:900;
      white-space:nowrap;
    }

    #js-qibla-distance{
      direction:rtl;
      unicode-bidi:isolate;
      text-align:left;
    }

    .qibla-summary-compass{
      min-height:auto;
      order:2;
    }

    .qibla-summary-compass .qibla-compass{
      width:155px;
      height:182px;
      margin:-8px auto -12px;
    }

    .qibla-summary-compass .qibla-compass-arrow{
      top:54px;
      width:7px;
      height:54px;
      margin-left:-3.5px;
      transform-origin:50% 47px;
    }

    .qibla-summary-compass .qibla-compass-arrow::before{
      top:-10px;
      margin-left:-8px;
      border-right-width:8px;
      border-left-width:8px;
      border-bottom-width:14px;
    }

    .qibla-summary-compass .qibla-compass-center{
      top:102px;
      width:13px;
      height:13px;
      margin:-6.5px 0 0 -6.5px;
    }

    .qibla-panel-search{
      order:3;
      margin-top:4px;
    }



  .qibla-map{
    height:390px;
    min-height:320px;
  }

  .qibla-status{
    font-size:.9rem;
  }
}

@media (max-width:420px){
  .qibla-hero h1{
    font-size:1.10rem;
    line-height:1.24;
  }
}

