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

*{
    margin:0;
    padding:0;
    box-sizing:border-box;
    font-family:'Inter',sans-serif;
}

body{
    background:#f4f7f6;
    color:#071421;
}

a{
    text-decoration:none;
    color:inherit;
}

/* =========================
   HEADER
========================= */

.topbar{
    background:#071421;
    color:#fff;
    display:flex;
    justify-content:space-between;
    align-items:center;
    padding:18px 34px;
    position:sticky;
    top:0;
    z-index:999;
    box-shadow:0 8px 25px rgba(0,0,0,.18);
}

.brand{
    display:flex;
    flex-direction:column;
    font-weight:900;
    color:#23d46b;
    font-size:30px;
    line-height:1;
}

.brand small{
    font-size:14px;
    letter-spacing:6px;
    margin-top:7px;
}

.topbar nav{
    display:flex;
    gap:10px;
    flex-wrap:wrap;
}

.topbar nav a{
    padding:12px 15px;
    border-radius:13px;
    font-weight:700;
    color:#fff;
    transition:.2s;
}

.topbar nav a:hover{
    background:#129947;
}

.tip-link{
    background:linear-gradient(90deg,#078839,#18aa51);
}

/* =========================
   HERO
========================= */

.hero{
    position:relative;
    min-height:430px;
    padding:42px 34px;

    display:grid;
    grid-template-columns:280px 1fr 270px;
    gap:28px;
    align-items:center;

    color:#fff;
    overflow:hidden;

    background:
    radial-gradient(circle at 50% 10%,rgba(38,220,107,.25),transparent 30%),
    linear-gradient(180deg,rgba(4,12,22,.82),rgba(4,12,22,.9)),
    linear-gradient(135deg,#071421 0%,#0c2035 45%,#0d4d22 100%);
}

.hero:before{
    content:"";
    position:absolute;
    inset:0;

    background:
    linear-gradient(
        transparent 66%,
        rgba(31,126,47,.7) 67%,
        rgba(12,70,28,.95) 100%
    ),

    repeating-linear-gradient(
        90deg,
        rgba(255,255,255,.04) 0 1px,
        transparent 1px 120px
    );
}

.hero>*{
    position:relative;
    z-index:1;
}

.hero-left h1{
    font-size:32px;
    line-height:1.15;
}

.hero-left h1 span{
    display:block;
    font-size:58px;
    color:#23d46b;
}

/* =========================
   BOXEN
========================= */

.rank-card,
.live-box{
    background:rgba(7,20,33,.82);
    border:1px solid rgba(255,255,255,.18);
    border-radius:18px;
    padding:22px;
    backdrop-filter:blur(6px);
}

.rank-card strong{
    display:block;
    color:#2ee475;
    font-size:34px;
    margin:10px 0 4px;
}

.rank-card span{
    color:#2ee475;
    font-weight:800;
}

.live-box{
    line-height:1.5;
}

.live-box strong{
    color:#2ee475;
}

/* =========================
   PODIUM
========================= */

.podium-area{
    text-align:center;
}

.podium-area h2{
    font-size:22px;
    margin-bottom:20px;
}

.podium{
    display:flex;
    justify-content:center;
    align-items:flex-end;
    gap:14px;
}

.podium-card{
    width:190px;
    background:#fff;
    color:#071421;
    border-radius:18px 18px 8px 8px;
    overflow:hidden;
    box-shadow:0 20px 45px rgba(0,0,0,.3);
}

.gold{
    border-top:5px solid #ffd84d;
}

.silver{
    border-top:5px solid #cfd6dc;
}

.bronze{
    border-top:5px solid #d3832b;
}

.avatar{
    width:72px;
    height:72px;
    border-radius:50%;
    background:linear-gradient(145deg,#dff8ea,#9dd9ff);
    display:flex;
    align-items:center;
    justify-content:center;
    margin:16px auto;
    font-size:28px;
    font-weight:900;
}

.podium-content{
    padding:16px;
}

.podium-content h3{
    margin-bottom:6px;
}

.step{
    height:54px;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:28px;
    font-weight:900;
    background:linear-gradient(180deg,#ffd84d,#cc8f08);
}

/* =========================
   DASHBOARD
========================= */

.dashboard{
    width:min(1500px,96%);
    margin:26px auto;
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:24px;
}

.panel{
    background:#fff;
    border-radius:18px;
    overflow:hidden;
    border:1px solid #e1e8e4;
    box-shadow:0 18px 45px rgba(7,20,33,.09);
}

.panel-head{
    display:flex;
    justify-content:space-between;
    align-items:center;
    padding:18px 22px;
    color:#fff;
}

.green{
    background:linear-gradient(90deg,#078839,#18aa51);
}

.dark{
    background:#071421;
}

.panel-body{
    padding:22px;
}

.match-row{
    display:grid;
    grid-template-columns:120px 1fr 80px 1fr 80px;
    gap:14px;
    align-items:center;
    padding:16px 0;
    border-bottom:1px solid #edf1ef;
}

.team{
    font-weight:800;
}

.right{
    text-align:right;
}

.versus{
    text-align:center;
    color:#71808c;
    font-weight:700;
}

.countdown{
    background:#edf9f1;
    border:1px solid #d4eadc;
    border-radius:8px;
    color:#078839;
    text-align:center;
    padding:8px;
    font-weight:900;
}

/* =========================
   BUTTONS
========================= */

.primary-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;

    background:linear-gradient(90deg,#078839,#18aa51);
    color:#fff;

    border:none;
    border-radius:14px;

    padding:14px 20px;
    font-weight:900;

    cursor:pointer;
}

/* =========================
   FOOTER
========================= */

.footer{
    text-align:center;
    color:#71808c;
    padding:30px;
}

/* =========================
   MOBILE
========================= */

@media(max-width:1050px){

    .topbar{
        flex-direction:column;
        align-items:flex-start;
        gap:18px;
    }

    .hero{
        grid-template-columns:1fr;
    }

    .dashboard{
        grid-template-columns:1fr;
    }

    .podium{
        flex-direction:column;
        align-items:center;
    }

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

    .right{
        text-align:left;
    }

/* === Tipps-Seite Fix === */
.tips-page{
    max-width:1200px;
}

.tips-form{
    display:grid;
    gap:14px;
    margin-top:22px;
}

.tip-card{
    display:grid;
    grid-template-columns:150px 1fr 180px;
    gap:18px;
    align-items:center;
    padding:18px;
    border:1px solid #e1e8e4;
    border-radius:18px;
    background:#fbfdfc;
}

.tip-date strong{
    display:block;
    color:#071421;
    font-weight:900;
}

.tip-date span{
    color:#607080;
    font-weight:700;
    font-size:14px;
}

.tip-teams{
    display:grid;
    grid-template-columns:1fr auto 1fr;
    gap:14px;
    align-items:center;
    font-size:18px;
}

.tip-teams strong:first-child{
    text-align:right;
}

.tip-teams strong:last-child{
    text-align:left;
}

.tip-teams span{
    color:#73808a;
    font-size:13px;
    text-transform:uppercase;
    font-weight:900;
    text-align:center;
}

.tip-inputs{
    display:flex;
    align-items:center;
    justify-content:flex-end;
    gap:8px;
}

.tip-inputs input{
    width:68px;
    padding:12px;
    border:1px solid #cfded6;
    border-radius:12px;
    text-align:center;
    font-size:20px;
    font-weight:900;
    background:#fff;
}

.submit-tips{
    margin-top:10px;
    width:max-content;
    font-size:17px;
}

@media(max-width:850px){
    .tip-card{
        grid-template-columns:1fr;
        gap:12px;
    }

    .tip-teams{
        grid-template-columns:1fr;
        gap:6px;
    }

    .tip-teams strong:first-child,
    .tip-teams strong:last-child,
    .tip-teams span{
        text-align:left;
    }

    .tip-inputs{
        justify-content:flex-start;
    }

    .submit-tips{
        width:100%;
    }
/* =========================================================
   MOBILE FIX: Letzte Ergebnisse + Nächste Spiele + Rangliste
   Ganz unten in /assets/style.css einfügen
========================================================= */

@media (max-width: 800px){

    body{
        background:#f4f7f6;
    }

    .dashboard{
        width:94% !important;
        margin:18px auto !important;
        display:block !important;
    }

    .panel{
        border-radius:22px !important;
        margin-bottom:18px !important;
        overflow:hidden !important;
        box-shadow:0 16px 35px rgba(7,20,33,.12) !important;
        border:1px solid #e1e8e4 !important;
        background:#fff !important;
    }

    .panel-head{
        display:flex !important;
        flex-direction:row !important;
        align-items:center !important;
        justify-content:space-between !important;
        gap:12px !important;
        padding:18px 18px !important;
        min-height:auto !important;
    }

    .panel-head h2{
        font-size:24px !important;
        line-height:1.15 !important;
        margin:0 !important;
        text-transform:none !important;
        max-width:70% !important;
    }

    .panel-head a{
        font-size:15px !important;
        white-space:nowrap !important;
        opacity:.95 !important;
    }

    .empty{
        padding:18px !important;
        font-size:16px !important;
        color:#607080 !important;
    }

    .match-row{
        display:grid !important;
        grid-template-columns:1fr !important;
        gap:10px !important;
        padding:18px !important;
        border-bottom:1px solid #edf1ef !important;
    }

    .match-row:last-child{
        border-bottom:0 !important;
    }

    .match-row .date{
        font-size:16px !important;
        color:#314052 !important;
        font-weight:900 !important;
    }

    .match-row .date small{
        display:block !important;
        margin-top:2px !important;
        font-size:14px !important;
        color:#607080 !important;
    }

    .match-row .team{
        font-size:20px !important;
        font-weight:900 !important;
        text-align:left !important;
        color:#071421 !important;
    }

    .match-row .versus{
        text-align:left !important;
        color:#73808a !important;
        font-size:15px !important;
        font-weight:900 !important;
        text-transform:uppercase !important;
    }

    .match-row .score,
    .match-row .countdown{
        display:inline-flex !important;
        justify-content:center !important;
        align-items:center !important;
        width:100% !important;
        min-height:46px !important;
        border-radius:14px !important;
        font-size:18px !important;
        background:#edf9f1 !important;
        color:#078839 !important;
        font-weight:900 !important;
    }

    .match-row .ok{
        display:none !important;
    }

    /* Rangliste auf der Startseite mobil als Karten statt kaputte Tabelle */
    .ranking-panel{
        width:94% !important;
        margin:22px auto 36px !important;
        border-radius:22px !important;
        overflow:hidden !important;
        background:#fff !important;
        box-shadow:0 16px 35px rgba(7,20,33,.12) !important;
        border:1px solid #e1e8e4 !important;
    }

    .ranking-head{
        display:flex !important;
        flex-direction:row !important;
        justify-content:space-between !important;
        align-items:center !important;
        gap:12px !important;
        padding:18px !important;
        background:#fff !important;
    }

    .ranking-head h2{
        font-size:28px !important;
        line-height:1.1 !important;
        margin:0 !important;
        text-transform:none !important;
    }

    .ranking-head a{
        font-size:15px !important;
        border:1px solid #d5e6dc !important;
        border-radius:14px !important;
        padding:10px 12px !important;
        white-space:nowrap !important;
        background:#eef6f1 !important;
        color:#071421 !important;
    }

    .ranking-panel table,
    .ranking-panel thead,
    .ranking-panel tbody,
    .ranking-panel tr,
    .ranking-panel th,
    .ranking-panel td{
        display:block !important;
        width:100% !important;
        min-width:0 !important;
    }

    .ranking-panel thead{
        display:none !important;
    }

    .ranking-panel tbody{
        padding:0 14px 14px !important;
    }

    .ranking-panel tr{
        position:relative !important;
        background:#fbfdfc !important;
        border:1px solid #e1e8e4 !important;
        border-radius:18px !important;
        margin:0 0 12px !important;
        padding:16px !important;
    }

    .ranking-panel tr.leader{
        background:linear-gradient(90deg,#eaf8ee,#fff) !important;
        border-color:#bfe8cc !important;
    }

    .ranking-panel td{
        border:0 !important;
        padding:4px 0 !important;
        font-size:16px !important;
    }

    .ranking-panel td:nth-child(1){
        position:absolute !important;
        right:16px !important;
        top:16px !important;
        width:auto !important;
        font-size:24px !important;
        font-weight:900 !important;
        color:#078839 !important;
    }

    .ranking-panel td:nth-child(2){
        font-size:20px !important;
        font-weight:900 !important;
        padding-right:60px !important;
        display:flex !important;
        align-items:center !important;
        gap:10px !important;
    }

    .ranking-panel td:nth-child(3)::before{
        content:"Parzelle: ";
        font-weight:800;
        color:#607080;
    }

    .ranking-panel td:nth-child(4)::before{
        content:"Punkte: ";
        font-weight:800;
        color:#607080;
    }

    .ranking-panel td:nth-child(4) strong{
        font-size:22px !important;
        color:#078839 !important;
    }

    .mini-avatar{
        width:42px !important;
        height:42px !important;
        min-width:42px !important;
        font-size:15px !important;
        margin:0 !important;
    }
}

@media (max-width: 420px){
    .panel-head h2{
        font-size:22px !important;
    }

    .ranking-head{
        flex-direction:column !important;
        align-items:flex-start !important;
    }

    .ranking-head h2{
        font-size:26px !important;
    }

    .ranking-head a{
        width:100% !important;
        text-align:center !important;
    }
}

