:root{
  --shak-cream:#fffaf7;
  --shak-card:#ffffff;
  --shak-accent:#f39a4b;
  --shak-accent-2:#ea7186;
  --shak-accent-soft:#fff0f3;
  --shak-dark:#223042;
  --shak-text:#5d6673;
  --shak-border:rgba(34,48,66,.10);
  --shak-shadow:0 18px 44px rgba(16,24,40,.08);
  --shak-radius:26px;
  --shak-danger:#d64f45;
  --shak-success:#158a52;
}

.shak-period-wrap,
.shak-period-wrap *{
  box-sizing:border-box;
}

.shak-period-wrap{
  direction:rtl;
  font-family:'Cairo',sans-serif;
  color:var(--shak-dark);
}

.shak-period-wrap .shakshuk-card{
  max-width:1120px;
  margin:0 auto;
  background:linear-gradient(180deg, #fff, #fffdfa);
  border:1px solid var(--shak-border);
  border-radius:32px;
  box-shadow:var(--shak-shadow);
  padding:28px;
  overflow:hidden;
}

.shak-period-wrap .shakshuk-header{
  text-align:center;
  margin:0 0 22px;
}

.shak-period-wrap .shakshuk-header h1{
  margin:0 0 10px;
  font-size:48px;
  line-height:1.15;
  font-weight:900;
  color:var(--shak-dark);
}

.shak-period-wrap .shakshuk-header h1 span{
  color:var(--shak-accent-2);
}

.shak-period-wrap .shakshuk-header p{
  margin:0 auto;
  max-width:760px;
  font-size:18px;
  color:var(--shak-text);
}

.shak-period-wrap .shakshuk-hero{
  margin:0 0 22px;
  border-radius:28px;
  overflow:hidden;
  border:1px solid rgba(234,113,134,.14);
  background:#fff6f8;
}

.shak-period-wrap .shakshuk-hero img{
  display:block;
  width:100%;
  height:auto;
}

.shak-period-wrap .shakshuk-helper-box,
.shak-period-wrap .shak-caution-box,
.shak-period-wrap .shak-faq-box,
.shak-period-wrap .shak-highlight-box,
.shak-period-wrap .shak-progress-card,
.shak-period-wrap .shak-list-card,
.shak-period-wrap .shak-stat-card,
.shak-period-wrap .shakshuk-form{
  background:var(--shak-card);
  border:1px solid var(--shak-border);
  border-radius:24px;
  box-shadow:0 10px 28px rgba(16,24,40,.05);
}

.shak-period-wrap .shakshuk-helper-box{
  display:grid;
  grid-template-columns:72px 1fr;
  gap:16px;
  padding:18px;
  margin-bottom:20px;
  background:linear-gradient(180deg, #fff8fa, #ffffff);
}

.shak-period-wrap .shak-helper-icon{
  width:72px;
  height:72px;
  border-radius:20px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--shak-accent-soft);
  border:1px solid rgba(234,113,134,.18);
  font-size:30px;
}

.shak-period-wrap .shak-helper-copy strong,
.shak-period-wrap .shak-section-head h2{
  display:block;
  margin:0 0 10px;
  font-size:24px;
  font-weight:900;
}

.shak-period-wrap .shak-helper-copy ul,
.shak-period-wrap .shak-caution-box ul,
.shak-period-wrap .shak-bullets-list{
  margin:0;
  padding:0 18px 0 0;
  color:var(--shak-text);
}

.shak-period-wrap .shak-helper-copy li,
.shak-period-wrap .shak-caution-box li,
.shak-period-wrap .shak-bullets-list li{
  margin:0 0 8px;
}

.shak-period-wrap .shakshuk-alert{
  border-radius:18px;
  padding:14px 16px;
  margin:0 0 18px;
  font-weight:700;
}

.shak-period-wrap .shakshuk-alert ul{
  margin:0;
  padding:0 18px 0 0;
}

.shak-period-wrap .shakshuk-alert-error{
  background:#fff4f3;
  color:var(--shak-danger);
  border:1px solid rgba(214,79,69,.16);
}

.shak-period-wrap .shakshuk-alert-success{
  background:#f1fff8;
  color:var(--shak-success);
  border:1px solid rgba(21,138,82,.16);
}

.shak-period-wrap .shakshuk-form{
  padding:20px;
  margin-bottom:20px;
}

.shak-period-wrap .shakshuk-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:16px;
}

