/* ============================================
   Site front-end — Premium Dark Theme v2.0
   Modern glassmorphism + animated gradients
   ============================================ */

/* === Self-hosted TH Sarabun New ===
   ไฟล์อยู่ที่ /fonts/th_sarabun/ — โหลดเร็ว ใช้งานได้แม้ออฟไลน์
   • unicode-range U+0E00-0E7F → ใช้ TH Sarabun "เฉพาะภาษาไทย"
     ส่วนภาษาอังกฤษ/ตัวเลขจะ fallback ไปใช้ Sarabun (Google Fonts) อัตโนมัติ
   • size-adjust: 140% → ขยาย glyph TH Sarabun ภายในให้ขนาดตา (visual size)
     เทียบเคียงกับ Sarabun fallback ที่ font-size เดียวกัน
   • font-display: swap → สลับมาใช้ TH Sarabun ทันทีเมื่อโหลดเสร็จ
     (ใช้คู่กับ preload + inline @font-face ใน header.php = แทบไม่มี FOUT) */
@font-face {
    font-family: 'TH Sarabun New';
    src: url('../fonts/th_sarabun/THSarabunNew.ttf') format('truetype');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
    size-adjust: 140%;
    unicode-range: U+0E00-0E7F, U+200B-200D, U+25CC;
}
@font-face {
    font-family: 'TH Sarabun New';
    src: url('../fonts/th_sarabun/THSarabunNew%20Bold.ttf') format('truetype');
    font-weight: 700;
    font-style: normal;
    font-display: swap;
    size-adjust: 140%;
    unicode-range: U+0E00-0E7F, U+200B-200D, U+25CC;
}
@font-face {
    font-family: 'TH Sarabun New';
    src: url('../fonts/th_sarabun/THSarabunNew%20Italic.ttf') format('truetype');
    font-weight: 400;
    font-style: italic;
    font-display: swap;
    size-adjust: 140%;
    unicode-range: U+0E00-0E7F, U+200B-200D, U+25CC;
}
@font-face {
    font-family: 'TH Sarabun New';
    src: url('../fonts/th_sarabun/THSarabunNew%20BoldItalic.ttf') format('truetype');
    font-weight: 700;
    font-style: italic;
    font-display: swap;
    size-adjust: 140%;
    unicode-range: U+0E00-0E7F, U+200B-200D, U+25CC;
}

/* === Variables === */
:root {
    --bg-dark: #060a13;
    --bg-darker: #030508;
    --bg-card: rgba(12, 20, 40, 0.55);
    --bg-card-hover: rgba(14, 26, 52, 0.7);
    --primary: #00d2ff;
    --primary-rgb: 0, 210, 255;
    --primary-glow: rgba(0, 210, 255, 0.35);
    --secondary: #7b61ff;
    --secondary-rgb: 123, 97, 255;
    --accent: #ff3d71;
    --accent-rgb: 255, 61, 113;
    --success: #00e676;
    --text-main: #eaf0f6;
    --text-light: #f8fafc;
    --text-muted: #8899b0;
    --border-color: rgba(255, 255, 255, 0.06);
    --border-glow: rgba(0, 210, 255, 0.15);
    --font-heading: 'TH Sarabun New', 'Sarabun', system-ui, sans-serif;
    --font-body: 'TH Sarabun New', 'Sarabun', system-ui, sans-serif;
    --container-width: 1200px;
    --radius-sm: 8px;
    --radius-md: 14px;
    --radius-lg: 20px;
    --radius-xl: 28px;
    --shadow-card: 0 8px 32px rgba(0, 0, 0, 0.35);
    --shadow-glow: 0 0 40px rgba(var(--primary-rgb), 0.12);
    --transition: 0.35s cubic-bezier(0.4, 0, 0.2, 1);
    --impersonation-bar-height: 48px;
}

/* === Reset === */
*,
*::before,
*::after {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
    /* ใช้ size-adjust ใน @font-face จัดการ Thai ให้ขนาดเท่า Latin แล้ว
       — root size ปรับขึ้นเล็กน้อยเพื่อความสบายตา */
    font-size: 17px;
}

body {
    font-family: var(--font-body);
    background: var(--bg-dark);
    color: var(--text-main);
    line-height: 1.7;
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: var(--font-heading);
    font-weight: 700;
    line-height: 1.25;
    color: var(--text-light);
}

a {
    text-decoration: none;
    color: inherit;
    transition: var(--transition);
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

ul {
    list-style: none;
}

/* === Select / Dropdown Fix === */
select {
    background-color: rgba(12, 20, 40, 0.95) !important;
    color: var(--text-main) !important;
    border: 1px solid var(--border-color);
    -webkit-appearance: menulist;
    -moz-appearance: menulist;
    appearance: menulist;
}

select option,
select optgroup {
    background-color: #0b1225 !important;
    color: #fff !important;
    padding: 12px;
    font-size: 1rem;
}

select option:hover,
select option:focus,
select option:checked {
    background-color: var(--secondary) !important;
    color: #fff !important;
}

select:-moz-focusring {
    color: transparent;
    text-shadow: 0 0 0 #fff;
}

select::-ms-expand {
    display: none;
}

select.form-control,
select.form-select,
select[name="bank"],
select[name="ext"] {
    background-color: rgba(12, 20, 40, 0.95) !important;
    color: #fff !important;
}

select.form-control option,
select.form-select option,
select[name="bank"] option,
select[name="ext"] option {
    background-color: #0b1225 !important;
    color: #fff !important;
}

/* === Animated Background === */
.fixed-bg {
    position: fixed;
    inset: 0;
    z-index: -1;
    pointer-events: none;
    background:
        radial-gradient(ellipse 600px 600px at 10% 20%, rgba(var(--primary-rgb), 0.06), transparent),
        radial-gradient(ellipse 500px 500px at 90% 80%, rgba(var(--secondary-rgb), 0.05), transparent),
        radial-gradient(ellipse 400px 400px at 50% 50%, rgba(var(--accent-rgb), 0.03), transparent);
    animation: bgFloat 20s ease-in-out infinite alternate;
}

@keyframes bgFloat {
    0% {
        filter: hue-rotate(0deg);
    }

    100% {
        filter: hue-rotate(15deg);
    }
}

/* Grid noise overlay for premium feel */
body::before {
    content: '';
    position: fixed;
    inset: 0;
    z-index: -1;
    pointer-events: none;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.02'/%3E%3C/svg%3E");
    opacity: 0.4;
}

/* === Container === */
.container {
    max-width: var(--container-width);
    margin: 0 auto;
    padding: 0 24px;
}

/* === Utility === */
.highlight {
    color: var(--primary);
}

.gradient-text {
    background: linear-gradient(135deg, var(--primary), var(--secondary));
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

/* === Scroll Reveal Animations === */
.reveal {
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 0.7s ease, transform 0.7s ease;
}

.reveal.active {
    opacity: 1;
    transform: translateY(0);
}

/* Date display: ดู d/m/yyyy ลากเมาส์ชี้ title = เวลา H:i */
span.dt-tip {
    cursor: help;
    text-decoration: underline;
    text-decoration-style: dotted;
    text-underline-offset: 2px;
    text-decoration-color: rgba(255, 255, 255, 0.35);
}

/* === Buttons === */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px 28px;
    border-radius: var(--radius-sm);
    font-weight: 600;
    font-family: var(--font-heading);
    font-size: 0.95rem;
    cursor: pointer;
    border: none;
    position: relative;
    overflow: hidden;
    transition: var(--transition);
    letter-spacing: 0.3px;
}

.btn-primary {
    /* ::before ใช้ position:absolute — ลูก DOM แค่ .btn-primary ต้องมีกล่องอ้างอิง ไม่งั้นลิงก์ใน admin อาจคลิกทับ layout */
    position: relative;
    overflow: hidden;
    background: linear-gradient(135deg, var(--primary), var(--secondary));
    color: #fff;
    box-shadow: 0 4px 20px rgba(var(--primary-rgb), 0.3);
    isolation: isolate;
}

.btn-primary::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, var(--secondary), var(--primary));
    opacity: 0;
    transition: opacity 0.4s;
    z-index: -1;
}

.btn-primary:hover::before {
    opacity: 1;
}

.btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 30px rgba(var(--primary-rgb), 0.45);
    color: #fff;
}

.btn-primary span,
.btn-primary i {
    position: relative;
    z-index: 1;
}

.btn-outline {
    background: transparent;
    border: 1px solid rgba(255, 255, 255, 0.12);
    color: var(--text-main);
    backdrop-filter: blur(4px);
}

.btn-outline:hover {
    border-color: var(--primary);
    color: var(--primary);
    background: rgba(var(--primary-rgb), 0.06);
}

.btn-glass {
    background: rgba(255, 255, 255, 0.04);
    backdrop-filter: blur(12px);
    border: 1px solid rgba(255, 255, 255, 0.08);
    color: var(--text-main);
}

.btn-glass:hover {
    background: rgba(255, 255, 255, 0.08);
    border-color: rgba(255, 255, 255, 0.15);
    transform: translateY(-2px);
}

.btn-lg {
    padding: 16px 36px;
    font-size: 1.05rem;
    border-radius: var(--radius-md);
}

/* === Navigation === */
/* Admin กำลังดูในนาม user: แถบ fixed บนสุด + เลื่อน .navbar ลง (เดิม navbar z-index ทับแถบ) */
.impersonation-bar {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 10050;
    min-height: var(--impersonation-bar-height);
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 10px 16px;
    padding: 10px 16px;
    background: linear-gradient(135deg, #4f46e5, #7c3aed);
    color: #fff;
    font-size: 0.9rem;
    text-align: center;
    box-sizing: border-box;
    box-shadow: 0 2px 16px rgba(0, 0, 0, 0.35);
}
.impersonation-bar__text {
    display: inline-flex;
    align-items: center;
    flex-wrap: wrap;
    justify-content: center;
    gap: 6px;
}
.impersonation-bar__text i {
    margin-right: 4px;
    opacity: 0.9;
}
.impersonation-bar__sub {
    opacity: 0.9;
    font-weight: 500;
}
.impersonation-bar__form {
    display: inline;
    margin: 0;
}
.btn-impersonation-exit {
    background: #fff;
    color: #4f46e5;
    border: 0;
    padding: 7px 16px;
    border-radius: 8px;
    font-weight: 600;
    cursor: pointer;
    font-size: 0.86rem;
    font-family: var(--font-heading, inherit);
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.12);
    transition: transform 0.15s, box-shadow 0.2s;
    white-space: nowrap;
}
.btn-impersonation-exit:hover {
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.2);
    filter: brightness(1.02);
}
body.impersonating .navbar {
    top: var(--impersonation-bar-height);
}
@media (max-width: 600px) {
    :root {
        --impersonation-bar-height: 52px;
    }
    .impersonation-bar {
        padding: 8px 12px;
        font-size: 0.82rem;
    }
}

.navbar {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 1000;
    padding: 18px 0;
    transition: var(--transition);
}

.navbar.scrolled {
    background: rgba(6, 10, 19, 0.82);
    backdrop-filter: blur(20px) saturate(1.8);
    -webkit-backdrop-filter: blur(20px) saturate(1.8);
    border-bottom: 1px solid var(--border-color);
    padding: 12px 0;
    box-shadow: 0 4px 30px rgba(0, 0, 0, 0.3);
}

.nav-container {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.logo {
    font-size: 1.8rem;
    font-weight: 700;
    letter-spacing: 1px;
    display: flex;
    align-items: center;
}

.logo img {
    height: 40px;
    transition: var(--transition);
}

.logo:hover img {
    filter: brightness(1.15);
}

.nav-links {
    display: flex;
    gap: 32px;
}

.nav-links a {
    font-weight: 400;
    font-size: 0.95rem;
    color: var(--text-muted);
    position: relative;
    padding: 4px 0;
}

.nav-links a::after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 50%;
    width: 0;
    height: 2px;
    background: linear-gradient(90deg, var(--primary), var(--secondary));
    transition: all 0.3s ease;
    transform: translateX(-50%);
    border-radius: 2px;
}

.nav-links a:hover {
    color: var(--text-light);
}

.nav-links a:hover::after {
    width: 100%;
}

.nav-actions {
    display: flex;
    gap: 12px;
    align-items: center;
}

.menu-toggle {
    display: none;
    background: none;
    border: none;
    color: var(--text-main);
    font-size: 1.4rem;
    cursor: pointer;
    width: 44px;
    height: 44px;
    border-radius: var(--radius-sm);
    transition: var(--transition);
}

.menu-toggle:hover {
    background: rgba(255, 255, 255, 0.06);
}

/* ── Mobile nav drawer ── */
.mobile-nav {
    position: fixed;
    inset: 0;
    z-index: 1100;
    visibility: hidden;
    pointer-events: none;
    transition: visibility 0.35s;
}

.mobile-nav.open {
    visibility: visible;
    pointer-events: auto;
}

.mobile-nav-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(3px);
    -webkit-backdrop-filter: blur(3px);
    opacity: 0;
    transition: opacity 0.35s ease;
    cursor: pointer;
}

.mobile-nav.open .mobile-nav-backdrop {
    opacity: 1;
}

.mobile-nav-panel {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    width: min(300px, 82vw);
    background: linear-gradient(180deg, #0e1628 0%, #06090f 100%);
    border-left: 1px solid rgba(255, 255, 255, 0.07);
    box-shadow: -24px 0 70px rgba(0, 0, 0, 0.7);
    display: flex;
    flex-direction: column;
    transform: translateX(100%);
    transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1);
    overflow-y: auto;
}

.mobile-nav.open .mobile-nav-panel {
    transform: translateX(0);
}

.mobile-nav-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 18px 16px 18px 20px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
    flex-shrink: 0;
}

.mobile-nav-close {
    width: 36px;
    height: 36px;
    border-radius: var(--radius-sm);
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.08);
    color: var(--text-light);
    font-size: 0.95rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: var(--transition);
    flex-shrink: 0;
}

.mobile-nav-close:hover {
    background: rgba(255, 61, 113, 0.15);
    border-color: rgba(255, 61, 113, 0.35);
    color: #ff6b93;
}

.mobile-nav-links {
    display: flex;
    flex-direction: column;
    padding: 14px 10px;
    gap: 2px;
    flex: 1;
}

.mobile-nav-links a {
    display: flex;
    align-items: center;
    gap: 14px;
    font-size: 0.97rem;
    font-weight: 500;
    color: var(--text-muted);
    padding: 13px 14px;
    border-radius: var(--radius-md);
    transition: var(--transition);
    text-decoration: none;
    font-family: var(--font-heading);
}

.mobile-nav-links a i {
    width: 20px;
    text-align: center;
    font-size: 0.9rem;
    color: var(--primary);
    opacity: 0.65;
    flex-shrink: 0;
    transition: var(--transition);
}

.mobile-nav-links a:hover {
    color: var(--text-light);
    background: rgba(var(--primary-rgb), 0.09);
}

.mobile-nav-links a:hover i {
    opacity: 1;
}

.mobile-nav-actions {
    padding: 16px 16px 28px;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
    display: flex;
    flex-direction: column;
    gap: 10px;
    flex-shrink: 0;
}

.btn.btn-full {
    width: 100%;
    justify-content: center;
}

/* === Hero Section === */
.hero {
    min-height: 100vh;
    display: flex;
    align-items: center;
    position: relative;
    padding-top: 80px;
    overflow: hidden;
    background: var(--bg-dark);
}

/* Dot grid background pattern */
.hero-grid-bg {
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    background-image:
        radial-gradient(circle at 1px 1px, rgba(255, 255, 255, 0.04) 1px, transparent 0);
    background-size: 40px 40px;
    mask-image: radial-gradient(ellipse 80% 70% at 50% 40%, black 30%, transparent 70%);
    -webkit-mask-image: radial-gradient(ellipse 80% 70% at 50% 40%, black 30%, transparent 70%);
}

/* Aurora gradient sweep */
.hero-aurora {
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    background:
        linear-gradient(135deg,
            rgba(var(--primary-rgb), 0.10) 0%,
            rgba(var(--secondary-rgb), 0.08) 25%,
            transparent 50%,
            rgba(var(--accent-rgb), 0.04) 75%,
            rgba(var(--primary-rgb), 0.06) 100%);
    animation: auroraShift 12s ease-in-out infinite alternate;
}

@keyframes auroraShift {
    0% {
        opacity: 0.6;
        filter: hue-rotate(0deg);
    }

    50% {
        opacity: 1;
    }

    100% {
        opacity: 0.7;
        filter: hue-rotate(20deg);
    }
}

/* Glowing orbs */
.hero-orb {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    filter: blur(80px);
    z-index: 0;
}

.hero-orb-1 {
    width: 500px;
    height: 500px;
    background: radial-gradient(circle, rgba(var(--primary-rgb), 0.18), transparent 70%);
    top: -10%;
    left: -5%;
    animation: orbFloat1 10s ease-in-out infinite alternate;
}

.hero-orb-2 {
    width: 400px;
    height: 400px;
    background: radial-gradient(circle, rgba(var(--secondary-rgb), 0.14), transparent 70%);
    top: 20%;
    right: 5%;
    animation: orbFloat2 8s ease-in-out infinite alternate;
}

.hero-orb-3 {
    width: 300px;
    height: 300px;
    background: radial-gradient(circle, rgba(var(--accent-rgb), 0.08), transparent 70%);
    bottom: 5%;
    left: 30%;
    animation: orbFloat3 14s ease-in-out infinite alternate;
}

@keyframes orbFloat1 {
    0% {
        transform: translate(0, 0) scale(1);
    }

    100% {
        transform: translate(60px, 40px) scale(1.15);
    }
}

@keyframes orbFloat2 {
    0% {
        transform: translate(0, 0) scale(1);
    }

    100% {
        transform: translate(-50px, 30px) scale(1.1);
    }
}

@keyframes orbFloat3 {
    0% {
        transform: translate(0, 0) scale(1);
    }

    100% {
        transform: translate(30px, -20px) scale(1.2);
    }
}

/* Bottom fade to bg */
.hero::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 200px;
    z-index: 1;
    pointer-events: none;
    background: linear-gradient(to bottom, transparent, var(--bg-dark));
}

.hero-container {
    position: relative;
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 60px;
}

.hero-content {
    max-width: 600px;
    flex-shrink: 0;
}

.badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 18px;
    background: rgba(var(--primary-rgb), 0.08);
    border: 1px solid rgba(var(--primary-rgb), 0.18);
    border-radius: 50px;
    font-size: 0.88rem;
    color: var(--primary);
    margin-bottom: 24px;
    font-family: var(--font-heading);
    font-weight: 500;
    backdrop-filter: blur(8px);
    animation: fadeInUp 0.8s ease both;
}

.hero-title {
    font-size: 4.2rem;
    line-height: 1.1;
    margin-bottom: 28px;
    letter-spacing: -1px;
    animation: fadeInUp 0.8s ease 0.1s both;
}

.hero-subtitle {
    font-size: 1.15rem;
    color: var(--text-muted);
    margin-bottom: 44px;
    max-width: 580px;
    line-height: 1.8;
    animation: fadeInUp 0.8s ease 0.2s both;
}

.hero-buttons {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
    animation: fadeInUp 0.8s ease 0.3s both;
}

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(24px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Hero Stats Row */
.hero-stats {
    display: flex;
    gap: 36px;
    margin-top: 48px;
    animation: fadeInUp 0.8s ease 0.4s both;
}

.hero-stat {
    display: flex;
    flex-direction: column;
}

.hero-stat-num {
    font-size: 1.8rem;
    font-weight: 800;
    font-family: var(--font-heading);
    background: linear-gradient(135deg, var(--primary), var(--secondary));
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

.hero-stat-label {
    font-size: 0.82rem;
    color: var(--text-muted);
    margin-top: 2px;
    text-transform: uppercase;
    letter-spacing: 1px;
    font-family: var(--font-heading);
}

/* === Hero Visual (right side) === */
.hero-visual {
    flex: 1;
    position: relative;
    min-height: 420px;
    animation: fadeInUp 0.8s ease 0.5s both;
}

/* Server dashboard card */
.hero-server-card {
    position: relative;
    width: 100%;
    max-width: 380px;
    margin-left: auto;
}

.server-card-glow {
    position: absolute;
    inset: -20px;
    border-radius: 30px;
    background: radial-gradient(ellipse at center, rgba(var(--primary-rgb), 0.12), transparent 70%);
    filter: blur(30px);
    z-index: 0;
    animation: cardGlow 4s ease-in-out infinite alternate;
}

@keyframes cardGlow {
    0% {
        opacity: 0.5;
        transform: scale(0.95);
    }

    100% {
        opacity: 1;
        transform: scale(1.05);
    }
}

.server-card-inner {
    position: relative;
    z-index: 1;
    background: rgba(12, 20, 40, 0.6);
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: var(--radius-lg);
    padding: 28px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.4);
}

.server-card-header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 24px;
    font-family: var(--font-heading);
    font-weight: 600;
    font-size: 1rem;
    color: var(--text-light);
}

.server-card-header i:first-child {
    color: var(--primary);
    font-size: 1.2rem;
}

.server-status {
    margin-left: auto;
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--success);
    display: flex;
    align-items: center;
    gap: 5px;
}

.server-status i {
    font-size: 0.5rem;
    animation: statusPulse 2s ease-in-out infinite;
}

@keyframes statusPulse {

    0%,
    100% {
        opacity: 1;
    }

    50% {
        opacity: 0.3;
    }
}

.server-card-stats {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.server-stat-row {
    display: flex;
    align-items: center;
    gap: 12px;
    font-family: var(--font-heading);
    font-size: 0.8rem;
    color: var(--text-muted);
}

.server-stat-row span:first-child {
    width: 30px;
    font-weight: 600;
    color: var(--text-light);
    font-size: 0.75rem;
}

.server-stat-row span:last-child {
    width: 40px;
    text-align: right;
    font-size: 0.75rem;
}

.server-bar {
    flex: 1;
    height: 6px;
    border-radius: 3px;
    background: rgba(255, 255, 255, 0.06);
    overflow: hidden;
}

.server-bar-fill {
    height: 100%;
    border-radius: 3px;
    background: linear-gradient(90deg, var(--primary), var(--secondary));
    transition: width 1.5s ease;
    animation: barPulse 3s ease-in-out infinite alternate;
}

.server-bar-net {
    background: linear-gradient(90deg, var(--success), var(--primary));
}

@keyframes barPulse {
    0% {
        opacity: 0.7;
    }

    100% {
        opacity: 1;
    }
}

.server-card-footer {
    display: flex;
    gap: 16px;
    margin-top: 20px;
    padding-top: 16px;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
    font-size: 0.75rem;
    color: var(--text-muted);
    font-family: var(--font-heading);
}

.server-card-footer i {
    color: var(--primary);
    margin-right: 5px;
}

/* Floating mini cards */
.hero-float-card {
    position: absolute;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    border-radius: 12px;
    background: rgba(12, 20, 40, 0.7);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border: 1px solid rgba(255, 255, 255, 0.08);
    font-size: 0.82rem;
    font-family: var(--font-heading);
    font-weight: 500;
    color: var(--text-light);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3);
    z-index: 2;
}

.float-card-1 {
    top: 10%;
    right: 0;
    animation: floatCard 5s ease-in-out infinite alternate;
}

.float-card-2 {
    bottom: 15%;
    left: 0;
    animation: floatCard 6s ease-in-out 1s infinite alternate;
}

@keyframes floatCard {
    0% {
        transform: translateY(0);
    }

    100% {
        transform: translateY(-12px);
    }
}

/* Floating particles in hero */
.hero-particles {
    position: absolute;
    inset: 0;
    z-index: 0;
    overflow: hidden;
    pointer-events: none;
}

.hero-particles span {
    position: absolute;
    display: block;
    background: rgba(var(--primary-rgb), 0.5);
    border-radius: 50%;
    animation: particleFloat linear infinite;
}

@keyframes particleFloat {
    0% {
        transform: translateY(100vh) scale(0);
        opacity: 0;
    }

    10% {
        opacity: 1;
    }

    90% {
        opacity: 0.6;
    }

    100% {
        transform: translateY(-10vh) scale(1);
        opacity: 0;
    }
}

/* === Section Header === */
.section-header {
    text-align: center;
    margin-bottom: 64px;
}

.section-header h2 {
    font-size: 2.6rem;
    margin-bottom: 16px;
    letter-spacing: -0.5px;
}

.section-header p {
    color: var(--text-muted);
    font-size: 1.05rem;
    max-width: 600px;
    margin: 0 auto;
}

/* === Services === */
.services {
    padding: 110px 0;
    position: relative;
}

.services-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 24px;
}

/* === Glass Card (services, general) === */
.glass-card {
    background: var(--bg-card);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    padding: 36px 28px;
    transition: var(--transition);
    position: relative;
    overflow: hidden;
}

.glass-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--primary), var(--secondary), transparent);
    opacity: 0;
    transition: opacity 0.4s;
}

.glass-card::after {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at top left, rgba(var(--primary-rgb), 0.04), transparent 60%);
    pointer-events: none;
}

.glass-card:hover {
    transform: translateY(-8px);
    background: var(--bg-card-hover);
    border-color: var(--border-glow);
    box-shadow: var(--shadow-card), var(--shadow-glow);
}

.glass-card:hover::before {
    opacity: 1;
}

.card-icon {
    width: 56px;
    height: 56px;
    background: linear-gradient(135deg, rgba(var(--primary-rgb), 0.12), rgba(var(--secondary-rgb), 0.08));
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.6rem;
    color: var(--primary);
    margin-bottom: 22px;
    transition: var(--transition);
    border: 1px solid rgba(var(--primary-rgb), 0.1);
}

.glass-card:hover .card-icon {
    background: linear-gradient(135deg, var(--primary), var(--secondary));
    color: #fff;
    border-color: transparent;
    transform: scale(1.08);
    box-shadow: 0 4px 20px rgba(var(--primary-rgb), 0.35);
}

.glass-card h3 {
    font-size: 1.3rem;
    margin-bottom: 12px;
    position: relative;
    z-index: 1;
}

.glass-card p {
    color: var(--text-muted);
    margin-bottom: 20px;
    font-size: 0.93rem;
    position: relative;
    z-index: 1;
    line-height: 1.7;
}

.card-link {
    color: var(--primary);
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: var(--font-heading);
    font-size: 0.9rem;
    position: relative;
    z-index: 1;
}

.card-link i {
    transition: transform 0.3s;
    font-size: 0.8rem;
}

.card-link:hover {
    color: var(--secondary);
}

.card-link:hover i {
    transform: translateX(5px);
}

.card-links-multi {
    display: flex;
    gap: 20px;
}

/* === Features === */
.features {
    padding: 110px 0;
    background: linear-gradient(180deg, transparent, rgba(12, 20, 40, 0.5), transparent);
    position: relative;
}

.container-features {
    display: flex;
    align-items: center;
    gap: 70px;
}

.feature-img-wrapper {
    flex: 1;
    position: relative;
    border-radius: var(--radius-xl);
    overflow: hidden;
}

.glass-sphere {
    position: absolute;
    width: 350px;
    height: 350px;
    background: rgba(var(--primary-rgb), 0.15);
    border-radius: 50%;
    filter: blur(100px);
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 0;
    animation: spherePulse 6s ease-in-out infinite alternate;
}

@keyframes spherePulse {
    0% {
        transform: translate(-50%, -50%) scale(1);
        opacity: 0.5;
    }

    100% {
        transform: translate(-50%, -50%) scale(1.2);
        opacity: 0.8;
    }
}

/* Old feature-img kept for backward compat on internal pages */
.feature-img {
    width: 100%;
    border-radius: var(--radius-xl);
    position: relative;
    z-index: 1;
    border: 1px solid var(--border-color);
    box-shadow: 0 25px 50px rgba(0, 0, 0, 0.5);
}

