/* =========================================================
   Scourge Hosting — Frontend Styles
   ========================================================= */

:root {
    --scourge-bg:        #0d0d1a;
    --scourge-surface:   #16213e;
    --scourge-border:    #1f2d50;
    --scourge-accent:    #e94560;
    --scourge-accent2:   #0f3460;
    --scourge-text:      #e0e0e0;
    --scourge-muted:     #8888aa;
    --scourge-success:   #2ecc71;
    --scourge-warning:   #f39c12;
    --scourge-radius:    8px;
}

/* ---- Base ---- */
.scourge-plans-wrap,
.scourge-order-wrap,
.scourge-confirmation-wrap,
.scourge-auth-wrap,
.scourge-account-wrap {
    max-width: 960px;
    margin: 0 auto;
    padding: 20px 0;
    color: var(--scourge-text);
    font-family: inherit;
}

/* ---- Buttons ---- */
.scourge-btn {
    display: inline-block;
    padding: 12px 24px;
    border-radius: var(--scourge-radius);
    font-weight: 600;
    font-size: 0.95rem;
    text-decoration: none;
    cursor: pointer;
    border: 2px solid transparent;
    transition: all .2s ease;
    text-align: center;
}
.scourge-btn-primary,
a.scourge-btn-primary {
    background: var(--scourge-accent);
    color: #fff !important;
    border-color: var(--scourge-accent);
}
.scourge-btn-primary:hover,
a.scourge-btn-primary:hover { background: #c73550; border-color: #c73550; color: #fff !important; }
.scourge-btn-outline,
a.scourge-btn-outline {
    background: transparent;
    color: var(--scourge-text) !important;
    border-color: var(--scourge-accent);
}
.scourge-btn-outline:hover,
a.scourge-btn-outline:hover { background: var(--scourge-accent); color: #fff !important; }
.scourge-btn-sm { padding: 7px 14px; font-size: 0.85rem; }
.scourge-full-width { width: 100%; display: block; }

/* ---- Notices ---- */
.scourge-notice {
    padding: 12px 16px;
    border-radius: var(--scourge-radius);
    margin-bottom: 20px;
}
.scourge-notice-error   { background: rgba(233,69,96,.15); border-left: 4px solid var(--scourge-accent); }
.scourge-notice-success { background: rgba(46,204,113,.15); border-left: 4px solid var(--scourge-success); }
.scourge-notice-info    { background: rgba(15,52,96,.4);    border-left: 4px solid #4a90d9; }

/* ---- Plan Selection ---- */
.scourge-game-tabs {
    display: flex;
    gap: 10px;
    margin-bottom: 30px;
    flex-wrap: wrap;
}
.scourge-game-tab {
    padding: 10px 20px;
    border: 2px solid var(--scourge-border);
    border-radius: 30px;
    background: transparent;
    color: var(--scourge-text);
    cursor: pointer;
    font-size: 0.95rem;
    transition: all .2s;
}
.scourge-game-tab:hover,
.scourge-game-tab.active {
    border-color: var(--scourge-accent);
    color: var(--scourge-accent);
    background: rgba(233,69,96,.08);
}

.scourge-plans-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 24px;
    margin-bottom: 40px;
}

.scourge-plan-card {
    background: var(--scourge-surface);
    border: 1px solid var(--scourge-border);
    border-radius: var(--scourge-radius);
    padding: 28px 24px;
    display: flex;
    flex-direction: column;
    gap: 14px;
    transition: border-color .2s, transform .2s;
}
.scourge-plan-card:hover {
    border-color: var(--scourge-accent);
    transform: translateY(-3px);
}
.scourge-plan-name {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--scourge-text);
}
.scourge-plan-price {
    font-size: 2.2rem;
    font-weight: 800;
    color: var(--scourge-accent);
    line-height: 1;
}
.scourge-plan-price .currency { font-size: 1.2rem; vertical-align: super; }
.scourge-plan-price .period   { font-size: 0.9rem; color: var(--scourge-muted); font-weight: 400; }
.scourge-plan-specs,
.scourge-plan-features {
    list-style: none;
    padding: 0;
    margin: 0;
    color: var(--scourge-muted);
    font-size: 0.9rem;
}
.scourge-plan-specs li,
.scourge-plan-features li { padding: 3px 0; }
.scourge-plan-features li { color: var(--scourge-text); }
.scourge-plan-card .scourge-btn { margin-top: auto; text-align: center; }

/* Add-ons section */
.scourge-addons-section { margin-top: 40px; }
.scourge-addons-section h2 { font-size: 1.4rem; margin-bottom: 20px; }
.scourge-addons-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 16px;
}
.scourge-addon-card {
    background: var(--scourge-surface);
    border: 1px solid var(--scourge-border);
    border-radius: var(--scourge-radius);
    padding: 18px;
}
.scourge-addon-name  { font-weight: 600; margin-bottom: 6px; }
.scourge-addon-price { color: var(--scourge-accent); font-weight: 700; margin-bottom: 8px; }
.scourge-addon-desc  { font-size: 0.85rem; color: var(--scourge-muted); }