.shak-period-wrap .shak-field label{
  display:block;
  margin:0 0 8px;
  font-weight:800;
  font-size:15px;
  color:var(--shak-dark);
}

.shak-period-wrap .shak-field input{
  width:100%;
  min-height:54px;
  border-radius:18px;
  border:1px solid rgba(34,48,66,.12);
  background:#fff;
  padding:12px 16px;
  font-family:'Cairo',sans-serif;
  font-size:16px;
  color:var(--shak-dark);
}

.shak-period-wrap .shak-field input:focus{
  outline:none;
  border-color:rgba(234,113,134,.40);
  box-shadow:0 0 0 4px rgba(234,113,134,.10);
}

.shak-period-wrap .shak-honeypot{
  position:absolute !important;
  left:-9999px !important;
  width:1px !important;
  height:1px !important;
  opacity:0 !important;
  pointer-events:none !important;
}

.shak-period-wrap .shakshuk-actions{
  margin-top:16px;
}

.shak-period-wrap .shak-btn{
  appearance:none;
  border:none;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:54px;
  padding:12px 26px;
  border-radius:999px;
  font-family:'Cairo',sans-serif;
  font-size:17px;
  font-weight:800;
  text-decoration:none;
  transition:.2s ease;
}

.shak-period-wrap .shak-btn:hover{
  transform:translateY(-2px);
}

.shak-period-wrap .shak-btn-primary{
  width:100%;
  background:linear-gradient(135deg, var(--shak-accent), var(--shak-accent-2));
  color:#fff;
}

.shak-period-wrap .shak-results{
  display:grid;
  gap:18px;
  margin-bottom:18px;
}

.shak-period-wrap .shak-highlight-box,
.shak-period-wrap .shak-progress-card,
.shak-period-wrap .shak-list-card,
.shak-period-wrap .shak-caution-box,
.shak-period-wrap .shak-faq-box{
  padding:20px;
}

.shak-period-wrap .shak-highlight-box{
  text-align:center;
  background:linear-gradient(180deg, #fff8fa, #ffffff);
}

.shak-period-wrap .shak-highlight-label{
  color:var(--shak-text);
  font-size:14px;
  font-weight:700;
  margin-bottom:8px;
}

.shak-period-wrap .shak-highlight-title{
  font-size:30px;
  line-height:1.3;
  font-weight:900;
  margin-bottom:8px;
}

.shak-period-wrap .shak-highlight-date{
  font-size:34px;
  line-height:1.2;
  font-weight:900;
  color:var(--shak-accent-2);
  margin-bottom:10px;
}

.shak-period-wrap .shak-highlight-box p,
.shak-period-wrap .shak-section-head p,
.shak-period-wrap .shak-upcoming-item span,
.shak-period-wrap .shak-faq-item p,
.shak-period-wrap .shak-caution-box{
  color:var(--shak-text);
}

.shak-period-wrap .shak-stats-grid,
.shak-period-wrap .shak-schedule-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:16px;
}

.shak-period-wrap .shak-stat-card{
  padding:18px;
}

.shak-period-wrap .shak-stat-card span{
  display:block;
  margin-bottom:10px;
  color:var(--shak-text);
  font-size:14px;
  font-weight:700;
}

.shak-period-wrap .shak-stat-card strong{
  display:block;
  font-size:26px;
  line-height:1.35;
  font-weight:900;
  color:var(--shak-dark);
}

.shak-period-wrap .shak-progress-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom:12px;
  font-weight:800;
}

.shak-period-wrap .shak-progress-bar{
  height:14px;
  background:#f4e7ea;
  border-radius:999px;
  overflow:hidden;
}

.shak-period-wrap .shak-progress-bar span{
  display:block;
  height:100%;
  border-radius:999px;
  background:linear-gradient(135deg, var(--shak-accent), var(--shak-accent-2));
}

