/* ===========================================================
   Rajadana.site — "Kerajaan Rajadana" flagship experience hub
   Royal identity: brand blue + gold over night-navy. 5th distinct
   network identity (Cinzel display + Inter UI), shared palette anchors.
   =========================================================== */
:root{
  --blue:#1787e8; --blue-d:#0d66c2; --blue-l:#5ea8f0;
  --gold:#f59e0b; --gold-l:#fbbf24; --gold-soft:#facc6b;
  --navy:#0a1628; --navy-2:#0b1d3a; --navy-3:#0f2547;
  --ink:#e8f1fb; --ink-60:rgba(232,241,251,.62); --ink-35:rgba(232,241,251,.35);
  --paper:#0a1424;
  --amber:#ff9d3c;
  --line:1px solid rgba(255,255,255,.10);
  --r:14px; --r-lg:22px;
  --fd:'Cinzel', Georgia, serif;
  --fu:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --gut:clamp(18px,4vw,48px);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--fu);background:var(--paper);color:var(--ink);line-height:1.7;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:var(--gold);color:var(--navy)}

/* ---------- shared bits ---------- */
.kicker{font-family:var(--fu);font-size:.72rem;font-weight:700;letter-spacing:.28em;text-transform:uppercase;color:var(--gold)}

/* =========================================================
   CRAWLABLE CONTENT PAGE (default view, no-JS safe)
   ========================================================= */
.site-top{display:flex;align-items:center;justify-content:space-between;padding:16px var(--gut);border-bottom:var(--line);background:rgba(10,20,36,.6);position:relative;z-index:2}
.brand img{height:42px;width:auto}
.top-cta{font-weight:700;font-size:.86rem;background:linear-gradient(180deg,var(--gold-l),var(--gold));color:var(--navy);padding:10px 18px;border-radius:999px;box-shadow:0 6px 22px rgba(245,158,11,.3)}