/* ---- Order Form ---- */
.scourge-order-form { max-width: 640px; }
.scourge-form-row {
    display: flex;
    flex-direction: column;
    margin-bottom: 18px;
}
.scourge-form-row label {
    font-size: 0.9rem;
    font-weight: 600;
    margin-bottom: 6px;
    color: var(--scourge-text);
}
.scourge-form-row input[type="text"],
.scourge-form-row input[type="email"],
.scourge-form-row input[type="password"],
.scourge-form-row select {
    padding: 10px 14px;
    background: var(--scourge-surface);
    border: 1px solid var(--scourge-border);
    border-radius: var(--scourge-radius);
    color: var(--scourge-text);
    font-size: 0.95rem;
    transition: border-color .2s;
}
.scourge-form-row input:focus,
.scourge-form-row select:focus {
    outline: none;
    border-color: var(--scourge-accent);
}
.scourge-form-row .required { color: var(--scourge-accent); }

.scourge-addons-checkboxes { display: flex; flex-direction: column; gap: 10px; }
.scourge-addon-check {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    cursor: pointer;
    padding: 10px 14px;
    background: var(--scourge-surface);
    border: 1px solid var(--scourge-border);
    border-radius: var(--scourge-radius);
    transition: border-color .2s;
}
.scourge-addon-check:hover { border-color: var(--scourge-accent); }
.scourge-addon-check input[type="checkbox"] { margin-top: 2px; accent-color: var(--scourge-accent); }
.addon-price { color: var(--scourge-accent); font-weight: 700; margin-left: auto; white-space: nowrap; }
.addon-desc  { display: block; font-size: 0.8rem; color: var(--scourge-muted); margin-top: 2px; }

.scourge-order-summary {
    background: var(--scourge-surface);
    border: 1px solid var(--scourge-border);
    border-radius: var(--scourge-radius);
    padding: 20px;
    margin: 24px 0;
}
.scourge-order-summary h3 { margin-top: 0; }
.scourge-order-summary table { width: 100%; }
.scourge-order-summary td { padding: 6px 0; color: var(--scourge-text); }
.summary-total td { border-top: 1px solid var(--scourge-border); padding-top: 10px; font-size: 1.1rem; }
.scourge-payment-note { color: var(--scourge-muted); font-size: 0.85rem; margin-top: 12px; }

/* ---- Confirmation ---- */
.scourge-confirmation-wrap { text-align: center; padding: 40px 20px; }
.scourge-confirmation-icon { font-size: 4rem; margin-bottom: 20px; }
.scourge-confirmation-message { text-align: left; max-width: 600px; margin: 0 auto 24px; }
.scourge-order-ref { font-size: 1.1rem; margin: 20px 0; color: var(--scourge-muted); }
.scourge-confirmation-actions { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-top: 24px; }

/* ---- Auth (Login/Register) ---- */
.scourge-auth-wrap { max-width: 480px; }
.scourge-auth-box {
    background: var(--scourge-surface);
    border: 1px solid var(--scourge-border);
    border-radius: var(--scourge-radius);
    padding: 36px 32px;
}
.scourge-auth-box h2 { margin-top: 0; }
.scourge-remember-row {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
}
.scourge-forgot { color: var(--scourge-muted); font-size: 0.85rem; }
.scourge-auth-switch { text-align: center; color: var(--scourge-muted); margin-top: 20px; }
.scourge-auth-switch a { color: var(--scourge-accent); }