/* === CSS Server Rack Illustration === */
.server-illustration {
    position: relative;
    z-index: 1;
    padding: 32px;
    background: rgba(8, 14, 28, 0.7);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: var(--radius-xl);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    box-shadow: 0 25px 60px rgba(0, 0, 0, 0.5), inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.si-rack {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.si-unit {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 18px;
    background: rgba(12, 20, 40, 0.6);
    border: 1px solid rgba(255, 255, 255, 0.05);
    border-radius: var(--radius-md);
    transition: var(--transition);
}

.si-unit.active {
    border-color: rgba(var(--primary-rgb), 0.15);
    background: linear-gradient(135deg, rgba(var(--primary-rgb), 0.04), rgba(var(--secondary-rgb), 0.03));
    box-shadow: 0 0 20px rgba(var(--primary-rgb), 0.06);
}

/* LEDs */
.si-leds {
    display: flex;
    gap: 5px;
    flex-shrink: 0;
}

.si-led {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    animation: ledBlink 3s ease-in-out infinite;
}

.si-led.green {
    background: #00e676;
    box-shadow: 0 0 6px #00e676;
}

.si-led.cyan {
    background: var(--primary);
    box-shadow: 0 0 6px var(--primary);
}

.si-led.blue {
    background: var(--secondary);
    box-shadow: 0 0 6px var(--secondary);
}

@keyframes ledBlink {

    0%,
    100% {
        opacity: 1;
    }

    50% {
        opacity: 0.3;
    }
}

.si-led:nth-child(2) {
    animation-delay: 0.5s;
}

.si-led:nth-child(3) {
    animation-delay: 1s;
}

/* Horizontal lines (simulates drive bays / ports) */
.si-lines {
    display: flex;
    gap: 4px;
    flex: 1;
}

.si-lines span {
    flex: 1;
    height: 4px;
    border-radius: 2px;
    background: rgba(255, 255, 255, 0.06);
    position: relative;
    overflow: hidden;
}

.si-unit.active .si-lines span {
    background: rgba(var(--primary-rgb), 0.1);
}

.si-unit.active .si-lines span::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, transparent, rgba(var(--primary-rgb), 0.3), transparent);
    animation: lineScan 2.5s ease-in-out infinite;
}

@keyframes lineScan {
    0% {
        transform: translateX(-100%);
    }

    100% {
        transform: translateX(100%);
    }
}

.si-unit.active .si-lines span:nth-child(2)::after {
    animation-delay: 0.3s;
}

.si-unit.active .si-lines span:nth-child(3)::after {
    animation-delay: 0.6s;
}

.si-unit.active .si-lines span:nth-child(4)::after {
    animation-delay: 0.9s;
}

/* Label */
.si-label {
    font-family: 'Courier New', monospace;
    font-size: 0.7rem;
    color: var(--text-muted);
    background: rgba(255, 255, 255, 0.04);
    padding: 3px 8px;
    border-radius: 4px;
    letter-spacing: 1px;
    flex-shrink: 0;
}

.si-unit.active .si-label {
    color: var(--primary);
    background: rgba(var(--primary-rgb), 0.08);
}

/* Stats overlay badges */
.si-stats-overlay {
    position: relative;
    margin-top: 16px;
    display: flex;
    justify-content: space-between;
}

.si-stat-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    border-radius: 10px;
    background: rgba(var(--primary-rgb), 0.06);
    border: 1px solid rgba(var(--primary-rgb), 0.12);
    font-family: var(--font-heading);
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--primary);
    animation: floatCard 5s ease-in-out infinite alternate;
}

.si-stat-badge.bottom {
    animation-delay: 1.5s;
}

.si-stat-badge i {
    font-size: 0.8rem;
}

.features-content {
    flex: 1;
}

.features-content h2 {
    font-size: 2.8rem;
    margin-bottom: 44px;
    line-height: 1.2;
}

.feature-item {
    display: flex;
    gap: 18px;
    margin-bottom: 28px;
}

.feature-icon {
    width: 48px;
    height: 48px;
    flex-shrink: 0;
    background: linear-gradient(135deg, rgba(var(--secondary-rgb), 0.1), rgba(var(--primary-rgb), 0.06));
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
    color: var(--secondary);
    border: 1px solid rgba(var(--secondary-rgb), 0.15);
    transition: var(--transition);
}

.feature-item:hover .feature-icon {
    background: linear-gradient(135deg, var(--secondary), var(--primary));
    color: #fff;
    border-color: transparent;
    box-shadow: 0 4px 15px rgba(var(--secondary-rgb), 0.3);
}

.feature-item h4 {
    font-size: 1.15rem;
    margin-bottom: 6px;
}

.feature-item p {
    color: var(--text-muted);
    font-size: 0.93rem;
}

/* === Footer === */
.footer {
    background: linear-gradient(180deg, var(--bg-darker), #020306);
    padding: 80px 0 28px;
    border-top: 1px solid var(--border-color);
    position: relative;
}

.footer::before {
    content: '';
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 40%;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(var(--primary-rgb), 0.3), transparent);
}

.footer-grid {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: 50px;
    margin-bottom: 60px;
}

/* Footer logo branding */
.brand-col .logo {
    display: inline-block;
    position: relative;
    padding: 8px 0;
}

.brand-col .logo img {
    height: 42px;
    position: relative;
    z-index: 1;
    filter: drop-shadow(0 0 12px rgba(var(--primary-rgb), 0.25));
    transition: var(--transition);
}

.brand-col .logo:hover img {
    filter: drop-shadow(0 0 20px rgba(var(--primary-rgb), 0.4));
    transform: translateY(-2px);
}

.brand-desc {
    margin: 18px 0;
    color: var(--text-muted);
    max-width: 300px;
    font-size: 0.93rem;
    line-height: 1.7;
}

/* Footer social icons */
.footer-social {
    display: flex;
    gap: 10px;
    margin: 16px 0;
}

.footer-social a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 10px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.06);
    color: var(--text-muted);
    font-size: 0.95rem;
    transition: var(--transition);
}

.footer-social a:hover {
    background: rgba(var(--primary-rgb), 0.1);
    border-color: rgba(var(--primary-rgb), 0.2);
    color: var(--primary);
    transform: translateY(-2px);
}

.payment-methods {
    margin-top: 22px;
}

.payment-methods span {
    display: block;
    color: var(--text-muted);
    margin-bottom: 10px;
    font-size: 0.88rem;
}

.pay-icons {
    display: flex;
    gap: 14px;
    font-size: 1.4rem;
    color: var(--text-muted);
}

.pay-icons i {
    transition: var(--transition);
}

.pay-icons i:hover {
    color: var(--primary);
}

.footer-col h4 {
    font-size: 1.05rem;
    margin-bottom: 22px;
    color: var(--text-light);
    position: relative;
    padding-bottom: 12px;
}

.footer-col h4::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 28px;
    height: 2px;
    background: linear-gradient(90deg, var(--primary), var(--secondary));
    border-radius: 2px;
}

.footer-col ul li {
    margin-bottom: 11px;
}

.footer-col ul li a {
    color: var(--text-muted);
    font-size: 0.93rem;
    transition: var(--transition);
    display: inline-block;
}

.footer-col ul li a:hover {
    color: var(--primary);
    transform: translateX(4px);
}

.footer-bottom {
    text-align: center;
    padding-top: 28px;
    border-top: 1px solid var(--border-color);
    color: var(--text-muted);
    font-size: 0.85rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.footer-bottom a {
    color: var(--primary);
}

.footer-bottom a:hover {
    text-decoration: underline;
}

/* ============================================
   Internal Pages
   ============================================ */

/* Internal Hero */
.internal-hero {
    padding: 160px 0 90px;
    text-align: center;
    position: relative;
    border-bottom: 1px solid var(--border-color);
    overflow: hidden;
}

.internal-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse 600px 400px at 30% 40%, rgba(var(--primary-rgb), 0.07), transparent),
        radial-gradient(ellipse 500px 400px at 70% 60%, rgba(var(--secondary-rgb), 0.05), transparent),
        linear-gradient(to bottom, rgba(6, 10, 19, 0.4), var(--bg-dark));
    z-index: 0;
}

.internal-hero>* {
    position: relative;
    z-index: 1;
}

.internal-hero .badge {
    margin-bottom: 18px;
}

.internal-hero h1 {
    font-size: 3.4rem;
    margin-bottom: 20px;
    letter-spacing: -0.5px;
}

.internal-hero p {
    font-size: 1.1rem;
    color: var(--text-muted);
    max-width: 640px;
    margin: 0 auto;
}

/* Page Section */
.page-section {
    padding: 90px 0;
    position: relative;
}

/* === Contact Cards === */
.contact-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    max-width: 800px;
    margin: 0 auto;
}

.contact-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    text-decoration: none;
    color: inherit;
    padding: 36px 20px 28px;
    background: var(--bg-card);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    transition: var(--transition);
    position: relative;
    overflow: hidden;
}

.contact-card::before {
    content: '';
    position: absolute;
    inset: 0;
    opacity: 0;
    background: radial-gradient(ellipse at 50% 0%, rgba(var(--primary-rgb), 0.06), transparent 70%);
    transition: opacity 0.4s;
}

.contact-card:hover {
    transform: translateY(-6px);
    border-color: rgba(var(--primary-rgb), 0.2);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.3), 0 0 30px rgba(var(--primary-rgb), 0.06);
}

.contact-card:hover::before {
    opacity: 1;
}

.contact-card-icon {
    width: 64px;
    height: 64px;
    border-radius: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.6rem;
    margin-bottom: 18px;
    position: relative;
    z-index: 1;
    transition: var(--transition);
}

.contact-card:hover .contact-card-icon {
    transform: scale(1.08);
}

.phone-icon {
    background: rgba(0, 210, 255, 0.08);
    color: var(--primary);
    border: 1px solid rgba(0, 210, 255, 0.15);
}

.email-icon {
    background: rgba(123, 97, 255, 0.08);
    color: var(--secondary);
    border: 1px solid rgba(123, 97, 255, 0.15);
}

.ticket-icon {
    background: rgba(255, 61, 113, 0.08);
    color: var(--accent);
    border: 1px solid rgba(255, 61, 113, 0.15);
}

.chat-icon {
    background: rgba(0, 230, 118, 0.08);
    color: var(--success);
    border: 1px solid rgba(0, 230, 118, 0.15);
}

.line-icon {
    background: rgba(0, 195, 0, 0.08);
    color: #00c300;
    border: 1px solid rgba(0, 195, 0, 0.15);
}

.contact-card h3 {
    font-size: 1rem;
    margin-bottom: 6px;
    color: var(--text-light);
    position: relative;
    z-index: 1;
}

.contact-card-value {
    font-size: 0.88rem;
    color: var(--primary);
    font-weight: 600;
    font-family: var(--font-heading);
    margin-bottom: 8px;
    position: relative;
    z-index: 1;
    word-break: break-all;
}

.contact-card-hint {
    font-size: 0.75rem;
    color: var(--text-muted);
    position: relative;
    z-index: 1;
}

/* LINE wide card spans full row */
.contact-card-wide {
    grid-column: 1 / -1;
    flex-direction: row;
    gap: 24px;
    padding: 28px 36px;
    text-align: left;
    background: linear-gradient(135deg, rgba(0, 195, 0, 0.03), var(--bg-card));
    border-color: rgba(0, 195, 0, 0.1);
}

.contact-card-wide .contact-card-icon {
    margin-bottom: 0;
}

.contact-card-line-info {
    display: flex;
    flex-direction: column;
}

/* === Payment Page === */
.pay-banks-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
    max-width: 800px;
    margin: 0 auto 32px;
}

.pay-bank-card {
    padding: 22px 24px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-left: 3px solid var(--bank-color, var(--primary));
    border-radius: var(--radius-md);
    transition: var(--transition);
}

.pay-bank-card:hover {
    transform: translateY(-3px);
    border-color: rgba(255, 255, 255, 0.1);
    border-left-color: var(--bank-color, var(--primary));
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.2);
}

.pay-bank-header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 8px;
    font-size: 0.95rem;
}

.pay-bank-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    flex-shrink: 0;
    box-shadow: 0 0 6px currentColor;
}

.pay-bank-branch {
    font-size: 0.8rem;
    color: var(--text-muted);
    margin-bottom: 6px;
}

.pay-bank-number {
    font-family: 'Courier New', monospace;
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--primary);
    letter-spacing: 1px;
}

/* Other payment methods */
.pay-other-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
    max-width: 800px;
    margin: 0 auto 24px;
}

.pay-other-card {
    display: flex;
    align-items: center;
    gap: 18px;
    padding: 22px 24px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    transition: var(--transition);
}

.pay-other-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.2);
}

.pay-other-icon {
    width: 52px;
    height: 52px;
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.4rem;
    flex-shrink: 0;
    border: 1px solid transparent;
}

.pay-other-card h4 {
    font-size: 0.95rem;
    margin-bottom: 2px;
}

.pay-other-value {
    font-family: 'Courier New', monospace;
    font-size: 1rem;
    font-weight: 700;
    color: var(--primary);
}

.pay-other-desc {
    font-size: 0.8rem;
    color: var(--text-muted);
    margin-top: 2px;
}

/* Alert box */
.pay-alert-box {
    display: flex;
    align-items: center;
    gap: 10px;
    max-width: 800px;
    margin: 0 auto;
    padding: 14px 20px;
    border-radius: var(--radius-md);
    background: rgba(255, 193, 7, 0.06);
    border: 1px solid rgba(255, 193, 7, 0.15);
    color: #ffc107;
    font-size: 0.88rem;
}

.pay-alert-box i {
    font-size: 1rem;
    flex-shrink: 0;
}

/* Notify steps */
.pay-notify-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    max-width: 900px;
    margin: 0 auto 40px;
}

.pay-notify-card {
    text-align: center;
    padding: 32px 24px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    position: relative;
    transition: var(--transition);
}

.pay-notify-card:hover {
    transform: translateY(-4px);
    border-color: rgba(var(--primary-rgb), 0.15);
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.2);
}

.pay-notify-step {
    position: absolute;
    top: -12px;
    left: 50%;
    transform: translateX(-50%);
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--primary), var(--secondary));
    color: #fff;
    font-size: 0.8rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
}

.pay-notify-icon {
    font-size: 1.8rem;
    margin-bottom: 14px;
    margin-top: 8px;
}

.pay-notify-card h4 {
    margin-bottom: 10px;
    font-size: 1rem;
}

.pay-notify-card p {
    font-size: 0.88rem;
    color: var(--text-muted);
    line-height: 1.6;
}

/* Info box */
.pay-info-box {
    max-width: 700px;
    margin: 0 auto;
    padding: 28px 32px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    text-align: center;
}

.pay-info-box h4 {
    margin-bottom: 16px;
    font-size: 1.05rem;
}

.pay-info-items {
    display: flex;
    flex-wrap: wrap;
    gap: 12px 24px;
    justify-content: center;
}

.pay-info-items span {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 0.88rem;
    color: var(--text-muted);
}

.pay-info-items i {
    color: var(--primary);
    font-size: 0.75rem;
}

/* ────────────────────────────────────────────────────────────────
 * Payment form (redesigned)
 * โครงสร้าง: card → header (icon + title + secure pill) → 4 sections
 * + drag-and-drop slip uploader (พร้อม preview รูป/PDF) + sticky footer
 * ──────────────────────────────────────────────────────────────── */