.fallback{max-width:1080px;margin:0 auto;padding:clamp(40px,7vw,84px) var(--gut)}
.intro{max-width:760px;margin-bottom:clamp(34px,5vw,56px)}
.intro h1{font-family:var(--fd);font-weight:800;font-size:clamp(2rem,5.5vw,3.6rem);line-height:1.08;letter-spacing:.01em;margin:14px 0 18px;
  background:linear-gradient(180deg,#fff,var(--gold-soft));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.intro .lead{font-size:1.05rem;color:var(--ink-60);max-width:680px}

.paths{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:clamp(34px,5vw,56px)}
.path-card{position:relative;display:flex;flex-direction:column;gap:8px;padding:26px 24px;border:var(--line);border-radius:var(--r-lg);
  background:linear-gradient(180deg,var(--navy-2),var(--navy));transition:transform .25s,border-color .25s,box-shadow .25s;overflow:hidden}
.path-card::before{content:'';position:absolute;inset:0 0 auto 0;height:2px;background:linear-gradient(90deg,transparent,var(--blue),transparent);opacity:.5}
.path-card:hover{transform:translateY(-5px);border-color:rgba(94,168,240,.5);box-shadow:0 18px 44px rgba(0,0,0,.4)}
.path-card-gold{background:linear-gradient(180deg,#1c1606,var(--navy));border-color:rgba(245,158,11,.35)}
.path-card-gold::before{background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:.8}
.path-card-gold:hover{border-color:rgba(245,158,11,.7);box-shadow:0 18px 44px rgba(245,158,11,.18)}
.path-tag{font-size:.66rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--blue-l)}
.path-card-gold .path-tag{color:var(--gold-l)}
.path-card h2{font-family:var(--fd);font-weight:700;font-size:1.4rem;letter-spacing:.01em;color:#fff}
.path-card p{font-size:.9rem;color:var(--ink-60);flex:1}
.path-link{font-weight:700;font-size:.85rem;color:var(--blue-l);margin-top:6px}
.path-card-gold .path-link{color:var(--gold-l)}

.why{margin-bottom:clamp(34px,5vw,56px)}
.why>h2,.about>h2,.faqs>h2{font-family:var(--fd);font-size:clamp(1.3rem,3vw,1.8rem);color:#fff;margin-bottom:18px}
.why-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.why-item{border:var(--line);border-left:3px solid var(--gold);border-radius:12px;padding:18px 20px;background:linear-gradient(180deg,var(--navy-2),var(--navy))}
.why-item h3{font-family:var(--fd);font-size:1.05rem;color:var(--gold-l);margin-bottom:6px}
.why-item p{font-size:.9rem;color:var(--ink-60)}
.about{max-width:760px;margin-bottom:clamp(34px,5vw,56px)}
.about p{color:var(--ink-60);font-size:.96rem}
.about a{color:var(--blue-l);font-weight:600}
.faqs{max-width:820px;margin-bottom:clamp(34px,5vw,56px)}
.faq-item{border-bottom:var(--line);padding:18px 0}
.faq-item:last-child{border-bottom:none}
.faq-item h3{font-family:var(--fd);font-size:1.05rem;color:#fff;margin-bottom:6px}
.faq-item p{font-size:.93rem;color:var(--ink-60)}
@media(max-width:640px){.why-grid{grid-template-columns:1fr}}
.rg-note{max-width:920px;font-size:.85rem;color:var(--ink-60);border:var(--line);border-left:3px solid var(--gold);border-radius:10px;padding:16px 20px;background:rgba(245,158,11,.05)}
.rg-note strong{color:var(--gold-l);margin-right:6px}

.site-foot{border-top:var(--line);padding:40px var(--gut) 30px;text-align:center;position:relative;overflow:hidden}
.foot-word{font-family:var(--fd);font-weight:800;font-size:clamp(3rem,14vw,9rem);letter-spacing:.06em;color:rgba(255,255,255,.04);line-height:.9;pointer-events:none;user-select:none}
.foot-links{display:flex;flex-wrap:wrap;justify-content:center;gap:10px 22px;margin:-10px 0 18px}
.foot-links a{font-size:.86rem;color:var(--ink-60);font-weight:600}
.foot-links a:hover{color:var(--blue-l)}
.foot-base{font-size:.74rem;color:var(--ink-35);letter-spacing:.04em}

@media(max-width:760px){.paths{grid-template-columns:1fr}}

/* ---------- sub-pages (tentang / faq / responsible) ---------- */
.page{max-width:820px}
.breadcrumb2{font-size:.8rem;color:var(--ink-35);margin-bottom:20px}
.breadcrumb2 a{color:var(--ink-60)}.breadcrumb2 a:hover{color:var(--blue-l)}
.page h1{font-family:var(--fd);font-weight:800;font-size:clamp(1.8rem,5vw,2.9rem);line-height:1.1;color:#fff;margin:6px 0 16px;
  background:linear-gradient(180deg,#fff,var(--gold-soft));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.page h2{font-family:var(--fd);font-weight:700;font-size:clamp(1.2rem,3vw,1.6rem);color:#fff;margin:30px 0 10px}
.page h3{font-family:var(--fd);font-weight:700;font-size:1.05rem;color:var(--gold-l);margin:20px 0 6px}
.page p{color:var(--ink-60);font-size:.98rem;margin-bottom:14px}
.page p strong{color:var(--ink)}
.page a{color:var(--blue-l);font-weight:600}
.page ul{margin:0 0 16px;padding-left:20px}
.page li{color:var(--ink-60);font-size:.96rem;margin-bottom:7px}
.page .lead{font-size:1.06rem;color:var(--ink);opacity:.9;margin-bottom:24px}

/* =========================================================
   IMMERSIVE EXPERIENCE — default visible (CSS); no-JS falls back to content
   ========================================================= */
/* Experience is the DEFAULT visual (renders with pure CSS, no JS needed).
   No-JS users are dropped to the content page via <noscript> in <head>.
   JS only adds interactivity (enter, parallax, routing). */
.exp{position:fixed;inset:0;z-index:60;overflow:hidden;background:var(--navy);--mx:0;--my:0}
html.exp-lock{overflow:hidden}          /* lock page scroll while the gate is up */
html.exp-off .exp{display:none}         /* gate dismissed -> reveal content homepage */

.exp-vignette{position:absolute;inset:0;z-index:40;pointer-events:none;
  background:radial-gradient(120% 90% at 50% 40%,transparent 55%,rgba(0,0,0,.7) 100%)}

.scene{position:absolute;inset:0;opacity:0;visibility:hidden;transition:opacity .8s ease,transform 1s ease,filter 1s ease;transform-origin:50% 55%}
.scene.is-active{opacity:1;visibility:visible}

.layer{position:absolute;inset:-4% ;background-size:cover;background-position:center bottom;will-change:transform;
  transform:translate3d(calc(var(--mx)*var(--d,0)*1px),calc(var(--my)*var(--d,0)*1px),0);transition:transform .25s ease-out}

/* ---- GATE scene (placeholder art via gradients + SVG silhouettes) ---- */
.layer-sky{--d:4;background:
  radial-gradient(60% 40% at 70% 18%,rgba(94,168,240,.18),transparent 60%),
  radial-gradient(40% 30% at 28% 22%,rgba(245,158,11,.10),transparent 60%),
  linear-gradient(180deg,#060e1f 0%,#0a1832 45%,#0c2142 100%)}
.layer-stars{--d:8;background-image:
  radial-gradient(1.5px 1.5px at 12% 20%,rgba(255,255,255,.8),transparent),
  radial-gradient(1.5px 1.5px at 32% 12%,rgba(255,255,255,.5),transparent),
  radial-gradient(2px 2px at 58% 24%,rgba(255,255,255,.7),transparent),
  radial-gradient(1.5px 1.5px at 78% 14%,rgba(255,255,255,.5),transparent),
  radial-gradient(1.5px 1.5px at 88% 30%,rgba(255,255,255,.6),transparent),
  radial-gradient(2px 2px at 45% 8%,rgba(255,255,255,.7),transparent)}
.layer-far{--d:12;opacity:.55;background-repeat:no-repeat;background-position:center bottom;background-size:100% auto;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 260' preserveAspectRatio='none'%3E%3Cpath fill='%23081428' d='M0 260V120h60v-30h30v30h40v-50h20v50h60v-24h28v24h70V96h22v44h66v-30h30v30h54v-52h20v52h72v-22h26v22h78V104h22v36h60v-30h30v30h64v-46h20v46h70v-20h26v20h66V120h60v140z'/%3E%3C/svg%3E")}
.layer-mid{--d:20;background-repeat:no-repeat;background-position:center bottom;background-size:120% auto;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 320' preserveAspectRatio='none'%3E%3Cpath fill='%23050d1c' d='M0 320V150h90v-44h44v44h70v-70h28v70h96v-40h30v40h120V140h30v60h110v-58h30v58h130v-72h28v72h104v-44h30v44h120V150h90v170z'/%3E%3C/svg%3E")}
.layer-fog{--d:28;background:linear-gradient(180deg,transparent 55%,rgba(120,160,210,.10) 80%,rgba(150,180,220,.22) 100%);animation:fogdrift 14s ease-in-out infinite alternate}
@keyframes fogdrift{from{transform:translate3d(calc(var(--mx)*28px - 20px),0,0)}to{transform:translate3d(calc(var(--mx)*28px + 20px),0,0)}}

.gate{position:absolute;left:50%;bottom:0;transform:translateX(-50%);width:min(560px,82vw);height:78%;z-index:20;perspective:1400px}
.gate-arch{position:absolute;inset:0 0 0 0;border-radius:50% 50% 0 0 /38% 38% 0 0;
  border:6px solid #243a5e;background:linear-gradient(180deg,#162540,#0c1830);box-shadow:inset 0 0 60px rgba(0,0,0,.7),0 0 50px rgba(0,0,0,.6)}
.gate-door{position:absolute;top:6%;height:92%;width:50%;background:
  repeating-linear-gradient(180deg,#1b2c49 0 22px,#16243d 22px 44px);
  border:3px solid var(--gold);box-shadow:inset 0 0 30px rgba(0,0,0,.6),0 0 24px rgba(245,158,11,.25);
  transition:transform 1.5s cubic-bezier(.6,.02,.2,1)}
.gate-door::after{content:'';position:absolute;top:50%;width:14px;height:14px;border-radius:50%;background:radial-gradient(circle,var(--gold-l),var(--gold));box-shadow:0 0 16px var(--gold)}
.gate-door-l{left:0;transform-origin:left center;border-radius:50% 0 0 0/40% 0 0 0}
.gate-door-l::after{right:10px;margin-top:-7px}
.gate-door-r{right:0;transform-origin:right center;border-radius:0 50% 0 0/0 40% 0 0}
.gate-door-r::after{left:10px;margin-top:-7px}
.exp.gate-open .gate-door-l{transform:rotateY(-118deg)}
.exp.gate-open .gate-door-r{transform:rotateY(118deg)}

.torch{position:absolute;bottom:30%;width:14px;height:14px;border-radius:50%;z-index:21;
  background:radial-gradient(circle,var(--gold-l),var(--amber) 60%,transparent 70%);
  box-shadow:0 0 26px 10px rgba(255,157,60,.55);animation:flick 1.6s ease-in-out infinite alternate}
.torch-l{left:-4%}.torch-r{right:-4%}
@keyframes flick{from{opacity:.7;box-shadow:0 0 22px 8px rgba(255,157,60,.45)}to{opacity:1;box-shadow:0 0 30px 13px rgba(255,180,80,.6)}}

.gate-ui{position:absolute;left:0;right:0;bottom:8%;z-index:30;text-align:center;padding:0 20px}
.gate-title{font-family:var(--fd);font-weight:800;font-size:clamp(1.8rem,6vw,3.4rem);color:#fff;letter-spacing:.04em;margin:6px 0 22px;text-shadow:0 4px 30px rgba(0,0,0,.7)}
.enter-btn{font-family:var(--fu);font-weight:700;font-size:1rem;letter-spacing:.02em;color:var(--navy);
  background:linear-gradient(180deg,var(--gold-l),var(--gold));border:none;cursor:pointer;
  padding:15px 30px;border-radius:999px;box-shadow:0 10px 34px rgba(245,158,11,.4);animation:breathe 2.4s ease-in-out infinite}
.enter-btn:hover{filter:brightness(1.06)}
@keyframes breathe{0%,100%{transform:translateY(0);box-shadow:0 10px 34px rgba(245,158,11,.4)}50%{transform:translateY(-4px);box-shadow:0 18px 44px rgba(245,158,11,.55)}}

/* entering push */
.exp.entering .scene-gate{transform:scale(2.6);opacity:0;filter:blur(10px)}

/* ---- HUB scene ---- */
.layer-hsky{--d:5;background:
  radial-gradient(80% 60% at 50% 12%,rgba(245,158,11,.16),transparent 60%),
  linear-gradient(180deg,#0b1730,#0c2042 60%,#0a1830)}
.layer-hhall{--d:12;opacity:.8;background-repeat:no-repeat;background-position:center bottom;background-size:120% auto;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 420' preserveAspectRatio='none'%3E%3Cg fill='%23091a33'%3E%3Crect x='80' y='120' width='60' height='300'/%3E%3Crect x='250' y='90' width='70' height='330'/%3E%3Crect x='1060' y='120' width='60' height='300'/%3E%3Crect x='880' y='90' width='70' height='330'/%3E%3C/g%3E%3Cpath fill='%230a1d38' d='M520 60h160l40 80H480z'/%3E%3C/svg%3E")}
.layer-hfloor{--d:20;background:linear-gradient(180deg,transparent 60%,rgba(245,158,11,.06) 78%,rgba(13,102,194,.12) 100%)}

.hub-portals{position:absolute;left:0;right:0;bottom:9%;z-index:30;display:flex;justify-content:center;align-items:flex-end;gap:clamp(14px,4vw,46px);padding:0 20px}
.portal{position:relative;display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px;width:min(280px,30vw);padding-top:164px;cursor:pointer;
  transition:transform .3s ease,filter .3s ease}
.portal:hover,.portal:focus-visible{transform:translateY(-8px);outline:none}
.portal-arch{position:absolute;top:0;width:120px;height:150px;border-radius:50% 50% 0 0/60% 60% 0 0;
  border:3px solid var(--blue);border-bottom:none;background:linear-gradient(180deg,rgba(23,135,232,.22),rgba(10,22,40,.1));
  box-shadow:0 0 40px rgba(23,135,232,.35),inset 0 0 30px rgba(23,135,232,.2);transition:box-shadow .3s,transform .3s}
.portal:hover .portal-arch{box-shadow:0 0 60px rgba(23,135,232,.6),inset 0 0 40px rgba(23,135,232,.35)}
.portal-arch-gold{border-color:var(--gold);width:140px;height:175px;
  background:linear-gradient(180deg,rgba(245,158,11,.26),rgba(20,16,6,.1));box-shadow:0 0 50px rgba(245,158,11,.45),inset 0 0 34px rgba(245,158,11,.3)}
.portal-center{width:min(320px,34vw);padding-top:196px}
.portal:hover .portal-arch-gold{box-shadow:0 0 80px rgba(245,158,11,.7),inset 0 0 46px rgba(245,158,11,.45)}
.portal-label,.portal-desc,.portal-go{position:relative;z-index:2;text-shadow:0 2px 12px rgba(4,9,18,.9)}
.portal-label{font-family:var(--fd);font-weight:700;font-size:clamp(1.05rem,2.6vw,1.5rem);color:#fff;letter-spacing:.02em}
.portal-desc{font-size:.8rem;color:var(--ink);opacity:.85;max-width:230px}
.portal-go{font-weight:700;font-size:.82rem;color:var(--blue-l);margin-top:2px}
.portal-center .portal-go{color:var(--gold-l)}

.hub-hint{position:absolute;left:0;right:0;top:7%;z-index:30;text-align:center;font-size:.8rem;letter-spacing:.06em;color:var(--ink-35)}

/* hub "look" shift (keyboard / arrows) */
.exp.look-left  .scene-hub .layer{transform:translate3d(60px,0,0)}
.exp.look-right .scene-hub .layer{transform:translate3d(-60px,0,0)}

/* exiting toward a portal */
.exp.exiting .scene-hub{transform:scale(2.2);opacity:0;filter:blur(10px)}

/* ---- HUD ---- */
.exp-hud{position:absolute;right:16px;bottom:14px;z-index:45;display:flex;gap:10px}
.hud-btn{font-family:var(--fu);font-size:.76rem;font-weight:600;color:var(--ink-60);background:rgba(8,16,30,.6);
  border:var(--line);border-radius:999px;padding:8px 14px;cursor:pointer;backdrop-filter:blur(6px);transition:color .2s,border-color .2s}
.hud-btn:hover{color:#fff;border-color:rgba(94,168,240,.5)}

@media(max-width:640px){
  .hub-portals{gap:10px}
  .portal{padding-top:122px;width:31vw}
  .portal-arch{width:84px;height:108px}
  .portal-arch-gold{width:100px;height:128px}
  .portal-center{padding-top:146px}
  .portal-desc{display:none}
}

/* =========================================================
   REAL ART (wired 2026-06-21). Flat full-scene photos used as
   cover backgrounds; CSS doors/torches/portals/parallax stay on top.
   NOTE: center file is named protal-center.jpg (typo) — referenced as-is.
   ========================================================= */
/* GATE: photo backdrop, hide placeholder silhouettes + stone arch */
.scene-gate .layer-sky{--d:6;opacity:1;background:#0a1628 url(../../img/scene-gate.jpg) center/cover no-repeat}
.scene-gate .layer-stars,.scene-gate .layer-far,.scene-gate .layer-mid{display:none}
.scene-gate .gate-arch{display:none}
.scene-gate .gate{height:66%;width:min(420px,64vw)}   /* doors sit in the gate's central opening */

/* HUB: photo backdrop, hide placeholder hall/floor */
.scene-hub .layer-hsky{--d:5;opacity:1;background:#0a1628 url(../../img/scene-hub.jpg) center/cover no-repeat}
.scene-hub .layer-hhall,.scene-hub .layer-hfloor{display:none}

/* PORTALS: each arch shows a peek of its destination scene */
.portal-left .portal-arch{background-image:url(../../img/portal-left.jpg);background-size:cover;background-position:center}
.portal-right .portal-arch{background-image:url(../../img/portal-right.jpg);background-size:cover;background-position:center}
.portal-center .portal-arch-gold{background-image:url(../../img/protal-center.jpg);background-size:cover;background-position:center}
.portal-arch{box-shadow:0 0 40px rgba(23,135,232,.4),inset 0 0 70px rgba(10,22,40,.6)}
.portal-arch-gold{box-shadow:0 0 52px rgba(245,158,11,.5),inset 0 0 70px rgba(20,16,6,.55)}

/* ============ KOLEKSI GAME (gallery) ============ */
.games{margin:64px 0}
.games-head{max-width:760px;margin:0 auto 28px;text-align:center}
.games-head h2{font-family:'Cinzel',serif;color:#f3d08a;font-size:clamp(22px,3.4vw,32px);margin:0 0 12px}
.games-head p{color:#aebfd6;line-height:1.7;margin:0}
.games-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
.game-tile{position:relative;display:block;border-radius:14px;overflow:hidden;border:1px solid rgba(245,158,11,.22);background:#0b1d3a;box-shadow:0 8px 24px rgba(4,9,18,.5);transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease}
.game-tile img{display:block;width:100%;height:auto;aspect-ratio:1/1;object-fit:cover}
.game-tile::after{content:"Main \2197";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;background:rgba(10,22,40,.62);opacity:0;transition:opacity .25s ease}
.game-tile:hover,.game-tile:focus-visible{transform:translateY(-4px);border-color:rgba(245,158,11,.7);box-shadow:0 14px 34px rgba(23,135,232,.35),0 0 26px rgba(245,158,11,.3)}
.game-tile:hover::after,.game-tile:focus-visible::after{opacity:1}
.games-cta{display:block;width:max-content;margin:28px auto 0;padding:13px 26px;border-radius:999px;font-weight:700;color:#0a1628;background:linear-gradient(135deg,#f59e0b,#f3d08a);text-decoration:none;box-shadow:0 10px 30px rgba(245,158,11,.35)}
.games-cta:hover{filter:brightness(1.06)}
@media(max-width:860px){.games-grid{grid-template-columns:repeat(4,1fr)}}
@media(max-width:520px){.games-grid{grid-template-columns:repeat(3,1fr);gap:10px}}

/* ============ HUB FLOATING GAME BUBBLES (hanging above the 3 doors) ============ */
.hub-bubbles{position:absolute;inset:0;pointer-events:none;z-index:3}
.bubble{position:absolute;width:clamp(60px,7vw,96px);height:clamp(60px,7vw,96px);border-radius:50%;overflow:hidden;pointer-events:auto;border:2px solid rgba(245,158,11,.55);box-shadow:0 10px 28px rgba(4,9,18,.6),0 0 22px rgba(23,135,232,.35),inset 0 0 18px rgba(10,22,40,.5);opacity:.86;backdrop-filter:blur(1px);transition:transform .3s ease,opacity .3s ease,box-shadow .3s ease;animation:bob 6s ease-in-out infinite}
.bubble::before{content:"";position:absolute;top:8%;left:14%;width:30%;height:22%;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.7),rgba(255,255,255,0));pointer-events:none;z-index:2}
.bubble img{width:100%;height:100%;object-fit:cover;display:block}
.bubble:hover,.bubble:focus-visible{opacity:1;transform:scale(1.16) translateY(-4px);box-shadow:0 16px 38px rgba(4,9,18,.7),0 0 30px rgba(245,158,11,.6)}
/* positions hang above the three portals */
.bubble.b1{left:11%;top:16%;animation-delay:0s}
.bubble.b2{left:24%;top:30%;animation-delay:-1.4s}
.bubble.b3{left:46%;top:11%;animation-delay:-2.6s}
.bubble.b4{left:58%;top:27%;animation-delay:-0.8s}
.bubble.b5{left:75%;top:14%;animation-delay:-3.2s}
.bubble.b6{left:86%;top:31%;animation-delay:-2.0s}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@media(prefers-reduced-motion:reduce){.bubble{animation:none}}
@media(max-width:640px){.bubble.b2,.bubble.b4{display:none}}


/* ============ FLOATING SVG DOCK MENU ============ */
.dock{position:fixed;right:16px;top:50%;transform:translateY(-50%);z-index:80;display:flex;flex-direction:column;gap:10px}
.dock a{position:relative;display:flex;align-items:center;height:46px;width:46px;overflow:hidden;border-radius:999px;background:rgba(11,29,58,.92);border:1px solid rgba(245,158,11,.35);box-shadow:0 8px 22px rgba(4,9,18,.55);color:#e9f0fb;text-decoration:none;transition:width .28s ease,border-color .28s ease,box-shadow .28s ease;backdrop-filter:blur(4px)}
.dock a svg{flex:0 0 46px;width:46px;height:46px;padding:12px;stroke:#f3d08a;fill:none;stroke-width:1.8}
.dock a span{white-space:nowrap;font-weight:600;font-size:14px;padding-right:18px;opacity:0;transition:opacity .2s ease .05s}
.dock a:hover,.dock a:focus-visible{width:178px;border-color:rgba(245,158,11,.85);box-shadow:0 10px 28px rgba(23,135,232,.4),0 0 22px rgba(245,158,11,.3)}
.dock a:hover span,.dock a:focus-visible span{opacity:1}
.dock a.is-gold{background:linear-gradient(135deg,rgba(245,158,11,.95),rgba(243,208,138,.95));border-color:transparent}
.dock a.is-gold svg{stroke:#0a1628}
.dock a.is-gold span{color:#0a1628}
@media(max-width:560px){.dock{right:10px;gap:8px}.dock a{height:42px;width:42px}.dock a svg{flex-basis:42px;width:42px;height:42px;padding:11px}.dock a:hover,.dock a:focus-visible{width:160px}}
@media(prefers-reduced-motion:reduce){.dock a{transition:none}.dock a span{transition:none}}

/* ============ FORM PAGES ============ */
.authwrap{max-width:480px;margin:0 auto;padding:8px 18px 40px}
.authcard{background:var(--ink,#0b1d3a);border:1px solid rgba(245,158,11,.28);border-radius:18px;padding:26px 24px;box-shadow:0 18px 44px rgba(4,9,18,.55)}
.authcard h1{font-family:'Cinzel',serif;color:#f3d08a;font-size:26px;margin:0 0 6px}
.authcard .sub{color:#aebfd6;margin:0 0 20px;line-height:1.6;font-size:15px}
.field{margin:0 0 14px}
.field label{display:block;font-size:13px;font-weight:600;color:#cdd9ea;margin:0 0 6px}
.field input,.field select,.field textarea{width:100%;padding:12px 14px;border-radius:10px;border:1px solid rgba(23,135,232,.35);background:#08152b;color:#eaf2ff;font-size:15px;font-family:inherit}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:#1787e8;box-shadow:0 0 0 3px rgba(23,135,232,.25)}
.field textarea{min-height:120px;resize:vertical}
.btn-primary{display:block;width:100%;padding:14px;border:0;border-radius:999px;font-weight:800;font-size:15px;cursor:pointer;color:#0a1628;background:linear-gradient(135deg,#f59e0b,#f3d08a);box-shadow:0 10px 28px rgba(245,158,11,.35)}
.btn-primary:hover{filter:brightness(1.06)}
.auth-alt{text-align:center;margin:16px 0 0;font-size:14px;color:#aebfd6}
.auth-alt a{color:#7cc0ff;font-weight:600}
.auth-note{font-size:12px;color:#8aa0bd;line-height:1.6;margin:14px 0 0}
.authcopy{max-width:560px;margin:26px auto 0;color:#aebfd6;line-height:1.75}
.authcopy h2{color:#f3d08a;font-size:18px;margin:22px 0 8px}
.authcopy p{margin:0 0 12px}
.contact-list{list-style:none;padding:0;margin:0 0 20px;display:grid;gap:10px}
.contact-list li{background:#08152b;border:1px solid rgba(23,135,232,.3);border-radius:10px;padding:12px 14px;font-size:14px}
.contact-list strong{color:#f3d08a}
