/* ============================================
   BulutUp Panel Theme - DigitalOcean Inspired
   Renk Paleti: #2f55d4 (primary), #1a3a8f (dark), #e8edfb (soft)
   ============================================ */

:root {
    --panel-primary: #2f55d4;
    --panel-primary-hover: #2648b5;
    --panel-primary-dark: #1a3a8f;
    --panel-primary-soft: #e8edfb;
    --panel-primary-softer: #f4f6fd;
    --panel-success: #2eca8b;
    --panel-success-soft: #e4f9f0;
    --panel-danger: #e43f52;
    --panel-danger-soft: #fde8ea;
    --panel-warning: #f7b84b;
    --panel-warning-soft: #fef5e4;
    --panel-info: #17a2b8;
    --panel-info-soft: #e3f6f9;
    --panel-dark: #161c2d;
    --panel-muted: #8492a6;
    --panel-border: #e9ecef;
    --panel-bg: #f8f9fc;
    --panel-card-bg: #ffffff;
    --panel-radius: 8px;
    --panel-radius-lg: 12px;
    --panel-shadow: 0 1px 3px rgba(0,0,0,0.04), 0 1px 2px rgba(0,0,0,0.06);
    --panel-shadow-md: 0 4px 6px -1px rgba(0,0,0,0.07), 0 2px 4px -1px rgba(0,0,0,0.04);
    --panel-shadow-lg: 0 10px 15px -3px rgba(0,0,0,0.08), 0 4px 6px -2px rgba(0,0,0,0.04);
    --panel-font: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    --panel-mono: 'JetBrains Mono', 'Fira Code', 'SF Mono', monospace;
    --panel-transition: all 0.15s ease;
}

/* === Base Panel Layout === */
.panel-body {
    background: var(--panel-bg);
    font-family: var(--panel-font);
    min-height: 100vh;
}

.panel-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 24px;
}

/* === Panel Sidebar === */
.panel-sidebar {
    background: var(--panel-card-bg);
    border-radius: var(--panel-radius-lg);
    border: 1px solid var(--panel-border);
    overflow: hidden;
    position: sticky;
    top: 90px;
}

.panel-sidebar .sidebar-header {
    padding: 20px 20px 16px;
    border-bottom: 1px solid var(--panel-border);
    text-align: center;
}

.panel-sidebar .sidebar-avatar {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: var(--panel-primary-soft);
    color: var(--panel-primary);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 1.1rem;
    margin-bottom: 8px;
}

.panel-sidebar .sidebar-name {
    font-weight: 600;
    font-size: 0.9rem;
    color: var(--panel-dark);
    margin: 0;
}

.panel-sidebar .sidebar-email {
    font-size: 0.75rem;
    color: var(--panel-muted);
}

.panel-sidebar .sidebar-nav {
    padding: 8px 0;
}

.panel-sidebar .nav-section-label {
    padding: 12px 20px 4px;
    font-size: 0.65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.8px;
    color: var(--panel-muted);
}

.panel-sidebar .nav-item {
    display: flex;
    align-items: center;
    padding: 10px 20px;
    color: #3c4858;
    text-decoration: none;
    font-size: 0.85rem;
    font-weight: 500;
    transition: var(--panel-transition);
    border-left: 3px solid transparent;
}

.panel-sidebar .nav-item:hover {
    background: var(--panel-primary-softer);
    color: var(--panel-primary);
}

.panel-sidebar .nav-item.active {
    background: var(--panel-primary-softer);
    color: var(--panel-primary);
    border-left-color: var(--panel-primary);
    font-weight: 600;
}

.panel-sidebar .nav-item i {
    width: 20px;
    margin-right: 12px;
    font-size: 1.1rem;
    opacity: 0.7;
}

.panel-sidebar .nav-item.active i {
    opacity: 1;
}

.panel-sidebar .nav-item .badge {
    margin-left: auto;
    font-size: 0.6rem;
    padding: 3px 6px;
}

.panel-sidebar .nav-item.text-danger:hover {
    background: var(--panel-danger-soft);
    color: var(--panel-danger);
}

/* === Panel Cards === */
.panel-card {
    background: var(--panel-card-bg);
    border-radius: var(--panel-radius-lg);
    border: 1px solid var(--panel-border);
    box-shadow: var(--panel-shadow);
    transition: var(--panel-transition);
}

.panel-card:hover {
    box-shadow: var(--panel-shadow-md);
}

