﻿/* =========================================================
   MakeaMatch UI Theme
   Clean, sporty, consistent
   ========================================================= */

/* Default theme fallback (MainLayout overrides these via CSS vars). */
:root {
    --mm-primary: #FF2D55;
    --mm-accent: #00D4FF;
    --mm-bg: #FFF7ED;
    --mm-surface: #FFFFFF;
    --mm-text: #0F172A;
    --mm-muted: #475569;
    --mm-border: #E2E8F0;
    --mm-chip: #EEF2FF;
    --mm-radius-card: 16px;
    --mm-radius-panel: 18px;
    --mm-radius-pill: 999px;
    --mm-shadow-sm: 0 2px 10px rgba(0,0,0,.05);
    --mm-shadow-md: 0 4px 16px rgba(0,0,0,.08);
}

/* App background + text */
body {
    background: var(--mm-bg);
    color: var(--mm-text);
}

/* ---------------------------------------------------------
   Core components
   --------------------------------------------------------- */

.mm-card {
    background: var(--mm-surface);
    border: 1px solid var(--mm-border);
    border-radius: var(--mm-radius-card);
    padding: 14px;
    box-shadow: var(--mm-shadow-sm);
}

.mm-panel {
    border: 1px dashed rgba(0,0,0,.12);
    border-radius: var(--mm-radius-panel);
    padding: 14px;
    background: rgba(255,255,255,.92);
}

.mm-panel-title {
    font-weight: 900;
    font-size: 1.05rem;
}

.mm-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: var(--mm-chip);
    border: 1px solid var(--mm-border);
    border-radius: var(--mm-radius-pill);
    padding: 4px 10px;
    font-size: 0.9rem;
    color: var(--mm-text);
}

.mm-muted {
    color: var(--mm-muted);
}

.mm-brand {
    font-weight: 900;
    letter-spacing: 0.3px;
}

.mm-tagline {
    color: var(--mm-muted);
    font-size: 0.95rem;
}

/* Links:
   - .mm-link = clean neutral (good for titles)
   - .mm-link-accent = uses primary color (calls-to-action)
*/
.mm-link {
    color: var(--mm-text);
    text-decoration: none;
    font-weight: 900;
}

    .mm-link:hover {
        text-decoration: underline;
    }

.mm-link-accent {
    color: var(--mm-primary);
    text-decoration: none;
    font-weight: 700;
}

    .mm-link-accent:hover {
        text-decoration: underline;
    }

/* ---------------------------------------------------------
   Buttons (keep Bootstrap classes, enhance via helpers)
   --------------------------------------------------------- */

/* Primary action (pill) */
.mm-btn-primary {
    background: var(--mm-primary);
    border-color: var(--mm-primary);
    color: #fff;
    border-radius: var(--mm-radius-pill) !important;
    padding: .5rem .95rem !important;
    box-shadow: var(--mm-shadow-md);
}

    .mm-btn-primary:hover {
        filter: brightness(1.05);
    }

/* Accent action (pill) */
.mm-btn-accent {
    background: var(--mm-accent);
    border-color: var(--mm-accent);
    color: #081018;
    border-radius: var(--mm-radius-pill) !important;
    padding: .5rem .95rem !important;
    box-shadow: var(--mm-shadow-md);
}

/* Soft sporty button (pill) */
.mm-btn-soft {
    border-radius: var(--mm-radius-pill) !important;
    padding: .45rem .85rem !important;
    border: 1px solid rgba(0,0,0,.14) !important;
    background: rgba(255,255,255,.95) !important;
    color: var(--mm-text) !important;
    box-shadow: var(--mm-shadow-sm);
}

    .mm-btn-soft:hover {
        transform: translateY(-1px);
        box-shadow: var(--mm-shadow-md);
    }

/* Rectangular rounded button (matches your "Close" vibe) */
.btn.mm-btn-rect {
    border-radius: 12px !important;
    padding: .45rem .85rem !important;
    border: 1px solid rgba(0,0,0,.18) !important;
    background: #fff !important;
    color: var(--mm-text) !important;
    box-shadow: var(--mm-shadow-sm) !important;
}

    .btn.mm-btn-rect:hover {
        border-color: rgba(0,0,0,.28) !important;
        box-shadow: var(--mm-shadow-md) !important;
        transform: translateY(-1px);
    }

    .btn.mm-btn-rect:disabled {
        opacity: .65;
        transform: none;
        box-shadow: none !important;
    }

/* ---------------------------------------------------------
   Forms & focus
   --------------------------------------------------------- */

.form-check-input {
    cursor: pointer;
}

    .form-check-input:checked {
        background-color: var(--mm-primary);
        border-color: var(--mm-primary);
    }

    .form-select:focus,
    .form-control:focus,
    .form-check-input:focus {
        box-shadow: 0 0 0 .2rem rgba(0,0,0,.08);
        border-color: var(--mm-border);
    }

/* ---------------------------------------------------------
   Details / disclosure (caret)
   --------------------------------------------------------- */

.mm-details > summary {
    cursor: pointer;
    list-style: none;
    display: flex;
    align-items: center;
    gap: 8px;
}

    .mm-details > summary::marker {
        content: "";
    }

    .mm-details > summary::before {
        content: "▸";
        color: rgba(0,0,0,.55);
        transform: translateY(-1px);
    }

.mm-details[open] > summary::before {
    content: "▾";
}

/* ---------------------------------------------------------
   Sporty Sidebar / Nav
   --------------------------------------------------------- */

.mm-side {
    height: 100%;
    padding: 14px;
    background: radial-gradient(900px 500px at 20% 0%, rgba(0, 212, 255, 0.22), transparent 60%), radial-gradient(900px 500px at 80% 10%, rgba(255, 45, 85, 0.16), transparent 60%), linear-gradient(180deg, rgba(255,255,255,0.85), rgba(255,255,255,0.65));
    border-right: 1px solid var(--mm-border);
}

.mm-side-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 10px;
}

.mm-side-title {
    font-weight: 900;
    letter-spacing: 0.2px;
}

.mm-nav {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-top: 10px;
}

    .mm-nav a {
        display: flex;
        align-items: center;
        gap: 10px;
        padding: 10px 12px;
        border-radius: 12px;
        text-decoration: none;
        color: var(--mm-text);
        border: 1px solid transparent;
    }

        .mm-nav a:hover {
            background: rgba(255, 45, 85, 0.08);
            border-color: rgba(255, 45, 85, 0.25);
        }

        .mm-nav a.active {
            background: rgba(255, 45, 85, 0.12);
            border-color: rgba(255, 45, 85, 0.35);
            box-shadow: 0 0 0 2px rgba(0, 212, 255, 0.10) inset;
        }

/* icon spacing */
.mm-ico {
    width: 22px;
    text-align: center;
    margin-right: 6px;
}

/* Make the default Blazor sidebar container look consistent */
.sidebar {
    background: transparent;
}

/* Prevent header clipping from template styles */
.mm-header,
.mm-auth-topbar,
.mm-auth-header,
.top-row {
    min-height: 64px;
    overflow: visible !important;
    display: flex;
    align-items: center;
}

    .mm-header img,
    .mm-auth-topbar img,
    .mm-auth-header img {
        max-height: 52px;
        height: 52px;
        width: auto;
        display: block;
    }

.mm-details > summary {
    margin: 0;
    padding: 0;
}

.mm-summary {
    padding: 0;
}

/* Tighten PlayFeed filter panel spacing */
.mm-panel .form-label {
    margin-bottom: 2px;
}

.mm-panel .row.g-2 {
    --bs-gutter-y: .25rem; /* tighter vertical gutters */
}
