/*
 * FSM My Account Dashboard - FSM UI Kit
 * Soft cards, groene accenten, rustige schaduw, duidelijke states.
 */

:root {
    --fsm-ui-green-900: #174f2a;
    --fsm-ui-green-800: #1f6b37;
    --fsm-ui-green-700: #268044;
    --fsm-ui-green-600: #2f9552;
    --fsm-ui-green-100: #eaf7ee;
    --fsm-ui-green-050: #f5fbf7;

    --fsm-ui-ink: #102033;
    --fsm-ui-muted: #627086;
    --fsm-ui-soft: #f8faf8;
    --fsm-ui-panel: #ffffff;
    --fsm-ui-border: #dce8dd;
    --fsm-ui-border-strong: #b9d9bf;
    --fsm-ui-warm: #fff8ef;
    --fsm-ui-warm-border: #f2c58e;

    --fsm-ui-radius-sm: 10px;
    --fsm-ui-radius: 16px;
    --fsm-ui-radius-lg: 20px;
    --fsm-ui-shadow: 0 10px 24px rgba(16, 32, 51, .055);
    --fsm-ui-shadow-hover: 0 16px 34px rgba(31, 107, 55, .14);
    --fsm-ui-focus: 0 0 0 3px rgba(47, 149, 82, .18);
}

.fsm-mad {
    max-width: 980px;
    margin: 0 auto 2rem;
    font-family: inherit;
    color: var(--fsm-ui-ink);
}

.fsm-mad * { box-sizing: border-box; }
.fsm-mad svg { width: 1em; height: 1em; display: block; fill: currentColor; }

.fsm-mad a:focus,
.fsm-mad button:focus,
.fsm-mad input:focus {
    outline: none;
    box-shadow: var(--fsm-ui-focus);
}