.panel-card-header {
    padding: 20px 24px;
    border-bottom: 1px solid var(--panel-border);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.panel-card-header h5,
.panel-card-header h6 {
    margin: 0;
    font-weight: 600;
    font-size: 1rem;
    color: var(--panel-dark);
}

.panel-card-body {
    padding: 24px;
}

/* === Panel Page Header === */
.panel-page-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 24px;
}

.panel-page-header h4 {
    font-weight: 700;
    font-size: 1.5rem;
    color: var(--panel-dark);
    margin: 0;
}

.panel-page-header .subtitle {
    color: var(--panel-muted);
    font-size: 0.85rem;
    margin-top: 4px;
}

/* === Status Indicators === */
.status-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    display: inline-block;
    margin-right: 6px;
}

.status-dot.running {
    background: var(--panel-success);
    box-shadow: 0 0 0 3px var(--panel-success-soft);
    animation: pulse-green 2s infinite;
}

.status-dot.stopped {
    background: var(--panel-danger);
    box-shadow: 0 0 0 3px var(--panel-danger-soft);
}

.status-dot.processing {
    background: var(--panel-warning);
    box-shadow: 0 0 0 3px var(--panel-warning-soft);
    animation: pulse-yellow 1.5s infinite;
}

@keyframes pulse-green {
    0%, 100% { box-shadow: 0 0 0 3px var(--panel-success-soft); }
    50% { box-shadow: 0 0 0 6px rgba(46, 202, 139, 0.1); }
}

@keyframes pulse-yellow {
    0%, 100% { box-shadow: 0 0 0 3px var(--panel-warning-soft); }
    50% { box-shadow: 0 0 0 6px rgba(247, 184, 75, 0.1); }
}

/* === Server Create - Step Wizard === */
.create-step {
    background: var(--panel-card-bg);
    border-radius: var(--panel-radius-lg);
    border: 1px solid var(--panel-border);
    padding: 24px;
    margin-bottom: 16px;
}

.create-step .step-header {
    display: flex;
    align-items: center;
    margin-bottom: 20px;
}

.create-step .step-number {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: var(--panel-primary);
    color: #fff;
    font-size: 0.75rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-right: 12px;
    flex-shrink: 0;
}

.create-step .step-title {
    font-weight: 600;
    font-size: 0.95rem;
    color: var(--panel-dark);
    margin: 0;
}

.create-step .step-desc {
    color: var(--panel-muted);
    font-size: 0.8rem;
    margin: 0;
}

/* === Region Selector === */
.region-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: 10px;
}

.region-item {
    border: 2px solid var(--panel-border);
    border-radius: var(--panel-radius);
    padding: 12px;
    text-align: center;
    cursor: pointer;
    transition: var(--panel-transition);
}

.region-item:hover {
    border-color: var(--panel-primary);
    background: var(--panel-primary-softer);
}

.region-item.active {
    border-color: var(--panel-primary);
    background: var(--panel-primary-soft);
}

.region-item img {
    width: 24px;
    height: 24px;
    margin-bottom: 6px;
}

.region-item .region-name {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--panel-dark);
}

/* === Plan Selector Grid === */
.plan-grid {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.create-step .plan-row {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr 1fr auto;
    align-items: center;
    gap: 12px;
    padding: 14px 18px;
    border: 2px solid var(--panel-border);
    border-radius: var(--panel-radius);
    cursor: pointer;
    transition: var(--panel-transition);
    font-size: 0.85rem;
}

.create-step .plan-row:hover {
    border-color: var(--panel-primary);
    background: var(--panel-primary-softer);
}

.create-step .plan-row.active {
    border-color: var(--panel-primary);
    background: var(--panel-primary-soft);
    box-shadow: 0 0 0 1px var(--panel-primary);
}

.create-step .plan-row.disabled {
    opacity: 0.5;
    cursor: not-allowed;
    pointer-events: none;
}

.create-step .plan-row .plan-spec {
    text-align: center;
}

.create-step .plan-row .plan-spec .spec-value {
    font-weight: 700;
    color: var(--panel-dark);
    display: block;
}

.create-step .plan-row .plan-spec .spec-label {
    font-size: 0.7rem;
    color: var(--panel-muted);
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.create-step .plan-row .plan-price {
    font-weight: 700;
    color: var(--panel-primary);
    text-align: right;
    white-space: nowrap;
}

.create-step .plan-row .plan-price .price-period {
    font-weight: 400;
    font-size: 0.75rem;
    color: var(--panel-muted);
}

/* === Config Section === */
.config-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 16px;
}

.config-field label {
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--panel-dark);
    margin-bottom: 6px;
    display: block;
}

