/* ============================================================
 * Sahhelha Free Mode — Banners Stylesheet
 * Matches the v3 preview design exactly
 * ============================================================ */

/* ===== Visitor Hero Banner ===== */
.sfm-hero-wrap{
  margin:80px 16px 24px;
  max-width:1100px;
}
@media(min-width:1132px){
  .sfm-hero-wrap{margin-left:auto;margin-right:auto}
}

.sfm-hero{
  position:relative;
  background:
    radial-gradient(ellipse at top right, rgba(250,199,117,.15), transparent 50%),
    radial-gradient(ellipse at bottom left, rgba(26,188,176,.2), transparent 50%),
    linear-gradient(135deg, #0a4a42 0%, #0F6E56 50%, #0a3a35 100%);
  border-radius:20px;
  padding:42px 28px;
  overflow:hidden;
  border:1px solid rgba(26,188,176,.25);
}
.sfm-hero-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size:32px 32px;
  -webkit-mask-image:radial-gradient(ellipse at center, #000 30%, transparent 75%);
  mask-image:radial-gradient(ellipse at center, #000 30%, transparent 75%);
  pointer-events:none;
}
.sfm-orb{position:absolute;border-radius:50%;filter:blur(50px);pointer-events:none}
.sfm-orb-1{width:240px;height:240px;background:rgba(26,188,176,.4);top:-80px;left:-60px;animation:sfm-orb-float 12s ease-in-out infinite}
.sfm-orb-2{width:180px;height:180px;background:rgba(250,199,117,.25);bottom:-60px;right:-40px;animation:sfm-orb-float 14s ease-in-out infinite -3s}
@keyframes sfm-orb-float{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(20px,-15px) scale(1.05)}
}

.sfm-hero-content{position:relative;z-index:2;max-width:680px;margin:0 auto;text-align:center}

.sfm-hero-badge{
  display:inline-flex;align-items:center;gap:7px;
  padding:6px 14px;
  background:rgba(255,255,255,.08);
  -webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.15);
  border-radius:50px;
  font-size:12px;font-weight:700;color:#fff;
  margin-bottom:14px;
  font-family:'Cairo','Noto Kufi Arabic',sans-serif;
}
.sfm-dot{width:7px;height:7px;border-radius:50%;background:#FAC775;box-shadow:0 0 10px #FAC775;animation:sfm-blink 1.5s infinite}
@keyframes sfm-blink{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}

.sfm-hero-title{
  font-family:'Noto Kufi Arabic','Cairo',sans-serif;
  font-size:clamp(20px, 3.6vw, 30px);
  font-weight:900;line-height:1.4;color:#fff;
  margin:0 0 6px 0;
  min-height:60px;
  display:flex;align-items:center;justify-content:center;
}
.sfm-tw-text{display:inline-block}
.sfm-tw-text .yellow{color:#FAC775}
.sfm-tw-cursor{
  display:inline-block;width:3px;height:1em;
  background:#FAC775;margin-right:3px;vertical-align:middle;
  animation:sfm-cursor-blink 1s step-end infinite;border-radius:2px;
}
@keyframes sfm-cursor-blink{0%,50%{opacity:1}51%,100%{opacity:0}}

.sfm-services-line{
  font-size:clamp(15px, 2.2vw, 19px);
  font-weight:700;
  color:rgba(255,255,255,.9);
  margin-bottom:16px;
  min-height:34px;
  display:flex;align-items:center;justify-content:center;gap:8px;
  flex-wrap:wrap;
  font-family:'Cairo',sans-serif;
}
.sfm-prefix{color:rgba(255,255,255,.7);font-weight:600;font-size:.92em}
.sfm-svc-rotator{
  display:inline-flex;align-items:center;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(250,199,117,.3);
  border-radius:50px;
  padding:5px 16px;
  min-width:140px;justify-content:center;
  position:relative;overflow:hidden;
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
}
.sfm-svc-text{
  display:inline-block;
  background:linear-gradient(135deg,#FAC775,#FFE0A0);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
  font-weight:900;white-space:nowrap;
}
.sfm-svc-text.sfm-in{animation:sfm-slide-in .5s cubic-bezier(.4,0,.2,1) forwards}
.sfm-svc-text.sfm-out{animation:sfm-slide-out .35s cubic-bezier(.4,0,1,1) forwards}
@keyframes sfm-slide-in{
  0%{transform:translateY(100%) rotate(8deg);opacity:0}
  100%{transform:translateY(0) rotate(0);opacity:1}
}
@keyframes sfm-slide-out{
  0%{transform:translateY(0) rotate(0);opacity:1}
  100%{transform:translateY(-100%) rotate(-8deg);opacity:0}
}

.sfm-hero-sub{
  font-size:clamp(12.5px, 1.5vw, 14px);
  color:rgba(255,255,255,.78);
  margin:0 auto 20px;
  max-width:480px;
  font-family:'Cairo',sans-serif;
  line-height:1.7;
}

.sfm-cta-row{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}

.sfm-btn-wrap{position:relative;display:inline-block}
.sfm-pulse-ring{
  position:absolute;inset:0;border-radius:50px;
  border:2px solid rgba(250,199,117,.55);
  animation:sfm-pulse 2s ease-out infinite;pointer-events:none;
}
.sfm-pr2{animation-delay:.6s}
.sfm-pr3{animation-delay:1.2s}
@keyframes sfm-pulse{
  0%{transform:scale(.95);opacity:1}
  100%{transform:scale(1.5);opacity:0}
}

.sfm-btn-primary{
  position:relative;display:inline-flex;align-items:center;gap:7px;
  padding:12px 26px;
  background:linear-gradient(135deg,#FAC775,#F59E0B);
  color:#5C3D00;
  border-radius:50px;
  font-size:14px;font-weight:900;
  text-decoration:none;border:none;cursor:pointer;
  font-family:'Cairo',sans-serif;
  box-shadow:0 6px 20px rgba(250,199,117,.4);
  transition:all .25s ease;z-index:2;
}
.sfm-btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(250,199,117,.55);color:#5C3D00}
.sfm-btn-primary svg{width:15px;height:15px}

.sfm-btn-secondary{
  display:inline-flex;align-items:center;gap:6px;
  padding:12px 22px;
  background:rgba(255,255,255,.08);color:#fff;
  border-radius:50px;
  font-size:13.5px;font-weight:700;text-decoration:none;
  border:1px solid rgba(255,255,255,.18);cursor:pointer;
  transition:all .25s ease;
  font-family:'Cairo',sans-serif;
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
}
.sfm-btn-secondary:hover{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.3);transform:translateY(-1px);color:#fff}
.sfm-btn-secondary svg{width:13px;height:13px;opacity:.85}

.sfm-features{
  display:flex;gap:14px;margin-top:16px;
  flex-wrap:wrap;justify-content:center;
}
.sfm-feat{
  display:flex;align-items:center;gap:5px;
  color:rgba(255,255,255,.78);
  font-size:11.5px;font-weight:600;
  font-family:'Cairo',sans-serif;
}
.sfm-feat svg{width:12px;height:12px;color:#FAC775;flex-shrink:0}

/* ===== Vendor Hero variant (yellow/gold theme) ===== */
.sfm-hero.sfm-hero-vendor{
  background:
    radial-gradient(ellipse at top right, rgba(250,199,117,.25), transparent 50%),
    radial-gradient(ellipse at bottom left, rgba(217,119,6,.18), transparent 50%),
    linear-gradient(135deg, #5C3D00 0%, #92591a 50%, #4a3008 100%);
  border-color:rgba(250,199,117,.35);
}
.sfm-hero-vendor .sfm-orb-1{background:rgba(250,199,117,.4)}
.sfm-hero-vendor .sfm-orb-2{background:rgba(217,119,6,.25)}

/* Client hero variant uses default theme (teal) */
.sfm-hero.sfm-hero-client{
  /* uses default colors */
}

/* ===== BIG Close button on Hero ===== */
.sfm-hero-close{
  position:absolute;
  top:16px;
  left:16px;
  z-index:10;
  width:40px;height:40px;
  border-radius:50%;
  background:rgba(0,0,0,.35);
  -webkit-backdrop-filter:blur(10px);
  backdrop-filter:blur(10px);
  border:1.5px solid rgba(255,255,255,.25);
  color:#fff;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0;
  font-family:inherit;
  transition:all .2s ease;
}
.sfm-hero-close:hover{
  background:rgba(239,68,68,.85);
  border-color:rgba(255,255,255,.4);
  transform:scale(1.1) rotate(90deg);
}
.sfm-hero-close svg{width:20px;height:20px}

@media(max-width:640px){
  .sfm-hero-close{
    top:12px;left:12px;
    width:36px;height:36px;
  }
  .sfm-hero-close svg{width:18px;height:18px}
}
.sfm-logged-banner{
  position:relative;
  border-radius:14px;
  padding:18px 20px;
  overflow:hidden;
  border:1px solid;
  margin-bottom:16px;
  font-family:'Cairo',sans-serif;
}
.sfm-logged-client{
  background:
    radial-gradient(ellipse at top right, rgba(26,188,176,.18), transparent 60%),
    linear-gradient(135deg,rgba(8,145,178,.12),rgba(15,110,86,.08));
  border-color:rgba(26,188,176,.28);
}
.sfm-logged-vendor{
  background:
    radial-gradient(ellipse at top right, rgba(250,199,117,.15), transparent 60%),
    linear-gradient(135deg,rgba(245,158,11,.1),rgba(217,119,6,.05));
  border-color:rgba(245,158,11,.3);
}

.sfm-lb-top{display:flex;align-items:center;gap:13px;margin-bottom:10px}
.sfm-banner-icon{
  position:relative;z-index:2;
  width:46px;height:46px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  font-size:21px;flex-shrink:0;
}
.sfm-logged-client .sfm-banner-icon{background:rgba(26,188,176,.18);border:1px solid rgba(26,188,176,.35)}
.sfm-logged-vendor .sfm-banner-icon{background:rgba(245,158,11,.18);border:1px solid rgba(245,158,11,.35)}

.sfm-banner-text{flex:1;min-width:0;position:relative;z-index:2}
.sfm-banner-tag{
  display:inline-flex;align-items:center;gap:4px;
  padding:2px 8px;border-radius:50px;
  font-size:10.5px;font-weight:800;
  margin-bottom:3px;
}
.sfm-logged-client .sfm-banner-tag{background:rgba(26,188,176,.18);color:#5DCAA5}
.sfm-logged-vendor .sfm-banner-tag{background:rgba(245,158,11,.18);color:#FAC775}

.sfm-banner-title{
  font-size:14.5px;font-weight:800;
  color:#fff;line-height:1.4;margin:0;
}

.sfm-banner-svc-line{
  font-size:13px;
  color:rgba(255,255,255,.72);
  display:flex;align-items:center;gap:6px;
  flex-wrap:wrap;
  margin-bottom:14px;
  min-height:30px;
  position:relative;z-index:2;
}
.sfm-prefix-sm{font-weight:600;color:rgba(255,255,255,.6)}
.sfm-bsvc-rotator{
  display:inline-flex;align-items:center;
  padding:4px 12px;border-radius:50px;
  font-weight:800;
  position:relative;overflow:hidden;
}
.sfm-logged-client .sfm-bsvc-rotator{background:rgba(26,188,176,.15);border:1px solid rgba(26,188,176,.3);color:#5DCAA5}
.sfm-logged-vendor .sfm-bsvc-rotator{background:rgba(250,199,117,.15);border:1px solid rgba(250,199,117,.3);color:#FAC775}
.sfm-bsvc-text{display:inline-block;white-space:nowrap;font-size:13px}
.sfm-bsvc-text.sfm-in{animation:sfm-slide-in .45s cubic-bezier(.4,0,.2,1) forwards}
.sfm-bsvc-text.sfm-out{animation:sfm-slide-out .3s cubic-bezier(.4,0,1,1) forwards}

.sfm-lb-bottom{
  display:flex;justify-content:space-between;align-items:center;
  gap:12px;flex-wrap:wrap;
  position:relative;z-index:2;
}
.sfm-lb-meta{font-size:11.5px;color:rgba(255,255,255,.45);display:flex;align-items:center;gap:5px}

.sfm-banner-action-wrap{position:relative}
.sfm-banner-pulse{
  position:absolute;inset:0;border-radius:10px;
  animation:sfm-pulse 2s ease-out infinite;pointer-events:none;
}
.sfm-logged-client .sfm-banner-pulse{border:2px solid rgba(26,188,176,.6)}
.sfm-logged-vendor .sfm-banner-pulse{border:2px solid rgba(250,199,117,.6)}

.sfm-banner-action{
  position:relative;
  display:inline-flex;align-items:center;gap:5px;
  padding:9px 18px;border-radius:10px;
  font-size:12.5px;font-weight:800;
  text-decoration:none;cursor:pointer;border:none;
  font-family:'Cairo',sans-serif;
  transition:all .2s ease;white-space:nowrap;z-index:2;
}
.sfm-logged-client .sfm-banner-action{background:#1ABCB0;color:#fff;box-shadow:0 4px 14px rgba(26,188,176,.3)}
.sfm-logged-client .sfm-banner-action:hover{background:#0F6E56;transform:translateY(-1px);color:#fff}
.sfm-logged-vendor .sfm-banner-action{background:#FAC775;color:#5C3D00;box-shadow:0 4px 14px rgba(250,199,117,.3)}
.sfm-logged-vendor .sfm-banner-action:hover{background:#FFB851;transform:translateY(-1px);color:#5C3D00}

.sfm-banner-close{
  position:absolute;top:8px;left:8px;z-index:3;
  width:24px;height:24px;border-radius:50%;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);
  color:rgba(255,255,255,.45);
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  font-size:14px;line-height:1;padding:0;
  font-family:inherit;
  transition:all .2s ease;
}
.sfm-banner-close:hover{background:rgba(239,68,68,.15);color:#fff;border-color:rgba(239,68,68,.3)}

/* ===== Mobile ===== */
@media(max-width:640px){
  .sfm-hero-wrap{margin:60px 10px 16px}
  .sfm-hero{padding:30px 18px;border-radius:16px}
  .sfm-hero-title{min-height:55px;line-height:1.45}
  .sfm-services-line{font-size:14px;min-height:30px;gap:6px}
  .sfm-svc-rotator{padding:4px 12px;min-width:110px}
  .sfm-cta-row{flex-direction:column;width:100%;gap:8px}
  .sfm-btn-wrap{width:100%}
  .sfm-btn-primary{width:100%;justify-content:center;padding:11px 20px;font-size:13px}
  .sfm-btn-secondary{width:100%;justify-content:center;padding:11px 20px;font-size:13px}
  .sfm-features{gap:8px;font-size:11px}

  .sfm-logged-banner{padding:14px}
  .sfm-lb-top{gap:10px;margin-bottom:8px}
  .sfm-banner-icon{width:40px;height:40px;font-size:18px;border-radius:11px}
  .sfm-banner-title{font-size:13.5px}
  .sfm-banner-svc-line{font-size:12px;min-height:28px;margin-bottom:12px}
  .sfm-bsvc-rotator{padding:3px 10px}
  .sfm-bsvc-text{font-size:12px}
  .sfm-lb-bottom{flex-direction:column;align-items:stretch;gap:8px}
  .sfm-banner-action-wrap{width:100%}
  .sfm-banner-action{width:100%;justify-content:center;padding:10px}
  .sfm-banner-close{top:6px;left:6px;width:22px;height:22px;font-size:12px}
}