/* FSM header */
.fsm-mad-hero {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin: 0 0 1rem;
    padding: 1.75rem 1.75rem;
    border: 1px solid var(--fsm-ui-border-strong);
    border-radius: var(--fsm-ui-radius-lg);
    background: linear-gradient(135deg, #ffffff 0%, var(--fsm-ui-green-050) 100%);
    box-shadow: var(--fsm-ui-shadow);
}

.fsm-mad-hero span {
    display: block;
    margin: 0 0 1.75rem;
    color: var(--fsm-ui-green-700);
    font-size: .78rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .08em;
}

.fsm-mad-hero h2 {
    margin: 0;
    font-family: Georgia, 'Times New Roman', serif;
    font-size: 1.65rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: #2a1609;
}

.fsm-mad-hero p {
    margin: .75rem 0 0;
    color: var(--fsm-ui-muted);
    font-size: 1rem;
}

.fsm-mad-hero-icon {
    display: grid;
    place-items: center;
    width: 70px;
    height: 70px;
    color: var(--fsm-ui-green-700);
    font-size: 2.2rem;
}

/* FSM info panel */
.fsm-mad-welcome {
    margin: 0 0 1rem;
    padding: 1.25rem 1.35rem;
    border: 1px solid var(--fsm-ui-warm-border);
    border-left: 4px solid var(--fsm-ui-green-600);
    border-radius: var(--fsm-ui-radius);
    background: var(--fsm-ui-warm);
}

.fsm-mad-welcome h3,
.fsm-mad-order-search h3,
.fsm-mad-section-title h3 {
    margin: 0;
    font-family: Georgia, 'Times New Roman', serif;
    text-transform: uppercase;
    font-weight: 500;
    color: #3b200d;
}

.fsm-mad-welcome p {
    margin: .75rem 0 0;
    color: var(--fsm-ui-muted);
    font-size: 1.05rem;
    line-height: 1.45;
}

/* FSM tile grid */
.fsm-mad-tiles {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
    margin: 0 0 1.25rem;
}

.fsm-mad-tile {
    position: relative;
    display: flex;
    gap: .9rem;
    align-items: flex-start;
    min-height: 112px;
    padding: 1rem 2rem 1rem 1rem;
    border: 1px solid var(--fsm-ui-border);
    border-radius: var(--fsm-ui-radius);
    background: var(--fsm-ui-panel);
    box-shadow: var(--fsm-ui-shadow);
    text-decoration: none !important;
    color: var(--fsm-ui-ink);
    transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease, background-color .16s ease;
}

.fsm-mad-tile:hover {
    transform: translateY(-2px);
    box-shadow: var(--fsm-ui-shadow-hover);
    border-color: var(--fsm-ui-border-strong);
    background: linear-gradient(135deg, #fff 0%, var(--fsm-ui-green-050) 100%);
}

.fsm-mad-tile.is-dragging { opacity: .55; }

.fsm-mad-tile-icon,
.fsm-mad-search-icon {
    display: grid;
    place-items: center;
    flex: 0 0 43px;
    width: 43px;
    height: 43px;
    border-radius: 14px;
    background: var(--fsm-ui-green-100);
    color: var(--fsm-ui-green-700);
    font-size: 1.35rem;
}

.fsm-mad-tile-content {
    display: flex;
    flex-direction: column;
    gap: .38rem;
}

.fsm-mad-tile-content strong {
    font-size: 1rem;
    line-height: 1.15;
    color: #071529;
}

.fsm-mad-tile-content small {
    line-height: 1.32;
    color: var(--fsm-ui-muted);
    font-size: .9rem;
}

.fsm-mad-tile-drag {
    position: absolute;
    right: .85rem;
    bottom: .75rem;
    color: #b2c4b6;
    cursor: grab;
    font-size: 1.05rem;
}

.fsm-mad-tile:hover .fsm-mad-tile-drag { color: var(--fsm-ui-green-700); }

/* FSM search card */
.fsm-mad-order-search {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(250px, 420px);
    gap: 1rem;
    align-items: center;
    margin: 0 0 1.25rem;
    padding: 1.25rem;
    border: 1px solid var(--fsm-ui-border);
    border-radius: var(--fsm-ui-radius);
    background: var(--fsm-ui-panel);
    box-shadow: var(--fsm-ui-shadow);
}

.fsm-mad-search-copy {
    display: flex;
    gap: .9rem;
    align-items: center;
}

.fsm-mad-order-search p {
    margin: .55rem 0 0;
    color: var(--fsm-ui-muted);
    line-height: 1.4;
}

.fsm-mad-order-search form {
    display: flex;
    gap: .65rem;
}

.fsm-mad-order-search input {
    width: 100%;
    min-height: 42px;
    border: 1px solid #cbd8cd;
    border-radius: var(--fsm-ui-radius-sm);
    padding: 0 .8rem;
    background: #fff;
}

.fsm-mad-order-search button,
.fsm-mad-order-link,
.fsm-mad-search-result a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: .55rem 1rem;
    border: 0;
    border-radius: var(--fsm-ui-radius-sm);
    background: var(--fsm-ui-green-700);
    color: #fff !important;
    text-decoration: none !important;
    font-weight: 700;
    white-space: nowrap;
    transition: background-color .16s ease, transform .16s ease, box-shadow .16s ease;
}

.fsm-mad-order-search button:hover,
.fsm-mad-order-link:hover,
.fsm-mad-search-result a:hover {
    background: var(--fsm-ui-green-900);
    transform: translateY(-1px);
    box-shadow: 0 8px 18px rgba(31, 107, 55, .18);
}

.fsm-mad-search-result {
    grid-column: 1 / -1;
    display: flex;
    gap: .75rem;
    align-items: center;
    justify-content: space-between;
    padding: .8rem;
    border-radius: 12px;
    background: var(--fsm-ui-green-050);
    border: 1px solid var(--fsm-ui-border-strong);
}

.fsm-mad-search-result.is-empty {
    display: block;
    color: #92400e;
    background: #fffbeb;
    border-color: #fde68a;
}

/* FSM recent orders */
.fsm-mad-section-title {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: center;
    margin: .2rem 0 .8rem;
}

.fsm-mad-section-title a {
    font-weight: 700;
    color: var(--fsm-ui-green-700);
}

.fsm-mad-order-list {
    display: grid;
    gap: .75rem;
}

.fsm-mad-order-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 1rem;
    align-items: center;
    padding: 1rem;
    border: 1px solid var(--fsm-ui-border);
    border-radius: var(--fsm-ui-radius);
    background: var(--fsm-ui-panel);
    box-shadow: 0 8px 18px rgba(16, 32, 51, .045);
}