.pay-form-wrap {
    max-width: 880px;
    margin: 0 auto;
    padding: 0;
    background: linear-gradient(180deg, rgba(20, 30, 56, 0.65) 0%, rgba(12, 20, 40, 0.85) 100%);
    border: 1px solid rgba(255, 255, 255, 0.07);
    border-radius: var(--radius-xl);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    overflow: hidden;
    box-shadow: 0 24px 60px -28px rgba(0, 0, 0, 0.55), 0 1px 0 rgba(255, 255, 255, 0.04) inset;
    position: relative;
}
.pay-form-wrap::before {
    content: '';
    position: absolute;
    inset: 0 0 auto 0;
    height: 3px;
    background: linear-gradient(90deg, var(--primary, #00d2ff), var(--secondary, #6c63ff), var(--accent, #c084fc));
    opacity: 0.85;
}

/* ── Card header ───────────────────────────────────────────── */
.pay-form-head {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 26px 32px;
    background: linear-gradient(135deg, rgba(99, 102, 241, 0.10) 0%, rgba(0, 210, 255, 0.06) 100%);
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}
.pay-form-head__icon {
    flex: 0 0 auto;
    width: 56px;
    height: 56px;
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, rgba(0, 210, 255, 0.20), rgba(108, 99, 255, 0.20));
    border: 1px solid rgba(255, 255, 255, 0.10);
    color: var(--primary, #00d2ff);
    font-size: 1.4rem;
    box-shadow: 0 8px 24px -10px rgba(0, 210, 255, 0.45);
}
.pay-form-head__text { flex: 1; min-width: 0; }
.pay-form-head__title {
    margin: 0 0 4px;
    font-size: 1.18rem;
    color: var(--text-light, #f1f5f9);
    font-weight: 700;
    letter-spacing: 0.2px;
}
.pay-form-head__sub {
    margin: 0;
    font-size: 0.86rem;
    color: var(--text-muted, #94a3b8);
    line-height: 1.5;
}
.pay-form-head__badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    border-radius: 999px;
    background: rgba(34, 197, 94, 0.12);
    border: 1px solid rgba(34, 197, 94, 0.28);
    color: #22c55e;
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.4px;
    text-transform: uppercase;
    flex-shrink: 0;
}

/* ── Flash messages (เลิกใช้ inline alert เดิม) ─────────────── */
.pay-flash {
    display: flex;
    gap: 10px;
    align-items: flex-start;
    margin: 18px 32px 0;
    padding: 12px 14px;
    border-radius: 12px;
    font-size: 0.92rem;
    line-height: 1.5;
}
.pay-flash i { font-size: 1.1rem; margin-top: 2px; flex-shrink: 0; }
.pay-flash--ok {
    background: rgba(34, 197, 94, 0.10);
    color: #86efac;
    border: 1px solid rgba(34, 197, 94, 0.28);
}
.pay-flash--err {
    background: rgba(239, 68, 68, 0.10);
    color: #fca5a5;
    border: 1px solid rgba(239, 68, 68, 0.28);
}

/* ── Form padding wrapper (ใช้ form > section.padding) ─────── */
.pay-form-wrap form { padding: 22px 32px 28px; }

/* ── Sections (1..4) ───────────────────────────────────────── */
.pay-form-section {
    margin: 0 0 22px;
    padding: 18px 18px 14px;
    background: rgba(255, 255, 255, 0.025);
    border: 1px solid rgba(255, 255, 255, 0.05);
    border-radius: 14px;
    transition: border-color 0.3s, background 0.3s;
}
.pay-form-section:hover {
    border-color: rgba(var(--primary-rgb, 0, 210, 255), 0.18);
    background: rgba(255, 255, 255, 0.035);
}
.pay-form-section__head {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    margin-bottom: 14px;
    padding-bottom: 12px;
    border-bottom: 1px dashed rgba(255, 255, 255, 0.06);
}
.pay-form-section__step {
    flex: 0 0 auto;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--primary, #00d2ff), var(--secondary, #6c63ff));
    color: #fff;
    font-weight: 700;
    font-size: 0.85rem;
    box-shadow: 0 6px 16px -6px rgba(0, 210, 255, 0.45);
}
.pay-form-section__title {
    margin: 0 0 2px;
    font-size: 1rem;
    font-weight: 700;
    color: var(--text-light, #f1f5f9);
}
.pay-form-section__sub {
    margin: 0;
    font-size: 0.82rem;
    color: var(--text-muted, #94a3b8);
}
.pay-form-section__pills {
    margin-left: auto;
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}
.pay-format-pill {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 4px 9px;
    border-radius: 999px;
    background: rgba(99, 102, 241, 0.10);
    border: 1px solid rgba(99, 102, 241, 0.22);
    color: #a5b4fc;
    font-size: 0.72rem;
    font-weight: 600;
}
.pay-form-optional {
    color: var(--text-muted, #94a3b8);
    font-weight: 500;
    font-size: 0.85em;
    margin-left: 4px;
}

/* ── Form rows / groups / inputs ───────────────────────────── */
.pay-form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    margin-bottom: 12px;
}
.pay-form-row:last-child { margin-bottom: 0; }
.pay-form-row-3 { grid-template-columns: 1fr 1fr 1fr; }

.pay-form-group { margin-bottom: 4px; }

.pay-form-group label {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 7px;
    font-size: 0.86rem;
    color: var(--text-light, #f1f5f9);
    font-weight: 500;
}
.pay-form-group label i {
    color: var(--primary, #00d2ff);
    width: 16px;
    text-align: center;
    opacity: 0.85;
}

.pay-form-group input,
.pay-form-group select,
.pay-form-group textarea {
    width: 100%;
    padding: 12px 14px;
    background: rgba(12, 20, 40, 0.55);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 10px;
    color: var(--text-light, #f1f5f9);
    font-size: 0.92rem;
    font-family: var(--font-body);
    outline: none;
    transition: border-color 0.25s, box-shadow 0.25s, background 0.25s;
}
.pay-form-group input:hover:not([readonly]),
.pay-form-group select:hover,
.pay-form-group textarea:hover {
    border-color: rgba(255, 255, 255, 0.16);
}
.pay-form-group input:focus,
.pay-form-group select:focus,
.pay-form-group textarea:focus {
    border-color: rgba(var(--primary-rgb, 0, 210, 255), 0.55);
    box-shadow: 0 0 0 3px rgba(var(--primary-rgb, 0, 210, 255), 0.10);
    background: rgba(12, 20, 40, 0.75);
}
.pay-form-group textarea { resize: vertical; min-height: 90px; line-height: 1.6; }
.pay-form-group select { cursor: pointer; }

.pay-form-readonly {
    background: rgba(26, 35, 50, 0.6) !important;
    cursor: not-allowed !important;
    color: var(--text-muted, #94a3b8) !important;
    opacity: 0.88;
}

/* ── Input affix (สำหรับช่องจำนวนเงิน — โชว์ ฿ ด้านหน้า) ── */
.pay-form-input-affix {
    position: relative;
    display: flex;
    align-items: stretch;
}
.pay-form-input-affix__icon {
    position: absolute;
    inset: 0 auto 0 0;
    width: 42px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-muted, #94a3b8);
    font-weight: 700;
    font-size: 1rem;
    pointer-events: none;
    border-right: 1px solid rgba(255, 255, 255, 0.06);
}
.pay-form-input-affix input { padding-left: 52px; }

/* ── Hint text ─────────────────────────────────────────────── */
.pay-form-hint {
    font-size: 0.78rem;
    color: var(--text-muted, #94a3b8);
    margin: 6px 0 0;
}

/* ── Drag & drop slip uploader ─────────────────────────────── */
.pay-dropzone {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 170px;
    padding: 22px;
    border: 2px dashed rgba(var(--primary-rgb, 0, 210, 255), 0.30);
    border-radius: 14px;
    background:
        radial-gradient(120% 100% at 50% 0%, rgba(0, 210, 255, 0.06), transparent 60%),
        rgba(12, 20, 40, 0.45);
    cursor: pointer;
    transition: border-color 0.25s, background 0.25s, transform 0.25s;
    outline: none;
}
.pay-dropzone:hover,
.pay-dropzone:focus-visible {
    border-color: rgba(var(--primary-rgb, 0, 210, 255), 0.55);
    background:
        radial-gradient(120% 100% at 50% 0%, rgba(0, 210, 255, 0.10), transparent 60%),
        rgba(12, 20, 40, 0.6);
}
.pay-dropzone.is-drag {
    border-color: rgba(34, 197, 94, 0.65);
    background:
        radial-gradient(120% 100% at 50% 0%, rgba(34, 197, 94, 0.14), transparent 60%),
        rgba(12, 20, 40, 0.7);
    transform: scale(1.005);
}
.pay-dropzone.has-file {
    cursor: default;
    border-style: solid;
    border-color: rgba(34, 197, 94, 0.45);
    background:
        radial-gradient(120% 100% at 50% 0%, rgba(34, 197, 94, 0.06), transparent 60%),
        rgba(12, 20, 40, 0.55);
}

/* hide-by-attribute — กัน [hidden] โดน flex override */
.pay-dropzone__inner[hidden],
.pay-dropzone__preview[hidden],
.pay-dropzone__file-icon[hidden] { display: none !important; }

.pay-dropzone__inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 10px;
    pointer-events: none; /* ให้ click ส่งไป dropzone */
}
.pay-dropzone__icon {
    width: 64px;
    height: 64px;
    border-radius: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, rgba(0, 210, 255, 0.16), rgba(108, 99, 255, 0.18));
    border: 1px solid rgba(255, 255, 255, 0.10);
    color: var(--primary, #00d2ff);
    font-size: 1.6rem;
    box-shadow: 0 10px 26px -12px rgba(0, 210, 255, 0.55);
}
.pay-dropzone__title {
    font-size: 0.98rem;
    color: var(--text-light, #f1f5f9);
    font-weight: 600;
}
.pay-dropzone__hint {
    font-size: 0.82rem;
    color: var(--text-muted, #94a3b8);
}

.pay-dropzone__preview {
    display: flex;
    align-items: center;
    gap: 16px;
    width: 100%;
}
.pay-dropzone__media {
    flex: 0 0 auto;
    width: 96px;
    height: 96px;
    border-radius: 14px;
    overflow: hidden;
    background: rgba(0, 0, 0, 0.30);
    border: 1px solid rgba(255, 255, 255, 0.08);
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
}
.pay-dropzone__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.pay-dropzone__file-icon {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, rgba(239, 68, 68, 0.15), rgba(239, 68, 68, 0.05));
    color: #f87171;
    font-size: 2.2rem;
}
.pay-dropzone__meta {
    flex: 1;
    min-width: 0;
}
.pay-dropzone__filename {
    font-size: 0.95rem;
    color: var(--text-light, #f1f5f9);
    font-weight: 600;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.pay-dropzone__sub {
    margin-top: 3px;
    font-size: 0.82rem;
    color: var(--text-muted, #94a3b8);
}
.pay-dropzone__status {
    margin-top: 8px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 9px;
    border-radius: 999px;
    background: rgba(34, 197, 94, 0.12);
    border: 1px solid rgba(34, 197, 94, 0.30);
    color: #86efac;
    font-size: 0.76rem;
    font-weight: 600;
}
.pay-dropzone__clear {
    flex: 0 0 auto;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(239, 68, 68, 0.12);
    border: 1px solid rgba(239, 68, 68, 0.30);
    color: #f87171;
    cursor: pointer;
    transition: background 0.2s, transform 0.2s;
}
.pay-dropzone__clear:hover {
    background: rgba(239, 68, 68, 0.20);
    transform: rotate(90deg);
}
.pay-dropzone__error {
    margin-top: 10px !important;
    color: #f87171 !important;
    font-weight: 500;
}

/* ── Footer / submit ───────────────────────────────────────── */
.pay-form-actions {
    display: flex;
    gap: 16px;
    align-items: center;
    flex-wrap: wrap;
    margin-top: 22px;
    padding: 16px 18px;
    background: rgba(255, 255, 255, 0.025);
    border: 1px solid rgba(255, 255, 255, 0.05);
    border-radius: 14px;
}
.pay-form-actions__hint {
    flex: 1;
    min-width: 200px;
    display: flex;
    align-items: center;
    gap: 8px;
    color: var(--text-muted, #94a3b8);
    font-size: 0.82rem;
    line-height: 1.5;
}
.pay-form-actions__hint i { color: #22c55e; }
.pay-form-submit {
    flex: 0 0 auto;
    min-width: 240px;
    padding: 13px 24px !important;
    font-weight: 700 !important;
    letter-spacing: 0.3px;
    box-shadow: 0 14px 32px -14px rgba(0, 210, 255, 0.65);
}
.pay-form-submit i { margin-right: 6px; }

/* === Pricing Toggle === */
.pricing-toggle-wrap {
    text-align: center;
    margin-bottom: 36px;
}

.pricing-toggle {
    display: inline-flex;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 50px;
    padding: 4px;
    gap: 4px;
}

.pricing-toggle .toggle-btn {
    padding: 10px 24px;
    border-radius: 50px;
    border: none;
    background: transparent;
    color: var(--text-muted);
    font-size: 0.9rem;
    font-weight: 500;
    cursor: pointer;
    transition: var(--transition);
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-family: inherit;
}

.pricing-toggle .toggle-btn:hover {
    color: var(--text-main);
}

.pricing-toggle .toggle-btn.active {
    background: var(--primary);
    color: #fff;
    box-shadow: 0 4px 15px rgba(var(--primary-rgb), 0.4);
}

.pricing-toggle-hint {
    margin-top: 12px;
    font-size: 0.85rem;
    color: var(--success);
    opacity: 0.8;
}

.price-amount {
    transition: opacity 0.2s ease;
}

.price-amount.switching {
    opacity: 0;
}

/* === Domain Page === */
.domain-search-box {
    max-width: 800px;
    margin: 0 auto;
    padding: 40px;
    text-align: center;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-xl);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
}

.domain-search-box h3 {
    margin-bottom: 20px;
    font-size: 1.2rem;
}

.domain-search-form {
    display: flex;
    gap: 10px;
    max-width: 640px;
    margin: 0 auto;
}

.domain-input-wrap {
    flex: 1;
    display: flex;
    align-items: center;
    background: rgba(12, 20, 40, 0.5);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 10px;
    padding-left: 14px;
    transition: border-color 0.3s;
}

.domain-input-wrap:focus-within {
    border-color: rgba(var(--primary-rgb), 0.4);
    box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.06);
}

.domain-prefix {
    color: var(--text-muted);
    font-size: 1rem;
    white-space: nowrap;
}

.domain-input-wrap input {
    flex: 1;
    background: transparent;
    border: none;
    padding: 14px 10px;
    color: var(--text-light);
    font-size: 1rem;
    outline: none;
    font-family: var(--font-body);
}

.domain-ext-select {
    background: rgba(12, 20, 40, 0.7);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 10px;
    padding: 0 16px;
    color: var(--text-light);
    font-size: 0.95rem;
    outline: none;
    cursor: pointer;
    transition: border-color 0.3s;
}

.domain-ext-select:focus {
    border-color: rgba(var(--primary-rgb), 0.4);
}

.domain-popular-tlds {
    display: flex;
    gap: 16px;
    justify-content: center;
    margin-top: 18px;
    flex-wrap: wrap;
}

.domain-popular-tlds span {
    font-size: 0.82rem;
    color: var(--text-muted);
    padding: 4px 12px;
    background: rgba(255, 255, 255, 0.03);
    border-radius: 20px;
    border: 1px solid rgba(255, 255, 255, 0.05);
}

.domain-popular-tlds strong {
    color: var(--primary);
}

/* ── Domain checker result card ─────────────────────────────────── */
.domain-result-card {
    max-width: 840px;
    margin: 0 auto;
    padding: 28px 32px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-xl);
    display: flex;
    gap: 22px;
    align-items: flex-start;
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    position: relative;
    overflow: hidden;
}
.domain-result-card::before {
    content: '';
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0.08;
    background: radial-gradient(circle at top right, var(--_accent, transparent), transparent 55%);
}
.domain-result-card .domain-result-icon {
    flex: 0 0 auto;
    width: 62px; height: 62px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.7rem;
    color: #fff;
    background: linear-gradient(135deg, var(--_accent, #64748b), rgba(100,116,139,0.5));
    box-shadow: 0 6px 22px -6px var(--_accent, rgba(100,116,139,0.5));
}
.domain-result-card .domain-result-body { flex: 1; min-width: 0; }
.domain-result-card .domain-result-name {
    font-family: var(--font-heading);
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--text-light);
    word-break: break-all;
    margin-bottom: 4px;
}
.domain-result-card .domain-result-punycode {
    display: block;
    font-size: 0.8rem;
    font-weight: 400;
    color: var(--text-muted);
    margin-top: 2px;
}
.domain-result-card .domain-result-punycode code {
    background: rgba(255,255,255,0.05);
    padding: 2px 8px;
    border-radius: 6px;
    font-size: 0.85em;
}
.domain-result-card h3 {
    margin: 6px 0 6px;
    font-size: 1.1rem;
    color: var(--_accent, var(--text-light));
}
.domain-result-card p {
    color: var(--text-muted);
    margin-bottom: 16px;
    line-height: 1.65;
}
.domain-result-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: center;
    margin-top: 4px;
}
.domain-result-price {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 14px;
    border-radius: 999px;
    background: rgba(34, 197, 94, 0.12);
    border: 1px solid rgba(34, 197, 94, 0.28);
    color: #34d399;
    font-size: 0.9rem;
    font-weight: 500;
}
.domain-result-price strong { color: #fff; font-weight: 700; }

.domain-result-available { --_accent: #22c55e; }
.domain-result-taken     { --_accent: #ef4444; }
.domain-result-error     { --_accent: #f59e0b; }
.domain-result-unknown   { --_accent: #60a5fa; }

/* Raw WHOIS collapsible */
.domain-whois-raw {
    max-width: 840px;
    margin: 22px auto 0;
    padding: 16px 20px;
    background: rgba(10, 14, 28, 0.55);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    font-size: 0.85rem;
}
.domain-whois-raw summary {
    cursor: pointer;
    color: var(--text-muted);
    font-weight: 500;
    user-select: none;
    outline: none;
}
.domain-whois-raw summary:hover { color: var(--text-light); }
.domain-whois-raw summary i { margin-right: 6px; color: var(--primary); }
.domain-whois-raw pre {
    margin: 14px 0 0;
    padding: 14px 16px;
    background: rgba(0,0,0,0.35);
    border-radius: var(--radius-sm);
    color: #cbd5e1;
    font-family: ui-monospace, Menlo, Consolas, monospace;
    font-size: 0.82rem;
    line-height: 1.55;
    max-height: 360px;
    overflow: auto;
    white-space: pre-wrap;
    word-break: break-all;
}

@media (max-width: 640px) {
    .domain-result-card {
        flex-direction: column;
        padding: 22px;
        gap: 14px;
    }
    .domain-result-card .domain-result-icon {
        width: 52px; height: 52px;
        font-size: 1.4rem;
    }
    .domain-result-card .domain-result-name { font-size: 1.25rem; }
}

/* Domain about */
.domain-about-box {
    max-width: 800px;
    margin: 0 auto;
    padding: 32px 36px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    line-height: 1.8;
    color: var(--text-muted);
}

.domain-about-box>p {
    margin-bottom: 24px;
}

.domain-parts {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

.domain-part {
    display: flex;
    gap: 14px;
    align-items: flex-start;
    padding: 18px;
    border-radius: var(--radius-md);
    background: rgba(255, 255, 255, 0.02);
    border: 1px solid rgba(255, 255, 255, 0.04);
}

.domain-part-num {
    width: 32px;
    height: 32px;
    flex-shrink: 0;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--primary), var(--secondary));
    color: #fff;
    font-size: 0.85rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
}

.domain-part h4 {
    font-size: 0.95rem;
    margin-bottom: 4px;
    color: var(--text-light);
}

.domain-part p {
    font-size: 0.85rem;
    color: var(--text-muted);
    line-height: 1.6;
    margin: 0;
}

/* Domain features */
.domain-features-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    max-width: 900px;
    margin: 0 auto;
}

.domain-feature-card {
    text-align: center;
    padding: 28px 20px;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    transition: var(--transition);
}

.domain-feature-card:hover {
    transform: translateY(-4px);
    border-color: rgba(var(--primary-rgb), 0.15);
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.2);
}

.domain-feature-icon {
    width: 52px;
    height: 52px;
    margin: 0 auto 14px;
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.3rem;
    color: var(--primary);
    background: rgba(var(--primary-rgb), 0.08);
    border: 1px solid rgba(var(--primary-rgb), 0.12);
    transition: var(--transition);
}

.domain-feature-card:hover .domain-feature-icon {
    background: linear-gradient(135deg, var(--primary), var(--secondary));
    color: #fff;
    border-color: transparent;
}

.domain-feature-card h4 {
    font-size: 0.95rem;
    margin-bottom: 8px;
}

.domain-feature-card p {
    font-size: 0.82rem;
    color: var(--text-muted);
    line-height: 1.6;
}

/* Domain pricing table */
.domain-table-wrap {
    max-width: 900px;
    margin: 0 auto;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    overflow: hidden;
}

.domain-table {
    width: 100%;
    border-collapse: collapse;
    text-align: center;
}

.domain-table thead tr {
    background: rgba(var(--primary-rgb), 0.04);
    border-bottom: 2px solid rgba(var(--primary-rgb), 0.1);
}

.domain-table th {
    padding: 14px 16px;
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--text-light);
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.domain-table .th-tld {
    text-align: left;
}

.domain-table td {
    padding: 12px 16px;
    font-size: 0.9rem;
    color: var(--text-muted);
    border-bottom: 1px solid rgba(255, 255, 255, 0.03);
}

.domain-table .td-tld {
    text-align: left;
}

.domain-table tbody tr {
    transition: background 0.2s;
}

.domain-table tbody tr:hover {
    background: rgba(var(--primary-rgb), 0.03);
}

.domain-table tbody tr:last-child td {
    border-bottom: none;
}

.tld-name {
    font-weight: 700;
    font-size: 1rem;
    color: var(--text-light);
    font-family: var(--font-heading);
}

.domain-row-popular {
    background: rgba(var(--primary-rgb), 0.03);
}

.domain-row-popular .tld-name {
    color: var(--primary);
}

.tld-badge {
    display: inline-block;
    font-size: 0.65rem;
    font-weight: 600;
    padding: 2px 8px;
    border-radius: 10px;
    margin-left: 6px;
    background: linear-gradient(135deg, var(--primary), var(--secondary));
    color: #fff;
    vertical-align: middle;
}

.tld-desc {
    display: block;
    font-size: 0.75rem;
    color: var(--text-muted);
    margin-top: 2px;
    font-weight: 400;
}

/* Domain note */
.domain-note {
    display: flex;
    gap: 14px;
    align-items: flex-start;
    max-width: 900px;
    margin: 24px auto 0;
    padding: 18px 24px;
    border-radius: var(--radius-md);
    background: rgba(255, 193, 7, 0.05);
    border: 1px solid rgba(255, 193, 7, 0.12);
}

.domain-note>i {
    color: #ffc107;
    font-size: 1.1rem;
    flex-shrink: 0;
    margin-top: 3px;
}

.domain-note p {
    font-size: 0.85rem;
    color: var(--text-muted);
    line-height: 1.7;
    margin: 0 0 4px;
}

.domain-note p:last-child {
    margin-bottom: 0;
}

/* .th document cards */
.th-docs-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
    max-width: 900px;
    margin: 0 auto;
}

.th-doc-card {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    overflow: hidden;
    transition: var(--transition);
}

.th-doc-card:hover {
    border-color: rgba(var(--primary-rgb), 0.15);
    box-shadow: 0 6px 24px rgba(0, 0, 0, 0.15);
}

.th-doc-header {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 20px;
    background: rgba(var(--primary-rgb), 0.04);
    border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}

.th-doc-tld {
    font-weight: 700;
    font-size: 1rem;
    color: var(--primary);
    font-family: var(--font-heading);
}

.th-doc-for {
    font-size: 0.8rem;
    color: var(--text-muted);
}

.th-doc-body {
    padding: 18px 20px;
}

.th-doc-body p {
    font-size: 0.85rem;
    color: var(--text-muted);
    line-height: 1.7;
    margin: 0;
}

.th-doc-links {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 12px;
}

.th-doc-links a {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 0.8rem;
    color: var(--primary);
    padding: 5px 12px;
    border-radius: 6px;
    background: rgba(var(--primary-rgb), 0.06);
    border: 1px solid rgba(var(--primary-rgb), 0.1);
    text-decoration: none;
    transition: var(--transition);
}

.th-doc-links a:hover {
    background: rgba(var(--primary-rgb), 0.12);
    border-color: rgba(var(--primary-rgb), 0.2);
}

.th-doc-highlight {
    margin-top: 12px;
    padding: 10px 14px;
    border-radius: 8px;
    font-size: 0.85rem;
    background: rgba(0, 230, 118, 0.06);
    border: 1px solid rgba(0, 230, 118, 0.12);
    color: var(--success);
}

.th-doc-highlight i {
    margin-right: 4px;
}

/* === Pricing === */
.pricing-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 24px;
    margin-top: 48px;
}

.pricing-card {
    background: var(--bg-card);
    backdrop-filter: blur(20px);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    padding: 36px 28px;
    text-align: center;
    transition: var(--transition);
    position: relative;
    display: flex;
    flex-direction: column;
}

.pricing-card::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at top, rgba(var(--primary-rgb), 0.03), transparent 60%);
    border-radius: var(--radius-lg);
    pointer-events: none;
}

.pricing-card:hover {
    transform: translateY(-8px);
    border-color: var(--border-glow);
    box-shadow: var(--shadow-card), 0 0 30px rgba(var(--primary-rgb), 0.1);
}

.pricing-card.popular {
    border-color: rgba(var(--secondary-rgb), 0.4);
    background: linear-gradient(180deg, rgba(12, 20, 40, 0.7), rgba(var(--secondary-rgb), 0.06));
}

.pricing-ribbon {
    position: absolute;
    top: 0;
    right: 28px;
    background: linear-gradient(135deg, var(--primary), var(--secondary));
    color: #fff;
    padding: 6px 16px;
    border-radius: 0 0 var(--radius-sm) var(--radius-sm);
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.5px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

.pricing-card h3 {
    font-size: 1.4rem;
    margin-bottom: 5px;
    position: relative;
    z-index: 1;
}

.pricing-price {
    font-size: 2.8rem;
    font-weight: 700;
    margin: 18px 0;
    font-family: var(--font-heading);
    display: flex;
    align-items: baseline;
    justify-content: center;
    gap: 5px;
    background: linear-gradient(135deg, var(--primary), var(--secondary));
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    position: relative;
    z-index: 1;
}

.pricing-price span {
    font-size: 0.95rem;
    color: var(--text-muted);
    font-weight: 400;
    -webkit-text-fill-color: var(--text-muted);
}

.pricing-features {
    margin: 28px 0;
    text-align: left;
    flex-grow: 1;
}

.pricing-features li {
    padding: 11px 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.04);
    color: var(--text-muted);
    font-size: 0.93rem;
    display: flex;
    align-items: center;
    gap: 10px;
}

.pricing-features li:last-child {
    border-bottom: none;
}

.pricing-features li i {
    color: var(--primary);
    font-size: 1rem;
}

.pricing-card .btn {
    width: 100%;
    position: relative;
    z-index: 1;
}

/* === Feature Detail Grid === */
.features-detail-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 32px;
    margin-top: 56px;
}

.feature-detail-card {
    display: flex;
    gap: 18px;
    padding: 24px;
    border-radius: var(--radius-md);
    border: 1px solid transparent;
    transition: var(--transition);
}

.feature-detail-card:hover {
    background: rgba(var(--primary-rgb), 0.03);
    border-color: var(--border-color);
}

.feature-detail-icon {
    width: 56px;
    height: 56px;
    flex-shrink: 0;
    background: linear-gradient(135deg, rgba(var(--primary-rgb), 0.1), rgba(var(--secondary-rgb), 0.06));
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.6rem;
    color: var(--primary);
    border: 1px solid rgba(var(--primary-rgb), 0.08);
    transition: var(--transition);
}

.feature-detail-card:hover .feature-detail-icon {
    background: linear-gradient(135deg, var(--primary), var(--secondary));
    color: #fff;
    border-color: transparent;
    box-shadow: 0 4px 16px rgba(var(--primary-rgb), 0.3);
}

.feature-detail-content h4 {
    font-size: 1.2rem;
    margin-bottom: 8px;
    color: var(--text-light);
}

.feature-detail-content p {
    color: var(--text-muted);
    font-size: 0.93rem;
    line-height: 1.7;
}

.feature-detail-content a {
    color: var(--primary);
}

.feature-detail-content a:hover {
    text-decoration: underline;
}

/* === Form Inputs (payment, domain, etc) === */
input[type="text"]:focus,
input[type="email"]:focus,
input[type="number"]:focus,
input[type="date"]:focus,
input[type="time"]:focus,
input[type="tel"]:focus,
input[type="password"]:focus,
input[type="url"]:focus,
textarea:focus,
select:focus {
    border-color: rgba(var(--primary-rgb), 0.4) !important;
    box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.08);
    outline: none;
}

input::placeholder,
textarea::placeholder {
    color: var(--text-muted);
    opacity: 0.6;
}

/* Date / Time picker icon brightness fix */
input[type="date"]::-webkit-calendar-picker-indicator,
input[type="time"]::-webkit-calendar-picker-indicator {
    filter: invert(0.7) brightness(1.5);
    cursor: pointer;
}

/* === Alert Boxes === */
.alert {
    border-radius: var(--radius-md) !important;
    padding: 16px 20px !important;
}

/* ============================================
   Responsive
   ============================================ */
@media (max-width: 1024px) {
    .hero-title {
        font-size: 3.4rem;
    }

    .hero-container {
        flex-direction: column;
        text-align: center;
    }

    .hero-content {
        max-width: 100%;
    }

    .hero-subtitle {
        margin-left: auto;
        margin-right: auto;
    }

    .hero-buttons {
        justify-content: center;
    }

    .hero-stats {
        justify-content: center;
    }

    .hero-visual {
        min-height: 340px;
        width: 100%;
        max-width: 420px;
        margin: 0 auto;
    }

    .hero-server-card {
        margin: 0 auto;
    }

    .float-card-1 {
        right: -10px;
    }

    .float-card-2 {
        left: -10px;
    }

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

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

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

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

    .container-features {
        flex-direction: column;
    }

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

    .features-content h2 {
        font-size: 2.3rem;
    }
}

/* เมนูข้อความแสดงจนถึง ~900px — กว้างกว่าเดิม (เดิม 1100px ซ่อนไว ทำให้เมนูหายบนจอแล็ปท็อป) */
@media (max-width: 1200px) {
    .nav-container {
        gap: 6px;
    }
    .nav-links {
        gap: 12px;
    }
    .nav-links a {
        font-size: 0.86rem;
        padding: 3px 0;
    }
    .nav-actions {
        gap: 8px;
        flex-shrink: 0;
    }
    .nav-actions .btn {
        font-size: 0.8rem;
        padding: 8px 10px;
    }
}

@media (max-width: 900px) {
    .nav-links {
        display: none;
    }

    .menu-toggle {
        display: flex;
        align-items: center;
        justify-content: center;
    }
}

@media (max-width: 900px) {
    .nav-actions .btn span {
        display: none;
    }

    .nav-actions .btn {
        padding: 8px 12px;
    }

    .nav-actions .btn i {
        margin-right: 0;
    }
}

@media (max-width: 768px) {
    .nav-actions .btn {
        display: none;
    }

    .nav-actions .language-switcher {
        margin-right: 4px !important;
    }

    .hero {
        min-height: auto;
        padding: 140px 0 80px;
    }

    .hero-title {
        font-size: 2.6rem;
    }

    .hero-subtitle {
        font-size: 1rem;
    }

    .hero-buttons {
        flex-direction: column;
        gap: 12px;
    }

    .hero-buttons .btn {
        width: 100%;
    }

    .hero-visual {
        min-height: 300px;
    }

    .hero-server-card {
        max-width: 320px;
    }

    .server-card-inner {
        padding: 20px;
    }

    .hero-float-card {
        display: none;
    }

    .hero-stats {
        gap: 24px;
    }

    .hero-stat-num {
        font-size: 1.5rem;
    }

    .services {
        padding: 70px 0;
    }

    .services-grid {
        grid-template-columns: 1fr;
        gap: 16px;
    }

    .section-header {
        margin-bottom: 40px;
    }

    .section-header h2 {
        font-size: 2rem;
    }

    .features {
        padding: 70px 0;
    }

    .features-content h2 {
        font-size: 2rem;
    }

    .internal-hero {
        padding: 130px 0 60px;
    }

    .internal-hero h1 {
        font-size: 2.2rem;
    }

    .page-section {
        padding: 60px 0;
    }

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

    .contact-card-wide {
        flex-direction: row;
    }

    .pay-banks-grid {
        grid-template-columns: 1fr;
    }

    .pay-other-grid {
        grid-template-columns: 1fr;
    }

    .pay-notify-grid {
        grid-template-columns: 1fr;
    }

    .pay-form-row {
        grid-template-columns: 1fr;
    }

    .pay-form-row-3 {
        grid-template-columns: 1fr;
    }

    .pay-form-wrap form { padding: 18px 16px 22px; }
    .pay-form-head { padding: 20px 18px; flex-wrap: wrap; gap: 12px; }
    .pay-form-head__badge { order: 99; }
    .pay-flash { margin: 14px 16px 0; }
    .pay-form-section { padding: 14px 14px 12px; }
    .pay-form-section__head { flex-wrap: wrap; }
    .pay-form-section__pills { margin-left: 0; width: 100%; }

    .pay-form-actions {
        flex-direction: column;
        align-items: stretch;
        gap: 12px;
    }
    .pay-form-submit { min-width: 0; width: 100%; justify-content: center; }
    .pay-form-actions__hint { justify-content: center; text-align: center; }

    .pay-dropzone { min-height: 160px; padding: 18px; }
    .pay-dropzone__preview { flex-direction: column; align-items: stretch; text-align: center; }
    .pay-dropzone__media { margin: 0 auto; width: 110px; height: 110px; }
    .pay-dropzone__clear { margin: 0 auto; }

    .domain-search-form {
        flex-direction: column;
    }

    .domain-search-box {
        padding: 28px 20px;
    }

    .domain-features-grid {
        grid-template-columns: 1fr 1fr;
    }

    .domain-parts {
        grid-template-columns: 1fr;
    }

    .domain-about-box {
        padding: 24px 20px;
    }

    .th-docs-grid {
        grid-template-columns: 1fr;
    }

    .domain-table th,
    .domain-table td {
        padding: 10px 12px;
        font-size: 0.82rem;
    }

    .tld-name {
        font-size: 0.9rem;
    }

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

    .features-detail-grid {
        grid-template-columns: 1fr;
    }

    /* ─── Footer (mobile redesign ≤768px) ──────────────────────────────
     * • Brand col: hero card อยู่บนสุด — center align + radial glow
     * • Link cols (services / domain / rules): จัดเป็น card style
     *   พร้อม chevron indicator หน้าลิงก์ ดูทันสมัยขึ้น
     * • Pay icons: ทำเป็น chip 44x44 มีกรอบโปร่ง
     * • Footer-bottom: center, padding ห่างขึ้น */
    .footer {
        padding: 56px 0 24px;
    }

    .footer-grid {
        grid-template-columns: 1fr;
        gap: 22px;
        margin-bottom: 32px;
    }

    /* Brand hero card */
    .brand-col {
        position: relative;
        text-align: center;
        padding: 30px 22px 26px;
        background: linear-gradient(180deg, rgba(var(--primary-rgb), 0.06), rgba(255, 255, 255, 0.01));
        border: 1px solid rgba(var(--primary-rgb), 0.14);
        border-radius: 20px;
        overflow: hidden;
        backdrop-filter: blur(6px);
        -webkit-backdrop-filter: blur(6px);
    }
    .brand-col::before {
        content: '';
        position: absolute;
        inset: 0;
        background:
            radial-gradient(circle at 50% 0%, rgba(var(--primary-rgb), 0.18), transparent 60%),
            radial-gradient(circle at 100% 100%, rgba(var(--secondary-rgb), 0.10), transparent 55%);
        pointer-events: none;
    }
    .brand-col > * {
        position: relative;
        z-index: 1;
    }

    .brand-col .logo {
        display: inline-flex;
        justify-content: center;
        margin-bottom: 14px;
    }
    .brand-col .logo img {
        height: 40px;
    }

    .brand-desc {
        margin: 0 auto 18px;
        max-width: 340px;
        text-align: center;
        font-size: 0.92rem;
        line-height: 1.65;
    }

    .footer-social {
        justify-content: center;
        gap: 12px;
        margin: 18px 0 6px;
    }
    .footer-social a {
        width: 44px;
        height: 44px;
        border-radius: 13px;
        font-size: 1.05rem;
        background: rgba(255, 255, 255, 0.05);
        border: 1px solid rgba(255, 255, 255, 0.08);
    }
    .footer-social a:hover {
        transform: translateY(-3px);
    }

    .payment-methods {
        margin-top: 20px;
        padding-top: 18px;
        border-top: 1px dashed rgba(255, 255, 255, 0.07);
    }
    .payment-methods span {
        text-align: center;
        margin-bottom: 12px;
        font-size: 0.82rem;
        letter-spacing: 0.3px;
        text-transform: uppercase;
        opacity: 0.75;
    }
    .pay-icons {
        justify-content: center;
        gap: 12px;
        font-size: 1.1rem;
    }
    .pay-icons i {
        width: 46px;
        height: 46px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        background: rgba(255, 255, 255, 0.04);
        border: 1px solid rgba(255, 255, 255, 0.06);
        border-radius: 12px;
        color: var(--text-muted);
    }
    .pay-icons i:hover {
        background: rgba(var(--primary-rgb), 0.1);
        border-color: rgba(var(--primary-rgb), 0.22);
        color: var(--primary);
        transform: translateY(-2px);
    }

    /* Link columns — subtle card */
    .footer-col:not(.brand-col) {
        background: rgba(255, 255, 255, 0.025);
        border: 1px solid rgba(255, 255, 255, 0.05);
        border-radius: 16px;
        padding: 22px 22px 18px;
    }

    .footer-col:not(.brand-col) h4 {
        font-size: 1rem;
        margin-bottom: 16px;
        padding-bottom: 12px;
        display: flex;
        align-items: center;
        gap: 8px;
    }
    .footer-col:not(.brand-col) h4::after {
        width: 36px;
        height: 2px;
    }

    .footer-col:not(.brand-col) ul {
        display: flex;
        flex-direction: column;
        gap: 2px;
    }
    .footer-col:not(.brand-col) ul li {
        margin-bottom: 0;
    }
    .footer-col:not(.brand-col) ul li a {
        display: flex;
        align-items: center;
        gap: 10px;
        padding: 9px 10px;
        margin: 0 -10px;
        border-radius: 10px;
        font-size: 0.93rem;
        position: relative;
        transition: var(--transition);
    }
    .footer-col:not(.brand-col) ul li a::before {
        content: '\f105'; /* chevron-right */
        font-family: 'Font Awesome 6 Free', 'Font Awesome 5 Free', 'FontAwesome';
        font-weight: 900;
        font-size: 0.78rem;
        color: var(--primary);
        width: 16px;
        text-align: center;
        opacity: 0.55;
        transition: var(--transition);
    }
    .footer-col:not(.brand-col) ul li a:hover {
        transform: none;
        color: var(--text-light);
        background: rgba(var(--primary-rgb), 0.06);
    }
    .footer-col:not(.brand-col) ul li a:hover::before {
        opacity: 1;
        transform: translateX(2px);
    }

    .footer-bottom {
        flex-direction: column;
        gap: 6px;
        text-align: center;
        padding-top: 22px;
        font-size: 0.82rem;
    }
}

/* ─── Footer (small phone ≤480px) — ปรับ pacing ให้กระชับ ────────── */
@media (max-width: 480px) {
    .footer {
        padding: 44px 0 22px;
    }
    .footer-grid {
        gap: 18px;
        margin-bottom: 26px;
    }
    .brand-col {
        padding: 26px 20px 22px;
        border-radius: 18px;
    }
    .brand-col .logo img {
        height: 36px;
    }
    .brand-desc {
        font-size: 0.88rem;
    }
    .footer-social a {
        width: 42px;
        height: 42px;
        border-radius: 12px;
        font-size: 1rem;
    }
    .pay-icons i {
        width: 42px;
        height: 42px;
        border-radius: 11px;
        font-size: 1rem;
    }
    .footer-col:not(.brand-col) {
        padding: 20px 18px 16px;
        border-radius: 14px;
    }
    .footer-col:not(.brand-col) h4 {
        font-size: 0.95rem;
        margin-bottom: 14px;
    }
    .footer-col:not(.brand-col) ul li a {
        font-size: 0.9rem;
        padding: 8px 10px;
    }
}

@media (max-width: 480px) {
    .hero-title {
        font-size: 2rem;
    }

    .hero-visual {
        display: none;
    }

    .hero-stats {
        flex-wrap: wrap;
        gap: 20px;
    }

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

    .contact-card-wide {
        flex-direction: column;
        text-align: center;
        padding: 28px 20px;
    }

    .internal-hero h1 {
        font-size: 1.8rem;
    }

    .section-header h2 {
        font-size: 1.7rem;
    }

    .glass-card {
        padding: 28px 20px;
    }

    .pricing-card {
        padding: 28px 20px;
    }

    .domain-features-grid {
        grid-template-columns: 1fr;
    }

    .domain-popular-tlds {
        gap: 8px;
    }

    .domain-popular-tlds span {
        font-size: 0.75rem;
        padding: 3px 8px;
    }

    .domain-table-wrap {
        overflow-x: auto;
    }

    .domain-table {
        min-width: 500px;
    }
}

/* ============================================
   Auth & Member System
   ============================================ */

/* Centered wrapper */
.auth-wrap {
    max-width: 780px;
    margin: 0 auto;
}

.auth-wrap-sm {
    max-width: 520px;
}

/* Alert banners */
.auth-alert {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 14px 18px;
    border-radius: var(--radius-md);
    font-size: 0.92rem;
    margin-bottom: 20px;
    font-family: var(--font-heading);
}

.auth-alert-error {
    background: rgba(255, 61, 113, 0.08);
    border: 1px solid rgba(255, 61, 113, 0.22);
    color: #ff6b93;
}

.auth-alert-success {
    background: rgba(0, 230, 118, 0.08);
    border: 1px solid rgba(0, 230, 118, 0.22);
    color: #00e676;
}

/* Auth card */
.auth-card {
    background: var(--bg-card);
    backdrop-filter: blur(22px);
    -webkit-backdrop-filter: blur(22px);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-xl);
    padding: 40px;
    position: relative;
    overflow: hidden;
}

.auth-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--primary), var(--secondary), transparent);
}

.auth-card-header {
    text-align: center;
    margin-bottom: 32px;
}

.auth-card-icon {
    width: 64px;
    height: 64px;
    margin: 0 auto 18px;
    background: linear-gradient(135deg, rgba(var(--primary-rgb), 0.12), rgba(var(--secondary-rgb), 0.08));
    border: 1px solid rgba(var(--primary-rgb), 0.15);
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.6rem;
    color: var(--primary);
}

.auth-card-header h2 {
    font-size: 1.7rem;
    margin-bottom: 8px;
}

.auth-card-header p {
    color: var(--text-muted);
    font-size: 0.93rem;
}

/* Form */
.auth-form {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.auth-form-group {
    margin-bottom: 18px;
}

.auth-form-group label {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 6px;
    margin-bottom: 8px;
    font-size: 0.88rem;
    color: var(--text-light);
    font-weight: 500;
    font-family: var(--font-heading);
}

.auth-form-group label .req {
    margin-left: auto;
}

.auth-form-group label i {
    color: var(--primary);
    font-size: 0.8rem;
    flex-shrink: 0;
}

.auth-form-group input[type="text"],
.auth-form-group input[type="email"],
.auth-form-group input[type="password"],
.auth-form-group input[type="tel"] {
    width: 100%;
    padding: 12px 14px;
    background: rgba(12, 20, 40, 0.55);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: var(--radius-sm);
    color: var(--text-light);
    font-size: 0.93rem;
    font-family: var(--font-body);
    outline: none;
    transition: border-color 0.3s, box-shadow 0.3s;
}

.auth-form-group input:focus {
    border-color: rgba(var(--primary-rgb), 0.45);
    box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.07);
}

.auth-form-group input:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.auth-hint {
    display: block;
    font-size: 0.77rem;
    color: var(--text-muted);
    margin-top: 5px;
}

/* Two-column form row */
.auth-form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

/* Password input with eye toggle */
.auth-input-wrap {
    position: relative;
    display: flex;
    align-items: center;
}

.auth-input-wrap input {
    position: relative;
    z-index: 0;
    flex: 1;
    padding-right: 44px !important;
}

.auth-eye-btn {
    position: absolute;
    z-index: 1;
    right: 12px;
    background: none;
    border: none;
    color: var(--text-muted);
    cursor: pointer;
    font-size: 0.9rem;
    padding: 4px;
    transition: color 0.2s;
}

.auth-eye-btn:hover {
    color: var(--primary);
}

/* ── Generate password button (in label) ── */
.auth-form-group label .auth-generate-btn {
    margin-left: auto;
}

.auth-generate-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: transparent;
    border: 1px solid rgba(255, 255, 255, 0.1);
    color: var(--text-muted);
    font-size: 0.78rem;
    font-weight: 500;
    padding: 4px 11px;
    border-radius: 999px;
    cursor: pointer;
    transition: all 0.25s ease;
    font-family: inherit;
    line-height: 1;
    letter-spacing: 0.2px;
}

.auth-generate-btn i {
    font-size: 0.72rem;
    color: var(--primary);
    transition: transform 0.35s ease, color 0.25s ease;
}

.auth-generate-btn:hover {
    background: rgba(0, 210, 255, 0.08);
    border-color: rgba(0, 210, 255, 0.35);
    color: var(--text-light);
}

.auth-generate-btn:hover i {
    transform: rotate(-18deg) scale(1.1);
    color: var(--primary);
}

.auth-generate-btn.is-pulsing i {
    animation: authWandSpin 0.55s ease;
}

@keyframes authWandSpin {
    0%   { transform: rotate(0) scale(1); }
    40%  { transform: rotate(-25deg) scale(1.2); }
    70%  { transform: rotate(15deg)  scale(1.15); }
    100% { transform: rotate(0) scale(1); }
}

/* ── Input wrap with multiple action icons (copy + eye) ── */
.auth-input-wrap-actions input {
    padding-right: 82px !important;
}

.auth-input-wrap-actions .auth-action-btn {
    position: absolute;
    background: none;
    border: none;
    color: var(--text-muted);
    cursor: pointer;
    font-size: 0.95rem;
    padding: 6px;
    width: 30px;
    height: 30px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    transition: color 0.2s ease, background 0.2s ease, transform 0.2s ease;
}

.auth-input-wrap-actions .auth-action-btn:hover {
    color: var(--primary);
    background: rgba(0, 210, 255, 0.08);
}

.auth-input-wrap-actions .auth-eye-btn {
    right: 8px;
}

.auth-input-wrap-actions #copyPwBtn {
    right: 44px;
}

.auth-input-wrap-actions #copyPwBtn.copied {
    color: #00e676;
    background: rgba(0, 230, 118, 0.12);
    transform: scale(1.08);
}

/* ── Subtle hint text shown after generation ── */
.auth-generated-hint {
    display: flex;
    align-items: center;
    gap: 7px;
    margin-top: 8px;
    font-size: 0.78rem;
    color: rgba(0, 230, 118, 0.9);
    letter-spacing: 0.1px;
    animation: authHintFadeIn 0.35s ease;
}

.auth-generated-hint i {
    font-size: 0.85rem;
    color: #00e676;
}

@keyframes authHintFadeIn {
    from { opacity: 0; transform: translateY(-3px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* Forgot link inside label */
.auth-forgot-link {
    font-size: 0.82rem;
    color: var(--primary);
    font-weight: 400;
    margin-left: auto;
}

.auth-forgot-link:hover {
    text-decoration: underline;
}

/* Required star */
.req {
    color: var(--accent);
    font-weight: 700;
}

/* Password strength */
.auth-password-strength {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 16px;
}

.auth-strength-bar {
    flex: 1;
    height: 5px;
    background: rgba(255, 255, 255, 0.06);
    border-radius: 3px;
    overflow: hidden;
}

.auth-strength-fill {
    height: 100%;
    border-radius: 3px;
    transition: width 0.4s ease, background 0.4s;
    width: 0%;
}

.auth-strength-label {
    font-size: 0.78rem;
    font-weight: 600;
    min-width: 70px;
    text-align: right;
    font-family: var(--font-heading);
}

/* Terms checkbox */
.auth-terms {
    margin-bottom: 20px;
}

.auth-checkbox-label {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    cursor: pointer;
    font-size: 0.88rem;
    color: var(--text-muted);
    line-height: 1.5;
    user-select: none;
}

.auth-checkbox-label input[type="checkbox"] {
    display: none;
}

.auth-checkbox-box {
    flex-shrink: 0;
    width: 18px;
    height: 18px;
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: 4px;
    margin-top: 2px;
    background: rgba(12, 20, 40, 0.5);
    transition: all 0.2s;
    position: relative;
}

.auth-checkbox-label input:checked + .auth-checkbox-box {
    background: var(--primary);
    border-color: var(--primary);
}

.auth-checkbox-label input:checked + .auth-checkbox-box::after {
    content: '\f00c';
    font-family: 'Font Awesome 6 Free';
    font-weight: 900;
    font-size: 0.65rem;
    color: #fff;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.auth-checkbox-label a {
    color: var(--primary);
}

/* Submit button */
.btn-auth-submit {
    width: 100%;
    padding: 14px;
    font-size: 1rem;
    margin-top: 4px;
}

/* Divider */
.auth-divider {
    display: flex;
    align-items: center;
    gap: 14px;
    margin: 22px 0;
    color: var(--text-muted);
    font-size: 0.82rem;
}

.auth-divider::before,
.auth-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--border-color);
}

/* Switch link */
.auth-switch {
    text-align: center;
    font-size: 0.9rem;
    color: var(--text-muted);
}

.auth-switch a {
    color: var(--primary);
    font-weight: 600;
}

.auth-switch a:hover {
    text-decoration: underline;
}

/* Success icon (forgot/reset done state) */
.auth-success-icon {
    width: 80px;
    height: 80px;
    margin: 0 auto 24px;
    background: rgba(0, 230, 118, 0.1);
    border: 1px solid rgba(0, 230, 118, 0.2);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2rem;
    color: var(--success);
}

/* ============================================
   Dashboard
   ============================================ */

.dashboard-hero {
    padding-top: 130px;
    padding-bottom: 30px;
    text-align: left;
}

/* Profile card frame for dashboard hero (desktop) — stack:
 *   1) avatar + greeting (row)
 *   2) stats strip (full width, 4-col grid)
 * เลี่ยงปัญหา stats บีบและตัวอักษรตกหล่นเมื่อวาง side-by-side
 */
.dashboard-user-header {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 18px;
    padding: 24px 28px;
    background:
        radial-gradient(ellipse 360px 220px at 0% 0%, rgba(var(--primary-rgb), 0.18), transparent 70%),
        radial-gradient(ellipse 320px 220px at 100% 100%, rgba(var(--secondary-rgb), 0.16), transparent 70%),
        linear-gradient(135deg, rgba(99, 102, 241, 0.06) 0%, rgba(12, 18, 36, 0.55) 60%, rgba(12, 18, 36, 0.55) 100%);
    border: 1px solid rgba(var(--primary-rgb), 0.2);
    border-radius: 22px;
    box-shadow:
        0 22px 60px -28px rgba(0, 0, 0, 0.7),
        inset 0 0 0 1px rgba(255, 255, 255, 0.03);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    position: relative;
    overflow: hidden;
}

.dashboard-user-header::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(circle 200px at 50% -50px, rgba(var(--primary-rgb), 0.18), transparent 70%);
    pointer-events: none;
    z-index: 0;
}

.dashboard-user-header > * {
    position: relative;
    z-index: 1;
}

/* Top row: avatar + greeting block (always row layout on desktop) */
.dashboard-user-main {
    display: flex;
    align-items: center;
    gap: 22px;
    width: 100%;
    min-width: 0;
}

.dashboard-avatar {
    width: 88px;
    height: 88px;
    flex-shrink: 0;
    background: linear-gradient(135deg, var(--primary), var(--secondary));
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.1rem;
    font-weight: 800;
    color: #fff;
    font-family: var(--font-heading);
    border: 3px solid rgba(255, 255, 255, 0.06);
    box-shadow:
        0 0 0 4px rgba(var(--primary-rgb), 0.22),
        0 16px 38px -10px rgba(var(--primary-rgb), 0.55);
    overflow: hidden;
}
.dashboard-avatar--image {
    background: #1a1f2e;
    border: 2px solid rgba(255, 255, 255, 0.1);
    padding: 0;
}
.dashboard-avatar--image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    border-radius: 50%;
}

