/* ========================================
   PORTAL — GRAFFITI BALLOON THEME
   Only applies to pages with body.portal-page
   ======================================== */

/* ── Font & Background ── */
body.portal-page {
    font-family: 'Cairo', 'Trebuchet MS', Arial, sans-serif;
    background:
        radial-gradient(circle at 6%  12%, rgba(255, 212, 71,  0.18), transparent 22rem),
        radial-gradient(circle at 94%  8%, rgba(255, 107, 53,  0.20), transparent 20rem),
        radial-gradient(circle at 50% 92%, rgba(113,  88, 255, 0.18), transparent 24rem),
        radial-gradient(circle at 18% 68%, rgba(  0, 178, 169, 0.14), transparent 18rem),
        radial-gradient(circle at 82% 60%, rgba(  0, 180, 216, 0.12), transparent 16rem),
        linear-gradient(135deg, #0e0e1f 0%, #1a0f3c 48%, #0b1d3a 100%);
    background-attachment: fixed;
}

/* ── Brand Panel (header) ── */
body.portal-page .portal-brand {
    min-height: 150px;
    padding-bottom: clamp(10px, 2vw, 18px);
    border-radius: 20px;
    border: 4px solid rgba(255, 212, 71, 0.55);
    place-items: center end;
    text-align: end;
    background:
        radial-gradient(circle at 12% 18%, rgba(255, 212, 71,  0.28), transparent 16rem),
        radial-gradient(circle at 88% 78%, rgba(113,  88, 255, 0.32), transparent 14rem),
        radial-gradient(circle at 50% 50%, rgba(  0, 178, 169, 0.14), transparent 20rem),
        linear-gradient(135deg, #12112a, #1e1048 52%, #0e2248);
    box-shadow:
        0 0 0 7px rgba(255, 212, 71, 0.10),
        0 32px 64px rgba(0, 0, 0, 0.55);
}

/* Remove the top bar from brand-panel::before on portal */
body.portal-page .portal-brand::before {
    background: linear-gradient(90deg, #FFD447, #FF6B35, #7158FF, #00B2A9, #FFD447);
    height: 6px;
    border-radius: 20px 20px 0 0;
}

/* ── Title "أصيدك" ── */
body.portal-page .portal-brand h1 {
    color: #FFD447;
    font-family: 'Cairo', 'Arial Black', Arial, sans-serif;
    font-size: clamp(5rem, 17vw, 11.5rem);
    font-weight: 900;
    letter-spacing: -0.02em;
    transform: rotate(-2deg) skew(-4deg);
    text-shadow:
        4px  4px 0 #FF6B35,
        8px  8px 0 #7158FF,
       -2px -2px 0 rgba(255, 255, 255, 0.25),
        0   22px 44px rgba(255, 212, 71, 0.45);
}

/* ── Quick-Join Panel ── */
body.portal-page .quick-join-panel {
    margin-top: 16px;
    border-radius: 16px;
    border: 2px solid rgba(255, 255, 255, 0.14);
    background: rgba(255, 255, 255, 0.07);
    box-shadow: 0 20px 42px rgba(0, 0, 0, 0.35);
    backdrop-filter: blur(10px);
}

body.portal-page .quick-join-panel .section-title h2 {
    color: #ffffff;
    font-size: clamp(1.2rem, 3vw, 1.75rem);
    font-weight: 900;
}

body.portal-page .quick-join-form input {
    background: rgba(255, 255, 255, 0.10);
    border: 2px solid rgba(255, 255, 255, 0.24);
    border-radius: 12px;
    color: #ffffff;
    font-size: 1.15rem;
    font-weight: 900;
}

body.portal-page .quick-join-form input::placeholder {
    color: rgba(255, 255, 255, 0.45);
    font-weight: 700;
}

body.portal-page .quick-join-form input:focus {
    border-color: #FFD447;
    background: rgba(255, 255, 255, 0.16);
    box-shadow: 0 0 0 4px rgba(255, 212, 71, 0.22);
}

body.portal-page .quick-join-form .primary-action {
    min-width: 104px;
    border-radius: 12px;
    border: 3px solid #0d0d1a;
    color: #0d0d1a;
    font-weight: 1000;
    background: linear-gradient(135deg, #FF6B35, #FFD447);
    box-shadow: 0 10px 22px rgba(255, 107, 53, 0.45);
    transition: transform 120ms ease, box-shadow 120ms ease;
}

body.portal-page .quick-join-form .primary-action:hover {
    background: linear-gradient(135deg, #ff5010, #ffcc00);
    transform: translateY(-2px);
    box-shadow: 0 14px 30px rgba(255, 107, 53, 0.55);
}

body.portal-page #quickJoinStatus {
    color: rgba(255, 255, 255, 0.65);
}

/* ── "اختر اللعبة" prompt ── */
body.portal-page .portal-prompt {
    margin: 22px 0 10px;
    color: #ffffff;
    font-family: 'Cairo', Arial, sans-serif;
    font-size: clamp(1.7rem, 5vw, 3.2rem);
    font-weight: 900;
    letter-spacing: 0.04em;
    text-align: center;
    text-shadow:
        3px  3px 0 rgba(255, 107, 53, 0.75),
       -1px -1px 0 rgba(113,  88, 255, 0.50),
        0    6px 18px rgba(0, 0, 0, 0.50);
}

/* ── Game Grid (panel) ── */
body.portal-page .portal-panel {
    border: none;
    background: transparent;
    box-shadow: none;
    gap: clamp(20px, 3.8vw, 32px);
    padding: 4px 0 12px;
}

/* ── Game Tiles base ── */
body.portal-page .game-tile {
    border: 4px solid #0d0d1a;
    border-radius: 20px;
    min-height: 200px;
    box-shadow:
        0 0 0 3px rgba(255, 255, 255, 0.88),
        7px 9px 0 #0d0d1a,
        0 20px 40px rgba(0, 0, 0, 0.45);
    transition: transform 120ms ease, box-shadow 120ms ease, filter 120ms ease;
}

body.portal-page .game-tile strong {
    font-family: 'Cairo', Arial, sans-serif;
    font-size: clamp(2rem, 5.5vw, 5rem);
    font-weight: 900;
    line-height: 1.1;
    letter-spacing: -0.01em;
    text-shadow:
        2px  2px 0 rgba(0, 0, 0, 0.50),
        0    5px 14px rgba(0, 0, 0, 0.35);
    -webkit-text-stroke: 1px rgba(0, 0, 0, 0.20);
}

body.portal-page .game-tile:hover {
    transform: translate(-3px, -5px) rotate(0.6deg);
    box-shadow:
        0 0 0 3px rgba(255, 255, 255, 0.98),
        10px 13px 0 #0d0d1a,
        0 28px 52px rgba(0, 0, 0, 0.55);
    filter: saturate(1.12) brightness(1.07);
}

body.portal-page .game-tile:active {
    transform: translate(5px, 6px) rotate(-0.5deg);
    box-shadow:
        0 0 0 3px rgba(255, 255, 255, 0.85),
        2px 3px 0 #0d0d1a,
        0 10px 22px rgba(0, 0, 0, 0.40);
}

/* ── Individual Game Tile Colors ── */

/* لا تقلد — Warm Orange → Yellow */
body.portal-page .game-tile.mimic {
    background:
        radial-gradient(circle at 20% 20%, rgba(255, 255, 255, 0.18), transparent 8rem),
        linear-gradient(135deg, #FF6B35 0%, #FF8C00 52%, #FFD447 100%);
}

/* اطلع برا — Electric Blue → Tiffany */
body.portal-page .game-tile.out {
    background:
        radial-gradient(circle at 80% 18%, rgba(255, 255, 255, 0.16), transparent 8rem),
        linear-gradient(135deg, #1267FF 0%, #0099CC 52%, #00B2A9 100%);
}

/* تحدي المعلومات — Purple → Blue */
body.portal-page .game-tile.trivia {
    background:
        radial-gradient(circle at 18% 22%, rgba(255, 255, 255, 0.16), transparent 8rem),
        linear-gradient(135deg, #7158FF 0%, #5A3FD4 50%, #1267FF 100%);
}

/* برا السالفة — Navy Blue → Tiffany */
body.portal-page .game-tile.bara {
    background:
        radial-gradient(circle at 75% 18%, rgba(255, 255, 255, 0.16), transparent 8rem),
        linear-gradient(135deg, #1267FF 0%, #0099CC 48%, #00B2A9 100%);
}

/* شفرة الكلمات — Tiffany → Dark Blue */
body.portal-page .game-tile.code-words {
    background:
        radial-gradient(circle at 22% 24%, rgba(255, 255, 255, 0.16), transparent 8rem),
        linear-gradient(135deg, #00B2A9 0%, #00D4C8 50%, #1267FF 100%);
}

/* أسئلة عالشاشة — Near Black → Orange Red */
body.portal-page .game-tile.jeopardy-tile {
    background:
        radial-gradient(circle at 70% 20%, rgba(255, 107, 53, 0.35), transparent 8rem),
        linear-gradient(135deg, #1a1a30 0%, #FF6B35 62%, #FF3D00 100%);
}

/* صمّم لعبتك — Yellow → Purple */
body.portal-page .game-tile.custom-trivia-tile {
    background:
        radial-gradient(circle at 18% 20%, rgba(255, 255, 255, 0.18), transparent 8rem),
        linear-gradient(135deg, #FFD447 0%, #FF8C00 48%, #7158FF 100%);
}

/* ولا كلمة — Teal Green → Yellow */
body.portal-page .game-tile.no-word-tile {
    background:
        radial-gradient(circle at 78% 20%, rgba(255, 255, 255, 0.16), transparent 8rem),
        linear-gradient(135deg, #00B2A9 0%, #16a34a 50%, #FFD447 100%);
}

/* توب 10 — Violet → Blue → Tiffany */
body.portal-page .game-tile.top10-tile {
    background:
        radial-gradient(circle at 20% 22%, rgba(255, 255, 255, 0.16), transparent 8rem),
        linear-gradient(135deg, #7158FF 0%, #1267FF 52%, #00B2A9 100%);
}

/* ── Account Widget on Portal ── */

/* Bar: full-width row, raised slightly */
body.portal-page .portal-brand .host-account-bar {
    --portal-account-stack-width: 82px;
    inset-block-start: 5px;
    inset-inline: 12px;
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-start;
    width: auto;
    gap: 0;
}

/* Avatar icon: restored size, overflow visible for ::after label */
body.portal-page .portal-brand .host-account-icon {
    order: 1;
    width: var(--portal-account-stack-width);
    height: auto;
    padding: 0;
    position: relative;
    overflow: visible;
    display: grid;
    justify-items: center;
    gap: 4px;
    border: 0;
    box-shadow: none;
    background: transparent;
    margin-inline-start: 0;
}

/* Clip avatar content to circle */
body.portal-page .portal-brand .host-account-icon > * {
    border-radius: 50%;
    overflow: hidden;
    display: block;
    width: 52px;
    height: 52px;
    border: 2px solid rgba(255, 255, 255, 0.65);
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.40);
    background: rgba(255, 255, 255, 0.18);
}

/* "الملف الشخصي" label below avatar */
body.portal-page .portal-brand .host-account-icon::after {
    content: "الملف الشخصي";
    position: static;
    transform: none;
    width: max-content;
    font-family: 'Cairo', Arial, sans-serif;
    font-size: 0.55rem;
    font-weight: 700;
    color: rgba(255, 255, 255, 0.88);
    white-space: nowrap;
    text-shadow: 0 1px 3px rgba(0, 0, 0, 0.60);
    background: rgba(0, 0, 0, 0.32);
    border-radius: 5px;
    padding: 2px 6px;
    pointer-events: none;
}

/* Balance: absolutely positioned below avatar (right side) */
body.portal-page .portal-brand .host-account-balance {
    position: absolute;
    inset-inline-start: 0;
    top: 82px;
    box-sizing: border-box;
    width: var(--portal-account-stack-width);
    display: flex;
    flex-direction: column-reverse;
    align-items: center;
    gap: 4px;
    background: rgba(0, 0, 0, 0.32);
    border-radius: 5px;
    padding: 2px 8px;
    pointer-events: auto;
    cursor: pointer;
}

body.portal-page .portal-brand .host-account-count {
    position: static;
    min-width: 18px;
    height: 18px;
    font-size: 0.68rem;
    font-weight: 900;
    background: linear-gradient(135deg, #16a34a, #22c55e);
    border: 1px solid rgba(255, 255, 255, 0.35);
    box-shadow: 0 2px 5px rgba(22, 163, 74, 0.40);
}

body.portal-page .host-account-balance span {
    color: rgba(255, 255, 255, 0.88);
    font-size: 0.55rem;
    font-weight: 700;
    font-family: 'Cairo', Arial, sans-serif;
    text-shadow: 0 1px 3px rgba(0, 0, 0, 0.60);
    white-space: nowrap;
    max-width: none;
}

/* Actions: left side in RTL, just the login button */
body.portal-page .portal-brand .host-account-actions {
    order: 2;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 0;
    max-width: none;
    margin-top: 0;
    background: none;
    border: none;
    border-radius: 0;
    padding: 0;
    backdrop-filter: none;
}

/* Login / logout button: green, compact */
body.portal-page .host-auth-toggle {
    min-height: 32px;
    padding: 5px 10px;
    font-size: 0.78rem;
    font-weight: 900;
    font-family: 'Cairo', Arial, sans-serif;
    border-radius: 10px;
    border: 2px solid rgba(0, 0, 0, 0.55);
    background: linear-gradient(135deg, #16a34a, #22c55e);
    color: #ffffff;
    box-shadow: 0 4px 10px rgba(22, 163, 74, 0.42), 2px 2px 0 rgba(0, 0, 0, 0.45);
    gap: 5px;
    width: auto;
    justify-content: center;
    transition: transform 100ms ease, box-shadow 100ms ease;
}

body.portal-page .host-auth-toggle:hover {
    background: linear-gradient(135deg, #15803d, #16a34a);
    transform: translateY(-1px);
}

body.portal-page .host-account-bar:not(.is-guest) .host-auth-toggle {
    background: linear-gradient(135deg, #dc2626, #ef4444);
    box-shadow: 0 4px 10px rgba(220, 38, 38, 0.42), 2px 2px 0 rgba(0, 0, 0, 0.45);
}

body.portal-page .host-account-bar:not(.is-guest) .host-auth-toggle:hover {
    background: linear-gradient(135deg, #b91c1c, #dc2626);
}

/* ── Footer on portal ── */
body.portal-page .site-footer {
    border-color: rgba(255, 255, 255, 0.18);
    background: rgba(255, 255, 255, 0.07);
    box-shadow: 0 14px 32px rgba(0, 0, 0, 0.30);
}

body.portal-page .site-footer a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 36px;
    background: rgba(255, 255, 255, 0.12);
    color: rgba(255, 255, 255, 0.85);
}

body.portal-page .site-footer a:hover {
    background: rgba(255, 255, 255, 0.22);
    color: #ffffff;
}

/* ── Responsive ── */
@media (max-width: 520px) {
    body.portal-page .portal-panel {
        gap: 16px;
    }

    body.portal-page .game-tile {
        min-height: 130px;
        border-radius: 14px;
    }

    body.portal-page .game-tile strong {
        font-size: clamp(1.55rem, 7.5vw, 2.4rem);
    }
}

@media (max-width: 420px) {
    body.portal-page .game-tile {
        min-height: 110px;
        border-radius: 12px;
        padding: 12px 8px;
    }

    body.portal-page .game-tile strong {
        font-size: clamp(1.35rem, 8vw, 2rem);
    }
}
