/* ============================================================
   GoToMorocco — lively design: logo, currency, reveal,
   reviews/TripAdvisor, CTA band, destinations, features
   ============================================================ */

/* ---------- New logo ---------- */
.brand-svg { flex: none; filter: drop-shadow(0 2px 8px oklch(0 0 0 / 0.35)); transition: transform .4s cubic-bezier(.2,.7,.2,1); }
.brand-logo:hover .brand-svg { transform: rotate(45deg); }
.brand-name { display: flex; align-items: baseline; gap: 1px; font-size: 1.42rem; letter-spacing: 0.005em; }
.bw-a { color: var(--text); font-weight: 600; }
.bw-b { color: var(--accent); font-weight: 600; }
[dir="rtl"] .brand-name { font-family: var(--font-ar); font-weight: 700; }

/* ---------- Currency switch ---------- */
.cur-switch { position: relative; }
.cur-btn {
  display: inline-flex; align-items: center; gap: 5px; padding: 7px 12px; border-radius: 999px;
  border: 1px solid var(--border); font-size: 0.82rem; font-weight: 700; color: var(--muted); transition: all .15s;
}
.cur-btn:hover { color: var(--text); border-color: var(--accent); }
.cur-caret { font-size: 0.7rem; opacity: 0.7; }
.cur-drop {
  position: absolute; top: calc(100% + 8px); inset-inline-end: 0; min-width: 120px; z-index: 60;
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md);
  box-shadow: var(--shadow-2); padding: 6px; display: flex; flex-direction: column; gap: 2px;
}
.cur-drop button { display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 9px 12px; border-radius: 8px; font-size: 0.86rem; font-weight: 600; color: var(--muted); }
.cur-drop button:hover { background: var(--surface-2); color: var(--text); }
.cur-drop button.on { color: var(--accent); }

/* ---------- Scroll reveal (progressive enhancement) ---------- */
@media (prefers-reduced-motion: no-preference) {
  body.js-ready .js-reveal { opacity: 0; transform: translateY(28px); transition: opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1); }
  body.js-ready .js-reveal.in { opacity: 1; transform: none; }
  body.js-ready .js-reveal.d1 { transition-delay: .08s; }
  body.js-ready .js-reveal.d2 { transition-delay: .16s; }
  body.js-ready .js-reveal.d3 { transition-delay: .24s; }
  body.js-ready .js-reveal.d4 { transition-delay: .32s; }
}

/* ---------- Hero Ken Burns ---------- */
@media (prefers-reduced-motion: no-preference) {
  .hero.classic .hero-bg, .hero.minimal .hero-bg { animation: kenburns 20s ease-out forwards; }
}
@keyframes kenburns { from { transform: scale(1); } to { transform: scale(1.08); } }

/* ---------- Hero color glow (Moroccan sunset) ---------- */
.hero::after {
  content: ""; position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background:
    radial-gradient(42% 50% at 10% 82%, oklch(0.64 0.165 42 / 0.30), transparent),
    radial-gradient(46% 56% at 92% 8%, oklch(0.56 0.185 268 / 0.26), transparent);
  mix-blend-mode: screen;
}

/* ---------- Hero TripAdvisor badge ---------- */
.hero-trust { display: flex; align-items: center; gap: 14px; margin-top: 26px; flex-wrap: wrap; }
.trust-pill {
  display: inline-flex; align-items: center; gap: 10px; padding: 9px 15px;
  background: oklch(0.22 0.014 65 / 0.7); border: 1px solid var(--border); border-radius: 999px; backdrop-filter: blur(8px);
}
.trust-pill .tp-score { font-family: var(--font-display); font-size: 1.2rem; color: var(--accent); line-height: 1; }
.trust-pill .tp-txt { font-size: 0.78rem; color: var(--muted); }