/* Profile: avatar upload */
.profile-avatar-card__title {
    font-size: 1.05rem;
    color: var(--text-light);
    margin: 0 0 4px;
    font-weight: 600;
}
.profile-avatar-row {
    display: flex;
    flex-wrap: wrap;
    gap: 24px;
    align-items: flex-start;
}
.profile-avatar-preview {
    width: 96px;
    height: 96px;
    border-radius: 50%;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--primary), var(--secondary));
    color: #fff;
    font-size: 2.2rem;
    font-weight: 800;
    font-family: var(--font-heading);
    box-shadow: 0 0 24px rgba(var(--primary-rgb), 0.25);
    overflow: hidden;
    border: 2px solid rgba(255, 255, 255, 0.1);
}
.profile-avatar-preview--image { background: #1a1f2e; padding: 0; }
.profile-avatar-preview img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.profile-avatar-side { flex: 1; min-width: 220px; }
.profile-avatar-dropzone {
    position: relative;
    isolation: isolate;
    border: 2px dashed var(--border-color);
    border-radius: var(--radius-md);
    padding: 20px 16px;
    text-align: center;
    color: var(--text-muted);
    font-size: 0.88rem;
    cursor: pointer;
    background: var(--bg-card);
    transition: var(--transition);
}
.profile-avatar-dropzone:hover,
.profile-avatar-dropzone.is-dragover {
    border-color: rgba(var(--primary-rgb), 0.45);
    background: rgba(var(--primary-rgb), 0.06);
    color: var(--text-light);
}
.profile-avatar-dropzone i {
    display: block;
    font-size: 1.5rem;
    margin-bottom: 8px;
    color: var(--primary);
}
.profile-avatar-dropzone input[type="file"] {
    position: absolute;
    inset: 0;
    z-index: 2;
    opacity: 0;
    cursor: pointer;
    width: 100%;
    height: 100%;
    font-size: 0;
}

.dashboard-user-info {
    flex: 1;
    min-width: 0;
    text-align: left;
}

.dashboard-user-info h1 {
    font-size: 1.9rem;
    line-height: 1.25;
    margin-bottom: 12px;
    letter-spacing: -0.01em;
}

.dashboard-user-info p {
    color: var(--text-muted);
    font-size: 0.86rem;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px 10px;
    margin: 0;
}
.dashboard-user-info .dash-user-handle,
.dashboard-user-info .dash-user-since {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 5px 12px;
    background: rgba(255, 255, 255, 0.045);
    border: 1px solid rgba(255, 255, 255, 0.07);
    border-radius: 999px;
    color: inherit;
    font-size: 0.78rem;
    line-height: 1.2;
}
.dashboard-user-info .dash-user-handle {
    color: rgba(165, 180, 252, 0.95);
    background: rgba(var(--primary-rgb), 0.1);
    border-color: rgba(var(--primary-rgb), 0.22);
}
.dashboard-user-info .dash-user-handle i,
.dashboard-user-info .dash-user-since i {
    font-size: 0.74rem;
    opacity: 0.9;
}
.dashboard-user-info .dash-user-handle i {
    color: var(--primary);
    opacity: 1;
}
.dashboard-user-info .dash-user-since i {
    color: rgba(165, 180, 252, 0.85);
}
.dashboard-user-info .dash-user-sep {
    display: none;
}
.dashboard-user-info .dash-user-date {
    color: var(--text-light);
    font-weight: 600;
}

/* ─── Quick Stats strip (full-width row below avatar/greeting) ─── */
.dashboard-user-stats {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
    width: 100%;
    min-width: 0;
    padding-top: 16px;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
}

.dashboard-user-stat {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 13px 14px;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.07);
    border-radius: 14px;
    color: var(--text-muted);
    text-decoration: none;
    transition:
        transform 0.18s ease,
        border-color 0.18s ease,
        background 0.18s ease,
        box-shadow 0.22s ease;
    min-width: 0;
    overflow: hidden;
}
.dashboard-user-stat:hover {
    transform: translateY(-2px);
    background: rgba(255, 255, 255, 0.05);
    border-color: rgba(var(--primary-rgb), 0.3);
    box-shadow: 0 12px 28px -14px rgba(0, 0, 0, 0.6);
}

.dashboard-user-stat__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    flex-shrink: 0;
    border-radius: 12px;
    background: rgba(var(--primary-rgb), 0.12);
    border: 1px solid rgba(var(--primary-rgb), 0.24);
    color: var(--primary);
    font-size: 1.05rem;
    transition: transform 0.2s ease, background 0.2s ease, border-color 0.2s ease;
}
.dashboard-user-stat:hover .dashboard-user-stat__icon {
    transform: scale(1.06);
}
.dashboard-user-stat__body {
    display: flex;
    flex-direction: column;
    gap: 3px;
    min-width: 0;
    flex: 1 1 auto;
    line-height: 1.2;
}
.dashboard-user-stat__label {
    font-size: 0.7rem;
    font-weight: 700;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-family: var(--font-heading);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
}
.dashboard-user-stat__value {
    display: inline-flex;
    align-items: baseline;
    gap: 6px;
    font-size: 1.25rem;
    font-weight: 800;
    color: var(--text-light);
    font-family: var(--font-heading);
    letter-spacing: -0.01em;
    line-height: 1.2;
    min-width: 0;
    max-width: 100%;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.dashboard-user-stat__unit {
    font-size: 0.72rem;
    font-weight: 500;
    color: var(--text-muted);
    letter-spacing: 0;
    text-transform: none;
    font-family: var(--font-heading);
    line-height: 1.2;
    flex-shrink: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Variant — Credit (green) */
.dashboard-user-stat--credit .dashboard-user-stat__icon {
    background: rgba(34, 197, 94, 0.14);
    border-color: rgba(34, 197, 94, 0.32);
    color: #22c55e;
}
.dashboard-user-stat--credit .dashboard-user-stat__value {
    color: #4ade80;
}
.dashboard-user-stat--credit:hover {
    border-color: rgba(34, 197, 94, 0.34);
    box-shadow: 0 12px 28px -14px rgba(34, 197, 94, 0.4);
}
/* Variant — Orders (purple/primary) — keep defaults */
/* Variant — Invoices (amber) */
.dashboard-user-stat--invoices .dashboard-user-stat__icon {
    background: rgba(245, 158, 11, 0.12);
    border-color: rgba(245, 158, 11, 0.3);
    color: #f59e0b;
}
.dashboard-user-stat--invoices:hover {
    border-color: rgba(245, 158, 11, 0.32);
    box-shadow: 0 12px 28px -14px rgba(245, 158, 11, 0.4);
}
/* Variant — Tickets (blue/info) */
.dashboard-user-stat--tickets .dashboard-user-stat__icon {
    background: rgba(56, 189, 248, 0.12);
    border-color: rgba(56, 189, 248, 0.3);
    color: #38bdf8;
}
.dashboard-user-stat--tickets:hover {
    border-color: rgba(56, 189, 248, 0.32);
    box-shadow: 0 12px 28px -14px rgba(56, 189, 248, 0.4);
}

/* When count > 0 → red highlight on value */
.dashboard-user-stat.is-alert .dashboard-user-stat__value {
    color: #f87171;
}
.dashboard-user-stat.is-alert .dashboard-user-stat__icon {
    background: rgba(239, 68, 68, 0.14);
    border-color: rgba(239, 68, 68, 0.34);
    color: #f87171;
    box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.06);
}
.dashboard-user-stat.is-alert:hover {
    border-color: rgba(239, 68, 68, 0.36);
    box-shadow: 0 12px 28px -14px rgba(239, 68, 68, 0.4);
}

.dashboard-logout-btn {
    margin-left: auto;
}

/* Layout */
.dashboard-layout {
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: 28px;
    align-items: start;
    scroll-behavior: smooth;
}

/* Scroll target: offset above content เพื่อชดเชย navbar fixed (~70-80px)
 * ใช้ตอน scroll ผ่าน hash #dashboard-content หลังคลิก nav item ใน sidebar
 * และ #auth-form หลังคลิก "เข้าสู่ระบบ / สมัครสมาชิก" บน navbar */
#dashboard-content,
#auth-form {
    scroll-margin-top: 90px;
}
@media (max-width: 768px) {
    #dashboard-content,
    #auth-form {
        scroll-margin-top: 76px;
    }
}

/* Sidebar */
.dashboard-sidebar {
    position: sticky;
    top: 100px;
}

.dashboard-nav {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    padding: 12px;
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
}

.dashboard-nav-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 11px 14px;
    border-radius: var(--radius-sm);
    color: var(--text-muted);
    font-size: 0.9rem;
    font-weight: 500;
    font-family: var(--font-heading);
    transition: var(--transition);
}

.dashboard-nav-item i {
    width: 18px;
    text-align: center;
    font-size: 0.85rem;
}

.dashboard-nav-item:hover {
    color: var(--text-light);
    background: rgba(255, 255, 255, 0.05);
}

.dashboard-nav-item.active {
    color: var(--primary);
    background: rgba(var(--primary-rgb), 0.08);
    border: 1px solid rgba(var(--primary-rgb), 0.12);
}

.dashboard-nav-logout {
    color: rgba(255, 61, 113, 0.7);
}

.dashboard-nav-logout:hover {
    color: var(--accent);
    background: rgba(255, 61, 113, 0.06);
}

.dashboard-nav-divider {
    height: 1px;
    background: var(--border-color);
    margin: 8px 0;
}

/* Main section */
.dashboard-section {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-xl);
    padding: 36px;
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
}

.dashboard-section-title {
    font-size: 1.3rem;
    margin-bottom: 28px;
    display: flex;
    align-items: center;
    gap: 10px;
    padding-bottom: 18px;
    border-bottom: 1px solid var(--border-color);
}

.dashboard-section-title i {
    color: var(--primary);
}

.dashboard-sub-title {
    font-size: 1rem;
    color: var(--text-light);
    margin: 28px 0 16px;
}

/* Account credit (overview) */
.dashboard-credit-balance {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    padding: 20px 22px;
    margin-bottom: 20px;
    background: linear-gradient(135deg, rgba(34, 197, 94, 0.12) 0%, rgba(0, 210, 255, 0.08) 45%, rgba(12, 20, 40, 0.55) 100%);
    border: 1px solid rgba(34, 197, 94, 0.3);
    border-radius: var(--radius-md);
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.2);
}
.dashboard-credit-balance__main {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    min-width: 0;
    flex: 1 1 240px;
}
.dashboard-credit-balance__icon {
    width: 52px;
    height: 52px;
    flex-shrink: 0;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.35rem;
    color: #4ade80;
    background: rgba(34, 197, 94, 0.18);
    border: 1px solid rgba(34, 197, 94, 0.35);
}
.dashboard-credit-balance__eyebrow {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.6px;
    color: var(--text-muted);
    margin: 0 0 6px;
    font-family: var(--font-heading);
}
.dashboard-credit-balance__amount {
    font-size: clamp(1.5rem, 4vw, 1.9rem);
    font-weight: 800;
    color: #86efac;
    margin: 0 0 8px;
    font-variant-numeric: tabular-nums;
    letter-spacing: 0.02em;
    line-height: 1.2;
    text-shadow: 0 0 32px rgba(34, 197, 94, 0.25);
}
.dashboard-credit-balance__hint {
    font-size: 0.8rem;
    color: var(--text-muted);
    margin: 0;
    line-height: 1.45;
    max-width: 42ch;
}
.dashboard-credit-balance__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    flex-shrink: 0;
    align-items: center;
    justify-content: flex-end;
}
.dashboard-credit-balance__btn {
    font-size: 0.84rem;
    padding: 8px 14px;
    white-space: nowrap;
}

/* Stats grid */
.dashboard-stats-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
}

.dashboard-stat-card {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 18px 20px;
    background: rgba(12, 20, 40, 0.4);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    transition: var(--transition);
}

.dashboard-stat-card:hover {
    border-color: rgba(var(--primary-rgb), 0.15);
}

.dashboard-stat-icon {
    width: 44px;
    height: 44px;
    flex-shrink: 0;
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
}

.dashboard-stat-label {
    font-size: 0.78rem;
    color: var(--text-muted);
    margin-bottom: 4px;
    font-family: var(--font-heading);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.dashboard-stat-value {
    font-size: 0.95rem;
    color: var(--text-light);
    font-weight: 600;
    word-break: break-all;
}

/* Quick link cards */
.dashboard-quick-links {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
}

.dashboard-quick-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 18px 12px;
    background: rgba(12, 20, 40, 0.4);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    color: var(--text-muted);
    font-size: 0.82rem;
    font-weight: 500;
    font-family: var(--font-heading);
    text-align: center;
    transition: var(--transition);
}

.dashboard-quick-card i {
    font-size: 1.3rem;
    color: var(--primary);
    transition: var(--transition);
}

.dashboard-quick-card:hover {
    color: var(--text-light);
    border-color: rgba(var(--primary-rgb), 0.2);
    background: rgba(var(--primary-rgb), 0.05);
    transform: translateY(-3px);
}

.dashboard-quick-card:hover i {
    transform: scale(1.15);
}

/* Profile/security form card */
.dashboard-form-card {
    background: rgba(12, 20, 40, 0.35);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    padding: 28px;
}

