/* The King PW — layout publico (inspirado em apicls/portal-update) */
:root {
    --king-bg: #06040c;
    --king-bg-soft: #120a20;
    --king-bg-footer: #080612;
    --king-line: #3a2a57;
    --king-line-light: #4a3975;
    --king-text: #eef3ff;
    --king-text-soft: #bfc8e4;
    --king-text-muted: #99a2c3;
    --king-purple: #7b3cff;
    --king-purple-mid: #5a2cc7;
    --king-purple-dark: #3b1e7d;
    --king-purple-soft: #b68cff;
    --king-purple-highlight: #d8c2ff;
    --king-green: #39d98a;
    --king-header-border: #31234a;

    --primary: #7f47f0;
    --primary-rgb: 127, 71, 240;
    --primary-hover: #5a2cc7;
    --accent: #b68cff;
    --background: var(--king-bg);
    --surface: rgba(24, 15, 44, 0.95);
    --text-primary: var(--king-text);
    --text-secondary: var(--king-text-soft);
    --text-muted: var(--king-text-muted);
    --border: rgba(58, 42, 87, 0.8);
    --footer-bg: var(--king-bg-footer);
    --footer-text: var(--king-text-muted);
    --gradient-1: linear-gradient(135deg, #7f47f0 0%, #5a2cc7 50%, #3c217c 100%);
}

html { scroll-behavior: smooth; }

body.portal-king {
    font-family: 'Inter', sans-serif;
    background: var(--king-bg);
    color: var(--king-text);
}

body.portal-king .background-container { display: none; }

/* Header */
.portal-header {
    position: sticky;
    top: 0;
    z-index: 1000;
    border-bottom: 1px solid var(--king-header-border);
    background: rgba(10, 7, 20, 0.92);
    backdrop-filter: blur(12px);
}

.portal-header.overlay {
    border-bottom-color: rgba(255, 255, 255, 0.1);
    background: rgba(6, 4, 12, 0.38);
    backdrop-filter: blur(4px);
}

.portal-header-inner {
    max-width: 72rem;
    margin: 0 auto;
    padding: 1rem 1.5rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.portal-logo {
    display: flex;
    align-items: center;
    text-decoration: none;
    min-width: 0;
    filter: drop-shadow(0 0 14px rgba(123, 60, 255, 0.45));
}

.portal-logo img {
    height: 2.75rem;
    width: auto;
    max-width: 10rem;
    object-fit: contain;
    object-position: left;
}

.portal-logo-text {
    font-family: 'Cinzel', serif;
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--king-purple-highlight);
    letter-spacing: 0.05em;
    text-transform: uppercase;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.portal-nav {
    display: flex;
    align-items: center;
    gap: 1.5rem;
}

.portal-nav-link {
    color: #e5eeff;
    opacity: 0.9;
    text-decoration: none;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    transition: color 0.2s;
}

.portal-nav-link:hover,
.portal-nav-link.active {
    color: #d4c1ff;
    opacity: 1;
}

.portal-cta-btn {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.5rem 1rem;
    border-radius: 0.5rem;
    border: 1px solid #9d83dd;
    background: linear-gradient(135deg, #7f47f0, #5a2cc7, #3c217c);
    color: #f7f1ff;
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    text-decoration: none;
    box-shadow: 0 6px 14px rgba(66, 34, 140, 0.35);
    transition: filter 0.2s;
}

.portal-cta-btn:hover { filter: brightness(1.1); }

.portal-menu-btn {
    display: none;
    background: transparent;
    border: none;
    color: var(--king-text);
    font-size: 1.5rem;
    cursor: pointer;
    padding: 0.5rem;
}

/* Logged-in extras */
.portal-nav .coin-badge {
    background: rgba(123, 60, 255, 0.12);
    border-color: rgba(123, 60, 255, 0.3);
    color: var(--king-purple-soft);
}

.portal-nav .nav-dropdown-content {
    background: rgba(12, 9, 24, 0.98);
    border-color: var(--king-line);
}

.portal-nav .dropdown-item:hover {
    background: rgba(123, 60, 255, 0.12);
    color: var(--king-purple-soft);
}

/* Footer */
.portal-footer {
    position: relative;
    z-index: 10;
    border-top: 1px solid #2f2450;
    background: var(--king-bg-footer);
    padding: 2rem 1rem;
}

.portal-footer-inner {
    max-width: 72rem;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
    text-align: center;
}

.portal-footer-logo {
    height: 2.5rem;
    width: 2.5rem;
    opacity: 0.8;
}

.portal-footer-links {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 1rem;
}

.portal-footer-links a {
    color: #cabef0;
    text-decoration: none;
    font-size: 0.875rem;
    transition: color 0.2s;
}

.portal-footer-links a:hover { color: #d8c2ff; }

.portal-footer-copy {
    font-size: 0.6875rem;
    letter-spacing: 0.05em;
    color: var(--king-text-muted);
}

/* Hero */
.portal-hero {
    position: relative;
    margin-top: -73px;
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    padding: 7.5rem 1.5rem 4rem;
}

.portal-hero-bg {
    position: absolute;
    inset: 0;
    z-index: 0;
}

.portal-hero-bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center 35%;
}

.portal-hero-overlay-1,
.portal-hero-overlay-2 {
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
}

.portal-hero-overlay-1 {
    background:
        radial-gradient(circle at 50% 42%, rgba(123, 60, 255, 0.12), transparent 48%),
        linear-gradient(180deg, rgba(3, 3, 8, 0.08), rgba(4, 3, 11, 0.28));
}

.portal-hero-overlay-2 {
    background:
        linear-gradient(180deg, rgba(0, 0, 0, 0.12), rgba(2, 4, 8, 0.55)),
        radial-gradient(circle at 50% 38%, transparent 0, rgba(0, 0, 0, 0.28) 72%);
}

.portal-hero-content {
    position: relative;
    z-index: 10;
    max-width: 48rem;
    width: 100%;
    text-align: center;
}

.portal-hero-logo {
    margin: 0 auto 1.5rem;
    height: 7rem;
    width: 18rem;
    max-width: 100%;
    filter: drop-shadow(0 10px 28px rgba(0, 0, 0, 0.75));
}

.portal-hero-logo img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.portal-hero-logo-text {
    font-family: 'Cinzel', serif;
    font-size: 2.5rem;
    font-weight: 700;
    color: var(--king-purple-highlight);
    line-height: 1.2;
}

.portal-status {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.375rem 1rem;
    border-radius: 9999px;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.portal-status.online {
    border: 1px solid rgba(57, 217, 138, 0.3);
    background: rgba(57, 217, 138, 0.1);
    color: var(--king-green);
}

.portal-status.offline {
    border: 1px solid rgba(255, 77, 103, 0.3);
    background: rgba(255, 77, 103, 0.1);
    color: #ff4d67;
}

.portal-status-dot {
    width: 0.625rem;
    height: 0.625rem;
    border-radius: 50%;
}

.portal-status.online .portal-status-dot {
    background: var(--king-green);
    box-shadow: 0 0 10px rgba(47, 213, 136, 0.9);
}

.portal-status.offline .portal-status-dot {
    background: #ff4d67;
    box-shadow: 0 0 10px rgba(255, 77, 103, 0.9);
}

.portal-gold-badge {
    display: inline-block;
    margin-top: 2rem;
    padding: 0.75rem 1.5rem;
    border-radius: 0.5rem;
    border: 1px solid #423366;
    background: rgba(16, 9, 30, 0.68);
}

.portal-gold-badge-label {
    font-size: 0.625rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.2em;
    color: #c5b7e8;
}

.portal-gold-badge-value {
    font-family: 'Cinzel', serif;
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--king-purple-highlight);
}

.portal-hero-actions {
    margin-top: 2.5rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.75rem;
}

@media (min-width: 640px) {
    .portal-hero-actions { flex-direction: row; justify-content: center; gap: 1rem; }
}

/* Buttons */
.portal-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 10rem;
    padding: 0.875rem 1.5rem;
    border-radius: 0.5rem;
    font-size: 0.875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    text-decoration: none;
    transition: filter 0.2s;
    border: 1px solid #9d83dd;
    cursor: pointer;
}

.portal-btn-primary {
    background: linear-gradient(135deg, #7f47f0, #5a2cc7, #3c217c);
    color: #f7f1ff;
    box-shadow: 0 6px 14px rgba(66, 34, 140, 0.35);
}

.portal-btn-secondary {
    border-color: #8f82d9;
    background: linear-gradient(135deg, #6050da, #4634a5);
    color: #f2ecff;
    box-shadow: 0 6px 14px rgba(63, 47, 146, 0.35);
}

.portal-btn:hover { filter: brightness(1.1); }

/* Sections */
.portal-section {
    scroll-margin-top: 6rem;
    padding: 4rem 1.5rem;
}

.portal-section-inner {
    max-width: 72rem;
    margin: 0 auto;
}

.portal-section-title {
    margin-bottom: 2.5rem;
    text-align: center;
}

.portal-section-title h2 {
    font-family: 'Cinzel', serif;
    font-size: 2rem;
    font-weight: 700;
    color: var(--king-text);
}

.portal-section-title p {
    margin: 0.75rem auto 0;
    max-width: 42rem;
    font-size: 0.875rem;
    line-height: 1.6;
    color: var(--king-text-soft);
}

.portal-cards-3 {
    display: grid;
    gap: 1.25rem;
}

@media (min-width: 768px) {
    .portal-cards-3 { grid-template-columns: repeat(3, 1fr); }
}

.portal-info-card {
    border-radius: 10px;
    border: 1px solid var(--king-line);
    background: linear-gradient(180deg, rgba(24, 15, 44, 0.95), rgba(12, 9, 24, 0.95));
    padding: 1.5rem;
    transition: border-color 0.2s;
}

.portal-info-card:hover { border-color: rgba(90, 44, 199, 0.5); }

.portal-info-card-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.75rem;
    height: 2.75rem;
    margin-bottom: 1rem;
    border-radius: 0.5rem;
    border: 1px solid rgba(90, 44, 199, 0.4);
    background: rgba(123, 60, 255, 0.12);
    color: var(--king-purple-soft);
    font-size: 1.1rem;
}

.portal-info-card h3 {
    font-family: 'Cinzel', serif;
    font-size: 1.25rem;
    font-weight: 600;
    color: #f0f5ff;
    margin-bottom: 0.5rem;
}

.portal-info-card p {
    font-size: 0.875rem;
    line-height: 1.6;
    color: var(--king-text-soft);
}

.portal-cards-downloads {
    display: grid;
    gap: 1.25rem;
}

@media (min-width: 640px) {
    .portal-cards-downloads { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 1024px) {
    .portal-cards-downloads { grid-template-columns: repeat(3, 1fr); }
}

.portal-download-card {
    display: flex;
    flex-direction: column;
    border-radius: 0.75rem;
    border: 1px solid var(--king-line);
    background: linear-gradient(180deg, rgba(24, 15, 44, 0.95), rgba(12, 9, 24, 0.95));
    padding: 1.5rem;
}

.portal-download-card h3 {
    font-family: 'Cinzel', serif;
    font-size: 1.125rem;
    font-weight: 600;
    color: #f0f5ff;
}

.portal-download-card p {
    flex: 1;
    margin-top: 0.5rem;
    font-size: 0.875rem;
    color: var(--king-text-soft);
}

.portal-download-card .portal-btn {
    width: 100%;
    margin-top: 1.25rem;
    min-width: 0;
    font-size: 0.75rem;
    letter-spacing: 0.08em;
}

.portal-req-grid {
    display: grid;
    gap: 1.5rem;
}

@media (min-width: 768px) {
    .portal-req-grid { grid-template-columns: repeat(2, 1fr); }
}

.portal-req-card {
    border-radius: 0.75rem;
    border: 1px solid var(--king-line-light);
    background: linear-gradient(180deg, rgba(22, 14, 40, 0.95), rgba(10, 8, 20, 0.95));
    padding: 1.5rem;
}

.portal-req-card h3 {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    margin-bottom: 1rem;
    font-family: 'Cinzel', serif;
    font-size: 1.125rem;
    font-weight: 600;
    color: #e9ddff;
}

.portal-req-card ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.portal-req-card li {
    display: flex;
    gap: 0.5rem;
    margin-bottom: 0.5rem;
    font-size: 0.875rem;
    color: var(--king-text-soft);
}

.portal-req-card li span.bullet { color: var(--king-purple-soft); }

.portal-bottom-cta {
    margin-top: 2.5rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.75rem;
}

@media (min-width: 640px) {
    .portal-bottom-cta { flex-direction: row; justify-content: center; }
}

/* Mobile nav */
@media (max-width: 900px) {
    .portal-menu-btn { display: block; }

    .portal-nav {
        display: none;
        position: absolute;
        top: 100%;
        left: 0;
        right: 0;
        flex-direction: column;
        align-items: stretch;
        gap: 0;
        padding: 0.5rem 1.5rem 1rem;
        background: rgba(10, 7, 20, 0.98);
        border-bottom: 1px solid var(--king-header-border);
    }

    .portal-nav.active { display: flex; }

    .portal-nav-link,
    .portal-nav .nav-link,
    .portal-nav .coin-badge {
        padding: 0.875rem 0;
        border-bottom: 1px solid rgba(58, 42, 87, 0.5);
        width: 100%;
    }

    .portal-header-inner { position: relative; flex-wrap: wrap; }

    .portal-cta-btn { margin-left: auto; }

    .portal-nav .nav-dropdown { width: 100%; }
    .portal-nav .nav-dropdown-content {
        position: static;
        display: none;
        min-width: 100%;
        box-shadow: none;
        border: none;
        padding-left: 1rem;
    }
    .portal-nav .nav-dropdown.open .nav-dropdown-content { display: block; }
    .portal-nav .nav-dropdown:hover .nav-dropdown-content { display: none; }
}