.shak-period-wrap .shak-upcoming-list{
  display:grid;
  gap:12px;
}

.shak-period-wrap .shak-upcoming-item{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:14px 16px;
  border-radius:18px;
  border:1px solid rgba(34,48,66,.08);
  background:#fffafa;
}

.shak-period-wrap .shak-upcoming-item strong{
  display:block;
  margin-bottom:4px;
  font-size:18px;
}

.shak-period-wrap .shak-upcoming-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:6px 12px;
  border-radius:999px;
  background:#fff0f3;
  color:var(--shak-accent-2);
  border:1px solid rgba(234,113,134,.16);
  font-size:14px;
  font-weight:800;
  white-space:nowrap;
}

.shak-period-wrap .shak-caution-box{
  margin-bottom:18px;
  background:linear-gradient(180deg, #fffaf8, #ffffff);
}

.shak-period-wrap .shak-caution-box strong{
  display:block;
  margin-bottom:10px;
  font-size:20px;
  color:var(--shak-danger);
}

.shak-period-wrap .shak-faq-list{
  display:grid;
  gap:12px;
  margin-top:16px;
}

.shak-period-wrap .shak-faq-item{
  border:1px solid var(--shak-border);
  border-radius:18px;
  padding:14px 16px;
  background:#fff;
}

.shak-period-wrap .shak-faq-item summary{
  cursor:pointer;
  font-weight:800;
  color:var(--shak-dark);
  list-style:none;
}

.shak-period-wrap .shak-faq-item summary::-webkit-details-marker{
  display:none;
}

.shak-period-wrap .shak-faq-item p{
  margin:12px 0 0;
}

.shak-period-wrap .shak-btn:focus-visible,
.shak-period-wrap .shak-faq-item summary:focus-visible{
  outline:3px solid rgba(234,113,134,.22);
  outline-offset:3px;
}

@media (max-width: 991px){
  .shak-period-wrap .shakshuk-card{
    padding:22px;
  }

  .shak-period-wrap .shak-stats-grid,
  .shak-period-wrap .shak-schedule-grid,
  .shak-period-wrap .shakshuk-grid{
    grid-template-columns:1fr;
  }
}

@media (max-width: 767px){
  .shak-period-wrap .shakshuk-card{
    padding:16px;
    border-radius:24px;
  }

  .shak-period-wrap .shakshuk-header h1{
    font-size:36px;
  }

  .shak-period-wrap .shakshuk-header p{
    font-size:16px;
  }

  .shak-period-wrap .shakshuk-hero{
    border-radius:20px;
  }

  .shak-period-wrap .shakshuk-helper-box{
    grid-template-columns:1fr;
    text-align:right;
  }

  .shak-period-wrap .shak-helper-icon{
    width:60px;
    height:60px;
    font-size:26px;
  }

  .shak-period-wrap .shakshuk-form,
  .shak-period-wrap .shak-highlight-box,
  .shak-period-wrap .shak-progress-card,
  .shak-period-wrap .shak-list-card,
  .shak-period-wrap .shak-caution-box,
  .shak-period-wrap .shak-faq-box,
  .shak-period-wrap .shak-stat-card{
    padding:16px;
    border-radius:18px;
  }

  .shak-period-wrap .shak-highlight-title{
    font-size:24px;
  }

  .shak-period-wrap .shak-highlight-date{
    font-size:28px;
  }

  .shak-period-wrap .shak-stat-card strong{
    font-size:22px;
  }

  .shak-period-wrap .shak-upcoming-item{
    align-items:flex-start;
    flex-direction:column;
  }
}

@media (max-width: 480px){
  .shak-period-wrap .shakshuk-header h1{
    font-size:31px;
  }

  .shak-period-wrap .shakshuk-header p,
  .shak-period-wrap .shak-highlight-box p,
  .shak-period-wrap .shak-upcoming-item span,
  .shak-period-wrap .shak-faq-item p,
  .shak-period-wrap .shak-field input{
    font-size:14px;
  }
}