/* ── Auth Responsive ── */
@media (max-width: 768px) {
    .auth-form-row {
        grid-template-columns: 1fr;
    }

    .auth-card {
        padding: 28px 20px;
    }

    /* ─── Dashboard layout: single column on mobile ─── */
    .dashboard-layout {
        grid-template-columns: 1fr;
        gap: 18px;
    }

    .dashboard-sidebar {
        position: static;
    }

    /* ─── Dashboard hero: centered profile card ─── */
    .dashboard-hero {
        padding-top: 100px;
        padding-bottom: 28px;
    }

    .dashboard-user-header {
        flex-direction: column;
        align-items: stretch;
        text-align: center;
        gap: 18px;
        padding: 26px 22px 24px;
    }
    .dashboard-user-header::before {
        background: radial-gradient(ellipse 220px 160px at 50% 0%, rgba(var(--primary-rgb), 0.22), transparent 70%);
    }
    .dashboard-user-header::after {
        content: '';
        position: absolute;
        top: -50px;
        right: -40px;
        width: 180px;
        height: 180px;
        background: radial-gradient(circle, rgba(var(--secondary-rgb), 0.18), transparent 70%);
        pointer-events: none;
        z-index: 0;
    }

    .dashboard-user-main {
        flex-direction: column;
        align-items: center;
        text-align: center;
        gap: 16px;
        flex: 0 0 auto;
        width: 100%;
    }

    .dashboard-avatar {
        width: 84px;
        height: 84px;
        font-size: 2rem;
    }

    .dashboard-user-info {
        width: 100%;
        text-align: center;
    }

    .dashboard-user-info h1 {
        font-size: 1.5rem;
        line-height: 1.32;
        margin: 0 0 12px;
        letter-spacing: -0.01em;
    }

    /* Quick stats strip — mobile uses vertical card (icon top + label + value) */
    .dashboard-user-stats {
        grid-template-columns: repeat(4, minmax(0, 1fr));
        gap: 8px;
        padding-top: 14px;
    }
    .dashboard-user-stat {
        flex-direction: column;
        align-items: center;
        text-align: center;
        gap: 7px;
        padding: 12px 8px;
        border-radius: 12px;
    }
    .dashboard-user-stat__icon {
        width: 34px;
        height: 34px;
        font-size: 0.92rem;
        border-radius: 10px;
    }
    .dashboard-user-stat__body {
        align-items: center;
        gap: 1px;
    }
    .dashboard-user-stat__label {
        font-size: 0.66rem;
    }
    .dashboard-user-stat__value {
        font-size: 0.98rem;
        flex-direction: column;
        align-items: center;
        gap: 0;
        white-space: normal;
    }
    .dashboard-user-stat__unit {
        font-size: 0.62rem;
    }

    .dashboard-user-info p {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        align-items: center;
        gap: 6px 8px;
        margin: 0;
        padding: 0;
        background: transparent;
        border: 0;
        font-size: 0.78rem;
        color: var(--text-muted);
    }
    .dashboard-user-info p .dash-user-sep {
        display: none;
    }
    .dashboard-user-info .dash-user-handle,
    .dashboard-user-info .dash-user-since {
        display: inline-flex;
        align-items: center;
        gap: 6px;
        padding: 5px 11px;
        background: rgba(255, 255, 255, 0.045);
        border: 1px solid rgba(255, 255, 255, 0.07);
        border-radius: 999px;
        font-size: 0.76rem;
        color: var(--text-muted);
        line-height: 1.2;
    }
    .dashboard-user-info .dash-user-handle {
        color: rgba(165, 180, 252, 0.95);
        background: rgba(var(--primary-rgb), 0.08);
        border-color: rgba(var(--primary-rgb), 0.18);
    }
    .dashboard-user-info .dash-user-handle i,
    .dashboard-user-info .dash-user-since i {
        font-size: 0.72rem;
        opacity: 0.85;
    }
    .dashboard-user-info .dash-user-handle i {
        color: var(--primary);
        opacity: 1;
    }
    .dashboard-user-info .dash-user-date {
        color: var(--text-light);
        font-weight: 600;
    }
    /* Prevent mobile browser auto-link styling for embedded dates / username */
    .dashboard-user-info p a,
    .dashboard-user-info p time,
    .dashboard-user-info p span {
        color: inherit;
        text-decoration: none;
    }
    .dashboard-user-info .dash-user-date,
    .dashboard-user-info .dash-user-handle {
        -webkit-touch-callout: none;
    }

    /* ─── Dashboard nav: polished 2-col grid with icon squircle ─── */
    .dashboard-nav {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: 10px;
        padding: 14px;
        background: linear-gradient(160deg, rgba(14, 20, 40, 0.72), rgba(10, 14, 28, 0.55));
        border: 1px solid rgba(255, 255, 255, 0.06);
        border-radius: 20px;
        box-shadow: 0 10px 32px -16px rgba(0, 0, 0, 0.65);
    }

    .dashboard-nav-item {
        position: relative;
        display: flex;
        align-items: center;
        justify-content: flex-start;
        gap: 11px;
        padding: 11px 12px;
        background: rgba(255, 255, 255, 0.025);
        border: 1px solid rgba(255, 255, 255, 0.06);
        border-radius: 14px;
        color: var(--text-muted);
        font-size: 0.84rem;
        font-weight: 600;
        font-family: var(--font-heading);
        line-height: 1.2;
        min-height: 56px;
        overflow: hidden;
        transition:
            transform 0.18s ease,
            border-color 0.18s ease,
            background 0.18s ease,
            box-shadow 0.22s ease,
            color 0.18s ease;
    }

    .dashboard-nav-item i {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 34px;
        height: 34px;
        flex-shrink: 0;
        border-radius: 11px;
        background: rgba(var(--primary-rgb), 0.12);
        border: 1px solid rgba(var(--primary-rgb), 0.22);
        color: var(--primary);
        font-size: 0.95rem;
        text-align: center;
        transition: transform 0.18s ease, background 0.18s ease, border-color 0.18s ease, color 0.18s ease, box-shadow 0.22s ease;
    }

    .dashboard-nav-item:hover {
        transform: translateY(-2px);
        background: rgba(var(--primary-rgb), 0.06);
        border-color: rgba(var(--primary-rgb), 0.3);
        color: #fff;
        box-shadow: 0 10px 24px -12px rgba(var(--primary-rgb), 0.5);
    }

    .dashboard-nav-item:hover i {
        background: rgba(var(--primary-rgb), 0.22);
        border-color: rgba(var(--primary-rgb), 0.45);
        transform: scale(1.05);
    }

    .dashboard-nav-item.active {
        background: linear-gradient(135deg, rgba(var(--primary-rgb), 0.28), rgba(var(--secondary-rgb), 0.16));
        border-color: rgba(var(--primary-rgb), 0.5);
        color: #fff;
        box-shadow:
            0 12px 30px -14px rgba(var(--primary-rgb), 0.7),
            inset 0 0 0 1px rgba(255, 255, 255, 0.06);
    }

    .dashboard-nav-item.active i {
        background: linear-gradient(135deg, var(--primary), var(--secondary));
        border-color: transparent;
        color: #fff;
        box-shadow: 0 6px 16px rgba(var(--primary-rgb), 0.55);
    }

    /* Admin Panel — amber accent */
    .dashboard-nav-item[href="admin/"] {
        background: linear-gradient(135deg, rgba(245, 158, 11, 0.13), rgba(245, 158, 11, 0.04));
        border-color: rgba(245, 158, 11, 0.34);
        color: #fbbf24 !important;
    }
    .dashboard-nav-item[href="admin/"] i {
        background: rgba(245, 158, 11, 0.16);
        border-color: rgba(245, 158, 11, 0.42);
        color: #f59e0b;
    }
    .dashboard-nav-item[href="admin/"]:hover {
        background: linear-gradient(135deg, rgba(245, 158, 11, 0.24), rgba(245, 158, 11, 0.08));
        border-color: rgba(245, 158, 11, 0.55);
        color: #fff !important;
        box-shadow: 0 10px 24px -12px rgba(245, 158, 11, 0.55);
    }
    .dashboard-nav-item[href="admin/"]:hover i {
        background: linear-gradient(135deg, #f59e0b, #f97316);
        border-color: transparent;
        color: #fff;
    }

    /* Logout — red accent, full-width row */
    .dashboard-nav-logout {
        grid-column: 1 / -1;
        justify-content: center;
        background: linear-gradient(135deg, rgba(255, 61, 113, 0.13), rgba(255, 61, 113, 0.03));
        border-color: rgba(255, 61, 113, 0.3);
        color: rgba(255, 110, 145, 0.95);
        margin-top: 6px;
    }
    .dashboard-nav-logout i {
        background: rgba(255, 61, 113, 0.14);
        border-color: rgba(255, 61, 113, 0.36);
        color: rgba(255, 110, 145, 0.95);
    }
    .dashboard-nav-logout:hover {
        background: linear-gradient(135deg, rgba(255, 61, 113, 0.24), rgba(255, 61, 113, 0.07));
        border-color: rgba(255, 61, 113, 0.55);
        color: #fff;
        box-shadow: 0 10px 24px -12px rgba(255, 61, 113, 0.6);
    }
    .dashboard-nav-logout:hover i {
        background: linear-gradient(135deg, #ff3d71, #ef4444);
        border-color: transparent;
        color: #fff;
    }

    .dashboard-nav-divider {
        display: none;
    }

    .dashboard-stats-grid {
        grid-template-columns: 1fr;
    }

    .dashboard-quick-links {
        grid-template-columns: repeat(4, 1fr);
    }

    .dashboard-section {
        padding: 24px 18px;
        border-radius: 20px;
    }

    .dashboard-logout-btn {
        margin-left: 0;
    }
}

/* ── Dashboard: small smartphone tweaks (<=480px) ── */
@media (max-width: 480px) {
    .dashboard-hero {
        padding-top: 90px;
        padding-bottom: 22px;
    }
    .dashboard-user-header {
        padding: 22px 16px 22px;
        gap: 14px;
        border-radius: 20px;
    }
    .dashboard-avatar {
        width: 76px;
        height: 76px;
        font-size: 1.85rem;
    }
    .dashboard-user-info h1 {
        font-size: 1.28rem;
        margin-bottom: 10px;
    }
    .dashboard-user-info p {
        font-size: 0.74rem;
    }
    /* Quick stats strip — 2×2 grid on small phones */
    .dashboard-user-stats {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 8px;
    }
    .dashboard-user-stat {
        flex-direction: row;
        text-align: left;
        align-items: center;
        gap: 10px;
        padding: 10px 12px;
    }
    .dashboard-user-stat__icon {
        width: 32px;
        height: 32px;
        font-size: 0.85rem;
    }
    .dashboard-user-stat__body {
        align-items: flex-start;
    }
    .dashboard-user-stat__value {
        flex-direction: row;
        align-items: baseline;
        gap: 5px;
    }
    .dashboard-nav {
        padding: 10px;
        gap: 8px;
        border-radius: 18px;
    }
    .dashboard-nav-item {
        padding: 10px 10px;
        font-size: 0.8rem;
        min-height: 52px;
        border-radius: 12px;
        gap: 9px;
    }
    .dashboard-nav-item i {
        width: 30px;
        height: 30px;
        font-size: 0.88rem;
        border-radius: 10px;
    }
    .dashboard-section {
        padding: 20px 14px;
        border-radius: 18px;
    }
}

/* ── Nav badge (mobile-tuned pill, applies globally; mobile gets shadow) ── */
@media (max-width: 768px) {
    .nav-badge {
        min-width: 20px;
        height: 20px;
        padding: 0 6px;
        border-radius: 10px;
        background: linear-gradient(135deg, #ef4444, #dc2626);
        font-size: 0.7rem;
        box-shadow:
            0 3px 8px rgba(239, 68, 68, 0.45),
            inset 0 0 0 1px rgba(255, 255, 255, 0.12);
        margin-left: auto;
    }
    .dashboard-nav-item.active .nav-badge {
        background: linear-gradient(135deg, #ffffff, #f1f5f9);
        color: var(--primary);
        box-shadow:
            0 3px 10px rgba(0, 0, 0, 0.25),
            inset 0 0 0 1px rgba(var(--primary-rgb), 0.2);
    }
}

/* ─── Member Tables ─────────────────────────────────────────── */
.table-responsive { overflow-x: auto; }
.member-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.88rem;
}
.member-table th {
    background: rgba(255,255,255,0.05);
    color: var(--text-muted);
    font-weight: 600;
    padding: 10px 14px;
    text-align: left;
    white-space: nowrap;
    border-bottom: 1px solid rgba(255,255,255,0.08);
    min-width: 60px;
}
.member-table td {
    padding: 10px 14px;
    border-bottom: 1px solid rgba(255,255,255,0.04);
    vertical-align: middle;
    color: var(--text-light);
    min-width: 60px;
}
.member-table tr:last-child td { border-bottom: none; }
.member-table tr:hover td { background: rgba(255,255,255,0.02); }

/* Client area: sortable headers + pager */
.clientarea-th-sort { white-space: nowrap; }
.clientarea-th-sort__link {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    color: inherit;
    text-decoration: none;
    font-weight: 600;
}
.clientarea-th-sort__link:hover {
    color: var(--text-light);
}
.clientarea-th-sort__ico { font-size: 0.72em; opacity: 0.85; }
.clientarea-th-sort__ico--muted { opacity: 0.45; }
.clientarea-th-nosort {
    color: var(--text-muted);
    font-weight: 600;
}
.clientarea-pager {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-top: 14px;
    padding: 10px 14px;
    border-radius: 12px;
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.06);
    font-size: 0.82rem;
    color: var(--text-muted);
}
.clientarea-pager__meta b { color: var(--text-light); font-weight: 600; }
.clientarea-pager__btns {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}
.clientarea-pager__link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: var(--primary);
    text-decoration: none;
    font-weight: 600;
    font-size: 0.82rem;
}
.clientarea-pager__link:hover { text-decoration: underline; }
.clientarea-pager__link--disabled {
    color: var(--text-muted);
    opacity: 0.45;
    cursor: not-allowed;
    pointer-events: none;
}

/* Stack table rows as cards on narrow viewports */
@media (max-width: 900px) {
    .table-responsive--stack {
        overflow-x: visible;
    }
    .member-table--stack thead {
        position: absolute;
        width: 1px;
        height: 1px;
        padding: 0;
        margin: -1px;
        overflow: hidden;
        clip: rect(0, 0, 0, 0);
        border: 0;
    }
    .member-table--stack tbody {
        display: block;
    }
    .member-table--stack tbody tr {
        display: block;
        margin-bottom: 12px;
        padding: 12px 14px;
        border-radius: 12px;
        background: rgba(255,255,255,0.03);
        border: 1px solid rgba(255,255,255,0.06);
    }
    .member-table--stack tbody tr:hover td {
        background: transparent;
    }
    .member-table--stack td {
        display: block;
        text-align: right;
        width: 100%;
        box-sizing: border-box;
        padding: 8px 14px;
        border-bottom: 1px solid rgba(255,255,255,0.04);
        overflow: hidden; /* clear floats for multi-line value cells */
    }
    .member-table--stack td:last-child {
        border-bottom: none;
    }
    .member-table--stack td::before {
        content: attr(data-label);
        float: left;
        text-align: left;
        max-width: 48%;
        padding-right: 8px;
        font-size: 0.78rem;
        font-weight: 600;
        color: var(--text-muted);
        line-height: 1.45;
    }
    .client-order-invoices-table.member-table--stack td {
        white-space: normal;
    }
}

/* Status badges */
.member-badge {
    display: inline-block;
    padding: 3px 10px;
    border-radius: 20px;
    font-size: 0.75rem;
    font-weight: 600;
}
.status-pending   { background: rgba(245,158,11,0.15); color: #f59e0b; }
.status-confirmed { background: rgba(34,197,94,0.15);  color: #22c55e; }
.status-paid      { background: rgba(34,197,94,0.15);  color: #22c55e; }
.status-cancelled { background: rgba(239,68,68,0.15);  color: #ef4444; }
.status-refunded  { background: rgba(244,114,182,0.15);color: #f472b6; }
.status-expired   { background: rgba(156,163,175,0.15);color: #9ca3af; }
.status-unpaid    { background: rgba(245,158,11,0.15); color: #f59e0b; }
.status-terminated{ background: rgba(127,29,29,.22);  color: #f87171; border-color: rgba(248,113,113,.4); }

/* Nav badge count */
.nav-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    border-radius: 9px;
    background: #ef4444;
    color: #fff;
    font-size: 0.7rem;
    font-weight: 700;
    margin-left: auto;
}

/* Btn-link inline */
.btn-link {
    color: var(--primary);
    text-decoration: none;
    font-size: 0.82rem;
    font-weight: 500;
}
.btn-link:hover { text-decoration: underline; }

/* Member dashboard: compact action buttons in data tables (orders / invoices / tickets) */
a.btn-table-action {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 8px 16px;
    border-radius: 999px;
    font-size: 0.8rem;
    font-weight: 600;
    font-family: var(--font-heading);
    line-height: 1.2;
    text-decoration: none;
    color: #fff;
    background: linear-gradient(135deg, var(--primary), var(--secondary));
    box-shadow: 0 2px 12px rgba(var(--primary-rgb), 0.3);
    border: none;
    isolation: isolate;
    overflow: hidden;
    white-space: nowrap;
    max-width: 100%;
    transition: transform 0.2s, box-shadow 0.2s;
}
a.btn-table-action::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, var(--secondary), var(--primary));
    opacity: 0;
    transition: opacity 0.4s;
    z-index: -1;
    border-radius: inherit;
}
a.btn-table-action:hover {
    color: #fff;
    text-decoration: none;
    transform: translateY(-1px);
    box-shadow: 0 5px 20px rgba(var(--primary-rgb), 0.45);
}
a.btn-table-action:hover::before {
    opacity: 1;
}
a.btn-table-action i {
    position: relative;
    z-index: 1;
    font-size: 0.9em;
    opacity: 0.95;
}
@media (max-width: 900px) {
    .member-table--stack .btn-table-action {
        white-space: normal;
        text-align: center;
    }
}

/* รายการออเดอร์ (clientarea?tab=orders): คอลัมน์แพ็กซ้อนชื่อ+ประเภท+โดเมน/Host — กรอบตารางใช้ .member-table เหมือนใบแจ้งหนี้/ticket */
.client-order-pkg-cell {
    vertical-align: top;
    max-width: 16rem;
}
.client-order-pkg-stack {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.35rem;
    max-width: 100%;
}
.client-order-pkg-head {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.25rem;
    width: 100%;
}
.client-order-pkg-name {
    display: block;
    font-weight: 600;
    font-size: 0.88rem;
    line-height: 1.35;
    color: var(--text-light);
}
.client-order-pkg-type {
    display: inline-block;
    margin: 0;
    font-size: 0.78rem;
    color: var(--text-muted);
    line-height: 1.3;
}
.client-order-pkg-target {
    margin-top: 0.2rem;
    font-size: 0.7rem;
    line-height: 1.35;
    color: #a8b0c0;
    font-family: var(--font-body, inherit), "TH Sarabun New", "Sarabun", "Kanit", system-ui, sans-serif;
    word-break: break-word;
    letter-spacing: 0.01em;
    padding: 0.2rem 0.4rem 0.3rem;
    border-radius: 6px;
    background: rgba(99, 102, 241, 0.07);
    border: 1px solid rgba(148, 163, 184, 0.15);
    max-width: 100%;
}
.client-order-status-note {
    display: block;
    margin-top: 4px;
    font-size: 0.72rem;
    line-height: 1.4;
    color: #8892a4;
}
@media (max-width: 900px) {
    .member-table--stack .client-order-pkg-cell {
        max-width: 100%;
    }
}

/* ─── Client area: order detail (tab=orders&order_id) ───────── */
.client-order-back {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--text-muted);
    text-decoration: none;
    font-size: 0.9rem;
    font-weight: 500;
    margin-bottom: 20px;
    transition: color 0.2s;
}
.client-order-back:hover {
    color: var(--primary);
}
.client-order-sec-link {
    display: inline-block;
    margin-top: 4px;
    font-size: 0.78rem;
    color: var(--text-muted);
    text-decoration: none;
    font-weight: 500;
}
.client-order-sec-link:hover {
    color: var(--primary);
    text-decoration: underline;
}
.client-order-detail {
    background: linear-gradient(145deg, rgba(15, 23, 42, 0.92) 0%, rgba(15, 23, 42, 0.65) 100%);
    border: 1px solid rgba(99, 102, 241, 0.22);
    border-radius: 20px;
    padding: 0;
    overflow: hidden;
    box-shadow: 0 24px 60px rgba(0, 0, 0, 0.35);
}
.client-order-detail__head {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    padding: 28px 28px 20px;
    background: linear-gradient(135deg, rgba(99, 102, 241, 0.18) 0%, rgba(0, 210, 255, 0.06) 100%);
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}
.client-order-detail__eyebrow {
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--primary);
    font-weight: 600;
    margin: 0 0 6px;
}
.client-order-detail__title {
    margin: 0 0 6px;
    font-size: 1.5rem;
    font-weight: 700;
    color: #fff;
    line-height: 1.25;
}
.client-order-detail__type {
    margin: 0;
    font-size: 0.92rem;
    color: var(--text-muted);
}
.client-order-detail__summary {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
    background: rgba(0, 0, 0, 0.2);
}
.client-order-detail__stat {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 18px 24px;
    border-right: 1px solid rgba(255, 255, 255, 0.04);
}
.client-order-detail__stat:last-child { border-right: none; }
.client-order-detail__stat > i {
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 12px;
    background: rgba(99, 102, 241, 0.15);
    color: #a5b4fc;
    font-size: 1.1rem;
}
.client-order-detail__stat span {
    display: block;
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text-muted);
    margin-bottom: 2px;
}
.client-order-detail__stat strong {
    font-size: 1rem;
    color: var(--text-light);
    font-weight: 600;
}
.client-order-detail__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
    padding: 24px 28px 10px;
}
.client-order-detail__grid--single {
    grid-template-columns: 1fr;
}
.client-order-card--invoices-list {
    margin-top: 0;
}
.client-order-invoice-count {
    font-weight: 500;
    color: var(--text-muted);
    font-size: 0.88em;
}
.client-order-invoices-table th,
.client-order-invoices-table td {
    font-variant-numeric: tabular-nums;
}
.client-order-badge-renewal {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 6px;
    font-size: 0.75rem;
    font-weight: 600;
    background: rgba(123, 114, 255, 0.15);
    color: #a5b4fc;
    border: 1px solid rgba(123, 114, 255, 0.35);
}
.client-order-card {
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 16px;
    padding: 20px 22px;
}
.client-order-card--wide {
    margin: 0 28px 20px;
    width: calc(100% - 56px);
    box-sizing: border-box;
}
.client-order-card--invoice {
    border-color: rgba(0, 210, 255, 0.2);
    background: rgba(0, 210, 255, 0.04);
}
.client-order-card--specs {
    background: rgba(15, 23, 42, 0.5);
}
.client-order-card__title {
    margin: 0 0 16px;
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--text-light);
    display: flex;
    align-items: center;
    gap: 10px;
}
.client-order-card__title i {
    color: var(--primary);
    opacity: 0.9;
}
.client-order-dl {
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 10px 0;
}
.client-order-dl > div {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: baseline;
    gap: 8px 16px;
    font-size: 0.9rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.04);
    padding-bottom: 10px;
}
.client-order-dl > div:last-of-type { border-bottom: none; padding-bottom: 0; }
.client-order-dl dt {
    color: var(--text-muted);
    font-weight: 500;
    margin: 0;
}
.client-order-dl dd {
    margin: 0;
    text-align: right;
    color: var(--text-light);
    max-width: 100%;
    word-break: break-word;
}
.client-order-card__note {
    margin: 12px 0 0;
    font-size: 0.9rem;
    line-height: 1.6;
    color: var(--text-muted);
}
.client-order-card__empty {
    margin: 0;
    font-size: 0.9rem;
    line-height: 1.65;
    color: var(--text-muted);
}
.client-order-card__empty a { color: var(--primary); }
.client-order-invoice-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    max-width: 100%;
    margin-top: 16px;
    padding: 12px 16px;
    font-size: 0.9rem;
    text-decoration: none;
    box-sizing: border-box;
    border-radius: 12px;
}
.client-order-cf-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 14px;
}
.client-order-cf-item {
    background: rgba(0, 0, 0, 0.25);
    border: 1px solid rgba(255, 255, 255, 0.07);
    border-radius: 12px;
    padding: 12px 14px;
}
.client-order-cf-label {
    display: block;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--text-muted);
    margin-bottom: 6px;
}
.client-order-cf-value {
    font-size: 0.9rem;
    color: var(--text-light);
    line-height: 1.45;
    word-break: break-word;
}
.client-order-cf-value--with-toggle {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    flex-wrap: wrap;
}
.client-order-cf-pw-view {
    flex: 1;
    min-width: 0;
    font-size: 0.9rem;
    color: var(--text-light);
    line-height: 1.5;
    word-break: break-all;
}
.client-order-cf-item--password .order-cf-pw-btn {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 10px;
    border: 1px solid var(--border-color);
    background: rgba(12, 20, 40, 0.6);
    color: var(--text-muted);
    cursor: pointer;
    transition: var(--transition);
}
.client-order-cf-item--password .order-cf-pw-btn:hover {
    color: var(--primary);
    border-color: rgba(var(--primary-rgb), 0.35);
    background: rgba(var(--primary-rgb), 0.08);
}
.client-order-cf-item--password .order-cf-pw-btn:focus-visible {
    outline: 2px solid rgba(var(--primary-rgb), 0.5);
    outline-offset: 2px;
}

/* ── Copy-to-clipboard button (รวมไอคอน Eye + Copy ให้ใช้สไตล์เดียวกัน) ── */
.client-order-cf-value--with-copy {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}
.client-order-cf-value--with-copy .client-order-cf-text {
    flex: 1;
    min-width: 0;
    font-size: 0.9rem;
    color: var(--text-light);
    line-height: 1.5;
    word-break: break-all;
}
.client-order-cf-item--copyable { cursor: default; }
.order-cf-icon-btn {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 9px;
    border: 1px solid var(--border-color, rgba(255,255,255,.08));
    background: rgba(12, 20, 40, 0.55);
    color: var(--text-muted);
    font-size: 0.82rem;
    cursor: pointer;
    transition: var(--transition);
    padding: 0;
}
.order-cf-icon-btn:hover {
    color: var(--primary);
    border-color: rgba(var(--primary-rgb), 0.4);
    background: rgba(var(--primary-rgb), 0.10);
    transform: translateY(-1px);
}
.order-cf-icon-btn:focus-visible {
    outline: 2px solid rgba(var(--primary-rgb), 0.55);
    outline-offset: 2px;
}
.order-cf-copy-btn.is-copied {
    color: #34d399;
    border-color: rgba(52, 211, 153, 0.5);
    background: rgba(52, 211, 153, 0.12);
    transform: none;
}
/* แก้ดัน 36×36 เก่าของ password btn ให้กับใหม่ (เล็กลง 32) consistent กัน */
.client-order-cf-item--password .order-cf-pw-btn {
    width: 32px;
    height: 32px;
    border-radius: 9px;
    font-size: 0.82rem;
}
.client-order-specs {
    font-size: 0.88rem;
    line-height: 1.65;
    color: var(--text-muted);
}
.client-order-specs--plain {
    background: rgba(0, 0, 0, 0.2);
    border: 1px solid rgba(255, 255, 255, 0.07);
    border-radius: 12px;
    padding: 14px 16px;
    font-size: 0.86rem;
    line-height: 1.6;
}
.client-order-specs-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(148px, 1fr));
    gap: 12px;
    margin-top: 2px;
}
.client-order-spec-tile {
    position: relative;
    padding: 16px 14px 14px;
    text-align: center;
    background: linear-gradient(165deg, rgba(0, 210, 255, 0.08) 0%, rgba(12, 20, 40, 0.65) 55%, rgba(0, 0, 0, 0.18) 100%);
    border: 1px solid rgba(0, 210, 255, 0.16);
    border-radius: 14px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2);
    transition: var(--transition);
}
.client-order-spec-tile:hover {
    border-color: rgba(0, 210, 255, 0.3);
    box-shadow: 0 6px 28px rgba(0, 210, 255, 0.08);
    transform: translateY(-1px);
}
.client-order-spec-tile__icon {
    width: 48px;
    height: 48px;
    margin: 0 auto 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 12px;
    font-size: 1.2rem;
    color: #7dd3fc;
    background: rgba(0, 210, 255, 0.12);
    border: 1px solid rgba(0, 210, 255, 0.25);
    box-shadow: 0 0 24px rgba(0, 210, 255, 0.12);
}
.client-order-spec-tile__label {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--text-muted);
    font-weight: 600;
    margin-bottom: 6px;
    line-height: 1.3;
    word-break: break-word;
}
.client-order-spec-tile__value {
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--text-light);
    font-family: var(--font-heading);
    line-height: 1.3;
    word-break: break-word;
    font-variant-numeric: tabular-nums;
}
/* สรุปสเปก Radio / Centova — ป้ายภาษาไทย ไม่บังคับ uppercase */
.client-order-specs-grid--cc-summary {
    grid-template-columns: repeat(auto-fill, minmax(168px, 1fr));
}
.client-order-specs-grid--cc-summary .client-order-spec-tile__label {
    text-transform: none;
    letter-spacing: 0.02em;
    font-size: 0.78rem;
    font-weight: 600;
}

