/* ============================================================
   "Under the Palm Tree" — Village Tour UI
   Earth palette: clay #9c6f44 · sand #d8c39a · palm #5e7b3e
   The 3D village is the hero; UI stays quiet and warm.
   ============================================================ */

:root{
  --clay:#9c6f44; --clay-dark:#6b4a2b; --sand:#e7d6b3;
  --palm:#5e7b3e; --cream:#f6ecd6; --ink:#3a2a18;
  --panel:rgba(246,236,214,.94);
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html,body{margin:0;height:100%;overflow:hidden;background:#caa46f;
  font-family:"Marcellus","Amiri",Georgia,serif;color:var(--ink);}
canvas{display:block;touch-action:none;}

/* ---- 3D canvas container ---- */
#scene{position:fixed;inset:0;}

/* ---- Loading screen ---- */
#loader{position:fixed;inset:0;z-index:50;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;padding:24px;
  background:radial-gradient(circle at 50% 35%,#e7d6b3,#b88f57);}
#loader .palm{font-size:64px;line-height:1;margin-bottom:8px;
  animation:sway 3s ease-in-out infinite;}
@keyframes sway{0%,100%{transform:rotate(-4deg)}50%{transform:rotate(4deg)}}
#loader h1{font-size:clamp(22px,5vw,34px);margin:.2em 0 .1em;color:var(--clay-dark);}
#loader p{margin:.2em 0 1.2em;opacity:.8;font-size:15px;}
.bar{width:min(80vw,320px);height:12px;border-radius:8px;background:#00000022;
  overflow:hidden;border:1px solid #00000018;}
.bar > i{display:block;height:100%;width:0%;border-radius:8px;
  background:linear-gradient(90deg,var(--palm),var(--clay));transition:width .2s;}
#loadPct{margin-top:10px;font-size:14px;letter-spacing:.04em;}
#beginBtn{margin-top:22px;display:none;cursor:pointer;border:none;
  background:var(--clay-dark);color:var(--cream);font-family:inherit;
  font-size:18px;padding:14px 34px;border-radius:30px;box-shadow:0 6px 18px #0003;}
#beginBtn:active{transform:translateY(1px);}

/* ---- Top bar ---- */
#topbar{position:fixed;top:0;left:0;right:0;z-index:20;display:flex;gap:8px;
  align-items:center;padding:10px 12px;pointer-events:none;}
#topbar .spacer{flex:1;}
.pill{pointer-events:auto;cursor:pointer;border:none;font-family:inherit;
  background:var(--panel);color:var(--ink);font-size:14px;padding:9px 14px;
  border-radius:22px;box-shadow:0 3px 10px #0002;display:flex;gap:6px;align-items:center;}
.pill:active{transform:translateY(1px);}
.pill.on{background:var(--palm);color:#fff;}

/* ---- Story / explanation panel ---- */
#panel{position:fixed;left:50%;bottom:96px;transform:translateX(-50%);
  z-index:20;width:min(92vw,560px);background:var(--panel);
  border-radius:18px;box-shadow:0 10px 30px #0003;padding:16px 18px;
  border:1px solid #00000012;opacity:0;pointer-events:none;transition:opacity .4s;}
#panel.show{opacity:1;pointer-events:auto;}
#panel h2{margin:0 0 6px;font-size:20px;color:var(--clay-dark);}
#panel .ar{font-family:"Aref Ruqaa","Amiri",serif;font-size:19px;direction:rtl;
  line-height:1.9;margin:0 0 8px;}
#panel .en{font-size:15.5px;line-height:1.5;margin:0;opacity:.92;}

/* ---- Bottom controls (tour) ---- */
#tourbar{position:fixed;left:50%;bottom:18px;transform:translateX(-50%);
  z-index:20;display:flex;gap:10px;align-items:center;}
.tbtn{cursor:pointer;border:none;font-family:inherit;background:var(--clay-dark);
  color:var(--cream);font-size:16px;padding:12px 20px;border-radius:26px;
  box-shadow:0 5px 16px #0003;}
.tbtn:active{transform:translateY(1px);}
.tbtn.ghost{background:var(--panel);color:var(--ink);}
#stopLabel{font-size:13px;background:var(--panel);padding:8px 12px;border-radius:18px;}

/* ---- Mobile joystick ---- */
#joy{position:fixed;left:18px;bottom:96px;z-index:15;width:110px;height:110px;
  border-radius:50%;background:#f6ecd655;border:2px solid #ffffff66;
  display:none;touch-action:none;}
#joy > i{position:absolute;left:50%;top:50%;width:46px;height:46px;margin:-23px;
  border-radius:50%;background:var(--clay);box-shadow:0 3px 8px #0004;}
@media (pointer:coarse){#joy{display:block;}}

/* ---- Mini-game bar ---- */
#game{position:fixed;left:50%;top:64px;transform:translateX(-50%);z-index:20;
  width:min(92vw,440px);background:var(--panel);border-radius:16px;
  box-shadow:0 8px 24px #0003;padding:14px 16px;text-align:center;
  display:none;border:1px solid #00000012;}
#game.show{display:block;}
#game .word{font-size:22px;color:var(--clay-dark);}
#game .hint{font-size:14px;margin-top:6px;min-height:20px;opacity:.85;}
#game .score{font-size:13px;margin-top:4px;opacity:.7;}
#game .ar{font-family:"Aref Ruqaa","Amiri",serif;font-size:20px;color:var(--palm);}

/* ---- Debug panel ---- */
#debug{position:fixed;right:10px;top:60px;z-index:25;width:min(70vw,260px);
  max-height:50vh;overflow:auto;background:#1c140bdd;color:#ffe9c2;
  font-family:ui-monospace,monospace;font-size:12px;padding:10px;border-radius:12px;
  display:none;}
#debug.show{display:block;}
#debug b{color:#ffd27a;}
#debug .row{padding:4px 0;border-bottom:1px solid #ffffff22;word-break:break-all;}

/* toast */
#toast{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);z-index:40;
  background:#1c140bcc;color:#fff;padding:16px 22px;border-radius:14px;font-size:18px;
  opacity:0;pointer-events:none;transition:opacity .3s;}
#toast.show{opacity:1;}

@media (prefers-reduced-motion:reduce){
  #loader .palm{animation:none;}
}

/* ---- Debug panel buttons ---- */
#debug .dbtns{margin:6px 0;}
#debug .dbtns button{cursor:pointer;border:none;font-family:inherit;background:#ffd27a;
  color:#1c140b;font-size:13px;padding:8px 12px;border-radius:14px;width:100%;}
#debug .dbtns button:active{transform:translateY(1px);}
#debug .dhint{font-size:11px;opacity:.8;margin:4px 0 6px;line-height:1.4;}