.config-field .form-control,
.config-field .form-select {
    border-radius: var(--panel-radius);
    border: 1px solid var(--panel-border);
    padding: 10px 14px;
    font-size: 0.85rem;
    transition: var(--panel-transition);
}

.config-field .form-control:focus,
.config-field .form-select:focus {
    border-color: var(--panel-primary);
    box-shadow: 0 0 0 3px rgba(47, 85, 212, 0.1);
}

.config-field .field-hint {
    font-size: 0.72rem;
    color: var(--panel-muted);
    margin-top: 4px;
}

/* === Sticky Summary (Right Side) === */
.order-summary {
    position: sticky;
    top: 90px;
    background: var(--panel-card-bg);
    border: 1px solid var(--panel-border);
    border-radius: var(--panel-radius-lg);
    padding: 24px;
    box-shadow: var(--panel-shadow-md);
}

.order-summary .summary-title {
    font-weight: 700;
    font-size: 0.9rem;
    color: var(--panel-dark);
    margin-bottom: 16px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--panel-border);
}

.order-summary .summary-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 8px 0;
    font-size: 0.82rem;
}

.order-summary .summary-row .label {
    color: var(--panel-muted);
}

.order-summary .summary-row .value {
    font-weight: 600;
    color: var(--panel-dark);
}

.order-summary .summary-total {
    margin-top: 16px;
    padding-top: 16px;
    border-top: 2px solid var(--panel-border);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.order-summary .summary-total .total-label {
    font-weight: 600;
    color: var(--panel-dark);
}

.order-summary .summary-total .total-price {
    font-size: 1.4rem;
    font-weight: 800;
    color: var(--panel-primary);
}

.order-summary .summary-total .total-period {
    font-size: 0.75rem;
    color: var(--panel-muted);
    font-weight: 400;
}

/* === Server List Table === */
.server-table {
    width: 100%;
    border-collapse: collapse;
}

.server-table thead th {
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--panel-muted);
    padding: 12px 16px;
    border-bottom: 1px solid var(--panel-border);
    background: var(--panel-bg);
}

.server-table tbody tr {
    transition: var(--panel-transition);
    border-bottom: 1px solid var(--panel-border);
}

.server-table tbody tr:hover {
    background: var(--panel-primary-softer);
}

.server-table tbody td {
    padding: 16px;
    font-size: 0.85rem;
    vertical-align: middle;
}

.server-table .server-name {
    font-weight: 600;
    color: var(--panel-dark);
}

.server-table .server-ip {
    font-family: var(--panel-mono);
    font-size: 0.8rem;
    color: var(--panel-muted);
}

/* === Server Detail Tabs === */
.panel-tabs {
    display: flex;
    border-bottom: 2px solid var(--panel-border);
    margin-bottom: 24px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.panel-tabs .tab-item {
    padding: 12px 20px;
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--panel-muted);
    text-decoration: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    transition: var(--panel-transition);
    white-space: nowrap;
}

.panel-tabs .tab-item:hover {
    color: var(--panel-primary);
}

.panel-tabs .tab-item.active {
    color: var(--panel-primary);
    border-bottom-color: var(--panel-primary);
    font-weight: 600;
}

/* === Server Detail Header === */
.server-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 20px 24px;
    background: var(--panel-card-bg);
    border: 1px solid var(--panel-border);
    border-radius: var(--panel-radius-lg);
    margin-bottom: 24px;
}

.server-header .server-info {
    display: flex;
    align-items: center;
    gap: 16px;
}

.server-header .server-icon {
    width: 48px;
    height: 48px;
    border-radius: var(--panel-radius);
    background: var(--panel-primary-soft);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--panel-primary);
    font-size: 1.3rem;
}

.server-header .server-meta h4 {
    margin: 0;
    font-weight: 700;
    font-size: 1.1rem;
    color: var(--panel-dark);
}

.server-header .server-meta .meta-row {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: 4px;
}

.server-header .server-meta .meta-item {
    font-size: 0.78rem;
    color: var(--panel-muted);
    font-family: var(--panel-mono);
}

.server-header .server-actions {
    display: flex;
    gap: 8px;
}

/* === Spec Cards (Detail Page) === */
.spec-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 12px;
}