/* ---------- TripAdvisor mark ---------- */
.ta-logo { display: inline-flex; align-items: center; gap: 8px; }
.ta-owl { position: relative; display: inline-flex; gap: 2px; }
.ta-owl .eye { width: 16px; height: 16px; border-radius: 50%; background: #fff; border: 3px solid #00aa6c; box-sizing: border-box; position: relative; }
.ta-owl .eye::after { content: ""; position: absolute; inset: 3px; border-radius: 50%; background: #00aa6c; }
.ta-word { font-weight: 800; font-size: 1.05rem; color: var(--text); letter-spacing: -0.01em; }
.ta-logo.sm .ta-owl .eye { width: 12px; height: 12px; border-width: 2px; }
.ta-logo.sm .ta-word { font-size: 0.88rem; }

/* rating bubbles */
.ta-bubbles { display: inline-flex; gap: 3px; }
.ta-bub { width: var(--bs, 15px); height: var(--bs, 15px); border-radius: 50%; border: 2px solid #00aa6c; box-sizing: border-box; }
.ta-bub.full { background: #00aa6c; }
.ta-bub.half { background: linear-gradient(90deg, #00aa6c 50%, transparent 50%); }
[dir="rtl"] .ta-bub.half { background: linear-gradient(270deg, #00aa6c 50%, transparent 50%); }

/* ---------- Reviews section ---------- */
.reviews-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; flex-wrap: wrap; margin-bottom: 40px; }
.reviews-aggregate { display: flex; align-items: center; gap: 18px; background: var(--surface); border: 1px solid var(--border-soft); border-radius: var(--r-lg); padding: 18px 22px; }
.agg-score { font-family: var(--font-display); font-size: 3rem; color: var(--accent); line-height: 1; }
.agg-meta { display: flex; flex-direction: column; gap: 7px; }
.agg-meta .agg-count { font-size: 0.82rem; color: var(--muted); }
.choice-badge { display: inline-flex; align-items: center; gap: 8px; font-size: 0.78rem; font-weight: 700; color: #00aa6c; }
.choice-badge .laurel { color: #00aa6c; }

.reviews-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.review-card { background: var(--surface); border: 1px solid var(--border-soft); border-radius: var(--r-lg); padding: 26px; transition: transform .25s, border-color .25s; }
.review-card:hover { transform: translateY(-4px); border-color: var(--accent); }
.rc-top { display: flex; align-items: center; gap: 13px; margin-bottom: 14px; }
.rc-av { width: 46px; height: 46px; border-radius: 50%; background: var(--surface-2); border: 1px solid var(--border); display: grid; place-items: center; font-family: var(--font-display); font-size: 1.1rem; color: var(--accent); flex: none; }
.rc-name { font-weight: 600; color: var(--text); font-size: 0.96rem; }
.rc-place { font-size: 0.8rem; color: var(--faint); }
.rc-text { color: var(--muted); font-size: 0.95rem; line-height: 1.6; }
.rc-foot { display: flex; align-items: center; justify-content: space-between; margin-top: 16px; }
.rc-when { font-size: 0.76rem; color: var(--faint); }

/* ---------- Features strip ---------- */
.features { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 18px; }
.feature { display: flex; gap: 14px; padding: 22px; background: var(--surface); border: 1px solid var(--border-soft); border-radius: var(--r-lg); }
.feature .f-ic { width: 46px; height: 46px; border-radius: 12px; display: grid; place-items: center; color: var(--accent); background: oklch(0.81 0.078 80 / 0.1); border: 1px solid var(--border); flex: none; }
.feature h4 { font-size: 1.02rem; font-weight: 600; color: var(--text); }
.feature p { font-size: 0.86rem; color: var(--muted); margin-top: 4px; }

/* ---------- Destinations strip ---------- */
.dest-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.dest-card { position: relative; border-radius: var(--r-lg); overflow: hidden; aspect-ratio: 3/4; border: 1px solid var(--border-soft); }
.dest-card image-slot { width: 100% !important; height: 100% !important; transition: transform .5s ease; }
.dest-card:hover image-slot { transform: scale(1.06); }
.dest-card .dest-scrim { position: absolute; inset: 0; background: linear-gradient(180deg, transparent 40%, oklch(0.14 0.01 65 / 0.85)); z-index: 2; pointer-events: none; }
.dest-card .dest-name { position: absolute; inset-inline-start: 16px; bottom: 14px; z-index: 3; font-family: var(--font-display); font-size: 1.35rem; color: #fff; font-weight: 600; }
.dest-card .dest-pin { position: absolute; inset-inline-end: 12px; top: 12px; z-index: 3; color: var(--accent); background: oklch(0.14 0.01 65 / 0.6); border-radius: 50%; padding: 6px; backdrop-filter: blur(4px); }

/* ---------- CTA band (vibrant Majorelle) ---------- */
.cta-band { position: relative; overflow: hidden; padding: 84px 0;
  background: linear-gradient(135deg, var(--majorelle) 0%, oklch(0.44 0.17 285) 100%); }
.cta-band::before {
  content: ""; position: absolute; inset: 0; z-index: 0; opacity: 0.16;
  background: url(zellij-star.svg); background-size: 86px 86px;
}
.cta-glow { position: absolute; z-index: 0; width: 70%; height: 200%; top: -50%; inset-inline-start: 15%;
  background: radial-gradient(closest-side, oklch(0.8 0.15 70 / 0.28), transparent); pointer-events: none; }
.cta-inner { position: relative; z-index: 2; text-align: center; max-width: 760px; margin: 0 auto; }
.cta-inner .eyebrow { justify-content: center; color: var(--saffron); }
.cta-title { font-size: clamp(2.2rem, 5vw, 3.6rem); color: #fff; margin: 14px 0 14px; }
.cta-sub { font-size: 1.1rem; color: oklch(0.94 0.03 250); max-width: 540px; margin: 0 auto 30px; }
.cta-actions { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }
.cta-actions .btn-ghost { border-color: oklch(1 0 0 / 0.4); color: #fff; }
.cta-actions .btn-ghost:hover { border-color: #fff; background: oklch(1 0 0 / 0.08); }
.btn-wa { background: #25D366; color: #06270f; }
.btn-wa:hover { background: #2ee072; }

/* ---------- Language dropdown ---------- */
.lang-switch { position: relative; }
.lang-trigger {
  display: inline-flex; align-items: center; gap: 7px; padding: 6px 10px; border-radius: 999px;
  border: 1px solid var(--border); color: var(--text); font-weight: 700; font-size: 0.82rem; transition: border-color .15s;
}
.lang-trigger:hover { border-color: var(--accent); }
.lang-trigger .flag { border-radius: 3px; box-shadow: 0 1px 4px oklch(0 0 0 / 0.3); }
.lt-label { letter-spacing: 0.02em; }
.lang-drop {
  position: absolute; top: calc(100% + 8px); inset-inline-end: 0; min-width: 180px; z-index: 80;
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md);
  box-shadow: var(--shadow-2); padding: 6px; display: flex; flex-direction: column; gap: 2px;
}
.lang-opt { display: flex; align-items: center; gap: 11px; padding: 9px 11px; border-radius: 8px; font-size: 0.9rem; font-weight: 600; color: var(--muted); text-align: start; }
.lang-opt:hover { background: var(--surface-2); color: var(--text); }
.lang-opt.on { color: var(--accent); }
.lang-opt .flag { flex: none; border-radius: 3px; }
/* inline pills for mobile menu */
.lang-pills { display: flex; flex-wrap: wrap; gap: 8px; padding: 14px 28px; }
.lang-pill { display: inline-flex; align-items: center; gap: 6px; padding: 6px 10px; border-radius: 999px; border: 1px solid var(--border); color: var(--muted); font-weight: 700; font-size: 0.8rem; }
.lang-pill.active { color: var(--accent); border-color: var(--accent); }
.lang-pill .flag { border-radius: 3px; }

body.no-zellij .cta-band::before { display: none; }

/* ---------- Languages strip ---------- */
.flag { display: block; border-radius: 4px; }
.langs-section { padding-top: 24px; padding-bottom: 24px; }
.langs-card {
  display: grid; grid-template-columns: 0.9fr 1.1fr; gap: 40px; align-items: center;
  background: var(--surface); border: 1px solid var(--border-soft); border-radius: var(--r-xl);
  padding: 44px; position: relative; overflow: hidden;
}
.langs-card::before {
  content: ""; position: absolute; inset: 0; opacity: 0.06; pointer-events: none;
  background: url(zellij-star.svg); background-size: 76px 76px;
}
.langs-text, .langs-flags { position: relative; z-index: 1; }
.langs-text .sec-title { font-size: clamp(1.8rem, 3.4vw, 2.6rem); }
.langs-flags { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.lang-flag {
  display: flex; align-items: center; gap: 13px; padding: 14px 16px;
  background: var(--bg-2); border: 1px solid var(--border-soft); border-radius: var(--r-md);
  transition: transform .2s, border-color .2s;
}
.lang-flag:hover { transform: translateY(-2px); border-color: var(--accent); }
.lang-flag .flag { flex: none; box-shadow: 0 2px 8px oklch(0 0 0 / 0.3); }
.lf-name { font-weight: 600; color: var(--text); font-size: 0.95rem; line-height: 1.1; }
.lf-count { display: block; font-size: 0.72rem; color: var(--faint); margin-top: 2px; }
[dir="rtl"] .lang-flag { text-align: right; }

body.no-zellij .langs-card::before { display: none; }

/* ---------- Events ---------- */
.events-section { background: var(--bg-2); }
.events-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.event-card { display: flex; flex-direction: column; background: var(--surface); border: 1px solid var(--border-soft); border-radius: var(--r-lg); overflow: hidden; transition: transform .25s, border-color .25s; }
.event-card:hover { transform: translateY(-4px); border-color: var(--accent); }
.ev-photo { position: relative; }
.ev-photo image-slot { width: 100% !important; height: 180px !important; }
.ev-datechip { position: absolute; top: 12px; inset-inline-start: 12px; z-index: 3; display: flex; flex-direction: column; align-items: center; background: oklch(0.20 0.02 60 / 0.82); backdrop-filter: blur(6px); border: 1px solid var(--border); border-radius: 12px; padding: 7px 12px; color: var(--accent); }
.ev-datechip .ev-d { font-family: var(--font-display); font-size: 1.45rem; line-height: 1; font-weight: 600; }
.ev-datechip .ev-m { font-size: 0.64rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--muted); }
.ev-body { padding: 22px; display: flex; flex-direction: column; flex: 1; }
.ev-meta { font-size: 0.8rem; color: var(--faint); display: flex; align-items: center; gap: 6px; }
.ev-body h3 { font-family: var(--font-display); font-size: 1.5rem; font-weight: 600; color: var(--text); margin: 8px 0; }
.ev-body p { color: var(--muted); font-size: 0.92rem; flex: 1; }
.ev-body .btn { margin-top: 16px; align-self: flex-start; }
[dir="rtl"] .ev-body .btn svg, [dir="rtl"] .nw-read svg { transform: scaleX(-1); }

/* ---------- News ---------- */
.news-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.news-card { display: flex; flex-direction: column; background: var(--surface); border: 1px solid var(--border-soft); border-radius: var(--r-lg); overflow: hidden; transition: transform .25s, border-color .25s; cursor: pointer; }
.news-card:hover { transform: translateY(-4px); border-color: var(--accent); }
.nw-photo { position: relative; }
.nw-photo image-slot { width: 100% !important; height: 170px !important; }
.nw-tag { position: absolute; top: 12px; inset-inline-start: 12px; z-index: 3; font-size: 0.7rem; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; padding: 4px 11px; border-radius: 999px; background: var(--accent); color: var(--on-accent); }
.nw-body { padding: 22px; display: flex; flex-direction: column; flex: 1; }
.nw-date { font-size: 0.78rem; color: var(--faint); }
.nw-body h3 { font-family: var(--font-display); font-size: 1.4rem; font-weight: 600; color: var(--text); margin: 7px 0; line-height: 1.15; }
.nw-body p { color: var(--muted); font-size: 0.92rem; flex: 1; }
.nw-read { margin-top: 16px; display: inline-flex; align-items: center; gap: 7px; font-size: 0.85rem; font-weight: 600; color: var(--accent); }

/* ---------- Billing segmented (personnel) ---------- */
.billing-block { margin-top: 22px; padding: 18px; border: 1px solid var(--border); border-radius: var(--r-md); background: var(--bg-2); }
.billing-label { font-size: 0.82rem; font-weight: 600; color: var(--muted); display: block; margin-bottom: 10px; }
.billing-seg { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; background: var(--surface); border: 1px solid var(--border); border-radius: 999px; padding: 4px; }
.bill-opt { padding: 10px 12px; border-radius: 999px; font-size: 0.88rem; font-weight: 600; color: var(--muted); transition: all .15s; }
.bill-opt:hover { color: var(--text); }
.bill-opt.on { background: var(--accent); color: var(--on-accent); }
.billing-hint { font-size: 0.78rem; color: var(--faint); margin-top: 10px; }

/* ---------- Map CTA ---------- */
.map-cta-row { align-items: flex-start; }
.map-cta { align-self: flex-start; }

@media (max-width: 940px) {
  .events-grid, .news-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 680px) {
  .events-grid, .news-grid { grid-template-columns: 1fr; }
  .billing-seg { grid-template-columns: 1fr; border-radius: var(--r-md); }
  .bill-opt { border-radius: 8px; }
}

@media (max-width: 860px) {
  .langs-card { grid-template-columns: 1fr; gap: 28px; padding: 30px; }
}
@media (max-width: 460px) {
  .langs-flags { grid-template-columns: 1fr; }
}

/* ---------- Personnel / corporate transport ---------- */
.pers-section { background: var(--bg-2); border-top: 1px solid var(--border-soft); border-bottom: 1px solid var(--border-soft); }
.pers-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 52px; align-items: center; }
.pers-photo { position: relative; height: 440px; border-radius: var(--r-xl); overflow: hidden; border: 1px solid var(--border); }
.pers-photo image-slot { width: 100% !important; height: 100% !important; }
.pers-badge {
  position: absolute; inset-inline-start: 16px; bottom: 16px; z-index: 4;
  display: inline-flex; align-items: center; gap: 8px; padding: 9px 15px; border-radius: 999px;
  background: oklch(0.20 0.02 60 / 0.78); backdrop-filter: blur(8px); border: 1px solid var(--border);
  color: var(--accent); font-weight: 700; font-size: 0.86rem;
}
.pers-body .eyebrow { color: var(--majorelle-bright); }
.pers-body .sec-title { margin-top: 12px; }
.pers-feats { display: flex; flex-direction: column; gap: 16px; margin: 26px 0 30px; }
.pers-feat { display: flex; gap: 14px; }
.pers-feat .pf-ic { width: 44px; height: 44px; flex: none; border-radius: 12px; display: grid; place-items: center; color: var(--majorelle-bright); background: oklch(0.66 0.17 262 / 0.14); border: 1px solid oklch(0.66 0.17 262 / 0.4); }
.pers-feat:nth-child(2) .pf-ic { color: var(--zgreen); background: oklch(0.66 0.135 168 / 0.14); border-color: oklch(0.66 0.135 168 / 0.4); }
.pers-feat:nth-child(3) .pf-ic { color: var(--gold); background: oklch(0.83 0.135 84 / 0.14); border-color: oklch(0.83 0.135 84 / 0.4); }
.pers-feat h4 { font-size: 1.04rem; font-weight: 600; color: var(--text); }
.pers-feat p { font-size: 0.9rem; color: var(--muted); margin-top: 3px; }

@media (max-width: 860px) {
  .pers-grid { grid-template-columns: 1fr; gap: 30px; }
  .pers-photo { height: 300px; order: -1; }
}

/* ---------- Vibrant multicolor accents ---------- */
.svc-grid .svc-card:nth-child(1) .svc-icon { color: var(--gold); background: oklch(0.83 0.135 84 / 0.14); border-color: oklch(0.83 0.135 84 / 0.4); }
.svc-grid .svc-card:nth-child(2) .svc-icon { color: var(--majorelle-bright); background: oklch(0.66 0.17 262 / 0.16); border-color: oklch(0.66 0.17 262 / 0.45); }
.svc-grid .svc-card:nth-child(3) .svc-icon { color: var(--terracotta); background: oklch(0.64 0.165 42 / 0.16); border-color: oklch(0.64 0.165 42 / 0.45); }
.svc-grid .svc-card:nth-child(4) .svc-icon { color: var(--zgreen); background: oklch(0.66 0.135 168 / 0.16); border-color: oklch(0.66 0.135 168 / 0.45); }
.svc-grid .svc-card:nth-child(5) .svc-icon { color: var(--pomegranate); background: oklch(0.58 0.205 22 / 0.16); border-color: oklch(0.58 0.205 22 / 0.45); }
.svc-grid .svc-card:hover { border-color: currentColor; }

.features .feature:nth-child(1) .f-ic { color: var(--gold); background: oklch(0.83 0.135 84 / 0.14); }
.features .feature:nth-child(2) .f-ic { color: var(--majorelle-bright); background: oklch(0.66 0.17 262 / 0.16); }
.features .feature:nth-child(3) .f-ic { color: var(--zgreen); background: oklch(0.66 0.135 168 / 0.16); }

.reviews-grid .review-card:nth-child(1) .rc-av { color: var(--gold); background: oklch(0.83 0.135 84 / 0.14); }
.reviews-grid .review-card:nth-child(2) .rc-av { color: var(--majorelle-bright); background: oklch(0.66 0.17 262 / 0.16); }
.reviews-grid .review-card:nth-child(3) .rc-av { color: var(--terracotta); background: oklch(0.64 0.165 42 / 0.16); }

.dest-grid .dest-card:nth-child(1) .dest-pin { color: var(--gold); }
.dest-grid .dest-card:nth-child(2) .dest-pin { color: var(--majorelle-bright); }
.dest-grid .dest-card:nth-child(3) .dest-pin { color: var(--zgreen); }
.dest-grid .dest-card:nth-child(4) .dest-pin { color: var(--terracotta); }

/* ---------- Responsive ---------- */
@media (max-width: 940px) {
  .reviews-grid { grid-template-columns: 1fr 1fr; }
  .features { grid-template-columns: 1fr; }
  .dest-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 720px) {
  .reviews-grid { grid-template-columns: 1fr; }
  .reviews-head { flex-direction: column; align-items: stretch; }
  .dest-grid { grid-template-columns: repeat(2, 1fr); }
  .cta-band { padding: 56px 0; }
}