/* ── VMware specs grid: 4 tiles (CPU / Memory / Disk / OS) ── */
.client-order-specs-grid--vmware {
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
}
.client-order-specs-grid--vmware .client-order-spec-tile__label {
    text-transform: none;
    letter-spacing: 0.03em;
    font-size: 0.78rem;
    font-weight: 600;
}
.client-order-specs-grid--vmware .client-order-spec-tile__value {
    font-size: 1.15rem;
}
/* OS tile: Windows = blue tone, Linux = warm tone */
.client-order-specs-grid--vmware .client-order-spec-tile:has(.fa-windows) .client-order-spec-tile__icon {
    color: #93c5fd;
    background: rgba(59, 130, 246, 0.14);
    border-color: rgba(59, 130, 246, 0.32);
    box-shadow: 0 0 24px rgba(59, 130, 246, 0.14);
}
.client-order-specs-grid--vmware .client-order-spec-tile:has(.fa-linux) .client-order-spec-tile__icon {
    color: #fcd34d;
    background: rgba(245, 158, 11, 0.14);
    border-color: rgba(245, 158, 11, 0.32);
    box-shadow: 0 0 24px rgba(245, 158, 11, 0.14);
}

/* ── Icon next to CF label (e.g. "🖥️ ชื่อ VM") ── */
.client-order-cf-label {
    display: flex;
    align-items: center;
    gap: 7px;
}
.client-order-cf-label__icon {
    font-size: 0.78rem;
    color: rgba(125, 211, 252, 0.85);
    width: 14px;
    text-align: center;
    flex-shrink: 0;
}

/* แผงเปลี่ยนรหัสบริการ (Centova / DA) ในหน้าออเดอร์ */
.client-service-panel .svc-cc-panel-actions {
    margin: 0 0 14px;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
}
.client-service-panel .svc-cc-sso-link {
    font-size: 0.84rem;
    padding: 8px 16px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
}
.client-service-panel .svc-pw-section {
    margin-top: 4px;
    padding-top: 16px;
    border-top: 1px solid rgba(148, 163, 184, 0.15);
}
.client-service-panel .svc-pw-section__title {
    font-size: 0.9rem;
    margin: 0 0 12px;
    color: var(--text-light);
    font-weight: 600;
}
.client-service-panel .svc-pw-form {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    align-items: flex-end;
}
.client-service-panel .svc-pw-field {
    flex: 1;
    min-width: 200px;
    max-width: 320px;
}
.client-service-panel .svc-pw-field label {
    display: block;
    font-size: 0.78rem;
    color: var(--text-muted);
    margin-bottom: 6px;
    font-weight: 500;
}
.client-service-panel .svc-pw-input {
    width: 100%;
    box-sizing: border-box;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 10px;
    padding: 11px 14px;
    color: var(--text);
    font-family: inherit;
    font-size: 0.9rem;
    line-height: 1.4;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.client-service-panel .svc-pw-input::placeholder {
    color: var(--text-muted);
    opacity: 0.72;
}
.client-service-panel .svc-pw-input:hover {
    border-color: rgba(148, 163, 184, 0.35);
}
.client-service-panel .svc-pw-input:focus {
    outline: none;
    border-color: rgba(var(--primary-rgb), 0.45);
    box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.15);
}
.client-order-specs-bullets {
    list-style: none;
    margin: 4px 0 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.client-order-specs-bullets li {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    font-size: 0.9rem;
    color: var(--text-light);
    line-height: 1.5;
    padding: 10px 12px;
    background: rgba(0, 0, 0, 0.15);
    border-radius: 10px;
    border: 1px solid rgba(255, 255, 255, 0.06);
}
.client-order-specs-bullets__dot {
    width: 6px;
    height: 6px;
    margin-top: 6px;
    flex-shrink: 0;
    border-radius: 50%;
    background: var(--primary);
    box-shadow: 0 0 10px rgba(0, 210, 255, 0.5);
}
.client-order-card--specs {
    background: linear-gradient(180deg, rgba(0, 210, 255, 0.04) 0%, rgba(12, 20, 40, 0.2) 100%);
    border-color: rgba(0, 210, 255, 0.12) !important;
}
@media (max-width: 900px) {
    .client-order-detail__grid {
        grid-template-columns: 1fr;
    }
    .client-order-card--wide {
        width: auto;
        margin: 0 16px 16px;
    }
    .client-order-detail__head,
    .client-order-detail__grid,
    .client-order-detail__summary {
        padding-left: 18px;
        padding-right: 18px;
    }
    .client-order-detail__stat {
        border-right: none;
        border-bottom: 1px solid rgba(255, 255, 255, 0.04);
    }
    .client-order-detail__summary {
        grid-template-columns: 1fr;
    }
    .client-order-detail__stat:last-child {
        border-bottom: none;
    }
}

/* ─── Order Page ─────────────────────────────────────────────── */
.auth-section {
    padding: 100px 0 60px;
    min-height: 100vh;
}
.auth-container { margin: 0 auto; padding: 0 16px; }
.auth-card {
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 20px;
    padding: 36px;
}
.auth-header { text-align: center; margin-bottom: 28px; }
.auth-header h1 { font-size: 1.6rem; font-weight: 700; color: #fff; }
.auth-header p  { color: var(--text-muted); margin-top: 8px; }

/* Package summary card on order.php */
.order-pkg-card {
    background: rgba(108,99,255,0.08);
    border: 1px solid rgba(108,99,255,0.2);
    border-radius: 14px;
    padding: 20px 22px;
    margin-bottom: 24px;
}
.order-pkg-type {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--primary);
    font-weight: 600;
    margin-bottom: 6px;
}
.order-pkg-name { font-size: 1.2rem; font-weight: 700; color: #fff; margin-bottom: 6px; }
.order-pkg-desc { font-size: 0.85rem; color: var(--text-muted); margin-bottom: 12px; }
.order-specs { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: 8px; }
.order-specs li {
    display: flex;
    align-items: center;
    gap: 6px;
    background: rgba(255,255,255,0.05);
    border-radius: 6px;
    padding: 4px 10px;
    font-size: 0.8rem;
}
.spec-k { color: var(--text-muted); }
.spec-v { color: #fff; font-weight: 500; }

/* Billing period radio options */
.billing-options { display: flex; gap: 12px; flex-wrap: wrap; }
.billing-opt { cursor: pointer; flex: 1; min-width: 160px; }
.billing-opt input[type="radio"] { display: none; }
.billing-opt-box {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 14px 16px;
    background: rgba(255,255,255,0.04);
    border: 2px solid rgba(255,255,255,0.1);
    border-radius: 12px;
    transition: all 0.2s;
}
.billing-opt input[type="radio"]:checked + .billing-opt-box {
    border-color: var(--primary);
    background: rgba(0,210,255,0.08);
}
.billing-opt:hover .billing-opt-box { border-color: rgba(255,255,255,0.25); }
.billing-period { font-size: 0.85rem; font-weight: 600; color: #fff; }
.billing-price  { font-size: 1rem; font-weight: 700; color: var(--primary); }
.billing-price small { font-size: 0.75rem; font-weight: 400; color: var(--text-muted); }
.billing-badge  {
    display: inline-block;
    background: rgba(34,197,94,0.15);
    color: #22c55e;
    font-size: 0.68rem;
    padding: 1px 7px;
    border-radius: 10px;
    font-weight: 600;
    margin-left: 6px;
}

/* Order summary box */
.order-summary {
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 12px;
    padding: 16px 20px;
    margin-top: 16px;
}
.summary-row {
    display: flex;
    justify-content: space-between;
    padding: 5px 0;
    font-size: 0.88rem;
    color: var(--text-muted);
}
.summary-total {
    font-size: 1.05rem;
    font-weight: 700;
    color: #fff;
    border-top: 1px solid rgba(255,255,255,0.1);
    margin-top: 8px;
    padding-top: 10px;
}

/* Order form helpers */
.order-form .form-label { font-size: 0.85rem; color: var(--text-muted); font-weight: 500; margin-bottom: 8px; display: block; }
.order-form .form-control {
    width: 100%;
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 10px;
    padding: 10px 14px;
    color: #fff;
    font-size: 0.9rem;
}
.order-form .form-control:focus { outline: none; border-color: var(--primary); }
.btn-full { width: 100%; }
.mt-2 { margin-top: 8px; }
.mt-3 { margin-top: 16px; }
.btn-secondary {
    background: rgba(255,255,255,0.08);
    color: var(--text-light);
    border: 1px solid rgba(255,255,255,0.12);
}
.btn-secondary:hover { background: rgba(255,255,255,0.14); }

/* Alert in order/invoice pages */
.alert-danger {
    background: rgba(239,68,68,0.12);
    border: 1px solid rgba(239,68,68,0.3);
    color: #ef4444;
    padding: 12px 16px;
    border-radius: 8px;
    margin-bottom: 16px;
    font-size: 0.88rem;
}

/* ─── Dashboard overview order stats ─────────────────────────── */
.dashboard-stat-card .order-count {
    font-size: 0.78rem;
    color: var(--text-muted);
    margin-top: 2px;
}

/* ============================================
   Register Form — Extended
   ============================================ */

.auth-wrap-reg {
    max-width: 860px;
}

/* Form sections */
.reg-section {
    margin-bottom: 26px;
    padding-bottom: 26px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.reg-section-last {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0;
}

.reg-section-title {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 0.93rem;
    font-weight: 700;
    color: var(--primary);
    margin-bottom: 18px;
    font-family: var(--font-heading);
    letter-spacing: 0.01em;
}

.reg-section-icon {
    width: 30px;
    height: 30px;
    background: linear-gradient(135deg, rgba(var(--primary-rgb), 0.15), rgba(var(--secondary-rgb), 0.08));
    border: 1px solid rgba(var(--primary-rgb), 0.18);
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.82rem;
    color: var(--primary);
    flex-shrink: 0;
}

.reg-optional-badge {
    margin-left: 4px;
    font-size: 0.7rem;
    font-weight: 500;
    color: var(--text-muted);
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 20px;
    padding: 1px 9px;
    letter-spacing: 0;
}

/* ID document type toggle */
.id-type-toggle {
    display: flex;
    gap: 4px;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.07);
    border-radius: 10px;
    padding: 4px;
    margin-bottom: 18px;
    width: fit-content;
}

.id-type-btn {
    display: flex;
    align-items: center;
    gap: 7px;
    padding: 8px 20px;
    border-radius: 7px;
    border: none;
    background: transparent;
    color: var(--text-muted);
    font-size: 0.88rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.25s;
    font-family: var(--font-heading);
    white-space: nowrap;
}

.id-type-btn.active {
    background: linear-gradient(135deg, var(--primary), var(--secondary));
    color: #fff;
    box-shadow: 0 2px 12px rgba(var(--primary-rgb), 0.25);
}

.id-type-btn:hover:not(.active) {
    background: rgba(255, 255, 255, 0.06);
    color: var(--text-main);
}

.id-format-hint {
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--text-muted);
    background: rgba(var(--primary-rgb), 0.07);
    border: 1px solid rgba(var(--primary-rgb), 0.12);
    border-radius: 20px;
    padding: 1px 9px;
    margin-left: 6px;
    font-family: monospace;
    letter-spacing: 0.04em;
}

/* Textarea in auth form */
.auth-form-group textarea {
    width: 100%;
    padding: 12px 14px;
    background: rgba(12, 20, 40, 0.55);
    border: 1px solid rgba(255, 255, 255, 0.09);
    border-radius: var(--radius-sm);
    color: var(--text-main);
    font-size: 0.93rem;
    font-family: var(--font-body);
    resize: vertical;
    min-height: 72px;
    transition: border-color 0.3s, box-shadow 0.3s;
    line-height: 1.6;
}

.auth-form-group textarea:focus {
    border-color: rgba(var(--primary-rgb), 0.45);
    box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.07);
    outline: none;
}

/* Select dropdown in auth form */
.auth-form-group select {
    width: 100%;
    padding: 12px 36px 12px 14px;
    background: rgba(12, 20, 40, 0.55);
    border: 1px solid rgba(255, 255, 255, 0.09);
    border-radius: var(--radius-sm);
    color: var(--text-main);
    font-size: 0.93rem;
    font-family: var(--font-body);
    transition: border-color 0.3s, box-shadow 0.3s;
    appearance: none;
    -webkit-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238899b0' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
    cursor: pointer;
}

.auth-form-group select:focus {
    border-color: rgba(var(--primary-rgb), 0.45);
    box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.07);
    outline: none;
}

.auth-form-group select option {
    background: #0c1428;
    color: var(--text-main);
}

/* 3-column grid for address section */
.reg-3col {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 16px;
}

/* Required star */
.req {
    color: #ff3d71;
    font-weight: 700;
    margin-left: 2px;
}

/* Confirm password match message */
.reg-confirm-msg {
    display: flex;
    align-items: center;
    font-size: 0.82rem;
    font-weight: 600;
    margin-top: -8px;
    margin-bottom: 14px;
    padding: 7px 12px;
    border-radius: 7px;
}

.reg-confirm-ok {
    color: #00e676;
    background: rgba(0, 230, 118, 0.07);
    border: 1px solid rgba(0, 230, 118, 0.18);
}

.reg-confirm-err {
    color: #ff6b93;
    background: rgba(255, 61, 113, 0.07);
    border: 1px solid rgba(255, 61, 113, 0.18);
}

/* Responsive register */
@media (max-width: 768px) {
    .reg-3col {
        grid-template-columns: 1fr;
    }
    .id-type-toggle {
        width: 100%;
    }
    .id-type-btn {
        flex: 1;
        justify-content: center;
    }
}

/* ============================================
   Terms & Conditions Page
   ============================================ */

.terms-wrap {
    max-width: 900px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: 28px;
    align-items: start;
}

/* Sticky TOC sidebar */
.terms-toc {
    position: sticky;
    top: 90px;
    background: var(--bg-card);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    padding: 20px;
}

.terms-toc-title {
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--primary);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 14px;
    display: flex;
    align-items: center;
    gap: 7px;
}

.terms-toc ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.terms-toc ul li a {
    display: block;
    font-size: 0.82rem;
    color: var(--text-muted);
    padding: 5px 8px;
    border-radius: 7px;
    transition: all 0.2s;
    line-height: 1.4;
}

.terms-toc ul li a:hover {
    color: var(--primary);
    background: rgba(var(--primary-rgb), 0.07);
}

/* Terms main card */
.terms-card {
    background: var(--bg-card);
    backdrop-filter: blur(22px);
    -webkit-backdrop-filter: blur(22px);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-xl);
    padding: 42px 44px;
    position: relative;
    overflow: hidden;
}

.terms-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--primary), var(--secondary), transparent);
}

.terms-updated {
    font-size: 0.8rem;
    color: var(--text-muted);
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 8px;
    padding: 9px 14px;
    margin-bottom: 32px;
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.terms-updated i {
    color: var(--primary);
}

/* Each section */
.terms-section {
    margin-bottom: 36px;
    scroll-margin-top: 90px;
}

.terms-section h2 {
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--text-light);
    margin-bottom: 14px;
    display: flex;
    align-items: center;
    gap: 12px;
}

.terms-num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    background: linear-gradient(135deg, rgba(var(--primary-rgb), 0.15), rgba(var(--secondary-rgb), 0.08));
    border: 1px solid rgba(var(--primary-rgb), 0.2);
    border-radius: 8px;
    font-size: 0.72rem;
    font-weight: 800;
    color: var(--primary);
    flex-shrink: 0;
    letter-spacing: 0.03em;
}

.terms-section p {
    color: var(--text-muted);
    font-size: 0.93rem;
    line-height: 1.8;
    margin-bottom: 12px;
}

.terms-section p:last-child {
    margin-bottom: 0;
}

/* Lists */
.terms-list {
    list-style: none;
    padding: 0;
    margin: 12px 0 16px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.terms-list li {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    font-size: 0.91rem;
    color: var(--text-muted);
    line-height: 1.6;
}

.terms-list li i {
    color: var(--primary);
    margin-top: 3px;
    flex-shrink: 0;
    font-size: 0.8rem;
}

.terms-list-ban li i {
    color: #ff6b93;
}

/* Note boxes */
.terms-note {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    background: rgba(var(--primary-rgb), 0.06);
    border: 1px solid rgba(var(--primary-rgb), 0.15);
    border-radius: var(--radius-sm);
    padding: 14px 16px;
    font-size: 0.88rem;
    color: var(--text-muted);
    margin: 14px 0;
    line-height: 1.6;
}

.terms-note i {
    color: var(--primary);
    flex-shrink: 0;
    margin-top: 2px;
}

.terms-note-warn {
    background: rgba(255, 152, 0, 0.06);
    border-color: rgba(255, 152, 0, 0.2);
}

.terms-note-warn i {
    color: #ff9800;
}

/* Contact grid */
.terms-contact-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    margin-top: 16px;
}

.terms-contact-item {
    display: flex;
    align-items: center;
    gap: 14px;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: var(--radius-sm);
    padding: 14px 16px;
}

.terms-contact-item > i {
    width: 36px;
    height: 36px;
    background: linear-gradient(135deg, rgba(var(--primary-rgb), 0.12), rgba(var(--secondary-rgb), 0.08));
    border-radius: 9px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--primary);
    font-size: 0.9rem;
    flex-shrink: 0;
}

.terms-contact-item > div {
    font-size: 0.85rem;
    line-height: 1.5;
}

.terms-contact-item strong {
    display: block;
    color: var(--text-light);
    font-size: 0.82rem;
    margin-bottom: 2px;
}

.terms-contact-item a {
    color: var(--primary);
    font-size: 0.82rem;
}

.terms-contact-item a:hover {
    text-decoration: underline;
}

/* Footer note */
.terms-footer-note {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
    background: linear-gradient(135deg, rgba(var(--primary-rgb), 0.07), rgba(var(--secondary-rgb), 0.04));
    border: 1px solid rgba(var(--primary-rgb), 0.15);
    border-radius: var(--radius-md);
    padding: 18px 20px;
    font-size: 0.9rem;
    color: var(--text-muted);
    margin-top: 32px;
}

.terms-footer-note i {
    color: #00e676;
    font-size: 1.1rem;
}

/* Terms responsive */
@media (max-width: 900px) {
    .terms-wrap {
        grid-template-columns: 1fr;
    }
    .terms-toc {
        position: static;
    }
}

@media (max-width: 600px) {
    .terms-card {
        padding: 28px 20px;
    }
    .terms-contact-grid {
        grid-template-columns: 1fr;
    }
}

/* ============================================================
   Login History (Security tab)  —  premium card list
   ============================================================ */
.login-history-card {
    padding: 28px 28px 24px;
    position: relative;
    overflow: hidden;
}

.login-history-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 2px;
    background: linear-gradient(90deg,
        transparent, rgba(var(--primary-rgb), .55),
        rgba(var(--secondary-rgb), .5), transparent);
}

/* Header */
.login-history-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 18px;
    margin-bottom: 22px;
    padding-bottom: 18px;
    border-bottom: 1px dashed rgba(255, 255, 255, 0.07);
    flex-wrap: wrap;
}

.lh-head-text {
    flex: 1;
    min-width: 240px;
}

.login-history-title {
    font-size: 1.15rem;
    color: var(--text-light);
    margin: 0 0 6px;
    display: flex;
    align-items: center;
    gap: 10px;
    font-weight: 700;
    letter-spacing: 0.2px;
}

.login-history-title i {
    color: var(--primary);
    font-size: 1rem;
    width: 34px;
    height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, rgba(var(--primary-rgb), 0.14), rgba(var(--secondary-rgb), 0.08));
    border: 1px solid rgba(var(--primary-rgb), 0.22);
    border-radius: 9px;
}

.login-history-sub {
    font-size: 0.83rem;
    color: var(--text-muted);
    line-height: 1.6;
    margin: 0;
    max-width: 560px;
}

/* Summary chips */
.login-history-stats {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.lh-chip {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    font-size: 0.8rem;
    padding: 7px 14px;
    border-radius: 999px;
    font-family: var(--font-heading);
    font-weight: 600;
    letter-spacing: 0.2px;
    line-height: 1;
}

.lh-chip i {
    font-size: 0.8rem;
}

.lh-chip-label {
    opacity: 0.85;
    font-weight: 500;
}

.lh-chip b {
    font-weight: 800;
    padding: 2px 7px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.12);
    font-size: 0.78rem;
    min-width: 22px;
    text-align: center;
}

.lh-chip-success {
    background: linear-gradient(135deg, rgba(0, 230, 118, 0.14), rgba(0, 230, 118, 0.06));
    border: 1px solid rgba(0, 230, 118, 0.28);
    color: #00e676;
    box-shadow: 0 4px 14px -8px rgba(0, 230, 118, 0.5);
}

.lh-chip-danger {
    background: linear-gradient(135deg, rgba(255, 61, 113, 0.14), rgba(255, 61, 113, 0.06));
    border: 1px solid rgba(255, 61, 113, 0.28);
    color: #ff6b93;
    box-shadow: 0 4px 14px -8px rgba(255, 61, 113, 0.5);
}

.lh-chip-neutral {
    background: linear-gradient(135deg, rgba(148, 163, 184, 0.12), rgba(148, 163, 184, 0.05));
    border: 1px solid rgba(148, 163, 184, 0.25);
    color: #cbd5e1;
}

/* Empty state */
.lh-empty {
    text-align: center;
    padding: 40px 20px 20px;
}

.lh-empty-icon {
    width: 64px;
    height: 64px;
    margin: 0 auto 14px;
    background: linear-gradient(135deg, rgba(var(--primary-rgb), 0.12), rgba(var(--secondary-rgb), 0.08));
    border: 1px solid rgba(var(--primary-rgb), 0.2);
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    color: var(--primary);
}

.lh-empty h4 {
    margin: 0 0 6px;
    color: var(--text-light);
    font-size: 1rem;
}

.lh-empty p {
    margin: 0;
    font-size: 0.86rem;
    color: var(--text-muted);
}

/* List */
.login-history-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.login-history-item {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 16px;
    align-items: flex-start;
    padding: 16px 18px 16px 16px;
    background: linear-gradient(135deg, rgba(12, 20, 40, 0.65), rgba(12, 20, 40, 0.4));
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 14px;
    position: relative;
    overflow: hidden;
    transition: transform 0.2s ease, border-color 0.25s ease, background 0.25s ease, box-shadow 0.25s ease;
}

.login-history-item::before {
    content: '';
    position: absolute;
    left: 0; top: 0; bottom: 0;
    width: 3px;
    background: rgba(148, 163, 184, 0.3);
    border-radius: 14px 0 0 14px;
}

.login-history-item:hover {
    transform: translateY(-1px);
    border-color: rgba(255, 255, 255, 0.1);
    box-shadow: 0 8px 24px -16px rgba(0, 0, 0, 0.6);
}

.login-history-item.lh-status-success::before {
    background: linear-gradient(180deg, #00e676, rgba(0, 230, 118, 0.4));
}

.login-history-item.lh-status-danger::before {
    background: linear-gradient(180deg, #ff3d71, rgba(255, 61, 113, 0.4));
}

.login-history-item.lh-status-neutral::before {
    background: linear-gradient(180deg, rgba(148, 163, 184, 0.6), rgba(148, 163, 184, 0.2));
}

.login-history-item.lh-current {
    background: linear-gradient(135deg, rgba(0, 210, 255, 0.08), rgba(123, 97, 255, 0.05));
    border-color: rgba(0, 210, 255, 0.28);
    box-shadow: 0 0 0 1px rgba(0, 210, 255, 0.1), 0 10px 30px -18px rgba(0, 210, 255, 0.35);
}

/* Device badge */
.lh-device {
    width: 64px;
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 5px;
}

.lh-device > i {
    width: 52px;
    height: 52px;
    border-radius: 14px;
    background: linear-gradient(135deg, rgba(148, 163, 184, 0.12), rgba(148, 163, 184, 0.04));
    border: 1px solid rgba(148, 163, 184, 0.2);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #94a3b8;
    font-size: 1.3rem;
    transition: all 0.25s ease;
}

.lh-device-label {
    font-size: 0.65rem;
    letter-spacing: 0.6px;
    text-transform: uppercase;
    color: var(--text-muted);
    font-weight: 600;
    font-family: var(--font-heading);
}

.lh-status-success .lh-device > i {
    color: #00e676;
    background: linear-gradient(135deg, rgba(0, 230, 118, 0.18), rgba(0, 230, 118, 0.05));
    border-color: rgba(0, 230, 118, 0.3);
    box-shadow: 0 6px 18px -10px rgba(0, 230, 118, 0.5);
}

.lh-status-danger .lh-device > i {
    color: #ff6b93;
    background: linear-gradient(135deg, rgba(255, 61, 113, 0.18), rgba(255, 61, 113, 0.05));
    border-color: rgba(255, 61, 113, 0.3);
    box-shadow: 0 6px 18px -10px rgba(255, 61, 113, 0.5);
}

.lh-status-neutral .lh-device > i {
    color: #cbd5e1;
}

.lh-current .lh-device > i {
    animation: lhDevicePulse 2.4s ease-in-out infinite;
}

@keyframes lhDevicePulse {
    0%, 100% { box-shadow: 0 0 0 0 rgba(0, 230, 118, 0.4), 0 6px 18px -10px rgba(0, 230, 118, 0.5); }
    50%      { box-shadow: 0 0 0 6px rgba(0, 230, 118, 0),   0 6px 18px -10px rgba(0, 230, 118, 0.5); }
}

/* Main column */
.lh-main {
    min-width: 0;
}

.lh-top {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 10px;
    align-items: center;
    margin-bottom: 8px;
}

.lh-status-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 0.8rem;
    font-weight: 700;
    padding: 4px 10px;
    border-radius: 7px;
    font-family: var(--font-heading);
    background: rgba(148, 163, 184, 0.12);
    color: var(--text-light);
    letter-spacing: 0.2px;
}

.lh-status-badge i {
    font-size: 0.82rem;
}

.lh-status-success .lh-status-badge {
    background: linear-gradient(135deg, rgba(0, 230, 118, 0.18), rgba(0, 230, 118, 0.08));
    color: #00e676;
    border: 1px solid rgba(0, 230, 118, 0.25);
}

.lh-status-danger .lh-status-badge {
    background: linear-gradient(135deg, rgba(255, 61, 113, 0.18), rgba(255, 61, 113, 0.08));
    color: #ff6b93;
    border: 1px solid rgba(255, 61, 113, 0.25);
}

.lh-status-neutral .lh-status-badge {
    background: rgba(148, 163, 184, 0.14);
    border: 1px solid rgba(148, 163, 184, 0.22);
    color: #cbd5e1;
}

.lh-current-tag {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 0.7rem;
    font-weight: 700;
    padding: 4px 10px;
    border-radius: 7px;
    background: linear-gradient(135deg, var(--primary), var(--secondary));
    color: #fff;
    text-transform: uppercase;
    letter-spacing: 0.6px;
    box-shadow: 0 6px 16px -8px rgba(var(--primary-rgb), 0.65);
}

.lh-current-tag i {
    font-size: 0.55rem;
    animation: lhDotBlink 1.4s ease-in-out infinite;
}

@keyframes lhDotBlink {
    0%, 100% { opacity: 1; }
    50%      { opacity: 0.3; }
}

.lh-relative {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    margin-left: auto;
    font-size: 0.77rem;
    color: var(--text-muted);
    font-weight: 500;
    padding: 3px 8px;
    background: rgba(255, 255, 255, 0.03);
    border-radius: 6px;
}

.lh-relative[title]:not([title=""]) {
    cursor: help;
}

.lh-relative i {
    font-size: 0.72rem;
    opacity: 0.7;
}

.lh-note-row {
    font-size: 0.82rem;
    color: var(--text-muted);
    margin-bottom: 10px;
    padding-left: 2px;
    font-style: italic;
}

/* Meta grid */
.lh-meta {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 8px 14px;
}

.lh-meta-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 10px;
    background: rgba(255, 255, 255, 0.025);
    border: 1px solid rgba(255, 255, 255, 0.045);
    border-radius: 8px;
    min-width: 0;
}