.spec-card {
    background: var(--panel-bg);
    border: 1px solid var(--panel-border);
    border-radius: var(--panel-radius);
    padding: 16px;
    text-align: center;
    transition: var(--panel-transition);
}

.spec-card .spec-icon {
    color: var(--panel-primary);
    font-size: 1.3rem;
    margin-bottom: 8px;
}

.spec-card .spec-value {
    font-weight: 700;
    font-size: 1rem;
    color: var(--panel-dark);
}

.spec-card .spec-label {
    font-size: 0.72rem;
    color: var(--panel-muted);
    text-transform: uppercase;
    letter-spacing: 0.3px;
    margin-top: 2px;
}

/* === Action Buttons === */
.btn-panel {
    padding: 10px 20px;
    font-size: 0.85rem;
    font-weight: 600;
    border-radius: var(--panel-radius);
    border: none;
    cursor: pointer;
    transition: var(--panel-transition);
    display: inline-flex;
    align-items: center;
    gap: 6px;
    text-decoration: none;
}

.btn-panel-primary {
    background: var(--panel-primary);
    color: #fff;
}

.btn-panel-primary:hover {
    background: var(--panel-primary-hover);
    color: #fff;
    transform: translateY(-1px);
    box-shadow: var(--panel-shadow-md);
}

.btn-panel-outline {
    background: transparent;
    color: var(--panel-dark);
    border: 1px solid var(--panel-border);
}

.btn-panel-outline:hover {
    border-color: var(--panel-primary);
    color: var(--panel-primary);
    background: var(--panel-primary-softer);
}

.btn-panel-danger {
    background: transparent;
    color: var(--panel-danger);
    border: 1px solid var(--panel-danger);
}

.btn-panel-danger:hover {
    background: var(--panel-danger);
    color: #fff;
}

.btn-panel-success {
    background: transparent;
    color: var(--panel-success);
    border: 1px solid var(--panel-success);
}

.btn-panel-success:hover {
    background: var(--panel-success);
    color: #fff;
}

.btn-panel-sm {
    padding: 6px 14px;
    font-size: 0.78rem;
}

.btn-panel-lg {
    padding: 14px 28px;
    font-size: 0.95rem;
}

/* === Badge/Tags === */
.panel-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 10px;
    border-radius: 20px;
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.2px;
}

.panel-badge-success {
    background: var(--panel-success-soft);
    color: var(--panel-success);
}

.panel-badge-danger {
    background: var(--panel-danger-soft);
    color: var(--panel-danger);
}

.panel-badge-warning {
    background: var(--panel-warning-soft);
    color: var(--panel-warning);
}

.panel-badge-info {
    background: var(--panel-info-soft);
    color: var(--panel-info);
}

.panel-badge-primary {
    background: var(--panel-primary-soft);
    color: var(--panel-primary);
}

/* === Metrics Card === */
.metrics-card {
    background: var(--panel-card-bg);
    border: 1px solid var(--panel-border);
    border-radius: var(--panel-radius-lg);
    overflow: hidden;
}

