/* -------------------------------------------------------------------------
   League Football Site Styles
   ------------------------------------------------------------------------- */

/* -------------------------------------------------------------------------
   Theme Variables
   ------------------------------------------------------------------------- */
:root{
    --bg:#151719;

    --surface:#202428;
    --surface-hover:#333941;
    --panel:#252A30;

    --border:#41474F;

    --text:#F0F1F2;
    --muted:#A4A9AF;

    --good:#6BA36E;
    --bad:#C46A6A;

    --input:#1A1D21;
}

/* -------------------------------------------------------------------------
   Base Layout
   ------------------------------------------------------------------------- */
*{
    box-sizing:border-box;
}

body{
    margin:0;
    font-family:Arial, Helvetica, sans-serif;
    background:var(--bg);
    color:var(--text);
}

.page-layout{
    max-width:1560px;
    margin:0 auto;
    padding:8px;
}

/* -------------------------------------------------------------------------
   Panels
   ------------------------------------------------------------------------- */
.panel-grid{
    display:grid;
    grid-template-columns:1fr;
   
}

.panel{
    border:1px solid var(--border);
    border-radius:9px;
    background:var(--panel);
    padding:16px;
    margin-bottom:18px;
}

.panel-header{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:14px;
    margin-bottom:16px;
}

.panel-header h2{
    margin:0;
    font-size:20px;
    text-transform:uppercase;
    letter-spacing:.04em;
}

.panel-header span{
    color:var(--muted);
    font-size:12px;
    font-weight:800;
    text-transform:uppercase;
}

/* -------------------------------------------------------------------------
   Cards
   ------------------------------------------------------------------------- */
.card-grid{
    display:grid;
    grid-template-columns:repeat(auto-fill, minmax(120px, 1fr));
    gap:12px;
}

.card{
    border:1px solid var(--border);
    border-radius:7px;
    background:var(--surface);
}

.card-tile{
    min-height:112px;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:9px;
    padding:12px 8px;
    color:var(--muted);
    text-align:center;
    text-decoration:none;
}

.card-tag{
    min-height:5px;
    padding:12px 14px;
    display:flex;
    align-items:center;
    justify-content:center;
    gap:9px;
    padding:12px 8px;
    color:var(--muted);
    text-align:center;
    text-decoration:none;
}

.card-tile{
    min-height:112px;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:9px;
    padding:12px 8px;
}

.card:hover{
    border-color:var(--text);
    color:var(--text);
    background:var(--surface-hover);
}

.card img{
    display:block;
    width:64px;
    height:48px;
    object-fit:cover;
    border:1px solid rgba(255,255,255,.14);
    border-radius:3px;
}

.card span{
    font-size:12px;
    font-weight:800;
    line-height:1.25;
    text-transform:uppercase;
}


/* -------------------------------------------------------------------------
   Global Form Controls
   ------------------------------------------------------------------------- */
button,
select,
input[type="text"]{
    border:1px solid var(--border);
    background:var(--input);
    color:var(--text);
    border-radius:5px;
    min-height:36px;
}

button{
    cursor:pointer;
    font-weight:800;
    padding:8px 12px;
}

button:hover{
    border-color:var(--text);
    background:var(--surface-hover);
}

button:disabled{
    opacity:.45;
    cursor:not-allowed;
}

select{
    width:100%;
    height:38px;
    padding:0 10px;
}

input[type="text"]{
    width:100%;
    height:38px;
    padding:0 10px;
    font-family:Consolas, monospace;
    text-transform:uppercase;
}

select:focus,
input[type="text"]:focus{
    outline:none;
    border-color:var(--text);
    background:var(--bg);
}

input[type="text"].invalid,
.invalid{
    border-color:var(--bad);
    color:var(--bad);
}

/* -------------------------------------------------------------------------
   Global Transitions
   ------------------------------------------------------------------------- */
button,
a,
select,
input[type="text"]{
    transition:
        background-color .15s ease,
        border-color .15s ease,
        color .15s ease;
}

/* -------------------------------------------------------------------------
   Site Header
   ------------------------------------------------------------------------- */
.site-header{
    margin-bottom:18px;
    border:1px solid var(--border);
    border-radius:9px;
    background:var(--panel);
}

.site-header-inner{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:16px;
    padding:12px 16px;
}

.site-logo img{
    display:block;
    max-height:48px;
    width:auto;
}

/* -------------------------------------------------------------------------
   Desktop Navigation
   ------------------------------------------------------------------------- */
.site-nav{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
}

