:root {
    --bg: #f3f4f8;
    --tile: #ffffff;
    --tile-border: #d9dce3;
    --hover: #e8f0fe;
    --text-main: #111827;
    --text-muted: #6b7280;
    --shadow: 0 4px 14px rgba(15, 23, 42, 0.08);
}

/* GLOBAL */
body {
    margin: 0;
    font-family: "Plus Jakarta Sans", sans-serif;
    background: var(--bg);
    color: var(--text-main);
}

/* HEADER */
h1 {
    font-size: 2rem;
    font-weight: 600;
}

.subtitle {
    font-size: 0.95rem;
    color: var(--text-muted);
}

.brand-logo {
    height: 30px;
}

/* SECTION TITLES */
.section-title {
    font-size: 1rem;
    font-weight: 600;
    margin-bottom: 0.4rem;
}

/* TILES */
.app-tile {
    display: block;
    background: var(--tile);
    border: 1px solid var(--tile-border);
    border-radius: 18px;
    padding: 18px 16px 16px;
    text-align: center;
    text-decoration: none;
    color: var(--text-main);
    box-shadow: var(--shadow);
    transition: background 0.15s ease, transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease;
}

    .app-tile:hover {
        background: var(--hover);
        transform: translateY(-3px);
        box-shadow: 0 10px 24px rgba(15, 23, 42, 0.16);
        border-color: #3b82f6;
    }

.app-icon {
    width: 56px;
    height: 56px;
    margin: 0 auto 10px;
    border-radius: 16px;
    font-size: 1.8rem;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #ffffff;
}

/* app colors */
.w {
    background: #2b579a;
}

.x {
    background: #217346;
}

.o {
    background: #c43e1c;
}

.p {
    background: #d24726;
}

.n {
    background: #80397b;
}

.t {
    background: #4b53bc;
}

.d {
    background: #174ea6;
}

.s {
    background: #1d5f8a;
}

.pl {
    background: #107c41;
}

.td {
    background: #0f6cbd;
}

.fms {
    background: #0066cc;
}

.wb {
    background: #0284c7;
}

.app-name {
    font-size: 1rem;
    font-weight: 600;
}

.app-desc {
    margin-top: 4px;
    font-size: 0.82rem;
    color: var(--text-muted);
}

/* FEATURED TILES (Word, Excel, Outlook) */
.featured-row .app-tile {
    border-width: 2px;
    border-color: #93c5fd;
}

    .featured-row .app-tile:hover {
        border-color: #2563eb;
    }

/* Small tweaks on mobile */
@media (max-width: 575.98px) {
    .brand-logo {
        height: 40px;
    }

    h1 {
        font-size: 1.6rem;
    }
}








/* Handy links row */
.sec {
    background: #0ea5e9;
}
/* light blue */
.az {
    background: #2563eb;
}
/* Azure blue */
.ado {
    background: #7c3aed;
}
/* purple */

.msearch {
    background: #0284c7;
}
/* Cyan-like blue */
.madmin {
    background: #2563eb;
}
/* Strong Microsoft admin blue */
.exadmin {
    background: #8b5cf6;
}
/* Exchange purple */
.entra {
    background: #0ea5e9;
}
/* Entra azure blue */
.oconfig {
    background: #6366f1;
}
/* Indigo */
.mapps {
    background: #10b981;
}
/* Green */












.app-footer {
    text-align: center;
    padding: 1rem 0;
    margin-top: 3rem;
}

    .app-footer small {
        color: #9ca3af; /* light gray */
        font-size: 0.65rem;
        opacity: 0.9;
    }








.domain-title {
    font-size: 2rem;
    letter-spacing: -0.02em; /* same subtle compression effect */
    margin-bottom: 0.25rem;
    color: #0f172a; /* Slate-900 */
}

    .domain-title .d365 {
        color: #1872e8;
    }


/* Subtitle styling (Resonance-like) */
.domain-subtitle {
    font-size: .95rem;
    font-weight: 400;
    color: #64748b; /* Slate-500 */
    letter-spacing: -0.01em;
    margin-top: -4px;
}



.section-title {
    font-family: "Plus Jakarta Sans", sans-serif;
    font-size: 0.95rem;
    font-weight: 300;
    color: #94a3b8; /* subtle slate-400 */
    letter-spacing: 0.02em; /* slight spacing for elegance */
    margin-bottom: 0.5rem;
    margin-top: 1rem;
}




.separator {
    border: 0;
    border-top: 1px solid #e2e8f0; /* slate-200 light line */
    margin: 2rem 0 1rem 0;
    opacity: 0.8; /* softer appearance */
}