.lh-meta-item i {
    color: var(--primary);
    font-size: 0.95rem;
    width: 22px;
    text-align: center;
    flex-shrink: 0;
    opacity: 0.85;
}

.lh-meta-item em {
    font-style: normal;
    font-size: 0.68rem;
    text-transform: uppercase;
    letter-spacing: 0.6px;
    color: var(--text-muted);
    font-weight: 600;
    margin-right: 2px;
    font-family: var(--font-heading);
}

.lh-meta-item b {
    font-weight: 600;
    font-size: 0.85rem;
    color: var(--text-light);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    min-width: 0;
    flex: 1;
}

/* Responsive */
@media (max-width: 820px) {
    .lh-relative {
        margin-left: 0;
        order: 3;
        width: 100%;
    }
}

@media (max-width: 720px) {
    .login-history-card {
        padding: 22px 18px;
    }
    .login-history-head {
        gap: 12px;
    }
    .login-history-title {
        font-size: 1.02rem;
    }
    .login-history-item {
        padding: 14px 14px 14px 12px;
        gap: 12px;
    }
    .lh-device {
        width: 48px;
    }
    .lh-device > i {
        width: 42px;
        height: 42px;
        font-size: 1.1rem;
        border-radius: 11px;
    }
    .lh-device-label {
        font-size: 0.6rem;
    }
    .lh-meta {
        grid-template-columns: 1fr 1fr;
        gap: 6px 8px;
    }
    .lh-meta-item {
        padding: 7px 9px;
        gap: 7px;
    }
    .lh-meta-item em {
        display: none;
    }
    .lh-meta-item b {
        font-size: 0.8rem;
    }
    .lh-chip-label {
        display: none;
    }
    .lh-chip {
        padding: 6px 10px;
    }
}

@media (max-width: 430px) {
    .login-history-item {
        grid-template-columns: 1fr;
    }
    .lh-device {
        flex-direction: row;
        width: auto;
        gap: 10px;
    }
    .lh-device > i {
        width: 38px;
        height: 38px;
        font-size: 1rem;
    }
    .lh-device-label {
        font-size: 0.72rem;
        letter-spacing: 0.5px;
    }
    .lh-meta {
        grid-template-columns: 1fr;
    }
    .lh-meta-item em {
        display: inline;
    }
}

/* ============================================================
   Auth pages — polish & mobile responsiveness
   (login / register / forgot / reset)
   ============================================================ */

/* Subtle ambient glow behind auth card */
.auth-wrap {
    position: relative;
    isolation: isolate;
}

.auth-wrap::before {
    content: '';
    position: absolute;
    inset: -40px 0;
    z-index: -1;
    background:
        radial-gradient(circle at 20% 20%, rgba(var(--primary-rgb), 0.12), transparent 55%),
        radial-gradient(circle at 80% 80%, rgba(var(--secondary-rgb), 0.1), transparent 55%);
    filter: blur(40px);
    opacity: 0.6;
    pointer-events: none;
}

/* Card entrance */
.auth-card {
    animation: authCardIn 0.5s cubic-bezier(.25,.8,.4,1) both;
}

@keyframes authCardIn {
    from { opacity: 0; transform: translateY(14px) scale(0.985); }
    to   { opacity: 1; transform: translateY(0)    scale(1); }
}

/* Animated gradient border at top of card */
.auth-card::before {
    background: linear-gradient(90deg,
        transparent 0%,
        rgba(var(--primary-rgb), 0.55) 25%,
        rgba(var(--secondary-rgb), 0.6) 50%,
        rgba(255, 61, 113, 0.5) 75%,
        transparent 100%);
    background-size: 250% 100%;
    animation: authTopShine 6s ease-in-out infinite;
}

@keyframes authTopShine {
    0%,100% { background-position: 0% 50%; }
    50%     { background-position: 100% 50%; }
}

/* Icon: add subtle pulse ring */
.auth-card-icon {
    position: relative;
    box-shadow: 0 10px 30px rgba(var(--primary-rgb), 0.15);
}

.auth-card-icon::after {
    content: '';
    position: absolute;
    inset: -6px;
    border-radius: inherit;
    border: 1px solid rgba(var(--primary-rgb), 0.18);
    opacity: 0;
    animation: authIconPulse 2.4s ease-out infinite;
}

@keyframes authIconPulse {
    0%   { opacity: 0.55; transform: scale(0.95); }
    60%  { opacity: 0;    transform: scale(1.15); }
    100% { opacity: 0;    transform: scale(1.25); }
}

/* Input: slight lift when focused + placeholder color */
.auth-form-group input::placeholder,
.auth-form-group textarea::placeholder {
    color: rgba(148, 163, 184, 0.55);
}

.auth-form-group input:focus {
    border-color: rgba(var(--primary-rgb), 0.6);
    box-shadow:
        0 0 0 4px rgba(var(--primary-rgb), 0.08),
        0 6px 18px -10px rgba(var(--primary-rgb), 0.3);
    background: rgba(12, 20, 40, 0.8);
}

/* Field-valid / field-error styling (used by register.php) */
.auth-form-group input.field-valid,
.auth-form-group textarea.field-valid,
.auth-form-group select.field-valid {
    border-color: rgba(0, 230, 118, 0.45);
}
.auth-form-group input.field-error,
.auth-form-group textarea.field-error,
.auth-form-group select.field-error {
    border-color: rgba(255, 61, 113, 0.55);
    box-shadow: 0 0 0 3px rgba(255, 61, 113, 0.08);
}

/* Submit button — add shimmer + loading state */
.btn-auth-submit {
    position: relative;
    overflow: hidden;
    letter-spacing: 0.3px;
}

.btn-auth-submit::after {
    content: '';
    position: absolute;
    top: 0; left: -80%;
    width: 50%; height: 100%;
    background: linear-gradient(100deg, transparent, rgba(255,255,255,0.18), transparent);
    transform: skewX(-20deg);
    transition: left 0.9s ease;
    pointer-events: none;
}

.btn-auth-submit:hover::after {
    left: 130%;
}

.btn-auth-submit.is-loading,
.btn.is-loading {
    color: transparent !important;
    pointer-events: none;
    opacity: 0.85;
    position: relative;
}
.btn.is-loading > * {
    visibility: hidden;
}

.btn-auth-submit.is-loading::before {
    content: '';
    position: absolute;
    top: 50%; left: 50%;
    width: 18px; height: 18px;
    margin: -9px 0 0 -9px;
    border: 2px solid rgba(255, 255, 255, 0.35);
    border-top-color: #fff;
    border-radius: 50%;
    animation: authSpin 0.7s linear infinite;
}

/* Generic .btn spinner (uses ::after because ::before is occupied by .btn-primary gradient) */
.btn.is-loading::after {
    content: '';
    position: absolute;
    top: 50%; left: 50%;
    width: 18px; height: 18px;
    margin: -9px 0 0 -9px;
    border: 2px solid rgba(255, 255, 255, 0.35);
    border-top-color: #fff;
    border-radius: 50%;
    animation: authSpin 0.7s linear infinite;
    z-index: 3;
}

@keyframes authSpin {
    to { transform: rotate(360deg); }
}

/* Cool-down / anti-flood state for any submit button */
.btn-auth-submit.is-cooldown,
.btn.is-cooldown {
    pointer-events: none;
    cursor: not-allowed;
    opacity: 0.75;
    background: linear-gradient(135deg, rgba(148, 163, 184, 0.35), rgba(99, 102, 241, 0.35)) !important;
    box-shadow: none !important;
    letter-spacing: 0.3px;
}
.btn-auth-submit.is-cooldown i,
.btn.is-cooldown i {
    animation: authSpin 1.6s linear infinite;
    opacity: 0.9;
}

/* Improve password strength bar look */
.auth-password-strength {
    padding: 2px 0 2px;
}

.auth-strength-bar {
    height: 6px;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.04);
}

/* ---- Mobile (≤ 720px): compact hero + card paddings ---- */
@media (max-width: 720px) {
    .internal-hero {
        padding: 120px 0 50px;
    }

    .internal-hero h1 {
        font-size: 2.1rem;
        line-height: 1.2;
        margin-bottom: 12px;
    }

    .internal-hero p {
        font-size: 0.95rem;
    }

    .page-section {
        padding: 40px 0 70px;
    }

    .auth-card {
        padding: 28px 22px;
        border-radius: var(--radius-md);
    }

    .auth-card-header {
        margin-bottom: 24px;
    }

    .auth-card-icon {
        width: 56px;
        height: 56px;
        font-size: 1.35rem;
        margin-bottom: 14px;
    }

    .auth-card-header h2 {
        font-size: 1.4rem;
    }

    .auth-card-header p {
        font-size: 0.88rem;
    }

    /* Stack two-column rows */
    .auth-form-row {
        grid-template-columns: 1fr;
        gap: 0;
    }

    /* Bigger tap targets */
    .auth-form-group input[type="text"],
    .auth-form-group input[type="email"],
    .auth-form-group input[type="password"],
    .auth-form-group input[type="tel"],
    .auth-form-group textarea,
    .auth-form-group select {
        padding: 13px 14px;
        font-size: 16px; /* prevents iOS auto-zoom */
    }

    .btn-auth-submit {
        padding: 15px;
        font-size: 1rem;
        min-height: 50px;
    }

    .auth-eye-btn,
    .auth-input-wrap-actions .auth-action-btn {
        padding: 8px;
        width: 36px;
        height: 36px;
    }

    .auth-input-wrap-actions input {
        padding-right: 86px !important;
    }

    /* Generate-password button shrinks / wraps */
    .auth-form-group label .auth-generate-btn {
        padding: 4px 9px;
        font-size: 0.72rem;
    }
    .auth-form-group label .auth-generate-btn span {
        display: none; /* show icon only on very small screens */
    }

    .auth-divider {
        margin: 18px 0;
    }

    .auth-success-icon {
        width: 68px;
        height: 68px;
        font-size: 1.6rem;
    }

    /* Register page-specific: lighter section gap */
    .reg-section {
        margin-bottom: 22px;
    }
    .reg-section-title {
        font-size: 0.95rem;
    }
    .reg-3col {
        grid-template-columns: 1fr !important;
    }
}

/* ---- Ultra small (≤ 380px) ---- */
@media (max-width: 380px) {
    .auth-card {
        padding: 22px 16px;
    }
    .internal-hero h1 {
        font-size: 1.85rem;
    }
    .auth-card-header h2 {
        font-size: 1.25rem;
    }
}

/* Respect iOS/Android safe areas */
@supports (padding: max(0px)) {
    .auth-wrap {
        padding-left:  max(0px, env(safe-area-inset-left));
        padding-right: max(0px, env(safe-area-inset-right));
    }
}

/* ============================================================
   Toast Notifications  (js/toast.js)
   ============================================================ */
.vt-toast-container {
    position: fixed;
    top: 24px;
    right: 24px;
    z-index: 2147483000;
    display: flex;
    flex-direction: column;
    gap: 12px;
    max-width: calc(100vw - 32px);
    width: 400px;
    pointer-events: none;
}

.vt-toast {
    position: relative;
    display: grid;
    grid-template-columns: 48px 1fr auto;
    align-items: flex-start;
    gap: 12px;
    padding: 14px 14px 14px 14px;
    border-radius: 14px;
    background: linear-gradient(145deg,
        rgba(24, 28, 42, 0.96) 0%,
        rgba(18, 22, 34, 0.96) 100%);
    border: 1px solid rgba(255, 255, 255, 0.07);
    box-shadow:
        0 20px 50px rgba(0, 0, 0, 0.45),
        0 6px 16px rgba(0, 0, 0, 0.28),
        inset 0 1px 0 rgba(255, 255, 255, 0.04);
    color: #e8ecf5;
    font-size: 0.92rem;
    line-height: 1.55;
    overflow: hidden;
    pointer-events: auto;
    transform: translateX(120%);
    opacity: 0;
    transition:
        transform 0.32s cubic-bezier(.22,.9,.3,1),
        opacity 0.22s ease;
    backdrop-filter: blur(14px) saturate(140%);
    -webkit-backdrop-filter: blur(14px) saturate(140%);
}

.vt-toast.in  { transform: translateX(0);   opacity: 1; }
.vt-toast.out { transform: translateX(120%); opacity: 0; }

.vt-toast-icon {
    width: 44px;
    height: 44px;
    border-radius: 12px;
    display: grid;
    place-items: center;
    font-size: 1.35rem;
    flex-shrink: 0;
    color: #fff;
}

