        * {
            margin: 0;
            padding: 0;
            box-sizing: border-box;
        }

        :root {
            /* ── First Sip Design System 2.0 ── */
            --cream:        #FAF7F2;
            --warm-white:   #FAF7F2;
            --espresso:     #1C0F07;
            --brown:        #3D2B1A;
            --caramel:      #B5651D;
            --caramel-light:#D4894A;
            --latte:        rgba(139,90,43,0.15);
            --latte-soft:   #F5EDE3;
            --sage:         #4CAF7D;
            --muted:        #8C7B6E;
            --muted-2:      #B8A898;
            --card:         #FFFFFF;
            --border:       rgba(139,90,43,0.12);
            --border-strong:rgba(139,90,43,0.22);
            --sidebar-w:    228px;
            --surface:      #FFFFFF;

            /* Legacy aliases */
            --primary:      #B5651D;
            --primary-light:#D4894A;
            --primary-dark: #1C0F07;
            --accent:       #F5EDE3;
            --accent-light: #F5EDE3;
            --success:      #4CAF7D;
            --danger:       #C0392B;
            --bg-dark:      #1C0F07;
            --bg-light:     #FAF7F2;
            --text-dark:    #1C0F07;
            --text-light:   #FAF7F2;
            --shadow:       0 1px 3px rgba(28,15,7,0.05), 0 4px 16px rgba(28,15,7,0.03);
            --shadow-hover: 0 4px 20px rgba(28,15,7,0.08);
        }

        [data-theme="dark"] {
            --cream:        #1a1410;
            --warm-white:   #1a1410;
            --espresso:     #EDE4D4;
            --brown:        #D4C4A8;
            --caramel:      #D4894A;
            --caramel-light:#E0A060;
            --latte:        rgba(212,137,74,0.15);
            --latte-soft:   #2a2218;
            --muted:        #9A8E82;
            --muted-2:      #7A6E62;
            --card:         #221c15;
            --border:       rgba(212,137,74,0.15);
            --border-strong:rgba(212,137,74,0.25);
            --surface:      #221c15;
            --primary:      #D4894A;
            --primary-light:#E0A060;
            --primary-dark: #EDE4D4;
            --accent:       #2a2218;
            --accent-light: #2a2218;
            --bg-dark:      #1a1410;
            --bg-light:     #EDE4D4;
            --text-dark:    #EDE4D4;
            --text-light:   #1a1410;
            --shadow:       0 1px 3px rgba(0,0,0,0.3), 0 4px 16px rgba(0,0,0,0.2);
            --shadow-hover: 0 4px 20px rgba(0,0,0,0.35);
        }

        body {
            font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
            background: var(--cream);
            color: var(--espresso);
            line-height: 1.6;
        }

        html { height: 100%; overflow-x: hidden; }
        body { overflow-x: hidden; }

        /* ─── TOP BAR ─── */
        .topbar {
            height: 56px;
            background: var(--card);
            border-bottom: 1px solid var(--border);
            display: none; /* shown only when logged in */
            align-items: center;
            padding: 0 20px 0 0;
            flex-shrink: 0;
            z-index: 50;
            position: fixed;
            top: 0; left: 0; right: 0;
        }
        .topbar.visible { display: flex; }

        .topbar-logo {
            padding: 0 20px;
            font-family: 'Playfair Display', serif;
            font-size: 19px;
            font-weight: 900;
            color: var(--espresso);
            flex-shrink: 0;
            height: 100%;
            display: flex;
            align-items: center;
            gap: 7px;
        }
        .topbar-logo span { color: var(--caramel); }

        /* ── Desktop 5-tab nav ── */
        .main-nav {
            display: flex;
            align-items: center;
            gap: 2px;
            flex: 1;
            justify-content: center;
        }
        .main-nav-tab {
            display: flex;
            flex-direction: column;
            align-items: center;
            gap: 2px;
            padding: 5px 18px;
            border: none;
            background: none;
            cursor: pointer;
            border-radius: 8px;
            color: var(--muted);
            font-family: 'DM Sans', sans-serif;
            transition: color 0.15s, background 0.15s;
            position: relative;
        }
        .main-nav-tab:hover { color: var(--espresso); background: var(--latte-soft); }
        .main-nav-tab.active { color: var(--caramel); }
        .main-nav-tab.active::after {
            content: '';
            position: absolute;
            bottom: 0;
            left: 50%; transform: translateX(-50%);
            width: 20px; height: 2px;
            border-radius: 2px;
            background: var(--caramel);
        }
        .main-nav-tab-icon { font-size: 18px; line-height: 1.1; }
        .main-nav-tab-label { font-size: 10.5px; font-weight: 500; line-height: 1; }

        .topbar-search-input {
            width: 280px;
            height: 34px;
            border: 1.5px solid var(--border);
            border-radius: 8px;
            background: var(--cream);
            padding: 0 14px 0 34px;
            font-family: 'DM Sans', sans-serif;
            font-size: 13px;
            color: var(--espresso);
            outline: none;
            background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%237A6E62' stroke-width='2'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.35-4.35'/%3E%3C/svg%3E");
            background-repeat: no-repeat;
            background-position: 10px center;
            transition: border-color 0.2s;
        }
        .topbar-search-input:focus { border-color: var(--caramel); }
        .topbar-search-input::placeholder { color: var(--muted); }

        .topbar-right {
            display: flex;
            align-items: center;
            gap: 6px;
            margin-left: auto;
        }

        .icon-btn {
            width: 34px; height: 34px;
            border-radius: 8px;
            border: none;
            background: none;
            color: var(--muted);
            cursor: pointer;
            display: flex; align-items: center; justify-content: center;
            font-size: 16px;
            transition: background 0.15s, color 0.15s;
            position: relative;
        }
        .icon-btn:hover { background: var(--latte-soft); color: var(--espresso); }

        .notif-dot {
            position: absolute;
            top: 6px; right: 6px;
            width: 7px; height: 7px;
            background: var(--caramel);
            border-radius: 50%;
            border: 1.5px solid var(--card);
        }

        .user-chip {
            display: flex;
            align-items: center;
            gap: 8px;
            padding: 4px 10px 4px 4px;
            border-radius: 20px;
            border: 1.5px solid var(--border);
            cursor: pointer;
            transition: background 0.15s;
            margin-left: 4px;
            background: var(--warm-white);
        }
        .user-chip:hover { background: var(--latte-soft); }

        .user-chip-av {
            width: 28px; height: 28px;
            border-radius: 50%;
            background: linear-gradient(135deg, var(--caramel), var(--caramel-light));
            display: flex; align-items: center; justify-content: center;
            font-size: 11px; font-weight: 700; color: white;
        }
        .user-chip-name { font-size: 13px; font-weight: 500; color: var(--espresso); }

        .app-container {
            min-height: 100vh;
            display: flex;
            flex-direction: column;
        }

        /* App body shifts down when topbar is visible */
        body.app-mode { overflow: hidden; }
        body.app-mode .app-container { padding-top: 56px; height: 100vh; box-sizing: border-box; }

        /* ─── SIDEBAR ─── */
        .sidebar {
            background: var(--card);
            border-right: 1px solid var(--border);
            position: fixed;
            left: 0;
            top: 56px;
            height: calc(100vh - 56px);
            width: var(--sidebar-w);
            overflow-y: auto;
            z-index: 90;
            display: flex;
            flex-direction: column;
            padding: 16px 12px;
        }

        /* Sidebar hidden on landing/login/signup */
        body:not(.app-mode) .sidebar { display: none; }

        .sidebar-label {
            font-size: 10px;
            font-weight: 700;
            letter-spacing: 1.2px;
            text-transform: uppercase;
            color: var(--muted);
            padding: 0 8px;
            margin-bottom: 4px;
            margin-top: 16px;
        }
        .sidebar-label:first-child { margin-top: 0; }

        .sidebar-divider {
            height: 1px;
            background: var(--border);
            margin: 10px 0;
        }

        .sidebar-bottom {
            margin-top: auto;
            padding-top: 12px;
        }

        .logo {
            font-family: 'Playfair Display', serif;
            font-weight: 900;
            font-size: 19px;
            color: var(--espresso);
        }

        .sidebar nav {
            display: flex;
            flex-direction: column;
            gap: 2px;
        }

        .nav-item {
            display: flex;
            align-items: center;
            gap: 10px;
            padding: 9px 10px;
            border-radius: 9px;
            cursor: pointer;
            font-size: 14px;
            font-weight: 500;
            color: var(--muted);
            transition: all 0.15s;
            border: none;
            background: none;
            width: 100%;
            text-align: left;
            font-family: 'DM Sans', sans-serif;
            position: relative;
        }

        .nav-item:hover { background: var(--latte-soft); color: var(--espresso); }

        .nav-item.active {
            background: var(--latte);
            color: var(--brown);
            font-weight: 600;
        }

        .nav-icon {
            font-size: 16px;
            width: 20px;
            text-align: center;
            opacity: 0.8;
            flex-shrink: 0;
        }

        .nav-badge {
            margin-left: auto;
            background: var(--caramel);
            color: white;
            font-size: 10px;
            font-weight: 700;
            padding: 2px 6px;
            border-radius: 10px;
            min-width: 18px;
            text-align: center;
        }

        .sidebar-spacer { flex: 1; }

        .logout-btn {
            display: flex;
            align-items: center;
            gap: 10px;
            padding: 9px 10px;
            border-radius: 9px;
            cursor: pointer;
            font-size: 14px;
            font-weight: 500;
            color: var(--muted);
            transition: all 0.15s;
            border: none;
            background: none;
            width: 100%;
            text-align: left;
            font-family: 'DM Sans', sans-serif;
            flex-shrink: 0;
        }

        .logout-btn:hover { background: var(--latte-soft); color: var(--espresso); }

        /* ── Sidebar user info ── */
        .sidebar-user-section {
            display: flex;
            align-items: center;
            gap: 10px;
            padding: 10px 8px 14px;
            border-bottom: 1px solid var(--border);
            margin-bottom: 8px;
        }
        .sidebar-user-av {
            width: 36px; height: 36px;
            border-radius: 50%;
            background: linear-gradient(135deg, var(--caramel), var(--caramel-light));
            color: white;
            font-weight: 700;
            font-size: 13px;
            display: flex; align-items: center; justify-content: center;
            flex-shrink: 0;
        }
        .sidebar-user-name {
            font-size: 13px;
            font-weight: 600;
            color: var(--espresso);
            line-height: 1.2;
        }
        .sidebar-user-status {
            font-size: 11px;
            color: var(--muted);
            margin-top: 1px;
        }

        /* ─── MAIN CONTENT ─── */
        body.app-mode .sidebar { display: none !important; }

        .main-content {
            margin-left: 0;
            padding: 2rem;
            overflow-y: auto;
            flex: 1;
            min-width: 0;
            height: calc(100vh - 56px);
        }

        /* Landing page — no sidebar offset */
        body:not(.app-mode) .main-content {
            margin-left: 0;
            height: 100vh;
            padding: 0;
        }

        .content-view {
            display: none;
            animation: fadeIn 0.18s ease;
        }

        .content-view.active {
            display: block;
        }

        .spanel { display: none !important; }
        .spanel.spanel-active { display: block !important; }

        #dashboardView.active {
            display: flex;
            flex-direction: column;
        }

        @keyframes fadeIn {
            from { opacity: 0; }
            to   { opacity: 1; }
        }

        /* Headers */
        h1 {
            font-family: 'Playfair Display', serif;
            font-weight: 700;
            font-size: 28px;
            margin-bottom: 1rem;
            color: var(--espresso);
        }

        h2 {
            font-family: 'Playfair Display', serif;
            font-size: 22px;
            font-weight: 700;
            margin-bottom: 1.5rem;
            color: var(--espresso);
        }

        h3 {
            font-size: 16px;
            font-weight: 600;
            color: var(--espresso);
            margin-bottom: 0.5rem;
        }

        /* Cards */
        .card {
            background: var(--card);
            border-radius: 14px;
            padding: 1.5rem;
            border: 1px solid var(--border);
            transition: transform 0.2s, box-shadow 0.2s;
        }

        .card:hover {
            transform: translateY(-2px);
            box-shadow: 0 8px 28px rgba(28,18,8,0.08);
        }

        .card.compact {
            padding: 1rem;
        }

        /* Forms */
        .form-group {
            margin-bottom: 1.5rem;
        }

        label {
            display: block;
            margin-bottom: 0.5rem;
            font-weight: 600;
            font-size: 14px;
            color: var(--text-dark);
        }

        input, select, textarea {
            width: 100%;
            padding: 12px 14px;
            border: 1.5px solid var(--border);
            border-radius: 8px;
            font-family: 'DM Sans', sans-serif;
            font-size: 14px;
            transition: all 0.2s ease;
            background: var(--warm-white);
            color: var(--espresso);
        }

        input:focus, select:focus, textarea:focus {
            outline: none;
            border-color: var(--caramel);
            box-shadow: 0 0 0 3px rgba(192,124,58,0.1);
            background: var(--warm-white);
        }

        textarea {
            resize: vertical;
            min-height: 100px;
        }

        /* Buttons */
        .btn {
            padding: 10px 20px;
            border: none;
            border-radius: 8px;
            font-weight: 600;
            cursor: pointer;
            transition: all 0.2s ease;
            font-size: 14px;
            font-family: 'DM Sans', sans-serif;
            display: inline-flex;
            align-items: center;
            gap: 8px;
        }

        .btn-primary {
            background: var(--espresso);
            color: var(--cream);
        }

        .btn-primary:hover {
            background: var(--brown);
            transform: translateY(-1px);
            box-shadow: 0 4px 14px rgba(28,18,8,0.2);
        }

        .btn-secondary {
            background: var(--latte-soft);
            color: var(--espresso);
            border: 1.5px solid var(--latte);
        }

        .btn-secondary:hover {
            background: var(--latte);
        }

        .btn-accent {
            background: var(--caramel);
            color: white;
        }

        .btn-accent:hover {
            background: var(--caramel-light);
            transform: translateY(-1px);
        }

        .btn-danger {
            background: var(--danger);
            color: white;
        }

        .btn-danger:hover {
            background: #e55555;
        }

        .btn-success {
            background: var(--success);
            color: white;
        }

        .btn-success:hover {
            background: #45a049;
        }

        .btn-sm {
            padding: 8px 16px;
            font-size: 12px;
        }

        .btn-icon {
            padding: 10px 12px;
            border-radius: 50%;
            display: inline-flex;
            align-items: center;
            justify-content: center;
        }

        /* Auth Screens */
        /* ===== AUTH PAGES ===== */
        .auth-page {
            display: grid;
            grid-template-columns: 1fr 1fr;
            min-height: 100vh;
        }

        /* Left panel */
        .auth-left {
            background: #1a0e07;
            position: relative;
            overflow: hidden;
            display: flex;
            flex-direction: column;
            justify-content: space-between;
            padding: 48px 56px;
        }

        .auth-left::before {
            content: '';
            position: absolute;
            inset: 0;
            background:
                radial-gradient(ellipse 80% 60% at 20% 80%, rgba(181,101,29,0.25) 0%, transparent 60%),
                radial-gradient(ellipse 50% 40% at 80% 20%, rgba(212,137,74,0.1) 0%, transparent 50%);
            pointer-events: none;
        }

        .auth-grain {
            position: absolute;
            inset: 0;
            background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E");
            pointer-events: none;
            opacity: 0.5;
        }

        .auth-left-logo {
            position: relative;
            z-index: 2;
            display: flex;
            align-items: center;
            gap: 10px;
        }

        .auth-logo-mark {
            width: 38px;
            height: 38px;
            background: linear-gradient(135deg, #d4894a, #b5651d);
            border-radius: 10px;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 18px;
        }

        .auth-logo-text {
            font-family: 'Playfair Display', serif;
            font-size: 22px;
            font-weight: 600;
            color: #f5ede3;
            letter-spacing: -0.3px;
        }

        .auth-left-hero {
            position: relative;
            z-index: 2;
        }

        .auth-eyebrow {
            font-size: 11px;
            font-weight: 500;
            letter-spacing: 2.5px;
            text-transform: uppercase;
            color: #d4894a;
            margin-bottom: 20px;
            display: flex;
            align-items: center;
            gap: 8px;
        }

        .auth-eyebrow::before {
            content: '';
            display: block;
            width: 24px;
            height: 1px;
            background: #d4894a;
        }

        .auth-hero-headline {
            font-family: 'Playfair Display', serif;
            font-size: 42px;
            line-height: 1.1;
            color: #f5ede3;
            margin-bottom: 20px;
            font-weight: 400;
        }

        .auth-hero-headline em {
            font-style: italic;
            color: #d4894a;
        }

        .auth-hero-body {
            font-size: 14px;
            line-height: 1.65;
            color: rgba(245,237,227,0.6);
            max-width: 320px;
            margin-bottom: 36px;
        }

        .auth-testimonial {
            background: rgba(255,255,255,0.05);
            border: 1px solid rgba(181,101,29,0.2);
            border-radius: 16px;
            padding: 22px;
            backdrop-filter: blur(10px);
            max-width: 360px;
        }

        .auth-testimonial-quote {
            font-family: 'Playfair Display', serif;
            font-size: 14px;
            font-style: italic;
            color: #f5ede3;
            line-height: 1.6;
            margin-bottom: 14px;
        }

        .auth-testimonial-author {
            display: flex;
            align-items: center;
            gap: 10px;
        }

        .auth-author-avatar {
            width: 34px;
            height: 34px;
            border-radius: 50%;
            background: linear-gradient(135deg, #b5651d, #d4894a);
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 13px;
            font-weight: 600;
            color: white;
            flex-shrink: 0;
        }

        .auth-author-name {
            font-size: 13px;
            font-weight: 500;
            color: #f5ede3;
        }

        .auth-author-role {
            font-size: 11px;
            color: #c9a98a;
        }

        .auth-decor-circles {
            position: absolute;
            bottom: 60px;
            right: -20px;
            z-index: 1;
        }

        .auth-decor-circle {
            border-radius: 50%;
            border: 1px solid rgba(181,101,29,0.2);
            position: absolute;
        }

        .auth-decor-circle:nth-child(1) { width: 120px; height: 120px; bottom: 0; right: 30px; }
        .auth-decor-circle:nth-child(2) { width: 70px; height: 70px; bottom: 40px; right: 0; }
        .auth-decor-circle:nth-child(3) { width: 40px; height: 40px; bottom: 80px; right: 60px; border-color: rgba(212,137,74,0.3); }

        /* Right panel */
        .auth-right {
            display: flex;
            flex-direction: column;
            justify-content: center;
            align-items: center;
            padding: 60px 72px;
            background: #faf6f1;
            position: relative;
        }

        .auth-right::before {
            content: '';
            position: absolute;
            top: 0; left: 0; right: 0;
            height: 3px;
            background: linear-gradient(90deg, #b5651d, #d4894a, transparent);
        }

        .auth-form-container {
            width: 100%;
            max-width: 380px;
            animation: authFadeUp 0.5s ease both;
        }

        @keyframes authFadeUp {
            from { opacity: 0; transform: translateY(20px); }
            to   { opacity: 1; transform: translateY(0); }
        }

        .auth-form-header { margin-bottom: 36px; }

        .auth-form-title {
            font-family: 'Playfair Display', serif;
            font-size: 32px;
            font-weight: 600;
            color: #1a0e07;
            margin-bottom: 6px;
            line-height: 1.15;
        }

        .auth-form-subtitle {
            font-size: 14px;
            color: #8b6a52;
            line-height: 1.5;
        }

        .auth-form-label {
            display: block;
            font-size: 11px;
            font-weight: 500;
            letter-spacing: 0.8px;
            text-transform: uppercase;
            color: #8b6a52;
            margin-bottom: 8px;
        }

        .auth-input-wrapper { position: relative; }

        .auth-input-icon {
            position: absolute;
            left: 14px;
            top: 50%;
            transform: translateY(-50%);
            color: #c9a98a;
            font-size: 14px;
            pointer-events: none;
        }

        .auth-form-input {
            width: 100%;
            padding: 13px 14px 13px 40px;
            border: 1.5px solid #e8d5c0;
            border-radius: 12px;
            background: white;
            font-family: 'DM Sans', sans-serif;
            font-size: 14px;
            color: #1a0e07;
            outline: none;
            transition: border-color 0.2s, box-shadow 0.2s;
        }

        .auth-form-input::placeholder { color: #c9a98a; }

        .auth-form-input:focus {
            border-color: #b5651d;
            box-shadow: 0 0 0 3px rgba(181,101,29,0.1);
        }

        .auth-btn-primary {
            width: 100%;
            margin-top: 8px;
            padding: 15px;
            background: #1a0e07;
            color: #f5ede3;
            border: none;
            border-radius: 12px;
            font-family: 'DM Sans', sans-serif;
            font-size: 15px;
            font-weight: 500;
            cursor: pointer;
            transition: all 0.25s;
            letter-spacing: 0.2px;
        }

        .auth-btn-primary:hover {
            background: #2c1a0e;
            transform: translateY(-1px);
            box-shadow: 0 8px 24px rgba(26,14,7,0.25);
        }

        .auth-btn-primary:active { transform: translateY(0); }

        .auth-toggle {
            text-align: center;
            margin-top: 22px;
            font-size: 13.5px;
            color: #8b6a52;
        }

        .auth-toggle button {
            background: none;
            border: none;
            color: #b5651d;
            font-weight: 500;
            cursor: pointer;
            font-family: 'DM Sans', sans-serif;
            font-size: 13.5px;
            transition: color 0.2s;
        }

        .auth-toggle button:hover { color: #5c3317; }

        .auth-stat-row {
            display: flex;
            gap: 20px;
            margin-top: 32px;
            padding-top: 28px;
            border-top: 1px solid #e8d5c0;
        }

        .auth-stat-item { text-align: center; flex: 1; }

        .auth-stat-value {
            font-family: 'Playfair Display', serif;
            font-size: 20px;
            font-weight: 600;
            color: #1a0e07;
        }

        .auth-stat-label {
            font-size: 11px;
            color: #8b6a52;
            margin-top: 2px;
        }

        @media (max-width: 860px) {
            .auth-page { grid-template-columns: 1fr; }
            .auth-left { display: none; }
            .auth-right { padding: 48px 28px; background: #faf6f1; min-height: 100vh; }
        }

        /* Legacy signup container (still used for signupView) */
        .auth-container {
            max-width: 500px;
            margin: 4rem auto;
            background: var(--card);
            padding: 3rem;
            border-radius: 18px;
            border: 1px solid var(--border);
        }

        .auth-container h1 {
            text-align: center;
            margin-bottom: 0.5rem;
        }

        .auth-subtitle {
            text-align: center;
            color: var(--muted);
            margin-bottom: 2rem;
            font-size: 14px;
        }

        .toggle-auth {
            text-align: center;
            margin-top: 1.5rem;
            font-size: 14px;
        }

        .toggle-auth button {
            background: none;
            border: none;
            color: var(--caramel);
            text-decoration: underline;
            cursor: pointer;
            font-weight: 600;
        }

        /* ===== SIGNUP PAGE ===== */
        .su-page {
            display: grid;
            grid-template-columns: 400px 1fr;
            min-height: 100vh;
        }

        .su-left {
            position: sticky;
            top: 0;
            height: 100vh;
            background: #2c1a0e;
            overflow: hidden;
            display: flex;
            flex-direction: column;
            padding: 44px 44px;
            z-index: 2;
        }

        .su-left::before {
            content: '';
            position: absolute;
            inset: 0;
            background:
                radial-gradient(ellipse 100% 70% at -10% 100%, rgba(181,101,29,0.3) 0%, transparent 55%),
                radial-gradient(ellipse 60% 50% at 110% 0%, rgba(212,137,74,0.12) 0%, transparent 50%);
            pointer-events: none;
        }

        .su-logo {
            position: relative;
            z-index: 1;
            display: flex;
            align-items: center;
            gap: 10px;
        }

        .su-logo-mark {
            width: 36px;
            height: 36px;
            background: linear-gradient(135deg, #d4894a, #b5651d);
            border-radius: 10px;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 16px;
            flex-shrink: 0;
        }

        .su-logo-text {
            font-family: 'Playfair Display', serif;
            font-size: 20px;
            font-weight: 600;
            color: #f5ede3;
        }

        .su-steps-area {
            position: relative;
            z-index: 1;
            margin-top: auto;
            margin-bottom: auto;
        }

        .su-steps-headline {
            font-family: 'Playfair Display', serif;
            font-size: 33px;
            line-height: 1.15;
            color: #f5ede3;
            margin-bottom: 10px;
            font-weight: 400;
        }

        .su-steps-headline em {
            font-style: italic;
            color: #d4894a;
        }

        .su-steps-tagline {
            font-size: 13px;
            color: rgba(245,237,227,0.5);
            margin-bottom: 32px;
            line-height: 1.55;
        }

        .su-step-list {
            display: flex;
            flex-direction: column;
            gap: 4px;
        }

        .su-step-item {
            display: flex;
            align-items: flex-start;
            gap: 14px;
            padding: 14px;
            border-radius: 12px;
            border: 1px solid transparent;
        }

        .su-step-item.su-active {
            background: rgba(255,255,255,0.06);
            border-color: rgba(181,101,29,0.2);
        }

        .su-step-num {
            width: 30px;
            height: 30px;
            border-radius: 50%;
            border: 1.5px solid rgba(181,101,29,0.35);
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 11px;
            font-weight: 500;
            color: #c9a98a;
            flex-shrink: 0;
            margin-top: 1px;
        }

        .su-step-item.su-active .su-step-num {
            background: linear-gradient(135deg, #b5651d, #d4894a);
            border-color: transparent;
            color: white;
        }

        .su-step-title {
            font-size: 13.5px;
            font-weight: 500;
            color: #f5ede3;
            margin-bottom: 2px;
        }

        .su-step-desc {
            font-size: 11.5px;
            color: rgba(245,237,227,0.42);
        }

        .su-bottom-pill {
            position: relative;
            z-index: 1;
            display: inline-flex;
            align-items: center;
            gap: 8px;
            background: rgba(255,255,255,0.05);
            border: 1px solid rgba(181,101,29,0.2);
            border-radius: 100px;
            padding: 9px 15px;
            font-size: 12px;
            color: rgba(245,237,227,0.65);
            align-self: flex-start;
        }

        .su-pulse-dot {
            width: 6px;
            height: 6px;
            border-radius: 50%;
            background: #4caf50;
            animation: suPulse 2s ease-in-out infinite;
            flex-shrink: 0;
        }

        @keyframes suPulse {
            0%, 100% { opacity: 1; transform: scale(1); }
            50% { opacity: 0.55; transform: scale(0.8); }
        }

        /* Right panel */
        .su-right {
            padding: 56px 72px 72px;
            background: #faf6f1;
            position: relative;
        }

        .su-right::before {
            content: '';
            position: absolute;
            top: 0; left: 0; right: 0;
            height: 3px;
            background: linear-gradient(90deg, #b5651d, #d4894a, transparent 65%);
        }

        .su-form-wrapper {
            max-width: 520px;
            animation: authFadeUp 0.5s ease both;
        }

        .su-form-header { margin-bottom: 32px; }

        .su-form-badge {
            display: inline-flex;
            align-items: center;
            gap: 6px;
            background: rgba(181,101,29,0.1);
            border: 1px solid rgba(181,101,29,0.2);
            border-radius: 100px;
            padding: 5px 12px;
            font-size: 11.5px;
            font-weight: 500;
            color: #b5651d;
            margin-bottom: 14px;
        }

        .su-form-title {
            font-family: 'Playfair Display', serif;
            font-size: 36px;
            font-weight: 600;
            color: #1a0e07;
            line-height: 1.12;
            margin-bottom: 8px;
        }

        .su-form-subtitle {
            font-size: 14px;
            color: #8b6a52;
            line-height: 1.5;
        }

        .su-section-divider {
            display: flex;
            align-items: center;
            gap: 12px;
            margin: 28px 0 18px;
        }

        .su-section-label {
            font-size: 10.5px;
            font-weight: 500;
            letter-spacing: 2px;
            text-transform: uppercase;
            color: #c9a98a;
            white-space: nowrap;
        }

        .su-section-line {
            flex: 1;
            height: 1px;
            background: #e8d5c0;
        }

        .su-grid-2 {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 14px;
        }

        .su-label {
            display: block;
            font-size: 11px;
            font-weight: 500;
            letter-spacing: 0.8px;
            text-transform: uppercase;
            color: #8b6a52;
            margin-bottom: 7px;
        }

        .su-input-wrap { position: relative; }

        .su-icon {
            position: absolute;
            left: 13px;
            top: 50%;
            transform: translateY(-50%);
            color: #c9a98a;
            font-size: 14px;
            pointer-events: none;
        }

        .su-input {
            width: 100%;
            padding: 12px 13px 12px 40px;
            border: 1.5px solid #e8d5c0;
            border-radius: 11px;
            background: white;
            font-family: 'DM Sans', sans-serif;
            font-size: 13.5px;
            color: #1a0e07;
            outline: none;
            transition: border-color 0.2s, box-shadow 0.2s;
        }

        .su-input.su-no-icon { padding-left: 13px; }

        .su-input::placeholder { color: #c9a98a; }

        .su-input:focus {
            border-color: #b5651d;
            box-shadow: 0 0 0 3px rgba(181,101,29,0.1);
        }

        select.su-input {
            cursor: pointer;
            appearance: none;
            background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='7' viewBox='0 0 12 7'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23c9a98a' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
            background-repeat: no-repeat;
            background-position: right 13px center;
        }

        textarea.su-input {
            resize: vertical;
            min-height: 82px;
            padding-top: 11px;
            line-height: 1.5;
        }

        .su-chips {
            display: flex;
            flex-wrap: wrap;
            gap: 8px;
        }

        .su-chip {
            padding: 7px 13px;
            border-radius: 100px;
            border: 1.5px solid #e8d5c0;
            background: white;
            font-size: 12.5px;
            font-family: 'DM Sans', sans-serif;
            color: #8b6a52;
            cursor: pointer;
            transition: all 0.18s;
            user-select: none;
        }

        .su-chip:hover { border-color: #b5651d; color: #b5651d; }

        .su-chip.su-chip-sel {
            background: #1a0e07;
            border-color: #1a0e07;
            color: #f5ede3;
        }

        .su-strength-bars {
            display: flex;
            gap: 4px;
            margin-top: 8px;
        }

        .su-bar {
            flex: 1;
            height: 3px;
            border-radius: 2px;
            background: #e8d5c0;
            transition: background 0.3s;
        }

        .su-bar.su-s1 { background: #e74c3c; }
        .su-bar.su-s2 { background: #e67e22; }
        .su-bar.su-s3 { background: #f1c40f; }
        .su-bar.su-s4 { background: #2ecc71; }

        .su-btn {
            width: 100%;
            margin-top: 4px;
            padding: 15px;
            background: #1a0e07;
            color: #f5ede3;
            border: none;
            border-radius: 12px;
            font-family: 'DM Sans', sans-serif;
            font-size: 15px;
            font-weight: 500;
            cursor: pointer;
            transition: all 0.25s;
            letter-spacing: 0.2px;
        }

        .su-btn:hover {
            background: #2c1a0e;
            transform: translateY(-1px);
            box-shadow: 0 8px 24px rgba(26,14,7,0.25);
        }

        .su-btn:active { transform: translateY(0); }

        .su-benefits {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 10px;
            margin-top: 32px;
            padding-top: 28px;
            border-top: 1px solid #e8d5c0;
        }

        .su-benefit-card {
            background: white;
            border: 1px solid #e8d5c0;
            border-radius: 12px;
            padding: 14px;
            text-align: center;
        }

        .su-benefit-icon { font-size: 20px; margin-bottom: 5px; }
        .su-benefit-title { font-size: 11.5px; font-weight: 500; color: #1a0e07; margin-bottom: 2px; }
        .su-benefit-desc { font-size: 10.5px; color: #8b6a52; line-height: 1.4; }

        @media (max-width: 1000px) {
            .su-right { padding: 44px 44px 56px; }
        }

        @media (max-width: 820px) {
            .su-page { grid-template-columns: 1fr; }
            .su-left { position: static; height: auto; }
            .su-steps-area { margin: 24px 0; }
            .su-right { padding: 32px 22px 48px; }
            .su-grid-2 { grid-template-columns: 1fr; }
            .su-benefits { grid-template-columns: 1fr 1fr; }
        }

        /* === LANDING PAGE === */
        .sidebar-hidden .sidebar { display: none; }
        .sidebar-hidden .main-content { margin-left: 0; padding: 0; width: 100%; }

        .landing-page {
            min-height: 100vh;
            overflow-x: hidden;
            background: var(--warm-white);
            color: var(--espresso);
            font-family: 'DM Sans', sans-serif;
            font-weight: 400;
        }

        /* ── NAV ── */
        .landing-page nav {
            position: fixed;
            top: 0; left: 0; right: 0;
            z-index: 100;
            display: flex;
            align-items: center;
            justify-content: space-between;
            padding: 20px 48px;
            background: rgba(253, 250, 244, 0.88);
            backdrop-filter: blur(16px);
            border-bottom: 1px solid rgba(192, 124, 58, 0.12);
        }

        .lp-nav-logo {
            font-family: 'Playfair Display', serif;
            font-size: 22px;
            font-weight: 900;
            color: var(--espresso);
            letter-spacing: -0.5px;
        }
        .lp-nav-logo span { color: var(--caramel); }

        .lp-nav-links { display: flex; gap: 36px; list-style: none; }
        .lp-nav-links a {
            text-decoration: none;
            color: var(--muted);
            font-size: 14px;
            font-weight: 500;
            letter-spacing: 0.3px;
            transition: color 0.2s;
            cursor: pointer;
        }
        .lp-nav-links a:hover { color: var(--espresso); }

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

        .lp-btn-ghost {
            background: none;
            border: none;
            color: var(--brown);
            font-family: 'DM Sans', sans-serif;
            font-size: 14px;
            font-weight: 500;
            cursor: pointer;
            padding: 10px 18px;
            border-radius: 8px;
            transition: background 0.2s;
        }
        .lp-btn-ghost:hover { background: var(--latte); }

        .lp-btn-primary {
            background: var(--espresso);
            color: var(--cream);
            font-family: 'DM Sans', sans-serif;
            font-size: 14px;
            font-weight: 500;
            cursor: pointer;
            padding: 10px 22px;
            border-radius: 8px;
            border: none;
            transition: background 0.2s, transform 0.15s;
            letter-spacing: 0.2px;
        }
        .lp-btn-primary:hover { background: var(--brown); transform: translateY(-1px); }

        /* ── HERO ── */
        .lp-hero {
            min-height: 100vh;
            display: flex;
            align-items: center;
            padding: 120px 48px 80px;
            position: relative;
            overflow: hidden;
        }

        .lp-hero-bg {
            position: absolute;
            inset: 0;
            background:
                radial-gradient(ellipse 60% 50% at 70% 40%, rgba(192, 124, 58, 0.10) 0%, transparent 70%),
                radial-gradient(ellipse 40% 60% at 20% 80%, rgba(138, 158, 133, 0.10) 0%, transparent 60%);
        }

        .lp-coffee-ring {
            position: absolute;
            right: 6%; top: 18%;
            width: 480px; height: 480px;
            border-radius: 50%;
            border: 1.5px solid rgba(192, 124, 58, 0.15);
            animation: lpSlowSpin 40s linear infinite;
        }
        .lp-coffee-ring::before {
            content: '';
            position: absolute; inset: 24px;
            border-radius: 50%;
            border: 1px solid rgba(192, 124, 58, 0.10);
        }
        .lp-coffee-ring::after {
            content: '';
            position: absolute; inset: 48px;
            border-radius: 50%;
            background: radial-gradient(circle, rgba(192, 124, 58, 0.06) 0%, transparent 70%);
        }
        @keyframes lpSlowSpin {
            from { transform: rotate(0deg); }
            to { transform: rotate(360deg); }
        }

        .lp-float-card {
            position: absolute;
            background: var(--card);
            border: 1px solid rgba(192, 124, 58, 0.18);
            border-radius: 16px;
            padding: 14px 18px;
            display: flex;
            align-items: center;
            gap: 12px;
            box-shadow: 0 8px 32px rgba(28, 18, 8, 0.08);
            animation: lpFloatUp 6s ease-in-out infinite;
        }
        .lp-float-card:nth-child(2) { animation-delay: -2s; }
        .lp-float-card:nth-child(3) { animation-delay: -4s; }
        @keyframes lpFloatUp {
            0%, 100% { transform: translateY(0px); }
            50% { transform: translateY(-8px); }
        }
        .lp-card-1 { right: 14%; top: 28%; }
        .lp-card-2 { right: 28%; top: 55%; }
        .lp-card-3 { right: 8%; top: 64%; }

        .lp-avatar {
            width: 40px; height: 40px;
            border-radius: 50%;
            display: flex; align-items: center; justify-content: center;
            font-weight: 700; font-size: 14px;
            color: white; flex-shrink: 0;
        }
        .lp-avatar.a { background: linear-gradient(135deg, #C07C3A, #D4964F); }
        .lp-avatar.b { background: linear-gradient(135deg, #8A9E85, #6B8566); }
        .lp-avatar.c { background: linear-gradient(135deg, #3D2B1A, #6B4A2E); }

        .lp-float-name { font-size: 13px; font-weight: 600; color: var(--espresso); line-height: 1; margin-bottom: 3px; }
        .lp-float-meta { font-size: 11px; color: var(--muted); }

        .lp-match-badge {
            margin-left: auto;
            background: var(--cream);
            color: var(--caramel);
            font-size: 11px; font-weight: 600;
            padding: 4px 8px;
            border-radius: 20px;
            border: 1px solid var(--latte);
        }

        .lp-hero-content {
            max-width: 580px;
            position: relative; z-index: 1;
            animation: lpFadeUp 0.8s ease both;
        }
        @keyframes lpFadeUp {
            from { opacity: 0; transform: translateY(24px); }
            to { opacity: 1; transform: translateY(0); }
        }

        .lp-hero-tag {
            display: inline-flex;
            align-items: center;
            gap: 8px;
            background: var(--latte);
            color: var(--brown);
            font-size: 12px; font-weight: 600;
            letter-spacing: 0.8px;
            text-transform: uppercase;
            padding: 6px 14px;
            border-radius: 20px;
            margin-bottom: 28px;
        }
        .lp-hero-tag::before {
            content: '';
            width: 6px; height: 6px;
            border-radius: 50%;
            background: var(--caramel);
        }

        .landing-page h1 {
            font-family: 'Playfair Display', serif;
            font-size: clamp(44px, 5.5vw, 72px);
            font-weight: 900;
            line-height: 1.05;
            letter-spacing: -1.5px;
            color: var(--espresso);
            margin-bottom: 24px;
        }
        .landing-page h1 em { font-style: italic; color: var(--caramel); }

        .lp-hero-sub {
            font-size: 17px;
            line-height: 1.7;
            color: var(--muted);
            max-width: 460px;
            margin-bottom: 40px;
            font-weight: 300;
        }

        .lp-hero-cta { display: flex; gap: 14px; align-items: center; flex-wrap: wrap; }

        .lp-btn-cta {
            background: var(--caramel);
            color: white;
            font-family: 'DM Sans', sans-serif;
            font-size: 15px; font-weight: 600;
            padding: 16px 32px;
            border-radius: 10px; border: none;
            cursor: pointer;
            transition: all 0.2s;
            letter-spacing: 0.2px;
            box-shadow: 0 4px 24px rgba(192, 124, 58, 0.35);
        }
        .lp-btn-cta:hover {
            background: var(--caramel-light);
            transform: translateY(-2px);
            box-shadow: 0 8px 32px rgba(192, 124, 58, 0.40);
        }

        .lp-btn-outline {
            background: transparent;
            color: var(--brown);
            font-family: 'DM Sans', sans-serif;
            font-size: 15px; font-weight: 500;
            padding: 15px 28px;
            border-radius: 10px;
            border: 1.5px solid rgba(61, 43, 26, 0.25);
            cursor: pointer;
            transition: all 0.2s;
        }
        .lp-btn-outline:hover { border-color: var(--caramel); color: var(--caramel); }

        .lp-social-proof {
            margin-top: 52px;
            display: flex; align-items: center; gap: 16px;
        }
        .lp-avatars-row { display: flex; }
        .lp-mini-av {
            width: 34px; height: 34px;
            border-radius: 50%;
            border: 2.5px solid var(--warm-white);
            margin-left: -10px;
            font-size: 12px; font-weight: 700;
            display: flex; align-items: center; justify-content: center;
            color: white;
        }
        .lp-mini-av:first-child { margin-left: 0; }
        .lp-mini-av.m1 { background: var(--caramel); }
        .lp-mini-av.m2 { background: var(--sage); }
        .lp-mini-av.m3 { background: var(--brown); }
        .lp-mini-av.m4 { background: #C4956A; }
        .lp-proof-text { font-size: 13px; color: var(--muted); line-height: 1.4; }
        .lp-proof-text strong { color: var(--espresso); font-weight: 600; }

        /* ── STATS BAR ── */
        .lp-stats-bar {
            background: var(--espresso);
            padding: 28px 48px;
            display: flex;
            justify-content: center;
            gap: 80px;
            flex-wrap: wrap;
        }
        .lp-stat-item { text-align: center; }
        .lp-stat-num {
            font-family: 'Playfair Display', serif;
            font-size: 32px; font-weight: 700;
            color: var(--caramel-light);
            line-height: 1; margin-bottom: 4px;
        }
        .lp-stat-label { font-size: 13px; color: rgba(245, 240, 232, 0.6); letter-spacing: 0.3px; }

        /* ── SECTION BASE ── */
        .lp-section { padding: 96px 48px; }
        .lp-section-tag {
            font-size: 11px; font-weight: 700;
            letter-spacing: 1.5px;
            text-transform: uppercase;
            color: var(--caramel);
            margin-bottom: 16px;
        }
        .landing-page h2 {
            font-family: 'Playfair Display', serif;
            font-size: clamp(32px, 4vw, 52px);
            font-weight: 700;
            line-height: 1.1;
            letter-spacing: -1px;
            color: var(--espresso);
            margin-bottom: 16px;
        }
        .landing-page h2 em { font-style: italic; color: var(--caramel); }
        .lp-section-sub {
            font-size: 16px;
            color: var(--muted);
            line-height: 1.7;
            font-weight: 300;
            max-width: 520px;
        }

        /* ── HOW IT WORKS ── */
        .lp-how { background: var(--cream); }
        .lp-how-inner { max-width: 1100px; margin: 0 auto; }
        .lp-how-header { margin-bottom: 64px; }
        .lp-steps {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 32px;
        }
        .lp-step {
            background: var(--card);
            border: 1px solid rgba(192, 124, 58, 0.15);
            border-radius: 20px;
            padding: 36px 32px;
            position: relative;
            transition: transform 0.25s, box-shadow 0.25s;
        }
        .lp-step:hover { transform: translateY(-4px); box-shadow: 0 16px 48px rgba(28, 18, 8, 0.10); }
        .lp-step-num {
            font-family: 'Playfair Display', serif;
            font-size: 64px; font-weight: 900;
            color: rgba(192, 124, 58, 0.45);
            line-height: 1;
            position: absolute; top: 20px; right: 24px;
            text-shadow: 0 2px 12px rgba(192, 124, 58, 0.15);
        }
        .lp-step-icon {
            width: 48px; height: 48px;
            background: var(--latte);
            border-radius: 12px;
            display: flex; align-items: center; justify-content: center;
            font-size: 22px;
            margin-bottom: 20px;
        }
        .lp-step h3 {
            font-family: 'Playfair Display', serif;
            font-size: 20px; font-weight: 700;
            color: var(--espresso);
            margin-bottom: 12px;
        }
        .lp-step p { font-size: 14px; line-height: 1.7; color: var(--muted); font-weight: 300; }

        /* ── FEATURES ── */
        .lp-features-inner {
            max-width: 1100px;
            margin: 0 auto;
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 80px;
            align-items: center;
        }
        .lp-feature-list { display: flex; flex-direction: column; gap: 28px; }
        .lp-feature-item {
            display: flex; gap: 20px;
            align-items: flex-start;
            padding: 24px; border-radius: 16px;
            cursor: pointer;
            transition: background 0.2s;
        }
        .lp-feature-item:hover, .lp-feature-item.active { background: var(--cream); }
        .lp-feature-icon {
            width: 44px; height: 44px; flex-shrink: 0;
            background: var(--latte);
            border-radius: 12px;
            display: flex; align-items: center; justify-content: center;
            font-size: 20px;
        }
        .lp-feature-item.active .lp-feature-icon { background: var(--espresso); }
        .lp-feature-item h3 { font-size: 16px; font-weight: 600; color: var(--espresso); margin-bottom: 6px; }
        .lp-feature-item p { font-size: 14px; color: var(--muted); line-height: 1.6; font-weight: 300; }

        /* App mockup */
        .lp-app-mockup {
            background: var(--espresso);
            border-radius: 28px;
            padding: 24px;
            box-shadow: 0 32px 80px rgba(28, 18, 8, 0.20);
            position: relative; overflow: hidden;
        }
        .lp-app-mockup::before {
            content: '';
            position: absolute; top: -60px; right: -60px;
            width: 200px; height: 200px;
            border-radius: 50%;
            background: radial-gradient(circle, rgba(192, 124, 58, 0.15) 0%, transparent 70%);
        }
        .lp-mockup-bar { display: flex; gap: 6px; margin-bottom: 20px; }
        .lp-mockup-dot { width: 8px; height: 8px; border-radius: 50%; }
        .lp-mockup-dot.r { background: #FF5F57; }
        .lp-mockup-dot.y { background: #FEBC2E; }
        .lp-mockup-dot.g { background: #28C840; }
        .lp-mockup-tabs {
            display: flex; gap: 4px;
            background: rgba(255,255,255,0.07);
            border-radius: 10px; padding: 4px;
            margin-bottom: 20px;
        }
        .lp-mockup-tab {
            flex: 1; text-align: center;
            padding: 8px; border-radius: 8px;
            font-size: 12px; font-weight: 500;
            color: rgba(245, 240, 232, 0.45);
        }
        .lp-mockup-tab.active { background: var(--caramel); color: white; }
        .lp-mockup-card {
            background: rgba(255,255,255,0.06);
            border: 1px solid rgba(255,255,255,0.08);
            border-radius: 14px; padding: 16px;
            margin-bottom: 10px;
            display: flex; align-items: center; gap: 14px;
        }
        .lp-mc-av {
            width: 42px; height: 42px; border-radius: 50%;
            display: flex; align-items: center; justify-content: center;
            font-size: 14px; font-weight: 700;
            color: white; flex-shrink: 0;
        }
        .lp-mc-av.a1 { background: linear-gradient(135deg, var(--caramel), #D4964F); }
        .lp-mc-av.a2 { background: linear-gradient(135deg, var(--sage), #6B8566); }
        .lp-mc-av.a3 { background: linear-gradient(135deg, #C4956A, #9E6B3A); }
        .lp-mc-info { flex: 1; }
        .lp-mc-name { font-size: 13px; font-weight: 600; color: rgba(245,240,232,0.9); margin-bottom: 3px; }
        .lp-mc-meta { font-size: 11px; color: rgba(245,240,232,0.45); }
        .lp-mc-btn {
            background: rgba(192, 124, 58, 0.25);
            color: var(--caramel-light);
            font-size: 11px; font-weight: 600;
            padding: 6px 12px; border-radius: 20px;
            border: 1px solid rgba(192, 124, 58, 0.3);
            cursor: pointer; white-space: nowrap;
        }

        /* ── MOCKUP PANELS ── */
        .lp-mockup-panel {
            display: none;
            animation: lpPanelIn 0.3s ease both;
        }
        .lp-mockup-panel.active { display: block; }
        @keyframes lpPanelIn {
            from { opacity: 0; transform: translateY(8px); }
            to { opacity: 1; transform: translateY(0); }
        }

        /* Match bar */
        .lp-match-bar-wrap {
            display: flex; align-items: center; gap: 6px;
            margin-top: 5px;
        }
        .lp-match-bar {
            height: 4px; border-radius: 4px;
            background: linear-gradient(90deg, var(--caramel), var(--caramel-light));
            flex-shrink: 0;
        }
        .lp-match-pct {
            font-size: 10px; font-weight: 700;
            color: var(--caramel-light); white-space: nowrap;
        }

        /* Icebreaker panel */
        .lp-ice-header {
            display: flex; align-items: center; gap: 10px;
            padding: 12px 14px;
            background: rgba(255,255,255,0.06);
            border-radius: 12px;
            margin-bottom: 14px;
        }
        .lp-ice-label {
            font-size: 10px; font-weight: 700;
            letter-spacing: 0.8px; text-transform: uppercase;
            color: rgba(245,240,232,0.4);
            margin-bottom: 10px;
        }
        .lp-ice-card {
            background: rgba(255,255,255,0.06);
            border: 1px solid rgba(255,255,255,0.08);
            border-radius: 12px;
            padding: 11px 14px;
            font-size: 12px; line-height: 1.5;
            color: rgba(245,240,232,0.82);
            margin-bottom: 8px;
            cursor: pointer;
            transition: background 0.2s, border-color 0.2s;
        }
        .lp-ice-card:hover {
            background: rgba(192,124,58,0.18);
            border-color: rgba(192,124,58,0.35);
        }

        /* Groups panel */
        .lp-group-card {
            background: rgba(255,255,255,0.06);
            border: 1px solid rgba(255,255,255,0.08);
            border-radius: 14px; padding: 14px;
            margin-bottom: 10px;
            display: flex; align-items: center; gap: 12px;
        }
        .lp-group-icon {
            width: 38px; height: 38px; border-radius: 10px;
            display: flex; align-items: center; justify-content: center;
            font-size: 18px; flex-shrink: 0;
        }
        .lp-group-badge {
            font-size: 10px; font-weight: 700;
            color: var(--sage);
            background: rgba(138,158,133,0.15);
            border: 1px solid rgba(138,158,133,0.3);
            padding: 4px 8px; border-radius: 20px;
            white-space: nowrap;
        }

        /* Schedule panel */
        .lp-sched-header {
            display: flex; align-items: center; gap: 10px;
            padding: 12px 14px;
            background: rgba(255,255,255,0.06);
            border-radius: 12px;
            margin-bottom: 14px;
        }
        .lp-sched-pill {
            margin-left: auto;
            font-size: 10px; font-weight: 700;
            color: var(--caramel-light);
            background: rgba(192,124,58,0.2);
            border: 1px solid rgba(192,124,58,0.3);
            padding: 4px 9px; border-radius: 20px;
        }
        .lp-sched-slot {
            display: flex; align-items: center; gap: 12px;
            background: rgba(255,255,255,0.05);
            border: 1px solid rgba(255,255,255,0.07);
            border-radius: 12px; padding: 12px 14px;
            margin-bottom: 8px;
            transition: background 0.2s, border-color 0.2s;
        }
        .lp-sched-slot--active {
            background: rgba(192,124,58,0.12);
            border-color: rgba(192,124,58,0.3);
        }
        .lp-sched-dot {
            width: 8px; height: 8px; border-radius: 50%;
            background: var(--caramel); flex-shrink: 0;
        }

        /* ── FOUNDER ── */
        .lp-founder { background: var(--cream); }
        .lp-founder-inner {
            max-width: 900px; margin: 0 auto;
            display: grid;
            grid-template-columns: auto 1fr;
            gap: 64px;
            align-items: center;
        }
        .lp-founder-portrait {
            width: 220px; height: 220px;
            border-radius: 50%;
            background: var(--latte);
            display: flex; align-items: center; justify-content: center;
            font-family: 'Playfair Display', serif;
            font-size: 72px; font-weight: 900;
            color: var(--caramel);
            flex-shrink: 0;
            position: relative; overflow: hidden;
            border: 4px solid rgba(192, 124, 58, 0.2);
        }
        .lp-founder-portrait img { width: 100%; height: 100%; object-fit: cover; }
        .lp-founder-quote {
            font-family: 'Playfair Display', serif;
            font-size: clamp(20px, 2.5vw, 28px);
            font-style: italic; font-weight: 700;
            line-height: 1.4;
            color: var(--espresso);
            margin-bottom: 24px;
        }
        .lp-founder-attr {
            font-size: 14px; color: var(--muted);
            display: flex; align-items: center; gap: 12px;
        }
        .lp-founder-attr::before {
            content: '';
            width: 32px; height: 1.5px;
            background: var(--caramel);
        }

        /* ── CTA SECTION ── */
        .lp-cta-section {
            background: var(--espresso);
            text-align: center;
            padding: 100px 48px;
            position: relative; overflow: hidden;
        }
        .lp-cta-section::before {
            content: '';
            position: absolute;
            top: -100px; left: 50%;
            transform: translateX(-50%);
            width: 600px; height: 600px;
            border-radius: 50%;
            background: radial-gradient(circle, rgba(192, 124, 58, 0.12) 0%, transparent 70%);
        }
        .lp-cta-section h2 { color: var(--cream); max-width: 600px; margin: 0 auto 16px; }
        .lp-cta-section .lp-section-sub { color: rgba(245, 240, 232, 0.55); margin: 0 auto 40px; }

        /* ── FOOTER ── */
        .lp-footer {
            background: var(--espresso);
            border-top: 1px solid rgba(245, 240, 232, 0.08);
            padding: 32px 48px;
            display: flex; align-items: center;
            justify-content: space-between;
        }
        .lp-footer-logo {
            font-family: 'Playfair Display', serif;
            font-size: 18px; font-weight: 900;
            color: var(--cream);
        }
        .lp-footer-logo span { color: var(--caramel); }
        .lp-footer-text { font-size: 13px; color: rgba(245, 240, 232, 0.35); }
        .lp-footer-links { display: flex; gap: 24px; list-style: none; }
        .lp-footer-links a {
            font-size: 13px; color: rgba(245, 240, 232, 0.45);
            text-decoration: none; transition: color 0.2s;
        }
        .lp-footer-links a:hover { color: var(--caramel-light); }

        /* ── SCROLL ANIMATIONS ── */
        .reveal {
            opacity: 0;
            transform: translateY(20px);
            transition: opacity 0.6s ease, transform 0.6s ease;
        }
        .reveal.visible { opacity: 1; transform: translateY(0); }

        /* ── HAMBURGER (mobile) ── */
        .lp-hamburger {
            display: none;
            background: none; border: none;
            cursor: pointer; padding: 8px;
            z-index: 101;
        }
        .lp-hamburger span {
            display: block;
            width: 22px; height: 2px;
            background: var(--espresso);
            margin: 5px 0; border-radius: 2px;
            transition: all 0.3s ease;
        }
        .lp-hamburger.active span:nth-child(1) { transform: rotate(45deg) translate(5px, 5px); }
        .lp-hamburger.active span:nth-child(2) { opacity: 0; }
        .lp-hamburger.active span:nth-child(3) { transform: rotate(-45deg) translate(5px, -5px); }

        .lp-mobile-menu {
            display: none;
            position: fixed; top: 0; left: 0; right: 0; bottom: 0;
            background: rgba(253, 250, 244, 0.97);
            backdrop-filter: blur(20px);
            z-index: 99;
            flex-direction: column;
            justify-content: center; align-items: center;
            gap: 1.5rem;
        }
        .lp-mobile-menu.active { display: flex; }
        .lp-mobile-menu a {
            font-size: 18px; color: var(--muted);
            text-decoration: none; padding: 12px 24px;
            cursor: pointer; transition: color 0.2s;
        }
        .lp-mobile-menu a:hover { color: var(--espresso); }
        .lp-mobile-buttons {
            display: flex; flex-direction: column;
            gap: 0.75rem; margin-top: 1rem;
            width: 100%; max-width: 280px;
        }
        .lp-mobile-buttons .lp-btn-ghost,
        .lp-mobile-buttons .lp-btn-primary {
            width: 100%; min-height: 48px;
            font-size: 15px; border-radius: 10px;
            display: flex; align-items: center; justify-content: center;
        }

        /* ── RESPONSIVE ── */
        @media (max-width: 900px) {
            .landing-page nav { padding: 16px 24px; }
            .lp-nav-links { display: none; }
            .lp-nav-actions { display: none; }
            .lp-hamburger { display: block; }
            .lp-hero { padding: 100px 24px 60px; }
            .lp-float-card { display: none; }
            .lp-coffee-ring { display: none; }
            .lp-section { padding: 64px 24px; }
            .lp-steps { grid-template-columns: 1fr; }
            .lp-features-inner { grid-template-columns: 1fr; gap: 40px; }
            .lp-founder-inner { grid-template-columns: 1fr; text-align: center; }
            .lp-founder-portrait { margin: 0 auto; }
            .lp-footer { flex-direction: column; gap: 16px; text-align: center; }
            .lp-stats-bar { gap: 40px; padding: 28px 24px; }
            .lp-cta-section { padding: 64px 24px; }
        }
        @media (max-width: 600px) {
            .lp-hero { padding: 90px 20px 48px; }
            .lp-section { padding: 48px 20px; }
            .landing-page h1 { font-size: 36px; }
            .landing-page h2 { font-size: 28px; }
            .lp-stats-bar { gap: 24px; }
            .lp-cta-section { padding: 48px 20px; }
            .lp-footer { padding: 24px 20px; }
        }


        /* Grid */
        .grid {
            display: grid;
            grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
            gap: 1.5rem;
            margin-bottom: 2rem;
        }

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

        /* Stats */
        .stats {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 1.5rem;
            margin-bottom: 2rem;
        }

        .stat-card {
            background: linear-gradient(135deg, var(--primary) 0%, var(--primary-light) 100%);
            color: white;
            padding: 1.5rem;
            border-radius: 12px;
            text-align: center;
        }

        .stat-card h3 {
            font-size: 28px;
            color: var(--accent);
            margin-bottom: 0.5rem;
        }

        .stat-card p {
            font-size: 14px;
            opacity: 0.9;
        }

        /* Zero-state CTA Cards */
        .cta-cards-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 14px;
            margin-bottom: 24px;
        }

        .cta-card {
            background: var(--card);
            border: 1.5px dashed rgba(192,124,58,0.25);
            border-radius: 16px;
            padding: 24px 20px;
            text-align: center;
            cursor: pointer;
            transition: all 0.2s ease;
        }

        .cta-card:hover {
            border-color: var(--caramel);
            transform: translateY(-3px);
            box-shadow: 0 10px 28px rgba(192,124,58,0.12);
        }

        .cta-icon {
            font-size: 2rem;
            margin-bottom: 0.75rem;
        }

        .cta-card h3 {
            font-size: 14px;
            font-weight: 600;
            color: var(--espresso);
            margin-bottom: 0.4rem;
        }

        .cta-card p {
            font-size: 12px;
            color: var(--muted);
            line-height: 1.5;
            font-weight: 300;
        }

        /* Hub Tab Bar */
        .hub-tab-bar {
            display: flex;
            gap: 0;
            margin-bottom: 20px;
            background: var(--card);
            border-radius: 12px;
            padding: 4px;
            border: 1px solid var(--border);
        }

        .hub-tab {
            flex: 1;
            padding: 9px 16px;
            border: none;
            background: transparent;
            border-radius: 8px;
            font-family: 'DM Sans', sans-serif;
            font-weight: 500;
            font-size: 13.5px;
            cursor: pointer;
            color: var(--muted);
            transition: all 0.15s ease;
        }

        .hub-tab.active {
            background: var(--espresso);
            color: var(--cream);
            font-weight: 600;
        }

        .hub-tab:hover:not(.active) {
            background: var(--latte-soft);
            color: var(--espresso);
        }

        .hub-panel-content {
            display: none;
        }

        .hub-panel-content.active {
            display: block;
            animation: fadeIn 0.3s ease;
        }

        /* My Chats Hub */
        .chats-hub-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            margin-bottom: 1.25rem;
            gap: 1rem;
        }

        .chats-hub-search {
            flex: 1;
            position: relative;
        }

        .chats-hub-search input {
            width: 100%;
            padding: 10px 16px 10px 40px;
            border: 1.5px solid var(--border);
            border-radius: 10px;
            font-family: 'DM Sans', sans-serif;
            font-size: 14px;
            background: white;
            transition: border-color 0.2s ease;
        }

        .chats-hub-search input:focus {
            outline: none;
            border-color: var(--primary);
        }

        .chats-hub-search::before {
            content: '🔍';
            position: absolute;
            left: 12px;
            top: 50%;
            transform: translateY(-50%);
            font-size: 14px;
            pointer-events: none;
        }

        .chats-section-label {
            font-weight: 700;
            font-size: 12px;
            color: #aaa;
            text-transform: uppercase;
            letter-spacing: 0.6px;
            margin-bottom: 0.75rem;
            margin-top: 1.25rem;
        }

        .chat-inbox-item {
            display: flex;
            align-items: center;
            gap: 0.75rem;
            padding: 0.875rem 1rem;
            border-radius: 10px;
            cursor: pointer;
            transition: background 0.2s;
            border: 1px solid transparent;
            margin-bottom: 0.25rem;
        }

        .chat-inbox-item:hover {
            background: var(--bg-light);
            border-color: var(--border);
        }

        .chat-inbox-avatar {
            width: 44px;
            height: 44px;
            border-radius: 12px;
            background: linear-gradient(135deg, var(--primary), var(--primary-light));
            color: white;
            display: flex;
            align-items: center;
            justify-content: center;
            font-weight: 700;
            font-size: 15px;
            flex-shrink: 0;
        }

        .chat-inbox-info {
            flex: 1;
            min-width: 0;
        }

        .chat-inbox-name {
            font-weight: 600;
            font-size: 14px;
            color: var(--text-dark);
        }

        .chat-inbox-preview {
            font-size: 13px;
            color: #888;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
        }

        .scheduled-chat-item {
            display: flex;
            align-items: center;
            gap: 0.875rem;
            padding: 0.875rem 1rem;
            border-radius: 10px;
            background: var(--accent-light);
            border: 1px solid var(--border);
            margin-bottom: 0.5rem;
            transition: all 0.2s ease;
        }

        .scheduled-chat-item:hover {
            border-color: var(--accent);
            box-shadow: 0 2px 8px rgba(139,90,60,0.1);
        }

        .scheduled-chat-icon {
            width: 40px;
            height: 40px;
            border-radius: 10px;
            background: var(--accent);
            color: var(--text-dark);
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 18px;
            flex-shrink: 0;
        }

        .btn-schedule-chat {
            background: var(--primary);
            color: white;
            border: none;
            border-radius: 10px;
            padding: 10px 20px;
            font-family: 'DM Sans', sans-serif;
            font-weight: 600;
            font-size: 14px;
            cursor: pointer;
            transition: all 0.2s ease;
            display: inline-flex;
            align-items: center;
            gap: 6px;
            white-space: nowrap;
            flex-shrink: 0;
        }

        .btn-schedule-chat:hover {
            background: var(--primary-dark);
            transform: translateY(-1px);
            box-shadow: 0 4px 12px rgba(139,90,60,0.25);
        }

        /* Connection card in My Network tab */
        .connection-card {
            display: flex;
            align-items: center;
            gap: 0.875rem;
            padding: 0.875rem 1rem;
            border-radius: 12px;
            background: white;
            border: 1px solid var(--border);
            margin-bottom: 0.5rem;
            transition: all 0.2s ease;
        }

        .connection-card:hover {
            border-color: var(--accent);
            box-shadow: 0 2px 8px rgba(139,90,60,0.08);
        }

        .connection-card-avatar {
            width: 46px;
            height: 46px;
            border-radius: 12px;
            background: linear-gradient(135deg, var(--primary), var(--primary-light));
            color: white;
            display: flex;
            align-items: center;
            justify-content: center;
            font-weight: 700;
            font-size: 16px;
            flex-shrink: 0;
        }

        .connection-card-info {
            flex: 1;
            min-width: 0;
        }

        .connection-card-name {
            font-weight: 600;
            font-size: 14px;
            color: var(--text-dark);
        }

        .connection-card-role {
            font-size: 12px;
            color: #888;
            margin-top: 2px;
        }

        .connection-card-actions {
            display: flex;
            gap: 0.5rem;
            flex-shrink: 0;
        }

        /* Group list card in My Groups tab */
        .group-list-card {
            display: flex;
            align-items: center;
            gap: 0.875rem;
            padding: 0.875rem 1rem;
            border-radius: 12px;
            background: white;
            border: 1px solid var(--border);
            margin-bottom: 0.5rem;
            transition: all 0.2s ease;
        }

        .group-list-card:hover {
            border-color: var(--accent);
            box-shadow: 0 2px 8px rgba(139,90,60,0.08);
        }

        .group-list-icon {
            width: 46px;
            height: 46px;
            border-radius: 12px;
            background: var(--accent-light);
            color: var(--primary);
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 20px;
            flex-shrink: 0;
        }

        /* Find More banner */
        .find-more-banner {
            display: flex;
            align-items: center;
            justify-content: space-between;
            background: linear-gradient(135deg, var(--accent-light), #fff8f0);
            border: 1.5px dashed var(--accent);
            border-radius: 12px;
            padding: 1.25rem 1.5rem;
            margin-top: 1.25rem;
            cursor: pointer;
            transition: all 0.2s ease;
            gap: 1rem;
        }

        .find-more-banner:hover {
            border-color: var(--primary);
            transform: translateY(-2px);
            box-shadow: 0 4px 12px rgba(139,90,60,0.1);
        }

        /* Feed sub-tabs */
        .feed-subtab-bar {
            display: inline-flex;
            gap: 0.25rem;
            background: white;
            border-radius: 10px;
            padding: 0.3rem;
            border: 1px solid var(--border);
        }

        .feed-subtab {
            padding: 7px 18px;
            border: none;
            background: transparent;
            border-radius: 7px;
            font-family: 'DM Sans', sans-serif;
            font-weight: 600;
            font-size: 13px;
            cursor: pointer;
            color: #888;
            transition: all 0.2s ease;
        }

        .feed-subtab.active {
            background: var(--primary);
            color: white;
        }

        .feed-subtab:hover:not(.active) {
            background: var(--bg-light);
            color: var(--primary);
        }

        /* Schedule chat modal person picker */
        .schedule-modal-person {
            display: flex;
            align-items: center;
            gap: 0.75rem;
            padding: 0.75rem 1rem;
            border-radius: 10px;
            cursor: pointer;
            border: 1.5px solid transparent;
            transition: all 0.2s;
            background: var(--bg-light);
            margin-bottom: 0.35rem;
        }

        .schedule-modal-person:hover {
            border-color: var(--primary);
            background: white;
        }

        /* Availability slots display */
        .avail-slot-btn {
            padding: 6px 14px;
            border: 1.5px solid var(--border);
            border-radius: 8px;
            background: white;
            font-family: 'DM Sans', sans-serif;
            font-size: 12px;
            font-weight: 600;
            cursor: pointer;
            transition: all 0.2s;
            color: var(--text-dark);
        }

        .avail-slot-btn:hover, .avail-slot-btn.selected {
            border-color: var(--primary);
            background: var(--primary);
            color: white;
        }

        @media (max-width: 600px) {
            .connection-card-actions {
                flex-direction: column;
            }
            .find-more-banner {
                flex-direction: column;
                text-align: center;
            }
        }

        /* Person Card */
        .person-card {
            text-align: center;
        }

        .person-avatar {
            width: 60px;
            height: 60px;
            background: linear-gradient(135deg, var(--primary), var(--primary-light));
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            color: white;
            font-weight: 700;
            font-size: 20px;
            margin: 0 auto 1rem;
        }

        .person-card h3 {
            text-align: center;
            margin-bottom: 0.25rem;
        }

        .person-card .role {
            font-size: 12px;
            color: #999;
            margin-bottom: 0.5rem;
        }

        .person-card .tags {
            display: flex;
            flex-wrap: wrap;
            gap: 0.5rem;
            justify-content: center;
            margin-bottom: 1rem;
        }

        .tag {
            background: var(--bg-light);
            color: var(--primary);
            padding: 4px 10px;
            border-radius: 20px;
            font-size: 11px;
            font-weight: 600;
        }

        /* Calendar */
        .calendar {
            background: white;
            border-radius: 12px;
            padding: 1.5rem;
            border: 1px solid var(--border);
        }

        .calendar-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            margin-bottom: 1.5rem;
        }

        .calendar-header button {
            background: none;
            border: none;
            color: var(--primary);
            cursor: pointer;
            font-size: 20px;
            padding: 4px 8px;
        }

        .calendar-grid {
            display: grid;
            grid-template-columns: repeat(7, 1fr);
            gap: 0.5rem;
            margin-bottom: 1.5rem;
        }

        .calendar-day-header {
            text-align: center;
            font-weight: 600;
            color: var(--primary);
            font-size: 12px;
            padding: 0.5rem;
        }

        .calendar-day {
            aspect-ratio: 1;
            display: flex;
            align-items: center;
            justify-content: center;
            border-radius: 8px;
            background: var(--bg-light);
            cursor: pointer;
            font-size: 14px;
            transition: all 0.3s ease;
            border: 1px solid transparent;
        }

        .calendar-day:hover {
            background: var(--primary);
            color: white;
        }

        .calendar-day.today {
            background: var(--primary);
            color: white;
            font-weight: 600;
        }

        .calendar-day.has-event {
            border: 2px solid var(--accent);
            font-weight: 600;
        }

        .calendar-day.other-month {
            opacity: 0.3;
        }

        /* Time Slots */
        .time-slots {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 0.75rem;
        }

        .time-slot {
            padding: 0.75rem;
            background: var(--bg-light);
            border: 1.5px solid var(--border);
            border-radius: 8px;
            cursor: pointer;
            text-align: center;
            font-size: 12px;
            transition: all 0.3s ease;
        }

        .time-slot:hover {
            border-color: var(--primary);
            background: white;
        }

        .time-slot.selected {
            background: var(--primary);
            color: white;
            border-color: var(--primary);
        }

        /* Video Call */
        .call-container {
            background: black;
            border-radius: 16px;
            padding: 2rem;
            color: white;
            text-align: center;
            min-height: 600px;
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            position: relative;
        }

        .video-grid {
            display: grid;
            grid-template-columns: 1fr;
            gap: 1rem;
            width: 100%;
            max-width: 600px;
            margin-bottom: 2rem;
        }

        .video-box {
            background: #333;
            border-radius: 12px;
            aspect-ratio: 16 / 9;
            display: flex;
            align-items: center;
            justify-content: center;
            border: 2px solid var(--border);
            position: relative;
            overflow: hidden;
        }

        .video-box.local {
            position: absolute;
            bottom: 20px;
            right: 20px;
            width: 150px;
            aspect-ratio: 9 / 16;
        }

        .video-placeholder {
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            gap: 0.5rem;
        }

        .avatar-large {
            width: 80px;
            height: 80px;
            background: linear-gradient(135deg, var(--primary), var(--primary-light));
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 40px;
            font-weight: 700;
        }

        .call-info {
            margin-bottom: 2rem;
        }

        .call-info h2 {
            color: white;
            margin-bottom: 0.5rem;
        }

        .call-duration {
            font-size: 14px;
            color: #aaa;
        }

        .call-controls {
            display: flex;
            justify-content: center;
            gap: 1rem;
        }

        .control-btn {
            width: 60px;
            height: 60px;
            border-radius: 50%;
            border: none;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 24px;
            cursor: pointer;
            transition: all 0.3s ease;
        }

        .control-btn.mic {
            background: var(--primary);
            color: white;
        }

        .control-btn.mic:hover {
            background: var(--primary-dark);
        }

        .control-btn.video {
            background: var(--primary);
            color: white;
        }

        .control-btn.video:hover {
            background: var(--primary-dark);
        }

        .control-btn.end {
            background: var(--danger);
            color: white;
        }

        .control-btn.end:hover {
            background: #e55555;
        }

        .control-btn.muted {
            background: #555;
            color: #aaa;
        }

        /* Messages */
        .messages-wrapper {
            display: grid;
            grid-template-columns: 300px 1fr;
            gap: 1.5rem;
            height: 600px;
        }

        .conversation-list {
            background: white;
            border-radius: 12px;
            overflow-y: auto;
            border: 1px solid var(--border);
        }

        .conversation-item {
            padding: 1rem;
            border-bottom: 1px solid var(--border);
            cursor: pointer;
            transition: all 0.3s ease;
        }

        .conversation-item:hover {
            background: var(--bg-light);
        }

        .conversation-item.active {
            background: linear-gradient(135deg, rgba(111, 78, 55, 0.1), rgba(212, 165, 116, 0.1));
        }

        .conversation-name-link {
            color: inherit;
            cursor: pointer;
        }

        .conversation-name-link:hover {
            color: var(--primary);
            text-decoration: underline;
        }

        .chat-window {
            background: white;
            border-radius: 12px;
            display: flex;
            flex-direction: column;
            border: 1px solid var(--border);
        }

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

        .chat-header h3 {
            margin: 0;
        }

        .chat-messages {
            flex: 1;
            overflow-y: auto;
            padding: 1rem;
        }

        .message {
            margin-bottom: 1rem;
            display: flex;
            gap: 0.75rem;
            animation: slideIn 0.3s ease;
        }

        @keyframes slideIn {
            from {
                opacity: 0;
                transform: translateY(10px);
            }
            to {
                opacity: 1;
                transform: translateY(0);
            }
        }

        /* === STEAM ANIMATION === */
        .steam-container {
            position: relative;
            display: inline-block;
        }
        .steam {
            position: absolute;
            top: -8px;
            width: 4px;
            height: 10px;
            background: transparent;
            border-radius: 50%;
            opacity: 0;
        }
        .steam::before, .steam::after {
            content: '';
            position: absolute;
            width: 4px;
            height: 10px;
            background: rgba(212, 165, 116, 0.5);
            border-radius: 50%;
            animation: steamRise 2s ease-out infinite;
        }
        .steam:nth-child(2)::before { animation-delay: 0.4s; left: 4px; }
        .steam:nth-child(3)::before { animation-delay: 0.8s; left: 8px; }

        @keyframes steamRise {
            0% { opacity: 0; transform: translateY(0) scaleX(1); }
            15% { opacity: 0.7; }
            50% { opacity: 0.3; transform: translateY(-12px) scaleX(1.5); }
            100% { opacity: 0; transform: translateY(-24px) scaleX(0.5); }
        }

        /* === ENHANCED CARD HOVER === */
        .card {
            transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
        }
        .card:hover {
            box-shadow: 0 12px 32px rgba(62, 39, 35, 0.15);
            transform: translateY(-4px);
        }

        /* === ENHANCED BUTTON HOVER === */
        .btn {
            transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
        }
        .btn:hover {
            transform: scale(1.02);
            box-shadow: 0 4px 12px rgba(111, 78, 55, 0.25);
        }
        .btn:active {
            transform: scale(0.98);
        }

        /* === NAV ITEM HOVER INDICATOR === */
        .nav-item {
            position: relative;
            overflow: hidden;
        }
        .nav-item::before {
            content: '';
            position: absolute;
            left: 0;
            top: 50%;
            transform: translateY(-50%) scaleY(0);
            width: 3px;
            height: 60%;
            background: var(--accent);
            border-radius: 0 3px 3px 0;
            transition: transform 0.2s ease;
        }
        .nav-item:hover::before {
            transform: translateY(-50%) scaleY(1);
        }
        .nav-item.active::before {
            transform: translateY(-50%) scaleY(1);
            background: var(--primary-dark);
        }

        /* === COFFEE DIVIDER === */
        .coffee-divider {
            display: flex;
            align-items: center;
            gap: 1rem;
            margin: 2rem 0;
            color: var(--accent);
            font-size: 14px;
        }
        .coffee-divider::before, .coffee-divider::after {
            content: '';
            flex: 1;
            height: 1px;
            background: linear-gradient(to right, transparent, var(--border), transparent);
        }

        /* === TOAST NOTIFICATIONS === */
        .toast-container {
            position: fixed;
            top: 1.5rem;
            right: 1.5rem;
            z-index: 10001;
            display: flex;
            flex-direction: column;
            gap: 0.5rem;
        }
        .toast {
            padding: 0.75rem 1.25rem;
            border-radius: 10px;
            color: white;
            font-size: 14px;
            font-weight: 500;
            box-shadow: 0 8px 24px rgba(0,0,0,0.2);
            animation: toastIn 0.4s cubic-bezier(0.4, 0, 0.2, 1), toastOut 0.4s ease 2.6s forwards;
            display: flex;
            align-items: center;
            gap: 0.5rem;
            max-width: 360px;
        }
        .toast.success { background: linear-gradient(135deg, #4CAF50, #2E7D32); }
        .toast.info { background: linear-gradient(135deg, var(--primary), var(--primary-dark)); }
        .toast.warning { background: linear-gradient(135deg, #FF9800, #E65100); }
        .toast.error { background: linear-gradient(135deg, #FF6B6B, #D32F2F); }
        .toast.celebration { background: linear-gradient(135deg, var(--accent), #C68B59); }

        @keyframes toastIn {
            from { opacity: 0; transform: translateX(100px); }
            to { opacity: 1; transform: translateX(0); }
        }
        @keyframes toastOut {
            from { opacity: 1; transform: translateX(0); }
            to { opacity: 0; transform: translateX(100px); }
        }

        /* === CONFETTI === */
        .confetti-piece {
            position: fixed;
            width: 8px;
            height: 8px;
            z-index: 10002;
            pointer-events: none;
            animation: confettiFall 1.5s ease forwards;
        }
        @keyframes confettiFall {
            0% { opacity: 1; transform: translateY(0) rotate(0deg) scale(1); }
            100% { opacity: 0; transform: translateY(400px) rotate(720deg) scale(0.3); }
        }

        /* === PULSE ANIMATION === */
        @keyframes pulse {
            0%, 100% { transform: scale(1); }
            50% { transform: scale(1.05); }
        }

        /* === GROUP CARD ENHANCEMENTS === */
        .group-card {
            background: linear-gradient(135deg, white 0%, #FFF8F0 100%);
            border-radius: 12px;
            padding: 1.5rem;
            border: 1px solid var(--border);
            transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
            position: relative;
            overflow: hidden;
        }
        .group-card:hover {
            box-shadow: 0 12px 32px rgba(62, 39, 35, 0.15);
            transform: translateY(-4px);
        }
        .group-card .group-header {
            display: flex;
            justify-content: space-between;
            align-items: flex-start;
            margin-bottom: 0.75rem;
        }
        .activity-dot {
            width: 8px;
            height: 8px;
            border-radius: 50%;
            display: inline-block;
            margin-right: 6px;
            flex-shrink: 0;
        }
        .activity-dot.active {
            background: #4CAF50;
            box-shadow: 0 0 6px rgba(76, 175, 80, 0.5);
            animation: dotPulse 2s ease infinite;
        }
        .activity-dot.inactive {
            background: #ccc;
        }
        @keyframes dotPulse {
            0%, 100% { box-shadow: 0 0 4px rgba(76, 175, 80, 0.3); }
            50% { box-shadow: 0 0 10px rgba(76, 175, 80, 0.6); }
        }
        .member-avatars {
            display: flex;
            margin: 0.75rem 0;
        }
        .member-avatars .mini-avatar {
            width: 28px;
            height: 28px;
            border-radius: 50%;
            background: var(--primary);
            color: white;
            font-size: 10px;
            font-weight: 600;
            display: flex;
            align-items: center;
            justify-content: center;
            border: 2px solid white;
            margin-left: -8px;
        }
        .member-avatars .mini-avatar:first-child {
            margin-left: 0;
        }
        .member-avatars .mini-avatar.more {
            background: var(--accent);
            color: var(--text-dark);
            font-size: 9px;
        }
        .group-meta {
            display: flex;
            align-items: center;
            gap: 1rem;
            font-size: 12px;
            color: #999;
            margin: 0.5rem 0;
        }
        .industry-pill {
            display: inline-block;
            padding: 2px 10px;
            border-radius: 12px;
            background: rgba(111, 78, 55, 0.1);
            color: var(--primary);
            font-size: 11px;
            font-weight: 600;
        }

        /* === PROFILE COMPLETION === */
        .completion-card {
            background: linear-gradient(135deg, #FFF8F0 0%, #F5E6D3 100%);
            border-radius: 16px;
            padding: 1.5rem;
            border: 1px solid var(--border);
            display: flex;
            align-items: center;
            gap: 1.5rem;
            margin-bottom: 1.5rem;
            transition: all 0.3s ease;
        }
        .completion-card:hover {
            box-shadow: 0 8px 24px rgba(62, 39, 35, 0.12);
        }
        .progress-ring-container {
            position: relative;
            width: 80px;
            height: 80px;
            flex-shrink: 0;
        }
        .progress-ring-container svg {
            transform: rotate(-90deg);
        }
        .progress-ring-bg {
            fill: none;
            stroke: var(--latte-soft);
            stroke-width: 6;
        }
        .progress-ring-fill {
            fill: none;
            stroke: var(--caramel);
            stroke-width: 6;
            stroke-linecap: round;
            transition: stroke-dashoffset 1s cubic-bezier(0.4, 0, 0.2, 1);
        }
        .progress-text {
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translate(-50%, -50%);
            font-size: 11px;
            font-weight: 700;
            color: var(--espresso);
        }
        .completion-info h3 {
            margin-bottom: 0.25rem;
        }
        .completion-info p {
            font-size: 13px;
            color: #999;
            margin-bottom: 0.5rem;
        }

        /* === GETTING STARTED CHECKLIST === */
        .getting-started {
            /* The dark card style is applied inline in the HTML */
            border-radius: 18px;
            margin-bottom: 1.5rem;
            position: relative;
        }
        .getting-started-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            margin-bottom: 1rem;
        }
        .getting-started-header h3 {
            margin-bottom: 0;
        }
        .dismiss-btn {
            background: none;
            border: none;
            color: #999;
            cursor: pointer;
            font-size: 18px;
            padding: 4px;
        }
        .dismiss-btn:hover {
            color: var(--primary);
        }
        .checklist {
            list-style: none;
        }
        .checklist-item {
            display: flex;
            align-items: center;
            gap: 10px;
            cursor: pointer;
            border-radius: 10px;
            padding: 10px 14px;
            transition: background 0.15s;
            background: rgba(255,255,255,0.07);
            border: 1px solid rgba(255,255,255,0.08);
            flex: 1;
            min-width: 150px;
        }
        .checklist-item:hover {
            background: rgba(255,255,255,0.11);
        }
        .checklist-item.done {
            opacity: 0.45;
        }
        .checklist-item .check-icon {
            width: 22px;
            height: 22px;
            border-radius: 50%;
            border: 1.5px solid rgba(255,255,255,0.2);
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 11px;
            flex-shrink: 0;
            color: rgba(255,255,255,0.4);
            transition: all 0.2s;
        }
        .checklist-item.done .check-icon {
            background: var(--caramel);
            border-color: var(--caramel);
            color: white;
        }
        .check-label {
            font-size: 12px;
            font-weight: 500;
            color: rgba(245,240,232,0.8);
            line-height: 1.3;
        }
        .checklist-item.done .check-label {
            text-decoration: line-through;
            color: rgba(245,240,232,0.4);
        }

        /* === NOTIFICATION BELL === */
        .notification-bell {
            position: relative;
            background: rgba(255, 255, 255, 0.1);
            border: none;
            color: var(--text-light);
            font-size: 20px;
            cursor: pointer;
            padding: 8px 12px;
            border-radius: 8px;
            transition: all 0.2s;
        }
        .notification-bell:hover {
            background: rgba(255, 255, 255, 0.2);
        }
        .notification-bell .bell-badge {
            position: absolute;
            top: 4px;
            right: 4px;
            width: 16px;
            height: 16px;
            border-radius: 50%;
            background: var(--danger);
            color: white;
            font-size: 9px;
            font-weight: 700;
            display: flex;
            align-items: center;
            justify-content: center;
        }
        .notification-bell .bell-badge.hidden {
            display: none;
        }
        @keyframes bellShake {
            0%, 100% { transform: rotate(0); }
            25% { transform: rotate(15deg); }
            50% { transform: rotate(-15deg); }
            75% { transform: rotate(10deg); }
        }
        .notification-bell.has-new {
            animation: bellShake 0.6s ease;
        }

        /* === NOTIFICATION PANEL === */
        .notification-panel {
            position: fixed;
            top: 0;
            right: -400px;
            width: 380px;
            height: 100vh;
            background: white;
            box-shadow: -4px 0 24px rgba(0,0,0,0.15);
            z-index: 9998;
            transition: right 0.3s cubic-bezier(0.4, 0, 0.2, 1);
            display: flex;
            flex-direction: column;
        }
        .notification-panel.open {
            right: 0;
        }
        .notification-panel-overlay {
            position: fixed;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            background: rgba(0,0,0,0.3);
            z-index: 9997;
            display: none;
        }
        .notification-panel-overlay.open {
            display: block;
        }
        .notification-panel-header {
            padding: 1.5rem;
            border-bottom: 1px solid var(--border);
            display: flex;
            justify-content: space-between;
            align-items: center;
        }
        .notification-panel-header h3 {
            margin-bottom: 0;
        }
        .notification-list {
            flex: 1;
            overflow-y: auto;
            padding: 0.5rem;
        }
        .notification-item {
            display: flex;
            align-items: flex-start;
            gap: 0.75rem;
            padding: 1rem;
            border-radius: 10px;
            cursor: pointer;
            transition: background 0.2s;
        }
        .notification-item:hover {
            background: #FFF8F0;
        }
        .notification-item.unread {
            background: rgba(212, 165, 116, 0.08);
        }
        .notification-item.notif-clickable:hover {
            background: #FFF3E0;
        }
        .notification-icon {
            width: 36px;
            height: 36px;
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 16px;
            flex-shrink: 0;
        }
        .notification-icon.meeting { background: rgba(111, 78, 55, 0.1); }
        .notification-icon.connection { background: rgba(76, 175, 80, 0.1); }
        .notification-icon.message { background: rgba(33, 150, 243, 0.1); }
        .notification-icon.event { background: rgba(255, 152, 0, 0.1); }
        .notification-icon.badge { background: rgba(212, 165, 116, 0.15); }
        .notification-text {
            flex: 1;
        }
        .notification-text p {
            font-size: 13px;
            margin-bottom: 2px;
            line-height: 1.4;
        }
        .notification-text .notif-time {
            font-size: 11px;
            color: #999;
        }
        .notification-empty {
            text-align: center;
            padding: 3rem 1rem;
            color: #999;
        }

        /* === BADGES & GAMIFICATION === */
        .badge-grid {
            display: flex;
            flex-wrap: wrap;
            gap: 1rem;
            margin-top: 0.5rem;
        }
        .badge-item {
            display: flex;
            flex-direction: column;
            align-items: center;
            gap: 0.4rem;
            width: 72px;
            text-align: center;
            position: relative;
        }
        .badge-icon {
            width: 48px;
            height: 48px;
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 22px;
            background: linear-gradient(135deg, #FFF8F0, #F5E6D3);
            border: 2px solid var(--accent);
            transition: all 0.3s;
        }
        .badge-item.locked .badge-icon {
            filter: grayscale(1);
            opacity: 0.4;
            border-color: #ddd;
        }
        .badge-item:not(.locked) .badge-icon:hover {
            transform: scale(1.1);
            box-shadow: 0 4px 16px rgba(212, 165, 116, 0.4);
        }
        .badge-name {
            font-size: 10px;
            font-weight: 600;
            color: var(--primary);
            line-height: 1.2;
        }
        .badge-item.locked .badge-name {
            color: #ccc;
        }
        .badge-tooltip {
            position: absolute;
            bottom: calc(100% + 8px);
            left: 50%;
            transform: translateX(-50%);
            background: var(--primary-dark);
            color: white;
            padding: 6px 10px;
            border-radius: 6px;
            font-size: 11px;
            white-space: nowrap;
            opacity: 0;
            pointer-events: none;
            transition: opacity 0.2s;
        }
        .badge-item:hover .badge-tooltip {
            opacity: 1;
        }
        .streak-counter {
            display: inline-flex;
            align-items: center;
            gap: 6px;
            background: linear-gradient(135deg, #FF9800, #E65100);
            color: white;
            padding: 4px 12px;
            border-radius: 20px;
            font-size: 13px;
            font-weight: 600;
        }
        .badge-toast-overlay {
            position: fixed;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            display: flex;
            align-items: center;
            justify-content: center;
            z-index: 10003;
            background: rgba(0,0,0,0.4);
            animation: fadeIn 0.3s ease;
        }
        .badge-toast-card {
            background: white;
            border-radius: 20px;
            padding: 2.5rem;
            text-align: center;
            box-shadow: 0 20px 60px rgba(0,0,0,0.2);
            animation: badgePop 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275);
            max-width: 300px;
        }
        .badge-toast-card .big-badge {
            font-size: 64px;
            margin-bottom: 1rem;
        }
        @keyframes badgePop {
            0% { transform: scale(0.3); opacity: 0; }
            50% { transform: scale(1.05); }
            100% { transform: scale(1); opacity: 1; }
        }

        .message.sent {
            justify-content: flex-end;
        }

        .message-content {
            max-width: 70%;
            padding: 0.75rem 1rem;
            border-radius: 12px;
            background: var(--bg-light);
            color: var(--text-dark);
            font-size: 14px;
            word-wrap: break-word;
        }

        .message.sent .message-content {
            background: var(--primary);
            color: white;
        }

        .chat-input {
            padding: 1rem;
            border-top: 1px solid var(--border);
            display: flex;
            gap: 0.75rem;
        }

        .chat-input input {
            flex: 1;
        }

        /* Search Bar */
        .search-bar {
            display: flex;
            gap: 1rem;
            margin-bottom: 2rem;
        }

        .search-bar input {
            flex: 1;
        }

        .search-bar select {
            min-width: 180px;
        }

        /* Meeting Card */
        .meeting-card {
            background: white;
            border-radius: 12px;
            padding: 1.5rem;
            border: 1px solid var(--border);
            border-left: 4px solid var(--accent);
            margin-bottom: 1rem;
        }

        .meeting-header {
            display: flex;
            justify-content: space-between;
            align-items: start;
            margin-bottom: 1rem;
        }

        .meeting-time {
            font-size: 12px;
            color: var(--primary);
            font-weight: 600;
        }

        .meeting-status {
            padding: 4px 12px;
            border-radius: 20px;
            font-size: 11px;
            font-weight: 600;
        }

        .meeting-status.pending {
            background: #fff3cd;
            color: #856404;
        }

        .meeting-status.confirmed {
            background: #d4edda;
            color: #155724;
        }

        .meeting-actions {
            display: flex;
            gap: 0.5rem;
            margin-top: 1rem;
        }

        /* Empty State */
        .empty-state {
            text-align: center;
            padding: 3rem;
            color: #999;
        }

        .empty-state-icon {
            font-size: 48px;
            margin-bottom: 1rem;
        }

        /* Profile Detail */
        .profile-detail {
            overflow: hidden;
            border-radius: 16px;
        }

        /* ─── PROFILE VIEW HERO REDESIGN ─── */
        .pv-banner {
            height: 156px;
            background: linear-gradient(135deg, #3D2B1A 0%, #7a3f22 45%, #C07C3A 100%);
            position: relative; overflow: hidden;
            background-size: cover; background-position: center;
        }
        .pv-banner.has-image::before { display: none; }
        .pv-banner.has-image::after  { display: none; }
        .pv-banner:not(.has-image)::before {
            content: '';
            position: absolute; inset: 0;
            background-image:
                radial-gradient(circle at 18% 50%, rgba(255,255,255,.07) 0%, transparent 55%),
                radial-gradient(circle at 82% 18%, rgba(255,255,255,.05) 0%, transparent 48%);
        }
        .pv-banner:not(.has-image)::after {
            content: '';
            position: absolute; right: 60px; top: 12px;
            width: 110px; height: 110px; border-radius: 50%;
            border: 1px solid rgba(255,255,255,.08);
            box-shadow: 0 0 0 22px rgba(255,255,255,.04), 0 0 0 44px rgba(255,255,255,.02);
        }
        .pv-banner-edit-btn {
            position: absolute; bottom: 10px; right: 14px;
            background: rgba(0,0,0,.45); color: #fff;
            border: none; border-radius: 8px;
            padding: 5px 12px; font-size: 12px; font-weight: 600;
            cursor: pointer; display: flex; align-items: center; gap: 5px;
            backdrop-filter: blur(4px); transition: background .15s;
        }
        .pv-banner-edit-btn:hover { background: rgba(0,0,0,.65); }
        #stBannerPreview:hover > #stBannerOverlay { opacity: 1 !important; }
        .pv-hero-inner { max-width: 1200px; margin: 0 auto; padding: 0 28px; }
        .pv-avatar-row {
            display: flex; justify-content: space-between; align-items: flex-end;
            gap: 12px; flex-wrap: wrap;
        }
        .pv-avatar-wrap { position: relative; display: inline-block; margin-top: -50px; }
        .pv-avatar {
            width: 100px; height: 100px; border-radius: 50%;
            background: linear-gradient(135deg, var(--brown) 0%, var(--caramel) 100%);
            border: 4px solid var(--card);
            box-shadow: 0 4px 16px rgba(92,51,23,.22);
            display: flex; align-items: center; justify-content: center;
            font-size: 34px; color: #fff; font-weight: 700; overflow: hidden;
        }
        .pv-avatar img { width:100%; height:100%; object-fit:cover; border-radius:50%; }
        .pv-hero-actions { display: flex; gap: 8px; flex-wrap: wrap; padding-bottom: 12px; }
        .pv-identity { padding: 12px 0 16px; border-bottom: 1px solid var(--border); margin-bottom: 18px; }
        .pv-name {
            font-family: 'Playfair Display', serif;
            font-size: 25px; color: var(--espresso); line-height: 1.15; margin-bottom: 4px;
        }
        .pv-headline { font-size: 13.5px; color: var(--muted); margin-bottom: 9px; line-height: 1.4; }
        .pv-chips { display: flex; flex-wrap: wrap; gap: 6px; }
        .pv-linkedin-link {
            display: inline-flex; align-items: center; gap: 6px;
            margin-top: 10px; padding: 5px 12px;
            background: #f0f4ff; border: 1px solid #c0cff5; border-radius: 8px;
            font-size: 12.5px; font-weight: 500; color: #2563eb; text-decoration: none;
            transition: background .15s;
        }
        .pv-linkedin-link:hover { background: #e0ebff; }
        .pv-chip {
            display: flex; align-items: center; gap: 4px;
            background: var(--card); border: 1.5px solid var(--border);
            border-radius: 99px; padding: 3px 10px;
            font-size: 12px; font-weight: 500; color: var(--muted);
        }
        .pv-chip.open {
            background: rgba(138,158,133,.1); border-color: rgba(138,158,133,.35);
            color: var(--sage); font-weight: 600;
        }
        .pv-chip.caramel {
            background: rgba(192,124,58,.07); border-color: rgba(192,124,58,.28);
            color: var(--caramel); font-weight: 600;
        }
        .pv-stat-row {
            display: flex; background: var(--card); border: 1px solid var(--border);
            border-radius: 12px; overflow: hidden; margin-bottom: 20px; box-shadow: var(--shadow);
        }
        .pv-stat-item { flex: 1; padding: 14px 8px; text-align: center; border-right: 1px solid var(--border); }
        .pv-stat-item:last-child { border-right: none; }
        .pv-stat-num {
            font-family: 'Playfair Display', serif;
            font-size: 19px; color: var(--caramel); line-height: 1; margin-bottom: 2px;
        }
        .pv-stat-lbl { font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: .5px; color: var(--muted); opacity: .7; }
        .pv-body {
            max-width: 1200px; margin: 0 auto; padding: 0 28px 36px;
            display: grid; grid-template-columns: 1fr 320px; gap: 20px; align-items: start;
        }
        .pv-card {
            background: var(--card); border: 1px solid var(--border);
            border-radius: 13px; padding: 19px; margin-bottom: 13px; box-shadow: var(--shadow);
        }
        .pv-card-eyebrow {
            font-size: 9.5px; font-weight: 700; text-transform: uppercase;
            letter-spacing: .7px; color: var(--muted); opacity: .6; margin-bottom: 5px;
        }
        .pv-card-title {
            font-family: 'Playfair Display', serif;
            font-size: 16px; color: var(--espresso); margin-bottom: 11px; line-height: 1.2;
        }
        .pv-card-title em { font-style: italic; color: var(--caramel); }
        .pv-bio { font-size: 14px; line-height: 1.75; color: var(--muted); }
        .pv-looking-for {
            margin-top: 11px; padding: 10px 12px;
            background: var(--latte-soft); border-radius: 8px;
            border-left: 3px solid var(--caramel);
            font-size: 13px; color: var(--muted); line-height: 1.6;
        }
        .pv-looking-for strong { display: block; font-size: 10.5px; font-weight: 700; color: var(--caramel); text-transform: uppercase; letter-spacing: .5px; margin-bottom: 3px; }
        .pv-tags { display: flex; flex-wrap: wrap; gap: 6px; }
        .pv-tag {
            background: var(--latte-soft); border: 1px solid var(--border);
            border-radius: 99px; padding: 4px 11px;
            font-size: 12px; font-weight: 500; color: var(--muted);
        }
        .pv-goals { font-size: 14px; line-height: 1.7; color: var(--muted); padding-left: 12px; border-left: 3px solid var(--caramel); }
        .pv-ach-row { display: flex; gap: 12px; align-items: flex-start; padding: 11px 0; border-bottom: 1px solid var(--border); }
        .pv-ach-row:last-child { border-bottom: none; padding-bottom: 0; }
        .pv-ach-icon {
            width: 34px; height: 34px; border-radius: 8px;
            background: var(--latte-soft); border: 1px solid var(--border);
            display: flex; align-items: center; justify-content: center;
            font-size: 15px; flex-shrink: 0;
        }
        .pv-ach-title { font-size: 13px; font-weight: 700; color: var(--espresso); }
        .pv-ach-org { font-size: 12.5px; color: var(--muted); margin-bottom: 1px; }
        .pv-ach-date { font-size: 11px; color: var(--muted); opacity: .65; }
        .pv-ach-desc { font-size: 12.5px; color: var(--muted); margin-top: 3px; line-height: 1.5; }
        .pv-action-card {
            background: linear-gradient(135deg, #3D2B1A 0%, #7a3f22 55%, #C07C3A 100%);
            border-radius: 13px; padding: 19px; margin-bottom: 13px;
            position: relative; overflow: hidden; color: #fff;
        }
        .pv-action-card::before {
            content: ''; position: absolute; right: -16px; top: -16px;
            width: 90px; height: 90px; border-radius: 50%;
            border: 1px solid rgba(255,255,255,.08);
            box-shadow: 0 0 0 18px rgba(255,255,255,.04), 0 0 0 36px rgba(255,255,255,.02);
        }
        .pv-action-label { font-size: 9.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .7px; color: rgba(255,255,255,.6); margin-bottom: 7px; }
        .pv-action-title { font-family: 'Playfair Display', serif; font-size: 14.5px; color: #fff; line-height: 1.45; margin-bottom: 13px; font-style: italic; }
        .pv-action-btn {
            display: block; background: rgba(255,255,255,.14); border: 1px solid rgba(255,255,255,.24);
            color: #fff; border-radius: 8px; padding: 9px 14px;
            font-size: 13px; font-weight: 600; font-family: 'DM Sans', sans-serif;
            cursor: pointer; width: 100%; transition: background .15s; margin-top: 6px; text-align: center;
        }
        .pv-action-btn:hover { background: rgba(255,255,255,.24); }
        .pv-action-btn.secondary { background: rgba(255,255,255,.07); border-color: rgba(255,255,255,.15); }
        .pv-cta-primary {
            background: var(--brown); color: #fff; border: none;
            border-radius: 10px; padding: 10px 16px; font-size: 13px; font-weight: 700;
            font-family: 'DM Sans', sans-serif; cursor: pointer;
            display: inline-flex; align-items: center; gap: 6px;
            transition: all .18s; box-shadow: 0 3px 10px rgba(92,51,23,.22);
        }
        .pv-cta-primary:hover { opacity: .88; transform: translateY(-1px); }
        .pv-cta-secondary {
            background: var(--card); color: var(--muted); border: 1.5px solid var(--border);
            border-radius: 10px; padding: 10px 14px; font-size: 13px; font-weight: 600;
            font-family: 'DM Sans', sans-serif; cursor: pointer;
            display: inline-flex; align-items: center; gap: 6px; transition: all .15s;
        }
        .pv-cta-secondary:hover { border-color: var(--caramel); color: var(--brown); }
        .pv-cta-secondary.connected { color: var(--sage); border-color: rgba(138,158,133,.35); background: rgba(138,158,133,.07); }
        .pv-resume-pill {
            display: flex; align-items: center; gap: 10px;
            padding: 12px 14px; background: var(--latte-soft);
            border: 1.5px solid var(--border); border-radius: 10px;
            cursor: pointer; transition: all .15s;
        }
        .pv-resume-pill:hover { border-color: var(--caramel); background: rgba(192,124,58,.05); }
        .pv-resume-icon {
            width: 34px; height: 34px; background: var(--brown); border-radius: 7px;
            display: flex; align-items: center; justify-content: center; font-size: 15px; flex-shrink: 0;
        }
        @media (max-width: 680px) {
            .pv-body { grid-template-columns: 1fr; padding: 0 16px 32px; }
            .pv-hero-inner { padding: 0 16px; }
        }

        /* ══════════════════════════════════
           PUBLIC PROFILE VIEW  (pvp-*)
           ══════════════════════════════════ */

        .pvp-back-row { margin-bottom: 16px; }
        .pvp-back-btn { display:flex;align-items:center;gap:6px;font-size:13px;color:var(--muted);cursor:pointer;border:none;background:none;font-family:'Sora',sans-serif;transition:color 0.15s;padding:0; }
        .pvp-back-btn:hover { color:var(--caramel); }
        .pvp-back-btn svg { width:15px;height:15px; }

        /* Match pill */
        .pvp-match-pill { display:inline-flex;align-items:center;gap:7px;padding:6px 14px;background:linear-gradient(135deg,#E8F5EE,#D4EDE2);border:1px solid rgba(29,158,117,0.2);border-radius:20px;font-size:13px;font-weight:500;color:#0F6E56;margin-bottom:16px; }
        .pvp-match-dot { width:8px;height:8px;border-radius:50%;background:#1D9E75;flex-shrink:0; }

        /* Hero card */
        .pvp-hero-card { background:#fff;border:1px solid var(--border);border-radius:18px;overflow:hidden;margin-bottom:20px;box-shadow:var(--shadow); }
        .pvp-cover { height:96px;background:linear-gradient(135deg,#EAD5BC 0%,#D4A574 50%,#C47B3A 100%);background-size:cover;background-position:center; }
        .pvp-hero-body { padding:0 24px 0; }
        .pvp-hero-top { display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:14px; }
        .pvp-avatar { width:76px;height:76px;border-radius:50%;border:3px solid #fff;display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-size:26px;font-weight:400;color:#fff;margin-top:-38px;box-shadow:var(--shadow);overflow:hidden;flex-shrink:0; }
        .pvp-cta-btns { display:flex;gap:8px;padding-top:12px;flex-wrap:wrap; }
        .pvp-btn-request { display:flex;align-items:center;gap:7px;padding:9px 18px;background:var(--caramel);color:#fff;border:none;border-radius:10px;font-size:13px;font-weight:500;cursor:pointer;font-family:'Sora',sans-serif;transition:all 0.15s; }
        .pvp-btn-request:hover { background:#9A5418;transform:translateY(-1px); }
        .pvp-btn-connect { display:flex;align-items:center;gap:6px;padding:9px 16px;background:transparent;color:var(--caramel);border:1.5px solid var(--caramel);border-radius:10px;font-size:13px;font-weight:500;cursor:pointer;font-family:'Sora',sans-serif;transition:all 0.15s; }
        .pvp-btn-connect:hover { background:#F5EDE3; }
        .pvp-btn-connect.connected { background:#E1F5EE;color:#0F6E56;border-color:rgba(29,158,117,0.3);cursor:default; }
        .pvp-btn-share { width:40px;height:40px;border-radius:10px;border:1px solid var(--border-strong);background:none;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--muted);transition:all 0.15s;margin-top:12px;flex-shrink:0;padding:0; }
        .pvp-btn-share:hover { background:var(--latte-soft);color:var(--caramel);border-color:var(--caramel); }

        /* Share Profile Modal — connection picker */
        .sp-conn-row {
          display:flex;align-items:center;gap:12px;padding:11px 20px;
          cursor:pointer;transition:background 0.12s;border-bottom:1px solid var(--border);
        }
        .sp-conn-row:last-child { border-bottom:none; }
        .sp-conn-row:hover { background:var(--latte-soft); }
        .sp-conn-row.selected { background:#F5EDE3; }
        .sp-av {
          width:38px;height:38px;border-radius:50%;flex-shrink:0;
          display:flex;align-items:center;justify-content:center;
          font-size:13px;font-weight:600;color:#fff;overflow:hidden;
        }
        .sp-info { flex:1;min-width:0; }
        .sp-name { font-size:14px;font-weight:500;color:var(--espresso); }
        .sp-sub  { font-size:12px;color:var(--muted);margin-top:1px; }
        .sp-check {
          width:22px;height:22px;border-radius:50%;border:1.5px solid var(--border-strong);
          display:flex;align-items:center;justify-content:center;flex-shrink:0;
          font-size:12px;font-weight:700;color:var(--caramel);transition:all 0.15s;
        }
        .sp-conn-row.selected .sp-check {
          background:var(--caramel);color:#fff;border-color:var(--caramel);
        }

        .pvp-name { font-family:'Playfair Display',serif;font-size:24px;font-weight:400;color:var(--espresso);letter-spacing:-0.02em;margin-bottom:4px; }
        .pvp-headline { font-size:14px;color:var(--muted);line-height:1.5;margin-bottom:10px; }
        .pvp-meta-row { display:flex;flex-wrap:wrap;gap:12px;margin-bottom:14px; }
        .pvp-meta-item { font-size:13px;color:var(--muted); }

        /* Stats strip */
        .pvp-stats-strip { display:flex;border-top:1px solid var(--border); }
        .pvp-strip-stat { flex:1;padding:11px 14px;border-right:1px solid var(--border);text-align:center; }
        .pvp-strip-stat:last-child { border-right:none; }
        .pvp-strip-num { font-family:'Playfair Display',serif;font-size:17px;font-weight:400;color:var(--caramel);letter-spacing:-0.02em; }
        .pvp-strip-lbl { font-size:10px;color:var(--muted);margin-top:2px; }

        /* Two-column body */
        .pvp-two-col { display:grid;grid-template-columns:1fr 292px;gap:18px;align-items:start; }

        /* Cards */
        .pvp-card { background:#fff;border:1px solid var(--border);border-radius:14px;margin-bottom:16px;box-shadow:var(--shadow);overflow:hidden; }
        .pvp-card-header { display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border); }
        .pvp-card-title { font-family:'Playfair Display',serif;font-size:15px;font-weight:400;color:var(--espresso);letter-spacing:-0.01em; }
        .pvp-card-body { padding:16px 18px; }
        .pvp-about-text { font-size:14px;color:var(--espresso);line-height:1.8; }

        /* Tags */
        .pvp-tag-label { font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:0.07em;color:var(--muted);margin-bottom:8px; }
        .pvp-tag-row { display:flex;flex-wrap:wrap;gap:6px;margin-bottom:4px; }
        .pvp-tag { display:inline-flex;align-items:center;padding:5px 11px;border-radius:20px;font-size:13px; }
        .pvp-tag-interest { background:#F5EDE3;border:1px solid rgba(181,101,29,0.15);color:var(--caramel); }
        .pvp-tag-hobby { background:var(--latte-soft);border:1px solid var(--border);color:var(--brown); }
        .pvp-tag-shared { background:#E1F5EE;border:1px solid rgba(29,158,117,0.2);color:#0F6E56;font-weight:500; }
        .pvp-shared-badge { font-size:11px;font-weight:500;background:#E1F5EE;color:#0F6E56;padding:3px 9px;border-radius:10px; }
        .pvp-shared-summary { margin-top:10px;padding:7px 10px;background:#E1F5EE;border-radius:8px;font-size:12px;color:#0F6E56; }

        /* Goals */
        .pvp-goal-item { display:flex;align-items:flex-start;gap:9px;padding:9px 0;border-bottom:1px solid var(--border); }
        .pvp-goal-item:last-child { border-bottom:none; }
        .pvp-goal-dot { width:7px;height:7px;border-radius:50%;background:var(--caramel);flex-shrink:0;margin-top:5px; }
        .pvp-goal-text { font-size:14px;color:var(--espresso);line-height:1.5; }

        /* Experience */
        .pvp-exp-item { display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--border); }
        .pvp-exp-item:last-child { border-bottom:none; }
        .pvp-exp-logo { width:38px;height:38px;border-radius:9px;background:var(--latte-soft);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0; }
        .pvp-exp-role { font-size:14px;font-weight:500;color:var(--espresso); }
        .pvp-exp-company { font-size:13px;color:var(--muted);margin-top:2px; }
        .pvp-exp-date { font-size:12px;color:var(--muted);margin-top:2px; }
        .pvp-exp-desc { font-size:13px;color:var(--espresso);line-height:1.55;margin-top:6px; }

        /* Reviews */
        .pvp-review-item { padding:11px 0;border-bottom:1px solid var(--border); }
        .pvp-review-item:last-child { border-bottom:none; }
        .pvp-review-header { display:flex;align-items:center;gap:8px;margin-bottom:5px; }
        .pvp-stars { color:var(--caramel);font-size:13px;letter-spacing:1px; }
        .pvp-review-date { font-size:11px;color:var(--muted); }
        .pvp-review-text { font-size:13px;color:var(--espresso);line-height:1.55;font-style:italic; }
        .pvp-review-anon { font-size:11px;color:var(--muted);margin-top:4px; }

        /* Sidebar */
        .pvp-sidebar { display:flex;flex-direction:column;gap:14px; }
        .pvp-cta-card { background:linear-gradient(135deg,#F5EDE3 0%,#EAD5BC 100%);border:1px solid rgba(181,101,29,0.2);border-radius:14px;padding:18px 20px;text-align:center;box-shadow:var(--shadow); }
        .pvp-cta-icon { font-size:28px;margin-bottom:8px; }
        .pvp-cta-title { font-family:'Playfair Display',serif;font-size:16px;font-weight:400;color:var(--espresso);letter-spacing:-0.01em;margin-bottom:5px; }
        .pvp-cta-sub { font-size:12px;color:var(--muted);line-height:1.55;margin-bottom:12px; }
        .pvp-btn-cta-full { width:100%;padding:10px;background:var(--caramel);color:#fff;border:none;border-radius:9px;font-size:13px;font-weight:500;cursor:pointer;font-family:'Sora',sans-serif;transition:background 0.15s;margin-bottom:7px; }
        .pvp-btn-cta-full:hover { background:#9A5418; }
        .pvp-btn-cta-ghost { width:100%;padding:9px;background:transparent;color:var(--caramel);border:1px solid rgba(181,101,29,0.3);border-radius:9px;font-size:13px;font-weight:500;cursor:pointer;font-family:'Sora',sans-serif;transition:all 0.15s; }
        .pvp-btn-cta-ghost:hover { background:rgba(181,101,29,0.06); }
        .pvp-sc { background:#fff;border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:var(--shadow); }
        .pvp-sc-header { padding:12px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between; }
        .pvp-sc-title { font-size:13px;font-weight:500;color:var(--espresso); }
        .pvp-sc-body { padding:10px 14px; }
        .pvp-avail-row { display:flex;align-items:center;justify-content:space-between;padding:7px 0;border-bottom:1px solid var(--border);font-size:13px; }
        .pvp-avail-row:last-child { border-bottom:none; }
        .pvp-avail-day { color:var(--muted); }
        .pvp-avail-time { color:var(--espresso);font-weight:400; }
        .pvp-common-item { display:flex;align-items:center;gap:9px;padding:7px 0;border-bottom:1px solid var(--border);cursor:pointer;transition:all 0.12s; }
        .pvp-common-item:last-child { border-bottom:none; }
        .pvp-common-icon { font-size:16px;width:26px;text-align:center;flex-shrink:0; }
        .pvp-common-text { font-size:13px;color:var(--espresso);font-weight:500; }
        .pvp-common-sub { font-size:11px;color:var(--muted);margin-top:1px; }
        .pvp-common-item:hover .pvp-common-text { color:var(--caramel); }
        .pvp-mutual-item { display:flex;align-items:center;gap:9px;padding:7px 0;border-bottom:1px solid var(--border);cursor:pointer;transition:all 0.12s; }
        .pvp-mutual-item:last-child { border-bottom:none; }
        .pvp-mutual-item:hover .pvp-mutual-name { color:var(--caramel); }
        .pvp-mutual-av { width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:600;color:#fff;overflow:hidden;flex-shrink:0; }
        .pvp-mutual-name { font-size:13px;font-weight:500;color:var(--espresso); }
        .pvp-mutual-role { font-size:11px;color:var(--muted); }

        @media (max-width:700px) {
            .pvp-two-col { grid-template-columns:1fr; }
            .pvp-stats-strip .pvp-strip-stat:nth-child(3),
            .pvp-stats-strip .pvp-strip-stat:nth-child(4) { display:none; }
        }

        /* ─── ACHIEVEMENTS SETTINGS ─── */
        .ach-entry {
            background: var(--latte-soft); border: 1px solid var(--border);
            border-radius: 12px; padding: 15px; margin-bottom: 10px;
        }
        .ach-entry-header { display: flex; gap: 8px; margin-bottom: 10px; align-items: center; }
        .ach-type-sel { flex: 1; }
        .ach-remove-btn {
            background: none; border: 1px solid var(--border); border-radius: 7px;
            padding: 4px 10px; font-size: 12px; color: var(--muted);
            cursor: pointer; font-family: 'DM Sans', sans-serif; transition: all .15s; flex-shrink: 0;
        }
        .ach-remove-btn:hover { border-color: #e55; color: #e55; }
        .ach-entry-fields { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
        .ach-entry-fields .st-form-group { margin-bottom: 0; }
        .ach-entry-fields .full-col { grid-column: 1 / -1; }
        .ach-add-btn {
            display: flex; align-items: center; gap: 8px; width: 100%;
            background: none; border: 1.5px dashed var(--border); border-radius: 10px;
            padding: 11px 16px; font-size: 13.5px; font-weight: 600; color: var(--muted);
            cursor: pointer; font-family: 'DM Sans', sans-serif; transition: all .15s; margin-top: 4px;
        }
        .ach-add-btn:hover { border-color: var(--caramel); color: var(--caramel); background: rgba(192,124,58,.04); }

        /* Achievement display cards */
        .ach-card {
            display: flex; gap: 12px; align-items: flex-start;
            background: var(--card); border: 1px solid var(--border);
            border-radius: 11px; padding: 14px; margin-bottom: 10px;
        }
        .ach-card-icon {
            width: 36px; height: 36px; border-radius: 8px;
            background: var(--latte-soft); border: 1px solid var(--border);
            display: flex; align-items: center; justify-content: center;
            font-size: 16px; flex-shrink: 0;
        }
        .ach-card-body { flex: 1; min-width: 0; }
        .ach-card-title { font-size: 13.5px; font-weight: 700; color: var(--espresso); }
        .ach-card-org { font-size: 12.5px; color: var(--muted); margin-bottom: 1px; }
        .ach-card-date { font-size: 11.5px; color: var(--muted); opacity: .7; }
        .ach-card-desc { font-size: 12.5px; color: var(--muted); margin-top: 4px; line-height: 1.5; }
        .ach-card-btns { display: flex; gap: 6px; flex-shrink: 0; }
        .ach-icon-btn {
            background: none; border: 1px solid var(--border); border-radius: 7px;
            width: 30px; height: 30px; display: flex; align-items: center; justify-content: center;
            cursor: pointer; font-size: 13px; transition: all .15s;
        }
        .ach-icon-btn:hover { border-color: var(--caramel); background: var(--latte-soft); }
        .ach-icon-btn.ach-danger:hover { border-color: #e55; background: #fdf0ee; }
        /* Inline add/edit form */
        .ach-form {
            background: var(--latte-soft); border: 1.5px solid var(--border);
            border-radius: 12px; padding: 18px; margin-bottom: 10px;
        }
        .ach-form-title { font-size: 13px; font-weight: 700; color: var(--espresso); margin-bottom: 14px; }
        .ach-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 10px; }
        .ach-form-grid .ach-full { grid-column: 1 / -1; }
        .ach-current-row { display: flex; align-items: center; gap: 8px; margin-bottom: 10px; }
        .ach-current-row label { font-size: 13px; color: var(--muted); cursor: pointer; }
        .ach-form-btns { display: flex; gap: 8px; justify-content: flex-end; }

        .profile-header {
            text-align: center;
            margin-bottom: 2rem;
            padding-bottom: 2rem;
            border-bottom: 1px solid var(--border);
            position: relative;
        }

        .profile-header .person-avatar {
            width: 120px;
            height: 120px;
            font-size: 48px;
            position: relative;
            cursor: pointer;
            overflow: hidden;
        }

        .profile-header .person-avatar img {
            width: 100%;
            height: 100%;
            object-fit: cover;
        }

        .profile-header .edit-profile-btn {
            position: absolute;
            top: 0;
            right: 0;
        }

        .profile-info {
            margin-bottom: 1.5rem;
        }

        .profile-info-row {
            display: flex;
            gap: 0.5rem;
            align-items: center;
            margin-bottom: 0.5rem;
            color: #666;
            font-size: 14px;
        }

        .profile-tags {
            display: flex;
            flex-wrap: wrap;
            gap: 0.5rem;
            margin-top: 0.75rem;
        }

        .profile-actions {
            display: flex;
            gap: 1rem;
            margin-top: 2rem;
        }

        .profile-actions button {
            flex: 1;
        }

        .profile-posts {
            margin-top: 2rem;
            padding-top: 2rem;
            border-top: 1px solid var(--border);
        }

        .post-card {
            background: var(--bg-light);
            border-radius: 12px;
            padding: 1.5rem;
            margin-bottom: 1rem;
            border: 1px solid var(--border);
        }

        .post-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            margin-bottom: 1rem;
        }

        .post-meta {
            font-size: 12px;
            color: #999;
        }

        .post-content {
            margin-bottom: 1rem;
            line-height: 1.6;
        }

        .post-actions {
            display: flex;
            gap: 1rem;
            padding-top: 0.75rem;
            border-top: 1px solid var(--border);
        }

        .post-action-btn {
            background: none;
            border: none;
            color: var(--primary);
            cursor: pointer;
            font-size: 13px;
            font-weight: 600;
            display: flex;
            align-items: center;
            gap: 0.25rem;
            padding: 0.25rem 0.5rem;
            border-radius: 4px;
            transition: all 0.3s ease;
        }

        .post-action-btn:hover {
            background: rgba(111, 78, 55, 0.1);
        }

        .resume-section {
            background: var(--bg-light);
            border-radius: 12px;
            padding: 1.5rem;
            margin-bottom: 1.5rem;
            border: 1px solid var(--border);
        }

        .resume-link {
            display: flex;
            align-items: center;
            gap: 1rem;
            padding: 1rem;
            background: white;
            border-radius: 8px;
            border: 1px solid var(--border);
            text-decoration: none;
            color: var(--text-dark);
            transition: all 0.3s ease;
        }

        .resume-link:hover {
            box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
        }

        .resume-icon {
            width: 48px;
            height: 48px;
            background: linear-gradient(135deg, var(--primary), var(--primary-light));
            border-radius: 8px;
            display: flex;
            align-items: center;
            justify-content: center;
            color: white;
            font-size: 24px;
        }

        .file-upload-area {
            border: 2px dashed var(--border);
            border-radius: 12px;
            padding: 2rem;
            text-align: center;
            cursor: pointer;
            transition: all 0.3s ease;
            background: var(--bg-light);
        }

        .file-upload-area:hover {
            border-color: var(--primary);
            background: white;
        }

        .file-upload-area.drag-over {
            border-color: var(--accent);
            background: rgba(212, 165, 116, 0.1);
        }

        .modal {
            display: none;
            position: fixed;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            width: 100%;
            height: 100%;
            background: rgba(0, 0, 0, 0.5);
            z-index: 9999;
            align-items: center;
            justify-content: center;
        }

        .modal.active {
            display: flex !important;
        }

        .modal-content {
            background: white;
            border-radius: 16px;
            padding: 2rem;
            max-width: 600px;
            width: 90%;
            max-height: 90vh;
            overflow-y: auto;
        }

        .modal-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            margin-bottom: 1.5rem;
        }

        .modal-close {
            background: none;
            border: none;
            font-size: 24px;
            cursor: pointer;
            color: #999;
        }

        .avatar-upload-preview {
            width: 150px;
            height: 150px;
            margin: 0 auto 1rem;
            border-radius: 50%;
            overflow: hidden;
            border: 3px solid var(--primary);
            display: flex;
            align-items: center;
            justify-content: center;
            background: linear-gradient(135deg, var(--primary), var(--primary-light));
            color: white;
            font-size: 60px;
            font-weight: 700;
        }

        .avatar-upload-preview img {
            width: 100%;
            height: 100%;
            object-fit: cover;
        }

        /* Responsive */
        @media (max-width: 1024px) {
            .messages-wrapper {
                grid-template-columns: 250px 1fr;
            }

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

            .cta-cards-grid {
                grid-template-columns: 1fr;
            }

            .hub-tab {
                font-size: 12px;
                padding: 8px 10px;
            }

            .grid.two-col {
                grid-template-columns: 1fr;
            }
        }

        @media (max-width: 768px) {
            /* Hide desktop tab nav on mobile — bottom nav takes over */
            .main-nav { display: none !important; }

            /* Add space for bottom nav */
            .main-content {
                padding: 1rem !important;
                padding-bottom: 72px !important;
            }

            body.app-mode #settingsView.active { margin-left: 0; width: 100%; }

            .messages-wrapper { grid-template-columns: 1fr; height: auto; }
            .search-bar { flex-direction: column; }
            .search-bar select { min-width: unset; }

            .auth-container {
                margin: 1.5rem auto;
                padding: 1.5rem;
                max-width: 100%;
                box-sizing: border-box;
            }
            .auth-container h1 { font-size: 24px; }

            /* Modals fit screen */
            .modal-content {
                margin: 1rem;
                max-width: calc(100vw - 2rem) !important;
                box-sizing: border-box;
            }

            /* Profile hero inner */
            .pv-hero-inner { padding: 0 12px !important; }

            /* Inbox — full-screen list, switch to chat when open */
            #inboxView.active { display: flex; flex-direction: column; height: 100%; }
            .ibx-shell { flex-direction: column; }
            .ibx-conv-panel { width: 100% !important; border-right: none; border-bottom: 1px solid var(--border); }
            .ibx-chat-panel { display: none; flex-direction: column; flex: 1; min-height: 0; }
            .ibx-shell.chat-open .ibx-conv-panel { display: none; }
            .ibx-shell.chat-open .ibx-chat-panel { display: flex !important; }
            .ibx-mob-back { display: flex !important; }

            /* Settings mobile already handled below */
        }

        /* Mobile bottom navigation bar */
        .mobile-bottom-nav {
            display: none;
            position: fixed;
            bottom: 0; left: 0; right: 0;
            height: 60px;
            background: var(--card);
            border-top: 1px solid var(--border);
            z-index: 200;
            justify-content: space-around;
            align-items: center;
            padding: 0 4px;
        }
        .mob-nav-btn {
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            gap: 2px;
            background: none;
            border: none;
            color: var(--muted);
            cursor: pointer;
            padding: 4px 10px;
            min-width: 52px;
            font-family: 'DM Sans', sans-serif;
            transition: color .15s;
            border-radius: 10px;
        }
        .mob-nav-btn .mob-nav-icon { font-size: 18px; line-height: 1; }
        .mob-nav-lbl { font-size: 10px; font-weight: 500; }
        .mob-nav-btn.active { color: var(--caramel); }
        .mob-nav-btn:active { background: var(--latte-soft); }
        @media (max-width: 768px) {
            body.app-mode .mobile-bottom-nav { display: flex; }
        }

        /* Inbox mobile back button — hidden on desktop */
        .ibx-mob-back {
            display: none;
            align-items: center;
            gap: 8px;
            background: none;
            border: none;
            color: var(--caramel);
            font-size: 14px;
            font-weight: 600;
            cursor: pointer;
            padding: 0;
            font-family: 'DM Sans', sans-serif;
        }

        /* Scrollbar */
        ::-webkit-scrollbar { width: 5px; height: 5px; }
        ::-webkit-scrollbar-track { background: transparent; }
        ::-webkit-scrollbar-thumb { background: var(--latte); border-radius: 3px; }
        ::-webkit-scrollbar-thumb:hover { background: var(--caramel); }

        /* Floating schedule chat button */
        .btn-schedule-chat {
            background: var(--caramel) !important;
            color: white !important;
            border: none !important;
            border-radius: 20px !important;
            font-weight: 600 !important;
            box-shadow: 0 4px 16px rgba(192,124,58,0.3) !important;
        }
        .btn-schedule-chat:hover {
            background: var(--caramel-light) !important;
            transform: translateY(-2px) !important;
        }

        /* ══════════════════════════════════
           MY CHATS — Redesigned View
        ══════════════════════════════════ */

        /* Extra tokens used in this view */
        #messagesView {
            --mc-steam:       #faf6f1;
            --mc-latte-light: #f0e4d4;
            --mc-honey:       #d4894a;
            --mc-dark-roast:  #2c1a0e;
            --mc-medium-roast:#5c3317;
            --mc-green:       #2d7a4f;
            --mc-green-bg:    #eaf6ef;
            --mc-red:         #c0392b;
            --mc-red-bg:      #fdecea;
            --mc-blue:        #2563eb;
            --mc-blue-bg:     #eff4ff;
            --mc-text-muted:  #8b6a52;
            --mc-text-light:  #c9a98a;
        }

        /* Page header */
        .mc-page-header {
            padding: 28px 36px 0;
            display: flex;
            align-items: flex-end;
            justify-content: space-between;
            gap: 16px;
            flex-wrap: wrap;
        }
        .mc-page-eyebrow {
            font-size: 10px;
            font-weight: 600;
            letter-spacing: 2px;
            text-transform: uppercase;
            color: var(--caramel);
            margin-bottom: 5px;
        }
        .mc-page-title {
            font-family: 'Playfair Display', serif;
            font-size: 28px;
            font-weight: 700;
            color: var(--espresso);
            line-height: 1.1;
        }
        .mc-page-title em { font-style: italic; color: var(--caramel); }
        .mc-btn-schedule {
            display: flex;
            align-items: center;
            gap: 8px;
            padding: 10px 18px;
            background: var(--espresso);
            color: var(--cream);
            border: none;
            border-radius: 10px;
            font-family: 'DM Sans', sans-serif;
            font-size: 13px;
            font-weight: 500;
            cursor: pointer;
            white-space: nowrap;
            transition: all 0.2s;
        }
        .mc-btn-schedule:hover { background: var(--mc-dark-roast); transform: translateY(-1px); box-shadow: 0 6px 20px rgba(26,14,7,0.2); }

        /* Stats row */
        .mc-stats-row {
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            gap: 14px;
            padding: 20px 36px 0;
        }
        .mc-stat-card {
            background: var(--card);
            border: 1px solid var(--border);
            border-radius: 14px;
            padding: 16px 18px;
            display: flex;
            align-items: center;
            gap: 13px;
            transition: border-color 0.2s, box-shadow 0.2s;
        }
        .mc-stat-card:hover { border-color: var(--caramel); box-shadow: 0 4px 16px rgba(192,124,58,0.09); }
        .mc-stat-icon {
            width: 40px; height: 40px;
            border-radius: 10px;
            display: flex; align-items: center; justify-content: center;
            font-size: 17px; flex-shrink: 0;
        }
        .mc-stat-icon.orange { background: rgba(192,124,58,0.1); }
        .mc-stat-icon.green  { background: var(--mc-green-bg); }
        .mc-stat-icon.cream  { background: var(--latte-soft); }
        .mc-stat-icon.blue   { background: var(--mc-blue-bg); }
        .mc-stat-val {
            font-family: 'Playfair Display', serif;
            font-size: 24px; font-weight: 700;
            color: var(--espresso); line-height: 1;
        }
        .mc-stat-lbl { font-size: 11.5px; color: var(--mc-text-muted); margin-top: 2px; }

        /* Content grid */
        .mc-content-grid {
            display: grid;
            grid-template-columns: 1fr 340px;
            gap: 22px;
            padding: 20px 36px 48px;
            align-items: start;
        }

        /* Tabs */
        .mc-tabs-bar {
            display: flex;
            background: var(--card);
            border: 1px solid var(--border);
            border-radius: 12px;
            padding: 4px;
            margin-bottom: 18px;
            width: fit-content;
            gap: 0;
        }
        .mc-tab-btn {
            padding: 7px 16px;
            border: none;
            border-radius: 9px;
            background: transparent;
            font-family: 'DM Sans', sans-serif;
            font-size: 13px;
            font-weight: 500;
            color: var(--mc-text-muted);
            cursor: pointer;
            transition: all 0.2s;
            white-space: nowrap;
        }
        .mc-tab-btn.active {
            background: var(--espresso);
            color: var(--cream);
            box-shadow: 0 2px 8px rgba(26,14,7,0.15);
        }
        .mc-tab-btn:hover:not(.active) { color: var(--espresso); }

        /* Chat cards */
        .mc-chat-list { display: flex; flex-direction: column; gap: 13px; }
        .mc-chat-card {
            background: var(--card);
            border: 1px solid var(--border);
            border-radius: 16px;
            padding: 18px 20px;
            display: flex;
            flex-direction: column;
            gap: 0;
            transition: border-color 0.2s, box-shadow 0.2s, transform 0.15s;
            cursor: pointer;
            position: relative;
            overflow: hidden;
        }
        .mc-chat-card::before {
            content: '';
            position: absolute;
            left: 0; top: 0; bottom: 0;
            width: 3px;
            border-radius: 3px 0 0 3px;
            background: transparent;
            transition: background 0.2s;
        }
        .mc-chat-card:hover { border-color: var(--caramel); box-shadow: 0 4px 20px rgba(192,124,58,0.1); transform: translateY(-1px); }
        .mc-chat-card:hover::before { background: var(--caramel); }
        .mc-chat-card.upcoming::before { background: var(--caramel); }
        .mc-chat-card.completed::before { background: var(--mc-green); }
        .mc-chat-card.pending::before { background: var(--mc-honey); }

        .mc-card-top { display: grid; grid-template-columns: auto 1fr auto; gap: 14px; align-items: center; }

        .mc-avatar-wrap { position: relative; flex-shrink: 0; }
        .mc-avatar {
            width: 48px; height: 48px;
            border-radius: 50%;
            display: flex; align-items: center; justify-content: center;
            font-size: 15px; font-weight: 700; color: white;
        }
        .mc-avatar-status {
            position: absolute;
            bottom: 1px; right: 1px;
            width: 11px; height: 11px;
            border-radius: 50%;
            border: 2px solid var(--card);
        }
        .mc-avatar-status.online  { background: var(--mc-green); }
        .mc-avatar-status.offline { background: var(--latte); }

        .mc-chat-name { font-size: 14.5px; font-weight: 600; color: var(--espresso); margin-bottom: 3px; }
        .mc-chat-meta {
            font-size: 12px; color: var(--mc-text-muted);
            display: flex; align-items: center; gap: 7px; flex-wrap: wrap;
        }
        .mc-meta-dot { width: 3px; height: 3px; border-radius: 50%; background: var(--mc-text-light); }
        .mc-chat-topic { font-size: 12.5px; color: var(--mc-text-muted); margin-top: 5px; }

        .mc-card-right { display: flex; flex-direction: column; align-items: flex-end; gap: 7px; }
        .mc-status-badge {
            display: inline-flex; align-items: center; gap: 5px;
            font-size: 10.5px; font-weight: 500;
            border-radius: 100px;
            padding: 3px 10px;
        }
        .mc-status-badge.upcoming  { background: rgba(192,124,58,0.1); color: var(--caramel); }
        .mc-status-badge.completed { background: var(--mc-green-bg); color: var(--mc-green); }
        .mc-status-badge.pending   { background: rgba(212,150,74,0.12); color: #b37a00; }
        .mc-status-badge.cancelled { background: var(--mc-red-bg); color: var(--mc-red); }

        .mc-chat-date  { font-size: 11.5px; color: var(--mc-text-muted); text-align: right; }
        .mc-chat-time  { font-size: 12.5px; font-weight: 600; color: var(--espresso); }

        /* Card actions */
        .mc-card-actions {
            display: flex; gap: 7px;
            margin-top: 14px;
            padding-top: 13px;
            border-top: 1px solid var(--mc-latte-light);
            flex-wrap: wrap;
        }
        .mc-btn-sm {
            padding: 6px 13px;
            border-radius: 8px;
            font-family: 'DM Sans', sans-serif;
            font-size: 12px; font-weight: 500;
            cursor: pointer;
            border: none;
            transition: all 0.18s;
        }
        .mc-btn-sm.primary { background: var(--espresso); color: var(--cream); }
        .mc-btn-sm.primary:hover { background: var(--mc-dark-roast); }
        .mc-btn-sm.secondary { background: var(--mc-steam); color: var(--mc-text-muted); border: 1px solid var(--border); }
        .mc-btn-sm.secondary:hover { border-color: var(--caramel); color: var(--caramel); }
        .mc-btn-sm.danger { background: transparent; color: var(--mc-red); border: 1px solid var(--border); margin-left: auto; }
        .mc-btn-sm.danger:hover { border-color: var(--mc-red); background: var(--mc-red-bg); }

        /* Meeting detail row (replaces Join Call) */
        .meeting-detail-row {
            display: flex;
            align-items: center;
            gap: 8px;
            padding: 10px 14px;
            background: #f5ece0;
            border: 1px solid #e8d9c8;
            border-radius: 10px;
            margin-top: 10px;
            font-size: 13.5px;
        }
        .meeting-link-btn {
            color: #6b3f2a;
            font-weight: 600;
            text-decoration: none;
            transition: opacity 0.15s;
        }
        .meeting-link-btn:hover { opacity: 0.7; text-decoration: underline; }
        .meeting-detail-row.no-details { color: #9a7a65; font-style: italic; }
        .meeting-detail-icon { font-size: 16px; flex-shrink: 0; }

        /* Icebreakers block */
        .mc-icebreakers {
            background: var(--mc-steam);
            border-radius: 10px;
            padding: 11px 13px;
            margin-top: 13px;
        }
        .mc-icebr-label {
            font-size: 10px; font-weight: 600;
            letter-spacing: 1.5px; text-transform: uppercase;
            color: var(--caramel); margin-bottom: 7px;
        }
        .mc-icebr-item {
            font-size: 12px; color: var(--mc-text-muted);
            padding: 5px 10px;
            background: var(--card);
            border-radius: 7px;
            border: 1px solid var(--border);
            margin-bottom: 5px;
            cursor: pointer;
            transition: border-color 0.15s, color 0.15s;
        }
        .mc-icebr-item:last-child { margin-bottom: 0; }
        .mc-icebr-item:hover { border-color: var(--caramel); color: var(--espresso); }

        /* Right column widgets */
        .mc-right-col { display: flex; flex-direction: column; gap: 18px; }
        .mc-widget {
            background: var(--card);
            border: 1px solid var(--border);
            border-radius: 16px;
            overflow: hidden;
        }
        .mc-widget-header {
            padding: 14px 18px;
            border-bottom: 1px solid var(--mc-latte-light);
            display: flex; align-items: center; justify-content: space-between;
        }
        .mc-widget-title {
            font-family: 'Playfair Display', serif;
            font-size: 15px; font-weight: 700; color: var(--espresso);
        }
        .mc-widget-action {
            font-size: 11.5px; color: var(--caramel);
            cursor: pointer; font-weight: 500;
            background: none; border: none; font-family: 'DM Sans', sans-serif;
        }
        .mc-widget-action:hover { color: var(--mc-medium-roast); }

        /* Mini calendar */
        .mc-cal-wrap { padding: 14px 18px 18px; }
        .mc-cal-nav {
            display: flex; align-items: center; justify-content: space-between;
            margin-bottom: 12px;
        }
        .mc-cal-nav-btn {
            width: 26px; height: 26px;
            border-radius: 7px;
            border: 1px solid var(--border);
            background: transparent;
            cursor: pointer;
            font-size: 12px; color: var(--mc-text-muted);
            display: flex; align-items: center; justify-content: center;
            transition: all 0.15s;
        }
        .mc-cal-nav-btn:hover { border-color: var(--caramel); color: var(--caramel); }
        .mc-cal-month { font-size: 13px; font-weight: 600; color: var(--espresso); }
        .mc-cal-days-grid {
            display: grid;
            grid-template-columns: repeat(7, 1fr);
            text-align: center;
            gap: 1px;
        }
        .mc-cal-day-name {
            font-size: 9.5px; font-weight: 600;
            letter-spacing: 0.5px; text-transform: uppercase;
            color: var(--mc-text-light);
            padding: 4px 0 6px;
        }
        .mc-cal-day {
            aspect-ratio: 1;
            display: flex; align-items: center; justify-content: center;
            font-size: 11.5px;
            border-radius: 6px;
            cursor: pointer;
            color: var(--mc-text-muted);
            transition: background 0.15s, color 0.15s;
            position: relative;
        }
        .mc-cal-day:hover { background: var(--latte-soft); color: var(--espresso); }
        .mc-cal-day.today {
            background: var(--espresso);
            color: var(--cream);
            font-weight: 600;
        }
        .mc-cal-day.has-event::after {
            content: '';
            position: absolute;
            bottom: 2px; left: 50%; transform: translateX(-50%);
            width: 3px; height: 3px;
            border-radius: 50%;
            background: var(--caramel);
        }
        .mc-cal-day.today.has-event::after { background: var(--mc-honey); }
        .mc-cal-day.other-month { color: var(--mc-text-light); opacity: 0.5; }

        /* Upcoming quick list */
        .mc-upcoming-list { padding: 4px 18px 18px; display: flex; flex-direction: column; gap: 10px; }
        .mc-upcoming-item {
            display: flex; align-items: center; gap: 11px;
            padding: 11px 13px;
            background: var(--latte-soft);
            border-radius: 11px;
            border: 1px solid var(--mc-latte-light);
            cursor: pointer;
            transition: border-color 0.2s;
        }
        .mc-upcoming-item:hover { border-color: var(--caramel); }
        .mc-udb {
            min-width: 38px;
            text-align: center;
            padding: 5px 7px;
            background: var(--cream);
            border-radius: 8px;
            border: 1px solid var(--border);
        }
        .mc-udb-month { font-size: 8.5px; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; color: var(--caramel); }
        .mc-udb-day { font-family: 'Playfair Display', serif; font-size: 18px; font-weight: 700; color: var(--espresso); line-height: 1; }
        .mc-upcoming-info { flex: 1; min-width: 0; }
        .mc-upcoming-name { font-size: 13px; font-weight: 600; color: var(--espresso); margin-bottom: 1px; }
        .mc-upcoming-time { font-size: 11px; color: var(--mc-text-muted); }
        .mc-upcoming-mode {
            font-size: 10px; font-weight: 500;
            background: var(--cream); color: var(--caramel);
            border-radius: 100px;
            padding: 2px 8px; white-space: nowrap;
            border: 1px solid var(--border);
        }

        /* Tips widget */
        .mc-tips-widget {
            background: linear-gradient(135deg, var(--espresso) 0%, var(--mc-dark-roast) 100%);
            border: none;
            border-radius: 16px;
            overflow: hidden;
            position: relative;
        }
        .mc-tips-widget::before {
            content: '';
            position: absolute; inset: 0;
            background: radial-gradient(ellipse 80% 80% at 100% 0%, rgba(212,137,74,0.18) 0%, transparent 60%);
            pointer-events: none;
        }
        .mc-tips-body {
            padding: 20px;
            position: relative; z-index: 1;
        }
        .mc-tips-icon { font-size: 26px; margin-bottom: 9px; }
        .mc-tips-title {
            font-family: 'Playfair Display', serif;
            font-size: 14px; font-weight: 700;
            color: var(--cream); margin-bottom: 6px;
        }
        .mc-tips-text { font-size: 12px; line-height: 1.5; color: rgba(245,237,227,0.6); margin-bottom: 13px; }
        .mc-tips-tip {
            background: rgba(255,255,255,0.06);
            border: 1px solid rgba(192,124,58,0.25);
            border-radius: 9px;
            padding: 10px 12px;
            font-size: 12px; color: rgba(245,237,227,0.8);
            line-height: 1.5; font-style: italic;
        }

        /* Empty state within My Chats */
        .mc-empty {
            display: flex; flex-direction: column; align-items: center;
            justify-content: center; text-align: center;
            padding: 48px 20px;
            background: var(--card);
            border: 1.5px dashed var(--border);
            border-radius: 16px;
        }
        .mc-empty-icon { font-size: 40px; margin-bottom: 12px; opacity: 0.6; }
        .mc-empty-title {
            font-family: 'Playfair Display', serif;
            font-size: 18px; color: var(--espresso); margin-bottom: 7px;
        }
        .mc-empty-desc { font-size: 13px; color: var(--mc-text-muted); max-width: 240px; line-height: 1.5; margin-bottom: 18px; }

        /* Direct messages tab (inside My Chats) */
        .mc-messages-wrapper {
            display: grid;
            grid-template-columns: 280px 1fr;
            gap: 0;
            background: var(--card);
            border: 1px solid var(--border);
            border-radius: 16px;
            overflow: hidden;
            min-height: 420px;
        }
        .mc-conv-list {
            border-right: 1px solid var(--border);
            overflow-y: auto;
        }
        .mc-conv-list-header {
            padding: 14px 16px 10px;
            font-size: 11px; font-weight: 600;
            letter-spacing: 1.5px; text-transform: uppercase;
            color: var(--mc-text-muted);
            border-bottom: 1px solid var(--mc-latte-light);
        }
        .mc-chat-win {
            display: flex; flex-direction: column;
        }

        @media (max-width: 1100px) {
            .mc-content-grid { grid-template-columns: 1fr; }
            .mc-right-col { display: grid; grid-template-columns: 1fr 1fr; }
            .mc-stats-row { grid-template-columns: repeat(2, 1fr); }
        }
        @media (max-width: 760px) {
            .mc-page-header, .mc-stats-row, .mc-content-grid { padding-left: 16px; padding-right: 16px; }
            .mc-right-col { grid-template-columns: 1fr; }
            .mc-stats-row { grid-template-columns: repeat(2, 1fr); }
            .mc-messages-wrapper { grid-template-columns: 1fr; }
            .mc-conv-list { border-right: none; border-bottom: 1px solid var(--border); max-height: 200px; }
        }

        /* ══════════════════════════════════
           DASHBOARD — Redesigned View
        ══════════════════════════════════ */

        /* extra tokens for dashboard */
        #dashboardView {
            --db-steam:       #faf6f1;
            --db-latte-light: #f0e4d4;
            --db-honey:       #d4894a;
            --db-dark-roast:  #2c1a0e;
            --db-medium-roast:#5c3317;
            --db-green:       #2d7a4f;
            --db-green-bg:    #eaf6ef;
            --db-blue:        #2563eb;
            --db-blue-bg:     #eff4ff;
            --db-text-muted:  #8b6a52;
            --db-text-light:  #c9a98a;
        }

        /* ── Hero Banner ── */
        .db-hero {
            background: var(--espresso);
            position: relative; overflow: hidden;
            padding: 36px 44px;
            flex-shrink: 0;
        }
        .db-hero::before {
            content: ''; position: absolute; inset: 0;
            background:
                radial-gradient(ellipse 70% 100% at -5% 100%, rgba(192,124,58,.35) 0%, transparent 55%),
                radial-gradient(ellipse 50% 80% at 105% -10%, rgba(212,137,74,.12) 0%, transparent 50%);
            pointer-events: none;
        }
        .db-grain {
            position: absolute; inset: 0;
            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='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");
            pointer-events: none; opacity: .5;
        }
        .db-hero-inner {
            position: relative; z-index: 1;
            display: flex; align-items: center; justify-content: space-between;
            gap: 24px; flex-wrap: wrap;
        }
        .db-greeting {
            font-size: 11px; font-weight: 500; letter-spacing: 2.5px; text-transform: uppercase;
            color: var(--db-honey); margin-bottom: 10px;
            display: flex; align-items: center; gap: 8px;
        }
        .db-greeting::before { content: ''; display: block; width: 20px; height: 1px; background: var(--db-honey); }
        .db-hero-title {
            font-family: 'Playfair Display', serif; font-size: 34px; font-weight: 700;
            color: var(--cream); line-height: 1.15; margin-bottom: 10px;
        }
        .db-hero-title em { font-style: italic; color: var(--db-honey); }
        .db-hero-sub { font-size: 13.5px; color: rgba(245,237,227,.55); max-width: 380px; line-height: 1.55; }
        .db-hero-stats { display: flex; gap: 12px; flex-wrap: wrap; }
        .db-hero-stat {
            background: rgba(255,255,255,.06); border: 1px solid rgba(192,124,58,.2);
            border-radius: 14px; padding: 16px 20px; text-align: center; min-width: 90px;
            backdrop-filter: blur(8px);
        }
        .db-stat-val {
            font-family: 'Playfair Display', serif; font-size: 28px; font-weight: 700;
            color: var(--cream); line-height: 1;
        }
        .db-stat-lbl { font-size: 11px; color: rgba(245,237,227,.5); margin-top: 4px; }

        /* ── Setup Bar ── */
        .db-setup-bar {
            background: var(--card); border-bottom: 1px solid var(--border);
            padding: 12px 44px;
            display: flex; align-items: center; gap: 18px; flex-wrap: wrap;
            flex-shrink: 0;
        }
        .db-setup-label { font-size: 12.5px; font-weight: 600; color: var(--espresso); white-space: nowrap; }
        .db-setup-steps { display: flex; gap: 6px; flex: 1; flex-wrap: wrap; }
        .db-setup-step {
            display: flex; align-items: center; gap: 7px;
            padding: 6px 12px; border-radius: 100px;
            font-size: 11.5px; font-weight: 500;
            border: 1.5px solid var(--border); background: var(--latte-soft); color: var(--muted);
            cursor: pointer; transition: all .2s; white-space: nowrap;
        }
        .db-setup-step.done { background: var(--db-green-bg); border-color: var(--db-green); color: var(--db-green); }
        .db-setup-step.active { background: var(--cream); border-color: var(--caramel); color: var(--caramel); }
        .db-step-num {
            width: 17px; height: 17px; border-radius: 50%;
            background: var(--latte); color: var(--muted);
            display: flex; align-items: center; justify-content: center;
            font-size: 9.5px; font-weight: 700; flex-shrink: 0;
        }
        .db-setup-step.done .db-step-num { background: var(--db-green); color: white; }
        .db-setup-step.active .db-step-num { background: var(--caramel); color: white; }
        .db-setup-cta {
            padding: 8px 16px; background: var(--espresso); color: var(--cream);
            border: none; border-radius: 8px; font-family: 'DM Sans', sans-serif;
            font-size: 12px; font-weight: 500; cursor: pointer;
            white-space: nowrap; transition: background .2s;
        }
        .db-setup-cta:hover { background: var(--db-dark-roast); }

        /* ── Content ── */
        .db-content { padding: 26px 44px 60px; display: flex; flex-direction: column; gap: 26px; }

        /* Section heading */
        .db-sec-head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 14px; }
        .db-sec-title { font-family: 'Playfair Display', serif; font-size: 20px; font-weight: 700; color: var(--espresso); }
        .db-sec-title em { font-style: italic; color: var(--caramel); }
        .db-sec-link {
            font-size: 12.5px; color: var(--caramel); font-weight: 500;
            cursor: pointer; text-decoration: none; background: none; border: none;
            font-family: 'DM Sans', sans-serif;
        }
        .db-sec-link:hover { color: var(--db-medium-roast); }

        /* Grid layouts */
        .db-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
        .db-grid-main { display: grid; grid-template-columns: 1fr 330px; gap: 22px; align-items: start; }
        .db-left-col { display: flex; flex-direction: column; gap: 22px; }
        .db-right-col { display: flex; flex-direction: column; gap: 18px; }

        /* Card base */
        .db-card {
            background: var(--card); border: 1px solid var(--border); border-radius: 16px;
            transition: border-color .2s, box-shadow .2s;
        }
        .db-card:hover { border-color: var(--caramel); box-shadow: 0 4px 20px rgba(192,124,58,.08); }

        /* Quick action cards */
        .db-quick-card {
            padding: 18px; display: flex; flex-direction: column; gap: 9px; cursor: pointer;
        }
        .db-qc-icon {
            width: 42px; height: 42px; border-radius: 11px;
            display: flex; align-items: center; justify-content: center; font-size: 19px;
        }
        .db-qc-icon.orange { background: rgba(192,124,58,.1); }
        .db-qc-icon.green  { background: var(--db-green-bg); }
        .db-qc-icon.cream  { background: var(--latte-soft); }
        .db-qc-icon.blue   { background: var(--db-blue-bg); }
        .db-qc-title { font-size: 14px; font-weight: 600; color: var(--espresso); }
        .db-qc-desc  { font-size: 12px; color: var(--db-text-muted); line-height: 1.45; }
        .db-qc-arrow { font-size: 12.5px; color: var(--caramel); margin-top: auto; font-weight: 500; }

        /* ── Upcoming Chat Card (dark) ── */
        .db-upcoming-card {
            background: var(--espresso); border-radius: 16px; padding: 22px 24px;
            position: relative; overflow: hidden; cursor: pointer;
            transition: transform .2s, box-shadow .2s;
        }
        .db-upcoming-card:hover { transform: translateY(-2px); box-shadow: 0 12px 32px rgba(26,14,7,.25); }
        .db-upcoming-card::before {
            content: ''; position: absolute; inset: 0;
            background: radial-gradient(ellipse 80% 80% at 100% 0%, rgba(212,137,74,.18) 0%, transparent 55%);
            pointer-events: none;
        }
        .db-ucc-inner { position: relative; z-index: 1; }
        .db-ucc-eyebrow {
            font-size: 9.5px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase;
            color: var(--db-honey); margin-bottom: 12px;
            display: flex; align-items: center; gap: 7px;
        }
        .db-ucc-eyebrow::before { content: ''; display: block; width: 14px; height: 1px; background: var(--db-honey); }
        .db-countdown-pill {
            display: inline-flex; align-items: center; gap: 6px;
            background: rgba(212,137,74,.15); border: 1px solid rgba(212,137,74,.3);
            border-radius: 100px; padding: 4px 12px; font-size: 12px;
            color: var(--db-honey); font-weight: 500; margin-bottom: 14px;
        }
        .db-pulse { width: 6px; height: 6px; border-radius: 50%; background: var(--db-honey); animation: dbPulse 2s ease-in-out infinite; }
        @keyframes dbPulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(.85)} }
        .db-ucc-person { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
        .db-ucc-avatar {
            width: 46px; height: 46px; border-radius: 50%;
            background: linear-gradient(135deg, var(--caramel), var(--db-honey));
            display: flex; align-items: center; justify-content: center;
            font-size: 15px; font-weight: 700; color: white;
            border: 2px solid rgba(255,255,255,.15); flex-shrink: 0;
        }
        .db-ucc-name { font-family: 'Playfair Display', serif; font-size: 18px; font-weight: 700; color: var(--cream); }
        .db-ucc-role { font-size: 12px; color: rgba(245,237,227,.55); }
        .db-ucc-details { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 16px; }
        .db-ucc-detail {
            display: flex; align-items: center; gap: 5px;
            font-size: 12px; color: rgba(245,237,227,.7);
            background: rgba(255,255,255,.06); border: 1px solid rgba(192,124,58,.2);
            padding: 4px 11px; border-radius: 100px;
        }
        .db-ucc-actions { display: flex; gap: 8px; flex-wrap: wrap; }
        .db-ucc-btn-primary {
            flex: 1; padding: 10px; min-width: 120px;
            background: linear-gradient(135deg, var(--caramel), var(--db-honey));
            color: white; border: none; border-radius: 9px;
            font-family: 'DM Sans', sans-serif; font-size: 13px; font-weight: 600;
            cursor: pointer; transition: opacity .2s, transform .2s;
        }
        .db-ucc-btn-primary:hover { opacity: .9; transform: translateY(-1px); }
        .db-ucc-btn-secondary {
            padding: 10px 16px;
            background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.12);
            color: rgba(245,237,227,.7); border-radius: 9px;
            font-family: 'DM Sans', sans-serif; font-size: 13px;
            cursor: pointer; transition: background .2s;
        }
        .db-ucc-btn-secondary:hover { background: rgba(255,255,255,.12); }

        /* No upcoming chat empty */
        .db-no-sip {
            background: var(--card); border: 1.5px dashed var(--border);
            border-radius: 16px; padding: 36px 24px;
            text-align: center;
        }
        .db-no-sip-icon { font-size: 36px; margin-bottom: 10px; opacity: .6; }
        .db-no-sip-title { font-family: 'Playfair Display', serif; font-size: 17px; color: var(--espresso); margin-bottom: 6px; }
        .db-no-sip-desc { font-size: 12.5px; color: var(--db-text-muted); margin-bottom: 16px; }
        .db-no-sip-btn {
            padding: 9px 18px; background: var(--espresso); color: var(--cream);
            border: none; border-radius: 9px; font-family: 'DM Sans', sans-serif;
            font-size: 13px; font-weight: 500; cursor: pointer; transition: all .2s;
        }
        .db-no-sip-btn:hover { background: var(--db-dark-roast); transform: translateY(-1px); }

        /* ── Suggested Match cards ── */
        .db-match-row {
            display: flex; align-items: center; gap: 13px;
            padding: 14px 18px; cursor: pointer;
            border-bottom: 1px solid var(--db-latte-light);
            position: relative; overflow: hidden;
            transition: background .15s;
        }
        .db-match-row:last-child { border-bottom: none; }
        .db-match-row:hover { background: var(--db-steam); }
        .db-match-row::before {
            content: ''; position: absolute; left: 0; top: 0; bottom: 0;
            width: 3px; background: transparent; transition: background .2s;
        }
        .db-match-row:hover::before { background: var(--caramel); }
        .db-match-av {
            width: 46px; height: 46px; border-radius: 50%; flex-shrink: 0;
            display: flex; align-items: center; justify-content: center;
            font-size: 15px; font-weight: 700; color: white;
            position: relative;
        }
        .db-match-online {
            position: absolute; bottom: 1px; right: 1px;
            width: 11px; height: 11px; border-radius: 50%;
            background: var(--db-green); border: 2px solid var(--card);
        }
        .db-match-info { flex: 1; min-width: 0; }
        .db-match-name { font-size: 14px; font-weight: 600; color: var(--espresso); margin-bottom: 2px; }
        .db-match-meta { font-size: 11.5px; color: var(--db-text-muted); margin-bottom: 5px; }
        .db-match-tags { display: flex; gap: 5px; flex-wrap: wrap; }
        .db-tag { font-size: 10.5px; padding: 2px 8px; border-radius: 100px; background: var(--cream); color: var(--caramel); font-weight: 500; }
        .db-match-right { display: flex; flex-direction: column; align-items: flex-end; gap: 8px; flex-shrink: 0; }
        .db-pct-ring { width: 40px; height: 40px; position: relative; }
        .db-pct-ring svg { transform: rotate(-90deg); }
        .db-pct-ring circle.bg { fill: none; stroke: var(--latte); stroke-width: 3; }
        .db-pct-ring circle.fill { fill: none; stroke: var(--caramel); stroke-width: 3; stroke-linecap: round; }
        .db-pct-label { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; font-size: 10px; font-weight: 700; color: var(--caramel); }
        .db-btn-chat {
            padding: 6px 13px; background: var(--espresso); color: var(--cream);
            border: none; border-radius: 8px; font-family: 'DM Sans', sans-serif;
            font-size: 12px; font-weight: 500; cursor: pointer; transition: all .2s;
            white-space: nowrap;
        }
        .db-btn-chat:hover { background: var(--db-dark-roast); transform: translateY(-1px); }

        /* ── Activity feed ── */
        .db-activity-item {
            display: flex; align-items: flex-start; gap: 12px;
            padding: 13px 18px; border-bottom: 1px solid var(--db-latte-light);
            transition: background .15s; cursor: pointer;
        }
        .db-activity-item:last-child { border-bottom: none; }
        .db-activity-item:hover { background: var(--db-steam); }
        .db-act-icon {
            width: 34px; height: 34px; border-radius: 50%; flex-shrink: 0;
            display: flex; align-items: center; justify-content: center; font-size: 13px;
        }
        .db-act-icon.orange { background: rgba(192,124,58,.1); }
        .db-act-icon.green  { background: var(--db-green-bg); }
        .db-act-icon.blue   { background: var(--db-blue-bg); }
        .db-act-icon.cream  { background: var(--latte-soft); }
        .db-act-main { font-size: 13px; color: var(--espresso); line-height: 1.4; }
        .db-act-main strong { font-weight: 600; }
        .db-act-time { font-size: 11px; color: var(--db-text-light); margin-top: 3px; }
        .db-act-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--caramel); flex-shrink: 0; margin-top: 5px; }

        /* ── Widget header ── */
        .db-widget-header {
            padding: 14px 18px; border-bottom: 1px solid var(--db-latte-light);
            display: flex; align-items: center; justify-content: space-between;
        }
        .db-widget-title { font-family: 'Playfair Display', serif; font-size: 16px; font-weight: 700; color: var(--espresso); }
        .db-widget-action {
            font-size: 11.5px; color: var(--caramel); font-weight: 500;
            background: none; border: none; font-family: 'DM Sans', sans-serif; cursor: pointer;
        }
        .db-widget-action:hover { color: var(--db-medium-roast); }

        /* ── Groups widget ── */
        .db-group-item {
            display: flex; align-items: center; gap: 11px;
            padding: 11px 18px; border-bottom: 1px solid var(--db-latte-light);
            cursor: pointer; transition: background .15s;
        }
        .db-group-item:last-child { border-bottom: none; }
        .db-group-item:hover { background: var(--db-steam); }
        .db-group-icon {
            width: 38px; height: 38px; border-radius: 10px; flex-shrink: 0;
            display: flex; align-items: center; justify-content: center; font-size: 17px;
            background: var(--cream); border: 1px solid var(--border);
        }
        .db-group-name { font-size: 13px; font-weight: 600; color: var(--espresso); margin-bottom: 1px; }
        .db-group-meta { font-size: 11px; color: var(--db-text-muted); }
        .db-group-badge {
            margin-left: auto; background: var(--cream); border: 1px solid var(--border);
            color: var(--caramel); font-size: 10px; font-weight: 600;
            border-radius: 100px; padding: 2px 9px; white-space: nowrap;
        }
        .db-group-badge.new { background: rgba(192,124,58,.1); border-color: rgba(192,124,58,.2); }

        /* ── Badges grid ── */
        .db-badges-grid {
            display: flex; gap: 8px; flex-wrap: wrap; padding: 14px 18px 18px;
        }

        /* ── Tip card ── */
        .db-tip-card {
            background: var(--espresso); border-radius: 16px;
            padding: 20px; position: relative; overflow: hidden;
        }
        .db-tip-card::before {
            content: ''; position: absolute; inset: 0;
            background: radial-gradient(ellipse 80% 80% at 100% 0%, rgba(212,137,74,.18) 0%, transparent 55%);
            pointer-events: none;
        }
        .db-tip-inner { position: relative; z-index: 1; }
        .db-tip-icon { font-size: 26px; margin-bottom: 9px; }
        .db-tip-title { font-family: 'Playfair Display', serif; font-size: 15px; font-weight: 700; color: var(--cream); margin-bottom: 8px; }
        .db-tip-text { font-size: 12.5px; line-height: 1.55; color: rgba(245,237,227,.6); font-style: italic; }

        /* Responsive */
        @media (max-width: 1100px) { .db-grid-main { grid-template-columns: 1fr; } }
        @media (max-width: 900px)  { .db-grid-3 { grid-template-columns: repeat(2, 1fr); } }
        @media (max-width: 760px)  {
            .db-hero, .db-content { padding-left: 20px; padding-right: 20px; }
            .db-setup-bar { padding-left: 20px; padding-right: 20px; }
            .db-grid-3 { grid-template-columns: 1fr; }
        }

        /* ── Redesigned Dashboard Layout ── */
        .db-header {
            padding: 28px 36px 0;
            flex-shrink: 0;
        }
        .db-greeting-row {
            display: flex;
            align-items: flex-start;
            justify-content: space-between;
            gap: 16px;
            flex-wrap: wrap;
        }
        .db-greeting-h1 {
            font-family: 'Playfair Display', serif;
            font-size: 28px;
            color: var(--espresso);
            line-height: 1.2;
            margin-bottom: 6px;
        }
        .db-greeting-h1 em { font-style: italic; color: var(--caramel); }
        .db-greeting-sub {
            font-size: 14px;
            color: var(--muted);
        }
        .db-alert-pill {
            display: flex;
            align-items: center;
            gap: 10px;
            background: var(--card);
            border: 1.5px solid var(--border);
            border-radius: 12px;
            padding: 12px 16px;
            flex-shrink: 0;
            box-shadow: var(--shadow);
            cursor: pointer;
            transition: all 0.15s;
        }
        .db-alert-pill:hover { border-color: var(--caramel); box-shadow: var(--shadow-hover); }
        .db-alert-dot {
            width: 8px; height: 8px;
            background: var(--caramel);
            border-radius: 50%;
            flex-shrink: 0;
            animation: dbAlertPulse 2s infinite;
        }
        @keyframes dbAlertPulse {
            0%, 100% { opacity: 1; transform: scale(1); }
            50% { opacity: 0.6; transform: scale(1.2); }
        }
        .db-alert-text { font-size: 13px; font-weight: 600; color: var(--espresso); }
        .db-alert-sub { font-size: 11.5px; color: var(--muted); margin-top: 1px; }
        .db-alert-arrow { font-size: 14px; color: var(--caramel); margin-left: 4px; }

        /* Sections */
        .db-section { padding: 20px 36px; }
        .db-section-header {
            display: flex;
            align-items: center;
            justify-content: space-between;
            margin-bottom: 12px;
        }
        .db-section-label {
            font-size: 11px;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 0.9px;
            color: var(--muted);
        }
        .db-see-all {
            font-size: 12.5px;
            color: var(--caramel);
            font-weight: 600;
            cursor: pointer;
            background: none;
            border: none;
            font-family: 'DM Sans', sans-serif;
            transition: opacity 0.15s;
        }
        .db-see-all:hover { opacity: 0.7; }

        /* Light Next Chat Card */
        .db-next-chat-card {
            background: var(--card);
            border-radius: 14px;
            border: 1px solid var(--border);
            padding: 20px 24px;
            display: flex;
            align-items: center;
            gap: 20px;
            box-shadow: var(--shadow);
            transition: box-shadow 0.15s;
        }
        .db-next-chat-card:hover { box-shadow: var(--shadow-hover); }
        .db-ncc-avatar {
            width: 56px; height: 56px;
            border-radius: 50%;
            display: flex; align-items: center; justify-content: center;
            font-size: 20px; font-weight: 700; color: white;
            flex-shrink: 0;
            border: 2.5px solid var(--caramel);
        }
        .db-ncc-info { flex: 1; min-width: 0; }
        .db-ncc-name { font-size: 16px; font-weight: 600; color: var(--espresso); margin-bottom: 3px; }
        .db-ncc-role { font-size: 13px; color: var(--muted); margin-bottom: 10px; }
        .db-ncc-meta { display: flex; flex-wrap: wrap; gap: 8px; }
        .db-meta-chip {
            display: flex; align-items: center; gap: 5px;
            background: var(--latte-soft);
            border-radius: 99px;
            padding: 4px 10px;
            font-size: 12px;
            color: var(--muted);
            font-weight: 500;
            border: 1px solid var(--border);
        }
        .db-ncc-actions {
            display: flex;
            flex-direction: column;
            gap: 8px;
            align-items: flex-end;
            flex-shrink: 0;
        }
        .db-countdown-badge {
            background: var(--db-green-bg);
            color: var(--db-green);
            font-size: 11.5px;
            font-weight: 700;
            border-radius: 99px;
            padding: 4px 10px;
            white-space: nowrap;
        }
        .db-ncc-btn-primary {
            background: var(--espresso);
            color: var(--cream);
            border: none;
            border-radius: 10px;
            padding: 10px 20px;
            font-size: 13.5px;
            font-weight: 600;
            cursor: pointer;
            font-family: 'DM Sans', sans-serif;
            transition: all 0.15s;
            white-space: nowrap;
        }
        .db-ncc-btn-primary:hover { opacity: 0.85; transform: translateY(-1px); }
        .db-ncc-btn-secondary {
            background: transparent;
            color: var(--muted);
            border: 1.5px solid var(--border);
            border-radius: 10px;
            padding: 8px 16px;
            font-size: 12.5px;
            font-weight: 500;
            cursor: pointer;
            font-family: 'DM Sans', sans-serif;
            transition: all 0.15s;
            white-space: nowrap;
        }
        .db-ncc-btn-secondary:hover { border-color: var(--caramel); color: var(--caramel); }

        /* People grid */
        .db-people-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 14px;
        }
        .db-person-card {
            background: var(--card);
            border-radius: 14px;
            border: 1px solid var(--border);
            padding: 20px 16px 16px;
            text-align: center;
            box-shadow: var(--shadow);
            transition: all 0.15s;
            cursor: pointer;
            position: relative;
            overflow: hidden;
        }
        .db-person-card:hover {
            box-shadow: var(--shadow-hover);
            transform: translateY(-2px);
            border-color: var(--caramel);
        }
        .db-person-card-av {
            width: 52px; height: 52px;
            border-radius: 50%;
            margin: 0 auto 10px;
            font-size: 18px; font-weight: 700; color: white;
            display: flex; align-items: center; justify-content: center;
            border: 2px solid var(--border);
        }
        .db-person-card-name { font-size: 14px; font-weight: 600; color: var(--espresso); margin-bottom: 2px; }
        .db-person-card-role { font-size: 11.5px; color: var(--muted); margin-bottom: 12px; line-height: 1.4; }
        .db-person-pct-badge {
            position: absolute;
            top: 10px; right: 10px;
            background: var(--latte-soft);
            color: var(--caramel);
            font-size: 10.5px;
            font-weight: 700;
            border-radius: 99px;
            padding: 2px 7px;
            border: 1px solid var(--border);
        }
        .db-person-card-btn {
            width: 100%;
            background: var(--latte-soft);
            color: var(--brown);
            border: 1.5px solid var(--border);
            border-radius: 8px;
            padding: 7px 12px;
            font-size: 12.5px;
            font-weight: 600;
            cursor: pointer;
            font-family: 'DM Sans', sans-serif;
            transition: all 0.15s;
        }
        .db-person-card-btn:hover { background: var(--espresso); color: var(--cream); border-color: var(--espresso); }

        @media (max-width: 900px) { .db-people-grid { grid-template-columns: repeat(2, 1fr); } }
        @media (max-width: 600px) { .db-people-grid { grid-template-columns: 1fr 1fr; } }
        @media (max-width: 760px) {
            .db-header { padding: 20px 16px 0; }
            .db-section { padding: 16px; }
            .db-next-chat-card { flex-wrap: wrap; }
            .db-ncc-actions { flex-direction: row; width: 100%; }
        }

        /* ===================================================
           SHARED VIEW HEADER  (reused across new view shells)
           =================================================== */
        .view-header {
            margin-bottom: 28px;
        }
        .view-eyebrow {
            font-size: 11px;
            font-weight: 700;
            letter-spacing: .1em;
            text-transform: uppercase;
            color: var(--caramel);
            margin-bottom: 4px;
        }
        .view-title {
            font-family: 'Playfair Display', serif;
            font-size: clamp(22px, 3vw, 30px);
            font-weight: 700;
            color: var(--espresso);
            line-height: 1.18;
            margin: 0 0 5px;
        }
        .view-title em { font-style: italic; color: var(--caramel); }
        .view-subtitle {
            font-size: 13.5px;
            color: var(--muted);
            margin: 0;
        }
        .view-header-row {
            display: flex;
            align-items: flex-end;
            justify-content: space-between;
            gap: 16px;
            flex-wrap: wrap;
        }

        /* Shared back button */
        .pv-back {
            display: inline-flex;
            align-items: center;
            gap: 6px;
            font-size: 13px;
            font-weight: 600;
            color: var(--muted);
            background: none;
            border: none;
            cursor: pointer;
            padding: 6px 0;
            margin-bottom: 20px;
            font-family: 'DM Sans', sans-serif;
            transition: color .15s;
        }
        .pv-back:hover { color: var(--caramel); }

        /* ===================================================
           DISCOVER VIEW  (dv-*)
           =================================================== */
        #discoverView { padding-bottom: 2rem; }

        .dv-filter-card {
            background: var(--card);
            border: 1px solid var(--border);
            border-radius: 16px;
            padding: 20px 22px;
            margin-bottom: 28px;
            box-shadow: var(--shadow);
        }
        .dv-filter-title {
            font-size: 12px;
            font-weight: 700;
            letter-spacing: .08em;
            text-transform: uppercase;
            color: var(--muted);
            margin: 0 0 14px;
        }
        .dv-search-row {
            display: grid;
            grid-template-columns: 1fr;
            gap: 10px;
            margin-bottom: 10px;
        }
        .dv-filter-row {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 10px;
            margin-bottom: 10px;
        }
        .dv-input {
            width: 100%;
            padding: 10px 14px;
            font-size: 13.5px;
            font-family: 'DM Sans', sans-serif;
            border: 1.5px solid var(--border);
            border-radius: 10px;
            background: var(--warm-white);
            color: var(--espresso);
            box-sizing: border-box;
            transition: border-color .15s;
            outline: none;
        }
        .dv-input:focus { border-color: var(--caramel); }
        .dv-input::placeholder { color: var(--muted); opacity: .7; }
        .dv-filter-actions {
            display: flex;
            gap: 10px;
            margin-top: 14px;
        }
        .dv-btn-primary {
            padding: 9px 22px;
            background: var(--caramel);
            color: #fff;
            border: none;
            border-radius: 100px;
            font-size: 13px;
            font-weight: 600;
            font-family: 'DM Sans', sans-serif;
            cursor: pointer;
            transition: background .15s;
        }
        .dv-btn-primary:hover { background: var(--caramel-light); }
        .dv-btn-secondary {
            padding: 9px 22px;
            background: var(--latte-soft);
            color: var(--espresso);
            border: none;
            border-radius: 100px;
            font-size: 13px;
            font-weight: 600;
            font-family: 'DM Sans', sans-serif;
            cursor: pointer;
            transition: background .15s;
        }
        .dv-btn-secondary:hover { background: var(--latte); }

        /* ===================================================
           FEED VIEW  (fv-*)
           =================================================== */
        #feedView { padding-bottom: 2rem; }

        .fv-toolbar {
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 12px;
            flex-wrap: wrap;
            margin-bottom: 22px;
        }
        .fv-tabs {
            display: flex;
            background: var(--latte-soft);
            border-radius: 100px;
            padding: 3px;
            gap: 2px;
        }
        .fv-tab {
            padding: 7px 18px;
            border: none;
            border-radius: 100px;
            font-size: 13px;
            font-weight: 600;
            font-family: 'DM Sans', sans-serif;
            cursor: pointer;
            background: transparent;
            color: var(--muted);
            transition: all .15s;
        }
        .fv-tab.active, .fv-tab:focus {
            background: var(--espresso);
            color: #fff;
            outline: none;
        }
        .fv-tab:hover:not(.active) { color: var(--espresso); }
        .fv-create-btn {
            display: inline-flex;
            align-items: center;
            gap: 6px;
            padding: 9px 20px;
            background: var(--caramel);
            color: #fff;
            border: none;
            border-radius: 100px;
            font-size: 13px;
            font-weight: 600;
            font-family: 'DM Sans', sans-serif;
            cursor: pointer;
            transition: background .15s;
        }
        .fv-create-btn:hover { background: var(--caramel-light); }

        /* ===================================================
           GROUPS VIEW  (gv-*)
           =================================================== */
        #groupsView { padding-bottom: 2rem; }

        .gv-header-row {
            display: flex;
            align-items: flex-end;
            justify-content: space-between;
            gap: 16px;
            flex-wrap: wrap;
            margin-bottom: 28px;
        }
        .gv-create-btn {
            display: inline-flex;
            align-items: center;
            gap: 6px;
            padding: 10px 22px;
            background: var(--caramel);
            color: #fff;
            border: none;
            border-radius: 100px;
            font-size: 13px;
            font-weight: 600;
            font-family: 'DM Sans', sans-serif;
            cursor: pointer;
            white-space: nowrap;
            transition: background .15s;
            flex-shrink: 0;
        }
        .gv-create-btn:hover { background: var(--caramel-light); }
        .gv-section-head {
            display: flex;
            align-items: center;
            justify-content: space-between;
            margin: 28px 0 14px;
            padding-bottom: 10px;
            border-bottom: 1.5px solid var(--border);
        }
        .gv-section-title {
            font-family: 'Playfair Display', serif;
            font-size: 18px;
            font-weight: 700;
            color: var(--espresso);
            margin: 0;
        }
        .gv-section-title:first-child { margin-top: 0; }

        /* ===================================================
           COMMUNITIES PANEL  (nwc-*)
           =================================================== */

        /* Header */
        .nwc-page-header {
            display: flex; align-items: flex-end; justify-content: space-between;
            margin-bottom: 22px; gap: 12px; flex-wrap: wrap;
        }
        .nwc-eyebrow {
            font-size: 11px; font-weight: 500; text-transform: uppercase;
            letter-spacing: 0.1em; color: var(--caramel); margin-bottom: 4px;
        }
        .nwc-title {
            font-family: 'Playfair Display', serif;
            font-size: 26px; font-weight: 400; color: var(--espresso);
            letter-spacing: -0.02em; line-height: 1.1; margin: 0;
        }
        .nwc-title em { font-style: italic; color: var(--caramel); }

        .nwc-btn-create {
            display: flex; align-items: center; gap: 6px;
            padding: 9px 16px; background: var(--caramel); color: #fff;
            border: none; border-radius: 9px; font-size: 13px; font-weight: 500;
            cursor: pointer; font-family: 'Sora', sans-serif; transition: background 0.15s;
            flex-shrink: 0;
        }
        .nwc-btn-create:hover { background: #9A5418; }

        /* Filter bar */
        .nwc-filter-bar { display: flex; gap: 10px; margin-bottom: 24px; flex-wrap: wrap; }

        .nwc-search-wrap {
            position: relative; flex: 1; min-width: 180px;
        }
        .nwc-search-wrap svg {
            position: absolute; left: 11px; top: 50%; transform: translateY(-50%);
            width: 14px; height: 14px; pointer-events: none; stroke: var(--muted);
        }
        .nwc-search-input {
            width: 100%; padding: 9px 12px 9px 33px;
            border: 1px solid var(--border-strong); border-radius: 9px;
            font-size: 13px; font-family: 'Sora', sans-serif;
            background: #fff; color: var(--espresso); outline: none;
            transition: border-color 0.15s;
        }
        .nwc-search-input:focus { border-color: var(--caramel); }

        .nwc-chips { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }
        .nwc-chip {
            padding: 6px 13px; border: 1px solid var(--border-strong);
            border-radius: 20px; font-size: 12px; color: var(--muted);
            background: #fff; cursor: pointer; transition: all 0.15s;
            font-family: 'Sora', sans-serif; white-space: nowrap;
        }
        .nwc-chip:hover { border-color: var(--caramel); color: var(--caramel); }
        .nwc-chip.active { background: #F5EDE3; border-color: var(--caramel); color: var(--caramel); font-weight: 500; }

        /* Section head */
        .nwc-section-head {
            font-size: 11px; font-weight: 500; text-transform: uppercase;
            letter-spacing: 0.08em; color: var(--muted); margin-bottom: 12px;
        }

        /* Joined row — horizontal scroll */
        .nwc-joined-row {
            display: flex; gap: 12px; overflow-x: auto;
            padding-bottom: 4px; scrollbar-width: none;
        }
        .nwc-joined-row::-webkit-scrollbar { display: none; }
        .nwc-joined-empty { font-size: 13px; color: var(--muted); font-style: italic; padding: 4px 0; }

        .nwc-joined-card {
            flex-shrink: 0; width: 180px;
            background: #fff; border: 1px solid var(--border);
            border-radius: 14px; padding: 14px 14px 12px;
            cursor: pointer; transition: all 0.15s; position: relative; overflow: hidden;
        }
        .nwc-joined-card::before {
            content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
            background: var(--caramel); border-radius: 14px 14px 0 0;
        }
        .nwc-joined-card:hover { border-color: var(--border-strong); transform: translateY(-2px); box-shadow: 0 4px 16px rgba(28,15,7,0.08); }
        .nwc-joined-icon { font-size: 22px; margin-bottom: 8px; }
        .nwc-joined-name { font-size: 13px; font-weight: 600; color: var(--espresso); margin-bottom: 3px; line-height: 1.3; }
        .nwc-joined-members { font-size: 11px; color: var(--muted); }

        /* Featured grid */
        .nwc-grid {
            display: grid;
            grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
            gap: 14px;
        }
        .nwc-card {
            background: #fff; border: 1px solid var(--border);
            border-radius: 14px; overflow: hidden; cursor: pointer;
            transition: all 0.15s;
        }
        .nwc-card:hover { border-color: var(--border-strong); transform: translateY(-2px); box-shadow: 0 4px 20px rgba(28,15,7,0.09); }

        .nwc-card-banner {
            height: 64px; display: flex; align-items: center;
            padding: 0 16px; font-size: 34px; position: relative;
        }
        .nwc-card-body { padding: 14px 16px; }
        .nwc-card-name {
            font-family: 'Playfair Display', serif;
            font-size: 15px; font-weight: 400; color: var(--espresso);
            letter-spacing: -0.01em; margin-bottom: 4px;
        }
        .nwc-card-desc {
            font-size: 12px; color: var(--muted); line-height: 1.5; margin-bottom: 11px;
        }
        .nwc-card-footer { display: flex; align-items: center; justify-content: space-between; }
        .nwc-card-meta { font-size: 11px; color: var(--muted); }

        .nwc-btn-join {
            padding: 5px 13px; background: var(--caramel); color: #fff;
            border: none; border-radius: 7px; font-size: 12px; font-weight: 500;
            cursor: pointer; font-family: 'Sora', sans-serif; transition: background 0.15s;
        }
        .nwc-btn-join:hover { background: #9A5418; }
        .nwc-btn-joined {
            padding: 5px 13px; background: #F5EDE3; color: var(--caramel);
            border: 1px solid rgba(181,101,29,0.2); border-radius: 7px;
            font-size: 12px; font-weight: 500; cursor: pointer;
            font-family: 'Sora', sans-serif; transition: all 0.15s;
        }
        .nwc-btn-joined:hover { background: #ffe8e8; color: #c0392b; border-color: #f5c6c2; }

        /* Back button */
        .nwc-back-btn {
            display: flex; align-items: center; gap: 6px;
            font-size: 13px; color: var(--muted); cursor: pointer;
            margin-bottom: 20px; padding: 6px 0; border: none;
            background: none; font-family: 'Sora', sans-serif; transition: color 0.15s;
        }
        .nwc-back-btn:hover { color: var(--caramel); }
        .nwc-back-btn svg { width: 15px; height: 15px; stroke: currentColor; stroke-width: 2; }

        /* Detail hero */
        .nwc-hero {
            background: #fff; border: 1px solid var(--border);
            border-radius: 16px; overflow: hidden; margin-bottom: 20px;
        }
        .nwc-hero-banner {
            height: 100px; display: flex; align-items: center;
            padding: 0 24px; gap: 14px; position: relative;
        }
        .nwc-hero-icon { font-size: 40px; }
        .nwc-hero-name {
            font-family: 'Playfair Display', serif;
            font-size: 24px; font-weight: 400; color: #fff;
            letter-spacing: -0.02em; text-shadow: 0 1px 8px rgba(0,0,0,0.2);
        }
        .nwc-hero-sub { font-size: 13px; color: rgba(255,255,255,0.8); margin-top: 2px; }

        .nwc-hero-body {
            padding: 16px 22px; display: flex;
            align-items: center; justify-content: space-between;
            flex-wrap: wrap; gap: 12px;
            border-top: 1px solid var(--border);
        }
        .nwc-stats { display: flex; gap: 20px; }
        .nwc-stat-num {
            font-family: 'Playfair Display', serif;
            font-size: 18px; color: var(--espresso); letter-spacing: -0.01em;
        }
        .nwc-stat-label { font-size: 11px; color: var(--muted); margin-top: 1px; }
        .nwc-hero-actions { display: flex; gap: 8px; }
        .nwc-btn-ghost {
            padding: 7px 14px; border: 1px solid var(--border-strong);
            border-radius: 8px; font-size: 12px; color: var(--muted);
            background: none; cursor: pointer; font-family: 'Sora', sans-serif;
            transition: all 0.15s;
        }
        .nwc-btn-ghost:hover { border-color: var(--caramel); color: var(--caramel); }
        .nwc-btn-post {
            padding: 7px 14px; background: var(--caramel); color: #fff;
            border: none; border-radius: 8px; font-size: 12px; font-weight: 500;
            cursor: pointer; font-family: 'Sora', sans-serif; transition: background 0.15s;
        }
        .nwc-btn-post:hover { background: #9A5418; }

        /* Detail layout */
        .nwc-detail-layout {
            display: grid; grid-template-columns: 1fr 256px; gap: 18px; align-items: start;
        }

        /* Post cards */
        .nwc-composer {
            background: #fff; border: 1px solid var(--border); border-radius: 12px;
            padding: 12px 14px; margin-bottom: 14px; display: flex; gap: 10px; align-items: flex-start;
        }
        .nwc-composer-av {
            width: 30px; height: 30px; border-radius: 50%;
            background: linear-gradient(135deg, var(--caramel-light), var(--caramel));
            display: flex; align-items: center; justify-content: center;
            font-size: 11px; font-weight: 600; color: #fff; flex-shrink: 0;
        }
        .nwc-composer-input {
            flex: 1; border: 1px solid var(--border-strong); border-radius: 8px;
            padding: 8px 11px; font-size: 13px; font-family: 'Sora', sans-serif;
            color: var(--espresso); resize: none; outline: none; min-height: 38px;
            transition: border-color 0.15s;
        }
        .nwc-composer-input:focus { border-color: var(--caramel); }
        .nwc-composer-input::placeholder { color: var(--muted); }
        .nwc-composer-post {
            padding: 7px 13px; background: var(--caramel); color: #fff;
            border: none; border-radius: 8px; font-size: 12px; font-weight: 500;
            cursor: pointer; font-family: 'Sora', sans-serif; white-space: nowrap;
            align-self: flex-end; transition: background 0.15s;
        }
        .nwc-composer-post:hover { background: #9A5418; }

        .nwc-post {
            background: #fff; border: 1px solid var(--border); border-radius: 12px;
            padding: 16px 18px; margin-bottom: 12px; transition: border-color 0.15s;
        }
        .nwc-post:hover { border-color: var(--border-strong); }
        .nwc-post-header { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
        .nwc-post-av {
            width: 34px; height: 34px; border-radius: 50%; flex-shrink: 0;
            display: flex; align-items: center; justify-content: center;
            font-size: 12px; font-weight: 600; color: #fff;
        }
        .nwc-post-name { font-size: 13px; font-weight: 600; color: var(--espresso); }
        .nwc-post-meta { font-size: 11px; color: var(--muted); margin-top: 1px; }
        .nwc-post-time { margin-left: auto; font-size: 11px; color: var(--muted); flex-shrink: 0; }
        .nwc-post-body { font-size: 13px; color: var(--espresso); line-height: 1.65; margin-bottom: 12px; }
        .nwc-post-actions {
            display: flex; gap: 2px; padding-top: 10px; border-top: 1px solid var(--border);
        }
        .nwc-post-btn {
            display: flex; align-items: center; gap: 5px; padding: 5px 9px;
            border-radius: 7px; font-size: 12px; color: var(--muted);
            background: none; border: none; cursor: pointer;
            font-family: 'Sora', sans-serif; transition: all 0.15s;
        }
        .nwc-post-btn:hover { background: var(--latte-soft); color: var(--caramel); }

        /* Sidebar cards */
        .nwc-sidebar { display: flex; flex-direction: column; gap: 14px; }
        .nwc-sidebar-card {
            background: #fff; border: 1px solid var(--border);
            border-radius: 12px; overflow: hidden;
        }
        .nwc-sidebar-head {
            padding: 11px 14px; border-bottom: 1px solid var(--border);
            font-size: 12px; font-weight: 600; color: var(--espresso);
            text-transform: uppercase; letter-spacing: 0.04em;
        }
        .nwc-sidebar-body { padding: 10px 14px; }
        .nwc-about-text { font-size: 13px; color: var(--muted); line-height: 1.6; }

        .nwc-member {
            display: flex; align-items: center; gap: 9px; padding: 7px 0;
            border-bottom: 1px solid var(--border); cursor: pointer;
        }
        .nwc-member:last-of-type { border-bottom: none; }
        .nwc-member-av {
            width: 28px; height: 28px; border-radius: 50%;
            display: flex; align-items: center; justify-content: center;
            font-size: 10px; font-weight: 600; color: #fff; flex-shrink: 0;
        }
        .nwc-member-name { font-size: 13px; font-weight: 500; color: var(--espresso); }
        .nwc-member-role { font-size: 11px; color: var(--muted); }
        .nwc-member:hover .nwc-member-name { color: var(--caramel); }

        .nwc-event { padding: 9px 0; border-bottom: 1px solid var(--border); }
        .nwc-event:last-child { border-bottom: none; padding-bottom: 0; }
        .nwc-event-title { font-size: 13px; font-weight: 500; color: var(--espresso); margin-bottom: 2px; }
        .nwc-event-time { font-size: 11px; color: var(--muted); }

        /* Banner colour helpers */
        .nwc-banner-a { background: linear-gradient(135deg, #D4894A, #B5651D); }
        .nwc-banner-b { background: linear-gradient(135deg, #4A7C5E, #2D5C42); }
        .nwc-banner-c { background: linear-gradient(135deg, #6B5B8E, #4A3D6E); }
        .nwc-banner-d { background: linear-gradient(135deg, #4A7EA8, #2D5E88); }
        .nwc-banner-e { background: linear-gradient(135deg, #B56540, #8A4420); }

        @media (max-width: 700px) {
            .nwc-detail-layout { grid-template-columns: 1fr; }
            .nwc-grid { grid-template-columns: 1fr; }
        }

        /* ===================================================
           AVAILABILITY VIEW  (av-*)
           =================================================== */
        #availabilityView { padding-bottom: 2rem; }

        .av-card {
            background: var(--card);
            border: 1px solid var(--border);
            border-radius: 18px;
            padding: 28px;
            max-width: 820px;
            box-shadow: var(--shadow);
        }
        .av-slots-title {
            font-family: 'Playfair Display', serif;
            font-size: 16px;
            font-weight: 700;
            color: var(--espresso);
            margin: 0 0 16px;
        }
        .av-divider {
            border: none;
            border-top: 1.5px solid var(--border);
            margin: 24px 0;
        }
        .av-add-title {
            font-family: 'Playfair Display', serif;
            font-size: 16px;
            font-weight: 700;
            color: var(--espresso);
            margin: 0 0 16px;
        }
        .av-form-label {
            display: block;
            font-size: 12px;
            font-weight: 700;
            letter-spacing: .06em;
            text-transform: uppercase;
            color: var(--muted);
            margin-bottom: 6px;
        }
        .av-input {
            width: 100%;
            padding: 10px 14px;
            font-size: 13.5px;
            font-family: 'DM Sans', sans-serif;
            border: 1.5px solid var(--border);
            border-radius: 10px;
            background: var(--warm-white);
            color: var(--espresso);
            box-sizing: border-box;
            outline: none;
            transition: border-color .15s;
            appearance: none;
        }
        .av-input:focus { border-color: var(--caramel); }
        .av-time-grid {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 14px;
            margin-bottom: 18px;
        }
        .av-btn {
            padding: 10px 26px;
            background: var(--caramel);
            color: #fff;
            border: none;
            border-radius: 100px;
            font-size: 13.5px;
            font-weight: 600;
            font-family: 'DM Sans', sans-serif;
            cursor: pointer;
            transition: background .15s;
        }
        .av-btn:hover { background: var(--caramel-light); }

        /* ===================================================
           SCHEDULE VIEW  (sv-*)
           =================================================== */
        #scheduleView { padding-bottom: 2rem; }

        .sv-shell {
            max-width: 600px;
            margin: 0 auto;
        }
        .sv-card {
            background: var(--card);
            border: 1px solid var(--border);
            border-radius: 20px;
            overflow: hidden;
            box-shadow: var(--shadow);
        }
        .sv-card-header {
            background: var(--espresso);
            padding: 26px 28px 22px;
            position: relative;
        }
        .sv-card-eyebrow {
            font-size: 11px;
            font-weight: 700;
            letter-spacing: .1em;
            text-transform: uppercase;
            color: var(--caramel);
            margin-bottom: 4px;
        }
        .sv-card-title {
            font-family: 'Playfair Display', serif;
            font-size: 22px;
            font-weight: 700;
            color: var(--cream);
            margin: 0;
        }
        .sv-card-with {
            font-size: 13px;
            color: rgba(245,237,227,.55);
            margin-top: 6px;
        }
        .sv-card-with strong {
            color: var(--latte);
            font-weight: 600;
        }
        .sv-card-body {
            padding: 24px 28px 28px;
        }
        .sv-form-label {
            display: block;
            font-size: 11.5px;
            font-weight: 700;
            letter-spacing: .07em;
            text-transform: uppercase;
            color: var(--muted);
            margin-bottom: 7px;
        }
        .sv-input {
            width: 100%;
            padding: 10px 14px;
            font-size: 13.5px;
            font-family: 'DM Sans', sans-serif;
            border: 1.5px solid var(--border);
            border-radius: 10px;
            background: var(--warm-white);
            color: var(--espresso);
            box-sizing: border-box;
            outline: none;
            transition: border-color .15s;
            appearance: none;
        }
        .sv-input:focus { border-color: var(--caramel); }
        .sv-form-group { margin-bottom: 18px; }
        .sv-form-hint {
            font-size: 11.5px;
            color: var(--muted);
            margin-top: 4px;
        }
        .sv-btn {
            width: 100%;
            padding: 13px;
            background: var(--caramel);
            color: #fff;
            border: none;
            border-radius: 100px;
            font-size: 14px;
            font-weight: 700;
            font-family: 'DM Sans', sans-serif;
            cursor: pointer;
            margin-top: 8px;
            transition: background .15s;
        }
        .sv-btn:hover { background: var(--caramel-light); }

        /* ===================================================
           CALL VIEW  (cv-*)
           =================================================== */
        #callView {
            padding: 0;
            flex-direction: column;
            height: 100%;
            background: #0e0a06;
        }
        #callView.active {
            display: flex;
        }
        .cv-topbar {
            display: flex;
            align-items: center;
            justify-content: space-between;
            padding: 16px 24px;
            background: rgba(255,255,255,.04);
            border-bottom: 1px solid rgba(255,255,255,.06);
            flex-shrink: 0;
        }
        .cv-logo {
            font-size: 14px;
            font-weight: 700;
            color: var(--caramel);
            font-family: 'DM Sans', sans-serif;
            letter-spacing: .02em;
        }
        .cv-end-btn {
            display: inline-flex;
            align-items: center;
            gap: 6px;
            padding: 7px 18px;
            background: rgba(192,60,60,.85);
            color: #fff;
            border: none;
            border-radius: 100px;
            font-size: 13px;
            font-weight: 600;
            font-family: 'DM Sans', sans-serif;
            cursor: pointer;
            transition: background .15s;
        }
        .cv-end-btn:hover { background: rgba(220,60,60,1); }
        .cv-stage {
            flex: 1;
            display: flex;
            align-items: center;
            justify-content: center;
            padding: 24px;
            flex-direction: column;
            gap: 20px;
            min-height: 0;
        }
        .cv-video-main {
            background: #1a1008;
            border-radius: 18px;
            border: 1px solid rgba(255,255,255,.08);
            width: 100%;
            max-width: 680px;
            aspect-ratio: 16/9;
            display: flex;
            align-items: center;
            justify-content: center;
            position: relative;
            overflow: hidden;
        }
        .cv-video-avatar {
            width: 90px;
            height: 90px;
            border-radius: 50%;
            background: linear-gradient(135deg, var(--caramel), var(--brown));
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 40px;
            font-weight: 700;
            color: #fff;
            flex-direction: column;
        }
        .cv-video-local {
            position: absolute;
            bottom: 14px;
            right: 14px;
            width: 110px;
            aspect-ratio: 9/16;
            background: #2a1c10;
            border-radius: 12px;
            border: 2px solid rgba(255,255,255,.12);
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 22px;
        }
        .cv-info {
            text-align: center;
        }
        .cv-person-name {
            font-family: 'Playfair Display', serif;
            font-size: 22px;
            font-weight: 700;
            color: var(--cream);
            margin: 0 0 4px;
        }
        .cv-timer {
            font-size: 13px;
            color: rgba(245,237,227,.45);
            font-family: 'DM Sans', sans-serif;
            letter-spacing: .05em;
        }
        .cv-controls {
            display: flex;
            align-items: center;
            gap: 14px;
            flex-shrink: 0;
            padding-bottom: 28px;
        }
        .cv-ctrl {
            width: 56px;
            height: 56px;
            border-radius: 50%;
            border: none;
            cursor: pointer;
            font-size: 22px;
            display: flex;
            align-items: center;
            justify-content: center;
            transition: all .15s;
        }
        .cv-ctrl-mic  { background: rgba(192,124,58,.2); color: var(--caramel); }
        .cv-ctrl-mic:hover  { background: rgba(192,124,58,.35); }
        .cv-ctrl-vid  { background: rgba(192,124,58,.2); color: var(--caramel); }
        .cv-ctrl-vid:hover  { background: rgba(192,124,58,.35); }
        .cv-ctrl-end  { background: rgba(192,60,60,.8); color: #fff; width: 64px; height: 64px; font-size: 26px; }
        .cv-ctrl-end:hover  { background: rgba(220,60,60,1); }
        .cv-ctrl.muted { background: rgba(255,255,255,.08); color: rgba(245,237,227,.35); }

        /* ===================================================
           PROFILE / GROUP DETAIL SHELLS
           =================================================== */
        .pv-shell { padding-bottom: 2rem; }

        /* ===================================================
           SETTINGS VIEW  (st-*)
           =================================================== */
        /* When settings is active, main-content is hidden via JS so settingsView fills app-container */
        #settingsView { display: none; padding: 0; }
        #settingsView.active { display: flex; flex-direction: column; flex: 1; overflow: hidden; }
        /* .settings-shell is a flex child that fills space — defined in new settings CSS below */

        /* Settings two-column layout */
        .settings-layout {
            display: grid;
            grid-template-columns: 220px 1fr;
            flex: 1;
            min-height: 0;
            overflow: hidden;
        }

        /* Settings left nav */
        .settings-nav {
            background: var(--card);
            border-right: 1px solid var(--border);
            padding: 28px 0;
            overflow-y: auto;
            display: flex;
            flex-direction: column;
        }
        .settings-nav-header {
            padding: 0 20px 20px;
            border-bottom: 1px solid var(--latte-soft);
            margin-bottom: 8px;
            flex-shrink: 0;
        }
        .settings-nav-title {
            font-family: 'Playfair Display', serif;
            font-size: 17px;
            font-weight: 600;
            color: var(--espresso);
        }
        .settings-nav-sub {
            font-size: 12px;
            color: var(--muted);
            margin-top: 3px;
        }

        /* Settings content area */
        .settings-content {
            overflow-y: auto;
            padding: 36px 48px 80px;
        }

        .st-layout {
            display: flex;
            gap: 0;
            flex: 1;
            min-height: 0;
        }

        /* Inner settings nav */
        .st-nav {
            background: var(--card);
            border-right: 1px solid var(--border);
            padding: 24px 0;
            height: 100%;
            overflow-y: auto;
        }
        .st-nav-header {
            padding: 0 18px 18px;
            border-bottom: 1px solid var(--border);
            margin-bottom: 6px;
        }
        .st-nav-title {
            font-family: 'Playfair Display', serif;
            font-size: 17px;
            font-weight: 700;
            color: var(--espresso);
        }
        .st-nav-sub { font-size: 11.5px; color: var(--muted); margin-top: 2px; }
        .st-nav-item {
            display: flex;
            align-items: center;
            gap: 9px;
            padding: 10px 18px;
            font-size: 13.5px;
            color: var(--muted);
            background: none;
            border: none;
            border-left: 3px solid transparent;
            cursor: pointer;
            width: 100%;
            text-align: left;
            font-family: 'DM Sans', sans-serif;
            transition: background .15s, color .15s;
        }
        .st-nav-item:hover { background: var(--latte-soft); color: var(--espresso); }
        .st-nav-item.active { background: var(--latte-soft); color: var(--caramel); font-weight: 600; border-left-color: var(--caramel); }
        .st-nav-icon { font-size: 15px; width: 20px; text-align: center; flex-shrink: 0; }
        .st-nav-divider { height: 1px; background: var(--border); margin: 8px 14px; }
        .st-nav-danger { color: var(--danger) !important; }
        .st-nav-danger:hover { background: #fdecea !important; }
        .st-nav-danger.active { background: #fdecea !important; border-left-color: var(--danger) !important; }

        /* (settings-nav defined above) */
        .snav-header {
            padding: 0 20px 18px;
            border-bottom: 1px solid var(--border);
            margin-bottom: 8px;
        }
        .snav-header-title {
            font-family: 'Playfair Display', serif;
            font-size: 17px; font-weight: 700;
            color: var(--espresso);
        }
        .snav-header-sub { font-size: 11.5px; color: var(--muted); margin-top: 2px; }

        .snav-item {
            display: flex; align-items: center; gap: 10px;
            padding: 11px 20px; font-size: 13.5px; font-weight: 400;
            color: var(--muted); cursor: pointer;
            border-left: 3px solid transparent;
            transition: background .15s, color .15s, border-color .15s;
            user-select: none;
        }
        .snav-item:hover { background: var(--latte-soft); color: var(--espresso); }
        .snav-item.active { background: var(--cream); color: var(--caramel); font-weight: 600; border-left-color: var(--caramel); }
        .snav-icon { font-size: 15px; width: 20px; text-align: center; flex-shrink: 0; }
        .snav-divider { height: 1px; background: var(--border); margin: 8px 16px; }
        .snav-danger { color: var(--danger) !important; }
        .snav-danger:hover { background: #fdecea !important; }
        .snav-danger.active { background: #fdecea !important; border-left-color: var(--danger) !important; color: var(--danger) !important; }
        .snav-danger { color: var(--danger) !important; }
        .snav-danger:hover { background: #fdecea !important; }
        .snav-danger.active { background: #fdecea !important; border-left-color: var(--danger) !important; color: var(--danger) !important; }

        /* Settings content sections */
        .settings-section { display: none; flex-direction: column; gap: 26px; animation: fadeIn .25s ease; }
        .settings-section.active { display: flex; }

        /* Keep old .settings-panel as alias */
        .settings-panel { display: none; flex-direction: column; gap: 26px; animation: fadeIn .25s ease; }
        .settings-panel.active { display: flex; }

        /* Content area */
        .st-content {
            flex: 1;
            padding: 36px 48px 80px;
            overflow-y: auto;
            min-width: 0;
        }

        /* Section panels */
        .st-section { display: none; flex-direction: column; gap: 26px; animation: fadeIn .25s ease; }
        .st-section.active { display: flex; }

        .st-eyebrow {
            font-size: 11px;
            font-weight: 700;
            letter-spacing: .1em;
            text-transform: uppercase;
            color: var(--caramel);
            margin-bottom: 5px;
        }
        .st-title {
            font-family: 'Playfair Display', serif;
            font-size: clamp(22px, 3vw, 28px);
            font-weight: 700;
            color: var(--espresso);
            line-height: 1.1;
            margin: 0 0 6px;
        }
        .st-title em { font-style: italic; color: var(--caramel); }
        .st-title.danger { color: var(--danger); }
        .st-title.danger em { color: var(--danger); }
        .st-desc { font-size: 13.5px; color: var(--muted); line-height: 1.5; }

        /* Cards */
        .st-card {
            background: var(--card);
            border: 1px solid var(--border);
            border-radius: 16px;
            overflow: hidden;
        }
        .st-card-header {
            padding: 16px 20px;
            border-bottom: 1px solid var(--border);
            display: flex;
            align-items: center;
            justify-content: space-between;
        }
        .st-card-title { font-size: 14.5px; font-weight: 600; color: var(--espresso); }
        .st-card-sub { font-size: 12px; color: var(--muted); margin-top: 2px; }
        .st-card-body { padding: 20px; display: flex; flex-direction: column; gap: 16px; }
        .st-card-body.no-gap { gap: 0; }
        .st-card-footer {
            padding: 12px 20px;
            border-top: 1px solid var(--border);
            background: var(--latte-soft);
            display: flex;
            align-items: center;
            justify-content: flex-end;
            gap: 8px;
        }

        /* Form elements */
        .st-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
        .st-form-group { display: flex; flex-direction: column; gap: 5px; }
        .st-form-group.full { grid-column: 1 / -1; }
        .st-label {
            font-size: 11px;
            font-weight: 700;
            letter-spacing: .07em;
            text-transform: uppercase;
            color: var(--muted);
        }
        .st-hint { font-size: 11.5px; color: var(--muted); opacity: .8; }
        .st-input {
            width: 100%;
            padding: 10px 13px;
            border: 1.5px solid var(--border);
            border-radius: 10px;
            background: var(--warm-white);
            font-family: 'DM Sans', sans-serif;
            font-size: 13.5px;
            color: var(--espresso);
            outline: none;
            box-sizing: border-box;
            transition: border-color .15s;
            appearance: none;
        }
        .st-input:focus { border-color: var(--caramel); }
        .st-input::placeholder { color: var(--muted); opacity: .6; }
        textarea.st-input { resize: vertical; min-height: 85px; line-height: 1.5; }
        select.st-input {
            cursor: pointer;
            background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23c9a98a' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
            background-repeat: no-repeat;
            background-position: right 12px center;
            padding-right: 30px;
        }

        /* Avatar upload */
        .st-avatar-wrap { display: flex; align-items: center; gap: 18px; }
        .st-avatar {
            width: 72px; height: 72px; border-radius: 50%;
            background: linear-gradient(135deg, var(--caramel), var(--caramel-light));
            display: flex; align-items: center; justify-content: center;
            font-size: 24px; font-weight: 700; color: #fff;
            border: 3px solid var(--latte); position: relative; cursor: pointer; flex-shrink: 0;
            overflow: hidden;
        }
        .st-avatar-overlay {
            position: absolute; inset: 0; border-radius: 50%;
            background: rgba(28,18,8,.5); display: flex; align-items: center;
            justify-content: center; opacity: 0; transition: opacity .2s; font-size: 18px;
        }
        .st-avatar:hover .st-avatar-overlay { opacity: 1; }
        .st-avatar-info-name { font-size: 14px; font-weight: 600; color: var(--espresso); margin-bottom: 2px; }
        .st-avatar-info-sub { font-size: 12.5px; color: var(--muted); margin-bottom: 10px; }
        .st-btn-upload {
            display: inline-flex; align-items: center; gap: 6px;
            padding: 7px 14px; background: var(--latte-soft);
            border: 1.5px solid var(--border); border-radius: 8px;
            font-family: 'DM Sans', sans-serif; font-size: 12.5px;
            color: var(--muted); cursor: pointer; transition: all .15s;
        }
        .st-btn-upload:hover { border-color: var(--caramel); color: var(--caramel); }

        /* Tags input */
        .st-tags-wrap {
            display: flex; flex-wrap: wrap; gap: 6px; align-items: center;
            padding: 8px 11px; border: 1.5px solid var(--border); border-radius: 10px;
            background: var(--warm-white); min-height: 44px; cursor: text;
            transition: border-color .15s;
        }
        .st-tags-wrap:focus-within { border-color: var(--caramel); }
        .st-tag-chip {
            display: inline-flex; align-items: center; gap: 4px;
            background: var(--latte-soft); border: 1px solid var(--border);
            color: var(--caramel); font-size: 12px; font-weight: 500;
            border-radius: 100px; padding: 3px 9px;
        }
        .st-tag-chip button {
            background: none; border: none; cursor: pointer;
            color: var(--muted); font-size: 12px; line-height: 1; padding: 0;
            transition: color .15s;
        }
        .st-tag-chip button:hover { color: var(--danger); }
        .st-tags-input {
            border: none; background: transparent;
            font-family: 'DM Sans', sans-serif; font-size: 13px;
            color: var(--espresso); outline: none; min-width: 80px; flex: 1;
        }
        .st-tags-input::placeholder { color: var(--muted); opacity: .6; }

        /* Toggle switch */
        .st-toggle-row {
            display: flex; align-items: flex-start; justify-content: space-between;
            gap: 16px; padding: 14px 0;
            border-bottom: 1px solid var(--border);
        }
        .st-toggle-row:last-child { border-bottom: none; padding-bottom: 0; }
        .st-toggle-row:first-child { padding-top: 0; }
        .st-toggle-label { font-size: 13.5px; font-weight: 500; color: var(--espresso); margin-bottom: 2px; }
        .st-toggle-desc { font-size: 12px; color: var(--muted); line-height: 1.45; max-width: 380px; }
        .st-toggle { position: relative; width: 42px; height: 23px; flex-shrink: 0; margin-top: 2px; }
        .st-toggle input { opacity: 0; width: 0; height: 0; position: absolute; }
        .st-toggle-track {
            position: absolute; inset: 0; border-radius: 100px;
            background: var(--latte); cursor: pointer; transition: background .2s;
        }
        .st-toggle input:checked ~ .st-toggle-track { background: var(--caramel); }
        .st-toggle-thumb {
            position: absolute; top: 3px; left: 3px;
            width: 17px; height: 17px; border-radius: 50%;
            background: white; box-shadow: 0 1px 4px rgba(0,0,0,.15);
            transition: transform .2s; pointer-events: none;
        }
        .st-toggle input:checked ~ .st-toggle-track .st-toggle-thumb { transform: translateX(19px); }

        /* Privacy select rows */
        .st-priv-row {
            display: flex; align-items: center; justify-content: space-between;
            flex-wrap: wrap; gap: 10px 16px; padding: 13px 0; border-bottom: 1px solid var(--border);
        }
        .st-priv-row:last-child { border-bottom: none; padding-bottom: 0; }
        .st-priv-row:first-child { padding-top: 0; }
        .st-priv-row > div:first-child { flex: 1; min-width: 0; }
        .st-priv-label { font-size: 13.5px; font-weight: 500; color: var(--espresso); margin-bottom: 2px; }
        .st-priv-desc { font-size: 12px; color: var(--muted); }
        .st-priv-select {
            padding: 7px 28px 7px 11px; border: 1.5px solid var(--border); border-radius: 8px;
            background: var(--warm-white); font-family: 'DM Sans', sans-serif; font-size: 12.5px;
            color: var(--espresso); cursor: pointer; outline: none; appearance: none;
            background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23c9a98a' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
            background-repeat: no-repeat; background-position: right 9px center;
            flex-shrink: 0; min-width: 130px; transition: border-color .15s;
        }
        .st-priv-select:focus { border-color: var(--caramel); }

        /* Security items */
        .st-sec-item {
            display: flex; align-items: center; gap: 13px;
            padding: 14px 0; border-bottom: 1px solid var(--border);
        }
        .st-sec-item:last-child { border-bottom: none; padding-bottom: 0; }
        .st-sec-item:first-child { padding-top: 0; }
        .st-sec-icon {
            width: 38px; height: 38px; border-radius: 10px;
            display: flex; align-items: center; justify-content: center;
            font-size: 17px; flex-shrink: 0;
        }
        .st-sec-icon.green { background: #eaf6ef; }
        .st-sec-icon.orange { background: rgba(192,124,58,.12); }
        .st-sec-icon.blue { background: #eff4ff; }
        .st-sec-info { flex: 1; }
        .st-sec-title { font-size: 13.5px; font-weight: 600; color: var(--espresso); margin-bottom: 2px; }
        .st-sec-desc { font-size: 12px; color: var(--muted); }
        .st-sec-badge {
            font-size: 11px; font-weight: 600; border-radius: 100px; padding: 3px 10px; flex-shrink: 0;
        }
        .st-sec-badge.ok { background: #eaf6ef; color: #2d7a4f; }
        .st-sec-badge.off { background: var(--latte-soft); color: var(--muted); }

        /* Availability slots list */
        .st-avail-slot {
            display: flex; align-items: center; justify-content: space-between;
            padding: 11px 14px; background: var(--latte-soft);
            border: 1px solid var(--border); border-radius: 10px; margin-bottom: 8px;
        }
        .st-avail-slot-day { font-size: 13.5px; font-weight: 600; color: var(--espresso); }
        .st-avail-slot-time { font-size: 12.5px; color: var(--muted); margin-top: 2px; }
        .st-avail-add {
            background: var(--latte-soft); border: 1.5px dashed var(--border);
            border-radius: 12px; padding: 16px 18px; margin-top: 4px;
        }
        .st-avail-add-title { font-size: 12px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--muted); margin-bottom: 12px; }
        .st-avail-row { display: grid; grid-template-columns: 1fr 1fr 1fr auto; gap: 10px; align-items: flex-end; }

        /* Danger zone */
        .st-danger-card {
            background: var(--card);
            border: 1.5px solid #f5c6c2;
            border-radius: 16px;
            overflow: hidden;
        }
        .st-danger-header {
            padding: 14px 20px;
            background: #fdecea;
            border-bottom: 1px solid #f5c6c2;
            display: flex;
            align-items: center;
            gap: 10px;
        }
        .st-danger-header-title { font-size: 14.5px; font-weight: 600; color: var(--danger); }
        .st-danger-header-desc { font-size: 12px; color: #a93226; margin-top: 1px; }
        .st-danger-body { padding: 0 20px; }
        .st-danger-item {
            display: flex; align-items: flex-start; justify-content: space-between;
            gap: 16px; padding: 16px 0; border-bottom: 1px solid #f5c6c2;
        }
        .st-danger-item:last-child { border-bottom: none; }
        .st-danger-label { font-size: 13.5px; font-weight: 600; color: var(--espresso); margin-bottom: 3px; }
        .st-danger-desc { font-size: 12px; color: var(--muted); max-width: 360px; line-height: 1.45; }

        /* Theme option cards */
        .st-theme-option {
            border: 1.5px solid var(--border); border-radius: 12px;
            padding: 14px 20px; background: var(--latte-soft);
            text-align: center; min-width: 110px;
            transition: border-color .2s, background .2s; cursor: pointer;
        }
        .st-theme-option:hover { border-color: var(--caramel); }
        .st-theme-option.active { border-color: var(--caramel); background: var(--cream); }

        /* Buttons */
        .st-btn-primary {
            padding: 9px 20px; background: var(--espresso); color: var(--cream);
            border: none; border-radius: 9px; font-family: 'DM Sans', sans-serif;
            font-size: 13px; font-weight: 600; cursor: pointer; transition: all .15s;
        }
        .st-btn-primary:hover { background: var(--brown); }
        .st-btn-secondary {
            padding: 9px 18px; background: var(--card); border: 1.5px solid var(--border);
            border-radius: 9px; font-family: 'DM Sans', sans-serif;
            font-size: 13px; font-weight: 500; color: var(--muted); cursor: pointer; transition: all .15s;
        }
        .st-btn-secondary:hover { border-color: var(--caramel); color: var(--caramel); }
        .st-btn-danger {
            padding: 8px 15px; background: white; border: 1.5px solid #f5c6c2;
            border-radius: 9px; font-family: 'DM Sans', sans-serif; font-size: 12.5px;
            font-weight: 500; color: var(--danger); cursor: pointer; transition: all .15s;
            white-space: nowrap; flex-shrink: 0;
        }
        .st-btn-danger:hover { background: #fdecea; border-color: var(--danger); }

        /* Saved toast */
        .st-toast {
            position: fixed; bottom: 28px; right: 28px;
            background: var(--espresso); color: var(--cream);
            padding: 12px 20px; border-radius: 12px;
            font-size: 13.5px; font-weight: 500;
            display: flex; align-items: center; gap: 8px;
            box-shadow: 0 8px 24px rgba(28,18,8,.25);
            transform: translateY(80px); opacity: 0;
            transition: transform .3s cubic-bezier(.34,1.56,.64,1), opacity .3s;
            z-index: 9999; pointer-events: none;
        }
        .st-toast.show { transform: translateY(0); opacity: 1; }

        /* Appearance theme cards */
        .st-theme-grid { display: flex; gap: 10px; flex-wrap: wrap; }
        .st-theme-option {
            border: 1.5px solid var(--border); border-radius: 12px;
            padding: 14px 18px; background: var(--latte-soft);
            text-align: center; min-width: 105px; cursor: pointer;
            transition: border-color .15s;
        }
        .st-theme-option.selected { border-color: var(--caramel); }
        .st-theme-icon { font-size: 22px; margin-bottom: 6px; }
        .st-theme-label { font-size: 13px; font-weight: 600; color: var(--muted); }
        .st-theme-label.active-theme { color: var(--caramel); }
        .st-theme-note { font-size: 11px; color: var(--muted); margin-top: 2px; }

        /* Mobile tab bar for settings (replaces sidebar nav) */
        .st-mobile-tabs {
            display: none;
            overflow-x: auto;
            white-space: nowrap;
            padding: 10px 16px;
            background: var(--card);
            border-bottom: 1px solid var(--border);
            gap: 6px;
            scrollbar-width: none;
            -ms-overflow-style: none;
            flex-shrink: 0;
        }
        .st-mobile-tabs::-webkit-scrollbar { display: none; }
        .st-mobile-tab {
            display: inline-flex;
            align-items: center;
            gap: 5px;
            padding: 6px 14px;
            font-size: 12.5px;
            font-weight: 500;
            color: var(--muted);
            background: var(--latte-soft);
            border: 1.5px solid var(--border);
            border-radius: 20px;
            cursor: pointer;
            white-space: nowrap;
            font-family: 'DM Sans', sans-serif;
            transition: background .15s, color .15s, border-color .15s;
        }
        .st-mobile-tab.active {
            background: var(--caramel);
            color: white;
            border-color: var(--caramel);
            font-weight: 600;
        }
        .st-mobile-tab.danger { color: var(--danger); }
        .st-mobile-tab.danger.active { background: var(--danger); border-color: var(--danger); color: white; }

        @media (max-width: 900px) {
            .st-layout { display: flex; flex-direction: column; flex: 1; min-height: 0; }
            .st-nav { display: none; }
            .settings-nav { display: none; }
            .settings-layout { grid-template-columns: 1fr; }
            .settings-content { padding: 24px 20px 60px; }
            .st-mobile-tabs { display: flex; }
            #settingsView.active { display: flex; flex-direction: column; flex: 1; overflow: hidden; }
            .st-content { flex: 1; overflow-y: auto; height: auto; min-height: 0; }
        }
        @media (max-width: 640px) {
            .st-content { padding: 20px 16px 60px; }
            .st-form-row { grid-template-columns: 1fr; }
            .st-avail-row { grid-template-columns: 1fr 1fr; }
        }

        /* ── Availability weekly schedule ── */
        .sa-days { display: flex; flex-direction: column; }

        .sa-day-row {
            display: flex; align-items: center; gap: 12px;
            padding: 13px 4px;
            border-bottom: 1px solid var(--border);
            transition: background 0.15s;
        }
        .sa-day-row:last-child { border-bottom: none; }
        .sa-day-row:hover { background: var(--latte-soft); border-radius: 10px; }

        .sa-day-abbr {
            width: 38px; height: 38px; flex-shrink: 0;
            border-radius: 10px;
            display: flex; align-items: center; justify-content: center;
            font-family: 'Sora', sans-serif;
            font-size: 11px; font-weight: 700; letter-spacing: 0.02em;
            background: var(--latte-soft); color: var(--muted);
            transition: all 0.2s;
        }
        .sa-day-row.on .sa-day-abbr {
            background: var(--caramel); color: #fff;
        }

        .sa-day-name {
            font-family: 'Sora', sans-serif;
            font-size: 14px; font-weight: 500;
            color: var(--muted); min-width: 88px;
            transition: color 0.2s;
        }
        .sa-day-row.on .sa-day-name { color: var(--espresso); }

        .sa-times {
            display: flex; align-items: center; gap: 6px;
            flex: 1; opacity: 0; pointer-events: none;
            transition: opacity 0.2s;
        }
        .sa-day-row.on .sa-times { opacity: 1; pointer-events: all; }

        .sa-time-input {
            padding: 7px 9px;
            border: 1px solid var(--border-strong);
            border-radius: 8px;
            font-size: 13px;
            font-family: 'Sora', sans-serif;
            background: #fff; color: var(--espresso);
            cursor: pointer; flex: 1; min-width: 0;
            transition: border-color 0.15s;
        }
        .sa-time-input:focus { outline: none; border-color: var(--caramel); }

        .sa-times-sep {
            font-size: 13px; color: var(--muted); flex-shrink: 0;
        }

        .sa-toggle {
            position: relative; display: inline-block;
            width: 42px; height: 24px; flex-shrink: 0; cursor: pointer;
        }
        .sa-toggle input { opacity: 0; width: 0; height: 0; }
        .sa-toggle-slider {
            position: absolute; inset: 0;
            background: var(--border); border-radius: 24px;
            transition: background 0.2s;
        }
        .sa-toggle-slider::before {
            content: ''; position: absolute;
            width: 18px; height: 18px; left: 3px; top: 3px;
            background: #fff; border-radius: 50%;
            transition: transform 0.2s;
            box-shadow: 0 1px 3px rgba(0,0,0,0.18);
        }
        .sa-toggle input:checked ~ .sa-toggle-slider { background: var(--caramel); }
        .sa-toggle input:checked ~ .sa-toggle-slider::before { transform: translateX(18px); }

        @media (max-width: 560px) {
            .sa-day-name { display: none; }
            .sa-times { gap: 4px; }
            .sa-time-input { font-size: 12px; padding: 6px 7px; }
        }

        /* Button loading state */
        .st-btn-primary:disabled { opacity: 0.6; cursor: not-allowed; }

        /* Error toast variant */
        .st-toast.error { background: var(--danger); }

        /* ══════════════════════════════
           MY NETWORK VIEW
        ══════════════════════════════ */
        #networkView { padding: 0; }
        #networkView.active { display: flex; flex-direction: column; }

        /* Hero strip */
        .nw-hero {
            background: var(--espresso);
            padding: 32px 40px 0;
            position: relative; overflow: hidden; flex-shrink: 0;
        }
        .nw-hero::before {
            content: ''; position: absolute; inset: 0; pointer-events: none;
            background: radial-gradient(ellipse 55% 120% at -5% 110%, rgba(192,124,58,.28) 0%, transparent 55%),
                        radial-gradient(ellipse 40% 70% at 105% -10%, rgba(212,137,74,.08) 0%, transparent 50%);
        }
        .nw-hero-inner {
            position: relative; z-index: 1;
            display: flex; align-items: flex-end; justify-content: space-between;
            gap: 24px; flex-wrap: wrap; padding-bottom: 26px;
        }
        .nw-eyebrow {
            font-size: 11px; font-weight: 500; letter-spacing: 2px; text-transform: uppercase;
            color: var(--caramel-light); margin-bottom: 7px;
            display: flex; align-items: center; gap: 8px;
        }
        .nw-eyebrow::before { content: ''; width: 18px; height: 1px; background: var(--caramel-light); display: block; }
        .nw-hero-title { font-family: 'Playfair Display', serif; font-size: 30px; font-weight: 700; color: var(--cream); line-height: 1.1; }
        .nw-hero-title em { font-style: italic; color: var(--caramel-light); }
        .nw-hero-sub { font-size: 14px; color: rgba(245,240,232,.45); margin-top: 6px; max-width: 380px; }
        .nw-stats { display: flex; gap: 10px; flex-wrap: wrap; }
        .nw-stat { background: rgba(255,255,255,.06); border: 1px solid rgba(192,124,58,.2); border-radius: 12px; padding: 13px 18px; text-align: center; min-width: 78px; }
        .nw-stat-val { font-family: 'Playfair Display', serif; font-size: 24px; font-weight: 700; color: var(--cream); line-height: 1; }
        .nw-stat-lbl { font-size: 11px; color: rgba(245,240,232,.42); margin-top: 3px; }

        /* Hero tabs */
        .nw-tabs { position: relative; z-index: 1; display: flex; border-top: 1px solid rgba(255,255,255,.08); }
        .nw-tab {
            padding: 13px 22px; font-size: 13.5px; font-weight: 500;
            color: rgba(245,240,232,.45); background: none; border: none;
            border-bottom: 2px solid transparent; cursor: pointer;
            transition: color .18s, border-color .18s; font-family: 'DM Sans', sans-serif;
            display: flex; align-items: center; gap: 7px; white-space: nowrap;
        }
        .nw-tab:hover { color: var(--cream); }
        .nw-tab.active { color: var(--caramel-light); border-bottom-color: var(--caramel-light); }
        .nw-tab-count {
            background: rgba(192,124,58,.18); color: var(--caramel-light);
            font-size: 10.5px; font-weight: 700; border-radius: 100px; padding: 1px 7px;
        }
        .nw-tab.active .nw-tab-count { background: var(--caramel-light); color: var(--espresso); }

        /* Content area */
        .nw-content { padding: 28px 40px 60px; overflow-y: auto; flex: 1; }
        .nw-panel { display: none; animation: nwFadeUp .22s ease; }
        .nw-panel.active { display: block; }
        @keyframes nwFadeUp { from { opacity:0; transform:translateY(8px); } to { opacity:1; transform:translateY(0); } }

        /* ── Filter bar ── */
        .nw-filter-bar { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-bottom: 20px; }
        .nw-search-box {
            display: flex; align-items: center; gap: 8px;
            background: var(--card); border: 1.5px solid var(--latte); border-radius: 10px;
            padding: 0 14px; height: 40px; flex: 1; max-width: 320px; transition: border-color .2s;
        }
        .nw-search-box:focus-within { border-color: var(--caramel); }
        .nw-search-box input { border: none; background: transparent; font-family: 'DM Sans', sans-serif; font-size: 13.5px; color: var(--espresso); outline: none; flex: 1; }
        .nw-search-box input::placeholder { color: var(--muted); }

        /* ── Connection cards grid ── */
        .nw-conn-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px,1fr)); gap: 14px; }

        .nw-conn-card {
            background: var(--card); border: 1px solid var(--latte); border-radius: 16px;
            overflow: hidden; cursor: pointer; display: flex; flex-direction: column;
            position: relative; transition: border-color .2s, box-shadow .2s, transform .2s;
        }
        .nw-conn-card:hover { border-color: var(--caramel); box-shadow: 0 6px 24px rgba(192,124,58,.1); transform: translateY(-2px); }
        .nw-conn-card::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: var(--caramel); opacity: 0; transition: opacity .2s; border-radius: 16px 0 0 16px; }
        .nw-conn-card:hover::before { opacity: 1; }

        .nw-cc-top { padding: 18px 18px 10px; display: flex; align-items: flex-start; justify-content: space-between; gap: 10px; }
        .nw-cc-avatar-wrap { position: relative; }
        .nw-cc-avatar { width: 52px; height: 52px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-family: 'Playfair Display', serif; font-size: 17px; font-weight: 700; color: #fff; border: 2.5px solid var(--warm-white); flex-shrink: 0; overflow: hidden; }
        .nw-cc-online { position: absolute; bottom: 1px; right: 1px; width: 12px; height: 12px; border-radius: 50%; background: #4caf50; border: 2.5px solid var(--card); }

        .nw-cc-body { padding: 0 18px 12px; flex: 1; }
        .nw-cc-name { font-size: 15px; font-weight: 700; color: var(--espresso); margin-bottom: 2px; }
        .nw-cc-role { font-size: 12px; color: var(--muted); margin-bottom: 8px; }
        .nw-cc-tags { display: flex; gap: 5px; flex-wrap: wrap; margin-bottom: 6px; }
        .nw-cc-tag { font-size: 11px; padding: 2px 9px; border-radius: 100px; background: var(--latte-soft); border: 1px solid var(--latte); color: var(--muted); }
        .nw-cc-tag.hi { background: var(--cream); color: var(--caramel); border-color: rgba(192,124,58,.22); }

        .nw-cc-footer { padding: 10px 18px 14px; display: flex; gap: 8px; border-top: 1px solid var(--latte); }
        .nw-btn-chat { flex: 1; padding: 8px; background: var(--espresso); color: var(--cream); border: none; border-radius: 8px; font-family: 'DM Sans', sans-serif; font-size: 12.5px; font-weight: 500; cursor: pointer; transition: opacity .18s; }
        .nw-btn-chat:hover { opacity: .85; }
        .nw-btn-msg { padding: 8px 12px; background: var(--latte-soft); border: 1.5px solid var(--latte); border-radius: 8px; font-family: 'DM Sans', sans-serif; font-size: 12.5px; color: var(--muted); cursor: pointer; transition: border-color .18s, color .18s; }
        .nw-btn-msg:hover { border-color: var(--caramel); color: var(--caramel); }

        .nw-alumni-pill { display: inline-flex; align-items: center; gap: 4px; background: rgba(126,63,242,.1); color: #7e3ff2; border-radius: 100px; padding: 2px 9px; font-size: 10.5px; font-weight: 600; margin-bottom: 4px; }

        .nw-empty { display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 60px 20px; text-align: center; background: var(--card); border: 1.5px dashed var(--latte); border-radius: 16px; }
        .nw-empty-icon { font-size: 40px; margin-bottom: 14px; opacity: .45; }
        .nw-empty-title { font-size: 16px; font-weight: 600; color: var(--espresso); margin-bottom: 6px; }
        .nw-empty-desc { font-size: 13.5px; color: var(--muted); max-width: 260px; line-height: 1.55; }

        /* ── Requests panel ── */
        .nw-req-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; align-items: start; }
        .nw-req-section-title { font-family: 'Playfair Display', serif; font-size: 18px; font-weight: 700; color: var(--espresso); margin-bottom: 14px; }
        .nw-req-section-title em { font-style: italic; color: var(--caramel); }
        .nw-req-count { font-size: 12px; color: var(--muted); margin-left: 8px; font-family: 'DM Sans', sans-serif; font-weight: 400; font-style: normal; }

        .nw-req-card {
            background: var(--card); border: 1px solid var(--latte); border-radius: 14px;
            padding: 16px 18px; display: flex; align-items: flex-start; gap: 12px;
            margin-bottom: 10px; transition: border-color .2s, box-shadow .2s;
        }
        .nw-req-card:hover { border-color: var(--caramel); box-shadow: 0 3px 14px rgba(192,124,58,.08); }
        .nw-req-avatar { width: 46px; height: 46px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-family: 'Playfair Display', serif; font-size: 15px; font-weight: 700; color: white; flex-shrink: 0; overflow: hidden; }
        .nw-req-info { flex: 1; min-width: 0; }
        .nw-req-name { font-size: 14px; font-weight: 700; color: var(--espresso); margin-bottom: 1px; }
        .nw-req-role { font-size: 12px; color: var(--muted); margin-bottom: 6px; }
        .nw-req-note { font-size: 12.5px; color: var(--muted); font-style: italic; line-height: 1.4; margin-bottom: 8px; padding: 7px 10px; background: var(--latte-soft); border-radius: 7px; border-left: 2px solid var(--latte); }
        .nw-req-actions { display: flex; gap: 7px; }
        .nw-btn-accept { padding: 7px 14px; background: var(--espresso); color: var(--cream); border: none; border-radius: 7px; font-family: 'DM Sans', sans-serif; font-size: 12.5px; font-weight: 500; cursor: pointer; transition: opacity .18s; }
        .nw-btn-accept:hover { opacity: .85; }
        .nw-btn-decline { padding: 7px 12px; background: var(--latte-soft); border: 1.5px solid var(--latte); border-radius: 7px; font-family: 'DM Sans', sans-serif; font-size: 12.5px; color: var(--muted); cursor: pointer; transition: all .18s; }
        .nw-btn-decline:hover { border-color: var(--danger); color: var(--danger); }
        .nw-req-time { font-size: 11px; color: var(--muted); margin-top: 5px; }

        /* ── Suggestions panel ── */
        .nw-suggest-section { margin-bottom: 28px; }
        .nw-suggest-title { font-family: 'Playfair Display', serif; font-size: 18px; font-weight: 700; color: var(--espresso); margin-bottom: 16px; }
        .nw-suggest-title em { font-style: italic; color: var(--caramel); }
        .nw-suggest-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(258px,1fr)); gap: 14px; }

        .nw-sug-card { background: var(--card); border: 1px solid var(--latte); border-radius: 16px; overflow: hidden; transition: border-color .2s, box-shadow .2s, transform .2s; }
        .nw-sug-card:hover { border-color: var(--caramel); box-shadow: 0 6px 22px rgba(192,124,58,.1); transform: translateY(-2px); }
        .nw-sug-banner { height: 54px; background: linear-gradient(135deg, var(--espresso), var(--brown)); position: relative; overflow: hidden; }
        .nw-sug-banner::after { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse 80% 80% at 100% 0%, rgba(192,124,58,.18) 0%, transparent 60%); }
        .nw-sug-avatar { position: absolute; bottom: -22px; left: 16px; width: 50px; height: 50px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-family: 'Playfair Display', serif; font-size: 17px; font-weight: 700; color: white; border: 3px solid var(--card); z-index: 1; overflow: hidden; }
        .nw-sug-body { padding: 30px 16px 12px; }
        .nw-sug-name { font-size: 14.5px; font-weight: 700; color: var(--espresso); margin-bottom: 2px; }
        .nw-sug-role { font-size: 12px; color: var(--muted); margin-bottom: 8px; }
        .nw-sug-reason { font-size: 12px; color: var(--muted); line-height: 1.45; margin-bottom: 10px; padding: 7px 10px; background: var(--latte-soft); border-radius: 8px; display: flex; gap: 6px; align-items: flex-start; }
        .nw-sug-tags { display: flex; gap: 5px; flex-wrap: wrap; }
        .nw-sug-tag { font-size: 11px; padding: 2px 9px; border-radius: 100px; background: var(--latte-soft); border: 1px solid var(--latte); color: var(--muted); }
        .nw-sug-footer { padding: 10px 16px 14px; display: flex; gap: 8px; border-top: 1px solid var(--latte); }
        .nw-btn-connect { flex: 1; padding: 8px; background: var(--espresso); color: var(--cream); border: none; border-radius: 8px; font-family: 'DM Sans', sans-serif; font-size: 12.5px; font-weight: 500; cursor: pointer; transition: opacity .18s; }
        .nw-btn-connect:hover { opacity: .85; }
        .nw-btn-view { padding: 8px 11px; background: var(--latte-soft); border: 1px solid var(--latte); border-radius: 8px; font-size: 12.5px; color: var(--muted); cursor: pointer; font-family: 'DM Sans', sans-serif; transition: border-color .18s, color .18s; }
        .nw-btn-view:hover { border-color: var(--caramel); color: var(--caramel); }

        /* Responsive */
        @media (max-width: 900px) { .nw-req-layout { grid-template-columns: 1fr; } }
        @media (max-width: 700px) { .nw-content { padding: 20px 18px 48px; } .nw-hero { padding: 24px 18px 0; } .nw-conn-grid { grid-template-columns: 1fr; } .nw-suggest-grid { grid-template-columns: 1fr; } }

        /* ─── Inbox / Messages View (ibx-) ─── */
        #inboxView { padding: 0; overflow: hidden; }
        #inboxView.active { display: flex; height: 100%; }

        .ibx-shell { display: flex; width: 100%; height: 100%; overflow: hidden; min-width: 0; }

        /* Left panel */
        .ibx-conv-panel {
            width: 300px; flex-shrink: 0;
            background: var(--card);
            border-right: 1px solid var(--border);
            display: flex; flex-direction: column; overflow: hidden;
        }
        .ibx-conv-header {
            padding: 20px 18px 14px;
            border-bottom: 1px solid var(--border);
            flex-shrink: 0;
        }
        .ibx-conv-header h2 {
            font-family: 'Playfair Display', serif;
            font-size: 20px; color: var(--espresso);
            margin-bottom: 12px;
        }
        .ibx-conv-header h2 em { font-style: italic; color: var(--caramel); }
        .ibx-header-row { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
        .ibx-header-row h2 { margin-bottom: 0; }
        .ibx-compose-btn {
            width: 32px; height: 32px; flex-shrink: 0;
            background: var(--espresso); border: none; border-radius: 50%;
            display: flex; align-items: center; justify-content: center;
            cursor: pointer; color: var(--cream); font-size: 15px;
            transition: background .15s; box-shadow: 0 2px 6px rgba(26,14,7,.18);
        }
        .ibx-compose-btn:hover { background: var(--brown); }
        .ibx-nm-overlay {
            position: fixed; inset: 0; z-index: 9999;
            background: rgba(26,14,7,.35); display: flex; align-items: center; justify-content: center;
        }
        .ibx-nm-modal {
            background: var(--card); border-radius: 16px;
            box-shadow: 0 8px 40px rgba(26,14,7,.2);
            width: 340px; max-height: 480px;
            display: flex; flex-direction: column; overflow: hidden;
            animation: ibxNmIn .18s ease;
        }
        @keyframes ibxNmIn { from { opacity:0; transform:scale(.95) } to { opacity:1; transform:scale(1) } }
        .ibx-nm-header {
            display: flex; align-items: center; justify-content: space-between;
            padding: 18px 18px 14px; border-bottom: 1px solid var(--border);
        }
        .ibx-nm-header h3 { font-family: 'Playfair Display', serif; font-size: 17px; color: var(--espresso); margin: 0; }
        .ibx-nm-header h3 em { font-style: italic; color: var(--caramel); }
        .ibx-nm-close {
            width: 28px; height: 28px; border: none; background: var(--latte-soft);
            border-radius: 50%; cursor: pointer; font-size: 14px; color: var(--muted);
            display: flex; align-items: center; justify-content: center; transition: background .12s;
        }
        .ibx-nm-close:hover { background: var(--border); }
        .ibx-nm-search-wrap { padding: 12px 16px; border-bottom: 1px solid var(--border); }
        .ibx-nm-search {
            width: 100%; background: var(--latte-soft);
            border: 1.5px solid var(--border); border-radius: 99px;
            padding: 7px 14px; font-size: 13px; font-family: 'DM Sans', sans-serif;
            color: var(--espresso); outline: none; transition: border-color .15s; box-sizing: border-box;
        }
        .ibx-nm-search:focus { border-color: var(--caramel); }
        .ibx-nm-list { overflow-y: auto; flex: 1; }
        .ibx-nm-row {
            display: flex; align-items: center; gap: 11px;
            padding: 11px 16px; cursor: pointer; transition: background .12s;
        }
        .ibx-nm-row:hover { background: var(--latte-soft); }
        .ibx-nm-av {
            width: 38px; height: 38px; border-radius: 50%; flex-shrink: 0;
            display: flex; align-items: center; justify-content: center;
            font-weight: 700; font-size: 14px; color: var(--cream); overflow: hidden;
        }
        .ibx-nm-info { flex: 1; min-width: 0; }
        .ibx-nm-name { font-size: 14px; font-weight: 600; color: var(--espresso); }
        .ibx-nm-sub { font-size: 12px; color: var(--muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
        .ibx-search-wrap { position: relative; }
        .ibx-search-input {
            width: 100%;
            background: var(--latte-soft);
            border: 1.5px solid var(--border);
            border-radius: 99px;
            padding: 7px 14px 7px 34px;
            font-size: 13px; font-family: 'DM Sans', sans-serif;
            color: var(--espresso); outline: none;
            transition: border-color .15s;
        }
        .ibx-search-input:focus { border-color: var(--caramel); }
        .ibx-search-input::placeholder { color: var(--muted); }
        .ibx-search-icon {
            position: absolute; left: 11px; top: 50%; transform: translateY(-50%);
            font-size: 13px; pointer-events: none; color: var(--muted);
        }
        .ibx-conv-list { flex: 1; overflow-y: auto; padding: 6px 0; }
        .ibx-conv-list::-webkit-scrollbar { width: 4px; }
        .ibx-conv-list::-webkit-scrollbar-thumb { background: var(--border); border-radius: 99px; }

        .ibx-conv-row {
            display: flex; align-items: center; gap: 11px;
            padding: 11px 16px; cursor: pointer;
            transition: background .12s;
            border-left: 3px solid transparent;
        }
        .ibx-conv-row:hover { background: var(--latte-soft); }
        .ibx-conv-row.active { background: var(--latte-soft); border-left-color: var(--caramel); padding-left: 13px; }
        .ibx-conv-row.unread .ibx-conv-name { font-weight: 700; }
        .ibx-conv-av { position: relative; flex-shrink: 0; }
        .ibx-conv-av-inner {
            width: 44px; height: 44px; border-radius: 50%;
            display: flex; align-items: center; justify-content: center;
            font-weight: 700; font-size: 15px; color: #fff;
            border: 2px solid var(--border); overflow: hidden;
        }
        .ibx-conv-av-inner img { width: 100%; height: 100%; object-fit: cover; }
        .ibx-conv-body { flex: 1; min-width: 0; }
        .ibx-conv-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 2px; }
        .ibx-conv-name {
            font-size: 13.5px; font-weight: 600; color: var(--espresso);
            white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
        }
        .ibx-conv-time { font-size: 11px; color: var(--muted); flex-shrink: 0; }
        .ibx-conv-preview {
            font-size: 12px; color: var(--muted);
            white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
        }
        .ibx-unread-dot { width: 8px; height: 8px; background: var(--caramel); border-radius: 50%; flex-shrink: 0; margin-left: 6px; }
        .ibx-unread-badge {
            background: var(--espresso); color: var(--cream);
            font-size: 10px; font-weight: 700;
            border-radius: 99px; padding: 1px 6px;
            min-width: 17px; text-align: center; flex-shrink: 0;
        }

        /* Right: chat area */
        .ibx-chat-panel {
            flex: 1; display: flex; flex-direction: column; min-width: 0;
            background: var(--warm-white); position: relative;
        }
        .ibx-chat-panel::before {
            content: ''; position: absolute; inset: 0; pointer-events: none;
            background-image: radial-gradient(circle, var(--border) 1px, transparent 1px);
            background-size: 24px 24px; opacity: .4;
        }

        /* Empty state */
        .ibx-empty {
            flex: 1; display: flex; flex-direction: column;
            align-items: center; justify-content: center;
            text-align: center; padding: 40px;
            position: relative; z-index: 1;
        }
        .ibx-empty-icon {
            width: 72px; height: 72px;
            background: var(--latte-soft);
            border: 2px solid var(--border); border-radius: 50%;
            display: flex; align-items: center; justify-content: center;
            font-size: 30px; margin-bottom: 18px;
        }
        .ibx-empty h3 { font-family: 'Playfair Display', serif; font-size: 22px; color: var(--espresso); margin-bottom: 8px; }
        .ibx-empty h3 em { font-style: italic; color: var(--caramel); }
        .ibx-empty p { font-size: 14px; color: var(--muted); line-height: 1.6; max-width: 280px; }

        /* Chat header */
        .ibx-chat-header {
            padding: 0 24px; height: 64px;
            display: flex; align-items: center;
            background: var(--card);
            border-bottom: 1px solid var(--border);
            gap: 14px; flex-shrink: 0;
            position: relative; z-index: 2;
            box-shadow: 0 1px 4px rgba(26,14,7,.06);
        }
        .ibx-ch-av {
            width: 40px; height: 40px; border-radius: 50%;
            display: flex; align-items: center; justify-content: center;
            font-weight: 700; font-size: 14px; color: #fff;
            flex-shrink: 0; overflow: hidden;
        }
        .ibx-ch-av img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; }
        .ibx-ch-info { flex: 1; min-width: 0; }
        .ibx-ch-name { font-size: 15px; font-weight: 700; color: var(--espresso); line-height: 1.2; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
        .ibx-ch-sub { font-size: 12px; color: var(--muted); }
        .ibx-ch-actions { display: flex; gap: 6px; }
        .ibx-icon-btn {
            width: 36px; height: 36px;
            background: var(--latte-soft); border: 1.5px solid var(--border);
            border-radius: 9px; display: flex; align-items: center; justify-content: center;
            font-size: 15px; cursor: pointer; transition: all .15s; color: var(--espresso);
        }
        .ibx-icon-btn:hover { border-color: var(--caramel); color: var(--caramel); }

        /* Message thread */
        .ibx-thread {
            flex: 1; overflow-y: auto;
            padding: 24px 28px; display: flex; flex-direction: column; gap: 4px;
            position: relative; z-index: 1;
        }
        .ibx-thread::-webkit-scrollbar { width: 4px; }
        .ibx-thread::-webkit-scrollbar-thumb { background: var(--border); border-radius: 99px; }

        .ibx-date-divider { display: flex; align-items: center; gap: 10px; margin: 16px 0 12px; }
        .ibx-date-divider::before, .ibx-date-divider::after { content: ''; flex: 1; height: 1px; background: var(--border); }
        .ibx-date-divider span { font-size: 11px; font-weight: 600; color: var(--muted); text-transform: uppercase; letter-spacing: .6px; }

        .ibx-msg-group { display: flex; flex-direction: column; gap: 3px; margin-bottom: 10px; }
        .ibx-msg-row { display: flex; align-items: flex-end; gap: 8px; }
        .ibx-msg-row.mine { flex-direction: row-reverse; }
        .ibx-msg-av {
            width: 28px; height: 28px; border-radius: 50%;
            display: flex; align-items: center; justify-content: center;
            font-size: 10px; font-weight: 700; color: #fff; flex-shrink: 0; overflow: hidden;
        }
        .ibx-msg-av img { width: 100%; height: 100%; object-fit: cover; }
        .ibx-msg-av.hidden { visibility: hidden; }
        .ibx-bubble {
            max-width: 62%; padding: 10px 14px; border-radius: 18px;
            font-size: 14px; line-height: 1.55; word-break: break-word;
        }
        .ibx-msg-row:not(.mine) .ibx-bubble {
            background: var(--card); color: var(--espresso);
            border: 1px solid var(--border); border-bottom-left-radius: 5px;
            box-shadow: 0 1px 4px rgba(26,14,7,.06);
        }
        .ibx-msg-row.mine .ibx-bubble {
            background: linear-gradient(135deg, var(--espresso) 0%, var(--brown) 100%);
            color: var(--cream); border-bottom-right-radius: 5px;
            box-shadow: 0 2px 8px rgba(26,14,7,.18);
        }
        .ibx-msg-time { font-size: 10.5px; color: var(--muted); padding: 2px 4px; align-self: flex-end; flex-shrink: 0; }

        /* Profile recommendation card inside chat thread */
        .ibx-prof-card {
            max-width: 240px;
            background: #fff;
            border: 1.5px solid rgba(181,101,29,0.25);
            border-radius: 14px;
            overflow: hidden;
            box-shadow: 0 1px 4px rgba(28,15,7,0.07);
        }
        .ibx-prof-card-label {
            font-size: 11px; font-weight: 500; color: var(--caramel);
            background: #F5EDE3; padding: 7px 12px;
            border-bottom: 1px solid rgba(181,101,29,0.15);
        }
        .ibx-prof-card-body {
            display: flex; align-items: center; gap: 10px; padding: 12px 12px 8px;
        }
        .ibx-prof-card-av {
            width: 38px; height: 38px; border-radius: 50%; flex-shrink: 0;
            background: linear-gradient(135deg, #D4894A, #B5651D);
            display: flex; align-items: center; justify-content: center;
            font-size: 13px; font-weight: 600; color: #fff;
        }
        .ibx-prof-card-name {
            font-size: 13px; font-weight: 600; color: var(--espresso);
        }
        .ibx-prof-card-sub {
            font-size: 11px; color: var(--muted); margin-top: 2px;
        }
        .ibx-prof-card-btn {
            display: block; width: 100%; padding: 9px 12px;
            background: none; border: none; border-top: 1px solid rgba(181,101,29,0.15);
            font-size: 13px; font-weight: 500; color: var(--caramel);
            cursor: pointer; text-align: center; font-family: 'Sora', sans-serif;
            transition: background 0.15s;
        }
        .ibx-prof-card-btn:hover { background: #F5EDE3; }

        /* Input bar */
        .ibx-input-bar {
            padding: 12px 20px 16px; background: var(--card);
            border-top: 1px solid var(--border); flex-shrink: 0;
            position: relative; z-index: 2;
        }
        .ibx-input-row { display: flex; align-items: flex-end; gap: 10px; }
        .ibx-input-wrap {
            flex: 1; background: var(--latte-soft);
            border: 1.5px solid var(--border); border-radius: 22px;
            display: flex; align-items: flex-end;
            padding: 8px 14px; transition: border-color .15s;
        }
        .ibx-input-wrap:focus-within { border-color: var(--caramel); box-shadow: 0 0 0 3px rgba(196,122,58,.08); }
        .ibx-textarea {
            flex: 1; border: none; background: transparent; outline: none;
            font-family: 'DM Sans', sans-serif; font-size: 14px; color: var(--espresso);
            resize: none; max-height: 120px; line-height: 1.5;
        }
        .ibx-textarea::placeholder { color: var(--muted); }
        .ibx-send-btn {
            width: 40px; height: 40px; flex-shrink: 0;
            background: var(--espresso); border: none; border-radius: 50%;
            display: flex; align-items: center; justify-content: center;
            cursor: pointer; font-size: 16px; color: var(--cream);
            transition: all .15s; box-shadow: 0 2px 8px rgba(26,14,7,.2);
        }
        .ibx-send-btn:hover { opacity: .85; transform: scale(1.07); }
        .ibx-send-btn:active { transform: scale(.95); }

        @media (max-width: 700px) { .ibx-conv-panel { width: 220px; } }
        @media (max-width: 520px) { .ibx-conv-panel { display: none; } }


/* ── Settings shell ── */
.settings-shell {
  display: flex;
  flex: 1;
  min-height: 0;
  background: #faf6f1;
  overflow: hidden;
}

/* ── Settings sidebar ── */
.settings-sidebar {
  width: 220px;
  flex-shrink: 0;
  background: #ffffff;
  border-right: 1px solid #e8d5c0;
  padding: 28px 0;
  overflow-y: auto;
  align-self: stretch;
}

.settings-sidebar-label {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #c9a98a;
  padding: 0 20px 10px;
}

.settings-nav-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 20px;
  cursor: pointer;
  font-size: 14px;
  font-weight: 400;
  color: #5c3317;
  transition: background 0.15s, color 0.15s;
  border-left: 3px solid transparent;
  width: 100%;
  background: none;
  border-top: none;
  border-right: none;
  border-bottom: none;
  text-align: left;
}
.settings-nav-item:hover { background: #faf6f1; color: #1a0e07; }
.settings-nav-item.active { background: #f5ede3; color: #b5651d; font-weight: 500; border-left-color: #b5651d; }
.settings-nav-item .nav-icon { font-size: 16px; width: 20px; text-align: center; }
.settings-nav-divider { height: 1px; background: #e8d5c0; margin: 12px 20px; }

/* ── Settings content area ── */
.settings-content {
  flex: 1;
  padding: 36px 40px;
  overflow-y: auto;
  min-width: 0;
}

/* ── Section visibility ── */
.settings-section { display: none; }
.settings-section.active { display: block; }

/* ── Section header ── */
.section-eyebrow { font-size: 11px; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: #b5651d; margin-bottom: 6px; }
.section-title { font-family: 'Playfair Display', Georgia, serif; font-size: 28px; font-weight: 600; color: #1a0e07; line-height: 1.2; margin-bottom: 6px; }
.section-title em { font-style: italic; color: #b5651d; }
.section-desc { font-size: 14px; color: #8b6a52; margin-bottom: 28px; line-height: 1.6; }

/* ── Cards ── */
.s-card { background: #ffffff; border: 1px solid #e8d5c0; border-radius: 14px; margin-bottom: 20px; overflow: hidden; }
.s-card-header { padding: 16px 22px; border-bottom: 1px solid #f0e4d4; display: flex; align-items: center; justify-content: space-between; }
.s-card-title { font-size: 15px; font-weight: 600; color: #1a0e07; }
.s-card-body { padding: 20px 22px; }
.s-card-footer { padding: 14px 22px; border-top: 1px solid #f0e4d4; background: #faf6f1; display: flex; gap: 10px; align-items: center; }

/* ── Form elements ── */
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 16px; }
.form-row.full { grid-template-columns: 1fr; }
.form-group { margin-bottom: 16px; }
.form-group:last-child { margin-bottom: 0; }
.form-label { display: block; font-size: 12px; font-weight: 600; color: #5c3317; text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 6px; }
.form-input, .form-select, .form-textarea { width: 100%; padding: 10px 14px; border: 1.5px solid #e8d5c0; border-radius: 8px; font-size: 14px; font-family: 'DM Sans', sans-serif; color: #1a0e07; background: #ffffff; transition: border-color 0.2s; outline: none; box-sizing: border-box; }
.form-input:focus, .form-select:focus, .form-textarea:focus { border-color: #b5651d; }
.form-textarea { resize: vertical; min-height: 90px; line-height: 1.6; }

/* ── Buttons ── */
.btn-primary { background: #b5651d; color: #ffffff; border: none; padding: 10px 20px; border-radius: 8px; font-size: 14px; font-weight: 500; cursor: pointer; transition: background 0.2s; font-family: 'DM Sans', sans-serif; }
.btn-primary:hover { background: #9a5418; }
.btn-ghost { background: transparent; color: #8b6a52; border: 1.5px solid #e8d5c0; padding: 10px 20px; border-radius: 8px; font-size: 14px; font-weight: 500; cursor: pointer; transition: all 0.2s; font-family: 'DM Sans', sans-serif; }
.btn-ghost:hover { border-color: #b5651d; color: #b5651d; }
.btn-danger { background: transparent; color: #c0392b; border: 1.5px solid #f5c6c2; padding: 9px 18px; border-radius: 8px; font-size: 14px; font-weight: 500; cursor: pointer; font-family: 'DM Sans', sans-serif; transition: all 0.2s; }
.btn-danger:hover { background: #fdecea; border-color: #c0392b; }

/* ── Avatar upload ── */
.avatar-upload-row { display: flex; align-items: center; gap: 20px; padding: 6px 0 16px; }
.avatar-circle { width: 72px; height: 72px; border-radius: 50%; background: linear-gradient(135deg, #d4894a, #b5651d); display: flex; align-items: center; justify-content: center; font-size: 26px; font-weight: 600; color: #fff; flex-shrink: 0; overflow: hidden; }
.avatar-circle img { width: 100%; height: 100%; object-fit: cover; }
.avatar-upload-btns { display: flex; flex-direction: column; gap: 6px; }
.btn-upload { background: #f5ede3; color: #b5651d; border: 1.5px solid #e8d5c0; padding: 7px 14px; border-radius: 7px; font-size: 13px; font-weight: 500; cursor: pointer; font-family: 'DM Sans', sans-serif; transition: all 0.2s; }
.btn-upload:hover { background: #e8d5c0; }
.avatar-hint { font-size: 11px; color: #c9a98a; }

/* ── Toggle rows ── */
.toggle-row { display: flex; align-items: center; justify-content: space-between; padding: 14px 0; border-bottom: 1px solid #f0e4d4; }
.toggle-row:last-child { border-bottom: none; padding-bottom: 0; }
.toggle-text { flex: 1; padding-right: 20px; }
.toggle-label { font-size: 14px; font-weight: 500; color: #1a0e07; }
.toggle-desc { font-size: 12px; color: #8b6a52; margin-top: 2px; line-height: 1.4; }
.toggle { position: relative; display: inline-block; width: 42px; height: 24px; flex-shrink: 0; }
.toggle input { opacity: 0; width: 0; height: 0; }
.toggle-track { position: absolute; inset: 0; background: #e8d5c0; border-radius: 24px; cursor: pointer; transition: background 0.2s; }
.toggle input:checked + .toggle-track { background: #b5651d; }
.toggle-thumb { position: absolute; width: 18px; height: 18px; top: 3px; left: 3px; background: white; border-radius: 50%; transition: transform 0.2s; }
.toggle input:checked + .toggle-track .toggle-thumb { transform: translateX(18px); }

/* ── Theme options ── */
.theme-options { display: flex; gap: 10px; flex-wrap: wrap; }
.theme-option { flex: 1; min-width: 100px; border: 2px solid #e8d5c0; border-radius: 10px; padding: 14px 12px; cursor: pointer; text-align: center; transition: all 0.2s; }
.theme-option:hover { border-color: #b5651d; }
.theme-option.selected { border-color: #b5651d; background: #f5ede3; }
.theme-option .theme-icon { font-size: 20px; margin-bottom: 5px; }
.theme-option .theme-name { font-size: 13px; font-weight: 500; color: #1a0e07; }
.theme-option .theme-desc { font-size: 11px; color: #8b6a52; }

/* ── Privacy pill options ── */
.privacy-group { margin-bottom: 18px; }
.privacy-label { font-size: 13px; font-weight: 600; color: #1a0e07; margin-bottom: 8px; }
.privacy-options { display: flex; gap: 8px; flex-wrap: wrap; }
.privacy-option { display: flex; align-items: center; gap: 6px; padding: 7px 14px; border: 1.5px solid #e8d5c0; border-radius: 20px; cursor: pointer; font-size: 13px; color: #5c3317; transition: all 0.2s; }
.privacy-option input { display: none; }
.privacy-option.selected { border-color: #b5651d; background: #f5ede3; color: #b5651d; font-weight: 500; }

/* ── Availability grid ── */
.avail-grid { display: flex; flex-direction: column; gap: 8px; }
.avail-day-row { display: grid; grid-template-columns: 90px 1fr 1fr auto; align-items: center; gap: 10px; }
.avail-day-name { font-size: 13px; font-weight: 500; color: #5c3317; }

/* ── Danger zone ── */
.danger-row { display: flex; align-items: center; justify-content: space-between; padding: 14px 0; border-bottom: 1px solid #f0e4d4; }
.danger-row:last-child { border-bottom: none; padding-bottom: 0; }
.danger-info .danger-title { font-size: 14px; font-weight: 500; color: #1a0e07; }
.danger-info .danger-desc { font-size: 12px; color: #8b6a52; margin-top: 2px; }

/* ── Settings toast ── */
.s-toast { position: fixed; bottom: 28px; right: 28px; background: #2d7a4f; color: white; padding: 12px 20px; border-radius: 10px; font-size: 14px; font-weight: 500; display: none; align-items: center; gap: 8px; z-index: 9999; box-shadow: 0 4px 20px rgba(0,0,0,0.15); animation: slideUp 0.3s ease; }
.s-toast.show { display: flex; }
@keyframes slideUp { from { transform: translateY(10px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }

/* ── Tags input ── */
.tags-container { display: flex; flex-wrap: wrap; gap: 6px; padding: 8px 10px; border: 1.5px solid #e8d5c0; border-radius: 8px; background: #fff; min-height: 44px; cursor: text; }
.tags-container:focus-within { border-color: #b5651d; }
.tag-pill { display: flex; align-items: center; gap: 4px; background: #f5ede3; color: #b5651d; border-radius: 20px; padding: 3px 10px; font-size: 13px; }
.tag-pill button { background: none; border: none; cursor: pointer; color: #b5651d; font-size: 15px; line-height: 1; padding: 0; }
.tags-input { border: none; outline: none; font-size: 14px; font-family: 'DM Sans', sans-serif; color: #1a0e07; flex: 1; min-width: 100px; padding: 0 4px; background: transparent; }

/* ── Security rows ── */
.security-row { display: flex; align-items: center; justify-content: space-between; padding: 14px 0; border-bottom: 1px solid #f0e4d4; }
.security-row:last-child { border-bottom: none; padding-bottom: 0; }
.security-info { display: flex; align-items: center; gap: 10px; }
.security-icon { font-size: 20px; }
.security-label { font-size: 14px; font-weight: 500; color: #1a0e07; }
.security-sub { font-size: 12px; color: #8b6a52; }
.badge-verified { background: #eaf6ef; color: #2d7a4f; font-size: 11px; font-weight: 600; padding: 3px 10px; border-radius: 20px; }
.badge-soon { background: #f5ede3; color: #b5651d; font-size: 11px; font-weight: 600; padding: 3px 10px; border-radius: 20px; }

/* ── Responsive ── */
@media (max-width: 700px) {
  .settings-shell { flex-direction: column; }
  .settings-sidebar { width: 100%; height: auto; position: static; display: flex; flex-wrap: wrap; gap: 4px; padding: 12px; border-right: none; border-bottom: 1px solid #e8d5c0; }
  .settings-nav-item { flex: 1; min-width: 80px; border-left: none; border-bottom: 3px solid transparent; padding: 8px 10px; font-size: 12px; border-radius: 8px; justify-content: center; }
  .settings-nav-item.active { border-bottom-color: #b5651d; border-left-color: transparent; }
  .settings-sidebar-label, .settings-nav-divider { display: none; }
  .settings-content { padding: 20px 16px; }
  .form-row { grid-template-columns: 1fr; }
  .avail-day-row { grid-template-columns: 70px 1fr 1fr; }
}

/* ── Legal page (Privacy Policy / Terms of Service) ── */
.legal-page {
  min-height: 100vh;
  background: #fdf8f3;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-bottom: 60px;
}

.legal-header {
  width: 100%;
  max-width: 800px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 24px 0;
}

.legal-back-btn {
  background: none;
  border: 1.5px solid #e8d5c0;
  border-radius: 8px;
  padding: 7px 14px;
  font-size: 13px;
  font-weight: 500;
  color: #5c3317;
  cursor: pointer;
  font-family: 'DM Sans', sans-serif;
  transition: background 0.15s;
}
.legal-back-btn:hover { background: #f5ede3; }

.legal-brand {
  font-family: 'Playfair Display', serif;
  font-size: 18px;
  font-weight: 900;
  color: #1a0e07;
}
.legal-brand span { color: #b5651d; }

.legal-tabs {
  display: flex;
  gap: 4px;
  padding: 20px 24px 0;
  width: 100%;
  max-width: 800px;
  border-bottom: 1px solid #e8d5c0;
  margin-top: 4px;
}

.legal-tab {
  background: none;
  border: none;
  border-bottom: 3px solid transparent;
  padding: 10px 20px 12px;
  font-size: 14px;
  font-weight: 500;
  color: #8b6a52;
  cursor: pointer;
  font-family: 'DM Sans', sans-serif;
  margin-bottom: -1px;
  transition: color 0.15s;
}
.legal-tab:hover { color: #1a0e07; }
.legal-tab.active { color: #b5651d; border-bottom-color: #b5651d; font-weight: 600; }

.legal-content {
  width: 100%;
  max-width: 800px;
  padding: 36px 24px;
}

.legal-doc { font-family: 'DM Sans', sans-serif; color: #1a0e07; }

.legal-effective {
  font-size: 12px;
  color: #8b6a52;
  margin-bottom: 8px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.legal-doc h1 {
  font-family: 'Playfair Display', serif;
  font-size: 32px;
  font-weight: 700;
  color: #1a0e07;
  margin: 0 0 28px;
  line-height: 1.2;
}

.legal-doc h2 {
  font-size: 17px;
  font-weight: 700;
  color: #1a0e07;
  margin: 28px 0 8px;
  padding-bottom: 6px;
  border-bottom: 1px solid #f0e4d4;
}

.legal-doc h3 {
  font-size: 14px;
  font-weight: 700;
  color: #5c3317;
  margin: 16px 0 6px;
}

.legal-doc p {
  font-size: 14px;
  line-height: 1.75;
  color: #3a2210;
  margin: 0 0 12px;
}

.legal-doc ul {
  margin: 0 0 12px 20px;
  padding: 0;
}

.legal-doc li {
  font-size: 14px;
  line-height: 1.75;
  color: #3a2210;
  margin-bottom: 4px;
}

.legal-doc a {
  color: #b5651d;
  text-decoration: underline;
}

.legal-doc strong { color: #1a0e07; }

@media (max-width: 600px) {
  .legal-content { padding: 20px 16px; }
  .legal-doc h1 { font-size: 24px; }
  .legal-header { padding: 16px 16px 0; }
  .legal-tabs { padding: 16px 16px 0; }
}

/* ════════════════════════════════════════════════════════════
   SETTINGS PROFILE — sp-* components
   ════════════════════════════════════════════════════════════ */

/* Preview card */
.sp-preview-card {
  background: #fff;
  border: 1px solid #ede0d0;
  border-radius: 14px;
  box-shadow: 0 2px 16px rgba(90,62,43,0.07);
  margin-bottom: 24px;
  overflow: hidden;
}

.sp-banner {
  height: 120px;
  background: linear-gradient(135deg, #c17d3c 0%, #8b4513 55%, #5a2d0c 100%);
  position: relative;
  cursor: pointer;
}
.sp-banner-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 600;
  color: rgba(255,255,255,0);
  transition: all 0.2s;
}
.sp-banner:hover .sp-banner-overlay {
  background: rgba(0,0,0,0.32);
  color: #fff;
}

.sp-preview-body {
  display: flex;
  align-items: flex-end;
  gap: 16px;
  padding: 0 24px 20px;
  flex-wrap: wrap;
}

.sp-avatar-wrap { margin-top: -36px; flex-shrink: 0; }

.sp-avatar {
  width: 72px; height: 72px;
  border-radius: 50%;
  background: linear-gradient(135deg, #d4894a, #b5651d);
  border: 3px solid #fff;
  box-shadow: 0 2px 10px rgba(0,0,0,0.15);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Playfair Display', serif;
  font-size: 26px; font-weight: 700; color: #fff;
  cursor: pointer; overflow: hidden; position: relative;
}
.sp-avatar-overlay {
  position: absolute; inset: 0; border-radius: 50%;
  background: rgba(0,0,0,0);
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; color: rgba(255,255,255,0);
  transition: all 0.2s;
}
.sp-avatar:hover .sp-avatar-overlay { background: rgba(0,0,0,0.4); color: #fff; }

.sp-preview-info { flex: 1; padding-top: 8px; min-width: 0; }
.sp-preview-name { font-family: 'Playfair Display', serif; font-size: 18px; font-weight: 700; color: #3b2512; line-height: 1.2; }
.sp-preview-headline { font-size: 13px; color: #6b3f2a; margin-top: 2px; }
.sp-preview-school { font-size: 12px; color: #b89a7a; margin-top: 2px; }

.sp-chat-badge { cursor: pointer; flex-shrink: 0; padding-top: 8px; }
.sp-chat-pill {
  display: inline-flex; align-items: center; gap: 5px;
  background: #eafaf1; color: #2d6a4f;
  border: 1px solid #a9dfbf;
  border-radius: 20px; padding: 5px 12px; font-size: 12.5px; font-weight: 600;
  transition: all 0.2s; user-select: none;
}
.sp-chat-badge:has(input:not(:checked)) .sp-chat-pill {
  background: #f5f5f5; color: #999; border-color: #ddd;
}

/* Cards */
.sp-card {
  background: #fff;
  border: 1px solid #ede0d0;
  border-radius: 14px;
  box-shadow: 0 2px 16px rgba(90,62,43,0.07);
  padding: 28px 32px;
  margin-bottom: 24px;
}

.sp-card-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #b89a7a;
  padding-bottom: 14px;
  border-bottom: 1px solid #f0e6d8;
  margin-bottom: 20px;
}

/* Fields */
.sp-field { margin-bottom: 18px; }
.sp-field:last-of-type { margin-bottom: 0; }

.sp-label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: #5a3e2b;
  margin-bottom: 6px;
}

.sp-hint { font-size: 12px; color: #b89a7a; margin-top: 4px; }

.sp-input {
  width: 100%;
  box-sizing: border-box;
  border: 1.5px solid #ddd0c0;
  border-radius: 9px;
  padding: 10px 14px;
  background: #fdf8f3;
  font-size: 14px;
  font-family: 'DM Sans', sans-serif;
  color: #3b2512;
  outline: none;
  transition: border-color 0.18s, background 0.18s, box-shadow 0.18s;
}
.sp-input:focus {
  border-color: #c17d3c;
  background: #fff;
  box-shadow: 0 0 0 3px rgba(193,125,60,0.12);
}
.sp-textarea { resize: vertical; min-height: 88px; line-height: 1.65; }

/* Grid */
.sp-grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  margin-bottom: 18px;
}

/* Status chips */
.sp-chips { display: flex; flex-wrap: wrap; gap: 8px; }
.sp-chip {
  border: 1.5px solid #ddd0c0;
  border-radius: 20px;
  padding: 6px 16px;
  font-size: 13px;
  font-weight: 500;
  color: #6b3f2a;
  background: #fdf8f3;
  cursor: pointer;
  font-family: 'DM Sans', sans-serif;
  transition: all 0.15s;
}
.sp-chip:hover { border-color: #c17d3c; color: #c17d3c; }
.sp-chip.active { background: #c17d3c; color: #fff; border-color: #c17d3c; }

/* Tags */
.sp-tags-wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 8px 10px;
  border: 1.5px solid #ddd0c0;
  border-radius: 9px;
  background: #fdf8f3;
  min-height: 44px;
  cursor: text;
  transition: border-color 0.18s, box-shadow 0.18s;
}
.sp-tags-wrap:focus-within {
  border-color: #c17d3c;
  box-shadow: 0 0 0 3px rgba(193,125,60,0.12);
}
.sp-tag-input {
  border: none; outline: none;
  background: transparent;
  font-size: 13.5px; font-family: 'DM Sans', sans-serif;
  color: #3b2512; flex: 1; min-width: 120px; padding: 2px 4px;
}

/* Buttons */
.sp-btn-primary {
  background: #c17d3c;
  color: #fff;
  border: none;
  border-radius: 9px;
  padding: 10px 22px;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  font-family: 'DM Sans', sans-serif;
  transition: background 0.18s, box-shadow 0.18s;
}
.sp-btn-primary:hover { background: #a8692f; box-shadow: 0 4px 12px rgba(193,125,60,0.3); }

.sp-btn-ghost {
  background: transparent;
  border: 1.5px solid #ddd0c0;
  color: #9c7b5f;
  border-radius: 9px;
  padding: 10px 22px;
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  font-family: 'DM Sans', sans-serif;
  transition: all 0.15s;
}
.sp-btn-ghost:hover { background: #fdf3ea; color: #5a3e2b; border-color: #c8a87a; }

.sp-btn-danger {
  background: #fff0ee;
  color: #c0392b;
  border: 1px solid #f5c6c2;
  border-radius: 9px;
  padding: 9px 18px;
  font-size: 13.5px;
  font-weight: 500;
  cursor: pointer;
  font-family: 'DM Sans', sans-serif;
  transition: all 0.15s;
}
.sp-btn-danger:hover { background: #fdecea; border-color: #c0392b; }

/* Save row */
.sp-save-row {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid #f0e6d8;
}

/* Resume row */
.sp-resume-row {
  display: flex;
  align-items: center;
  gap: 14px;
  background: #fdf8f3;
  border: 1px solid #ede0d0;
  border-radius: 10px;
  padding: 14px 18px;
  margin-bottom: 14px;
}
.sp-resume-info { flex: 1; min-width: 0; }
.sp-resume-name { font-size: 14px; font-weight: 600; color: #3b2512; }

/* Responsive */
@media (max-width: 600px) {
  .sp-card { padding: 20px 18px; }
  .sp-grid-2 { grid-template-columns: 1fr; gap: 0; }
  .sp-preview-body { flex-direction: column; align-items: flex-start; }
}

/* ── Home tab bar (Home / Feed) ── */
.home-tab-bar {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--border);
  background: var(--card);
  padding: 0 24px;
  position: sticky;
  top: 0;
  z-index: 10;
}
.home-tab {
  background: none;
  border: none;
  border-bottom: 3px solid transparent;
  padding: 14px 20px;
  font-size: 14px;
  font-weight: 500;
  color: var(--muted);
  cursor: pointer;
  font-family: 'DM Sans', sans-serif;
  transition: color 0.15s;
  margin-bottom: -1px;
}
.home-tab:hover { color: var(--espresso); }
.home-tab.active { color: var(--caramel); border-bottom-color: var(--caramel); font-weight: 600; }

/* ── Inbox: conversation list tabs ── */
.ibx-tabs-row {
    display: flex;
    padding: 0 18px;
    gap: 0;
    border-bottom: 1px solid var(--border);
    flex-shrink: 0;
}
.ibx-tab-btn {
    flex: 1;
    padding: 9px 0;
    font-size: 12.5px;
    font-weight: 500;
    color: var(--muted);
    background: none;
    border: none;
    border-bottom: 2px solid transparent;
    cursor: pointer;
    font-family: 'DM Sans', sans-serif;
    transition: all 0.15s;
    margin-bottom: -1px;
}
.ibx-tab-btn.active { color: var(--caramel); border-bottom-color: var(--caramel); }
.ibx-tab-btn:hover:not(.active) { color: var(--espresso); }

/* ── Inbox: right upcoming-chats panel ── */
.ibx-upcoming-panel {
    width: 260px;
    flex-shrink: 0;
    border-left: 1px solid var(--border);
    display: flex;
    flex-direction: column;
    background: var(--warm-white, #fdf8f3);
    overflow: hidden;
}
.ibx-up-header {
    padding: 18px 16px 14px;
    border-bottom: 1px solid var(--border);
    flex-shrink: 0;
}
.ibx-up-title {
    font-family: 'Playfair Display', serif;
    font-size: 15px;
    font-weight: 600;
    color: var(--espresso);
    margin-bottom: 2px;
}
.ibx-up-sub { font-size: 12px; color: var(--muted); }

.ibx-up-list {
    flex: 1;
    overflow-y: auto;
    padding: 10px 12px;
}
.ibx-up-list::-webkit-scrollbar { width: 0; }

.ibx-up-card {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 12px;
    margin-bottom: 8px;
    cursor: pointer;
    transition: all 0.15s;
    box-shadow: 0 1px 4px rgba(28,15,7,0.05);
}
.ibx-up-card:hover {
    border-color: var(--caramel);
    box-shadow: 0 4px 16px rgba(28,15,7,0.09);
    transform: translateY(-1px);
}
.ibx-up-card-top {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 8px;
}
.ibx-up-av {
    width: 28px; height: 28px;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 10px; font-weight: 600; color: #fff;
    flex-shrink: 0;
}
.ibx-up-name { font-size: 13px; font-weight: 600; color: var(--espresso); }
.ibx-up-role { font-size: 11px; color: var(--muted); }
.ibx-up-badge {
    margin-left: auto;
    font-size: 10px;
    font-weight: 600;
    padding: 2px 7px;
    border-radius: 20px;
    flex-shrink: 0;
}
.ibx-up-badge.today    { background: #fff3e0; color: #e65100; }
.ibx-up-badge.soon     { background: #e8f5e9; color: #2e7d32; }
.ibx-up-badge.upcoming { background: var(--latte-soft); color: var(--muted); }

.ibx-up-time {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 12px;
    color: var(--muted);
    margin-bottom: 8px;
}
.ibx-up-actions { display: flex; gap: 5px; }
.ibx-up-btn {
    flex: 1;
    padding: 5px 8px;
    border-radius: 6px;
    font-size: 11px;
    font-weight: 500;
    cursor: pointer;
    font-family: 'DM Sans', sans-serif;
    border: none;
    transition: all 0.15s;
    text-align: center;
}
.ibx-up-btn.join { background: var(--caramel); color: #fff; }
.ibx-up-btn.join:hover { background: var(--espresso); }
.ibx-up-btn.details { background: var(--latte-soft); color: var(--muted); }
.ibx-up-btn.details:hover { color: var(--espresso); }

.ibx-up-empty {
    padding: 24px 16px;
    text-align: center;
    font-size: 13px;
    color: var(--muted);
    line-height: 1.6;
}

.ibx-up-new-btn {
    margin: 0 12px 14px;
    padding: 10px;
    background: var(--latte-soft);
    border: 1px dashed var(--border);
    border-radius: 10px;
    font-size: 13px;
    font-weight: 500;
    color: var(--caramel);
    cursor: pointer;
    font-family: 'DM Sans', sans-serif;
    transition: all 0.15s;
    flex-shrink: 0;
}
.ibx-up-new-btn:hover { background: var(--latte); }

/* Hide right panel on narrow screens */
@media (max-width: 900px) { .ibx-upcoming-panel { display: none; } }

/* Inbox header h2 plain style */
.ibx-conv-header h2 {
    font-size: 18px;
    font-weight: 700;
    color: var(--espresso);
    font-family: 'Playfair Display', serif;
    margin-bottom: 12px;
}

/* ════════════════════════════════════════════════════════════════════
   FIRST SIP — DESIGN SYSTEM 2.0
   Warm · Premium · Minimal
   All rules here override earlier declarations to apply the new system.
   ════════════════════════════════════════════════════════════════════ */

/* ── Base typography ── */
body, button, input, select, textarea {
  font-family: 'Sora', -apple-system, BlinkMacSystemFont, sans-serif;
}
body { background: var(--cream); color: var(--espresso); }

/* Playfair only for display headings */
h1, h2, .view-title, .section-title, .db-greeting-h1,
.spanel-title, .su-steps-headline, .lp-hero-headline,
.mp2-stat div:first-child, .auth-headline,
.legal-doc h1 { font-family: 'Playfair Display', Georgia, serif; }

/* Global heading refinements */
h1, h2, h3 { letter-spacing: -0.02em; font-weight: 400; }

/* ── Page background ── */
.main-content, #mainContent, .content-view,
.settings-content, .settings-shell { background: var(--cream); }

/* ── Top navigation ── */
.topbar {
  background: var(--cream) !important;
  border-bottom: 1px solid var(--border) !important;
  box-shadow: none !important;
}
.topbar-logo { color: var(--espresso); border-right: none !important; }
.topbar-logo span { color: var(--caramel); }

/* Desktop tab nav */
.main-nav-tab {
  font-family: 'Sora', sans-serif;
  font-size: 13px;
  font-weight: 400;
  color: var(--muted);
  border-radius: 8px;
  padding: 6px 14px;
}
.main-nav-tab:hover { background: var(--latte-soft); color: var(--espresso); }
.main-nav-tab.active {
  background: var(--latte-soft) !important;
  color: var(--caramel) !important;
  font-weight: 500;
}
.main-nav-tab.active::after { background: var(--caramel); }
.main-nav-tab-label { font-size: 10px; }

/* ── Mobile bottom nav ── */
.mobile-bottom-nav {
  background: var(--cream) !important;
  border-top: 1px solid var(--border) !important;
  box-shadow: none !important;
  height: 64px;
}
.mob-nav-btn {
  font-family: 'Sora', sans-serif;
  font-size: 10px;
  color: var(--muted);
  font-weight: 400;
}
.mob-nav-btn.active { color: var(--caramel) !important; }
.mob-nav-icon { font-size: 20px; }

/* ── Cards & surfaces ── */
.s-card, .sp-card, .mc-chat-card, .group-card, .st-card,
.nw-conn-card, .db-section, .pv-card, .av-card,
.feed-post-card, .ibx-up-card, .mc-widget,
div[style*="border-radius: 14px"], div[style*="border-radius:14px"] {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: 14px !important;
  box-shadow: var(--shadow) !important;
}
.s-card:hover, .sp-card:hover, .mc-chat-card:hover,
.group-card:hover, .nw-conn-card:hover, .ibx-up-card:hover {
  border-color: var(--border-strong) !important;
  transform: translateY(-1px);
  box-shadow: var(--shadow-hover) !important;
}

/* ── Buttons — primary ── */
.btn-primary, .sp-btn-primary, .s-btn-primary,
button.btn.btn-primary, .su-btn, .lp-btn-primary,
.fv-create-btn, .send-btn, .ibx-send-btn,
.nw-btn-connect, .mc-btn-sm.primary,
.db-no-sip-btn, .gv-create-btn, .ibx-up-btn.join,
.event-btn.join, .card-btn.accept {
  background: var(--caramel) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 9px !important;
  font-family: 'Sora', sans-serif !important;
  font-weight: 500 !important;
  transition: all 0.15s !important;
}
.btn-primary:hover, .sp-btn-primary:hover, .su-btn:hover,
.nw-btn-connect:hover, .db-no-sip-btn:hover {
  background: #9A5418 !important;
  box-shadow: 0 4px 12px rgba(181,101,29,0.25) !important;
  transform: translateY(-1px);
}

/* ── Buttons — ghost/secondary ── */
.btn-ghost, .sp-btn-ghost, .s-btn-ghost,
button.btn.btn-secondary, .btn-secondary,
.mc-btn-sm.secondary, .ibx-up-btn.details,
.event-btn.view, .card-btn.decline,
.lp-btn-ghost, .nw-btn-message {
  background: transparent !important;
  border: 1px solid var(--border-strong) !important;
  color: var(--muted) !important;
  border-radius: 9px !important;
  font-family: 'Sora', sans-serif !important;
  font-weight: 400 !important;
  transition: all 0.15s !important;
}
.btn-ghost:hover, .sp-btn-ghost:hover, .btn-secondary:hover {
  border-color: var(--caramel) !important;
  color: var(--caramel) !important;
  background: var(--latte-soft) !important;
}

/* ── Buttons — danger ── */
.btn-danger, .sp-btn-danger, .s-btn-danger,
.mc-btn-sm.danger, .nw-btn-decline {
  background: transparent !important;
  border: 1px solid rgba(192,57,43,0.3) !important;
  color: #C0392B !important;
  border-radius: 9px !important;
  font-family: 'Sora', sans-serif !important;
  font-weight: 400 !important;
  transition: all 0.15s !important;
}
.btn-danger:hover, .sp-btn-danger:hover { background: #FFF0EE !important; border-color: #C0392B !important; }

/* ── Form inputs ── */
input:not([type="checkbox"]):not([type="radio"]):not([type="file"]):not([type="range"]),
select, textarea,
.sp-input, .form-input, .form-select, .form-textarea,
.ibx-search-input, .ibx-nm-search, .nwSearchInput,
.ibx-textarea, .su-input {
  font-family: 'Sora', sans-serif !important;
  font-size: 14px !important;
  border: 1px solid rgba(139,90,43,0.18) !important;
  border-radius: 8px !important;
  background: #fff !important;
  color: var(--espresso) !important;
  padding: 10px 14px !important;
  transition: border-color 0.15s, box-shadow 0.15s !important;
}
input:focus, select:focus, textarea:focus,
.sp-input:focus, .form-input:focus {
  border-color: var(--caramel) !important;
  box-shadow: 0 0 0 3px rgba(181,101,29,0.08) !important;
  outline: none !important;
}
input::placeholder, textarea::placeholder { color: var(--muted-2) !important; }

/* ── Labels ── */
.sp-label, .form-label, label {
  font-family: 'Sora', sans-serif !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  color: var(--brown) !important;
}

/* ── Section eyebrows & titles ── */
.section-eyebrow, .view-eyebrow, .db-section-label,
.sp-card-label, .s-card-title, .panel-title {
  font-family: 'Sora', sans-serif !important;
  font-size: 11px !important;
  font-weight: 500 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: var(--caramel) !important;
}
.view-title, .section-title {
  font-family: 'Playfair Display', serif !important;
  font-weight: 400 !important;
  letter-spacing: -0.02em !important;
  color: var(--espresso) !important;
}
.view-title em, .section-title em { color: var(--caramel); font-style: italic; }
.view-subtitle { font-family: 'Sora', sans-serif !important; font-size: 14px !important; color: var(--muted) !important; font-weight: 300 !important; }

/* ── Dashboard ── */
.db-header { background: var(--cream) !important; border-bottom: 1px solid var(--border) !important; }
.db-greeting-h1 { font-weight: 400 !important; letter-spacing: -0.02em !important; }
.db-greeting-h1 em { color: var(--caramel); font-style: italic; }
.db-greeting-sub { font-family: 'Sora', sans-serif !important; color: var(--muted) !important; font-size: 14px !important; font-weight: 300 !important; }
.db-see-all { font-family: 'Sora', sans-serif !important; color: var(--caramel) !important; font-size: 13px !important; font-weight: 500 !important; background: none !important; border: none !important; cursor: pointer; }
.db-alert-pill {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  box-shadow: var(--shadow) !important;
  border-radius: 12px !important;
}
.db-alert-dot { background: var(--caramel) !important; }
.db-alert-text { font-family: 'Sora', sans-serif !important; font-weight: 500 !important; font-size: 14px !important; color: var(--espresso) !important; }
.db-alert-sub { font-family: 'Sora', sans-serif !important; font-size: 12px !important; color: var(--muted) !important; }

/* ── Discover / user cards ── */
.discover-card, .pv-card, .user-card {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: 14px !important;
  box-shadow: var(--shadow) !important;
}
.discover-card:hover { border-color: var(--border-strong) !important; transform: translateY(-2px); box-shadow: var(--shadow-hover) !important; }

/* Default avatars everywhere */
.pv-av-circle, .nw-av-circle, .discover-av,
div[class*="avatar"]:not([class*="upload"]):not([class*="preview"]),
.ibx-conv-av-inner, .msg-avatar, .chat-event-avatar {
  background: linear-gradient(135deg, #D4894A, #B5651D) !important;
}

/* Interest / hobby tags */
.tag-pill, .pv-chip, .sp-chip.active,
span[style*="background:var(--latte-soft)"],
span[style*="background: var(--latte-soft)"] {
  background: var(--latte-soft) !important;
  color: var(--caramel) !important;
  border: 1px solid rgba(181,101,29,0.15) !important;
  border-radius: 20px !important;
  font-family: 'Sora', sans-serif !important;
  font-size: 12px !important;
  padding: 3px 10px !important;
  font-weight: 400 !important;
}

/* ── Feed / Home post cards ── */
.feed-post-card {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: 14px !important;
  padding: 20px 22px !important;
  margin-bottom: 16px !important;
  box-shadow: var(--shadow) !important;
  transition: border-color 0.15s, box-shadow 0.15s !important;
}
.feed-post-card:hover { border-color: var(--border-strong) !important; }
.post-author-name { font-family: 'Playfair Display', serif !important; font-size: 15px !important; color: var(--espresso) !important; font-weight: 400 !important; }
.post-author-meta { font-family: 'Sora', sans-serif !important; font-size: 12px !important; color: var(--muted-2) !important; }
.post-content { font-family: 'Sora', sans-serif !important; font-size: 14px !important; line-height: 1.7 !important; color: var(--espresso) !important; margin: 12px 0 !important; }
.post-action-btn {
  font-family: 'Sora', sans-serif !important;
  font-size: 13px !important;
  color: var(--muted) !important;
  border: 1px solid var(--border) !important;
  border-radius: 8px !important;
  background: transparent !important;
  padding: 5px 12px !important;
  cursor: pointer !important;
  transition: all 0.15s !important;
}
.post-action-btn:hover { color: var(--caramel) !important; border-color: var(--caramel) !important; }
.post-action-btn.liked { color: var(--caramel) !important; border-color: var(--caramel) !important; background: var(--latte-soft) !important; }

/* ── Home feed section ── */
.home-tab-bar { background: var(--cream) !important; border-bottom: 1px solid var(--border) !important; }
.home-tab { font-family: 'Sora', sans-serif !important; font-size: 13px !important; font-weight: 400 !important; color: var(--muted) !important; }
.home-tab.active { color: var(--caramel) !important; border-bottom-color: var(--caramel) !important; font-weight: 500 !important; }

/* ── Network view ── */
.nw-tab { font-family: 'Sora', sans-serif !important; font-size: 13px !important; font-weight: 400 !important; }
.nw-tab.active { color: var(--caramel) !important; border-bottom-color: var(--caramel) !important; font-weight: 500 !important; }
.nw-stat-val { font-family: 'Playfair Display', serif !important; font-weight: 400 !important; color: var(--caramel) !important; }
.nw-stat-lbl { font-family: 'Sora', sans-serif !important; color: var(--muted) !important; font-size: 12px !important; }
.nw-conn-name { font-family: 'Sora', sans-serif !important; font-weight: 500 !important; color: var(--espresso) !important; }
.nw-conn-role { font-family: 'Sora', sans-serif !important; color: var(--muted) !important; font-size: 12px !important; }

/* ── My Chats (messagesView) ── */
.mc-tab-btn {
  font-family: 'Sora', sans-serif !important;
  font-size: 13px !important;
  color: var(--muted) !important;
  font-weight: 400 !important;
}
.mc-tab-btn.active { color: var(--caramel) !important; border-bottom-color: var(--caramel) !important; font-weight: 500 !important; }
.mc-chat-name { font-family: 'Sora', sans-serif !important; font-size: 14px !important; font-weight: 500 !important; color: var(--espresso) !important; }
.mc-status-badge.pending { background: var(--latte-soft) !important; color: var(--caramel) !important; border: 1px solid rgba(181,101,29,0.2) !important; }
.mc-status-badge.completed { background: #E8F5E9 !important; color: #2E7D32 !important; }
.mc-btn-sm {
  font-family: 'Sora', sans-serif !important;
  font-size: 12px !important;
  border-radius: 7px !important;
  font-weight: 400 !important;
}

/* ── Inbox / Messages ── */
.ibx-conv-panel, .ibx-upcoming-panel {
  background: var(--cream) !important;
  border-color: var(--border) !important;
}
.ibx-conv-header h2 {
  font-family: 'Playfair Display', serif !important;
  font-weight: 400 !important;
  letter-spacing: -0.02em !important;
}
.ibx-conv-name { font-family: 'Sora', sans-serif !important; font-weight: 500 !important; color: var(--espresso) !important; }
.ibx-conv-preview { font-family: 'Sora', sans-serif !important; font-size: 13px !important; color: var(--muted) !important; }
.ibx-conv-time { font-family: 'Sora', sans-serif !important; font-size: 11px !important; color: var(--muted-2) !important; }
.ibx-tab-btn { font-family: 'Sora', sans-serif !important; font-size: 12px !important; font-weight: 400 !important; }
.ibx-tab-btn.active { color: var(--caramel) !important; border-bottom-color: var(--caramel) !important; }
.ibx-ch-name { font-family: 'Playfair Display', serif !important; font-weight: 400 !important; color: var(--espresso) !important; letter-spacing: -0.01em !important; }
.ibx-ch-sub { font-family: 'Sora', sans-serif !important; font-size: 12px !important; color: var(--muted) !important; }
.ibx-input-wrap {
  border: 1px solid var(--border-strong) !important;
  border-radius: 12px !important;
  background: #fff !important;
  box-shadow: var(--shadow) !important;
}
.ibx-input-wrap:focus-within { border-color: var(--caramel) !important; box-shadow: 0 0 0 3px rgba(181,101,29,0.08), var(--shadow) !important; }
.ibx-textarea { font-family: 'Sora', sans-serif !important; font-size: 14px !important; background: transparent !important; border: none !important; }
.ibx-send-btn { background: var(--caramel) !important; border-radius: 9px !important; }
.ibx-send-btn:hover { background: #9A5418 !important; }

/* Message bubbles */
.ibx-msg-bubble {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  font-family: 'Sora', sans-serif !important;
  font-size: 14px !important;
  border-radius: 16px 16px 16px 4px !important;
}
.ibx-msg-bubble.out {
  background: var(--caramel) !important;
  color: #fff !important;
  border-color: var(--caramel) !important;
  border-radius: 16px 16px 4px 16px !important;
}
.ibx-msg-time { font-family: 'Sora', sans-serif !important; font-size: 11px !important; color: var(--muted-2) !important; }

/* ── Settings page ── */
.settings-sidebar { background: var(--cream) !important; border-right: 1px solid var(--border) !important; }
.settings-nav-item { font-family: 'Sora', sans-serif !important; font-size: 13px !important; font-weight: 400 !important; color: var(--muted) !important; }
.settings-nav-item.active { background: var(--latte-soft) !important; color: var(--caramel) !important; border-left-color: var(--caramel) !important; font-weight: 500 !important; }
.settings-nav-item:hover { background: var(--latte-soft) !important; }
.settings-sidebar-label { font-family: 'Sora', sans-serif !important; color: var(--muted-2) !important; }
.settings-nav-divider { background: var(--border) !important; }
.section-desc { font-family: 'Sora', sans-serif !important; color: var(--muted) !important; font-size: 14px !important; font-weight: 300 !important; }
.s-card-header { border-bottom: 1px solid var(--border) !important; }
.s-card-footer { background: var(--cream) !important; border-top: 1px solid var(--border) !important; }
.s-card-title { font-family: 'Sora', sans-serif !important; font-size: 14px !important; font-weight: 500 !important; color: var(--espresso) !important; }
.sp-card-label { border-bottom: 1px solid var(--border) !important; }

/* Status chips in settings */
.sp-chip { font-family: 'Sora', sans-serif !important; font-size: 12px !important; font-weight: 400 !important; }
.sp-chip.active { background: var(--caramel) !important; color: #fff !important; border-color: var(--caramel) !important; }

/* Settings toggle */
.toggle-track { background: var(--border) !important; }
input:checked + .toggle-track { background: var(--caramel) !important; }

/* Privacy pills */
.privacy-option.selected { background: var(--latte-soft) !important; color: var(--caramel) !important; border-color: var(--caramel) !important; }

/* ── Profile page (My Profile) ── */
.mp2-stat div:first-child { color: var(--caramel) !important; font-weight: 400 !important; }
.pv-chip { font-family: 'Sora', sans-serif !important; font-size: 12px !important; font-weight: 400 !important; background: var(--latte-soft) !important; color: var(--caramel) !important; border-radius: 20px !important; padding: 4px 12px !important; }
.pv-chip.caramel { background: var(--latte-soft) !important; color: var(--caramel) !important; }
.pv-chip.open { background: #E8F5E9 !important; color: #2E7D32 !important; border: 1px solid #A9DFBF !important; }

/* ── Communities / Groups ── */
.group-card { padding: 18px 20px !important; }
.group-card h3 { font-family: 'Playfair Display', serif !important; font-weight: 400 !important; color: var(--espresso) !important; letter-spacing: -0.01em !important; }
.industry-pill { background: var(--latte-soft) !important; color: var(--caramel) !important; border-radius: 20px !important; font-family: 'Sora', sans-serif !important; font-size: 11px !important; padding: 2px 10px !important; }
.gv-section-title { font-family: 'Playfair Display', serif !important; font-weight: 400 !important; color: var(--espresso) !important; letter-spacing: -0.01em !important; }

/* ── Toast notifications ── */
.toast { font-family: 'Sora', sans-serif !important; border-radius: 10px !important; font-size: 13px !important; }
.toast.success { background: #E8F5E9 !important; color: #1B5E20 !important; border: 1px solid #A5D6A7 !important; }
.toast.info { background: var(--latte-soft) !important; color: var(--caramel) !important; border: 1px solid rgba(181,101,29,0.2) !important; }
.toast.error { background: #FFF0EE !important; color: #C0392B !important; border: 1px solid #F5C6C2 !important; }
.s-toast { border-radius: 10px !important; font-family: 'Sora', sans-serif !important; font-size: 13px !important; }

/* ── Modals ── */
.modal-content {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: 16px !important;
  box-shadow: 0 8px 40px rgba(28,15,7,0.12) !important;
}
.modal-header { border-bottom: 1px solid var(--border) !important; }
.modal-header h2, .modal-header h3 { font-family: 'Playfair Display', serif !important; font-weight: 400 !important; letter-spacing: -0.02em !important; color: var(--espresso) !important; }

/* ── Auth pages (login/signup) ── */
.auth-container {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: 16px !important;
  box-shadow: var(--shadow) !important;
}
.auth-headline { font-family: 'Playfair Display', serif !important; font-weight: 400 !important; letter-spacing: -0.02em !important; }
.auth-form-input { font-family: 'Sora', sans-serif !important; }

/* ── Schedule modal ── */
.sv-card {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: 16px !important;
  box-shadow: var(--shadow) !important;
}
.sv-card-eyebrow { font-family: 'Sora', sans-serif !important; font-size: 11px !important; letter-spacing: 0.1em !important; color: var(--caramel) !important; text-transform: uppercase !important; }
.sv-card-title { font-family: 'Playfair Display', serif !important; font-weight: 400 !important; letter-spacing: -0.02em !important; color: var(--espresso) !important; }
.sv-form-label { font-family: 'Sora', sans-serif !important; font-size: 12px !important; font-weight: 500 !important; text-transform: uppercase !important; letter-spacing: 0.06em !important; color: var(--muted) !important; }
.sv-input { font-family: 'Sora', sans-serif !important; border: 1px solid rgba(139,90,43,0.18) !important; border-radius: 8px !important; }
.sv-btn { background: var(--caramel) !important; border-radius: 9px !important; font-family: 'Sora', sans-serif !important; font-weight: 500 !important; }
.sv-btn:hover { background: #9A5418 !important; }

/* ── Notification panel ── */
.notification-panel {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  box-shadow: 0 8px 32px rgba(28,15,7,0.10) !important;
}
.notification-panel-header { border-bottom: 1px solid var(--border) !important; }
.notification-panel-header h3 { font-family: 'Playfair Display', serif !important; font-weight: 400 !important; }

/* ── Legal page ── */
.legal-brand { font-family: 'Playfair Display', serif !important; }
.legal-tab { font-family: 'Sora', sans-serif !important; font-size: 13px !important; }
.legal-tab.active { color: var(--caramel) !important; border-bottom-color: var(--caramel) !important; }
.legal-back-btn { font-family: 'Sora', sans-serif !important; }

/* ── Availability view ── */
.av-card { background: var(--surface) !important; border: 1px solid var(--border) !important; border-radius: 14px !important; }
.av-slots-title { font-family: 'Playfair Display', serif !important; font-weight: 400 !important; color: var(--espresso) !important; }

/* ── Calendar (mini) ── */
.mc-cal-month { font-family: 'Sora', sans-serif !important; font-weight: 500 !important; color: var(--espresso) !important; }
.mc-cal-day { font-family: 'Sora', sans-serif !important; font-size: 12px !important; }
.mc-cal-day.today { background: var(--caramel) !important; color: #fff !important; border-radius: 50% !important; }
.mc-cal-day.has-event { color: var(--caramel) !important; font-weight: 500 !important; }

/* ── Profile preview card ── */
.sp-preview-card { border: 1px solid var(--border) !important; border-radius: 14px !important; box-shadow: var(--shadow) !important; overflow: hidden; }
.sp-preview-name { font-family: 'Playfair Display', serif !important; font-weight: 400 !important; letter-spacing: -0.01em !important; }
.sp-preview-headline { font-family: 'Sora', sans-serif !important; font-size: 13px !important; color: var(--muted) !important; }
.sp-preview-school { font-family: 'Sora', sans-serif !important; font-size: 12px !important; color: var(--muted-2) !important; }
.sp-chat-pill { font-family: 'Sora', sans-serif !important; font-size: 12px !important; }

/* ── Achievement items ── */
.ach-card, .ach-item {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: 10px !important;
}

/* ── Scrollbars ── */
::-webkit-scrollbar { width: 4px; height: 4px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(139,90,43,0.15); border-radius: 99px; }
::-webkit-scrollbar-thumb:hover { background: rgba(139,90,43,0.25); }

/* ── Utility ── */
.page-content { max-width: 860px; margin: 0 auto; }


/* ════════════════════════════════════════
   CHAT DETAIL MODAL
   ════════════════════════════════════════ */
.cdm-overlay {
  position: fixed; inset: 0; z-index: 1000;
  background: rgba(28,15,7,0.55);
  display: flex; align-items: center; justify-content: center;
  padding: 20px;
  animation: cdmFadeIn 0.2s ease;
}
@keyframes cdmFadeIn { from { opacity:0 } to { opacity:1 } }

.cdm-card {
  background: #FFFFFF;
  border: 1px solid rgba(139,90,43,0.12);
  border-radius: 18px;
  box-shadow: 0 20px 60px rgba(28,15,7,0.18), 0 4px 16px rgba(28,15,7,0.08);
  width: 100%; max-width: 480px;
  padding: 32px;
  position: relative;
  animation: cdmSlideUp 0.22s cubic-bezier(0.22,1,0.36,1);
}
@keyframes cdmSlideUp { from { opacity:0; transform:translateY(16px) } to { opacity:1; transform:translateY(0) } }

.cdm-close {
  position: absolute; top: 18px; right: 18px;
  width: 32px; height: 32px;
  background: #FAF7F2; border: 1px solid rgba(139,90,43,0.12);
  border-radius: 50%; font-size: 18px; line-height: 1;
  color: #8C7B6E; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all 0.15s;
}
.cdm-close:hover { background: #F5EDE3; color: #B5651D; border-color: rgba(181,101,29,0.25); }

/* Profile row */
.cdm-profile-row {
  display: flex; align-items: center; gap: 16px; margin-bottom: 24px;
}
.cdm-avatar {
  width: 64px; height: 64px; border-radius: 50%; flex-shrink: 0;
  background: linear-gradient(135deg, #D4894A, #B5651D);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Playfair Display', serif; font-size: 22px;
  font-weight: 400; color: #fff; overflow: hidden;
}
.cdm-avatar img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; }
.cdm-profile-info { flex: 1; min-width: 0; }
.cdm-name {
  font-family: 'Playfair Display', serif;
  font-size: 20px; font-weight: 400;
  color: #1C0F07; letter-spacing: -0.02em;
  margin-bottom: 2px;
}
.cdm-role {
  font-family: 'Sora', sans-serif;
  font-size: 13px; color: #8C7B6E; font-weight: 400;
  margin-bottom: 1px;
}
.cdm-school {
  font-family: 'Sora', sans-serif;
  font-size: 12px; color: #B8A898; font-weight: 300;
}
.cdm-status-badge {
  font-family: 'Sora', sans-serif;
  font-size: 11px; font-weight: 500;
  padding: 4px 10px; border-radius: 20px;
  flex-shrink: 0; align-self: flex-start;
}
.cdm-status-badge.today    { background: #FFF3E0; color: #E65100; }
.cdm-status-badge.upcoming { background: #E8F5E9; color: #2E7D32; }
.cdm-status-badge.pending  { background: #F5EDE3; color: #B5651D; }

.cdm-divider { height: 1px; background: rgba(139,90,43,0.10); margin-bottom: 22px; }

/* Details grid */
.cdm-details-grid { display: flex; flex-direction: column; gap: 14px; margin-bottom: 28px; }
.cdm-detail-item { display: flex; align-items: flex-start; gap: 12px; }
.cdm-detail-icon { font-size: 16px; flex-shrink: 0; margin-top: 1px; }
.cdm-detail-label {
  font-family: 'Sora', sans-serif;
  font-size: 11px; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.08em;
  color: #B8A898; margin-bottom: 2px;
}
.cdm-detail-value {
  font-family: 'Sora', sans-serif;
  font-size: 14px; color: #1C0F07; font-weight: 400; line-height: 1.5;
}
.cdm-link {
  color: #B5651D; text-decoration: none; font-weight: 500;
  word-break: break-all;
}
.cdm-link:hover { text-decoration: underline; }

/* Actions */
.cdm-actions {
  display: flex; gap: 8px; flex-wrap: wrap;
}
.cdm-btn {
  flex: 1; min-width: 100px;
  padding: 10px 16px; border-radius: 9px;
  font-family: 'Sora', sans-serif; font-size: 13px; font-weight: 500;
  cursor: pointer; border: none; transition: all 0.15s;
  text-align: center; white-space: nowrap;
}
.cdm-btn-primary {
  background: #B5651D; color: #fff;
}
.cdm-btn-primary:hover { background: #9A5418; box-shadow: 0 4px 12px rgba(181,101,29,0.28); }
.cdm-btn-secondary {
  background: transparent; color: #8C7B6E;
  border: 1px solid rgba(139,90,43,0.22) !important;
}
.cdm-btn-secondary:hover { border-color: #B5651D !important; color: #B5651D; background: #F5EDE3; }
.cdm-btn-danger {
  background: transparent; color: #C0392B;
  border: 1px solid rgba(192,57,43,0.25) !important;
}
.cdm-btn-danger:hover { background: #FFF0EE; border-color: #C0392B !important; }

@media (max-width: 520px) {
  .cdm-card { padding: 24px 20px; }
  .cdm-btn { flex: none; width: 100%; }
  .cdm-actions { flex-direction: column; }
}

/* ── Home feed post avatar — small circle ── */
.post-avatar {
  width: 40px !important;
  height: 40px !important;
  min-width: 40px !important;
  border-radius: 50% !important;
  overflow: hidden !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  color: #fff !important;
  flex-shrink: 0 !important;
}
.post-avatar img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  border-radius: 50% !important;
  display: block !important;
}
.post-header {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  margin-bottom: 12px !important;
}
.post-author-info { flex: 1; min-width: 0; }

/* ── Restore icon-padding for inputs with absolute-positioned icons ──
   The global override uses input:not(...):not(...):not(...):not(...) which
   has specificity (0,4,1) — higher than any class selector. Only ID
   selectors (1,0,0) reliably beat it, so we target each field by ID. ── */
#loginEmail,
#loginPassword,
#signupEmail,
#signupFirstName,
#signupLastName,
#signupPassword {
  padding-left: 40px !important;
}

/* Inbox search bar has a left icon — restore its padding-left */
#inboxSearchInput {
  padding-left: 34px !important;
}

/* Search inputs that use a background-image icon (not absolute-positioned) */
.topbar-search-input,
.ibx-search-input,
.ibx-nm-search {
  padding-left: 34px !important;
}

/* ════════════════════════════════════════════════════════════════════
   DARK MODE OVERRIDES
   These rules flip every hardcoded hex from the design-system override
   block so all components render correctly in dark mode.
   ════════════════════════════════════════════════════════════════════ */

/* ── Core surfaces ── */
[data-theme="dark"] body,
[data-theme="dark"] .main-content,
[data-theme="dark"] #mainContent,
[data-theme="dark"] .content-view,
[data-theme="dark"] .settings-content,
[data-theme="dark"] .settings-shell {
  background: var(--cream) !important;
  color: var(--espresso) !important;
}

/* ── Cards ── */
[data-theme="dark"] .s-card,
[data-theme="dark"] .sp-card,
[data-theme="dark"] .mc-chat-card,
[data-theme="dark"] .group-card,
[data-theme="dark"] .nw-conn-card,
[data-theme="dark"] .db-section,
[data-theme="dark"] .feed-post-card,
[data-theme="dark"] .ibx-up-card,
[data-theme="dark"] .mc-widget,
[data-theme="dark"] .av-card,
[data-theme="dark"] .auth-container,
[data-theme="dark"] .sv-card,
[data-theme="dark"] .modal-content {
  background: var(--card) !important;
  border-color: var(--border) !important;
  color: var(--espresso) !important;
}

/* ── Navigation ── */
[data-theme="dark"] .topbar {
  background: var(--cream) !important;
  border-bottom-color: var(--border) !important;
}
[data-theme="dark"] .mobile-bottom-nav {
  background: var(--cream) !important;
  border-top-color: var(--border) !important;
}
[data-theme="dark"] .main-nav-tab { color: var(--muted) !important; }
[data-theme="dark"] .main-nav-tab:hover,
[data-theme="dark"] .main-nav-tab.active { background: var(--latte-soft) !important; }
[data-theme="dark"] .main-nav-tab.active { color: var(--caramel) !important; }
[data-theme="dark"] .mob-nav-btn { color: var(--muted) !important; }
[data-theme="dark"] .mob-nav-btn.active { color: var(--caramel) !important; }

/* ── Settings sidebar ── */
[data-theme="dark"] .settings-sidebar {
  background: var(--cream) !important;
  border-right-color: var(--border) !important;
}
[data-theme="dark"] .settings-nav-item { color: var(--muted) !important; }
[data-theme="dark"] .settings-nav-item:hover,
[data-theme="dark"] .settings-nav-item.active {
  background: var(--latte-soft) !important;
  color: var(--caramel) !important;
}
[data-theme="dark"] .settings-nav-divider { background: var(--border) !important; }
[data-theme="dark"] .s-card-footer { background: var(--cream) !important; border-top-color: var(--border) !important; }
[data-theme="dark"] .s-card-header { border-bottom-color: var(--border) !important; }

/* ── Form inputs ── */
[data-theme="dark"] input:not([type="checkbox"]):not([type="radio"]):not([type="file"]),
[data-theme="dark"] select,
[data-theme="dark"] textarea,
[data-theme="dark"] .sp-input,
[data-theme="dark"] .form-input,
[data-theme="dark"] .form-select,
[data-theme="dark"] .form-textarea,
[data-theme="dark"] .su-input,
[data-theme="dark"] .auth-form-input {
  background: var(--card) !important;
  color: var(--espresso) !important;
  border-color: var(--border-strong) !important;
}
[data-theme="dark"] input::placeholder,
[data-theme="dark"] textarea::placeholder { color: var(--muted-2) !important; }
[data-theme="dark"] label,
[data-theme="dark"] .sp-label,
[data-theme="dark"] .form-label { color: var(--espresso) !important; }

/* ── Buttons ── */
[data-theme="dark"] .btn-ghost,
[data-theme="dark"] .sp-btn-ghost,
[data-theme="dark"] .btn-secondary,
[data-theme="dark"] .mc-btn-sm.secondary {
  border-color: var(--border-strong) !important;
  color: var(--muted) !important;
}
[data-theme="dark"] .btn-ghost:hover,
[data-theme="dark"] .btn-secondary:hover {
  background: var(--latte-soft) !important;
  color: var(--caramel) !important;
}

/* ── Post cards ── */
[data-theme="dark"] .feed-post-card {
  background: var(--card) !important;
  border-color: var(--border) !important;
}
[data-theme="dark"] .post-author-name { color: var(--espresso) !important; }
[data-theme="dark"] .post-content { color: var(--espresso) !important; }
[data-theme="dark"] .post-author-meta { color: var(--muted-2) !important; }
[data-theme="dark"] .post-actions { border-top-color: var(--border) !important; }
[data-theme="dark"] .post-action-btn {
  color: var(--muted) !important;
  border-color: var(--border) !important;
  background: transparent !important;
}
[data-theme="dark"] .post-action-btn:hover { color: var(--caramel) !important; border-color: var(--caramel) !important; }
[data-theme="dark"] .post-action-btn.liked { background: var(--latte-soft) !important; color: var(--caramel) !important; }

/* ── Tag pills ── */
[data-theme="dark"] .tag-pill,
[data-theme="dark"] .pv-chip {
  background: var(--latte-soft) !important;
  color: var(--caramel) !important;
  border-color: var(--border) !important;
}

/* ── Inbox / messages ── */
[data-theme="dark"] .ibx-conv-panel,
[data-theme="dark"] .ibx-upcoming-panel {
  background: var(--cream) !important;
  border-color: var(--border) !important;
}
[data-theme="dark"] .ibx-conv-row:hover { background: var(--latte-soft) !important; }
[data-theme="dark"] .ibx-conv-row.active { background: var(--latte-soft) !important; }
[data-theme="dark"] .ibx-input-wrap {
  background: var(--card) !important;
  border-color: var(--border-strong) !important;
}
[data-theme="dark"] .ibx-textarea { color: var(--espresso) !important; }
[data-theme="dark"] .ibx-msg-bubble {
  background: var(--card) !important;
  border-color: var(--border) !important;
  color: var(--espresso) !important;
}
[data-theme="dark"] .ibx-conv-name { color: var(--espresso) !important; }
[data-theme="dark"] .ibx-conv-preview { color: var(--muted) !important; }

/* ── My Chats ── */
[data-theme="dark"] .mc-chat-card { background: var(--card) !important; }
[data-theme="dark"] .mc-chat-name { color: var(--espresso) !important; }
[data-theme="dark"] .mc-tabs-bar { border-bottom-color: var(--border) !important; background: var(--cream) !important; }

/* ── Dashboard ── */
[data-theme="dark"] .db-header { background: var(--cream) !important; border-bottom-color: var(--border) !important; }
[data-theme="dark"] .db-alert-pill { background: var(--card) !important; border-color: var(--border) !important; }
[data-theme="dark"] .db-alert-text { color: var(--espresso) !important; }
[data-theme="dark"] .db-alert-sub { color: var(--muted) !important; }

/* ── Groups / communities ── */
[data-theme="dark"] .group-card { background: var(--card) !important; }
[data-theme="dark"] .group-card h3 { color: var(--espresso) !important; }

/* ── Network ── */
[data-theme="dark"] .nw-conn-card { background: var(--card) !important; }
[data-theme="dark"] .nw-conn-name { color: var(--espresso) !important; }
[data-theme="dark"] .nw-conn-role { color: var(--muted) !important; }

/* ── Modals ── */
[data-theme="dark"] .modal-content {
  background: var(--card) !important;
  border-color: var(--border) !important;
}
[data-theme="dark"] .modal-header h2,
[data-theme="dark"] .modal-header h3 { color: var(--espresso) !important; }

/* ── Chat detail modal ── */
[data-theme="dark"] .cdm-card {
  background: var(--card) !important;
  border-color: var(--border) !important;
  box-shadow: 0 20px 60px rgba(0,0,0,0.5), 0 4px 16px rgba(0,0,0,0.3) !important;
}
[data-theme="dark"] .cdm-close {
  background: var(--cream) !important;
  border-color: var(--border) !important;
  color: var(--muted) !important;
}
[data-theme="dark"] .cdm-close:hover { background: var(--latte-soft) !important; }
[data-theme="dark"] .cdm-name { color: var(--espresso) !important; }
[data-theme="dark"] .cdm-role { color: var(--muted) !important; }
[data-theme="dark"] .cdm-school { color: var(--muted-2) !important; }
[data-theme="dark"] .cdm-detail-value { color: var(--espresso) !important; }
[data-theme="dark"] .cdm-detail-label { color: var(--muted-2) !important; }
[data-theme="dark"] .cdm-divider { background: var(--border) !important; }
[data-theme="dark"] .cdm-btn-secondary {
  color: var(--muted) !important;
  border-color: var(--border-strong) !important;
}
[data-theme="dark"] .cdm-btn-secondary:hover {
  color: var(--caramel) !important;
  background: var(--latte-soft) !important;
  border-color: var(--caramel) !important;
}

/* ── Profile page ── */
[data-theme="dark"] .sp-preview-card { background: var(--card) !important; border-color: var(--border) !important; }
[data-theme="dark"] .sp-preview-name { color: var(--espresso) !important; }
[data-theme="dark"] .sp-preview-headline { color: var(--muted) !important; }
[data-theme="dark"] .sp-chip { background: var(--cream) !important; color: var(--muted) !important; border-color: var(--border) !important; }
[data-theme="dark"] .sp-chip.active { background: var(--caramel) !important; color: #fff !important; }

/* ── Toasts ── */
[data-theme="dark"] .toast.success { background: #1B4D2B !important; color: #A5D6A7 !important; border-color: #2E7D32 !important; }
[data-theme="dark"] .toast.info { background: var(--latte-soft) !important; color: var(--caramel) !important; }
[data-theme="dark"] .toast.error { background: #3D1010 !important; color: #F5A0A0 !important; border-color: #C0392B !important; }

/* ── Section headers ── */
[data-theme="dark"] .view-title,
[data-theme="dark"] .section-title { color: var(--espresso) !important; }
[data-theme="dark"] .view-subtitle,
[data-theme="dark"] .section-desc { color: var(--muted) !important; }
[data-theme="dark"] .section-eyebrow,
[data-theme="dark"] .view-eyebrow,
[data-theme="dark"] .db-section-label { color: var(--caramel) !important; }

/* ── Scrollbar in dark ── */
[data-theme="dark"] ::-webkit-scrollbar-thumb { background: rgba(212,137,74,0.2); }
[data-theme="dark"] ::-webkit-scrollbar-thumb:hover { background: rgba(212,137,74,0.35); }


/* ── Network hero: keep dark background in dark mode ── */
[data-theme="dark"] .nw-hero {
  background: #1a1410 !important;
  border-bottom: 1px solid rgba(212,137,74,0.15) !important;
}
[data-theme="dark"] .nw-hero-title { color: #EDE4D4 !important; }
[data-theme="dark"] .nw-hero-title em { color: var(--caramel-light) !important; }
[data-theme="dark"] .nw-hero-sub { color: rgba(237,228,212,0.55) !important; }
[data-theme="dark"] .nw-eyebrow { color: var(--caramel-light) !important; }
[data-theme="dark"] .nw-stat-val { color: var(--caramel) !important; }
[data-theme="dark"] .nw-stat-lbl { color: rgba(237,228,212,0.5) !important; }
[data-theme="dark"] .nw-stat { border-right-color: rgba(212,137,74,0.15) !important; }
[data-theme="dark"] .nw-tabs { background: var(--card) !important; border-bottom-color: var(--border) !important; }
[data-theme="dark"] .nw-tab { color: var(--muted) !important; }
[data-theme="dark"] .nw-tab.active { color: var(--caramel) !important; border-bottom-color: var(--caramel) !important; }
[data-theme="dark"] .nw-content { background: var(--cream) !important; }

/* ════════════════════════════════════════════════════════════════════
   MY PROFILE — mpn-* component system (new design)
   ════════════════════════════════════════════════════════════════════ */
@keyframes mpnFillBar { from { width:0% } to { width:100%; } }

.mpn-page { padding: 0; }

/* ── Hero card ── */
.mpn-hero {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 18px;
  overflow: hidden;
  margin-bottom: 20px;
  box-shadow: var(--shadow);
}
.mpn-cover {
  height: 100px;
  position: relative;
  cursor: pointer;
  transition: filter 0.15s;
}
.mpn-cover:hover { filter: brightness(0.92); }

.mpn-hero-body { padding: 0 28px 24px; }

.mpn-avatar-row {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: 16px;
}

.mpn-avatar-wrap { margin-top: -40px; position: relative; flex-shrink: 0; }

.mpn-avatar {
  width: 84px; height: 84px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--caramel-light), var(--caramel));
  border: 3px solid #fff;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Playfair Display', serif;
  font-size: 28px; font-weight: 400; color: #fff;
  cursor: pointer; overflow: hidden;
  box-shadow: 0 2px 10px rgba(28,15,7,0.15);
  transition: opacity 0.15s;
}
.mpn-avatar:hover { opacity: 0.88; }
.mpn-avatar img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; }

.mpn-avatar-edit {
  position: absolute; bottom: 2px; right: 2px;
  width: 22px; height: 22px;
  background: var(--caramel);
  border: 2px solid #fff; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; pointer-events: none;
}

.mpn-hero-actions { display: flex; gap: 8px; flex-wrap: wrap; padding-top: 10px; }

.mpn-name {
  font-family: 'Playfair Display', serif;
  font-size: 26px; font-weight: 400;
  color: var(--espresso); letter-spacing: -0.02em; margin-bottom: 4px;
}
.mpn-headline {
  font-family: 'Sora', sans-serif;
  font-size: 14px; color: var(--muted); line-height: 1.5; margin-bottom: 12px;
}
.mpn-meta {
  display: flex; flex-wrap: wrap; gap: 14px; margin-bottom: 16px;
}
.mpn-meta-item {
  display: flex; align-items: center; gap: 5px;
  font-family: 'Sora', sans-serif; font-size: 13px; color: var(--muted);
}
.mpn-meta-item svg { flex-shrink: 0; stroke: var(--muted-2); }

.mpn-stat-row {
  display: flex; gap: 24px;
  padding-top: 16px;
  border-top: 1px solid var(--border);
}
.mpn-stat-item { cursor: pointer; }
.mpn-stat-num {
  font-family: 'Playfair Display', serif;
  font-size: 20px; font-weight: 400;
  color: var(--espresso); letter-spacing: -0.02em;
}
.mpn-stat-label {
  font-family: 'Sora', sans-serif;
  font-size: 11.5px; color: var(--muted); margin-top: 1px;
}
.mpn-stat-item:hover .mpn-stat-num { color: var(--caramel); }

/* ══ Profile 3-tab structure (mpv-*) ══ */
.mpv-stats-strip {
  display: flex; border-top: 1px solid var(--border);
}
.mpv-strip-stat {
  flex: 1; padding: 12px 16px; text-align: left;
  border-right: 1px solid var(--border);
  border-top: none; border-bottom: none; border-left: none;
  background: none; cursor: pointer; font-family: 'Sora', sans-serif;
  transition: background 0.15s;
}
.mpv-strip-stat:last-child { border-right: none; }
.mpv-strip-stat:hover { background: var(--latte-soft); }
.mpv-strip-num {
  font-family: 'Playfair Display', serif;
  font-size: 18px; font-weight: 400;
  color: var(--caramel); letter-spacing: -0.02em;
}
.mpv-strip-label { font-size: 11px; color: var(--muted); margin-top: 2px; }

.mpv-tab-nav {
  display: flex; border-top: 1px solid var(--border);
  padding: 0 28px; background: #fff;
}
.mpv-tab {
  padding: 13px 16px; font-size: 13px; font-weight: 400;
  color: var(--muted); cursor: pointer;
  border-bottom: 2px solid transparent; margin-bottom: -1px;
  border-top: none; border-left: none; border-right: none;
  background: none; font-family: 'Sora', sans-serif; transition: all 0.15s;
}
.mpv-tab:hover { color: var(--espresso); }
.mpv-tab.active { color: var(--caramel); border-bottom-color: var(--caramel); font-weight: 500; }

.mpv-tab-content { display: none; padding-top: 24px; animation: mpvFadeIn 0.2s ease; }
.mpv-tab-content.active { display: block; }
@keyframes mpvFadeIn { from { opacity:0; transform:translateY(4px); } to { opacity:1; transform:translateY(0); } }

.mpv-info-row {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 7px 0; border-bottom: 1px solid var(--border);
}
.mpv-info-row:last-child { border-bottom: none; }
.mpv-info-label {
  font-size: 11px; font-weight: 500; text-transform: uppercase;
  letter-spacing: 0.06em; color: var(--muted); min-width: 76px; flex-shrink: 0; margin-top: 2px;
}
.mpv-info-val { font-size: 13px; color: var(--espresso); line-height: 1.5; }

/* ── Two-column layout ── */
.mpn-two-col {
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: 20px;
  align-items: start;
}

/* ── Main cards ── */
.mpn-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 14px;
  margin-bottom: 20px;
  box-shadow: var(--shadow);
  overflow: hidden;
  transition: border-color 0.15s;
}
.mpn-card:hover { border-color: var(--border-strong); }

.mpn-card-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 22px 0; margin-bottom: 14px;
}
.mpn-card-title {
  font-family: 'Playfair Display', serif;
  font-size: 16px; font-weight: 400;
  color: var(--espresso); letter-spacing: -0.01em;
}
.mpn-card-body { padding: 0 22px 20px; }

.mpn-card-edit {
  width: 30px; height: 30px;
  border-radius: 7px;
  border: 1px solid var(--border-strong);
  background: none; display: flex; align-items: center; justify-content: center;
  cursor: pointer; color: var(--muted); font-size: 12px;
  font-family: 'Sora', sans-serif; font-weight: 500;
  transition: all 0.15s;
}
.mpn-card-edit:hover { background: var(--latte-soft); color: var(--caramel); border-color: var(--caramel); }

/* ── Text content ── */
.mpn-about-text {
  font-family: 'Sora', sans-serif;
  font-size: 14px; color: var(--espresso); line-height: 1.75;
}
.mpn-empty-text {
  font-family: 'Sora', sans-serif;
  font-size: 13.5px; color: var(--muted); font-style: italic;
}

/* ── Goals ── */
.mpn-goal-item {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 10px 0; border-bottom: 1px solid var(--border);
}
.mpn-goal-item:last-child { border-bottom: none; padding-bottom: 0; }
.mpn-goal-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--caramel); flex-shrink: 0; margin-top: 5px;
}
.mpn-goal-text {
  font-family: 'Sora', sans-serif;
  font-size: 14px; color: var(--espresso); line-height: 1.55;
}

/* ── Experience ── */
.mpn-exp-item {
  display: flex; gap: 14px;
  padding: 12px 0; border-bottom: 1px solid var(--border);
}
.mpn-exp-item:last-child { border-bottom: none; padding-bottom: 0; }
.mpn-exp-logo {
  width: 40px; height: 40px;
  border-radius: 10px; background: var(--latte-soft);
  border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; flex-shrink: 0;
}
.mpn-exp-info { flex: 1; }
.mpn-exp-role { font-family: 'Sora', sans-serif; font-size: 14px; font-weight: 500; color: var(--espresso); }
.mpn-exp-company { font-family: 'Sora', sans-serif; font-size: 13px; color: var(--muted); margin-top: 2px; }
.mpn-exp-date { font-family: 'Sora', sans-serif; font-size: 12px; color: var(--muted-2); margin-top: 3px; }
.mpn-exp-desc { font-family: 'Sora', sans-serif; font-size: 13px; color: var(--espresso); line-height: 1.5; margin-top: 6px; }

/* ── Tags ── */
.mpn-tags-label {
  font-family: 'Sora', sans-serif;
  font-size: 11px; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.07em;
  color: var(--muted-2); margin-bottom: 8px;
}
.mpn-tags-wrap { display: flex; flex-wrap: wrap; gap: 7px; }
.mpn-tag {
  display: inline-flex; align-items: center;
  padding: 4px 12px;
  background: var(--latte-soft); border: 1px solid var(--border);
  border-radius: 20px; font-family: 'Sora', sans-serif;
  font-size: 13px; color: var(--brown);
  transition: all 0.15s; cursor: default;
}
.mpn-tag:hover { border-color: var(--border-strong); }
.mpn-tag.mpn-tag-interest {
  background: var(--latte-soft); border-color: rgba(181,101,29,0.18); color: var(--caramel);
}

/* ── Profile strength ── */
.mpn-strength-bar-wrap { margin-bottom: 8px; }
.mpn-strength-label {
  display: flex; justify-content: space-between;
  font-family: 'Sora', sans-serif; font-size: 12px; color: var(--muted); margin-bottom: 6px;
}
.mpn-strength-pct { color: var(--caramel); font-weight: 500; }
.mpn-bar-track { height: 5px; background: var(--latte-soft); border-radius: 3px; overflow: hidden; }
.mpn-bar-fill { height: 100%; background: linear-gradient(90deg, var(--caramel-light), var(--caramel)); border-radius: 3px; }
.mpn-strength-tip { font-family: 'Sora', sans-serif; font-size: 12.5px; color: var(--muted); margin-top: 8px; line-height: 1.55; }
.mpn-strength-tip strong { color: var(--caramel); }

/* ── Resume ── */
.mpn-resume-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.mpn-resume-info { display: flex; align-items: center; gap: 10px; }
.mpn-resume-icon {
  width: 36px; height: 36px; border-radius: 8px;
  background: var(--latte-soft); border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center; font-size: 18px;
}
.mpn-resume-name { font-family: 'Sora', sans-serif; font-size: 13.5px; font-weight: 500; color: var(--espresso); }
.mpn-resume-sub { font-family: 'Sora', sans-serif; font-size: 12px; color: var(--muted-2); margin-top: 1px; }

/* ── Buttons ── */
.mpn-btn-primary {
  display: flex; align-items: center; gap: 6px;
  padding: 8px 18px; background: var(--caramel); color: #fff;
  border: none; border-radius: 9px;
  font-family: 'Sora', sans-serif; font-size: 13px; font-weight: 500;
  cursor: pointer; transition: background 0.15s;
  white-space: nowrap;
}
.mpn-btn-primary:hover { background: #9A5418; }
.mpn-btn-ghost {
  display: flex; align-items: center; gap: 6px;
  padding: 8px 16px; background: transparent; color: var(--muted);
  border: 1px solid var(--border-strong); border-radius: 9px;
  font-family: 'Sora', sans-serif; font-size: 13px; font-weight: 400;
  cursor: pointer; transition: all 0.15s;
  white-space: nowrap;
}
.mpn-btn-ghost:hover { border-color: var(--caramel); color: var(--caramel); }

/* ── Sidebar cards ── */
.mpn-sidebar-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 14px;
  margin-bottom: 16px;
  box-shadow: var(--shadow);
  overflow: hidden;
}
.mpn-sidebar-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 18px 0; margin-bottom: 12px;
}
.mpn-sidebar-title {
  font-family: 'Playfair Display', serif;
  font-size: 15px; font-weight: 400;
  color: var(--espresso); letter-spacing: -0.01em;
}
.mpn-sidebar-body { padding: 0 18px 16px; }

/* ── Availability ── */
.mpn-avail-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 7px 0; border-bottom: 1px solid var(--border);
  font-family: 'Sora', sans-serif; font-size: 13px;
}
.mpn-avail-row:last-child { border-bottom: none; }
.mpn-avail-day { color: var(--muted); }
.mpn-avail-time { color: var(--espresso); font-weight: 500; font-size: 12.5px; }
.mpn-avail-off { color: var(--muted-2); font-style: italic; font-size: 12.5px; }

/* ── Connections grid ── */
.mpn-conn-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
.mpn-conn-item {
  display: flex; flex-direction: column; align-items: center; gap: 5px; cursor: pointer;
}
.mpn-conn-av {
  width: 44px; height: 44px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Sora', sans-serif; font-size: 13px; font-weight: 500; color: #fff;
  overflow: hidden; transition: transform 0.15s;
}
.mpn-conn-item:hover .mpn-conn-av { transform: scale(1.07); }
.mpn-conn-name {
  font-family: 'Sora', sans-serif;
  font-size: 10px; color: var(--muted); text-align: center; line-height: 1.3;
}

/* ══════════════════════════════════════════
   MY NETWORK SECTION v2  (mn2-*)
   ══════════════════════════════════════════ */

/* Stats card — 4-cell grid */
.mn2-stats-card {
  background: #fff;
  border: 1px solid rgba(139,90,43,0.11);
  border-radius: 14px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  overflow: hidden;
  margin-bottom: 18px;
  box-shadow: 0 1px 3px rgba(28,15,7,0.04), 0 4px 16px rgba(28,15,7,0.03);
}
.mn2-stat-cell {
  padding: 16px 18px;
  border-right: 1px solid rgba(139,90,43,0.11);
  cursor: default;
  transition: background 0.15s;
}
.mn2-stat-cell:last-child { border-right: none; }
.mn2-stat-cell:hover { background: var(--latte-soft); }
.mn2-stat-eyebrow {
  font-size: 10px; font-weight: 500; text-transform: uppercase;
  letter-spacing: 0.09em; color: var(--muted); margin-bottom: 5px;
}
.mn2-stat-num {
  font-family: 'Playfair Display', serif;
  font-size: 26px; font-weight: 400; color: var(--caramel);
  letter-spacing: -0.03em; line-height: 1; margin-bottom: 4px;
}
.mn2-stat-sub { font-size: 11px; color: var(--muted); }

/* Two-column layout */
.mn2-two-col {
  display: grid;
  grid-template-columns: 1fr 292px;
  gap: 18px;
  align-items: start;
}

/* Section card (connections list) */
.mn2-section-card {
  background: #fff;
  border: 1px solid rgba(139,90,43,0.11);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 1px 3px rgba(28,15,7,0.04), 0 4px 16px rgba(28,15,7,0.03);
}
.mn2-section-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 18px; border-bottom: 1px solid rgba(139,90,43,0.09);
}
.mn2-section-title { font-size: 14px; font-weight: 500; color: var(--espresso); }

/* Search row */
.mn2-search-row {
  padding: 10px 16px;
  border-bottom: 1px solid rgba(139,90,43,0.09);
}
.mn2-search-inner { position: relative; }
.mn2-search-inner svg {
  position: absolute; left: 10px; top: 50%; transform: translateY(-50%);
  width: 14px; height: 14px; stroke: var(--muted); pointer-events: none;
}
.mn2-search-inner input {
  width: 100%; padding: 8px 10px 8px 32px;
  border: 1px solid var(--border-strong); border-radius: 8px;
  font-size: 13px; font-family: 'Sora', sans-serif;
  background: var(--latte-soft); color: var(--espresso); outline: none;
  transition: border-color 0.15s, background 0.15s;
}
.mn2-search-inner input::placeholder { color: var(--muted); }
.mn2-search-inner input:focus { border-color: var(--caramel); background: #fff; }

/* Connection list items */
.mn2-conn-list { }
.mn2-conn-item {
  display: flex; align-items: center; gap: 12px;
  padding: 11px 18px; cursor: pointer;
  border-bottom: 1px solid rgba(139,90,43,0.07);
  transition: background 0.12s;
}
.mn2-conn-item:last-child { border-bottom: none; }
.mn2-conn-item:hover { background: var(--latte-soft); }
.mn2-conn-av {
  width: 44px; height: 44px; border-radius: 50%; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 15px; font-weight: 600; color: #fff; overflow: hidden;
  background: linear-gradient(135deg,#D4894A,#B5651D);
}
.mn2-conn-info { flex: 1; min-width: 0; }
.mn2-conn-name { font-size: 14px; font-weight: 500; color: var(--espresso); }
.mn2-conn-role { font-size: 12px; color: var(--muted); margin-top: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mn2-conn-note {
  font-size: 12px; color: var(--muted); margin-top: 4px; font-style: italic;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.mn2-conn-actions { display: flex; gap: 6px; flex-shrink: 0; }
.mn2-btn-msg {
  padding: 6px 12px; background: var(--caramel); color: #fff;
  border: none; border-radius: 7px; font-size: 12px; font-weight: 500;
  cursor: pointer; font-family: 'Sora', sans-serif; transition: background 0.15s;
}
.mn2-btn-msg:hover { background: #9A5418; }
.mn2-btn-chat {
  padding: 6px 10px; background: transparent; color: var(--muted);
  border: 1px solid var(--border-strong); border-radius: 7px; font-size: 13px;
  cursor: pointer; font-family: 'Sora', sans-serif; transition: all 0.15s;
}
.mn2-btn-chat:hover { border-color: var(--caramel); color: var(--caramel); }

.mn2-empty-state { padding: 36px 20px; text-align: center; }

/* Right sidebar */
.mn2-sidebar { display: flex; flex-direction: column; gap: 14px; }
.mn2-sidebar-card {
  background: #fff; border: 1px solid rgba(139,90,43,0.11);
  border-radius: 14px; overflow: hidden;
  box-shadow: 0 1px 3px rgba(28,15,7,0.04), 0 4px 16px rgba(28,15,7,0.03);
}
.mn2-sidebar-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 13px 14px; border-bottom: 1px solid rgba(139,90,43,0.09);
}
.mn2-sidebar-title { font-size: 13px; font-weight: 500; color: var(--espresso); }
.mn2-sidebar-body { padding: 10px 14px; }
.mn2-pending-badge {
  font-size: 10px; font-weight: 600; background: #FAECE7; color: #993C1D;
  padding: 2px 7px; border-radius: 10px; letter-spacing: 0;
}

/* Pending request items */
.mn2-pending-item {
  padding: 10px 0; border-bottom: 1px solid rgba(139,90,43,0.09);
  transition: opacity 0.3s, transform 0.3s;
}
.mn2-pending-item:last-child { border-bottom: none; padding-bottom: 0; }
.mn2-pending-top { display: flex; align-items: center; gap: 9px; margin-bottom: 7px; }
.mn2-pending-av {
  width: 34px; height: 34px; border-radius: 50%; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 600; color: #fff; overflow: hidden;
}
.mn2-pending-name { font-size: 13px; font-weight: 500; color: var(--espresso); }
.mn2-pending-role { font-size: 11px; color: var(--muted); margin-top: 1px; }
.mn2-pending-note {
  font-size: 12px; color: var(--muted); line-height: 1.5; margin-bottom: 8px;
  padding: 6px 8px; background: var(--latte-soft); border-radius: 6px;
  border-left: 2px solid var(--caramel); font-style: italic;
}
.mn2-pending-btns { display: flex; gap: 6px; }
.mn2-btn-accept {
  flex: 1; padding: 7px 0; background: var(--caramel); color: #fff;
  border: none; border-radius: 7px; font-size: 12px; font-weight: 500;
  cursor: pointer; font-family: 'Sora', sans-serif; transition: background 0.15s; text-align: center;
}
.mn2-btn-accept:hover { background: #9A5418; }
.mn2-btn-decline {
  flex: 1; padding: 7px 0; background: transparent; color: var(--muted);
  border: 1px solid var(--border-strong); border-radius: 7px; font-size: 12px;
  cursor: pointer; font-family: 'Sora', sans-serif; transition: all 0.15s; text-align: center;
}
.mn2-btn-decline:hover { border-color: #C0392B; color: #C0392B; }
.mn2-no-pending { padding: 14px 0; text-align: center; font-size: 12px; color: var(--muted); }

/* People you may know */
.mn2-suggest-item {
  display: flex; align-items: center; gap: 9px; padding: 8px 0;
  border-bottom: 1px solid rgba(139,90,43,0.07);
}
.mn2-suggest-item:last-of-type { border-bottom: none; }
.mn2-suggest-av {
  width: 32px; height: 32px; border-radius: 50%; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 10px; font-weight: 600; color: #fff; overflow: hidden;
}
.mn2-suggest-name { font-size: 13px; font-weight: 500; color: var(--espresso); }
.mn2-suggest-role { font-size: 11px; color: var(--muted); margin-top: 1px; }
.mn2-btn-connect {
  padding: 5px 10px; background: #F5EDE3; color: var(--caramel);
  border: 1px solid rgba(181,101,29,0.2); border-radius: 6px;
  font-size: 11px; font-weight: 500; cursor: pointer; white-space: nowrap;
  font-family: 'Sora', sans-serif; transition: all 0.15s;
}
.mn2-btn-connect:hover { background: var(--caramel); color: #fff; }
.mn2-btn-connect:disabled { opacity: 0.6; cursor: default; }

/* Recent activity */
.mn2-act-item {
  display: flex; gap: 9px; padding: 8px 0;
  border-bottom: 1px solid rgba(139,90,43,0.07);
  font-size: 12px; color: var(--muted); line-height: 1.5;
}
.mn2-act-item:last-child { border-bottom: none; }
.mn2-act-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--caramel); flex-shrink: 0; margin-top: 5px;
}
.mn2-act-name { font-weight: 500; color: var(--espresso); }
.mn2-act-time { font-size: 11px; color: var(--muted); margin-top: 2px; }

@media (max-width: 720px) {
  .mn2-two-col { grid-template-columns: 1fr; }
  .mn2-stats-card { grid-template-columns: repeat(2, 1fr); }
  .mn2-stat-cell:nth-child(2) { border-right: none; }
  .mn2-stat-cell:nth-child(3) { border-top: 1px solid rgba(139,90,43,0.11); border-right: none; }
}

/* ── Keep old mn-* vars for any legacy references ── */
.mn-card {
  background: #fff;
  border: 1px solid rgba(139,90,43,0.11);
  border-radius: 16px;
  padding: 24px 28px 28px;
  box-shadow: 0 1px 3px rgba(28,15,7,0.04), 0 4px 16px rgba(28,15,7,0.03);
}

/* Stats bar */
.mn-stats-bar {
  display: flex; align-items: stretch;
  background: var(--latte-soft);
  border-radius: 12px;
  overflow: hidden;
  margin-bottom: 28px;
}
.mn-stat {
  flex: 1; padding: 16px 12px; text-align: center;
}
.mn-stat-num {
  font-family: 'Playfair Display', serif;
  font-size: 22px; font-weight: 400;
  color: var(--caramel); letter-spacing: -0.02em;
  line-height: 1;
}
.mn-stat-label {
  font-size: 10px; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.09em;
  color: var(--muted); margin-top: 5px;
}
.mn-stat-divider {
  width: 1px; background: rgba(139,90,43,0.14);
  margin: 12px 0;
}

/* Section heads */
.mn-section-head {
  display: flex; align-items: center; gap: 8px;
  font-size: 11px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.08em;
  color: var(--muted); margin-bottom: 14px;
}
.mn-badge {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 18px; height: 18px; padding: 0 5px;
  background: var(--caramel); color: #fff;
  border-radius: 10px; font-size: 10px; font-weight: 600;
  letter-spacing: 0;
}

/* Connections grid */
.mn-conn-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(88px, 1fr));
  gap: 12px;
}
.mn-conn-card {
  display: flex; flex-direction: column; align-items: center;
  gap: 7px; padding: 14px 8px;
  background: #fff; border: 1px solid rgba(139,90,43,0.11);
  border-radius: 12px; cursor: pointer;
  transition: all 0.15s;
  box-shadow: 0 1px 3px rgba(28,15,7,0.04);
  text-align: center;
}
.mn-conn-card:hover {
  border-color: rgba(181,101,29,0.28);
  transform: translateY(-2px);
  box-shadow: 0 4px 14px rgba(28,15,7,0.08);
}
.mn-av {
  width: 44px; height: 44px; border-radius: 50%; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 14px; font-weight: 600; color: #fff; overflow: hidden;
  background: linear-gradient(135deg,#D4894A,#B5651D);
}
.mn-av-sm { width: 40px; height: 40px; font-size: 12px; }
.mn-conn-name {
  font-size: 12px; font-weight: 500; color: var(--espresso);
  line-height: 1.3; word-break: break-word;
}
.mn-conn-sub {
  font-size: 11px; color: var(--muted); line-height: 1.3;
}

/* Pending requests */
.mn-pending-row {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 0; border-bottom: 1px solid rgba(139,90,43,0.09);
  transition: opacity 0.3s;
}
.mn-pending-row:last-child { border-bottom: none; padding-bottom: 0; }
.mn-pending-info { flex: 1; min-width: 0; }
.mn-pending-name {
  font-size: 13px; font-weight: 500; color: var(--espresso);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.mn-pending-sub { font-size: 11px; color: var(--muted); margin-top: 1px; }
.mn-pending-note {
  font-size: 12px; color: var(--brown); font-style: italic;
  margin-top: 3px; line-height: 1.4;
}
.mn-pending-actions { display: flex; gap: 6px; flex-shrink: 0; }
.mn-btn-accept {
  padding: 6px 14px; background: var(--caramel); color: #fff;
  border: none; border-radius: 7px; font-size: 12px; font-weight: 500;
  cursor: pointer; font-family: 'Sora', sans-serif; transition: background 0.15s;
}
.mn-btn-accept:hover { background: #9A5418; }
.mn-btn-decline {
  padding: 6px 14px; background: transparent; color: var(--muted);
  border: 1px solid rgba(139,90,43,0.2); border-radius: 7px;
  font-size: 12px; cursor: pointer; font-family: 'Sora', sans-serif;
  transition: all 0.15s;
}
.mn-btn-decline:hover { border-color: #C0392B; color: #C0392B; }

.mn-empty {
  font-size: 13px; color: var(--muted); font-style: italic;
  padding: 4px 0; margin: 0;
}

@media (max-width: 560px) {
  .mn-conn-grid { grid-template-columns: repeat(auto-fill, minmax(72px, 1fr)); }
  .mn-card { padding: 18px 16px 22px; }
}

/* ── My Network — Reviews (inside sidebar card) ── */
.mn2-reviews-rating {
  font-size: 12px; color: var(--caramel); font-weight: 400; margin-left: 4px;
}
.mn2-reviews-count { font-size: 11px; color: var(--muted); }
.mn2-review-item {
  padding: 12px 0; border-bottom: 1px solid rgba(139,90,43,0.07);
}
.mn2-review-item:last-of-type { border-bottom: none; }
.mn2-review-header {
  display: flex; align-items: center; gap: 8px; margin-bottom: 5px;
}
.mn2-review-stars { color: var(--caramel); font-size: 13px; letter-spacing: 1px; }
.mn2-review-date  { font-size: 11px; color: var(--muted); }
.mn2-review-text  { font-size: 13px; color: var(--espresso); line-height: 1.6; font-style: italic; }
.mn2-review-anon  { font-size: 11px; color: var(--muted); margin-top: 4px; }
.mn2-reviews-see-all {
  padding: 12px 0 4px;
  font-size: 13px; font-weight: 500; color: var(--caramel);
  cursor: pointer; transition: opacity 0.15s;
}
.mn2-reviews-see-all:hover { opacity: 0.75; }

/* ── Communities ── */
.mpn-community-item {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 0; border-bottom: 1px solid var(--border);
  cursor: pointer; transition: all 0.15s;
}
.mpn-community-item:last-child { border-bottom: none; padding-bottom: 0; }
.mpn-community-item:hover .mpn-community-name { color: var(--caramel); }
.mpn-community-icon {
  width: 34px; height: 34px; border-radius: 9px;
  background: var(--latte-soft); border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center; font-size: 16px; flex-shrink: 0;
}
.mpn-community-name { font-family: 'Sora', sans-serif; font-size: 13px; font-weight: 500; color: var(--espresso); }
.mpn-community-sub { font-family: 'Sora', sans-serif; font-size: 11px; color: var(--muted); margin-top: 1px; }

/* ── Dark mode ── */
[data-theme="dark"] .mpn-hero,
[data-theme="dark"] .mpn-card,
[data-theme="dark"] .mpn-sidebar-card { background: var(--card) !important; border-color: var(--border) !important; }
[data-theme="dark"] .mpn-name,
[data-theme="dark"] .mpn-stat-num,
[data-theme="dark"] .mpn-card-title,
[data-theme="dark"] .mpn-sidebar-title,
[data-theme="dark"] .mpn-exp-role,
[data-theme="dark"] .mpn-resume-name,
[data-theme="dark"] .mpn-about-text,
[data-theme="dark"] .mpn-goal-text { color: var(--espresso) !important; }
[data-theme="dark"] .mpn-headline,
[data-theme="dark"] .mpn-meta-item,
[data-theme="dark"] .mpn-stat-label,
[data-theme="dark"] .mpn-strength-tip,
[data-theme="dark"] .mpn-exp-company,
[data-theme="dark"] .mpn-avail-day { color: var(--muted) !important; }
[data-theme="dark"] .mpn-card-header,
[data-theme="dark"] .mpn-goal-item,
[data-theme="dark"] .mpn-exp-item,
[data-theme="dark"] .mpn-avail-row,
[data-theme="dark"] .mpn-community-item,
[data-theme="dark"] .mpn-stat-row { border-color: var(--border) !important; }
[data-theme="dark"] .mpn-exp-logo,
[data-theme="dark"] .mpn-resume-icon,
[data-theme="dark"] .mpn-community-icon,
[data-theme="dark"] .mpn-tag { background: var(--latte-soft) !important; border-color: var(--border) !important; }
[data-theme="dark"] .mpn-bar-track { background: var(--latte-soft) !important; }
[data-theme="dark"] .mpn-avail-time { color: var(--espresso) !important; }

/* ── Responsive ── */
@media (max-width: 700px) {
  .mpn-two-col { grid-template-columns: 1fr; }
  .mpn-hero-actions { flex-wrap: wrap; }
  .mpn-stat-row { gap: 16px; }
  .mpn-conn-grid { grid-template-columns: repeat(4, 1fr); }
}

/* ── Profile hero: gear button (top-right) + actions below name ── */
.mpn-hero { position: relative; }

.mpn-gear-btn {
  position: absolute;
  top: 14px; right: 14px;
  z-index: 10;
  width: 34px; height: 34px;
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,0.35);
  background: rgba(255,255,255,0.18);
  backdrop-filter: blur(4px);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; color: #fff;
  transition: all 0.15s;
}
.mpn-gear-btn:hover {
  background: rgba(255,255,255,0.32);
  border-color: rgba(255,255,255,0.6);
}
.mpn-gear-btn svg { stroke: #fff; flex-shrink: 0; }

/* After cover strip, avatar row no longer has action buttons on the right */
.mpn-avatar-row { margin-bottom: 12px; }

/* Action buttons sit below name+headline, flush left */
.mpn-hero-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 14px;
  margin-bottom: 16px;
}

/* ── Chat invite note displayed on received invite card ── */
.mc-invite-note {
  font-size: 12.5px;
  color: var(--espresso);
  font-style: italic;
  background: var(--latte-soft);
  border-left: 3px solid var(--caramel);
  border-radius: 0 6px 6px 0;
  padding: 5px 10px;
  margin-top: 6px;
  line-height: 1.5;
}

/* ── Pending chat invite cards in inbox sidebar ── */
.ibx-pending-section { border-bottom: 1px solid var(--border); }

.ibx-invite-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 12px;
  margin: 0 12px 8px;
  box-shadow: var(--shadow);
}

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

.ibx-invite-av {
  width: 36px; height: 36px; border-radius: 50%; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; font-weight: 600; color: #fff; overflow: hidden;
}

.ibx-invite-info { flex: 1; min-width: 0; }
.ibx-invite-name  { font-family: 'Sora', sans-serif; font-size: 13px; font-weight: 600; color: var(--espresso); }
.ibx-invite-meta  { font-family: 'Sora', sans-serif; font-size: 11px; color: var(--muted); margin-top: 1px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

.ibx-invite-note {
  font-family: 'Sora', sans-serif;
  font-size: 12px; color: var(--espresso); font-style: italic;
  background: var(--latte-soft);
  border-left: 3px solid var(--caramel);
  border-radius: 0 6px 6px 0;
  padding: 5px 8px; margin-bottom: 6px; line-height: 1.5;
}

.ibx-invite-time {
  font-family: 'Sora', sans-serif;
  font-size: 11px; color: var(--muted); margin-bottom: 8px;
}

.ibx-invite-details {
  display: flex; flex-direction: column; gap: 3px;
  margin-bottom: 8px;
}
.ibx-invite-detail-row {
  font-family: 'Sora', sans-serif;
  font-size: 12px; color: var(--brown); line-height: 1.4;
}

/* Availability hint — used in invite modal (sender) and invite card (receiver) */
.avail-hint {
  display: flex; align-items: center; gap: 6px;
  font-family: 'Sora', sans-serif; font-size: 12px;
  color: var(--muted); margin-top: 6px; min-height: 18px;
}
.avail-hint--card {
  margin-top: 4px; margin-bottom: 6px;
}
.avail-hint-dot {
  display: inline-block; width: 7px; height: 7px;
  border-radius: 50%; flex-shrink: 0;
}

.ibx-invite-actions { display: flex; gap: 6px; }

.ibx-inv-btn {
  flex: 1; padding: 5px 8px; border-radius: 6px;
  font-size: 12px; font-weight: 500; cursor: pointer;
  font-family: 'Sora', sans-serif; border: none; transition: all 0.15s;
}
.ibx-inv-btn.accept  { background: var(--caramel); color: #fff; }
.ibx-inv-btn.accept:hover  { background: #9A5418; }
.ibx-inv-btn.decline { background: var(--latte-soft); color: var(--muted); border: 1px solid var(--border); }
.ibx-inv-btn.decline:hover { color: #C0392B; border-color: rgba(192,57,43,0.3); }

/* ── Notification panel: inline invite actions ── */
.notif-invite-actions { display: flex; gap: 6px; margin-top: 8px; }

.notif-inv-btn {
  padding: 4px 12px; border-radius: 6px;
  font-size: 12px; font-weight: 500; cursor: pointer;
  font-family: 'Sora', sans-serif; border: none; transition: all 0.15s;
}
.notif-inv-btn.accept  { background: var(--caramel); color: #fff; }
.notif-inv-btn.accept:hover  { background: #9A5418; }
.notif-inv-btn.decline { background: var(--latte-soft); color: var(--muted); border: 1px solid var(--border); }
.notif-inv-btn.decline:hover { color: #C0392B; }

/* ════════════════════════════════════════════════════════════
   CHATS PAGE (inboxView) — stats bar + right rail redesign
   ════════════════════════════════════════════════════════════ */

/* Stats bar */
.ibx-stats-bar {
  display: flex;
  align-items: center;
  gap: 0;
  padding: 14px 28px;
  background: #fff;
  border-bottom: 1px solid rgba(139,90,43,0.11);
  flex-shrink: 0;
}
.ibx-stat-item {
  flex: 1;
  text-align: center;
}
.ibx-stat-num {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 26px;
  font-weight: 400;
  color: #B5651D;
  letter-spacing: -0.02em;
  line-height: 1;
  margin-bottom: 3px;
}
.ibx-stat-label {
  font-family: 'Sora', sans-serif;
  font-size: 11px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #8C7B6E;
}
.ibx-stat-divider {
  width: 1px;
  height: 36px;
  background: rgba(139,90,43,0.12);
  flex-shrink: 0;
  margin: 0 4px;
}

/* Right rail */
.ibx-right-rail {
  width: 260px;
  flex-shrink: 0;
  border-left: 1px solid rgba(139,90,43,0.11);
  display: flex;
  flex-direction: column;
  background: #FAF7F2;
  overflow: hidden;
}
.ibx-right-scroll {
  flex: 1;
  overflow-y: auto;
  padding: 0 0 8px;
}
.ibx-right-scroll::-webkit-scrollbar { width: 0; }

.ibx-rail-section {
  padding: 14px 14px 10px;
  border-bottom: 1px solid rgba(139,90,43,0.08);
}
.ibx-rail-section:last-child { border-bottom: none; }

.ibx-rail-label {
  font-family: 'Sora', sans-serif;
  font-size: 10.5px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: #B5651D;
  margin-bottom: 10px;
}

/* Schedule button pinned to bottom */
.ibx-rail-footer {
  padding: 12px 14px 16px;
  border-top: 1px solid rgba(139,90,43,0.11);
  flex-shrink: 0;
  background: #FAF7F2;
}
.ibx-schedule-btn {
  width: 100%;
  padding: 11px 16px;
  background: #B5651D;
  color: #fff;
  border: none;
  border-radius: 10px;
  font-family: 'Sora', sans-serif;
  font-size: 13.5px;
  font-weight: 500;
  cursor: pointer;
  transition: background 0.15s;
}
.ibx-schedule-btn:hover { background: #9A5418; }

/* Past chats cards */
.ibx-past-card {
  background: #fff;
  border: 1px solid rgba(139,90,43,0.11);
  border-radius: 10px;
  padding: 10px 12px;
  margin-bottom: 8px;
  box-shadow: 0 1px 3px rgba(28,15,7,0.04);
}
.ibx-past-card:last-child { margin-bottom: 0; }
.ibx-past-top {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
}
.ibx-past-review-btn {
  width: 100%;
  padding: 5px 0;
  background: #F5EDE3;
  color: #B5651D;
  border: 1px solid rgba(181,101,29,0.18);
  border-radius: 7px;
  font-family: 'Sora', sans-serif;
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.15s;
}
.ibx-past-review-btn:hover { background: #B5651D; color: #fff; border-color: #B5651D; }

/* Invite cards inside the new rail sections */
#ibxPendingInvitesList .ibx-invite-card { margin: 0 0 8px; }
#ibxPendingInvitesList .ibx-invite-card:last-child { margin-bottom: 0; }
#ibxUpcomingList .ibx-up-card { margin: 0 0 8px; }

/* Hide old ibx-upcoming-panel styles now that rail takes over */
.ibx-pending-section { background: transparent; border: none; box-shadow: none; }

/* Responsive: hide right rail on narrow screens */
@media (max-width: 900px) { .ibx-right-rail { display: none !important; } }

/* Remove old ibx-up-new-btn since schedule is now in rail footer */
.ibx-up-new-btn { display: none !important; }

/* ════════════════════════════════════════════════════════════
   CHATS PAGE LAYOUT & DESIGN FIXES
   ════════════════════════════════════════════════════════════ */

/* Fix 1: inboxView must be column flex so stats bar spans full width */
#inboxView { display: none; flex-direction: column; }
#inboxView.active { display: flex !important; flex-direction: column !important; }

/* Stats bar — full width horizontal strip */
.ibx-stats-bar {
  display: flex !important;
  flex-direction: row !important;
  width: 100% !important;
  flex-shrink: 0 !important;
}

/* ibx-shell fills the remaining height below the stats bar */
.ibx-shell { flex: 1; min-height: 0; }

/* Fix 2: Message bubbles — caramel outgoing, white incoming */
.ibx-msg-row.mine .ibx-bubble {
  background: #B5651D !important;
  color: #ffffff !important;
  border: none !important;
  box-shadow: 0 2px 8px rgba(181,101,29,0.25) !important;
  border-bottom-right-radius: 5px !important;
  border-bottom-left-radius: 18px !important;
}
.ibx-msg-row:not(.mine) .ibx-bubble {
  background: #ffffff !important;
  color: #1C0F07 !important;
  border: 1px solid rgba(139,90,43,0.14) !important;
  border-bottom-left-radius: 5px !important;
  border-bottom-right-radius: 18px !important;
  box-shadow: 0 1px 3px rgba(28,15,7,0.06) !important;
}

/* Fix 3: Active conversation — 2px caramel left border */
.ibx-conv-row.active {
  border-left: 2px solid #B5651D !important;
  padding-left: 12px !important;
  background: #F5EDE3 !important;
}
.ibx-conv-row.active .ibx-conv-name { color: #B5651D !important; font-weight: 600 !important; }

/* Fix 4: Compose button hidden */
.ibx-compose-btn { display: none !important; }

/* Right rail sections — always visible with empty state */
.ibx-rail-section { display: block !important; }

/* Review modal stars */
.review-stars {
  display: flex;
  gap: 6px;
}
.review-star {
  font-size: 32px;
  color: #DDD0C0;
  cursor: pointer;
  transition: color 0.12s, transform 0.12s;
  user-select: none;
  line-height: 1;
}
.review-star:hover,
.review-star.selected { color: #B5651D; transform: scale(1.15); }
.review-star.lit { color: #B5651D; }

/* Past chat card — reviewed badge */
.ibx-reviewed-badge {
  font-family: 'Sora', sans-serif;
  font-size: 12px;
  font-weight: 500;
  color: #2d7a4f;
  background: #E8F5E9;
  border: 1px solid #A5D6A7;
  border-radius: 20px;
  padding: 4px 12px;
  display: inline-block;
  margin-top: 6px;
}

/* Dark mode bubble override */
[data-theme="dark"] .ibx-msg-row.mine .ibx-bubble {
  background: #B5651D !important;
  color: #fff !important;
}
[data-theme="dark"] .ibx-msg-row:not(.mine) .ibx-bubble {
  background: var(--card) !important;
  color: var(--espresso) !important;
  border-color: var(--border) !important;
}
