/* portal.css - harte Wiederherstellung Blau + Banner */

*{box-sizing:border-box}

body{
    margin:0;
    font-family:Arial,Helvetica,sans-serif;
    background:
        radial-gradient(circle at top left, rgba(107,182,255,.28), transparent 34%),
        linear-gradient(135deg,#f5f8fc 0%,#eaf3ff 48%,#ffffff 100%);
    color:#24364b;
}

.shell{
    max-width:1500px;
    width:calc(100% - 40px);
    margin:24px auto;
    background:#fff;
    border-radius:24px;
    overflow:hidden;
    box-shadow:0 20px 55px rgba(47,94,158,.18);
    border:1px solid rgba(107,182,255,.25);
}

/* Banner direkt im Haupt-CSS */
.header{
    background-image:url("header.jpg") !important;
    background-size:cover !important;
    background-position:center center !important;
    background-repeat:no-repeat !important;
    min-height:190px;
    padding:0 !important;
    border-bottom:1px solid rgba(47,94,158,.25);
}

.header h1,.header p,.header::after{
    display:none !important;
}

.portal{
    display:grid;
    grid-template-columns:310px minmax(0,1fr);
    min-height:580px;
}

/* Vorgänger-Blau */
.leftnav{
    background:linear-gradient(180deg,#2f5e9e,#214d83) !important;
    padding:20px;
    border-right:none !important;
}

.leftnav h3{
    color:#eaf3ff !important;
    margin:8px 12px 14px;
    text-transform:uppercase;
    letter-spacing:.08em;
    font-size:14px;
}

.leftnav a{
    display:block;
    color:#fff !important;
    text-decoration:none;
    padding:13px 15px;
    border-radius:14px;
    margin:7px 0;
    font-weight:bold;
    border:1px solid transparent !important;
    background:transparent !important;
}

.leftnav a:hover,.leftnav .admin{
    background:rgba(255,255,255,.16) !important;
    border-color:rgba(255,255,255,.22) !important;
}

.content-area{padding:34px}

.layout{display:grid;gap:28px}
.layout-right{grid-template-columns:minmax(0,1fr) 390px}
.layout-left{grid-template-columns:390px minmax(0,1fr)}
.layout-both{grid-template-columns:330px minmax(0,1fr) 330px}
.layout-none{grid-template-columns:1fr}

.card,.widget,.gallery-page{
    background:rgba(255,255,255,.96);
    border:1px solid rgba(107,182,255,.28);
    border-radius:22px;
    padding:26px;
    box-shadow:0 12px 32px rgba(47,94,158,.10);
}

.card h2,.widget h3,.gallery-page h2{
    margin-top:0;
    color:#2f5e9e !important;
    border-bottom:1px solid rgba(107,182,255,.28);
    padding-bottom:11px;
}

.content{line-height:1.68}

.content img,.inserted-image{
    max-width:100%;
    height:auto;
    border-radius:18px;
    box-shadow:0 10px 24px rgba(47,94,158,.16);
}

.content img.float-left{float:left;width:280px;max-width:45%;margin:5px 22px 14px 0}
.content img.float-right{float:right;width:280px;max-width:45%;margin:5px 0 14px 22px}
.content img.image-center{display:block;width:480px;max-width:100%;margin:16px auto}

.sidebar{display:flex;flex-direction:column;gap:18px;min-width:0}

.widget,.widget-html,.widget-weather,.widget-embed{overflow:visible}
.widget iframe,.widget table,.widget div,.widget script,.widget link{max-width:100%}
.widget [id^="wcom-"]{max-width:100%!important;width:100%!important}
.wcom-default,.w300x250{max-width:100%!important}

.public-gallery{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(230px,1fr));
    gap:20px;
    margin-top:22px;
}

.public-gallery a{
    display:block;
    text-decoration:none;
    color:#24364b;
    background:#fff;
    border:1px solid rgba(107,182,255,.28);
    border-radius:20px;
    overflow:hidden;
    box-shadow:0 10px 26px rgba(47,94,158,.12);
    transition:transform .15s ease,box-shadow .15s ease;
}

.public-gallery a:hover{transform:translateY(-4px);box-shadow:0 16px 36px rgba(47,94,158,.22)}
.public-gallery img{width:100%;height:185px;object-fit:cover;display:block}
.public-gallery span{display:block;padding:13px;font-weight:bold}

.mini-gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.mini-gallery div{
    height:88px;border-radius:12px;background:linear-gradient(135deg,#e3f2ff,#6bb6ff);
    display:flex;align-items:center;justify-content:center;color:#2f5e9e;font-weight:bold;font-size:13px;
}

.footer{
    display:flex;
    justify-content:space-between;
    background:#f5f8fc !important;
    border-top:1px solid rgba(107,182,255,.26);
    padding:18px 32px;
    color:#56708d !important;
}

@media(max-width:1100px){
    .shell{width:100%;margin:0;border-radius:0}
    .portal{grid-template-columns:1fr}
    .layout,.layout-right,.layout-left,.layout-both{grid-template-columns:1fr}
    .footer{display:block}
    .header{min-height:120px}
}

/* Adminbereich */
.admin-body{
    background:radial-gradient(circle at top left,rgba(107,182,255,.28),transparent 34%),linear-gradient(135deg,#f5f8fc,#fff);
}

.admin-box,.admin-panel{
    background:#fff;
    border:1px solid rgba(107,182,255,.28);
    border-radius:20px;
    padding:24px;
    box-shadow:0 12px 32px rgba(47,94,158,.12);
}

.admin-box{max-width:1100px;margin:40px auto}

.admin-layout{
    display:grid;
    grid-template-columns:270px 1fr;
    min-height:100vh;
}

.admin-sidebar{
    background:linear-gradient(180deg,#2f5e9e,#214d83) !important;
    color:#fff;
    padding:24px;
    border-right:none !important;
}

.admin-sidebar a{
    display:block;
    color:#fff;
    text-decoration:none;
    padding:12px;
    border-radius:12px;
    margin:5px 0;
}

.admin-sidebar a:hover,.admin-sidebar a.active{background:rgba(255,255,255,.16)!important}
.admin-main{padding:28px}

.button,button{
    display:inline-block;
    background:linear-gradient(135deg,#4a90e2,#6bb6ff) !important;
    color:#fff !important;
    border:0;
    border-radius:12px;
    padding:11px 15px;
    text-decoration:none;
    font-weight:bold;
    cursor:pointer;
}

.button.secondary{background:#56708d !important;color:#fff}
.button.danger{background:#d94c4c !important;color:#fff}

input,textarea,select{
    width:100%;
    padding:11px;
    border:1px solid rgba(107,182,255,.38);
    border-radius:12px;
    font:inherit;
    background:#fbfdff;
}

label{font-weight:bold;display:block;margin:12px 0 6px}
.hint{color:#56708d;font-size:14px}
.ok{background:#ecfdf3;color:#166534;padding:10px;border-radius:10px}
.bad{background:#fee2e2;color:#991b1b;padding:10px;border-radius:10px}

.table{width:100%;border-collapse:collapse}
.table th,.table td{padding:10px;border-bottom:1px solid rgba(107,182,255,.24);text-align:left;vertical-align:top}

.grid{display:grid;grid-template-columns:repeat(4,minmax(150px,1fr));gap:18px}
.stat{
    background:#fff;border:1px solid rgba(107,182,255,.28);border-radius:18px;padding:24px;
    box-shadow:0 10px 26px rgba(47,94,158,.10);
}
.stat strong{font-size:38px;color:#4a90e2!important;display:block}

.image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:16px}
.image-card{border:1px solid rgba(107,182,255,.28);border-radius:16px;padding:12px;background:#fff}
.image-card img{width:100%;height:130px;object-fit:cover;border-radius:12px;background:#f3f8ff}
.codebox{
    font-family:Consolas,monospace;font-size:12px;background:#f5f8fc;border:1px solid rgba(107,182,255,.25);
    border-radius:8px;padding:8px;word-break:break-all;margin-top:8px;
}
.toolbar-note,.html-warning{
    background:#eef7ff;border:1px solid rgba(107,182,255,.38);color:#2f5e9e;
    border-radius:12px;padding:12px;margin:12px 0;
}