.vt-toast-success .vt-toast-icon {
    background: linear-gradient(135deg, #16c784 0%, #0aa56b 100%);
    box-shadow: 0 10px 24px -10px rgba(16, 199, 132, 0.6);
}
.vt-toast-error .vt-toast-icon {
    background: linear-gradient(135deg, #ef4444 0%, #b91c1c 100%);
    box-shadow: 0 10px 24px -10px rgba(239, 68, 68, 0.6);
}
.vt-toast-warning .vt-toast-icon {
    background: linear-gradient(135deg, #f59e0b 0%, #d97706 100%);
    box-shadow: 0 10px 24px -10px rgba(245, 158, 11, 0.55);
}
.vt-toast-info .vt-toast-icon {
    background: linear-gradient(135deg,
        rgba(var(--primary-rgb), 1) 0%,
        rgba(var(--primary-rgb), 0.7) 100%);
    box-shadow: 0 10px 24px -10px rgba(var(--primary-rgb), 0.55);
}

.vt-toast-body { min-width: 0; padding-top: 2px; }

.vt-toast-title {
    font-size: 0.95rem;
    font-weight: 700;
    color: #fff;
    margin-bottom: 2px;
    letter-spacing: 0.2px;
}

.vt-toast-success .vt-toast-title { color: #5ee7b8; }
.vt-toast-error   .vt-toast-title { color: #ffb0b0; }
.vt-toast-warning .vt-toast-title { color: #ffd78a; }
.vt-toast-info    .vt-toast-title { color: rgba(var(--primary-rgb), 1); }

.vt-toast-msg {
    color: #cbd2e0;
    word-wrap: break-word;
    overflow-wrap: anywhere;
}

.vt-toast-close {
    appearance: none;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.08);
    color: #a2adc0;
    width: 28px;
    height: 28px;
    border-radius: 8px;
    cursor: pointer;
    font-size: 0.85rem;
    display: grid;
    place-items: center;
    transition: all 0.18s ease;
    flex-shrink: 0;
}
.vt-toast-close:hover {
    background: rgba(255, 255, 255, 0.1);
    color: #fff;
    transform: rotate(90deg);
}

.vt-toast-progress {
    position: absolute;
    left: 0; right: 0; bottom: 0;
    height: 3px;
    background: rgba(255, 255, 255, 0.04);
    overflow: hidden;
}
.vt-toast-progress-fill {
    height: 100%;
    width: 100%;
    transform-origin: left center;
    transform: scaleX(1);
}
.vt-toast-success .vt-toast-progress-fill { background: linear-gradient(90deg, #16c784, #0aa56b); }
.vt-toast-error   .vt-toast-progress-fill { background: linear-gradient(90deg, #ef4444, #b91c1c); }
.vt-toast-warning .vt-toast-progress-fill { background: linear-gradient(90deg, #f59e0b, #d97706); }
.vt-toast-info    .vt-toast-progress-fill {
    background: linear-gradient(90deg,
        rgba(var(--primary-rgb), 1),
        rgba(var(--primary-rgb), 0.6));
}

@media (max-width: 520px) {
    .vt-toast-container {
        top: 12px;
        right: 12px;
        left: 12px;
        width: auto;
        max-width: none;
    }
    .vt-toast {
        grid-template-columns: 42px 1fr auto;
        padding: 12px;
        border-radius: 12px;
        font-size: 0.88rem;
    }
    .vt-toast-icon { width: 38px; height: 38px; font-size: 1.15rem; }
}

/* ============================================================
   Remember-me checkbox + Forgot link row on login form
   ============================================================ */
.auth-form-meta-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin: -4px 0 10px;
    flex-wrap: wrap;
}

.auth-remember {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    user-select: none;
    font-size: 0.88rem;
    color: var(--text-muted);
    padding: 6px 4px;
}
.auth-remember input[type="checkbox"] {
    appearance: none;
    -webkit-appearance: none;
    width: 18px;
    height: 18px;
    border-radius: 5px;
    border: 1.5px solid rgba(255, 255, 255, 0.18);
    background: rgba(255, 255, 255, 0.02);
    cursor: pointer;
    position: relative;
    transition: all 0.18s ease;
    flex-shrink: 0;
}
.auth-remember input[type="checkbox"]:hover {
    border-color: rgba(var(--primary-rgb), 0.5);
    background: rgba(var(--primary-rgb), 0.06);
}
.auth-remember input[type="checkbox"]:checked {
    background: linear-gradient(135deg,
        rgba(var(--primary-rgb), 1),
        rgba(var(--primary-rgb), 0.75));
    border-color: rgba(var(--primary-rgb), 1);
    box-shadow: 0 4px 12px -4px rgba(var(--primary-rgb), 0.55);
}
.auth-remember input[type="checkbox"]:checked::after {
    content: "\2713";
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    color: #fff;
    font-size: 11px;
    font-weight: 900;
    line-height: 1;
}
.auth-remember:hover { color: #e7ebf5; }

.auth-remember-note {
    font-size: 0.76rem;
    color: var(--text-muted);
    opacity: 0.75;
    display: inline-flex;
    align-items: center;
    gap: 5px;
}
.auth-remember-note i { font-size: 0.72rem; }
@media (max-width: 420px) {
    .auth-remember-note { display: none; }
}

/* ======================================================
   Domain inline check — button states & result panel
   ====================================================== */
#domainCheckBtn,
#hostBundleWhoisBtn {
    position: relative;
    min-width: 140px;
}
#domainCheckBtn .btn-loading,
#hostBundleWhoisBtn .btn-loading { display: none; }
#domainCheckBtn.is-loading .btn-label,
#hostBundleWhoisBtn.is-loading .btn-label { visibility: hidden; }
#domainCheckBtn.is-loading .btn-loading,
#hostBundleWhoisBtn.is-loading .btn-loading {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    position: absolute;
    inset: 0;
    justify-content: center;
}
#domainCheckBtn:disabled,
#hostBundleWhoisBtn:disabled { cursor: progress; opacity: 0.92; }

.domain-result-panel {
    margin-top: 24px;
    opacity: 0;
    transform: translateY(8px);
    transition: opacity .3s ease, transform .3s ease;
    pointer-events: none;
}
.domain-result-panel.is-visible {
    opacity: 1;
    transform: none;
    pointer-events: auto;
}
.domain-result-panel.is-loading {
    opacity: 0.55;
}

/* ---------- Card (centered hero style) ---------- */
.domain-result-card {
    --drc-accent: #22c55e;
    --drc-accent-2: #16a34a;
    --drc-tint: rgba(34,197,94,0.18);
    --drc-glow: rgba(34,197,94,0.45);

    position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 14px;
    padding: 40px 28px 32px;
    border-radius: 22px;
    border: 1px solid rgba(255,255,255,0.08);
    background:
        radial-gradient(800px 220px at 50% -40px, var(--drc-tint), transparent 70%),
        linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01));
    box-shadow:
        0 30px 70px -40px rgba(0,0,0,0.6),
        0 0 0 1px rgba(255,255,255,0.02) inset,
        0 60px 120px -60px var(--drc-glow);
    animation: drcFadeIn .45s cubic-bezier(.2,.8,.2,1) both;
}
.domain-result-card::before {
    /* subtle top accent bar */
    content: '';
    position: absolute;
    top: 0; left: 10%; right: 10%;
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--drc-accent), transparent);
    opacity: 0.55;
}
.domain-result-card::after {
    /* soft ambient halo behind icon */
    content: '';
    position: absolute;
    top: -60px;
    left: 50%;
    transform: translateX(-50%);
    width: 220px;
    height: 220px;
    border-radius: 50%;
    background: radial-gradient(circle, var(--drc-tint), transparent 65%);
    pointer-events: none;
    filter: blur(8px);
    opacity: .9;
}
@keyframes drcFadeIn {
    from { opacity: 0; transform: translateY(12px) scale(.98); }
    to   { opacity: 1; transform: none; }
}

/* Status badge — floating pill above icon */
.domain-result-card .drc-head {
    position: relative;
    z-index: 2;
    order: 1;
    display: flex;
    justify-content: center;
    margin-bottom: 2px;
}
.domain-result-card .drc-status-label {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.6px;
    text-transform: uppercase;
    padding: 6px 14px;
    border-radius: 999px;
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.1);
    color: #fff;
    backdrop-filter: blur(6px);
}
.domain-result-card .drc-status-label::before {
    content: '';
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--drc-accent);
    box-shadow: 0 0 10px var(--drc-accent);
}

/* Large status icon */
.domain-result-card .drc-icon {
    position: relative;
    z-index: 2;
    order: 2;
    width: 84px;
    height: 84px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.1rem;
    color: #fff;
    background: linear-gradient(145deg, var(--drc-accent), var(--drc-accent-2));
    box-shadow:
        0 18px 40px -14px var(--drc-glow),
        0 0 0 6px rgba(255,255,255,0.03),
        0 0 0 12px rgba(255,255,255,0.015);
    animation: drcIconPop .55s cubic-bezier(.2,.8,.2,1) both;
}
@keyframes drcIconPop {
    from { opacity: 0; transform: scale(.6); }
    to   { opacity: 1; transform: scale(1); }
}

.domain-result-card .drc-body {
    position: relative;
    z-index: 2;
    order: 3;
    display: contents;
}
.domain-result-card .drc-domain {
    order: 3;
    font-size: 1.9rem;
    line-height: 1.15;
    font-weight: 800;
    color: #fff;
    word-break: break-all;
    margin: 4px 0 0;
    letter-spacing: -0.01em;
    background: linear-gradient(180deg, #fff, rgba(255,255,255,0.7));
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}
.domain-result-card .drc-idn {
    order: 4;
    font-size: 0.85rem;
    color: rgba(255,255,255,0.65);
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
.domain-result-card .drc-idn code {
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.08);
    padding: 3px 10px;
    border-radius: 999px;
    font-size: 0.82rem;
    color: #fff;
}
.domain-result-card .drc-message {
    order: 5;
    color: rgba(255,255,255,0.72);
    font-size: 0.98rem;
    margin: 0;
    max-width: 560px;
}

/* Actions row */
.domain-result-card .drc-actions {
    order: 6;
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: center;
    justify-content: center;
    margin-top: 10px;
}
.domain-result-card .drc-price {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 18px;
    border-radius: 12px;
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.1);
    color: #fff;
    font-size: 0.95rem;
    transition: all .2s ease;
}
.domain-result-card .drc-price:hover {
    background: rgba(255,255,255,0.08);
    transform: translateY(-1px);
}
.domain-result-card .drc-price strong {
    font-size: 1.08rem;
    color: #fff;
    font-weight: 800;
}
.domain-result-card .drc-price i {
    color: var(--drc-accent);
}
.domain-result-card .drc-buy-btn {
    font-weight: 700;
    padding: 12px 22px;
    border-radius: 12px;
    box-shadow: 0 15px 35px -12px var(--drc-glow);
    transition: transform .2s ease, box-shadow .2s ease;
}
.domain-result-card .drc-buy-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 20px 45px -10px var(--drc-glow);
}

/* ---------- Status color variants ---------- */
.domain-result-card.status-available {
    --drc-accent: #22c55e;
    --drc-accent-2: #16a34a;
    --drc-tint: rgba(34,197,94,0.22);
    --drc-glow: rgba(34,197,94,0.55);
    border-color: rgba(34,197,94,0.28);
}
.domain-result-card.status-available .drc-status-label {
    color: #bbf7d0;
    background: rgba(34,197,94,0.15);
    border-color: rgba(34,197,94,0.35);
}

.domain-result-card.status-taken {
    --drc-accent: #ef4444;
    --drc-accent-2: #dc2626;
    --drc-tint: rgba(239,68,68,0.22);
    --drc-glow: rgba(239,68,68,0.5);
    border-color: rgba(239,68,68,0.28);
}
.domain-result-card.status-taken .drc-status-label {
    color: #fecaca;
    background: rgba(239,68,68,0.15);
    border-color: rgba(239,68,68,0.35);
}

.domain-result-card.status-unknown {
    --drc-accent: #f59e0b;
    --drc-accent-2: #d97706;
    --drc-tint: rgba(245,158,11,0.22);
    --drc-glow: rgba(245,158,11,0.45);
    border-color: rgba(245,158,11,0.28);
}
.domain-result-card.status-unknown .drc-status-label {
    color: #fde68a;
    background: rgba(245,158,11,0.15);
    border-color: rgba(245,158,11,0.35);
}

.domain-result-card.status-error {
    --drc-accent: #ef4444;
    --drc-accent-2: #b91c1c;
    --drc-tint: rgba(239,68,68,0.18);
    --drc-glow: rgba(239,68,68,0.4);
    border-color: rgba(239,68,68,0.28);
}
.domain-result-card.status-error .drc-status-label {
    color: #fecaca;
    background: rgba(239,68,68,0.15);
    border-color: rgba(239,68,68,0.35);
}

/* ---------- Responsive ---------- */
@media (max-width: 640px) {
    .domain-result-card {
        padding: 32px 20px 24px;
        gap: 12px;
        border-radius: 18px;
    }
    .domain-result-card::after {
        width: 180px;
        height: 180px;
        top: -50px;
    }
    .domain-result-card .drc-icon {
        width: 72px;
        height: 72px;
        font-size: 1.8rem;
    }
    .domain-result-card .drc-domain { font-size: 1.45rem; }
    .domain-result-card .drc-message { font-size: 0.92rem; }
    .domain-result-card .drc-actions {
        width: 100%;
        flex-direction: column;
        gap: 10px;
    }
    .domain-result-card .drc-actions > * {
        width: 100%;
    }
}

/* ════════════════════════════════════════════════════════════════════
   CART PAGE
   ════════════════════════════════════════════════════════════════════ */
.cart-empty {
    text-align: center;
    padding: 80px 30px;
    background: linear-gradient(180deg, rgba(108,99,255,0.06), rgba(108,99,255,0.01));
    border: 1px dashed rgba(108,99,255,0.3);
    border-radius: 24px;
    max-width: 640px;
    margin: 0 auto;
}
.cart-empty-icon {
    font-size: 4rem;
    color: #6c63ff;
    margin-bottom: 16px;
    opacity: 0.7;
}
.cart-empty h3 {
    color: #fff;
    font-size: 1.5rem;
    margin-bottom: 10px;
}
.cart-empty p {
    color: #8892a4;
    margin-bottom: 24px;
}
.cart-empty-actions {
    display: flex;
    gap: 10px;
    justify-content: center;
    flex-wrap: wrap;
}

.cart-layout {
    display: grid;
    grid-template-columns: 1fr 360px;
    gap: 28px;
    align-items: start;
}
.cart-items {
    display: flex;
    flex-direction: column;
    gap: 16px;
}
.cart-item {
    display: grid;
    grid-template-columns: 64px 1fr auto;
    gap: 18px;
    padding: 20px;
    background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.01));
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 16px;
    transition: all .2s;
}
.cart-item:hover {
    border-color: rgba(108,99,255,0.35);
    transform: translateY(-2px);
    box-shadow: 0 20px 40px -20px rgba(108,99,255,0.4);
}
.cart-item-icon {
    width: 56px;
    height: 56px;
    border-radius: 14px;
    background: linear-gradient(135deg, #6c63ff, #4e4ab9);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 1.4rem;
    box-shadow: 0 10px 25px -8px rgba(108,99,255,0.6);
}
.cart-item-type {
    display: inline-block;
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: #6c63ff;
    font-weight: 700;
    padding: 4px 10px;
    background: rgba(108,99,255,0.1);
    border-radius: 20px;
    margin-bottom: 6px;
}
.cart-item-name {
    font-size: 1.15rem;
    color: #fff;
    margin: 0 0 6px;
    font-weight: 700;
}
.cart-item-desc {
    color: #8892a4;
    font-size: 0.88rem;
    margin: 0 0 10px;
    line-height: 1.5;
}
.cart-item-meta {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
    font-size: 0.82rem;
    color: #8892a4;
}
.cart-item-meta i {
    color: #6c63ff;
    margin-right: 4px;
}
.cart-item-price {
    text-align: right;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: flex-end;
    gap: 8px;
}
.cart-item-total {
    font-size: 1.3rem;
    font-weight: 800;
    color: #fff;
    background: linear-gradient(135deg, #6c63ff, #a78bfa);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}
.cart-item-unit {
    font-size: 0.78rem;
    color: #8892a4;
}
.cart-item-remove {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    background: rgba(239,68,68,0.1);
    color: #ef4444;
    border: 1px solid rgba(239,68,68,0.25);
    border-radius: 8px;
    font-size: 0.82rem;
    text-decoration: none;
    transition: all .15s;
}
.cart-item-remove:hover {
    background: rgba(239,68,68,0.2);
    color: #fecaca;
}

.cart-summary {
    position: sticky;
    top: 100px;
    padding: 24px;
    background: linear-gradient(180deg, rgba(108,99,255,0.08), rgba(255,255,255,0.02));
    border: 1px solid rgba(108,99,255,0.25);
    border-radius: 20px;
    box-shadow: 0 30px 60px -30px rgba(108,99,255,0.4);
}
.cart-summary-title {
    font-size: 1.1rem;
    color: #fff;
    margin: 0 0 18px;
    padding-bottom: 14px;
    border-bottom: 1px solid rgba(255,255,255,0.08);
}
.cart-summary-row {
    display: flex;
    justify-content: space-between;
    padding: 8px 0;
    font-size: 0.92rem;
    color: #cbd5e1;
}
.cart-summary-divider {
    margin: 12px 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(108,99,255,0.3), transparent);
}
.cart-summary-total {
    font-size: 1.15rem;
    font-weight: 800;
    color: #fff;
}
.cart-summary-total span:last-child {
    background: linear-gradient(135deg, #6c63ff, #a78bfa);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}
.cart-checkout-btn {
    margin-top: 18px;
    padding: 14px 20px;
    font-size: 1rem;
    font-weight: 700;
}
.cart-clear-link {
    display: block;
    text-align: center;
    margin-top: 10px;
    color: #8892a4;
    font-size: 0.85rem;
    text-decoration: none;
    padding: 8px;
    transition: color .15s;
}
.cart-clear-link:hover {
    color: #ef4444;
}

/* ════════════════════════════════════════════════════════════════════
   ORDER / CHECKOUT PAGE
   ════════════════════════════════════════════════════════════════════ */
.order-steps {
    display: flex;
    gap: 8px;
    margin-bottom: 28px;
    flex-wrap: wrap;
}
.order-step {
    flex: 1;
    min-width: 140px;
    padding: 12px 16px;
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 12px;
    color: #8892a4;
    font-size: 0.88rem;
    display: flex;
    align-items: center;
    gap: 10px;
    font-weight: 500;
    transition: all .2s;
}
.order-step span {
    display: inline-flex;
    width: 26px;
    height: 26px;
    border-radius: 50%;
    align-items: center;
    justify-content: center;
    background: rgba(255,255,255,0.06);
    font-size: 0.82rem;
    font-weight: 700;
    color: #8892a4;
}
.order-step.is-complete {
    background: rgba(34,197,94,0.08);
    border-color: rgba(34,197,94,0.3);
    color: #22c55e;
}
.order-step.is-complete span {
    background: #22c55e;
    color: #fff;
}
.order-step.is-active {
    background: rgba(108,99,255,0.12);
    border-color: rgba(108,99,255,0.5);
    color: #fff;
    box-shadow: 0 10px 25px -12px rgba(108,99,255,0.5);
}
.order-step.is-active span {
    background: #6c63ff;
    color: #fff;
}

.order-alert {
    padding: 14px 18px;
    background: rgba(239,68,68,0.1);
    border: 1px solid rgba(239,68,68,0.3);
    border-radius: 12px;
    color: #fca5a5;
    margin-bottom: 20px;
    display: flex;
    align-items: center;
    gap: 10px;
}

.order-layout {
    display: grid;
    grid-template-columns: 1fr 360px;
    gap: 28px;
    align-items: start;
}
.order-main {
    display: flex;
    flex-direction: column;
    gap: 18px;
}
.order-panel {
    padding: 24px;
    background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.01));
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 18px;
}
.order-panel-title {
    font-size: 1.05rem;
    color: #fff;
    margin: 0 0 16px;
    padding-bottom: 12px;
    border-bottom: 1px solid rgba(255,255,255,0.06);
    display: flex;
    align-items: center;
    gap: 10px;
}
.order-panel-title i { color: #6c63ff; }
.order-panel--domain-addons { margin-top: 4px; }
.order-domain-addons {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.order-domain-addons__row {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 12px 14px;
    border-radius: 12px;
    border: 1px solid rgba(255, 255, 255, 0.1);
    background: rgba(0, 0, 0, 0.15);
    cursor: pointer;
    margin: 0;
    transition: border-color 0.15s, background 0.15s;
}
.order-domain-addons__row input {
    margin-top: 4px;
    flex-shrink: 0;
    accent-color: #7c3aed;
}
.order-domain-addons__row > span {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 2px;
    font-size: 0.95rem;
    line-height: 1.45;
}
.order-domain-addons__row--highlight {
    border-color: rgba(34, 197, 94, 0.25);
}
.order-domain-addons__price {
    font-weight: 700;
    color: #6ee7b7;
    margin-top: 2px;
}

.order-billing {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 12px;
}
.order-billing-opt { cursor: pointer; }
.order-billing-opt input { display: none; }
.order-billing-box {
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding: 16px 18px;
    background: rgba(255,255,255,0.03);
    border: 2px solid rgba(255,255,255,0.08);
    border-radius: 14px;
    transition: all .2s;
}
.order-billing-opt input:checked + .order-billing-box {
    background: rgba(108,99,255,0.12);
    border-color: #6c63ff;
    box-shadow: 0 10px 30px -12px rgba(108,99,255,0.5);
}
.obb-period {
    font-size: 0.82rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: #8892a4;
    font-weight: 700;
    display: flex;
    align-items: center;
    gap: 8px;
}
.order-billing-opt input:checked + .order-billing-box .obb-period { color: #fff; }
.obb-badge {
    background: linear-gradient(135deg, #22c55e, #10b981);
    color: #fff !important;
    font-size: 0.68rem !important;
    padding: 3px 8px;
    border-radius: 20px;
    letter-spacing: 0.3px !important;
    font-weight: 700 !important;
}
.obb-price {
    font-size: 1.25rem;
    font-weight: 800;
    color: #fff;
}
.obb-price small {
    font-size: 0.75rem;
    color: #8892a4;
    font-weight: 500;
    margin-left: 4px;
}

.order-fields {
    display: grid;
    gap: 16px;
}
.order-field {
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.order-field label {
    font-size: 0.88rem;
    color: #e2e8f0;
    font-weight: 600;
}
.order-field .req {
    color: #ef4444;
    margin-left: 3px;
}
.order-field .form-control.is-invalid {
    border-color: #ef4444;
    box-shadow: 0 0 0 3px rgba(239,68,68,0.2);
}
.order-field-help {
    color: #8892a4;
    font-size: 0.78rem;
    padding-left: 2px;
}
.order-check {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 14px;
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 10px;
    cursor: pointer;
    color: #cbd5e1;
    width: fit-content;
}

.order-actions {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    margin-top: 8px;
    flex-wrap: wrap;
}
.order-actions .btn {
    min-width: 160px;
}

/* Review step */
.review-section {
    display: grid;
    grid-template-columns: 160px 1fr;
    gap: 14px;
    padding: 10px 0;
    align-items: start;
}
.review-label {
    font-size: 0.82rem;
    color: #8892a4;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.review-label-section {
    padding-top: 16px;
    color: #6c63ff;
    font-size: 0.85rem;
}
.review-value {
    color: #e2e8f0;
    line-height: 1.6;
}
.review-value small {
    color: #8892a4;
    font-size: 0.82rem;
    margin-left: 6px;
}
.review-specs {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}
.review-chip {
    padding: 4px 10px;
    background: rgba(108,99,255,0.1);
    color: #a78bfa;
    border-radius: 20px;
    font-size: 0.78rem;
    border: 1px solid rgba(108,99,255,0.2);
}

/* VMware spec tiles in review step — สวยงามและตรงประเด็น (CPU / RAM / Disk) */
.review-vmw-specs-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 10px;
    width: 100%;
}
.review-vmw-spec-tile {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 14px;
    background: linear-gradient(135deg, rgba(108,99,255,0.10) 0%, rgba(167,139,250,0.06) 100%);
    border: 1px solid rgba(167,139,250,0.22);
    border-radius: 12px;
    transition: border-color .18s ease, transform .18s ease, box-shadow .18s ease;
}
.review-vmw-spec-tile:hover {
    border-color: rgba(167,139,250,0.45);
    transform: translateY(-1px);
    box-shadow: 0 6px 18px rgba(108,99,255,0.18);
}
.review-vmw-spec-tile__icon {
    flex: 0 0 auto;
    width: 38px;
    height: 38px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    background: rgba(108,99,255,0.18);
    color: #c4b5fd;
    font-size: 1.05rem;
}
.review-vmw-spec-tile__body {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}
.review-vmw-spec-tile__label {
    font-size: 0.7rem;
    color: #8892a4;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    line-height: 1;
}
.review-vmw-spec-tile__value {
    font-size: 1.05rem;
    color: #f1f5f9;
    font-weight: 700;
    line-height: 1.2;
}
.review-vmw-spec-tile__unit {
    font-size: 0.78rem;
    color: #94a3b8;
    font-weight: 500;
    margin-left: 3px;
}
@media (max-width: 480px) {
    .review-vmw-specs-grid { grid-template-columns: 1fr; }
}
.review-value-password {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: rgba(108,99,255,0.06);
    border: 1px solid rgba(108,99,255,0.18);
    border-radius: 8px;
    padding: 6px 10px;
    max-width: 100%;
}
.review-pw {
    font-family: 'SF Mono', 'Menlo', 'Consolas', monospace;
    letter-spacing: 2px;
    color: #e2e8f0;
    word-break: break-all;
    min-width: 80px;
}
.review-pw[data-masked="0"] { letter-spacing: 0.5px; }
.review-pw-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    border-radius: 6px;
    background: rgba(108,99,255,0.15);
    color: #a78bfa;
    border: 1px solid rgba(108,99,255,0.25);
    cursor: pointer;
    transition: background 0.15s, color 0.15s;
    flex-shrink: 0;
}
.review-pw-toggle:hover {
    background: rgba(108,99,255,0.3);
    color: #fff;
}
.review-divider {
    margin: 12px 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.1), transparent);
}

/* Sticky summary sidebar */
.order-summary-box {
    position: sticky;
    top: 100px;
    padding: 24px;
    background: linear-gradient(180deg, rgba(108,99,255,0.08), rgba(255,255,255,0.02));
    border: 1px solid rgba(108,99,255,0.25);
    border-radius: 20px;
    box-shadow: 0 30px 60px -30px rgba(108,99,255,0.4);
}
.order-summary-title {
    font-size: 1.05rem;
    color: #fff;
    margin: 0 0 18px;
    padding-bottom: 14px;
    border-bottom: 1px solid rgba(255,255,255,0.08);
    display: flex;
    align-items: center;
    gap: 10px;
}
.order-summary-title i { color: #6c63ff; }
.order-summary-pkg {
    padding: 14px;
    background: rgba(108,99,255,0.08);
    border-radius: 12px;
    margin-bottom: 16px;
}
.osp-type {
    font-size: 0.7rem;
    color: #a78bfa;
    text-transform: uppercase;
    letter-spacing: 1px;
    font-weight: 700;
    margin-bottom: 4px;
}
.osp-name {
    font-size: 1.05rem;
    font-weight: 700;
    color: #fff;
}
.order-summary-row {
    display: flex;
    justify-content: space-between;
    padding: 8px 0;
    font-size: 0.92rem;
    color: #cbd5e1;
}
.order-summary-divider {
    margin: 12px 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(108,99,255,0.3), transparent);
}
.order-summary-total {
    font-size: 1.2rem;
    font-weight: 800;
    color: #fff;
}
.order-summary-total span:last-child {
    background: linear-gradient(135deg, #6c63ff, #a78bfa);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}
.order-summary-period {
    margin-top: 12px;
    padding: 10px;
    background: rgba(255,255,255,0.03);
    border-radius: 8px;
    font-size: 0.78rem;
    color: #8892a4;
    text-align: center;
}

@media (max-width: 960px) {
    .cart-layout, .order-layout {
        grid-template-columns: 1fr;
    }
    .cart-summary, .order-summary-box {
        position: static;
    }
    .cart-item {
        grid-template-columns: 48px 1fr;
    }
    .cart-item-price {
        grid-column: 1 / -1;
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
        text-align: left;
        padding-top: 12px;
        margin-top: 6px;
        border-top: 1px solid rgba(255,255,255,0.06);
    }
    .review-section {
        grid-template-columns: 1fr;
        gap: 4px;
    }
    .order-actions {
        flex-direction: column-reverse;
    }
    .order-actions .btn {
        width: 100%;
        justify-content: center;
        text-align: center;
    }
}

/* Domain-order summary card (shown on order.php when ?domain=X is used) */
.domain-order-card {
    display: grid;
    gap: 10px;
    padding: 16px 18px;
    background: linear-gradient(135deg, rgba(108,99,255,0.10), rgba(59,130,246,0.08));
    border: 1px solid rgba(108,99,255,0.25);
    border-radius: 14px;
}
.domain-order-card .doc-row {
    display: grid;
    grid-template-columns: 140px 1fr;
    gap: 12px;
    align-items: center;
    padding: 6px 0;
    border-bottom: 1px dashed rgba(255,255,255,0.06);
}
.domain-order-card .doc-row:last-child { border-bottom: 0; }
.domain-order-card .doc-label {
    font-size: 0.82rem;
    color: #8892a4;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.domain-order-card .doc-value {
    color: #e2e8f0;
    font-size: 1.02rem;
    line-height: 1.5;
}
.domain-order-card .doc-value strong { color: #fff; font-weight: 700; }
.domain-order-card .doc-value small {
    display: inline-block;
    margin-left: 6px;
    color: #8892a4;
    font-size: 0.82rem;
}
@media (max-width: 640px) {
    .domain-order-card .doc-row {
        grid-template-columns: 1fr;
        gap: 4px;
    }
}

/* Admin login-as-user: ขยาย padding หน้า hero ให้สอดคล้องกับแถบ (ต้องอยู่หลังกฎ .internal-hero ทั้งหมด) */
body.impersonating .internal-hero {
    padding-top: calc(160px + var(--impersonation-bar-height));
}
body.impersonating .dashboard-sidebar {
    top: calc(100px + var(--impersonation-bar-height));
}
@media (max-width: 1100px) {
    body.impersonating .internal-hero {
        padding-top: calc(130px + var(--impersonation-bar-height));
    }
}
@media (max-width: 720px) {
    body.impersonating .internal-hero {
        padding-top: calc(120px + var(--impersonation-bar-height));
    }
}

/* —— MFA flow (mfa-setup / mfa-verify): clear fixed navbar, compact header —— */
body.mfa-pending-auth .navbar .nav-links {
    display: none;
}
body.mfa-pending-auth .mobile-nav .mobile-nav-links {
    display: none;
}
.nav-mfa-pill {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 14px;
    border-radius: 999px;
    font-size: 0.86rem;
    font-weight: 600;
    color: var(--text-muted, #9aa4b2);
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.08);
    white-space: nowrap;
}
.nav-mfa-pill i { color: rgba(var(--primary-rgb, 99, 102, 241), 1); }
.mobile-nav-mfa-hint {
    text-align: center;
    color: var(--text-muted, #9aa4b2);
    font-size: 0.9rem;
    margin: 0 0 8px;
}
.mfa-auth-section {
    min-height: min(100dvh, 900px);
    padding-top: calc(96px + env(safe-area-inset-top, 0px));
    padding-bottom: max(32px, env(safe-area-inset-bottom, 0px));
}
body.impersonating.mfa-pending-auth .mfa-auth-section {
    padding-top: calc(96px + var(--impersonation-bar-height) + env(safe-area-inset-top, 0px));
}
.auth-wrap-mfa {
    max-width: 480px;
    margin: 0 auto;
}
.auth-wrap-mfa-wide {
    max-width: 720px;
}
.mfa-auth-title {
    font-size: clamp(1.35rem, 2.2vw, 1.6rem);
    font-weight: 800;
    margin: 0 0 6px;
    letter-spacing: -0.02em;
    line-height: 1.25;
}
.mfa-auth-lead {
    margin: 0;
    font-size: 0.95rem;
    line-height: 1.55;
    max-width: 42rem;
    margin-left: auto;
    margin-right: auto;
}
.mfa-method-card .auth-card-header {
    margin-bottom: 20px;
}
.mfa-method-tabs {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    margin-bottom: 24px;
}
.mfa-tab {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 14px 16px;
    border-radius: var(--radius-md, 12px);
    text-decoration: none;
    color: var(--text-muted, #9aa4b2);
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.08);
    font-weight: 600;
    font-size: 0.95rem;
    transition: background 0.2s, border-color 0.2s, color 0.2s;
}
.mfa-tab:hover {
    color: #e2e8f0;
    border-color: rgba(var(--primary-rgb, 99, 102, 241), 0.35);
    background: rgba(var(--primary-rgb, 99, 102, 241), 0.08);
}
.mfa-tab.is-active {
    color: #f1f5f9;
    border-color: rgba(var(--primary-rgb, 99, 102, 241), 0.55);
    background: linear-gradient(135deg, rgba(var(--primary-rgb, 99, 102, 241), 0.18), rgba(99, 102, 241, 0.06));
    box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.04) inset;
}
.mfa-panel {
    text-align: left;
}
.mfa-panel-icon-row {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 10px;
}
.mfa-panel-icon {
    width: 48px;
    height: 48px;
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    color: #fff;
    flex-shrink: 0;
}
.mfa-panel-title {
    font-size: 1.2rem;
    font-weight: 800;
    margin: 0;
    letter-spacing: -0.02em;
}
.mfa-panel-desc {
    color: var(--text-muted, #9aa4b2);
    font-size: 0.92rem;
    line-height: 1.6;
    margin: 0 0 20px;
}
.mfa-qr-wrap {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 20px;
    align-items: flex-start;
    margin-bottom: 24px;
}
.mfa-qr-box {
    background: #fff;
    padding: 12px;
    border-radius: 14px;
    flex-shrink: 0;
}
.mfa-qr-instructions { min-width: 0; }
.mfa-steps {
    margin: 0 0 14px 18px;
    padding: 0;
    color: var(--text-muted, #9aa4b2);
    font-size: 0.9rem;
    line-height: 1.65;
}
.mfa-secret-box {
    display: block;
    background: var(--bg-card, rgba(15, 18, 28, 0.6));
    border: 1px solid var(--border-color, rgba(255, 255, 255, 0.1));
    border-radius: 10px;
    padding: 12px 14px;
    font-family: ui-monospace, monospace;
    font-size: 0.85rem;
    color: var(--text-light, #e2e8f0);
    word-break: break-all;
    line-height: 1.45;
}
.mfa-code-input {
    text-align: center;
    letter-spacing: 0.4em;
    font-size: 1.4rem;
    font-weight: 700;
    padding: 12px 10px;
}
.mfa-hint { margin: 0 0 16px; font-size: 0.9rem; line-height: 1.5; }
.mfa-hint--muted { color: var(--text-muted, #9aa4b2); }
.mfa-resend {
    margin: 8px 0 0;
    text-align: center;
}
.mfa-resend-btn {
    display: inline-block;
    width: 100%;
    margin-top: 4px;
    padding: 12px 16px;
    background: transparent;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 10px;
    color: var(--text-muted, #9aa4b2);
    font: inherit;
    font-size: 0.9rem;
    font-weight: 600;
    cursor: pointer;
    transition: color 0.2s, border-color 0.2s, background 0.2s;
}
.mfa-resend-btn:hover {
    color: #e2e8f0;
    border-color: rgba(var(--primary-rgb, 99, 102, 241), 0.45);
    background: rgba(var(--primary-rgb, 99, 102, 241), 0.06);
}
.mfa-foot-link {
    text-align: center;
    margin: 20px 0 0;
    font-size: 0.88rem;
}
.mfa-foot-logout { color: var(--primary, #6c9fff) !important; }
@media (max-width: 640px) {
    .mfa-method-tabs {
        grid-template-columns: 1fr;
    }
    .mfa-qr-wrap {
        grid-template-columns: 1fr;
        justify-items: center;
        text-align: center;
    }
    .mfa-qr-instructions { width: 100%; }
    .mfa-steps { text-align: left; }
    .nav-mfa-pill span { display: none; }
    .mfa-auth-section { padding-top: calc(88px + env(safe-area-inset-top, 0px)); }
}

/* Domain registrar management (client order — shared block with admin partial) */
.client-order-detail .order-dreg {
  margin-top: 20px;
  padding: 22px 24px;
  border-radius: var(--radius-lg, 16px);
  border: 1px solid var(--border-color);
  background: var(--bg-card);
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.25);
}
.order-dreg__title { margin: 0 0 10px; font-size: 1.12rem; font-weight: 700; display: flex; align-items: center; gap: 10px; color: var(--text-light); }
.order-dreg__title .fa-globe { color: var(--primary); }
.order-dreg__lead { margin: 0 0 14px; font-size: 0.92rem; line-height: 1.55; color: var(--text-muted); }
.order-dreg__meta { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 12px; }
.order-dreg__pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 12px; border-radius: 999px; font-size: 0.82rem;
  background: rgba(255,255,255,.04); border: 1px solid var(--border-color);
  color: var(--text-muted);
}
.order-dreg__hint { font-size: 0.85rem; margin: 0 0 14px; }
.order-dreg__btn-main { border-radius: 999px; padding: 10px 18px; font-weight: 600; }
.order-dreg__status { min-height: 1.2em; font-size: 0.88rem; margin: 8px 0 6px; color: var(--success); }
.order-dreg__body { margin-top: 16px; padding-top: 16px; border-top: 1px solid var(--border-color); }
.order-dreg__h3 { font-size: 0.98rem; margin: 18px 0 10px; font-weight: 650; color: var(--text-light); }
.order-dreg__h3:first-child { margin-top: 0; }
.order-dreg__grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 12px 16px; }
.order-dreg__toggle { display: flex; align-items: flex-start; gap: 10px; margin: 8px 0 0; cursor: pointer; }
.order-dreg__epp-row { display: flex; flex-wrap: wrap; align-items: center; gap: 12px; margin-top: 8px; }
.order-dreg__epp-out {
  display: inline-block; padding: 10px 14px; border-radius: 10px;
  background: rgba(0,0,0,.25); border: 1px dashed rgba(255,255,255,.12);
  font-size: 0.95rem; word-break: break-all; min-width: 200px;
}
@media (max-width: 640px) { .order-dreg__grid { grid-template-columns: 1fr; } }

/* Registrar nameservers (client area) — สอดคล้อง layout ตาราง + ป้ายลำดับจาก dreg-nameservers.js */
.dreg-ns-sr {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.dreg-ns-wrap { margin: 0 0 4px; }
.dreg-ns-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(200px, 300px);
  gap: 18px 24px;
  align-items: start;
}
.dreg-ns-panel {
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: linear-gradient(165deg, rgba(30, 40, 80, 0.35) 0%, rgba(0, 0, 0, 0.25) 100%);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2), inset 0 1px 0 rgba(255, 255, 255, 0.05);
  overflow: hidden;
}
.dreg-ns-panel__head {
  display: grid;
  grid-template-columns: 48px 1fr;
  align-items: center;
  gap: 10px 14px;
  padding: 10px 14px 10px 12px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-muted, #8b9cb5);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(0, 0, 0, 0.2);
}
.dreg-ns-panel__th--idx { text-align: center; }
.dreg-ns-list { display: flex; flex-direction: column; }
.dreg-ns-list .dreg-ns-row:last-child { border-bottom: 0; }
.dreg-ns-row {
  display: grid;
  grid-template-columns: 48px 1fr;
  gap: 10px 14px;
  align-items: center;
  padding: 10px 14px 10px 12px;
  margin: 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  transition: background 0.12s ease;
}
.dreg-ns-row:hover { background: rgba(0, 210, 255, 0.04); }
.dreg-ns-idx {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  margin: 0 auto;
  border-radius: 10px;
  font-size: 0.8rem;
  font-weight: 800;
  color: #b8c5db;
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.08), rgba(0, 0, 0, 0.2));
  border: 1px solid rgba(255, 255, 255, 0.1);
}
.dreg-ns-idx--req {
  color: #fecdd3;
  border-color: rgba(248, 113, 113, 0.45);
  background: linear-gradient(145deg, rgba(220, 38, 38, 0.22), rgba(0, 0, 0, 0.18));
}
.dreg-ns-field { min-width: 0; }
.dreg-ns-req { color: #f87171; font-weight: 700; }
.client-order-detail .dreg-ns-row .dreg-ns-input,
.client-order-detail .dreg-ns-row .form-control {
  color: var(--text-light, #f1f5f9);
  background: rgba(0, 0, 0, 0.35);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 10px;
  width: 100%;
  box-sizing: border-box;
  min-width: 0;
  padding: 9px 12px;
  font-size: 0.9rem;
  line-height: 1.5;
  height: auto;
}
.dreg-ns-hint {
  line-height: 1.55;
  font-size: 0.84rem;
  color: var(--text-muted, #8b9cb5);
  padding: 16px 18px;
  border-radius: 14px;
  border: 1px solid rgba(0, 210, 255, 0.2);
  background: linear-gradient(145deg, rgba(0, 210, 255, 0.08), rgba(0, 0, 0, 0.15));
}
.dreg-ns-hint__title {
  display: block;
  font-size: 0.72rem;
  font-weight: 750;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #5ee4ff;
  margin-bottom: 8px;
}
.dreg-ns-add {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 12px;
  padding: 8px 14px;
  border-radius: 999px;
  border: 1px solid rgba(0, 210, 255, 0.4);
  background: rgba(0, 210, 255, 0.1);
  color: #7cefff;
  font: inherit;
  font-size: 0.86rem;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
}
.dreg-ns-add__ic {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.25rem;
  height: 1.25rem;
  border-radius: 50%;
  background: rgba(0, 210, 255, 0.25);
  font-size: 1.05rem;
  line-height: 1;
  font-weight: 700;
}
.dreg-ns-add:hover { background: rgba(0, 210, 255, 0.18); }
.dreg-ns-add:disabled { opacity: 0.4; cursor: not-allowed; }
@media (max-width: 900px) { .dreg-ns-layout { grid-template-columns: 1fr; } }
@media (max-width: 480px) {
  .dreg-ns-row { grid-template-columns: 1fr; }
  .dreg-ns-idx { margin: 0 0 4px; }
  .dreg-ns-panel__head { grid-template-columns: 1fr 1fr; }
  .dreg-ns-panel__th--idx { text-align: left; }
}