.site-nav a{
    padding:7px 10px;
    border:1px solid var(--border);
    border-radius:5px;
    background:var(--surface);
    color:var(--muted);
    font-size:12px;
    font-weight:700;
    text-decoration:none;
    text-transform:uppercase;
}

.site-nav a:hover,
.site-nav a.active{
    border-color:var(--text);
    background:var(--surface-hover);
    color:var(--text);
}

/* -------------------------------------------------------------------------
   Desktop Dropdowns
   ------------------------------------------------------------------------- */
.site-nav-dropdown{
    position:relative;
    display:flex;
    align-items:center;
}

.site-nav-dropdown > a{
    display:block;
}

.site-nav-dropdown-menu{
    display:none;
    position:absolute;
    top:100%;
    left:0;
    z-index:50;
    min-width:180px;
    padding:8px 6px 6px;
    border:1px solid var(--border);
    border-radius:7px;
    background:var(--surface);
    box-shadow:0 10px 24px rgba(0,0,0,.28);
}

.site-nav-dropdown:hover .site-nav-dropdown-menu{
    display:block;
}

.site-nav-dropdown-menu a{
    display:block;
    margin:0;
    padding:8px 10px;
    border:0;
    border-radius:5px;
    background:transparent;
}

.site-nav-dropdown-menu a:hover{
    background:var(--surface-hover);
    color:var(--text);
}

/* -------------------------------------------------------------------------
   Mobile Navigation
   ------------------------------------------------------------------------- */
.site-hamburger{
    display:none;
    width:40px;
    height:36px;
    border:1px solid var(--border);
    border-radius:5px;
    background:var(--surface);
    padding:0;
    cursor:pointer;
}

.site-hamburger:hover{
    border-color:var(--text);
    background:var(--surface-hover);
}

.site-hamburger span{
    display:block;
    width:18px;
    height:2px;
    background:var(--text);
    border-radius:2px;
}

.site-hamburger span + span{
    margin-top:4px;
}

.site-mobile-menu{
    display:none;
    margin:-12px 0 22px;
    border:1px solid var(--border);
    border-top:0;
    border-radius:0 0 9px 9px;
    background:var(--surface);
    padding:10px;
}

.site-mobile-menu.is-open{
    display:block;
}

.site-mobile-menu a,
.site-mobile-dropdown-toggle{
    display:block;
    width:100%;
    min-height:36px;
    padding:10px;
    border:1px solid var(--border);
    border-radius:5px;
    background:var(--surface);
    color:var(--muted);
    font-size:12px;
    font-weight:700;
    font-family:inherit;
    line-height:1.2;
    text-align:left;
    text-decoration:none;
    text-transform:uppercase;
}

.site-mobile-menu a:hover,
.site-mobile-menu a.active,
.site-mobile-dropdown-toggle:hover{
    border-color:var(--text);
    background:var(--surface-hover);
    color:var(--text);
}

.site-mobile-menu a + a,
.site-mobile-menu a + .site-mobile-dropdown,
.site-mobile-dropdown + a{
    margin-top:8px;
}

.site-mobile-dropdown-menu{
    display:none;
    margin-top:8px;
    padding-left:12px;
}

.site-mobile-dropdown-menu a + a{
    margin-top:8px;
}

.site-mobile-dropdown.is-open .site-mobile-dropdown-menu{
    display:block;
}

/* -------------------------------------------------------------------------
   Site Footer
   ------------------------------------------------------------------------- */
.site-footer{
    
    border:1px solid var(--border);
    border-radius:9px;
    background:var(--panel);
}

.site-footer-inner{
    display:flex;
    justify-content:center;
    align-items:center;
    padding:12px 16px;
    color:var(--muted);
    font-size:12px;
    font-weight:700;
    text-transform:uppercase;
    letter-spacing:.04em;
}

/* -------------------------------------------------------------------------
   Nation Profile Page
   ------------------------------------------------------------------------- */
.nation-hero{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:18px;
}

.nation-hero-main{
    display:flex;
    align-items:center;
    gap:18px;
    min-width:0;
}

.nation-hero-info h1{
    margin:0 0 10px;
    font-size:30px;
    text-transform:uppercase;
    letter-spacing:.04em;
}

.nation-profile-flag{
    width:160px;
    height:120px;
    object-fit:cover;
    border:1px solid rgba(255,255,255,.14);
    border-radius:5px;
    flex:0 0 auto;
}

.nation-meta{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
    margin-bottom:14px;
}

.nation-meta span{
    padding:6px 9px;
    border:1px solid var(--border);
    border-radius:5px;
    background:rgba(255,255,255,.03);
    color:var(--muted);
    font-size:12px;
    font-weight:800;
    text-transform:uppercase;
}