/* ---- My Account ---- */
.scourge-account-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 30px;
}
.scourge-account-header h2 { margin: 0 0 4px; }
.scourge-subs-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 20px;
}
.scourge-sub-card {
    background: var(--scourge-surface);
    border: 1px solid var(--scourge-border);
    border-radius: var(--scourge-radius);
    padding: 20px;
}
.scourge-sub-card.expired { border-color: var(--scourge-accent); opacity: .8; }
.scourge-sub-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px;
}
.scourge-sub-name { font-weight: 700; font-size: 1.05rem; }
.scourge-sub-details { display: flex; flex-direction: column; gap: 8px; }
.scourge-sub-detail { display: flex; justify-content: space-between; font-size: 0.9rem; }
.scourge-sub-detail .label { color: var(--scourge-muted); }
.scourge-sub-renew { margin-top: 16px; border-top: 1px solid var(--scourge-border); padding-top: 14px; }
.scourge-sub-renew p { margin: 0 0 8px; font-size: 0.9rem; color: var(--scourge-muted); }
.scourge-account-footer { margin-top: 30px; color: var(--scourge-muted); font-size: 0.9rem; }
.scourge-account-footer a { color: var(--scourge-muted); }
.scourge-account-footer a:hover { color: var(--scourge-accent); }
.scourge-days-left { color: var(--scourge-success); font-size: 0.85rem; }
.scourge-warn { color: var(--scourge-accent) !important; }
.scourge-warn-soft { color: var(--scourge-warning) !important; }

/* ---- Badges ---- */
.scourge-badge {
    display: inline-block;
    padding: 3px 9px;
    border-radius: 30px;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
}
.scourge-badge.active    { background: rgba(46,204,113,.2);  color: var(--scourge-success); }
.scourge-badge.suspended { background: rgba(243,156,18,.2);  color: var(--scourge-warning); }
.scourge-badge.cancelled,
.scourge-badge.expired   { background: rgba(233,69,96,.2);   color: var(--scourge-accent); }
.scourge-badge.warning   { background: rgba(243,156,18,.2);  color: var(--scourge-warning); }

/* ---- Resource sliders ---- */
.scourge-sliders {
    background: var(--scourge-surface);
    border: 1px solid var(--scourge-border);
    border-radius: var(--scourge-radius);
    padding: 20px 24px;
    margin-bottom: 20px;
}
.scourge-slider-row label {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    margin-bottom: 10px;
}
.scourge-slider-row label strong {
    color: var(--scourge-accent);
    min-width: 28px;
    display: inline-block;
    text-align: center;
}
.scourge-slider-hint { color: var(--scourge-muted); font-size: 0.8rem; font-weight: 400; }
.scourge-slider-track { position: relative; }
.scourge-slider-track input[type="range"] {
    width: 100%;
    -webkit-appearance: none;
    appearance: none;
    height: 6px;
    border-radius: 3px;
    background: var(--scourge-border);
    outline: none;
    cursor: pointer;
}
.scourge-slider-track input[type="range"]::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: var(--scourge-accent);
    cursor: pointer;
    border: 2px solid #fff;
    box-shadow: 0 0 4px rgba(233,69,96,.5);
}
.scourge-slider-track input[type="range"]::-moz-range-thumb {
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: var(--scourge-accent);
    cursor: pointer;
    border: 2px solid #fff;
}
.scourge-slider-labels {
    display: flex;
    justify-content: space-between;
    font-size: 0.75rem;
    color: var(--scourge-muted);
    margin-top: 4px;
}