.metrics-card .metrics-header {
    padding: 16px 24px;
    border-bottom: 1px solid var(--panel-border);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.metrics-card .metrics-body {
    padding: 24px;
}

/* === Copy Button === */
.copy-field {
    display: flex;
    align-items: center;
    background: var(--panel-bg);
    border: 1px solid var(--panel-border);
    border-radius: var(--panel-radius);
    padding: 10px 14px;
    gap: 10px;
}

.copy-field code {
    flex: 1;
    font-family: var(--panel-mono);
    font-size: 0.82rem;
    color: var(--panel-dark);
    background: none;
}

.copy-field .copy-btn {
    background: none;
    border: none;
    color: var(--panel-muted);
    cursor: pointer;
    padding: 4px;
    border-radius: 4px;
    transition: var(--panel-transition);
}

.copy-field .copy-btn:hover {
    color: var(--panel-primary);
    background: var(--panel-primary-soft);
}

/* === Empty State === */
.empty-state {
    text-align: center;
    padding: 60px 20px;
}

.empty-state .empty-icon {
    font-size: 3rem;
    color: var(--panel-border);
    margin-bottom: 16px;
}

.empty-state .empty-title {
    font-weight: 600;
    font-size: 1rem;
    color: var(--panel-dark);
    margin-bottom: 8px;
}

.empty-state .empty-desc {
    color: var(--panel-muted);
    font-size: 0.85rem;
    max-width: 400px;
    margin: 0 auto 20px;
}

/* === Info Boxes === */
.info-box {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 18px;
    background: var(--panel-bg);
    border: 1px solid var(--panel-border);
    border-radius: var(--panel-radius);
}

.info-box .info-icon {
    width: 36px;
    height: 36px;
    border-radius: var(--panel-radius);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    font-size: 1rem;
}

.info-box .info-icon.primary {
    background: var(--panel-primary-soft);
    color: var(--panel-primary);
}

.info-box .info-icon.success {
    background: var(--panel-success-soft);
    color: var(--panel-success);
}

.info-box .info-label {
    font-size: 0.72rem;
    color: var(--panel-muted);
    margin-bottom: 2px;
}

.info-box .info-value {
    font-weight: 600;
    font-size: 0.85rem;
    color: var(--panel-dark);
}

/* === Alerts === */
.panel-alert {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 14px 18px;
    border-radius: var(--panel-radius);
    font-size: 0.82rem;
}

.panel-alert.alert-info {
    background: var(--panel-info-soft);
    border: 1px solid rgba(23, 162, 184, 0.2);
    color: #0c5460;
}

.panel-alert.alert-warning {
    background: var(--panel-warning-soft);
    border: 1px solid rgba(247, 184, 75, 0.3);
    color: #856404;
}

.panel-alert.alert-success {
    background: var(--panel-success-soft);
    border: 1px solid rgba(46, 202, 139, 0.3);
    color: #155724;
}

/* === Responsive === */
@media (max-width: 768px) {
    .create-step .plan-row {
        grid-template-columns: 1fr 1fr;
        gap: 8px;
        padding: 12px;
    }

    .create-step .plan-row .plan-spec:nth-child(n+4) {
        display: none;
    }

    .region-grid {
        grid-template-columns: repeat(3, 1fr);
    }

    .spec-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .server-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 16px;
    }

    .server-header .server-actions {
        width: 100%;
    }

    .server-header .server-actions .btn-panel {
        flex: 1;
        justify-content: center;
    }

    .panel-tabs {
        gap: 0;
    }

    .panel-tabs .tab-item {
        padding: 10px 14px;
        font-size: 0.8rem;
    }

    .order-summary {
        position: static;
        margin-top: 16px;
    }

    .config-grid {
        grid-template-columns: 1fr;
    }

    .panel-page-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }
}

@media (max-width: 576px) {
    .region-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .create-step .plan-row {
        grid-template-columns: 1fr;
        text-align: center;
    }
}

/* === Utility Overrides for Panel Pages === */
.panel-body .section {
    padding: 30px 0;
}

.panel-body .bg-half-100 {
    padding: 60px 0 30px;
}

/* Fix navbar overlap */
.panel-body {
    background: var(--panel-bg);
}

.panel-sidebar {
    top: 100px;
}

/* ============================================
   Legacy Page Compatibility
   Eski blade sayfalarının panel layout içinde
   tutarlı görünmesi için otomatik stiller
   ============================================ */

/* Eski sayfaların form ve tablo yapısını panele uyumlu hale getir */
.panel-content-area h5:first-child,
.panel-content-area h4:first-child {
    font-family: var(--panel-font);
    font-weight: 700;
    font-size: 1.3rem;
    color: var(--panel-dark);
    margin-bottom: 20px;
}

/* Eski sayfaların shadow card'larını normalize et */
.panel-content-area .rounded.shadow,
.panel-content-area .card.shadow,
.panel-content-area .component-wrapper {
    border: 1px solid var(--panel-border);
    border-radius: var(--panel-radius-lg) !important;
    box-shadow: var(--panel-shadow) !important;
}

/* Tablolar */
.panel-content-area .table {
    font-family: var(--panel-font);
    font-size: 0.85rem;
}

.panel-content-area .table thead th {
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--panel-muted);
    border-bottom: 1px solid var(--panel-border);
    background: var(--panel-bg);
    padding: 12px 16px;
}

.panel-content-area .table tbody td {
    padding: 14px 16px;
    vertical-align: middle;
    border-bottom: 1px solid var(--panel-border);
    color: var(--panel-dark);
}

.panel-content-area .table tbody tr:hover {
    background: var(--panel-primary-softer);
}