.nation-actions{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
}

.nation-actions a{
    padding:8px 11px;
    border:1px solid var(--border);
    border-radius:5px;
    background:var(--surface);
    color:var(--muted);
    font-size:12px;
    font-weight:800;
    text-decoration:none;
    text-transform:uppercase;
}

.nation-actions a:hover{
    border-color:var(--text);
    color:var(--text);
    background:var(--surface-hover);
}

.nation-info-box{
    width:320px;
    flex:0 0 320px;
    display:grid;
    grid-template-columns:1fr;
    gap:7px;
    padding:12px;
    border:1px solid var(--border);
    border-radius:7px;
    background:rgba(255,255,255,.025);
}

.nation-info-box div{
    display:flex;
    justify-content:space-between;
    gap:14px;
    padding-bottom:7px;
    border-bottom:1px solid rgba(255,255,255,.06);
}

.nation-info-box div:last-child{
    padding-bottom:0;
    border-bottom:0;
}

.nation-info-box span{
    color:var(--muted);
    font-size:11px;
    font-weight:800;
    text-transform:uppercase;
}

.nation-info-box strong{
    color:var(--text);
    font-size:12px;
    font-weight:900;
    text-align:right;
}

.is-capital{
    border-color:var(--muted);
}

.league-tiers{
    display:grid;
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:14px;
}

.league-tier-card{
    border:1px solid var(--border);
    border-radius:7px;
    background:rgba(255,255,255,.02);
    overflow:hidden;
    display:flex;
    flex-direction:column;
}

.league-tier-card h3{
    margin:0;
    padding:10px 12px;
    border-bottom:1px solid var(--border);
    background:rgba(255,255,255,.03);
    font-size:14px;
    text-transform:uppercase;
    letter-spacing:.04em;
}

.league-table{
    table-layout:fixed;
    width:100%;
}


.league-table th,
.league-table td{
    padding:7px 8px;
    border-bottom:1px solid rgba(255,255,255,.06);
    font-size:12px;
    text-align:center;
    white-space:nowrap;
}

.league-table th{
    color:var(--muted);
    text-transform:uppercase;
    
}

.league-table th:nth-child(2),
.league-table td:nth-child(2){
    width:35%;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
}

.league-table td:first-child{
    width:34px;
    color:var(--muted);
    font-weight:800;
}

.league-table a{
    color:var(--text);
    font-weight:800;
    text-decoration:none;
}

.league-table a:hover{
    color:var(--text);
}

.league-table-wrap{
    width:100%;
    overflow-x:auto;
    flex:1;
}

.league-table tr.promoted{
    background:rgba(76,175,80,.20);
}

.league-table tr.relegated{
    background:rgba(217,83,79,.20);
}
.league-table tr.qualification-champions-league{
    background:rgba(79, 88, 217, 0.2);
}
/* -------------------------------------------------------------------------
   Responsive Layout
   ------------------------------------------------------------------------- */
@media (max-width:1100px){
    .league-tiers{
        grid-template-columns:1fr;
    }
}

@media (max-width:900px){

}

@media (max-width:760px){
    .page-layout{
        padding:16px;
    }

    .site-header-inner{
        align-items:center;
    }

    .site-nav{
        display:none;
    }

    .site-hamburger{
        display:flex;
        align-items:center;
        justify-content:center;
        flex-direction:column;
    }

    .card-grid{
        grid-template-columns:repeat(auto-fill, minmax(96px, 1fr));
        gap:10px;
    }

    .card-tile{
        min-height:104px;
        padding:10px 6px;
    }

    .card-tag{
        min-height:5px;
        padding:10px 6px;
    }

    .card span{
        font-size:11px;
    }

    .nation-hero{
        display:grid;
        grid-template-columns:1fr;
        gap:16px;
        align-items:stretch;
    }

    .nation-hero-main{
        display:grid;
        grid-template-columns:1fr;
        gap:14px;
        justify-items:center;
        text-align:center;
        width:100%;
    }

    .nation-hero-info{
        width:100%;
    }

    .nation-profile-flag{
        width:128px;
        height:96px;
    }

    .nation-hero-info h1{
        font-size:28px;
        margin:0 0 12px;
    }

    .nation-meta{
        justify-content:center;
        margin-bottom:14px;
    }

    .nation-actions{
        display:grid;
        grid-template-columns:1fr;
        gap:8px;
        width:100%;
    }

    .nation-actions a{
        display:block;
        width:100%;
        text-align:center;
        padding:11px 12px;
    }

    .nation-info-box{
        width:100%;
        flex:none;
    }
    


}