.fsm-mad-order-main {
    display: grid;
    gap: .15rem;
}

.fsm-mad-order-number {
    display: inline-flex;
    width: max-content;
    padding: .18rem .55rem;
    border-radius: 999px;
    background: var(--fsm-ui-green-100);
    color: var(--fsm-ui-green-800);
    font-weight: 800;
}

.fsm-mad-order-main small { color: var(--fsm-ui-muted); }

.fsm-mad-order-meta {
    display: flex;
    align-items: center;
    gap: .65rem;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.fsm-mad-status {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: .22rem .6rem;
    border-radius: 999px;
    background: #f1f5f9;
    color: #334155;
    font-size: .86rem;
    font-weight: 800;
}

.fsm-mad-status.status-completed { background: #dcfce7; color: #166534; }
.fsm-mad-status.status-processing { background: var(--fsm-ui-green-100); color: var(--fsm-ui-green-800); }
.fsm-mad-status.status-on-hold { background: #fef3c7; color: #92400e; }
.fsm-mad-status.status-cancelled,
.fsm-mad-status.status-failed { background: #fee2e2; color: #991b1b; }

.fsm-mad-total { font-weight: 800; }

.fsm-mad-empty,
.fsm-mad-notice {
    padding: 1rem;
    border-radius: 14px;
    background: var(--fsm-ui-soft);
    border: 1px solid var(--fsm-ui-border);
    color: #475569;
}

@media (max-width: 860px) {
    .fsm-mad-tiles { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .fsm-mad-order-search { grid-template-columns: 1fr; }
    .fsm-mad-order-search form { max-width: none; }
}

@media (max-width: 620px) {
    .fsm-mad { max-width: none; }
    .fsm-mad-hero { padding: 1.25rem; }
    .fsm-mad-hero-icon { display: none; }
    .fsm-mad-tiles { grid-template-columns: 1fr; }
    .fsm-mad-order-card { grid-template-columns: 1fr; }
    .fsm-mad-order-search form { flex-direction: column; }
    .fsm-mad-order-meta { justify-content: flex-start; }
}

/* Endpoint dashboard return button */
.fsm-mad-endpoint-bar {
    max-width: 980px;
    margin: 0 auto 1rem;
}

.fsm-mad-back-dashboard {
    display: inline-flex;
    align-items: center;
    gap: .75rem;
    padding: .85rem 1rem;
    border: 1px solid var(--fsm-ui-border-strong);
    border-radius: var(--fsm-ui-radius);
    background: linear-gradient(135deg, #ffffff 0%, var(--fsm-ui-green-050) 100%);
    color: var(--fsm-ui-ink);
    text-decoration: none;
    box-shadow: var(--fsm-ui-shadow);
    transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.fsm-mad-back-dashboard:hover,
.fsm-mad-back-dashboard:focus {
    transform: translateY(-1px);
    border-color: var(--fsm-ui-green-600);
    box-shadow: var(--fsm-ui-shadow-hover);
    color: var(--fsm-ui-green-800);
    text-decoration: none;
}

.fsm-mad-back-dashboard span:last-child {
    display: grid;
    gap: .1rem;
}

.fsm-mad-back-dashboard strong {
    font-weight: 800;
    line-height: 1.1;
}

.fsm-mad-back-dashboard small {
    color: var(--fsm-ui-muted);
    font-size: .82rem;
}

.fsm-mad-back-icon {
    display: grid;
    place-items: center;
    width: 38px;
    height: 38px;
    border-radius: 12px;
    background: var(--fsm-ui-green-100);
    color: var(--fsm-ui-green-700);
    font-size: 1.1rem;
}

.fsm-mad-back-icon svg {
    width: 1em;
    height: 1em;
    display: block;
    fill: currentColor;
}
