/* ============================================================
   angel in hood — shared stylesheet
   Calm artbook / blueprint. White · tracing-paper blue · ink.
   No animation, no gradient, no glow. Flat paper + hairlines.
   ============================================================ */

:root{
  --paper:      #f6f7f9;   /* dominant white            */
  --paper-card: #fdfdfe;   /* slightly brighter card    */
  --blue-pale:  #e4ecf4;   /* faint panel               */
  --blue-light: #d6e2ee;   /* tracing-paper blue        */
  --blue-mid:   #aec4da;   /* stronger blue             */
  --line:       #c3d4e4;   /* hairline borders          */
  --ink:        #1e3a5f;   /* blueprint ink (headings)  */
  --ink-soft:   #46618a;   /* secondary text            */
  --ink-faint:  #7e94ac;   /* captions / meta           */

  --serif:   'Cormorant Garamond', Georgia, serif;
  --body:    'EB Garamond', Georgia, serif;
  --mono:    'Courier Prime', 'Courier New', monospace;

  --maxw: 1080px;
}

*{ box-sizing:border-box; }

/* The [hidden] attribute must always win, even over display rules like
   .admin-auth{display:flex}. Without this, hiding the login overlay via
   JS (el.hidden = true) leaves it rendered on top of the panel. */
[hidden]{ display:none !important; }

html{ -webkit-text-size-adjust:100%; }

body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--body);
  font-size:19px;
  line-height:1.6;
  font-feature-settings:"liga" 1, "onum" 1;
  -webkit-font-smoothing:antialiased;
}

img{ display:block; max-width:100%; }
a{ color:inherit; }

/* ---------- mono label helper ---------- */
.label{
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-faint);
}

/* ---------- site frame / container ---------- */
.wrap{
  max-width:var(--maxw);
  margin:0 auto;
  padding:0 28px;
}

/* ---------- top bar (inner pages) ---------- */
.topbar{
  border-bottom:1px solid var(--line);
}
.topbar .wrap{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:18px;
  padding-top:22px;
  padding-bottom:22px;
}
.brand{
  font-family:var(--serif);
  font-weight:500;
  font-size:25px;
  letter-spacing:.01em;
  text-decoration:none;
  color:var(--ink);
  white-space:nowrap;
}
.brand .at{ color:var(--ink-faint); font-family:var(--mono); font-size:14px; }
.nav{
  display:flex;
  gap:26px;
  font-family:var(--mono);
  font-size:12.5px;
  letter-spacing:.14em;
  text-transform:uppercase;
}
.nav a{
  text-decoration:none;
  color:var(--ink-soft);
  padding-bottom:3px;
  border-bottom:1px solid transparent;
}
.nav a:hover{ color:var(--ink); border-bottom-color:var(--ink); }
.nav a.here{ color:var(--ink); border-bottom-color:var(--blue-mid); }

/* ---------- page heading ---------- */
.page-head{
  padding:56px 0 30px;
  border-bottom:1px solid var(--line);
}
.page-head h1{
  font-family:var(--serif);
  font-weight:500;
  font-size:clamp(2.2rem, 5vw, 3.1rem);
  line-height:1.04;
  margin:.35em 0 0;
  letter-spacing:.005em;
}
.page-head p{
  max-width:46ch;
  margin:.9em 0 0;
  color:var(--ink-soft);
  font-size:1.05rem;
}

/* ---------- footer ---------- */
.foot{
  margin-top:70px;
  border-top:1px solid var(--line);
}
.foot .wrap{
  display:flex;
  flex-wrap:wrap;
  gap:14px 28px;
  justify-content:space-between;
  align-items:center;
  padding-top:26px;
  padding-bottom:40px;
}
.foot a{ color:var(--ink-soft); text-decoration:none; border-bottom:1px solid var(--line); }
.foot a:hover{ color:var(--ink); border-bottom-color:var(--ink); }

/* ============================================================
   HOME
   ============================================================ */
