
/* =========================
   Root Variables
========================= */
:root{
  --bg:#111827;
  --bg2:#1f2937;
  --bg3:#253244;

  --surface:#1e293b;
  --surface-2:#233146;
  --surface-3:#2a3a51;

  --txt:#e5e7eb;
  --mut:#b7c0cd;

  --line:#374151;
  --line-strong:#4b5563;

  --acc:#60a5fa;
  --acc-2:#34d399;
  --warm:#fbbf24;

  --shadow-1:0 10px 26px rgba(0,0,0,.34);
  --shadow-2:0 24px 56px rgba(0,0,0,.48);

  --radius-sm:12px;
  --radius-md:16px;
  --radius-lg:20px;
}

/* ===== Calm Therapeutic Workshop Palette ===== */
*{box-sizing:border-box}
html,body{overflow-x:hidden}
html[lang="he"] body,html[lang="he"] button,html[lang="he"] input,html[lang="he"] select,html[lang="he"] .emotion,html[lang="he"] .meaning,html[lang="he"] .back-title,html[lang="he"] .back-question,html[lang="he"] .back-reflection{font-family:"David","Arial Hebrew","Segoe UI",sans-serif !important}
html[lang="ar"] body{font-family:"IBM Plex Sans Arabic","Tajawal","Segoe UI",Tahoma,sans-serif}
html[lang="ar"] .title-wrap h1,html[lang="ar"] .wheel-title,html[lang="ar"] .draw-title,html[lang="ar"] .journey-title,html[lang="ar"] .info-head h2,html[lang="ar"] .info-card h3,html[lang="ar"] .back-title,html[lang="ar"] .emotion,html[lang="ar"] .footer-link-card{font-family:"Cairo","Tajawal","IBM Plex Sans Arabic",sans-serif}
html[lang="ar"] .btn,html[lang="ar"] .games-btn,html[lang="ar"] .lang-btn{font-family:"Cairo","Tajawal","IBM Plex Sans Arabic",sans-serif}
html[lang="ar"] .field,html[lang="ar"] .select,html[lang="ar"] .title-wrap .sub,html[lang="ar"] .meaning,html[lang="ar"] .back-question,html[lang="ar"] .back-reflection,html[lang="ar"] .journey-meta span,html[lang="ar"] .journey-question,html[lang="ar"] .info-card p,html[lang="ar"] .info-card li,html[lang="ar"] .footer-credit,html[lang="ar"] .draw-result{font-family:"IBM Plex Sans Arabic","Tajawal","Segoe UI",sans-serif}
body{
  margin:0;
  min-height:100vh;
  font-family:"IBM Plex Sans Arabic","Tajawal","Segoe UI",Tahoma,sans-serif;
  color:var(--txt);
  background:
    radial-gradient(1200px 820px at 10% -12%, rgba(96,165,250,.15) 0%, transparent 62%),
    radial-gradient(920px 620px at 92% -10%, rgba(52,211,153,.12) 0%, transparent 64%),
    radial-gradient(760px 520px at 50% 108%, rgba(96,165,250,.08) 0%, transparent 72%),
    linear-gradient(160deg,var(--bg),var(--bg2) 54%,var(--bg3));
}
.shell{width:min(1260px,94vw);margin:18px auto}
.topbar{display:grid;grid-template-columns:1fr auto 1fr;gap:12px;align-items:center;margin-bottom:12px}
.logos{display:flex;gap:10px;align-items:center}
.logo{
  width:210px;
  height:130px;
  object-fit:contain;
  background:#fff;
  border-radius:12px;
  padding:6px;
  border:1px solid #dce6ef99;
  box-shadow:0 10px 24px rgba(0,0,0,.22);
}
.title-wrap{text-align:center}
.title-wrap h1{margin:0;font-family:"Cairo","Tajawal","IBM Plex Sans Arabic",sans-serif;font-weight:800;letter-spacing:0;font-size:clamp(1.4rem,2.4vw,2.28rem);line-height:1.35}
.title-wrap .sub{color:var(--mut);font-family:"IBM Plex Sans Arabic","Tajawal",sans-serif;font-size:clamp(.98rem,1.28vw,1.08rem);font-weight:500;line-height:1.85;letter-spacing:0}
.lang-wrap{display:flex;justify-content:flex-end}
.lang-switch{display:inline-flex;align-items:center;gap:6px;padding:4px;border:1px solid var(--line);border-radius:999px;background:linear-gradient(180deg,#27354a,#223143);box-shadow:0 6px 14px rgba(0,0,0,.2)}
.lang-btn{min-height:32px;min-width:48px;padding:0 10px;border-radius:999px;border:1px solid transparent;background:transparent;color:var(--txt);font:700 .86rem "IBM Plex Sans Arabic","Tajawal",sans-serif;cursor:pointer}
.lang-btn.active{background:linear-gradient(180deg,#60a5fa,#4f86c6);border-color:rgba(96,165,250,.7);color:#f8fbff}
.lang-sep{color:#9fb1c8;font-size:.86rem;opacity:.85}

.presenter,
.dialog,
.wheel-dialog,
.draw-dialog,
.journey-dialog{
  border:1px solid var(--line);
  box-shadow:var(--shadow-1);
}

/* =========================
   Toolbar
========================= */
.toolbar{
  display:grid;
  grid-template-columns:1.4fr 1fr repeat(5,auto);
  gap:8px;
  background:linear-gradient(170deg,var(--surface-2),var(--surface));
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:10px;
  margin-bottom:14px;
}
.field,.select,.btn{
  min-height:44px;
  color:var(--txt);
  border:1px solid var(--line);
  border-radius:12px;
  background:linear-gradient(180deg,#263245,#202b3d);
  font:700 .98rem "Cairo","Tajawal","IBM Plex Sans Arabic",sans-serif;
  letter-spacing:0;
  transition:transform .18s ease,box-shadow .22s ease,border-color .22s ease,background .22s ease,color .22s ease;
}
.field{padding:0 13px}
.select{padding:0 11px}
.select{
  color-scheme:dark;
  background-color:#223143;
}
.select option{
  color:var(--txt);
  background-color:var(--surface-2);
}
.select option:checked{
  color:#f8fbff;
  background-color:#315173;
}
.btn{padding:0 13px;cursor:pointer;box-shadow:0 4px 12px rgba(0,0,0,.2)}
.field:focus,.select:focus,.btn:focus{outline:none;border-color:var(--acc);box-shadow:0 0 0 3px rgba(96,165,250,.25)}
.btn:hover{transform:translateY(-1px);border-color:var(--line-strong);background:linear-gradient(180deg,#2f3e54,#253347)}
.btn:active{transform:translateY(0) scale(.99)}
.btn.active{border-color:rgba(52,211,153,.65);background:linear-gradient(180deg,#2f4565,#295046);box-shadow:0 8px 18px rgba(52,211,153,.18)}

.games-wrap{position:relative}
.games-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-width:170px}
.games-btn::after{content:"\25BE";font-size:.84rem;opacity:.82;transition:transform .2s ease}
.games-btn[aria-expanded="true"]::after{transform:rotate(180deg)}
.games-menu{
  position:absolute;
  top:calc(100% + 8px);
  right:0;
  min-width:250px;
  display:grid;
  gap:7px;
  padding:9px;
  background:linear-gradient(160deg,var(--surface-2),var(--surface));
  border:1px solid var(--line);
  border-radius:14px;
  box-shadow:0 18px 36px rgba(14,20,34,.48);
  z-index:35;
}
.games-menu[hidden]{display:none}
.game-option{width:100%;text-align:right;min-height:46px}

/* Primary action buttons */
#gamesBtn,
#wheelStart,
#wheelAgain,
#drawStart,
#drawOpen,
#journeyStart,
#journeyResume,
#journeyShowCard,
#presenterRandom,
#modalFull{
  background:linear-gradient(180deg,#60a5fa,#4f86c6);
  border-color:rgba(96,165,250,.72);
  color:#f8fbff;
}
#gamesBtn:hover,
#wheelStart:hover,
#wheelAgain:hover,
#drawStart:hover,
#drawOpen:hover,
#journeyStart:hover,
#journeyResume:hover,
#journeyShowCard:hover,
#presenterRandom:hover,
#modalFull:hover{
  background:linear-gradient(180deg,#74b2fb,#5e96d4);
  border-color:rgba(116,178,251,.9);
}

/* =========================
   Cards
========================= */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:14px}
.card{
  background:linear-gradient(170deg,#27354a,var(--surface));
  border:1px solid var(--line);
  border-radius:16px;
  overflow:hidden;
  box-shadow:0 10px 24px rgba(0,0,0,.28), 0 1px 0 rgba(255,255,255,.05) inset;
  transition:transform .24s cubic-bezier(.18,.76,.21,1),box-shadow .24s ease,border-color .24s ease;
}
.card:hover{
  transform:translateY(-4px) scale(1.01);
  border-color:rgba(96,165,250,.62);
  box-shadow:0 22px 40px rgba(0,0,0,.46),0 0 0 1px rgba(52,211,153,.24);
}
.thumb-wrap{all:unset;cursor:pointer;display:block;position:relative;aspect-ratio:4/3;background:#162233}
.thumb{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease,filter .4s ease}
.card:hover .thumb{transform:scale(1.035);filter:saturate(1.04) contrast(1.03)}
.fav-chip{position:absolute;top:8px;left:8px;width:34px;height:34px;border-radius:999px;display:grid;place-items:center;background:rgba(15,23,35,.78);border:1px solid #6b7280;backdrop-filter:blur(4px);font-size:1rem}
.fav-chip.active{color:#fde68a;border-color:var(--warm)}
.card-meta{padding:10px 10px 11px;border-top:1px solid var(--line);background:linear-gradient(180deg,rgba(30,41,59,.72),rgba(30,41,59,.55))}
.line-1{display:flex;justify-content:space-between;color:#dbe3ec;font-size:.84rem;margin-bottom:3px}
.emotion{font:800 1.08rem "Cairo","Tajawal","IBM Plex Sans Arabic",sans-serif;color:#fff;line-height:1.5;letter-spacing:0}
.meaning{color:#d9e3ed;font-family:"IBM Plex Sans Arabic","Tajawal",sans-serif;font-size:.95rem;line-height:1.9;margin-top:4px}

/* =========================
   Modals + Presenter
========================= */
.presenter{display:none;background:linear-gradient(170deg,var(--surface-2),var(--surface));border-radius:16px;overflow:hidden;margin-bottom:12px}
.presenter.open{display:grid}
.presenter-main{position:relative;aspect-ratio:16/9;background:var(--bg)}
.presenter-main img{width:100%;height:100%;object-fit:contain}
.presenter-overlay{position:absolute;inset-inline:10px;bottom:10px;display:flex;gap:8px;justify-content:center;flex-wrap:wrap}
.presenter-controls{display:flex;justify-content:space-between;gap:8px;padding:10px;border-top:1px solid var(--line);background:#24364e}
.presenter:not(:fullscreen) #presenterExitFullscreen{display:none}

.modal{position:fixed;inset:0;display:none;align-items:flex-start;justify-content:center;padding:12px;background:rgba(10,14,22,.70);backdrop-filter:blur(6px);z-index:99;overflow-y:auto;overflow-x:hidden}
.modal.open{display:flex;animation:fade .22s ease both}
.dialog{width:min(1080px,97vw);max-height:calc(100dvh - 24px);display:flex;flex-direction:column;background:linear-gradient(170deg,var(--surface-2),var(--surface));border-radius:16px;overflow:hidden;animation:pop .26s cubic-bezier(.19,.77,.21,1) both;box-shadow:var(--shadow-2)}
.viewer{position:relative;flex:1 1 auto;height:min(64vh,720px);min-height:250px;background:var(--bg);padding:12px}
.flip-card{width:100%;height:100%;position:relative;perspective:1600px;touch-action:pan-y}
.flip-card-inner{position:absolute;inset:0;transform-style:preserve-3d;transition:transform .74s cubic-bezier(.2,.78,.18,1)}
.flip-card.flipped .flip-card-inner{transform:rotateY(180deg)}
.flip-card-front,.flip-card-back{position:absolute;inset:0;border:1px solid #4b5563;border-radius:12px;overflow:hidden;backface-visibility:hidden}
.flip-card-front{background:var(--bg);box-shadow:inset 0 0 0 1px rgba(255,255,255,.06)}
.flip-card-front img{width:100%;height:100%;object-fit:contain;display:block;background:var(--bg)}
.flip-card-back{transform:rotateY(180deg);display:grid;align-content:center;gap:12px;padding:24px;background:linear-gradient(160deg,#28405c,#255046 52%,#1f3a55);overflow:auto}
.back-title{font:800 1.14rem "Cairo","Tajawal","IBM Plex Sans Arabic",sans-serif;line-height:1.6;letter-spacing:0}
.back-question,.back-reflection{font-family:"IBM Plex Sans Arabic","Tajawal",sans-serif;line-height:2.08;font-size:1.04rem;letter-spacing:0}
.back-question{color:#fff}
.back-reflection{border-top:1px solid #4b5563;padding-top:10px;color:#e5edf5}

.viewer-controls{position:absolute;top:10px;right:10px;display:flex;gap:9px;z-index:5}
.icon-btn{min-height:44px;min-width:44px;padding:0 13px;border-radius:999px;border:1px solid #6b7280;background:linear-gradient(180deg,#2a3d57d9,#223246d2);color:var(--txt);cursor:pointer;font-weight:700}
.icon-btn:hover{background:linear-gradient(180deg,#334d6ed9,#2a425ed2)}
#modalFlip{border-color:rgba(96,165,250,.75);background:linear-gradient(180deg,rgba(96,165,250,.35),rgba(96,165,250,.20))}
#modalFlip[aria-pressed="true"]{border-color:rgba(52,211,153,.80);background:linear-gradient(180deg,rgba(52,211,153,.40),rgba(52,211,153,.22));box-shadow:0 0 0 2px rgba(52,211,153,.18)}
.viewer-fs-controls{position:absolute;inset-inline:10px;bottom:10px;display:none;justify-content:center;gap:8px;z-index:6}
.dialog:fullscreen .viewer-fs-controls{display:flex}
.dialog-foot{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;padding:11px;border-top:1px solid var(--line);background:#24364e;position:sticky;bottom:0;z-index:7}
.dialog-text strong{display:block;margin-bottom:7px;line-height:1.55;font-size:1.02rem}
.dialog-text span{display:block;color:#cbd5e1;line-height:1.86}
.nav{display:flex;gap:8px;flex-wrap:wrap}

/* =========================
   Wheel
========================= */
.wheel-modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;padding:12px;background:rgba(10,14,22,.72);backdrop-filter:blur(6px);z-index:120}
.wheel-modal.open{display:flex;animation:fade .2s ease both}
.wheel-dialog{width:min(760px,96vw);max-height:min(94dvh,920px);overflow:auto;background:linear-gradient(170deg,var(--surface-2),var(--surface));border-radius:18px;padding:14px;box-shadow:var(--shadow-2)}
.wheel-title{margin:0 0 10px;text-align:center;font:800 1.32rem "Cairo","Tajawal","IBM Plex Sans Arabic",sans-serif;letter-spacing:0;line-height:1.5}
.wheel-wrap{display:grid;justify-items:center;gap:12px}
.wheel-stage{position:relative;width:min(78vw,460px);aspect-ratio:1/1;display:grid;place-items:center}
.wheel-pointer{position:absolute;right:-10px;top:50%;transform:translateY(-50%);width:0;height:0;border-top:20px solid transparent;border-bottom:20px solid transparent;border-right:34px solid var(--warm);filter:drop-shadow(0 4px 8px rgba(251,191,36,.35));z-index:4}
.wheel-pointer::after{content:"";position:absolute;right:-34px;top:-4px;width:10px;height:8px;border-radius:4px;background:#f7e7a8;box-shadow:0 0 10px rgba(247,231,168,.8)}
.wheel-disc{width:100%;height:100%;border-radius:50%;border:5px solid #cbd5e1;box-shadow:inset 0 0 0 2px rgba(229,231,235,.45),0 20px 48px rgba(0,0,0,.42);background:rgba(255,255,255,.12);transition:transform 3.8s cubic-bezier(.12,.72,.14,1), filter .28s ease}
.wheel-disc.impact{animation:wheelImpact .58s cubic-bezier(.22,.8,.2,1)}
.wheel-result-panel{width:min(92vw,560px);margin-inline:auto;display:grid;gap:11px;justify-items:center;padding:12px 12px 8px;border:1px solid #4b5563;border-radius:16px;background:linear-gradient(160deg,#29445f,#245045)}
.wheel-result{min-height:1.8rem;color:#fff;text-align:center;font:800 1.12rem "Cairo","Tajawal","IBM Plex Sans Arabic",sans-serif;line-height:1.82;letter-spacing:0}
.wheel-result.wheel-result-picked{font-size:clamp(1.4rem,3.4vw,2.2rem);line-height:1.65;padding:12px 14px;border-radius:16px;border:1px solid rgba(251,191,36,.75);background:linear-gradient(145deg,rgba(96,165,250,.42),rgba(52,211,153,.32),rgba(251,191,36,.20));box-shadow:0 0 0 1px rgba(255,255,255,.55),0 14px 36px rgba(9,16,26,.36);animation:wheelWinPop .62s cubic-bezier(.2,.84,.22,1) both}
.wheel-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;padding-top:2px}
.wheel-result-panel.winner{box-shadow:0 0 0 2px rgba(251,191,36,.55),0 16px 34px rgba(0,0,0,.50)}

/* =========================
   Draw + Journey
========================= */
.draw-modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;padding:12px;background:rgba(10,14,22,.72);backdrop-filter:blur(6px);z-index:121}
.draw-modal.open{display:flex;animation:fade .2s ease both}
.draw-dialog{width:min(920px,97vw);background:linear-gradient(170deg,var(--surface-2),var(--surface));border-radius:18px;padding:18px;box-shadow:var(--shadow-2);text-align:center}
.draw-title{margin:0 0 10px;font:800 1.26rem "Cairo","Tajawal","IBM Plex Sans Arabic",sans-serif;line-height:1.5}
.draw-stage{display:grid;justify-items:center;gap:14px}
.draw-card{width:min(95vw,720px);aspect-ratio:16/9;border-radius:14px;border:1px solid #4b5563;background:linear-gradient(145deg,#2c4866,#2a5449);box-shadow:0 18px 42px rgba(14,17,32,.42);display:grid;place-items:center;font-size:1.1rem;color:#f4f8fb;position:relative;overflow:hidden;transform:translateZ(0)}
.draw-card img{width:100%;height:100%;object-fit:cover;display:block}
.draw-card-back{position:absolute;inset:0;display:grid;place-items:center;background:radial-gradient(120% 120% at 18% 16%,#3e6489 0%,#315170 52%,#2a5449 100%)}
.draw-card-back::before{content:"";position:absolute;inset:8px;border:1px solid rgba(255,255,255,.42);border-radius:10px}
.draw-card-back::after{content:"";position:absolute;inset:16px;border:1px dashed rgba(230,238,250,.58);border-radius:8px}
.draw-card-back span{position:relative;z-index:1;font-size:1.05rem;color:#f4f8fb;font-weight:700}
.draw-card.anim{animation:drawPulse 1.05s ease-in-out infinite alternate}
.draw-card.forward{animation:drawForward .82s cubic-bezier(.18,.82,.2,1) forwards}
.draw-card.reveal{animation:drawReveal .55s cubic-bezier(.22,.75,.25,1) both}
.draw-card.revealed{box-shadow:0 18px 44px rgba(12,15,30,.52),0 0 0 1px rgba(255,255,255,.35),0 0 26px rgba(96,165,250,.25)}
.draw-result{min-height:1.9rem;font-family:"IBM Plex Sans Arabic","Tajawal",sans-serif;font-weight:700;color:#f4f8fb;font-size:1.08rem;line-height:1.92}
.draw-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:8px}

.journey-modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;padding:12px;background:rgba(10,14,22,.72);backdrop-filter:blur(6px);z-index:122}
.journey-modal.open{display:flex;animation:fade .2s ease both}
.journey-dialog{width:min(920px,96vw);max-height:min(94dvh,920px);overflow:auto;background:linear-gradient(170deg,var(--surface-2),var(--surface));border-radius:18px;padding:14px;box-shadow:var(--shadow-2)}
.journey-title{margin:0 0 10px;text-align:center;font:800 1.28rem "Cairo","Tajawal","IBM Plex Sans Arabic",sans-serif;line-height:1.5}
.journey-stage{display:grid;justify-items:center;gap:10px}
.journey-img{width:min(88vw,720px);max-height:58dvh;object-fit:contain;border-radius:12px;border:1px solid #4b5563;background:#1b2a3d;box-shadow:0 16px 34px rgba(14,18,32,.46);animation:fade .28s ease}
.journey-meta{display:grid;justify-items:center;gap:6px}
.journey-meta strong{font:800 1.34rem "Cairo","Tajawal","IBM Plex Sans Arabic",sans-serif;line-height:1.45}
.journey-meta span{color:#dbe4ee;font-family:"IBM Plex Sans Arabic","Tajawal",sans-serif;line-height:1.9;font-size:1rem}
.journey-question{max-width:780px;font-family:"IBM Plex Sans Arabic","Tajawal",sans-serif;line-height:2.02;border-radius:12px;padding:12px 14px;border:1px solid #4b5563;color:var(--txt);background:linear-gradient(160deg,#315173,#2b584d);font-size:1rem}
.journey-controls{display:grid;gap:10px;margin-top:10px}
.journey-speeds,.journey-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:8px}
.journey-speeds .btn.active{background:linear-gradient(180deg,#2f4565,#295046);border-color:rgba(52,211,153,.65)}

/* =========================
   Utility
========================= */
.empty{padding:18px;text-align:center;color:#cbd5e1;border:1px dashed #4b5563;border-radius:12px;background:rgba(30,41,59,.35)}
.count-bottom{text-align:center;color:#dbe3ec;padding:10px 12px;border-top:1px solid var(--line);margin-top:12px;font-weight:600;background:linear-gradient(180deg,rgba(31,41,55,.46),rgba(17,24,39,.30))}
.footer{color:#dbe3ec;padding:18px 12px 16px;border-top:1px solid var(--line);background:linear-gradient(180deg,rgba(31,41,55,.52),rgba(17,24,39,.36))}
.footer-links{width:min(1280px,94vw);margin:0 auto 14px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;align-items:stretch}
.footer-link-card{display:flex;align-items:center;justify-content:center;min-height:84px;padding:16px 14px;border-radius:16px;border:1px solid var(--line);background:linear-gradient(170deg,var(--surface-2),var(--surface));box-shadow:var(--shadow-1);text-align:center;color:#f3f7fb;text-decoration:none;font:800 1.04rem "Cairo","Tajawal","IBM Plex Sans Arabic",sans-serif;line-height:1.95;letter-spacing:0;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}
.footer-link-card:hover{transform:translateY(-2px);border-color:#5f7593;box-shadow:0 18px 36px rgba(0,0,0,.35)}
.footer-link-card:focus-visible{outline:none;border-color:var(--acc);box-shadow:0 0 0 3px rgba(96,165,250,.25)}
.footer-link-card{appearance:none;-webkit-appearance:none;width:100%;cursor:pointer}
.info-dialog{width:min(980px,96vw);max-height:calc(100dvh - 24px);overflow:hidden;display:flex;flex-direction:column;border:1px solid var(--line);border-radius:18px;background:linear-gradient(170deg,var(--surface-2),var(--surface));box-shadow:var(--shadow-2)}
.info-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px 16px;border-bottom:1px solid var(--line)}
.info-head h2{margin:0;font:800 clamp(1.24rem,2.3vw,1.62rem) "Cairo","Tajawal","IBM Plex Sans Arabic",sans-serif;color:#f5f8fc;line-height:1.5;letter-spacing:0}
.info-body{padding:16px;overflow:auto;display:grid;gap:14px}
.info-content{display:grid;gap:14px}
.info-card{background:linear-gradient(170deg,var(--surface-2),var(--surface));border:1px solid var(--line);border-radius:16px;padding:18px 18px 16px;box-shadow:var(--shadow-1)}
.info-card h3{margin:0 0 10px;font:800 1.12rem "Cairo","Tajawal","IBM Plex Sans Arabic",sans-serif;color:#f2f6fb;line-height:1.6}
.info-card p{margin:0 0 12px;font-family:"IBM Plex Sans Arabic","Tajawal",sans-serif;line-height:2.08;color:var(--txt);font-size:1rem}
.info-card ul,.info-card ol{margin:0;padding:0 24px 0 0;color:var(--txt);line-height:2}
.info-card li{margin:0 0 8px;font-family:"IBM Plex Sans Arabic","Tajawal",sans-serif;line-height:2;font-size:1rem}
.footer-credit{text-align:center;color:#dbe3ec;padding-top:4px;font-family:"IBM Plex Sans Arabic","Tajawal",sans-serif;font-weight:600;line-height:1.9;font-size:.98rem}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}

/* =========================
   Animations
========================= */
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes pop{from{opacity:0;transform:translateY(10px) scale(.99)}to{opacity:1;transform:none}}
@keyframes wheelReveal{from{opacity:0;transform:translateY(8px) scale(.97)}to{opacity:1;transform:none}}
@keyframes wheelQuestionPop{0%{opacity:0;transform:translateY(6px) scale(.98)}60%{opacity:1;transform:translateY(-2px) scale(1.03)}100%{opacity:1;transform:none}}
@keyframes wheelWinPop{0%{opacity:0;transform:translateY(10px) scale(.93)}52%{opacity:1;transform:translateY(-4px) scale(1.06)}100%{opacity:1;transform:none}}
@keyframes wheelImpact{0%{filter:brightness(1) saturate(1)}45%{filter:brightness(1.08) saturate(1.08)}100%{filter:brightness(1) saturate(1)}}
@keyframes drawPulse{from{transform:scale(1);box-shadow:0 16px 36px rgba(12,15,30,.42)}to{transform:scale(1.03);box-shadow:0 22px 50px rgba(12,15,30,.58)}}
@keyframes drawForward{0%{transform:translateY(16px) scale(.94)}45%{transform:translateY(-8px) scale(1.08)}100%{transform:translateY(0) scale(1.03)}}
@keyframes drawReveal{from{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}

/* =========================
   Responsive
========================= */
@media (max-width:980px){
  .topbar{grid-template-columns:1fr}
  .toolbar{grid-template-columns:1fr 1fr}
  .logos{justify-content:center}
  .footer-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
  .footer-links{grid-template-columns:repeat(2,minmax(0,1fr))}
@media (max-width:768px){
  .shell{width:min(100%,96vw);margin:10px auto}
  .logo{width:128px;height:80px}
  .toolbar{grid-template-columns:repeat(2,minmax(0,1fr));gap:9px}
  #searchInput{grid-column:1/-1}

  .modal{padding:6px}
  .dialog{width:100%;min-height:calc(100dvh - 12px);max-height:calc(100dvh - 12px);display:flex;flex-direction:column}
  .viewer{height:58dvh;min-height:58dvh;padding:10px}
  .viewer-controls{gap:10px}

  .flip-card,.flip-card-inner,.flip-card-front,.flip-card-back{width:100%;height:100%;min-height:100%}
  .flip-card{perspective:none}
  .flip-card-inner{position:relative;display:block;transform:none!important}
  .flip-card-front,.flip-card-back{position:relative;inset:auto;backface-visibility:visible;transform:none!important}
  .flip-card-back{display:none}
  .flip-card.flipped .flip-card-front{display:none}
  .flip-card.flipped .flip-card-back{display:block}

  .back-title{font-size:1.02rem}
  .back-question,.back-reflection{font-size:1rem;line-height:2.05}
}

@media (max-width:430px){
  .toolbar{grid-template-columns:1fr}
  .btn,#searchInput,#sortSelect,.games-btn{width:100%}
  .footer-grid{grid-template-columns:1fr}
  .games-menu{position:static;min-width:0;margin-top:6px}
  .footer-links{grid-template-columns:1fr}

  .journey-dialog{padding:10px}
  .journey-img{max-height:52dvh}
  .journey-meta strong{font-size:1.08rem}
  .journey-question{font-size:.95rem}

  .grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:9px}
  .card-meta{padding:8px 8px 9px}
  .line-1{font-size:.78rem}
  .emotion{font-size:.95rem}
  .meaning{display:none}

  .viewer{height:56dvh;min-height:56dvh;padding:8px}
  .viewer-controls{gap:10px}
  .flip-card-back{padding:16px}

  .wheel-dialog{padding:10px}
  .wheel-stage{width:min(92vw,360px)}
  .wheel-result-panel{width:min(95vw,520px);padding:9px 8px 6px}
  .wheel-result.wheel-result-picked{font-size:clamp(1.35rem,6vw,2rem)}

  .draw-dialog{padding:10px}
  .draw-card{width:min(96vw,520px)}
}

.setup-notice{
  margin:0 0 14px;
  padding:14px 16px;
  border:1px solid rgba(251,191,36,.45);
  border-radius:16px;
  background:linear-gradient(160deg,rgba(96,165,250,.16),rgba(251,191,36,.12));
  color:#f8fafc;
  line-height:1.9;
  box-shadow:var(--shadow-1);
}

.admin-page{
  background:
    radial-gradient(900px 620px at 12% -10%, rgba(96,165,250,.18) 0%, transparent 60%),
    radial-gradient(720px 540px at 88% -12%, rgba(52,211,153,.12) 0%, transparent 62%),
    linear-gradient(160deg,#0f172a,#162235 54%,#1d3045);
}

.admin-shell{
  width:min(1180px,94vw);
  margin:24px auto 40px;
}

.admin-login-shell{
  min-height:100vh;
  display:grid;
  place-items:center;
}

.admin-login-card,
.admin-panel,
.admin-stat-card{
  background:linear-gradient(170deg,var(--surface-2),var(--surface));
  border:1px solid var(--line);
  border-radius:18px;
  box-shadow:var(--shadow-1);
}

.admin-login-card{
  width:min(460px,100%);
  padding:28px;
}

.admin-login-card h1,
.admin-panel h2,
.admin-hero h1{
  margin:0 0 10px;
  font:800 1.4rem "Cairo","Tajawal","IBM Plex Sans Arabic",sans-serif;
}

.admin-login-card p,
.admin-panel p,
.admin-note,
.admin-stat-card span{
  color:var(--mut);
  line-height:1.85;
}

.admin-form-stack,
.admin-form-grid{
  display:grid;
  gap:14px;
}

.admin-form-grid{
  grid-template-columns:repeat(2,minmax(0,1fr));
}

.admin-form-grid label,
.admin-form-stack label{
  display:grid;
  gap:7px;
}

.admin-form-grid span,
.admin-form-stack span{
  font-weight:700;
  color:#f8fafc;
}

.admin-textarea{
  min-height:124px;
  padding:12px 13px;
  resize:vertical;
}

.admin-code-textarea{
  min-height:220px;
  font-family:"Consolas","Courier New",monospace;
  font-size:.95rem;
  line-height:1.7;
}

.admin-checkbox{
  display:flex !important;
  align-items:center;
  gap:10px;
  min-height:44px;
}

.admin-checkbox input{
  width:18px;
  height:18px;
}

.admin-form-span-2{
  grid-column:1 / -1;
}

.admin-form-actions{
  display:flex;
  justify-content:flex-start;
}

.admin-hero{
  display:flex;
  justify-content:space-between;
  gap:16px;
  align-items:flex-start;
  margin-bottom:16px;
}

.admin-user{
  display:flex;
  align-items:center;
  gap:10px;
}

.admin-nav{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-bottom:16px;
}

.admin-nav a{
  color:#f8fafc;
  text-decoration:none;
  padding:11px 14px;
  border-radius:999px;
  border:1px solid var(--line);
  background:linear-gradient(180deg,#263245,#202b3d);
  font-weight:700;
}

.admin-nav a.active{
  border-color:rgba(96,165,250,.72);
  background:linear-gradient(180deg,#60a5fa,#4f86c6);
}

.admin-alert{
  margin-bottom:16px;
  padding:13px 14px;
  border-radius:14px;
  border:1px solid var(--line);
  color:#f8fafc;
}

.admin-alert-success{
  background:linear-gradient(160deg,rgba(52,211,153,.22),rgba(37,84,73,.72));
  border-color:rgba(52,211,153,.42);
}

.admin-alert-error{
  background:linear-gradient(160deg,rgba(248,113,113,.2),rgba(127,29,29,.48));
  border-color:rgba(248,113,113,.4);
}

.admin-grid{
  display:grid;
  gap:14px;
}

.admin-dashboard-grid{
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  margin-bottom:16px;
}

.admin-stat-card{
  padding:20px;
  display:grid;
  gap:8px;
}

.admin-stat-card strong{
  font-size:2rem;
  color:#fff;
}

.admin-stat-card a{
  color:#9bd2ff;
  text-decoration:none;
  font-weight:700;
}

.admin-panel{
  padding:18px;
  margin-bottom:16px;
}

.admin-panel-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-bottom:14px;
}

.admin-table-wrap{
  overflow:auto;
}

.admin-table{
  width:100%;
  border-collapse:collapse;
  min-width:720px;
}

.admin-table th,
.admin-table td{
  padding:12px 10px;
  border-bottom:1px solid rgba(255,255,255,.08);
  text-align:right;
  vertical-align:top;
}

.admin-table th{
  color:#f8fafc;
  font-size:.95rem;
}

.admin-table td{
  color:#dbe4ee;
  line-height:1.7;
}

.admin-actions-cell{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}

.admin-actions-cell form{
  margin:0;
}

@media (max-width: 860px){
  .admin-form-grid{
    grid-template-columns:1fr;
  }

  .admin-form-span-2{
    grid-column:auto;
  }

  .admin-hero,
  .admin-panel-head{
    flex-direction:column;
    align-items:stretch;
  }

  .admin-user{
    justify-content:space-between;
  }
}