
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700&display=swap');

/* Mio v2.3 Poppins + mini grafieken */
*{
    font-family:'Poppins', Arial, sans-serif;
}
body, input, select, button, textarea{
    font-family:'Poppins', Arial, sans-serif;
}

*{box-sizing:border-box}
body{margin:0;font-family:Arial,sans-serif;background:#f4f6f8;color:#111827;display:flex}
aside{width:245px;min-height:100vh;background:#0b1b34;color:#fff;padding:24px;position:fixed;left:0;top:0;bottom:0}
aside h1{margin:0 0 28px;font-size:26px}
aside a{display:block;color:#dbeafe;text-decoration:none;padding:11px 12px;border-radius:8px;margin-bottom:4px}
aside a:hover{background:#123a70}
.admin-main{margin-left:245px;padding:34px;width:calc(100% - 245px)}
h2{font-size:30px;margin:0 0 22px}
h3{font-size:20px;margin:30px 0 14px}
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:24px}
.card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:22px}
.card strong{display:block;font-size:34px}
.card span{color:#6b7280}
.notice{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:16px;margin:0 0 18px}
.notice.ok{border-color:#b7e3a7;background:#f6fff2}
.notice.bad{border-color:#f3b1aa;background:#fff6f4}
pre{white-space:pre-wrap;background:#f1f5f9;border-radius:8px;padding:12px;overflow:auto}
code{background:#eef2f7;padding:2px 6px;border-radius:5px}
table{width:100%;border-collapse:collapse;background:#fff;border-radius:12px;overflow:hidden;margin-bottom:18px}
th,td{text-align:left;padding:13px 15px;border-bottom:1px solid #e5e7eb}
th{background:#f9fafb}
@media(max-width:800px){body{display:block}aside{position:relative;width:auto;min-height:auto}.admin-main{margin-left:0;width:auto;padding:20px}}

.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:22px}
.page-head h2{margin:0 0 6px}.page-head p{margin:0;color:#6b7280}
.button,.small-button{display:inline-flex;align-items:center;justify-content:center;background:#4d9c29;color:#fff;text-decoration:none;border:0;border-radius:8px;font-weight:700;cursor:pointer}
.button{min-height:42px;padding:0 18px}.button.secondary{background:#10233f}.small-button{min-height:32px;padding:0 12px;font-size:13px}
.form-card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:22px;max-width:680px}
.form-card label{display:block;font-weight:700;margin-bottom:18px}.form-card input{display:block;width:100%;margin-top:8px;padding:12px;border:1px solid #d1d5db;border-radius:8px}
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;margin-bottom:24px}
.step{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:20px}
.step>strong{width:34px;height:34px;display:flex;align-items:center;justify-content:center;background:#e7f6df;color:#4d9c29;border-radius:50%;margin-bottom:12px}.step h3{margin:0 0 10px}.step label{display:block;font-weight:700;margin:12px 0 6px}
.copy-row{display:flex;gap:8px}.copy-row input{flex:1;padding:11px;border:1px solid #d1d5db;border-radius:8px}.copy-row button{border:0;background:#10233f;color:#fff;border-radius:8px;padding:0 12px;font-weight:700;cursor:pointer}
@media(max-width:800px){body{display:block}aside{position:relative;width:auto;min-height:auto}.admin-main{margin-left:0;width:auto;padding:20px}.page-head{display:block}}

.mini-form label{display:block;font-weight:700;margin:10px 0 6px}
.mini-form input{width:100%;padding:11px;border:1px solid #d1d5db;border-radius:8px;margin-bottom:10px}

.search-card{display:flex;align-items:end;gap:12px;flex-wrap:wrap;background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:16px;margin-bottom:18px}
.search-card label{display:block;font-weight:700}
.search-card input,.search-card select{display:block;margin-top:6px;padding:11px;border:1px solid #d1d5db;border-radius:8px;min-width:220px}
.search-card input{min-width:420px}
.pagination{display:flex;gap:10px;align-items:center;margin:18px 0}
.notice.bad{border-color:#f3b1aa;background:#fff6f4;color:#9f1d16}
@media(max-width:800px){.search-card{display:block}.search-card input,.search-card select{min-width:0;width:100%;margin-bottom:12px}}

.form-card textarea{
    display:block;
    width:100%;
    margin-top:8px;
    padding:12px;
    border:1px solid #d1d5db;
    border-radius:8px;
    font-family:Arial,sans-serif;
    min-height:130px;
}

.button-row{
    display:flex;
    gap:12px;
    flex-wrap:wrap;
    align-items:center;
}
.button.secondary{
    background:#10233f;
}
.button.secondary:hover{
    background:#17395f;
}

.button.danger,
button.danger{
    background:#c0392b!important;
    color:#fff!important;
    border:0;
}
.button.danger:hover,
button.danger:hover{
    background:#962d22!important;
}
.notice.ok{
    background:#f0fdf4;
    border:1px solid #bbf7d0;
    color:#14532d;
    border-radius:12px;
    padding:14px 16px;
    margin:16px 0;
}



/* Mio v0.6 look-overrides gebaseerd op aangeleverde beheer.css */
body{
    background:#f4f7fb;
    color:#00173d;
}
aside{
    background:#fff;
    color:#00173d;
    border-right:1px solid #dfe7f2;
    box-shadow:0 0 28px rgba(15,31,58,.05);
}
.logo-wrap{
    padding:4px 6px 18px;
    margin-bottom:18px;
    border-bottom:1px solid #e7edf5;
}
.logo-wrap img{
    display:block;
    width:145px;
    height:auto;
}
aside a{
    color:#00173d;
    border:1px solid #dce5f2;
    background:#fff;
    margin-bottom:10px;
}
aside a:hover{
    background:#eef5ff;
    border-color:#bcd2f2;
}
.admin-main{
    background:#f4f7fb;
}
.topbar{
    background:#fff;
    border:1px solid #dce5f2;
    border-radius:14px;
    padding:14px 18px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    margin-bottom:22px;
    box-shadow:0 10px 24px rgba(15,31,58,.04);
}
.eyebrow{
    color:#42618f;
    font-weight:700;
    font-size:13px;
}
.page-head{
    align-items:center;
}
.page-head h2{
    color:#2f5fb3;
    font-size:30px;
}
.cards{
    grid-template-columns:repeat(auto-fit,minmax(185px,1fr));
}
.card{
    border-radius:16px;
    border-color:#dce5f2;
    box-shadow:0 10px 24px rgba(15,31,58,.04);
}
.card span{
    color:#2f5fb3;
    font-weight:700;
}
.card strong{
    color:#00173d;
}
.card small{
    color:#42618f;
}
.table-card,
.form-card,
.notice,
table{
    border:1px solid #dce5f2;
    border-radius:16px;
    box-shadow:0 10px 24px rgba(15,31,58,.04);
}
.table-card{
    background:#fff;
    padding:22px;
    margin-bottom:22px;
}
.table-card table{
    box-shadow:none;
    border-radius:12px;
}
.form-card{
    margin-bottom:24px;
}
.form-card.wide{
    max-width:none;
}
.form-row{
    display:grid;
    grid-template-columns:1fr 1fr 1fr auto;
    gap:14px;
    align-items:end;
}
.form-card select,
select{
    display:block;
    width:100%;
    margin-top:8px;
    padding:12px;
    border:1px solid #d1d9e8;
    border-radius:8px;
    background:#fff;
}
.button,.small-button{
    background:#71c248;
    border-radius:9px;
}
.button.secondary,.small-button.secondary{
    background:#3b61ac;
}
.small-button.ghost{
    background:#fff;
    border:1px solid #d1d9e8;
    color:#00173d;
}
.inline-form{
    display:flex;
    gap:8px;
    align-items:center;
    margin-bottom:8px;
}
.inline-form select{
    margin-top:0;
    min-width:230px;
    padding:9px;
}
.muted{
    color:#7a8aa5;
}
.pill{
    display:inline-block;
    padding:4px 9px;
    border-radius:999px;
    background:#eef2f7;
    font-weight:700;
    font-size:12px;
}
.pill.ok{
    background:#edf9e9;
    color:#2f7b17;
}
.notice.bad{
    color:#9f1d16;
}
@media(max-width:900px){
    .form-row{display:block}
    .form-row label{margin-bottom:12px}
    .topbar{display:block}
}



/* Mio v0.7 polish */
:root{
    --mio-blue:#3B61AC;
    --mio-green:#71C248;
    --mio-orange:#F69220;
    --mio-ink:#00173d;
    --mio-muted:#486081;
    --mio-line:#dce6f3;
    --mio-bg:#f4f7fb;
    --mio-card:#ffffff;
}

body{
    background:
        radial-gradient(circle at top right, rgba(59,97,172,.07), transparent 32%),
        var(--mio-bg);
    color:var(--mio-ink);
}

aside{
    width:250px;
    padding:26px 18px;
    background:rgba(255,255,255,.96);
}

.logo-wrap{
    padding:0 6px 24px;
    margin-bottom:18px;
}

.logo-wrap img{
    width:150px;
}

aside nav a{
    min-height:43px;
    display:flex;
    align-items:center;
    padding:0 14px;
    border-radius:10px;
    border:1px solid var(--mio-line);
    font-weight:600;
    transition:.15s ease;
}

aside nav a:first-child{
    background:#eef5ff;
    border-color:#bfd3f2;
    color:var(--mio-blue);
}

aside nav a:hover{
    transform:translateX(2px);
    background:#f6f9ff;
}

.admin-main{
    margin-left:250px;
    width:calc(100% - 250px);
    padding:34px;
}

.topbar{
    min-height:62px;
    padding:13px 18px;
    border-radius:16px;
    border-color:var(--mio-line);
}

.topbar strong{
    color:var(--mio-blue);
}

.small-button.ghost{
    min-height:38px;
    border-radius:10px;
    padding:0 16px;
    font-weight:700;
}

.page-head{
    margin:24px 0 20px;
}

.eyebrow{
    display:block;
    margin-bottom:3px;
    color:var(--mio-muted);
}

.page-head h2{
    margin:0 0 5px;
    font-size:34px;
    line-height:1;
    color:var(--mio-blue);
    letter-spacing:-.8px;
}

.page-head p{
    color:var(--mio-muted);
    font-size:15px;
}

.cards{
    gap:16px;
    margin-bottom:24px;
}

.card{
    min-height:124px;
    padding:22px;
    border-radius:18px;
    position:relative;
    overflow:hidden;
}

.card:after{
    content:"";
    position:absolute;
    right:-22px;
    bottom:-26px;
    width:88px;
    height:88px;
    border-radius:50%;
    background:rgba(59,97,172,.06);
}

.card:nth-child(2):after{background:rgba(113,194,72,.10)}
.card:nth-child(5):after{background:rgba(246,146,32,.10)}

.card span{
    display:block;
    margin-bottom:7px;
    color:var(--mio-blue);
    font-size:14px;
}

.card strong{
    font-size:38px;
    line-height:1;
    letter-spacing:-1px;
}

.card small{
    display:block;
    margin-top:9px;
    color:var(--mio-muted);
}

.notice{
    border-radius:16px;
    padding:16px 18px;
    margin-bottom:22px;
    border-color:var(--mio-line);
}

.notice strong{
    color:var(--mio-ink);
}

code{
    background:#eef3fa;
    color:var(--mio-blue);
    border:1px solid #dce6f3;
}

.table-card{
    border-radius:18px;
    padding:24px;
}

.table-card h3,
.form-card h3,
h3{
    margin:0 0 16px;
    color:var(--mio-ink);
    font-size:22px;
}

table{
    border:1px solid var(--mio-line);
    border-radius:14px;
    overflow:hidden;
}

th{
    background:#f7faff;
    color:var(--mio-ink);
    font-size:14px;
    padding:14px 16px;
}

td{
    padding:16px;
    vertical-align:middle;
}

td strong{
    color:var(--mio-ink);
}

td small{
    font-size:12px;
    color:var(--mio-muted);
    line-height:1.5;
}

.pill{
    padding:5px 10px;
    font-size:12px;
    border-radius:999px;
}

.pill.ok{
    background:#edf9e9;
    color:#2e7d1c;
}

.inline-form{
    display:flex;
    align-items:center;
    gap:9px;
    margin:0 0 9px;
}

.inline-form select{
    min-width:265px;
    border-radius:10px;
    border-color:#cdd9eb;
    height:39px;
}

button,
.button,
.small-button{
    border-radius:10px;
    font-weight:700;
    box-shadow:none;
}

.small-button{
    min-height:36px;
    padding:0 14px;
}

.small-button.secondary,
.button.secondary{
    background:var(--mio-blue);
}

button:hover,
.button:hover,
.small-button:hover{
    filter:brightness(.96);
}

.form-card{
    max-width:none;
    border-radius:18px;
    padding:24px;
}

.form-card input,
.form-card select,
input,
select{
    border-radius:10px;
    border-color:#cdd9eb;
    min-height:42px;
}

.form-card label{
    color:var(--mio-ink);
}

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

.muted{
    color:#8291a8;
}

@media(max-width:800px){
    aside{
        width:auto;
        position:relative;
    }
    .admin-main{
        margin-left:0;
        width:auto;
        padding:20px;
    }
}


/* Mio v0.8 clickthrough */
.row-link{
    color:var(--mio-blue,#3B61AC);
    text-decoration:none;
    font-weight:700;
}
.row-link:hover{
    text-decoration:underline;
}
table tr:hover td{
    background:#fbfdff;
}


/* Mio v0.9 icon buttons */
.icon-button{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:7px;
    white-space:nowrap;
}

.icon-button .icon{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:18px;
    height:18px;
    border-radius:50%;
    background:rgba(255,255,255,.22);
    font-size:13px;
    line-height:1;
    font-weight:900;
}

.small-button.secondary.icon-button .icon{
    background:rgba(255,255,255,.18);
}

.inline-form{
    align-items:center;
}

.inline-form select{
    height:42px;
}

td:last-child{
    min-width:390px;
}

@media(max-width:900px){
    td:last-child{
        min-width:0;
    }
    .inline-form{
        flex-wrap:wrap;
    }
    .inline-form select{
        min-width:100%;
    }
}


/* Mio v1.0 - alleen knopjes aangepast naar icon-only */
.icon-only{
    width:40px;
    height:40px;
    min-width:40px;
    padding:0;
    border:0;
    border-radius:10px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    font-size:17px;
    font-weight:900;
    line-height:1;
    cursor:pointer;
    color:#fff;
}

.icon-only.success{
    background:#71C248;
}

.icon-only.secondary{
    background:#3B61AC;
}

.icon-only:hover{
    filter:brightness(.95);
}

.inline-form{
    display:inline-flex;
    align-items:center;
    gap:8px;
    margin:0 6px 0 0;
    vertical-align:middle;
}

.inline-form select{
    height:40px;
}

td:last-child{
    min-width:340px;
}


/* Mio v1.1 lokale monitoring */
.monitor-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
    gap:16px;
    margin-bottom:24px;
}
.monitor-card{
    background:#fff;
    border:1px solid #dce6f3;
    border-radius:18px;
    padding:20px;
    box-shadow:0 10px 24px rgba(15,31,58,.04);
}
.monitor-card.primary{
    border-left:5px solid #3B61AC;
}
.monitor-card span{
    display:block;
    color:#3B61AC;
    font-weight:700;
    font-size:14px;
    margin-bottom:8px;
}
.monitor-card strong{
    display:block;
    font-size:28px;
    line-height:1.1;
    color:#00173d;
}
.monitor-card small{
    display:block;
    color:#486081;
    margin-top:8px;
}
.meter{
    height:10px;
    background:#edf2f8;
    border-radius:999px;
    overflow:hidden;
    margin:8px 0 8px;
}
.meter span{
    display:block;
    height:100%;
    background:#71C248;
    border-radius:999px;
}
.table-card.compact table{
    margin-bottom:0;
}
.pill.bad{
    background:#fff1f0;
    color:#a33127;
}


/* Mio v1.2 - topbar verwijderd */
.page-head{
    margin-top:0;
}
.admin-main{
    padding-top:28px;
}


/* Mio v1.3 monitoring page */
.table-card.compact{
    margin-bottom:22px;
}


/* Mio v1.4 alerts */
.alert-summary{
    background:#fff;
    border:1px solid #dce6f3;
    border-radius:18px;
    padding:16px 18px;
    margin-bottom:18px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    box-shadow:0 10px 24px rgba(15,31,58,.04);
}
.alert-summary strong{
    display:block;
    color:#00173d;
    margin-bottom:5px;
}
.alert-status{
    display:inline-flex;
    align-items:center;
    min-height:26px;
    padding:0 11px;
    border-radius:999px;
    font-weight:700;
    font-size:13px;
}
.alert-status.ok{
    background:#edf9e9;
    color:#2e7d1c;
}
.alert-status.warn{
    background:#fff8e5;
    color:#8a5a00;
}
.alert-status.bad{
    background:#fff1f0;
    color:#a33127;
}
.alerts{
    display:grid;
    gap:12px;
    margin-bottom:20px;
}
.alert{
    background:#fff;
    border:1px solid #dce6f3;
    border-radius:14px;
    padding:14px 16px;
}
.alert strong{
    display:block;
    margin-bottom:4px;
}
.alert span{
    color:#486081;
}
.alert.warn{
    border-color:#f4d27a;
    background:#fffaf0;
}
.alert.bad{
    border-color:#f0aaaa;
    background:#fff6f4;
}


/* Mio v1.6 - IP alleen op Monitoring + subtielere monitoring typografie */
.monitor-card strong{
    font-size:24px;
    font-weight:700;
    letter-spacing:-0.3px;
}

.monitor-card.primary strong{
    font-size:23px;
    font-weight:700;
}

.monitor-card span{
    font-size:13px;
}

.monitor-card small{
    font-size:13px;
    line-height:1.45;
}

.monitor-card{
    padding:18px;
}


/* Mio v1.8 smooth navigation */
aside nav a.active{
    background:#eef5ff;
    border-color:#bfd3f2;
    color:#3B61AC;
}
.admin-main{
    transition:opacity .12s ease;
}
.admin-main.is-loading{
    opacity:.55;
}


/* Mio v2.1 complete monitoring */
.meter.warn-meter span{
    background:#F69220;
}
.meter.bad-meter span{
    background:#c0392b;
}
.table-card.compact th{
    width:auto;
}


/* Mio v2.2 monitoring tabs */
.tabs{
    margin-top:18px;
}
.tab-nav{
    display:flex;
    gap:8px;
    flex-wrap:wrap;
    margin-bottom:18px;
}
.tab-nav button{
    background:#fff;
    color:#00173d;
    border:1px solid #dce6f3;
    border-radius:10px;
    min-height:40px;
    padding:0 14px;
    font-weight:700;
    cursor:pointer;
}
.tab-nav button.active{
    background:#3B61AC;
    color:#fff;
    border-color:#3B61AC;
}
.tab-panel{
    display:none;
}
.tab-panel.active{
    display:block;
}


.mini-charts{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(210px,1fr));
    gap:16px;
    margin:0 0 20px;
}
.chart-card{
    background:#fff;
    border:1px solid #dce6f3;
    border-radius:18px;
    padding:18px;
    box-shadow:0 10px 24px rgba(15,31,58,.04);
}
.chart-card span{
    display:block;
    color:#3B61AC;
    font-weight:700;
    font-size:13px;
    margin-bottom:6px;
}
.chart-card strong{
    display:block;
    font-size:26px;
    line-height:1.1;
    color:#00173d;
    font-weight:700;
    margin-bottom:12px;
}
.chart-card small{
    display:block;
    color:#486081;
    font-size:12px;
    margin-top:10px;
}
.chart-line{
    height:9px;
    background:#edf2f8;
    border-radius:999px;
    overflow:hidden;
}
.chart-line i{
    display:block;
    height:100%;
    background:#71C248;
    border-radius:999px;
}
.chart-bars{
    height:44px;
    display:flex;
    align-items:end;
    gap:5px;
}
.chart-bars i{
    display:block;
    width:12px;
    background:#3B61AC;
    border-radius:6px 6px 0 0;
    opacity:.9;
}





/* Mio v2.6 - typografie hiërarchie */
body{
    font-size:14px;
    font-weight:400;
    line-height:1.5;
}

.eyebrow{
    font-size:12px !important;
    font-weight:600 !important;
    color:#486081;
    margin-bottom:2px;
}

.page-head h2{
    font-size:28px !important;
    line-height:1.15;
    font-weight:600 !important;
    color:#3B61AC;
    letter-spacing:-0.4px;
    margin:0 0 4px;
}

.page-head p{
    font-size:14px;
    font-weight:400;
    color:#243f66;
}

.table-card h3,
.form-card h3,
h3{
    font-size:20px !important;
    font-weight:600 !important;
    line-height:1.25;
    color:#00173d;
}

.card strong,
.monitor-card strong,
.chart-card strong{
    font-size:24px !important;
    font-weight:600 !important;
    line-height:1.15;
}

.card span,
.monitor-card span,
.chart-card span{
    font-size:13px;
    font-weight:600;
}

th{
    font-size:13px;
    font-weight:600;
}

td{
    font-size:14px;
    font-weight:400;
}

td strong,
.card small,
.monitor-card small,
.chart-card small{
    font-weight:400;
}

aside nav a{
    font-size:14px;
    font-weight:600;
}

button,
.button,
.small-button,
.icon-only{
    font-weight:600;
}


/* Mio v2.7 monitoring strak trekken */
.alert-summary{
    margin:18px 0 26px;
    padding:18px 20px;
}

.mini-charts{
    gap:22px;
    margin:0 0 32px;
}

.chart-card{
    min-height:170px;
    padding:22px;
}

.chart-card strong{
    margin-bottom:16px;
}

.chart-line{
    height:10px;
    margin:12px 0 12px;
}

.chart-bars{
    height:54px;
    margin-top:10px;
}

.tabs{
    margin-top:8px;
}

.tab-nav{
    display:flex;
    gap:8px;
    flex-wrap:wrap;
    margin:0 0 24px;
    padding:8px;
    background:#eef3fa;
    border:1px solid #dce6f3;
    border-radius:16px;
}

.tab-nav button{
    min-height:42px;
    padding:0 16px;
    border:0;
    border-radius:12px;
    background:transparent;
    color:#243f66;
    font-size:13px;
    font-weight:600;
    box-shadow:none;
}

.tab-nav button:hover{
    background:#fff;
}

.tab-nav button.active{
    background:#3B61AC;
    color:#fff;
    box-shadow:0 8px 18px rgba(59,97,172,.22);
}

.tab-panel{
    margin-top:0;
}

.tab-panel .table-card{
    margin-top:0;
}

.monitor-grid{
    gap:22px;
    margin-bottom:30px;
}

.monitor-card{
    padding:22px;
    min-height:145px;
}

.table-card{
    padding:24px;
}

.table-card.compact{
    padding:24px;
}

.table-card h3{
    margin-bottom:20px;
}

@media(max-width:900px){
    .mini-charts{
        gap:14px;
    }
    .tab-nav{
        display:grid;
        grid-template-columns:1fr 1fr;
    }
    .tab-nav button{
        width:100%;
    }
}


/* Mio v2.8 - formulieren klanten/resellers strak trekken */
.form-card.wide{
    max-width:none;
}

.form-row{
    display:grid;
    grid-template-columns:1fr 1fr 1fr auto;
    gap:14px;
    align-items:end;
}

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

.form-row label{
    margin-bottom:0;
}

.form-row .button,
.reseller-form-row .button{
    height:46px;
    align-self:end;
    margin-top:0;
    white-space:nowrap;
}

.form-card input,
.form-card select{
    height:46px;
}

@media(max-width:900px){
    .form-row,
    .reseller-form-row{
        display:block;
    }

    .form-row label,
    .reseller-form-row label{
        margin-bottom:14px;
    }

    .form-row .button,
    .reseller-form-row .button{
        width:100%;
    }
}


/* Mio v2.9 detailpagina's */
.row-link{
    color:#3B61AC;
    text-decoration:none;
    font-weight:600;
}
.row-link:hover{
    text-decoration:underline;
}


/* Mio v3.0 login */
.login-body{
    min-height:100vh;
    display:flex;
    align-items:center;
    justify-content:center;
    background:
        radial-gradient(circle at top right, rgba(59,97,172,.09), transparent 34%),
        #f4f7fb;
    padding:24px;
}

.login-card{
    width:100%;
    max-width:420px;
    background:#fff;
    border:1px solid #dce6f3;
    border-radius:20px;
    padding:34px;
    box-shadow:0 18px 45px rgba(15,31,58,.08);
}

.login-logo{
    margin-bottom:22px;
}

.login-logo img{
    width:150px;
    height:auto;
}

.login-card h1{
    font-size:28px;
    line-height:1.1;
    font-weight:600;
    margin:0 0 8px;
    color:#3B61AC;
}

.login-card p{
    margin:0 0 22px;
    color:#486081;
}

.login-card label{
    display:block;
    margin-bottom:16px;
    font-weight:600;
}

.login-card input{
    display:block;
    width:100%;
    height:46px;
    margin-top:7px;
    border:1px solid #cdd9eb;
    border-radius:10px;
    padding:0 12px;
}

.login-card .button{
    width:100%;
    height:46px;
    margin-top:4px;
}

.login-help{
    display:block;
    margin-top:18px;
    color:#8291a8;
}


/* Mio v3.1 install/stability */
.install-card{
    max-width:620px;
}
.install-card table{
    margin:18px 0;
}
.install-card .button{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    text-decoration:none;
}
.notice.ok{
    background:#f0fdf4;
    border-color:#bbf7d0;
    color:#14532d;
}


/* Mio v3.2 WeFact */
.settings-form{
    display:grid;
    gap:16px;
}
.settings-form label{
    display:block;
}
.tabs{
    margin-top:18px;
}
.tab-nav{
    display:flex;
    gap:8px;
    flex-wrap:wrap;
    margin:0 0 20px;
    padding:8px;
    background:#eef3fa;
    border:1px solid #dce6f3;
    border-radius:16px;
}
.tab-nav button{
    min-height:40px;
    padding:0 14px;
    border:0;
    border-radius:12px;
    background:transparent;
    color:#243f66;
    font-size:13px;
    font-weight:600;
}
.tab-nav button.active{
    background:#3B61AC;
    color:#fff;
}
.tab-panel{display:none}
.tab-panel.active{display:block}


/* Mio v3.3 klant bewerken */
.button.secondary{
    text-decoration:none;
}
.page-head{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:18px;
}
@media(max-width:900px){
    .page-head{
        display:block;
    }
    .page-head > div:last-child{
        margin-top:14px;
    }
}


/* Mio v3.7 WeFact openstaand */
.card span{
    white-space:nowrap;
}


/* Mio v3.7.3 definitieve klantenlijst */
table th:last-child,
table td:last-child{
    white-space:nowrap;
}


/* Mio v3.8 domain backup */
.button-row{
    display:flex;
    gap:10px;
    align-items:center;
    flex-wrap:wrap;
}
.notice.ok{
    background:#f0fdf4;
    border-color:#bbf7d0;
    color:#14532d;
}


/* Mio v3.9 domain tabs */
.tabs{
    margin-top:22px;
}
.tab-nav{
    display:flex;
    gap:8px;
    flex-wrap:wrap;
    margin:0 0 20px;
    padding:8px;
    background:#eef3fa;
    border:1px solid #dce6f3;
    border-radius:16px;
}
.tab-nav button{
    min-height:40px;
    padding:0 14px;
    border:0;
    border-radius:12px;
    background:transparent;
    color:#243f66;
    font-size:13px;
    font-weight:600;
}
.tab-nav button.active{
    background:#3B61AC;
    color:#fff;
}
.tab-panel{display:none}
.tab-panel.active{display:block}


/* Mio v4.0 async backup */
.backup-status{
    margin:0 0 16px;
    padding:14px 16px;
    border:1px solid #dce6f3;
    border-radius:14px;
    background:#f7faff;
}
.backup-status.running{
    border-color:#f4d27a;
    background:#fffaf0;
}
.backup-status.done{
    border-color:#bbf7d0;
    background:#f0fdf4;
}
.backup-status.error{
    border-color:#f0aaaa;
    background:#fff6f4;
}
button[disabled]{
    opacity:.55;
    cursor:not-allowed;
}


/* Mio v4.1 backup progress */
.backup-status-line{
    display:flex;
    align-items:center;
    gap:8px;
    justify-content:space-between;
    margin-bottom:10px;
}
.backup-percent{
    font-weight:600;
    color:#3B61AC;
}
.backup-progress{
    height:12px;
    background:#e8eef7;
    border-radius:999px;
    overflow:hidden;
    margin-bottom:8px;
}
.backup-progress span{
    display:block;
    height:100%;
    width:0;
    background:#71C248;
    border-radius:999px;
    transition:width .25s ease;
}
.backup-status.running .backup-progress span{
    background:#F69220;
}
.backup-status.error .backup-progress span{
    background:#c0392b;
}


/* Mio v4.3 backup cancel */
.backup-actions form{
    display:inline-flex;
    margin:0;
}
.button.secondary{
    background:#3B61AC;
    color:#fff;
}
.backup-status.cancelled{
    border-color:#dce6f3;
    background:#f7faff;
}


/* Mio v4.4 beheerpagina */
.action-bar{
    display:flex;
    gap:10px;
    margin:20px 0;
    flex-wrap:wrap;
}
.action-btn{
    display:flex;
    align-items:center;
    gap:8px;
    padding:10px 14px;
    border-radius:12px;
    background:#eef3fa;
    border:1px solid #dce6f3;
    font-size:13px;
    font-weight:600;
    cursor:pointer;
}
.action-btn:hover{
    background:#e4ebf7;
}


/* Mio v4.5 breadcrumbs */
.breadcrumb{
    display:flex;
    align-items:center;
    flex-wrap:wrap;
    gap:8px;
    margin:0 0 18px;
    color:#486081;
    font-size:13px;
    line-height:1.4;
}

.breadcrumb a{
    color:#3B61AC;
    text-decoration:none;
    font-weight:500;
}

.breadcrumb a:hover{
    text-decoration:underline;
}

.breadcrumb span{
    color:#486081;
}

.breadcrumb .breadcrumb-sep{
    color:#9aa8bb;
}

.page-head{
    margin-top:0;
}


/* Mio v4.6 domeinen overzicht */
.domain-toolbar{
    background:#fff;
    border:1px solid #dce6f3;
    border-radius:18px;
    padding:18px;
    margin:22px 0 18px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:18px;
    box-shadow:0 10px 24px rgba(15,31,58,.04);
}
.domain-toolbar strong{
    display:block;
    color:#00173d;
    font-weight:600;
}
.domain-toolbar span{
    display:block;
    color:#486081;
    font-size:13px;
}
.domain-toolbar input{
    width:min(420px,100%);
    height:44px;
    border:1px solid #cdd9eb;
    border-radius:12px;
    padding:0 14px;
}
.domain-grid{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
    gap:16px;
    margin-bottom:26px;
}
.domain-tile{
    background:#fff;
    border:1px solid #dce6f3;
    border-radius:18px;
    padding:18px;
    box-shadow:0 10px 24px rgba(15,31,58,.04);
}
.domain-tile-head{
    display:flex;
    gap:12px;
    align-items:flex-start;
    margin-bottom:16px;
}
.domain-icon{
    width:42px;
    height:42px;
    border-radius:14px;
    display:flex;
    align-items:center;
    justify-content:center;
    background:#eef5ff;
    color:#3B61AC;
    font-weight:600;
}
.domain-title{
    color:#00173d;
    font-weight:600;
    text-decoration:none;
}
.domain-title:hover{
    text-decoration:underline;
}
.domain-tile small{
    color:#486081;
    font-size:12px;
}
.domain-meta{
    display:flex;
    justify-content:space-between;
    gap:10px;
    padding:8px 0;
    border-top:1px solid #edf2f8;
}
.domain-meta span{
    color:#486081;
    font-size:12px;
}
.domain-meta strong{
    color:#00173d;
    font-size:13px;
    text-align:right;
}
.domain-actions{
    display:flex;
    gap:8px;
    margin-top:14px;
}
.domain-actions a{
    flex:1;
    min-height:38px;
    display:flex;
    align-items:center;
    justify-content:center;
    gap:6px;
    background:#f7faff;
    border:1px solid #dce6f3;
    border-radius:12px;
    color:#243f66;
    text-decoration:none;
    font-size:13px;
    font-weight:600;
}
.domain-actions a:hover{
    background:#eef5ff;
    color:#3B61AC;
}
.compact-table td,
.compact-table th{
    padding:13px 14px;
}
@media(max-width:900px){
    .domain-toolbar{
        display:block;
    }
    .domain-toolbar input{
        margin-top:14px;
        width:100%;
    }
}


/* Mio v4.7 - panelbrede overzichtsblokken */
.panel-sections{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(320px,1fr));
    gap:18px;
    margin:22px 0;
}

.panel-section{
    background:#fff;
    border:1px solid #dce6f3;
    border-radius:18px;
    padding:20px;
    box-shadow:0 10px 24px rgba(15,31,58,.04);
}

.panel-section h3{
    margin:0 0 14px;
    font-size:18px !important;
    font-weight:600 !important;
    color:#00173d;
}

.panel-tools{
    display:grid;
    grid-template-columns:1fr;
    gap:10px;
}

.panel-tool{
    display:flex;
    align-items:center;
    gap:12px;
    min-height:62px;
    padding:12px;
    border:1px solid #dce6f3;
    border-radius:14px;
    background:#f7faff;
    color:#00173d;
    text-decoration:none;
}

.panel-tool:hover{
    background:#eef5ff;
    border-color:#bfd3f2;
}

.panel-tool-icon{
    width:42px;
    height:42px;
    display:flex;
    align-items:center;
    justify-content:center;
    border-radius:12px;
    background:#fff;
    border:1px solid #dce6f3;
    font-size:18px;
    flex:0 0 auto;
}

.panel-tool strong{
    display:block;
    font-size:14px;
    font-weight:600;
    color:#00173d;
}

.panel-tool small{
    display:block;
    color:#486081;
    font-size:12px;
    line-height:1.35;
    margin-top:2px;
}

.panel-tool.disabled{
    opacity:.55;
    cursor:not-allowed;
}

.panel-tool.disabled:hover{
    background:#f7faff;
    border-color:#dce6f3;
}

.quick-panel{
    background:#fff;
    border:1px solid #dce6f3;
    border-radius:18px;
    padding:18px;
    margin:20px 0;
    box-shadow:0 10px 24px rgba(15,31,58,.04);
}

.quick-panel h3{
    margin:0 0 12px;
    font-size:18px !important;
}

.quick-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(210px,1fr));
    gap:12px;
}

.quick-tile{
    display:flex;
    gap:12px;
    align-items:center;
    min-height:70px;
    padding:14px;
    border:1px solid #dce6f3;
    border-radius:14px;
    background:#f7faff;
    text-decoration:none;
    color:#00173d;
}

.quick-tile:hover{
    background:#eef5ff;
    border-color:#bfd3f2;
}

.quick-tile .panel-tool-icon{
    width:38px;
    height:38px;
}

.quick-tile strong{
    font-size:14px;
    font-weight:600;
}

.quick-tile small{
    display:block;
    font-size:12px;
    color:#486081;
    margin-top:2px;
}


/* Mio v4.8 cache legen */
.panel-tool-form{
    margin:0;
}

.panel-tool-form .panel-tool{
    width:100%;
    text-align:left;
    cursor:pointer;
    font-family:inherit;
}

.panel-tool-form button.panel-tool{
    border:1px solid #dce6f3;
}


/* v4.9 Dashboard strak */
.dashboard-actions{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(140px,1fr));
    gap:12px;
    margin:20px 0;
}

.dashboard-action{
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    padding:16px;
    border-radius:14px;
    border:1px solid #dce6f3;
    background:#f7faff;
    text-decoration:none;
    color:#00173d;
}

.dashboard-action .icon{
    font-size:22px;
    margin-bottom:6px;
}

.dashboard-action strong{
    font-size:13px;
    font-weight:600;
}

.dashboard-status{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(140px,1fr));
    gap:10px;
    margin:20px 0;
}

.status-card{
    padding:12px;
    border-radius:12px;
    background:#fff;
    border:1px solid #e3ebf5;
}

.status-card span{
    font-size:12px;
    color:#486081;
}

.status-card strong{
    font-size:16px;
    font-weight:600;
    color:#00173d;
}

.dashboard-stats{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(120px,1fr));
    gap:10px;
    margin-top:20px;
}

.stat-box{
    text-align:center;
    padding:14px;
    border-radius:12px;
    background:#fff;
    border:1px solid #e3ebf5;
}

.stat-box strong{
    display:block;
    font-size:18px;
    font-weight:600;
}

.stat-box span{
    font-size:12px;
    color:#486081;
}


/* Mio v4.9.1 dashboard data-fix */
.status-card,
.stat-box{
    text-decoration:none;
    color:inherit;
}
.status-card small{
    display:block;
    margin-top:4px;
    font-size:12px;
    color:#486081;
}
.status-card:hover,
.stat-box:hover{
    background:#f7faff;
    border-color:#bfd3f2;
}


/* Mio v5.0.2 consistente headers */
.page-head-actions{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:20px;
}

.page-head-actions h2{
    margin-top:0;
}

.page-actions{
    display:flex;
    align-items:center;
    gap:10px;
    flex:0 0 auto;
    padding-top:4px;
}

.page-actions .button,
.page-actions .small-button{
    white-space:nowrap;
}

@media(max-width:800px){
    .page-head-actions{
        display:block;
    }
    .page-actions{
        margin-top:14px;
    }
}


/* Backup throttle + verwijderen */
.backup-row-actions{
    display:flex;
    gap:8px;
    align-items:center;
    flex-wrap:wrap;
}
.backup-row-actions form{
    margin:0;
}
.small-button.danger{
    background:#fff5f5;
    color:#b42318;
    border:1px solid #f3b4ad;
}
.small-button.danger:hover{
    background:#ffe7e5;
}


/* Plesk-achtige bestandsbeheerder */
.fm-layout{
    display:grid;
    grid-template-columns:240px minmax(0,1fr);
    gap:22px;
    align-items:start;
}

.fm-tree{
    background:#fff;
    border:1px solid #dce6f3;
    border-radius:16px;
    padding:14px;
    max-height:70vh;
    overflow:auto;
}

.fm-tree a{
    display:block;
    color:#00173d;
    text-decoration:none;
    padding:7px 8px;
    border-radius:8px;
    font-size:13px;
}

.fm-tree a:hover,
.fm-tree a.active{
    background:#eef5ff;
    color:#3B61AC;
}

.fm-tree ul{
    list-style:none;
    margin:0;
    padding-left:14px;
}

.fm-root{
    font-weight:600;
    margin-bottom:8px;
}

.fm-main{
    min-width:0;
}

.fm-toolbar{
    background:#fff;
    border:1px solid #dce6f3;
    border-radius:16px;
    padding:14px;
    margin-bottom:12px;
    display:flex;
    gap:10px;
    align-items:center;
}

.fm-upload{
    margin:0;
}

.fm-search{
    margin-left:auto;
}

.fm-search input{
    min-width:300px;
    height:40px;
    border:1px solid #cdd9eb;
    border-radius:10px;
    padding:0 12px;
}

.fm-path{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
    align-items:center;
    margin:12px 0;
    color:#486081;
    font-size:13px;
}

.fm-path a{
    color:#3B61AC;
    text-decoration:none;
}

.fm-table{
    background:#fff;
    border:1px solid #dce6f3;
    border-radius:16px;
    overflow:hidden;
}

.fm-table th,
.fm-table td{
    padding:12px 14px;
    vertical-align:middle;
}

.fm-actions{
    display:flex;
    gap:8px;
    align-items:center;
    flex-wrap:wrap;
}

.fm-actions form{
    margin:0;
}

.small-button.danger{
    background:#fff5f5;
    color:#b42318;
    border:1px solid #f3b4ad;
}

.small-button.danger:hover{
    background:#ffe7e5;
}

@media(max-width:900px){
    .fm-layout{
        grid-template-columns:1fr;
    }
    .fm-search{
        margin-left:0;
        width:100%;
    }
    .fm-search input{
        width:100%;
        min-width:0;
    }
}


/* Filemanager UI polish */
.fm-layout{
    grid-template-columns:250px minmax(0,1fr) !important;
    gap:18px !important;
}

.fm-tree{
    padding:10px !important;
    border-radius:14px !important;
    background:#fff !important;
    box-shadow:0 8px 22px rgba(15,31,58,.035);
}

.fm-tree ul{
    list-style:none !important;
    margin:0 !important;
    padding-left:10px !important;
}

.fm-tree li{
    list-style:none !important;
    margin:3px 0 !important;
    padding:0 !important;
}

.fm-tree li::marker{
    content:"" !important;
}

.fm-tree a,
.fm-root{
    min-height:34px;
    display:flex !important;
    align-items:center;
    gap:7px;
    padding:7px 10px !important;
    border-radius:10px !important;
    color:#00173d !important;
    font-size:13px !important;
    font-weight:500;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
}

.fm-tree a:hover,
.fm-tree a.active{
    background:#eef5ff !important;
    color:#3B61AC !important;
}

.fm-main{
    background:#fff;
    border:1px solid #dce6f3;
    border-radius:18px;
    padding:16px;
    box-shadow:0 10px 24px rgba(15,31,58,.04);
}

.fm-toolbar{
    border:0 !important;
    background:transparent !important;
    padding:0 0 14px !important;
    margin:0 0 10px !important;
    border-bottom:1px solid #edf2f8 !important;
    border-radius:0 !important;
}

.fm-upload-button{
    background:#3B61AC !important;
    color:#fff !important;
    border-color:#3B61AC !important;
    min-height:38px;
    display:inline-flex;
    align-items:center;
}

.fm-toolbar .small-button.ghost{
    min-height:38px;
    display:inline-flex;
    align-items:center;
}

.fm-search input{
    height:38px !important;
    min-width:330px !important;
    border-radius:10px !important;
    background:#fff !important;
}

.fm-path{
    padding:0 0 12px;
    margin:0 0 4px !important;
    border-bottom:1px solid #edf2f8;
}

.fm-path a{
    font-weight:500;
}

.fm-table{
    border:0 !important;
    border-radius:0 !important;
    box-shadow:none !important;
    width:100%;
}

.fm-table thead th{
    background:#f6f9fd !important;
    color:#00173d !important;
    font-size:12px !important;
    font-weight:600 !important;
    padding:11px 12px !important;
    border-bottom:1px solid #dce6f3 !important;
}

.fm-table tbody td{
    padding:10px 12px !important;
    border-bottom:1px solid #edf2f8 !important;
    font-size:13px !important;
    vertical-align:middle !important;
}

.fm-table tbody tr:hover{
    background:#f9fbff;
}

.fm-name-link{
    display:inline-flex;
    align-items:center;
    gap:7px;
    color:#00173d !important;
    text-decoration:none;
}

.fm-name-link:hover{
    color:#3B61AC !important;
    text-decoration:underline;
}

.fm-table code{
    display:inline-block;
    padding:3px 7px;
    border-radius:7px;
    background:#eef5ff;
    color:#3B61AC;
    font-size:12px;
}

.fm-actions{
    justify-content:flex-start;
}

.fm-actions .small-button,
.backup-row-actions .small-button{
    min-height:32px;
    padding:7px 10px;
    font-size:12px;
}

.small-button.danger{
    background:#fff !important;
    color:#b42318 !important;
    border:1px solid #f0b8b0 !important;
}

.small-button.danger:hover{
    background:#fff2f0 !important;
}

.page-head .eyebrow + h2{
    line-height:1.15;
}

@media(max-width:1000px){
    .fm-layout{
        grid-template-columns:1fr !important;
    }
    .fm-tree{
        max-height:260px !important;
    }
    .fm-toolbar{
        flex-wrap:wrap;
    }
    .fm-search{
        margin-left:0 !important;
        width:100%;
    }
    .fm-search input{
        width:100%;
        min-width:0 !important;
    }
}


/* Filemanager UI v2 - strakker en breder */
.fm-layout{
    display:grid !important;
    grid-template-columns:220px minmax(0,1fr) !important;
    gap:22px !important;
    width:100% !important;
}

.fm-tree{
    background:transparent !important;
    border:0 !important;
    box-shadow:none !important;
    padding:0 10px 0 0 !important;
    border-right:1px solid #dce6f3 !important;
    border-radius:0 !important;
    max-height:calc(100vh - 170px) !important;
}

.fm-tree a,
.fm-root{
    min-height:30px !important;
    padding:5px 8px !important;
    border-radius:8px !important;
    background:transparent !important;
    border:0 !important;
    font-size:13px !important;
}

.fm-tree a:hover,
.fm-tree a.active{
    background:#eef5ff !important;
}

.fm-tree ul{
    padding-left:14px !important;
}

.fm-main{
    width:100% !important;
    max-width:none !important;
    min-width:0 !important;
    background:#fff !important;
    border:1px solid #dce6f3 !important;
    border-radius:18px !important;
    padding:16px !important;
    box-sizing:border-box !important;
}

.fm-toolbar{
    display:flex !important;
    align-items:center !important;
    gap:10px !important;
    width:100% !important;
    box-sizing:border-box !important;
}

.fm-search{
    margin-left:auto !important;
    flex:0 0 360px !important;
}

.fm-search input{
    width:100% !important;
    min-width:0 !important;
}

.fm-table{
    width:100% !important;
    table-layout:auto !important;
}

.fm-table th:first-child,
.fm-table td:first-child{
    width:38%;
}

.fm-table th:nth-child(2),
.fm-table td:nth-child(2){
    width:150px;
}

.fm-table th:nth-child(3),
.fm-table td:nth-child(3){
    width:110px;
}

.fm-table th:nth-child(4),
.fm-table td:nth-child(4){
    width:90px;
}

.fm-table th:last-child,
.fm-table td:last-child{
    width:180px;
}

.fm-table tbody td{
    height:40px !important;
}

.fm-table .small-button{
    border-radius:9px !important;
}

.fm-actions{
    display:flex !important;
    gap:8px !important;
    justify-content:flex-start !important;
    white-space:nowrap !important;
}

@media(max-width:1100px){
    .fm-layout{
        grid-template-columns:1fr !important;
    }
    .fm-tree{
        border-right:0 !important;
        border-bottom:1px solid #dce6f3 !important;
        padding:0 0 12px !important;
    }
    .fm-toolbar{
        flex-wrap:wrap !important;
    }
    .fm-search{
        flex:1 1 100% !important;
        margin-left:0 !important;
    }
}


/* Filemanager v2.1 full width + uitklappen + chmod */
body.filemanager-page .sidebar{
    display:none !important;
}

body.filemanager-page .content,
body.filemanager-page main,
body.filemanager-page .main,
body.filemanager-page #content{
    margin-left:0 !important;
    width:100% !important;
    max-width:none !important;
}

body.filemanager-page{
    overflow-x:hidden;
}

body.filemanager-page .page-wrap,
body.filemanager-page .container{
    max-width:none !important;
}

body.filemanager-page .content{
    padding-left:28px !important;
    padding-right:28px !important;
}

.filemanager-page .fm-layout{
    grid-template-columns:270px minmax(0,1fr) !important;
    width:100% !important;
    max-width:none !important;
}

.filemanager-page .fm-main{
    width:100% !important;
    max-width:none !important;
}

.filemanager-page .fm-table{
    width:100% !important;
    min-width:980px;
}

.filemanager-page .fm-main{
    overflow-x:auto;
}

.fm-tree details{
    margin:0 !important;
    padding:0 !important;
}

.fm-tree summary{
    list-style:none !important;
    cursor:pointer;
    display:flex;
    align-items:center;
    gap:4px;
}

.fm-tree summary::-webkit-details-marker{
    display:none;
}

.fm-tree summary:before{
    content:"›";
    color:#8ca0bd;
    font-weight:600;
    width:10px;
    transform:rotate(0deg);
}

.fm-tree details[open] > summary:before{
    transform:rotate(90deg);
}

.fm-tree summary a{
    flex:1;
}

.fm-tree li{
    margin:1px 0 !important;
}

.fm-tree a,
.fm-root{
    border-radius:7px !important;
    min-height:28px !important;
    padding:4px 7px !important;
}

.chmod-form{
    display:inline-flex;
    gap:6px;
    align-items:center;
    margin:0;
}

.chmod-form input{
    width:58px;
    height:32px;
    border:1px solid #cdd9eb;
    border-radius:8px;
    padding:0 7px;
    font-size:12px;
    font-family:inherit;
}

.filemanager-page .fm-actions{
    flex-wrap:nowrap !important;
}

.filemanager-page .fm-table th:first-child,
.filemanager-page .fm-table td:first-child{
    min-width:260px;
}

.filemanager-page .fm-table th:last-child,
.filemanager-page .fm-table td:last-child{
    min-width:310px;
}

.filemanager-page .fm-toolbar{
    width:100% !important;
}

.filemanager-page .fm-search{
    flex:1 1 auto !important;
    max-width:520px;
}

.filemanager-page .fm-search input{
    width:100% !important;
}

@media(max-width:1100px){
    body.filemanager-page .content{
        padding-left:18px !important;
        padding-right:18px !important;
    }
    .filemanager-page .fm-layout{
        grid-template-columns:1fr !important;
    }
    .filemanager-page .fm-table{
        min-width:920px;
    }
}


/* Filemanager fullscreen fallback */
html.filemanager-page body .sidebar,
html.filemanager-page body .app-sidebar{
    display:none !important;
}
html.filemanager-page body .content{
    margin-left:0 !important;
    width:100vw !important;
    max-width:none !important;
}


/* Mio V007 - Plesk-achtig domeinbeheer met duidelijke tegels */
.mio-domain-hero{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:24px;
    background:#f7faff;
    border:1px solid #dce6f3;
    border-radius:18px;
    padding:24px;
    margin-bottom:22px;
}
.mio-domain-hero h2{
    margin:4px 0 6px;
    color:#2f5fb3;
    font-size:32px;
    line-height:1.1;
}
.mio-domain-hero p{
    margin:0 0 12px;
    color:#18345f;
}
.mio-domain-meta-line{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
}
.mio-domain-meta-line span{
    display:inline-flex;
    align-items:center;
    min-height:28px;
    padding:4px 10px;
    border-radius:999px;
    background:#fff;
    border:1px solid #dce6f3;
    color:#42618f;
    font-size:12px;
    font-weight:600;
}
.mio-domain-status-row{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
    gap:16px;
    margin-bottom:24px;
}
.mio-status-card{
    background:#fff;
    border:1px solid #dce6f3;
    border-radius:18px;
    padding:18px;
    box-shadow:0 10px 24px rgba(15,31,58,.04);
    min-height:118px;
}
.mio-status-card span{
    display:block;
    color:#2f5fb3;
    font-size:13px;
    font-weight:700;
    margin-bottom:8px;
}
.mio-status-card strong{
    display:block;
    color:#00173d;
    font-size:24px;
    line-height:1.15;
    margin-bottom:8px;
}
.mio-status-card small{
    color:#486081;
}
.mio-tool-section{
    background:#fff;
    border:1px solid #dce6f3;
    border-radius:18px;
    padding:22px;
    margin-bottom:20px;
    box-shadow:0 10px 24px rgba(15,31,58,.04);
}
.mio-tool-section h3{
    margin:0 0 16px;
    color:#00173d;
    font-size:21px;
}
.mio-tool-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
    gap:14px;
}
.mio-tool-card,
button.mio-tool-card{
    display:flex !important;
    align-items:center;
    gap:14px;
    min-height:86px;
    padding:16px;
    border:1px solid #dce6f3;
    border-radius:16px;
    background:#f7faff;
    color:#00173d !important;
    text-decoration:none !important;
    width:100%;
    text-align:left;
    font-family:inherit;
    cursor:pointer;
}
.mio-tool-card:hover,
button.mio-tool-card:hover{
    background:#eef5ff;
    border-color:#b7cdf0;
    transform:translateY(-1px);
}
.mio-tool-icon{
    width:48px;
    height:48px;
    display:flex;
    align-items:center;
    justify-content:center;
    flex:0 0 48px;
    border-radius:14px;
    background:#fff;
    border:1px solid #dce6f3;
    font-size:23px;
}
.mio-tool-card strong{
    display:block;
    color:#00173d;
    font-size:16px;
    font-weight:700;
    margin-bottom:4px;
}
.mio-tool-card small{
    display:block;
    color:#486081;
    font-size:13px;
    line-height:1.35;
}
.mio-tool-card-form{
    margin:0;
}
.mio-tool-card.is-disabled{
    opacity:.52;
    cursor:not-allowed;
}
.mio-tool-card.is-disabled:hover{
    transform:none;
    background:#f7faff;
    border-color:#dce6f3;
}
.domain-title,
.row-link{
    font-weight:700;
}
@media(max-width:900px){
    .mio-domain-hero{display:block}
    .mio-domain-hero .page-actions{margin-top:16px}
    .mio-tool-grid{grid-template-columns:1fr}
}


/* Mio V011 - nette formulieren voor database en WordPress */
.mio-form{
    display:grid;
    gap:18px;
    margin-top:18px;
}

.mio-form-2col{
    grid-template-columns:repeat(2,minmax(0,1fr));
    align-items:start;
}

.mio-form-section{
    display:grid;
    gap:14px;
    padding:18px;
    background:#f8fbff;
    border:1px solid #dbe6f5;
    border-radius:16px;
}

.mio-form-section h4{
    margin:0 0 4px;
    font-size:16px;
    color:var(--mio-ink,#07162f);
}

.mio-field{
    display:grid;
    gap:7px;
    margin:0;
    font-weight:700;
    color:var(--mio-ink,#07162f);
}

.mio-field span{
    display:flex;
    align-items:baseline;
    gap:8px;
    line-height:1.25;
}

.mio-field small{
    font-weight:500;
    color:#6f7f96;
}

.mio-field input,
.mio-field select,
.mio-field textarea{
    width:100%;
    box-sizing:border-box;
    min-height:46px;
    padding:10px 13px;
    border:1px solid #cdd9eb;
    border-radius:10px;
    background:#fff;
    color:var(--mio-ink,#07162f);
    font:inherit;
}

.mio-field input:focus,
.mio-field select:focus,
.mio-field textarea:focus{
    outline:none;
    border-color:#3B61AC;
    box-shadow:0 0 0 3px rgba(59,97,172,.14);
}

.mio-field-wide,
.mio-form-actions{
    grid-column:1 / -1;
}

.mio-form-actions{
    display:flex;
    justify-content:flex-start;
    gap:12px;
    margin-top:2px;
}

.mio-form-actions .button{
    min-height:46px;
}

@media(max-width:900px){
    .mio-form-2col{
        grid-template-columns:1fr;
    }

    .mio-form-actions .button{
        width:100%;
    }
}


/* Mio V012 - formulierfix: labels boven velden en rustige breedtes */
.table-card .mio-form{
    max-width:980px;
}
.table-card .mio-form-2col{
    display:grid;
    grid-template-columns:minmax(0,1fr) minmax(0,1fr);
    gap:18px;
}
.table-card .mio-form > .mio-field{
    grid-column:1 / -1;
    max-width:560px;
}
.table-card .mio-form-section .mio-field{
    max-width:none;
}
.mio-field span{
    display:block;
}
.mio-field span small{
    display:block;
    margin-top:3px;
}
.mio-field input,
.mio-field select,
.mio-field textarea{
    display:block;
    width:100%;
}
@media(max-width:980px){
    .table-card .mio-form-2col{
        grid-template-columns:1fr;
    }
}