/* Form elemanları */
.panel-content-area .form-control,
.panel-content-area .form-select {
    border-radius: var(--panel-radius);
    border: 1px solid var(--panel-border);
    font-family: var(--panel-font);
    font-size: 0.85rem;
    padding: 10px 14px;
    transition: var(--panel-transition);
}

.panel-content-area .form-control:focus,
.panel-content-area .form-select:focus {
    border-color: var(--panel-primary);
    box-shadow: 0 0 0 3px rgba(47, 85, 212, 0.1);
}

.panel-content-area .form-label,
.panel-content-area label {
    font-family: var(--panel-font);
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--panel-dark);
    margin-bottom: 6px;
}

/* Buttons in legacy pages */
.panel-content-area .btn-primary {
    background: var(--panel-primary);
    border-color: var(--panel-primary);
    border-radius: var(--panel-radius);
    font-family: var(--panel-font);
    font-weight: 600;
    font-size: 0.85rem;
    padding: 10px 20px;
    transition: var(--panel-transition);
}

.panel-content-area .btn-primary:hover {
    background: var(--panel-primary-hover);
    border-color: var(--panel-primary-hover);
    transform: translateY(-1px);
    box-shadow: var(--panel-shadow-md);
}

.panel-content-area .btn-outline-primary {
    color: var(--panel-primary);
    border-color: var(--panel-primary);
    border-radius: var(--panel-radius);
    font-family: var(--panel-font);
    font-weight: 600;
    font-size: 0.85rem;
}

.panel-content-area .btn-outline-primary:hover {
    background: var(--panel-primary);
    color: #fff;
}

/* Section titles in legacy pages */
.panel-content-area h5.title,
.panel-content-area h4.title {
    font-family: var(--panel-font);
    font-weight: 700;
    color: var(--panel-dark);
}

/* Alert styles */
.panel-content-area .alert {
    border-radius: var(--panel-radius);
    font-family: var(--panel-font);
    font-size: 0.85rem;
}

/* Badge normalization */
.panel-content-area .badge {
    font-family: var(--panel-font);
    font-weight: 600;
    border-radius: 20px;
    padding: 4px 10px;
    font-size: 0.72rem;
}

/* Accordion */
.panel-content-area .accordion-item {
    border-radius: var(--panel-radius) !important;
    border: 1px solid var(--panel-border);
    box-shadow: none !important;
}

.panel-content-area .accordion-button {
    font-family: var(--panel-font);
    font-size: 0.88rem;
    font-weight: 500;
}

/* Links in content area */
.panel-content-area a:not(.btn):not(.btn-panel):not(.nav-item) {
    color: var(--panel-primary);
}

.panel-content-area a:not(.btn):not(.btn-panel):not(.nav-item):hover {
    color: var(--panel-primary-hover);
}

/* General typography in panel */
.panel-content-area {
    font-family: var(--panel-font);
}

.panel-content-area h1, .panel-content-area h2,
.panel-content-area h3, .panel-content-area h4,
.panel-content-area h5, .panel-content-area h6 {
    font-family: var(--panel-font);
    color: var(--panel-dark);
}

/* Text muted */
.panel-body .text-muted {
    color: var(--panel-muted) !important;
}

/* Auto card styling for legacy pages (no panel-page-header) */
.panel-content-area > form {
    background: var(--panel-card-bg);
    border: 1px solid var(--panel-border);
    border-radius: var(--panel-radius-lg);
    padding: 24px;
    box-shadow: var(--panel-shadow);
    margin-bottom: 16px;
}

/* Legacy div containers (like #account, direct content wrappers) */
.panel-content-area > div:not(.panel-page-header):not(.panel-card):not(.server-header):not(.create-step):not(.panel-alert):not(.panel-tabs):not(.tab-content):not(.row):not(.d-flex):not(.order-summary):not(.spec-grid):not(.metrics-card):not(.empty-state):not([class*="col-"]):not([class*="btn"]) {
    background: var(--panel-card-bg);
    border: 1px solid var(--panel-border);
    border-radius: var(--panel-radius-lg);
    padding: 24px;
    box-shadow: var(--panel-shadow);
    margin-bottom: 16px;
}

/* Don't double-style our new components */
.panel-content-area > .panel-page-header,
.panel-content-area > .create-step,
.panel-content-area > .panel-card,
.panel-content-area > .server-header,
.panel-content-area > .panel-tabs,
.panel-content-area > .tab-content,
.panel-content-area > .panel-alert,
.panel-content-area > .row,
.panel-content-area > .d-flex {
    /* Already styled by their own rules */
}