.home{
  min-height:100vh;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  text-align:center;
  padding:60px 28px;
  position:relative;
  overflow:hidden;
}
/* Matrix digital rain — pale tracing-paper blue, behind content */
.home-matrix{
  position:absolute;
  inset:0;
  z-index:0;
  width:100%;
  height:100%;
  pointer-events:none;
  -webkit-mask-image:radial-gradient(120% 114% at 50% 48%, transparent 0%, transparent 28%, #000 62%);
          mask-image:radial-gradient(120% 114% at 50% 48%, transparent 0%, transparent 28%, #000 62%);
}
.home > *:not(.home-matrix){ position:relative; z-index:1; }
.home-mark{
  font-family:var(--serif);
  font-weight:500;
  font-size:clamp(2.8rem, 9vw, 4.6rem);
  line-height:1;
  letter-spacing:.01em;
  margin:0;
}
.home-sub{
  margin:18px 0 0;
  letter-spacing:.26em;
  white-space:nowrap;
}
@media (max-width:440px){ .home-sub{ white-space:normal; letter-spacing:.2em; } }
.home-rule{
  width:54px;
  height:1px;
  background:var(--blue-mid);
  margin:34px 0 40px;
}
.home-buttons{
  display:flex;
  flex-direction:column;
  gap:14px;
  width:100%;
  max-width:330px;
}
.btn{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  text-decoration:none;
  color:var(--ink);
  background:var(--paper-card);
  border:1px solid var(--ink);
  padding:17px 22px;
  font-family:var(--mono);
  font-size:13px;
  letter-spacing:.16em;
  text-transform:uppercase;
}
.btn > span:first-child{ white-space:nowrap; }
.btn .arrow{ color:var(--ink-faint); }
.btn:hover{ background:var(--blue-light); }
.btn:hover .arrow{ color:var(--ink); }
.home-foot{
  margin-top:48px;
  display:flex;
  flex-direction:column;
  gap:6px;
  align-items:center;
}
.home-foot a{ color:var(--ink-soft); text-decoration:none; border-bottom:1px solid var(--line); }
.home-foot a:hover{ color:var(--ink); }
.home-loc{
  letter-spacing:.12em;
  color:var(--ink-soft);
  border:1px solid var(--line);
  background:var(--paper-card);
  padding:9px 16px;
  margin:2px 0 4px;
}
.home-loc strong{ color:var(--ink); font-weight:700; }

/* ============================================================
   PORTFOLIO  — editorial column flow
   ============================================================ */
.gallery{
  padding:46px 0 0;
  column-count:3;
  column-gap:30px;
}
@media (max-width:900px){ .gallery{ column-count:2; } }
@media (max-width:560px){ .gallery{ column-count:1; } }

figure.plate{
  break-inside:avoid;
  margin:0 0 38px;
}
figure.plate .frame{
  border:1px solid var(--line);
  background:var(--paper-card);
  padding:9px;
}
figure.plate img{ width:100%; }
figure.plate figcaption{
  display:flex;
  gap:12px;
  align-items:baseline;
  padding:12px 2px 0;
  border-top:0;
}
figure.plate .idx{
  font-family:var(--mono);
  font-size:12px;
  color:var(--ink-faint);
  flex:0 0 auto;
}
figure.plate .cap-body .t{
  font-family:var(--serif);
  font-size:1.32rem;
  line-height:1.15;
  display:block;
}
figure.plate .cap-body .m{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.13em;
  text-transform:uppercase;
  color:var(--ink-faint);
  display:block;
  margin-top:4px;
}

/* ============================================================
   SHOP
   ============================================================ */
.shop-grid{
  padding:46px 0 0;
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:34px 30px;
}
@media (max-width:860px){ .shop-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:520px){ .shop-grid{ grid-template-columns:1fr; } }

.item{
  cursor:pointer;
  background:none;
  border:0;
  padding:0;
  text-align:left;
  font:inherit;
  color:inherit;
  display:block;
}
.item .frame{
  border:1px solid var(--line);
  background:var(--paper-card);
  padding:8px;
}
.item:hover .frame{ border-color:var(--blue-mid); background:var(--blue-pale); }
.item img{ width:100%; aspect-ratio:1/1; object-fit:cover; }
.item .meta{ padding:12px 2px 0; }
.item .meta .t{
  font-family:var(--serif);
  font-size:1.3rem;
  line-height:1.2;
}
.item .meta .d{
  color:var(--ink-soft);
  font-size:.98rem;
  margin:3px 0 8px;
}
.item .meta .p{
  font-family:var(--mono);
  font-size:12.5px;
  letter-spacing:.1em;
  color:var(--ink);
}

/* modal */
.modal{
  position:fixed; inset:0;
  display:none;
  z-index:50;
}
.modal[data-open="true"]{ display:block; }
.modal .veil{
  position:absolute; inset:0;
  background:rgba(30,58,95,.34);
}
.modal .panel{
  position:relative;
  max-width:560px;
  margin:7vh auto 0;
  background:var(--paper);
  border:1px solid var(--ink);
  padding:14px;
  max-height:86vh;
  overflow:auto;
}
.modal .panel img{
  width:100%;
  max-height:42vh;
  object-fit:cover;
  border:1px solid var(--line);
}
.modal .pbody{ padding:18px 6px 8px; }
.modal .pbody h3{
  font-family:var(--serif); font-weight:500;
  font-size:1.9rem; margin:0 0 2px;
}
.modal .pbody .p{ font-family:var(--mono); font-size:13px; letter-spacing:.08em; }
.modal .inquiry{
  margin-top:16px;
  border:1px solid var(--line);
  background:var(--blue-light);
  padding:16px 18px;
  font-size:1.05rem;
}
.modal .inquiry a{ color:var(--ink); }
.modal .close{
  position:absolute; top:10px; right:12px;
  font-family:var(--mono); font-size:12px; letter-spacing:.14em;
  background:var(--paper); border:1px solid var(--ink);
  padding:6px 12px; cursor:pointer; text-transform:uppercase;
}
.modal .close:hover{ background:var(--blue-light); }

.shop-note{
  margin-top:40px;
  font-family:var(--mono);
  font-size:12.5px;
  letter-spacing:.06em;
  color:var(--ink-faint);
}

/* ============================================================
   BOOKING FORM
   ============================================================ */
.formwrap{
  max-width:560px;
  padding:46px 0 0;
}
.field{ margin-bottom:26px; }
.field label{
  display:block;
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--ink-soft);
  margin-bottom:8px;
}
.field .opt{ color:var(--ink-faint); text-transform:none; letter-spacing:.04em; }
.field input,
.field textarea{
  width:100%;
  background:var(--paper-card);
  border:1px solid var(--line);
  color:var(--ink);
  font-family:var(--body);
  font-size:1.05rem;
  padding:12px 14px;
  border-radius:0;
}
.field input:focus,
.field textarea:focus{
  outline:none;
  border-color:var(--ink);
  background:#fff;
}
.field textarea{ min-height:120px; resize:vertical; line-height:1.5; }

/* file input */
.field .file{
  display:flex; align-items:center; gap:14px;
  border:1px dashed var(--blue-mid);
  background:var(--blue-pale);
  padding:14px 16px;
}
.field .file input{ display:none; }
.field .file .pick{
  font-family:var(--mono); font-size:11.5px; letter-spacing:.12em;
  text-transform:uppercase; border:1px solid var(--ink);
  background:var(--paper); padding:9px 14px; cursor:pointer; white-space:nowrap;
}
.field .file .pick:hover{ background:var(--blue-light); }
.field .file .fname{ font-family:var(--mono); font-size:12.5px; color:var(--ink-faint); }

.submit{
  font-family:var(--mono); font-size:13px; letter-spacing:.16em;
  text-transform:uppercase; color:#fff; background:var(--ink);
  border:1px solid var(--ink); padding:16px 30px; cursor:pointer;
}
.submit:hover{ background:#16304f; }

.done-note{
  display:none;
  border:1px solid var(--ink);
  background:var(--blue-light);
  padding:22px 24px;
  margin-top:8px;
}
.done-note[data-show="true"]{ display:block; }
.done-note h3{ font-family:var(--serif); font-weight:500; font-size:1.7rem; margin:0 0 6px; }
.done-note a{ color:var(--ink); }

.intro-note{
  border-left:1px solid var(--blue-mid);
  padding:2px 0 2px 18px;
  margin:0 0 4px;
  color:var(--ink-soft);
  font-size:1.05rem;
  max-width:52ch;
}


/* ============================================================
   WELCOME INTRO — "Pharaoh's Tome" slot  (home only)
   ORIGINAL golden-Egypt adventure slot — inspired by the genre,
   NOT a copy: own name, own SVG symbols, own art. Mechanics:
   line wins + a Tome scatter that triggers an expanding-symbol
   free-spin showcase. Dark temple, gold/amber, no third-party assets.
   Appears AFTER full page load as a cinematic reveal over the
   blurred home. Revealed by slot.js.
   ============================================================ */
.intro{
  --g-deep:#0e0802;
  --g-bg:#1a1004;
  --g-bg2:#241606;
  --g-frame:#5a3f17;
  --g-frame-hi:#9c7430;
  --g-gold:#e3b24a;
  --g-gold-hi:#ffe6a0;
  --g-gold-dp:#9a6e22;
  --g-sand:#cdab68;
  --g-ember:#c2531f;
  --g-face:#f6e4b0;
  --g-reel-a:#1c1206;
  --g-reel-b:#120b03;

  display:none;
  position:fixed; inset:0; z-index:200;
  color:var(--g-face);
  font-family:var(--body);
  -webkit-tap-highlight-color:transparent;
}
.intro[data-show="true"]{
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  padding:20px; overflow:auto;
}
.intro .sr-only{
  position:absolute; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap; border:0;
}

/* ---- cinematic veil over the loaded page ---- */
.intro-veil{
  position:fixed; inset:0; z-index:0;
  background:rgba(8,5,1,.62);
  -webkit-backdrop-filter:blur(8px) saturate(1.05);
          backdrop-filter:blur(8px) saturate(1.05);
  opacity:0; transition:opacity .6s ease;
}
.intro[data-enter="true"] .intro-veil{ opacity:1; }
@supports not ((-webkit-backdrop-filter:blur(2px)) or (backdrop-filter:blur(2px))){
  .intro-veil{ background:rgba(8,5,1,.9); }
}

/* ---- skip ---- */
.intro .skip{
  position:fixed; top:18px; right:20px; z-index:3;
  font-family:var(--mono); font-size:12px; letter-spacing:.14em; text-transform:uppercase;
  background:none; border:0; border-bottom:1px solid var(--g-frame-hi);
  color:var(--g-sand); cursor:pointer; padding:2px 0;
  transition:color .2s ease, border-color .2s ease;
}
.intro .skip:hover, .intro .skip:focus-visible{ color:var(--g-gold-hi); border-bottom-color:var(--g-gold-hi); outline:none; }

/* ============================================================
   CABINET — dark temple chassis, gold bevel
   ============================================================ */
.cabinet{
  position:relative; z-index:1;
  width:100%; max-width:480px;
  padding:16px 16px 18px;
  border-radius:24px;
  background:
    radial-gradient(140% 80% at 50% 0%, #34230d 0%, var(--g-bg2) 36%, var(--g-bg) 70%, var(--g-deep) 100%);
  border:1px solid var(--g-deep);
  box-shadow:
    inset 0 2px 0 rgba(255,230,160,.28),
    inset 0 -4px 12px rgba(0,0,0,.6),
    inset 0 0 0 2px rgba(156,116,48,.35),
    0 34px 80px -30px rgba(0,0,0,.9),
    0 0 90px -40px rgba(227,178,74,.55);
  opacity:0; transform:translateY(14px) scale(.965);
  transition:opacity .55s ease, transform .55s cubic-bezier(.2,.7,.2,1);
}
.intro[data-enter="true"] .cabinet{ opacity:1; transform:none; }
.cabinet.jackpot{ animation:cab-glow 1.1s ease-in-out infinite alternate; }
.cabinet::before, .cabinet::after{
  content:""; position:absolute; top:10px; width:9px; height:9px; border-radius:50%;
  background:radial-gradient(circle at 35% 35%,var(--g-gold-hi),var(--g-gold-dp) 70%);
  box-shadow:0 1px 1px rgba(0,0,0,.6);
}
.cabinet::before{ left:12px; }
.cabinet::after{ right:12px; }

.cabinet-close{
  position:absolute; top:7px; right:10px; z-index:8;
  width:30px; height:30px; border-radius:50%;
  background:rgba(14,8,2,.7); border:1px solid var(--g-frame-hi);
  color:var(--g-gold-hi); font-family:var(--serif); font-size:18px; line-height:1; cursor:pointer;
}
.cabinet-close:hover, .cabinet-close:focus-visible{ color:#fff; border-color:var(--g-gold-hi); outline:none; }

/* ---- crown / marquee ---- */
.crown{
  position:relative; margin:6px 2px 14px; padding:14px 16px 12px;
  border-radius:14px; text-align:center;
  background:linear-gradient(180deg,#2c1c08,#1a1004);
  border:1px solid var(--g-frame);
  box-shadow:inset 0 1px 0 rgba(255,230,160,.2), inset 0 -3px 8px rgba(0,0,0,.55);
}
.crown .label{ color:var(--g-sand); }
.crown-title{
  font-family:var(--serif); font-weight:600; letter-spacing:.03em;
  font-size:clamp(1.7rem,7vw,2.3rem); line-height:1; margin:3px 0 8px;
  color:var(--g-gold-hi); text-wrap:balance;
  text-shadow:0 1px 0 rgba(0,0,0,.5), 0 0 22px rgba(227,178,74,.45);
}
.lights{ display:flex; justify-content:center; gap:7px; margin-bottom:2px; }
.lights span{
  width:6px; height:6px; border-radius:50%;
  background:var(--g-gold-hi); opacity:.3;
  box-shadow:0 0 6px rgba(255,230,160,.7);
  animation:bulb 1.4s linear infinite;
}
.cabinet.jackpot .lights span{ animation-duration:.45s; }
.jackpot-strip{
  display:inline-flex; gap:6px; margin:0;
  font-family:var(--mono); font-size:9.5px; letter-spacing:.14em; text-transform:uppercase;
}
.jackpot-strip span{
  padding:2px 8px; border:1px solid var(--g-frame-hi); border-radius:99px;
  color:var(--g-sand); opacity:.85;
}
.jackpot-strip .grand{ color:var(--g-gold-hi); border-color:var(--g-gold); }
.cabinet.jackpot .jackpot-strip .grand{
  background:var(--g-gold); color:var(--g-deep); opacity:1;
  box-shadow:0 0 14px rgba(227,178,74,.8);
}

/* ---- display / reel window ---- */
.display{
  position:relative; padding:12px; border-radius:12px;
  background:linear-gradient(180deg,#0c0702,#160d04);
  box-shadow:inset 0 0 0 2px rgba(0,0,0,.85), inset 0 3px 12px rgba(0,0,0,.7);
}
.display.win{ box-shadow:inset 0 0 0 2px var(--g-gold), inset 0 3px 12px rgba(0,0,0,.7), 0 0 30px -2px rgba(227,178,74,.6); }
.display.feature .reels{ filter:brightness(.42); }
.reels{
  position:relative; display:grid; grid-template-columns:repeat(5,1fr);
  border-radius:8px; overflow:hidden;
  background:linear-gradient(180deg,var(--g-reel-a),var(--g-reel-b));
  --cell:clamp(44px,13.2vw,74px);
}
.reel{
  position:relative; height:calc(var(--cell) * 3); overflow:hidden;
  background:linear-gradient(180deg,var(--g-reel-a),var(--g-reel-b));
  border-right:1px solid rgba(90,63,23,.5);
}
.reel:last-child{ border-right:0; }
.reel.near-shake{ animation:reel-shake .4s ease; }
.strip{ display:flex; flex-direction:column; will-change:transform; }
.strip.blur{ filter:blur(1.1px); }
.tile{
  position:relative; height:var(--cell);
  display:flex; align-items:center; justify-content:center;
  color:var(--g-gold);
}
.tile svg{ width:56%; height:56%; transition:transform .2s ease, color .2s ease;
  filter:drop-shadow(0 1px 2px rgba(0,0,0,.6)); }
/* low-pay royal ranks (generic playing-card letters) */
.tile.royal{ font-family:var(--serif); font-weight:600; color:var(--g-sand);
  font-size:calc(var(--cell) * .46); line-height:1; }
.tile[data-sym="book"]{ color:var(--g-gold-hi); }
.tile.hit{ color:var(--g-gold-hi); }
.tile.hit.royal{ color:var(--g-gold-hi); }
.tile.hit::after{ content:""; position:absolute; inset:11%; border:2px solid var(--g-gold); border-radius:6px;
  box-shadow:0 0 12px rgba(227,178,74,.7), inset 0 0 10px rgba(227,178,74,.4); }
.tile.hit svg{ animation:mark-pulse .55s ease; }
.tile.scatter::after{ content:""; position:absolute; inset:11%; border:2px solid var(--g-gold-hi); border-radius:6px;
  box-shadow:0 0 16px rgba(255,230,160,.85); animation:scatter-pulse 1s ease infinite; }
.tile.near{ color:var(--g-gold-hi); }
.tile.near::after{ content:""; position:absolute; inset:11%; border:2px dashed var(--g-frame-hi); border-radius:6px; }

/* expanding symbol (feature) */
.reel.expanded{ background:radial-gradient(120% 80% at 50% 50%, #3a2607, var(--g-reel-b)); }
.expand-sym{
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  color:var(--g-gold-hi); z-index:2; animation:expand .5s ease;
}
.expand-sym svg{ width:64%; height:88%; filter:drop-shadow(0 0 14px rgba(255,230,160,.85)); }

/* recessed depth */
.display .reel-shade{ position:absolute; inset:12px; border-radius:8px; pointer-events:none; z-index:3; }
.display .reel-shade::before, .display .reel-shade::after{ content:""; position:absolute; left:0; right:0; height:26%; }
.display .reel-shade::before{ top:0; background:linear-gradient(180deg,rgba(0,0,0,.6),transparent); border-radius:8px 8px 0 0; }
.display .reel-shade::after{ bottom:0; background:linear-gradient(0deg,rgba(0,0,0,.6),transparent); border-radius:0 0 8px 8px; }

/* glass sheen */
.glass{ position:absolute; inset:12px; border-radius:8px; pointer-events:none; z-index:4;
  background:linear-gradient(180deg,rgba(255,230,160,.12),transparent 26%,transparent 78%,rgba(0,0,0,.3)); }

/* payline + side indicators */
.payline{
  position:absolute; left:12px; right:12px; top:50%; transform:translateY(-50%);
  height:2px; background:var(--g-frame-hi); opacity:.45; z-index:5; pointer-events:none;
  transition:opacity .3s ease, background .3s ease, box-shadow .3s ease;
}
.payline::before, .payline::after{ content:""; position:absolute; top:50%; width:0; height:0;
  border:6px solid transparent; transform:translateY(-50%); }
.payline::before{ left:-12px; border-left-color:var(--g-frame-hi); }
.payline::after{ right:-12px; border-right-color:var(--g-frame-hi); }
.display.win .payline{ opacity:1; background:var(--g-gold); box-shadow:0 0 10px rgba(227,178,74,.7); }
.display.win .payline::before{ border-left-color:var(--g-gold); }
.display.win .payline::after{ border-right-color:var(--g-gold); }

/* win light sweep */
.sweep{ position:absolute; inset:12px; border-radius:8px; pointer-events:none; z-index:6; overflow:hidden; }
.sweep::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(115deg,transparent 38%,rgba(255,230,160,.6) 50%,transparent 62%);
  transform:translateX(-130%); }
.display.win .sweep::after{ animation:sweep .75s ease; }

/* feature banner (Tome free-spins showcase) */
.feature-banner{
  position:absolute; inset:12px; z-index:7; border-radius:8px;
  display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; gap:6px;
  padding:10px; background:radial-gradient(circle, rgba(26,16,4,.82), rgba(8,5,1,.95));
  opacity:0; pointer-events:none; transition:opacity .35s ease;
}
.feature-banner[data-on="true"]{ opacity:1; }
.feature-banner .fb-kicker{ font-family:var(--mono); font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--g-sand); margin:0; }
.feature-banner h4{ font-family:var(--serif); font-weight:600; color:var(--g-gold-hi); font-size:clamp(1.2rem,5vw,1.6rem); margin:.1em 0;
  text-shadow:0 0 18px rgba(255,230,160,.6); }
.feature-banner .fb-sym{ color:var(--g-gold-hi); }
.feature-banner .fb-sym svg{ width:46px; height:46px; filter:drop-shadow(0 0 12px rgba(255,230,160,.8)); }

/* ---- deck / controls ---- */
.deck{ display:flex; align-items:center; justify-content:center; gap:clamp(14px,5vw,26px); margin-top:16px; }
.meter{ display:flex; flex-direction:column; align-items:center; gap:2px; min-width:54px; }
.meter .label{ color:var(--g-sand); font-size:10px; }
.meter strong{ font-family:var(--mono); font-size:1.05rem; color:var(--g-gold-hi); }
.spin{
  position:relative; width:86px; height:86px; border-radius:50%;
  background:radial-gradient(circle at 50% 34%,var(--g-gold-hi),var(--g-gold) 52%,var(--g-gold-dp));
  border:3px solid var(--g-deep); cursor:pointer;
  color:#3a2607; font-family:var(--mono); font-weight:700; font-size:13px; letter-spacing:.12em;
  box-shadow:0 7px 0 #5a3f17, inset 0 3px 5px rgba(255,255,255,.55), inset 0 -5px 9px rgba(80,52,12,.5);
  transition:transform .08s ease, box-shadow .08s ease, filter .2s ease;
}
.spin:hover{ filter:brightness(1.05); }
.spin:active{ transform:translateY(5px); box-shadow:0 2px 0 #5a3f17, inset 0 3px 5px rgba(255,255,255,.5), inset 0 -5px 9px rgba(80,52,12,.6); }
.spin:focus-visible{ outline:3px solid var(--g-gold-hi); outline-offset:4px; }
.spin:disabled{ filter:grayscale(.4) brightness(.78); cursor:default; box-shadow:0 4px 0 #5a3f17, inset 0 2px 4px rgba(255,255,255,.35); }

/* ---- lever ---- */
.lever{ position:absolute; right:-26px; top:38%; z-index:2; width:30px; background:none; border:0; cursor:pointer; padding:0; }
.lever .stick{ display:block; width:8px; height:96px; margin:0 auto;
  background:linear-gradient(90deg,#7a591f,var(--g-gold-hi),#7a591f); border-radius:6px;
  transform-origin:bottom center; transition:transform .25s cubic-bezier(.3,.8,.3,1); box-shadow:0 2px 4px rgba(0,0,0,.4); }
.lever .knob{ display:block; width:26px; height:26px; border-radius:50%; margin:0 auto -8px;
  background:radial-gradient(circle at 38% 34%,#fff,var(--g-gold) 58%,var(--g-gold-dp));
  border:2px solid var(--g-deep); box-shadow:0 2px 5px rgba(0,0,0,.5); position:relative; z-index:1; }
.lever.pulled .stick{ transform:scaleY(.62); }
.lever:focus-visible{ outline:3px solid var(--g-gold-hi); outline-offset:3px; border-radius:8px; }

/* ---- result + entry CTA ---- */
.result{
  position:relative; z-index:1; width:100%; max-width:440px; margin-top:16px;
  text-align:center; opacity:0; transform:translateY(6px); pointer-events:none;
  transition:opacity .4s ease, transform .4s ease;
}
.result[data-on="true"]{ opacity:1; transform:none; pointer-events:auto; }
.r-kicker{ margin:0; color:var(--g-gold-hi); }
.result h3{ font-family:var(--serif); font-weight:600; font-size:clamp(1.25rem,5vw,1.55rem);
  line-height:1.15; margin:.25em 0 .35em; color:#fff; text-wrap:balance; }
.result p{ margin:0 0 16px; color:var(--g-sand); font-size:1rem; }
.result strong{ color:var(--g-gold-hi); }
.enter{
  display:inline-block; text-decoration:none;
  font-family:var(--mono); font-size:12px; letter-spacing:.16em; text-transform:uppercase;
  color:#3a2607; background:linear-gradient(180deg,var(--g-gold-hi),var(--g-gold-dp));
  border:1px solid var(--g-gold); padding:14px 28px; border-radius:8px;
  opacity:.4; pointer-events:none; transition:opacity .3s ease, filter .2s ease, transform .1s ease;
}
.enter[data-unlocked="true"]{ opacity:1; pointer-events:auto; }
.enter:hover{ filter:brightness(1.06); }
.enter:active{ transform:translateY(1px); }
.enter:focus-visible{ outline:3px solid var(--g-gold-hi); outline-offset:3px; }

/* tiny replay trigger in the home foot */
.replay{
  background:none; border:0; cursor:pointer;
  font-family:var(--mono); font-size:12px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--ink-soft); border-bottom:1px solid var(--line); padding:2px 0;
}
.replay:hover{ color:var(--ink); border-bottom-color:var(--ink); }

/* ---- keyframes ---- */
@keyframes bulb{ 0%,100%{ opacity:.25; } 50%{ opacity:1; } }
@keyframes mark-pulse{ 0%{ transform:scale(1); } 45%{ transform:scale(1.16); } 100%{ transform:scale(1); } }
@keyframes scatter-pulse{ 0%,100%{ box-shadow:0 0 10px rgba(255,230,160,.5); } 50%{ box-shadow:0 0 20px rgba(255,230,160,.95); } }
@keyframes sweep{ to{ transform:translateX(130%); } }
@keyframes reel-shake{ 0%,100%{ transform:translateX(0); } 25%{ transform:translateX(-2px); } 75%{ transform:translateX(2px); } }
@keyframes expand{ from{ transform:scaleY(.18); opacity:0; } to{ transform:scaleY(1); opacity:1; } }
@keyframes cab-glow{
  from{ box-shadow:inset 0 2px 0 rgba(255,230,160,.28), inset 0 -4px 12px rgba(0,0,0,.6), inset 0 0 0 2px rgba(156,116,48,.35), 0 34px 80px -30px rgba(0,0,0,.9), 0 0 70px -40px rgba(227,178,74,.5); }
  to{ box-shadow:inset 0 2px 0 rgba(255,230,160,.4), inset 0 -4px 12px rgba(0,0,0,.6), inset 0 0 0 2px rgba(227,178,74,.6), 0 34px 80px -30px rgba(0,0,0,.9), 0 0 120px -30px rgba(255,230,160,.85); }
}

/* ---- small screens ---- */
@media (max-width:560px){ .lever{ display:none; } }
@media (max-width:440px){
  .intro[data-show="true"]{ padding:14px; }
  .cabinet{ padding:14px 12px 16px; border-radius:18px; }
  .spin{ width:76px; height:76px; }
}

/* ============================================================
   PREMIUM POLISH — richer original gold-temple finish
   Carved-sandstone reels, gilded tile dividers, glowing icons.
   All original CSS — no third-party assets.
   ============================================================ */
/* carved sandstone texture behind the symbols (subtle, original, cheap to paint) */
.reel::before{
  content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background:
    repeating-linear-gradient(0deg, rgba(0,0,0,.16) 0 1px, transparent 1px 7px),
    radial-gradient(120% 70% at 50% 0%, rgba(255,230,160,.06), transparent 64%);
}
.strip{ position:relative; z-index:1; }

/* gilded hairline divider carved across the top of every cell */
.tile::before{
  content:""; position:absolute; left:9%; right:9%; top:0; height:1px; z-index:0;
  background:linear-gradient(90deg, transparent, rgba(156,116,48,.45), transparent);
}

/* bigger, richer symbols with a soft gold aura */
.tile svg{ width:62%; height:62%; }
.tile[data-sym="book"] svg,
.tile[data-sym="explorer"] svg,
.tile[data-sym="pharaoh"] svg,
.tile[data-sym="scarab"] svg,
.tile[data-sym="eye"] svg{
  filter:drop-shadow(0 1px 2px rgba(0,0,0,.7)) drop-shadow(0 0 5px rgba(227,178,74,.28));
}
.tile[data-sym="book"]{ color:var(--g-gold-hi); }
.tile[data-sym="book"] svg{ filter:drop-shadow(0 1px 2px rgba(0,0,0,.7)) drop-shadow(0 0 9px rgba(255,230,160,.55)); }

/* gilded, engraved royal letters */
.tile.royal{
  text-shadow:0 1px 0 rgba(0,0,0,.55), 0 0 12px rgba(227,178,74,.30);
  -webkit-text-stroke:.5px rgba(154,110,34,.55);
}

/* crown title — a touch more gilded depth */
.crown-title{ text-shadow:0 1px 0 rgba(0,0,0,.55), 0 2px 0 rgba(90,63,23,.5), 0 0 26px rgba(227,178,74,.5); }

/* ---- touch targets: keep the visual size, expand the hit area to >=44px ----
   (.cabinet-close is already position:absolute, .skip is position:fixed —
    both establish a positioning context, so the ::after centers on them) */
.cabinet-close::after, .intro .skip::after{
  content:""; position:absolute; left:50%; top:50%; transform:translate(-50%,-50%);
  min-width:44px; min-height:44px; width:100%; height:100%;
}

/* ---- reduced motion ---- */
@media (prefers-reduced-motion: reduce){
  .intro-veil, .cabinet, .result, .payline, .tile svg, .lever .stick, .feature-banner{ transition:none; }
  .cabinet, .cabinet.jackpot{ transform:none; animation:none; }
  .lights span, .tile.hit svg, .tile.scatter::after, .reel.near-shake, .display.win .sweep::after, .expand-sym{ animation:none; }
  .strip.blur{ filter:none; }
}

/* ============================================================
   ADMIN  — /admin panel (product register)
   Same blueprint palette, denser/tool-like. No gold, no slot.
   ============================================================ */
.admin{ background:var(--paper); }

/* ---- login ---- */
.admin-auth{
  min-height:100vh; min-height:100dvh; display:flex; align-items:center; justify-content:center; padding:24px;
}
.auth-card{
  width:100%; max-width:380px;
  background:var(--paper-card); border:1px solid var(--line); border-radius:2px;
  padding:38px 32px 30px;
  box-shadow:0 20px 50px -34px rgba(30,58,95,.55);
}
.auth-brand{ font-family:var(--serif); font-size:1.5rem; line-height:1; color:var(--ink); margin:0; }
.auth-kicker{ margin:.55em 0 0; }
.auth-card h1{
  font-family:var(--serif); font-weight:500; font-size:2.1rem; line-height:1; margin:.5em 0 0;
}
.auth-lead{ color:var(--ink-soft); font-size:1.02rem; margin:.5em 0 26px; }
.auth-card .field:last-of-type{ margin-bottom:22px; }
.auth-card .submit{
  display:flex; align-items:center; justify-content:center; gap:10px; width:100%;
}
.auth-card .submit .arrow{ color:rgba(255,255,255,.7); transition:transform .15s ease; }
.auth-card .submit:hover .arrow{ transform:translateX(3px); color:#fff; }

/* password show/hide */
.pass-wrap{ position:relative; }
.pass-wrap input{ padding-right:78px; }
.pass-toggle{
  position:absolute; top:50%; right:6px; transform:translateY(-50%);
  appearance:none; background:none; border:0; cursor:pointer;
  font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase;
  color:var(--ink-soft); padding:8px 10px; border-radius:2px;
}
.pass-toggle:hover{ color:var(--ink); }
.pass-toggle:focus-visible{ outline:2px solid var(--ink); outline-offset:1px; }

/* auth feedback — error (default) + success */
.auth-msg{
  margin:14px 0 0; padding:11px 13px; font-size:.95rem; border-radius:2px;
  border:1px solid #d6a3a3; background:#f7e9e9; color:#7d2b2b;
}
.auth-msg[data-kind="ok"]{ border-color:var(--blue-mid); background:var(--blue-light); color:var(--ink); }

/* forgot-password link */
.auth-link{
  display:block; width:100%; margin:18px 0 0; padding:6px 0; text-align:center;
  appearance:none; background:none; border:0; cursor:pointer;
  font-family:var(--mono); font-size:11.5px; letter-spacing:.08em; color:var(--ink-soft);
  border-top:1px solid var(--line); padding-top:16px;
}
.auth-link:hover{ color:var(--ink); }
.auth-link:focus-visible{ outline:2px solid var(--ink); outline-offset:2px; }
.auth-link:disabled{ opacity:.5; cursor:default; }

/* ---- top bar + tabs ---- */
.admin-bar{ border-bottom:1px solid var(--line); background:var(--paper-card); position:sticky; top:0; z-index:20; }
.admin-bar-in{ display:flex; align-items:center; gap:18px; padding-top:14px; padding-bottom:0; flex-wrap:wrap; }
.admin-bar .brand{ font-family:var(--serif); font-size:1.35rem; color:var(--ink); }
.admin-bar .brand .at{ font-family:var(--mono); font-size:12px; color:var(--ink-faint); }
.admin-tabs{ display:flex; gap:4px; margin-left:auto; align-self:flex-end; }
.atab{
  appearance:none; background:none; border:0; cursor:pointer;
  font-family:var(--mono); font-size:12px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--ink-soft); padding:12px 14px; border-bottom:2px solid transparent; margin-bottom:-1px;
}
.atab:hover{ color:var(--ink); }
.atab[aria-selected="true"]{ color:var(--ink); border-bottom-color:var(--ink); }
.atab .count{
  display:inline-block; min-width:18px; padding:0 5px; margin-left:4px;
  font-size:11px; line-height:18px; text-align:center; color:#fff; background:var(--ink); border-radius:99px;
}
.admin-bar .ghost{ align-self:flex-end; margin-bottom:9px; }

.ghost{
  appearance:none; cursor:pointer; background:none; border:1px solid var(--line); color:var(--ink-soft);
  font-family:var(--mono); font-size:11.5px; letter-spacing:.1em; text-transform:uppercase;
  padding:8px 12px; border-radius:2px; transition:border-color .15s ease, color .15s ease, background .15s ease;
}
.ghost:hover{ color:var(--ink); border-color:var(--ink); }
.ghost.sm{ padding:6px 10px; font-size:11px; }
.ghost.danger:hover{ color:#7d2b2b; border-color:#c08; border-color:#bb6a6a; background:#f7ecec; }

/* ---- panels ---- */
.admin-main{ padding-top:28px; padding-bottom:64px; }
.panel-head{
  display:flex; align-items:flex-end; justify-content:space-between; gap:18px;
  margin-bottom:20px; padding-bottom:16px; border-bottom:1px solid var(--line);
}
.panel-head-text{ min-width:0; }
.panel-head h2{ font-family:var(--serif); font-weight:500; font-size:1.9rem; margin:0; line-height:1.05; }
.panel-sub{ margin:6px 0 0; color:var(--ink-soft); font-size:.98rem; max-width:60ch; text-wrap:pretty; }
.panel-tools{ font-family:var(--mono); font-size:12px; color:var(--ink-soft); }
.checkline{
  display:inline-flex; align-items:center; gap:8px; cursor:pointer; white-space:nowrap;
  font-family:var(--mono); font-size:11.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-soft);
}
.checkline input{ accent-color:var(--ink); width:15px; height:15px; }
.checkline:hover{ color:var(--ink); }

/* status strip — instant "what needs attention" */
.panel-status{
  margin:0 0 18px; padding:11px 15px; border-radius:2px;
  font-family:var(--mono); font-size:12.5px; letter-spacing:.04em;
  border:1px solid var(--line); background:var(--paper-card); color:var(--ink-soft);
}
.panel-status[data-kind="new"]{
  border-color:var(--ink); background:var(--blue-light); color:var(--ink);
  display:flex; align-items:center; gap:9px;
}
.panel-status[data-kind="new"]::before{
  content:""; width:8px; height:8px; border-radius:50%; background:var(--ink); flex:none;
}
.add-btn{ width:auto; padding:11px 16px; }
.add-btn .arrow{ color:var(--ink-faint); font-size:1.1em; }

/* ---- messages list ---- */
.list{ display:flex; flex-direction:column; gap:14px; }
.msg{
  background:var(--paper-card); border:1px solid var(--line); border-radius:2px; padding:16px 18px;
}
.msg.is-read{ background:var(--paper); }
.msg-top{ display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:12px; }
.msg-when{ font-family:var(--mono); font-size:12px; letter-spacing:.06em; color:var(--ink-faint); display:flex; align-items:center; gap:8px; }
.msg .dot{ width:8px; height:8px; border-radius:50%; background:var(--ink); display:inline-block; }
.msg-actions{ display:flex; gap:6px; }
.msg-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:6px 22px; }
.kv{ display:flex; flex-direction:column; gap:1px; }
.kv .k{ font-family:var(--mono); font-size:10.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-faint); }
.kv .v{ color:var(--ink); font-size:1.02rem; word-break:break-word; }
.kv .v a{ color:var(--ink); text-decoration:none; border-bottom:1px solid var(--line); }
.kv .v a:hover{ border-bottom-color:var(--ink); }
.msg-idea{ margin:14px 0 0; color:var(--ink-soft); white-space:pre-wrap; max-width:72ch; text-wrap:pretty; }
.msg-ref{ display:inline-block; margin-top:14px; border:1px solid var(--line); padding:5px; }
.msg-ref img{ width:120px; height:120px; object-fit:cover; }

/* ---- portfolio / shop editor ---- */
.editor-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(330px,1fr)); gap:18px; }
.editor{
  background:var(--paper-card); border:1px solid var(--line); border-radius:2px; padding:16px;
  display:flex; flex-direction:column; gap:14px;
}
.editor-media{ display:flex; flex-direction:column; gap:10px; }
.editor-img{
  aspect-ratio:4/3; background:var(--blue-pale); border:1px solid var(--line);
  display:flex; align-items:center; justify-content:center; overflow:hidden;
}
.editor-img img{ width:100%; height:100%; object-fit:cover; }
.editor-img-empty{ font-family:var(--mono); font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-faint); }
.editor .pick{
  align-self:flex-start; font-family:var(--mono); font-size:11.5px; letter-spacing:.1em; text-transform:uppercase;
  border:1px solid var(--ink); background:var(--paper); padding:8px 14px; cursor:pointer;
}
.editor .pick:hover{ background:var(--blue-light); }
.editor-fields{ display:flex; flex-direction:column; gap:12px; }
.editor-fields .field{ margin:0; }
.editor-fields textarea{ min-height:88px; }
.editor-actions{ display:flex; align-items:center; gap:10px; margin-top:2px; }
.submit.sm{ padding:9px 18px; font-size:12px; }

/* ---- skeleton / empty / toast ---- */
.skeleton{ height:84px; border:1px solid var(--line); border-radius:2px; background:
  linear-gradient(90deg,var(--paper-card) 0%, var(--blue-pale) 50%, var(--paper-card) 100%);
  background-size:200% 100%; animation:sk 1.2s ease-in-out infinite; margin-bottom:14px; }
@keyframes sk{ from{ background-position:200% 0; } to{ background-position:-200% 0; } }
.empty{
  text-align:center; padding:54px 24px; border:1px dashed var(--blue-mid); background:var(--paper-card); border-radius:2px;
}
.empty h3{ font-family:var(--serif); font-weight:500; font-size:1.5rem; margin:0 0 6px; }
.empty p{ color:var(--ink-soft); margin:0; }
.empty.err{ border-color:#d6a3a3; background:#f7e9e9; }
.empty.err h3, .empty.err p{ color:#7d2b2b; }
.toast{
  position:fixed; left:50%; bottom:24px; transform:translateX(-50%);
  background:var(--ink); color:#fff; font-family:var(--mono); font-size:12.5px; letter-spacing:.04em;
  padding:12px 18px; border-radius:2px; z-index:50; box-shadow:0 8px 24px -12px rgba(30,58,95,.6);
}
.toast[data-kind="err"]{ background:#7d2b2b; }

/* ---- admin focus + reduced motion ---- */
.atab:focus-visible, .ghost:focus-visible, .editor .pick:focus-visible{ outline:2px solid var(--ink); outline-offset:2px; }
@media (prefers-reduced-motion: reduce){ .skeleton{ animation:none; } }

@media (max-width:560px){
  .admin-bar-in{ gap:10px; }
  .admin-tabs{ width:100%; order:3; margin-left:0; }
  .admin-bar .ghost{ margin-left:auto; }
}