/* ---- Account tabs ---- */
.scourge-account-tabs {
    display: flex;
    gap: 4px;
    border-bottom: 2px solid var(--scourge-border, #2a2a3a);
    margin-bottom: 24px;
}
.scourge-account-tab {
    padding: 10px 20px;
    font-size: 13.5px;
    font-weight: 600;
    color: var(--scourge-muted, #888);
    text-decoration: none;
    border-radius: 6px 6px 0 0;
    border: 2px solid transparent;
    border-bottom: none;
    transition: color .15s, background .15s;
    position: relative;
    bottom: -2px;
}
.scourge-account-tab:hover { color: var(--scourge-text, #e8e8ec); }
.scourge-account-tab.active {
    color: var(--scourge-text, #e8e8ec);
    background: var(--scourge-bg2, #111114);
    border-color: var(--scourge-border, #2a2a3a);
    border-bottom-color: var(--scourge-bg2, #111114);
}
.scourge-tab-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--scourge-accent, #cc2a2a);
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    border-radius: 100px;
    padding: 1px 6px;
    margin-left: 4px;
}
.scourge-tab-content { padding-top: 8px; }

/* ---- Order cards ---- */
.scourge-orders-list { display: flex; flex-direction: column; gap: 16px; }
.scourge-order-card {
    background: var(--scourge-card-bg, #111114);
    border: 1px solid var(--scourge-border, #2a2a3a);
    border-radius: 10px;
    overflow: hidden;
}
.scourge-order-card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 18px;
    border-bottom: 1px solid var(--scourge-border, #2a2a3a);
    gap: 12px;
    flex-wrap: wrap;
}
.scourge-order-info { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.scourge-order-id { font-weight: 700; color: var(--scourge-text, #e8e8ec); }
.scourge-order-game { color: var(--scourge-muted, #888); font-size: 13px; }
.scourge-order-date { color: var(--scourge-muted, #888); font-size: 12px; }

/* ---- Message thread ---- */
.scourge-order-thread, .scourge-ticket-thread {
    padding: 16px 18px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.scourge-messages { display: flex; flex-direction: column; gap: 8px; }
.scourge-thread-empty { color: var(--scourge-muted, #888); font-size: 13px; margin: 0; }
.scourge-message {
    border-radius: 8px;
    padding: 10px 14px;
    font-size: 13.5px;
    line-height: 1.55;
}
.scourge-message-user {
    background: var(--scourge-bg3, #16161a);
    border: 1px solid var(--scourge-border, #2a2a3a);
    align-self: flex-start;
    max-width: 85%;
}
.scourge-message-admin {
    background: rgba(204,42,42,0.08);
    border: 1px solid rgba(204,42,42,0.25);
    align-self: flex-end;
    max-width: 85%;
}
.scourge-message-meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 5px;
    font-size: 12px;
    color: var(--scourge-muted, #888);
    gap: 8px;
}
.scourge-message-meta strong { color: var(--scourge-text, #e8e8ec); }
.scourge-send-message {
    display: flex;
    gap: 8px;
    align-items: flex-start;
    margin-top: 4px;
}
.scourge-send-message .scourge-msg-input {
    flex: 1;
    background: var(--scourge-bg3, #16161a);
    border: 1px solid var(--scourge-border, #2a2a3a);
    border-radius: 6px;
    color: var(--scourge-text, #e8e8ec);
    font-size: 13px;
    padding: 8px 12px;
    resize: vertical;
    font-family: inherit;
}
.scourge-send-message .scourge-msg-input:focus {
    outline: none;
    border-color: var(--scourge-accent, #cc2a2a);
}

/* ---- Ticket cards ---- */
.scourge-tickets-list { display: flex; flex-direction: column; gap: 16px; }
.scourge-ticket-card {
    background: var(--scourge-card-bg, #111114);
    border: 1px solid var(--scourge-border, #2a2a3a);
    border-radius: 10px;
    overflow: hidden;
}
.scourge-ticket-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 18px;
    border-bottom: 1px solid var(--scourge-border, #2a2a3a);
    gap: 12px;
    flex-wrap: wrap;
}
.scourge-ticket-id { font-weight: 700; color: var(--scourge-muted, #888); font-size: 12px; margin-right: 6px; }
.scourge-ticket-subject { font-weight: 600; color: var(--scourge-text, #e8e8ec); }

/* ---- New ticket form ---- */
.scourge-new-ticket {
    background: var(--scourge-bg3, #16161a);
    border: 1px solid var(--scourge-border, #2a2a3a);
    border-radius: 10px;
    padding: 20px;
    margin-bottom: 8px;
}
.scourge-new-ticket h4 { margin: 0 0 16px; color: var(--scourge-text, #e8e8ec); font-size: 15px; }
.scourge-new-ticket input[type="text"],
.scourge-new-ticket textarea {
    background: var(--scourge-bg, #0d0d0f);
    border: 1px solid var(--scourge-border, #2a2a3a);
    border-radius: 6px;
    color: var(--scourge-text, #e8e8ec);
    font-size: 13.5px;
    padding: 8px 12px;
    font-family: inherit;
}
.scourge-new-ticket input[type="text"]:focus,
.scourge-new-ticket textarea:focus {
    outline: none;
    border-color: var(--scourge-accent, #cc2a2a);
}

/* ---- Status badge extras ---- */
.scourge-badge.status-new        { background: rgba(100,110,200,0.15); color: #8899ee; border-color: rgba(100,110,200,0.3); }
.scourge-badge.status-processing { background: rgba(200,150,50,0.15);  color: #e0a840; border-color: rgba(200,150,50,0.3); }
.scourge-badge.status-active     { background: rgba(50,180,100,0.15);  color: #4cc97a; border-color: rgba(50,180,100,0.3); }
.scourge-badge.status-cancelled  { background: rgba(200,50,50,0.12);   color: #e07070; border-color: rgba(200,50,50,0.3); }
.scourge-badge.status-open       { background: rgba(50,180,100,0.15);  color: #4cc97a; border-color: rgba(50,180,100,0.3); }
.scourge-badge.status-closed     { background: rgba(100,100,100,0.15); color: #888;    border-color: rgba(100,100,100,0.3); }

/* ---- Location picker page ---- */
.scourge-location-wrap {
    max-width: 960px;
    margin: 0 auto;
    padding: 20px 0;
    color: var(--scourge-text);
}
.scourge-location-heading {
    font-size: 1.6rem;
    font-weight: 700;
    margin: 0 0 8px;
    color: var(--scourge-text);
}
.scourge-location-subtitle {
    color: var(--scourge-muted);
    font-size: 0.95rem;
    margin: 0 0 32px;
}
.scourge-location-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 20px;
}
.scourge-location-card {
    background: var(--scourge-surface);
    border: 2px solid var(--scourge-border);
    border-radius: 12px;
    padding: 28px 20px;
    text-align: center;
    text-decoration: none;
    color: var(--scourge-text);
    transition: border-color .2s, transform .2s, box-shadow .2s;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
}
.scourge-location-card:hover {
    border-color: var(--scourge-accent);
    transform: translateY(-3px);
    box-shadow: 0 6px 24px rgba(0,0,0,0.35);
    color: var(--scourge-text);
    text-decoration: none;
}
.scourge-location-flag { font-size: 3rem; line-height: 1; }
.scourge-location-name { font-weight: 700; font-size: 1.05rem; }
.scourge-location-soldout {
    opacity: 0.45;
    pointer-events: none;
    cursor: default;
    position: relative;
}
.scourge-soldout-badge {
    display: inline-block;
    background: rgba(200,50,50,0.18);
    color: #e07070;
    border: 1px solid rgba(200,50,50,0.35);
    border-radius: 20px;
    padding: 3px 12px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .04em;
    text-transform: uppercase;
}
.scourge-soldout-msg {
    font-size: 12px;
    color: var(--scourge-muted);
    margin: 0;
    line-height: 1.4;
}

/* ---- Plans page location bar ---- */
.scourge-plans-location-bar {
    display: flex;
    align-items: center;
    gap: 10px;
    background: var(--scourge-surface);
    border: 1px solid var(--scourge-border);
    border-radius: 8px;
    padding: 10px 16px;
    margin-bottom: 28px;
    font-size: 0.9rem;
    color: var(--scourge-muted);
}
.scourge-plans-location-bar strong { color: var(--scourge-text); }
.scourge-plans-change-loc {
    margin-left: auto;
    color: var(--scourge-accent);
    font-size: 0.85rem;
    text-decoration: none;
    font-weight: 600;
}
.scourge-plans-change-loc:hover { text-decoration: underline; }

/* ---- Sold-out full page (plans page for disabled location) ---- */
.scourge-soldout-page {
    text-align: center;
    padding: 60px 20px;
}
.scourge-soldout-page .scourge-soldout-icon { font-size: 3.5rem; margin-bottom: 16px; }
.scourge-soldout-page h2 { font-size: 1.5rem; margin: 0 0 12px; color: var(--scourge-text); }
.scourge-soldout-page p  { color: var(--scourge-muted); max-width: 420px; margin: 0 auto 24px; line-height: 1.6; }

/* ---- Responsive ---- */
@media (max-width: 600px) {
    .scourge-plans-grid  { grid-template-columns: 1fr; }
    .scourge-subs-grid   { grid-template-columns: 1fr; }
    .scourge-addons-grid { grid-template-columns: 1fr; }
    .scourge-auth-box    { padding: 24px 18px; }
    .scourge-account-header { flex-direction: column; gap: 12px; }
    .scourge-confirmation-actions { flex-direction: column; align-items: center; }
    .scourge-location-grid { grid-template-columns: 1fr 1fr; }
}

/* ---- Social login card ---- */
.scourge-social-login {
    position: relative;
    padding: 16px;
    background: rgba(88,101,242,0.06);
    border: 1px solid rgba(88,101,242,0.22);
    border-radius: 6px;
    margin-bottom: 20px;
}
.scourge-social-login__label {
    display: block;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .07em;
    color: var(--scourge-muted, #888);
    margin-bottom: 10px;
}

/* ---- Discord login button ---- */
.scourge-auth-box .scourge-discord-login-btn,
.scourge-discord-login-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    width: 100%;
    padding: 11px 16px;
    background: #5865F2;
    color: #fff !important;
    border: none;
    border-radius: 4px;
    font-size: 15px;
    font-weight: 600;
    text-decoration: none !important;
    cursor: pointer;
    transition: background .15s;
    box-sizing: border-box;
}
.scourge-auth-box .scourge-discord-login-btn:hover,
.scourge-discord-login-btn:hover { background: #4752c4; color: #fff !important; }

.scourge-auth-divider {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 14px 0;
    color: var(--scourge-muted, #888);
    font-size: 12px;
}
.scourge-auth-divider::before,
.scourge-auth-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--scourge-border, rgba(255,255,255,0.08));
}

