*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}
:root{
    --bg:#eef6ea;
    --card:#ffffff;
    --card-soft:#f7fff4;
    --line:#e6efe2;
    --text:#1e1e1e;
    --muted:#6a746c;
    --green:#39b54a;
    --green-dark:#2d963c;
    --green-soft:#e4f7de;
    --shadow:0 10px 30px rgba(0,0,0,.05);
    --radius-xl:30px;
    --radius-lg:24px;
    --radius-md:18px;
    --radius-sm:14px;
}
body{
    font-family:'Inter',sans-serif;
    background:var(--bg);
    color:var(--text);
}
.container{
    width:92%;
    max-width:1400px;
    margin:30px auto;
}
.navbar{
    width:92%;
    max-width:1400px;
    margin:30px auto 0;
    background:#fff;
    border-radius:24px;
    padding:20px 35px;
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:20px;
    box-shadow:var(--shadow);
}
.logo{
    display:flex;
    align-items:center;
    gap:0;
    flex-shrink:0;
}
.logo a{display:inline-flex;align-items:center;}
.logo img{width:200px;max-width:100%;display:block;}
nav ul{
    display:flex;
    list-style:none;
    gap:30px;
    flex-wrap:wrap;
    justify-content:center;
}
nav ul li a{
    text-decoration:none;
    color:#6c6c6c;
    font-weight:700;
    transition:.25s ease;
}
nav ul li a.active,
nav ul li a:hover{color:#2db24a;}
.nav-buttons{
    display:flex;
    gap:14px;
    flex-wrap:wrap;
    justify-content:flex-end;
}
.btn{
    appearance:none;
    border:none;
    cursor:pointer;
    text-decoration:none;
    border-radius:14px;
    padding:14px 24px;
    font-weight:900;
    transition:.25s ease;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    font-size:15px;
}
.btn-primary{
    background:var(--green);
    color:#fff;
}
.btn-primary:hover{background:var(--green-dark);}
.btn-outline{
    border:2px solid #d9ead7;
    color:#2db24a;
    background:#fff;
}
.btn-outline:hover{
    background:#f6fff3;
}
.btn-light{
    background:#fff;
    color:#1e1e1e;
    border:1px solid #ddd;
}
.btn-soft{
    background:#f6fbf4;
    color:#27402c;
    border:1px solid #e5efe0;
}
.btn-danger{
    background:#e95e5e;
    color:white;
}
.large{padding:16px 28px;}
.full{width:100%;}
.badge{
    display:inline-block;
    background:var(--green-soft);
    color:#2f9f44;
    padding:8px 14px;
    border-radius:999px;
    font-size:13px;
    font-weight:800;
    margin-bottom:18px;
}
.flash{
    border-radius:18px;
    padding:16px 18px;
    margin-bottom:18px;
    font-weight:700;
    box-shadow:var(--shadow);
}
.flash-success{background:#eafbe7;color:#256932;}
.flash-error{background:#fdeceb;color:#a23232;}
.flash-info{background:#edf6ff;color:#245484;}
.hero,
.offers-hero,
.dashboard-hero,
.auth-shell,
.checkout-shell,
.profile-grid,
.billing-grid,
.dashboard-grid,
.info-grid,
.stats-row,
.compare-section,
.faq-section,
.simple-card,
.panel-card,
.orders-card,
.section-card,
.table-card,
.form-card,
.mode-picker,
.auth-card,
.checkout-card{
    box-shadow:var(--shadow);
}
.hero{
    margin-top:25px;
    background:linear-gradient(135deg,#f5fff2,#dff4df);
    border-radius:30px;
    padding:60px;
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:50px;
}
.hero-content{flex:1;}
.hero-content h1{
    font-size:72px;
    line-height:1.05;
    font-weight:800;
    margin-bottom:25px;
}
.hero-content h1 span{color:var(--green);}
.hero-content p{
    font-size:20px;
    color:#666;
    margin-bottom:30px;
    line-height:1.7;
}
.hero-buttons{
    display:flex;
    gap:18px;
    margin-bottom:35px;
    flex-wrap:wrap;
}
.hero-image img{width:100%;max-width:520px;}
.features-row{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:15px;
}
.feature-box{
    background:white;
    padding:18px;
    border-radius:16px;
    text-align:center;
    font-size:18px;
    font-weight:700;
    box-shadow:0 4px 12px rgba(0,0,0,0.04);
}
.servers-section{
    display:grid;
    grid-template-columns:2fr 1fr;
    gap:25px;
    margin-top:30px;
}
.servers-list,.pricing-box,.stats-section,.compare-section,.faq-section,.section-card,.table-card,.simple-card,.panel-card,.orders-card,.form-card{
    background:#f7fff4;
    border-radius:28px;
    padding:30px;
}
.cards-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:20px;
    margin-top:25px;
}
.server-card{
    background:white;
    border-radius:20px;
    overflow:hidden;
    box-shadow:var(--shadow);
}
.server-card img{
    width:100%;
    height:180px;
    object-fit:cover;
}
.card-content{padding:18px;}
.card-content h3{margin-bottom:10px;}
.meta{
    display:flex;
    justify-content:space-between;
    color:#888;
    font-size:14px;
    margin-bottom:10px;
}
.pricing-box h3,
.section-title h2,
.cards-title{
    font-size:34px;
    line-height:1.15;
}
.pricing-box ul{
    list-style:none;
    margin:25px 0;
}
.pricing-box ul li{
    margin-bottom:14px;
    color:#444;
}
.big-feature-section,
.features-grid{
    margin-top:30px;
}
.big-feature-section{
    display:grid;
    grid-template-columns:1fr 1.2fr;
    gap:25px;
    align-items:center;
    background:#fff;
    border-radius:28px;
    padding:30px;
    box-shadow:var(--shadow);
}
.big-feature-image img{
    width:100%;
    border-radius:20px;
}
.big-feature-content h2{
    font-size:42px;
    margin-bottom:16px;
}
.big-feature-content p{
    color:#5f6a61;
    line-height:1.7;
    margin-bottom:16px;
}
.big-feature-content ul{
    padding-left:18px;
    color:#425246;
    line-height:1.8;
}
.features-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:20px;
}
.feature-card{
    background:#fff;
    border-radius:24px;
    padding:24px;
    box-shadow:var(--shadow);
}
.feature-card img{
    width:72px;
    height:72px;
    object-fit:contain;
    margin-bottom:18px;
}
.feature-card h3{
    font-size:22px;
    margin-bottom:10px;
}
.feature-card p{
    color:#5f6a61;
    line-height:1.7;
}
.offers-page{padding-bottom:40px;}
.offers-hero{
    margin-top:25px;
    background:linear-gradient(135deg,#f5fff2,#dff4df);
    border-radius:30px;
    padding:45px;
    display:grid;
    grid-template-columns:2fr 1fr;
    gap:25px;
    align-items:center;
}
.offers-hero h1{font-size:48px;line-height:1.1;margin-bottom:18px;}
.offers-hero p{color:#5f6a61;font-size:18px;line-height:1.7;max-width:800px;}
.offers-hero-card{
    background:#fff;
    border-radius:24px;
    padding:30px;
    text-align:center;
}
.offers-hero-card p{font-size:15px;margin-bottom:8px;}
.offers-hero-card h2{font-size:50px;color:#2db24a;margin-bottom:8px;}
.offers-hero-card h2 span{font-size:20px;color:#666;}
.offer-image{
    width:100%;
    object-fit:contain;
    display:block;
    margin:0 auto 20px;
    max-height:180px;
}
.pricing-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:24px;
    margin-top:30px;
}
.pricing-card{
    position:relative;
    background:#fff;
    border-radius:28px;
    padding:30px;
    box-shadow:var(--shadow);
    border:1px solid #edf3eb;
    display:flex;
    flex-direction:column;
}
.pricing-card.featured{
    border:2px solid var(--green);
    transform:translateY(-6px);
}
.popular-tag{
    position:absolute;
    top:18px;
    right:18px;
    background:var(--green);
    color:white;
    font-size:12px;
    font-weight:800;
    padding:8px 12px;
    border-radius:999px;
}
.pricing-card h3{font-size:28px;margin-bottom:14px;}
.price{font-size:46px;font-weight:800;color:#1f2b21;margin-bottom:22px;}
.price span{font-size:18px;font-weight:600;color:#6f6f6f;}
.specs{display:grid;gap:12px;margin-bottom:25px;}
.spec-item{
    background:#f6fbf4;
    border:1px solid #e7f0e3;
    border-radius:14px;
    padding:12px 14px;
    font-weight:700;
    color:#334236;
}
.pricing-card ul{
    list-style:none;
    margin-bottom:24px;
}
.pricing-card ul li{
    position:relative;
    padding-left:24px;
    margin-bottom:14px;
    color:#4f5a51;
}
.pricing-card ul li::before{
    content:'✔';
    position:absolute;
    left:0;
    top:0;
    color:var(--green);
    font-weight:800;
}
.card-footer-cta{margin-top:auto;}
.compare-table-wrapper{overflow-x:auto;}
.compare-table{
    width:100%;
    border-collapse:collapse;
    background:white;
    border-radius:20px;
    overflow:hidden;
}
.compare-table th,.compare-table td{
    padding:18px 20px;
    border-bottom:1px solid #edf2ea;
    text-align:left;
}
.compare-table th{
    background:#eef9ea;
    color:#27402c;
    font-size:15px;
}
.faq-grid{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:20px;
}
.faq-card{
    background:white;
    border-radius:22px;
    padding:24px;
    box-shadow:var(--shadow);
}
.faq-card h3{font-size:20px;margin-bottom:10px;}
.faq-card p{color:#5f6a61;line-height:1.7;}
.servers-hero{
    margin-top:25px;
    background:linear-gradient(135deg,#f5fff2,#dff4df);
    border-radius:30px;
    padding:45px;
    display:grid;
    grid-template-columns:2fr 1fr;
    gap:25px;
    align-items:center;
}
.servers-hero h1{font-size:48px;line-height:1.1;margin-bottom:18px;}
.servers-hero p{color:#5f6a61;font-size:18px;line-height:1.7;}
.servers-hero-card{
    background:#fff;
    border-radius:24px;
    padding:30px;
    text-align:center;
}
.servers-hero-card h2{font-size:42px;color:var(--green);}
.servers-filters{
    display:flex;
    gap:12px;
    flex-wrap:wrap;
    margin-top:20px;
}
.filter-chip{
    background:#fff;
    border:1px solid #dfead9;
    color:#48614e;
    border-radius:999px;
    padding:10px 18px;
    font-weight:800;
    cursor:pointer;
}
.filter-chip.active{background:var(--green);color:#fff;border-color:var(--green);}
.servers-grid-page{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:20px;
    margin-top:24px;
}
.server-page-card{
    background:#fff;
    border-radius:24px;
    overflow:hidden;
    box-shadow:var(--shadow);
}
.server-image-wrap{position:relative;}
.server-image-wrap img{
    width:100%;
    height:220px;
    object-fit:cover;
}
.server-status{
    position:absolute;
    top:16px;
    right:16px;
    background:#fff;
    color:#246d31;
    padding:8px 12px;
    border-radius:999px;
    font-size:12px;
    font-weight:900;
}
.server-page-content{padding:24px;}
.server-top-meta{
    display:flex;
    justify-content:space-between;
    gap:12px;
    align-items:center;
    margin-bottom:12px;
}
.server-top-meta h3{font-size:24px;}
.server-category{
    background:#edf7ea;
    color:#2f8c40;
    padding:7px 10px;
    border-radius:999px;
    font-size:12px;
    font-weight:800;
}
.server-meta-line{
    display:flex;
    justify-content:space-between;
    gap:8px;
    color:#657267;
    font-size:14px;
    margin-bottom:14px;
}
.server-page-content p{
    color:#59655b;
    line-height:1.7;
    margin-bottom:18px;
}
.server-actions{
    display:flex;
    gap:12px;
    flex-wrap:wrap;
}
.auth-page{
    width:92%;
    max-width:1080px;
    margin:30px auto;
}
.auth-topbar{
    display:flex;
    justify-content:flex-start;
    margin-bottom:18px;
}
.auth-back{
    text-decoration:none;
    color:#2f8f41;
    font-weight:800;
}
.auth-card{
    background:#fff;
    border-radius:30px;
    overflow:hidden;
    display:grid;
    grid-template-columns:1fr 1fr;
    min-height:640px;
}
.auth-banner{
    background:linear-gradient(135deg,#2fb64d,#73d56a);
    color:#fff;
    padding:45px;
    position:relative;
    display:flex;
    align-items:flex-end;
}
.auth-banner::after{
    content:'';
    position:absolute;
    inset:0;
    background:url('../images/mascotte2.webp') no-repeat right 30px bottom 30px/260px auto;
    opacity:.16;
}
.auth-banner-content{
    position:relative;
    z-index:1;
    max-width:420px;
}
.auth-banner h2{
    font-size:38px;
    line-height:1.1;
    margin-bottom:16px;
}
.auth-banner p{
    line-height:1.7;
    color:rgba(255,255,255,.92);
}
.auth-panel{
    padding:34px;
    background:#fff;
}
.auth-tabs{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:10px;
    margin-bottom:22px;
}
.auth-tab-btn{
    border:none;
    border-radius:16px;
    background:#f2f7f0;
    color:#5c685e;
    padding:14px;
    font-weight:900;
    cursor:pointer;
}
.auth-tab-btn.active{
    background:var(--green);
    color:#fff;
}
.form-view{display:none;}
.form-view.active{display:block;}
.status-message{
    border-radius:16px;
    padding:14px 16px;
    margin-bottom:18px;
    font-weight:700;
    display:flex;
    gap:10px;
    align-items:flex-start;
}
.status-message.success{background:#ecfbe7;color:#286f33;}
.status-message.error{background:#fdeceb;color:#a23232;}
.auth-grid{
    display:grid;
    gap:16px;
}
.field-row-2{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:16px;
}
.form-group label{
    display:block;
    margin-bottom:8px;
    font-size:14px;
    font-weight:800;
    color:#2f3e31;
}
.input-wrap{
    background:#fff;
    border:1px solid #dfe8db;
    border-radius:16px;
    padding:0 14px;
}
.form-control{
    width:100%;
    border:none;
    padding:16px 0;
    font-size:15px;
    outline:none;
    background:transparent;
}
.field-error{
    color:#c24343;
    font-size:13px;
    font-weight:700;
    margin-top:8px;
}
.helper-row{
    display:flex;
    justify-content:space-between;
    gap:14px;
    align-items:center;
    flex-wrap:wrap;
}
.remember-check,.terms-check{
    display:flex;
    gap:10px;
    align-items:flex-start;
    color:#5b675c;
    font-size:14px;
}
.forgot-link,.auth-footer-link button{
    color:#2e9c43;
    font-weight:800;
    text-decoration:none;
    background:none;
    border:none;
    cursor:pointer;
}
.discord-btn{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    border:1px solid #dbe3f9;
    color:#4f66d1;
    background:#f6f8ff;
    border-radius:16px;
    padding:14px 16px;
    text-decoration:none;
    font-weight:800;
    margin-bottom:18px;
}
.divider{
    display:flex;
    align-items:center;
    gap:12px;
    margin-bottom:18px;
    color:#97a39a;
    font-size:13px;
    font-weight:800;
}
.divider::before,.divider::after{
    content:'';
    height:1px;
    flex:1;
    background:#e7eee2;
}
.dashboard-hero{
    margin-top:25px;
    background:linear-gradient(135deg,#f5fff2,#dff4df);
    border-radius:30px;
    padding:42px;
    display:grid;
    grid-template-columns:1.6fr .9fr;
    gap:24px;
    align-items:center;
}
.dashboard-hero h1{
    font-size:46px;
    line-height:1.08;
    margin-bottom:14px;
}
.dashboard-hero p{
    font-size:18px;
    color:#5f6a61;
    line-height:1.7;
}
.hero-action-stack{
    display:flex;
    gap:14px;
    flex-wrap:wrap;
    margin-top:22px;
}
.hero-side-card{
    background:white;
    border-radius:24px;
    padding:28px;
}
.hero-side-card h3{
    font-size:26px;
    margin-bottom:12px;
}
.hero-side-card ul{
    list-style:none;
    display:grid;
    gap:12px;
    color:#48554a;
}

.hero-side-summary{display:grid;gap:16px;min-height:320px;}
.hero-side-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;}
.hero-side-grid div{background:#f7fbf4;border:1px solid #e4eee0;border-radius:18px;padding:14px;display:grid;gap:4px;}
.hero-side-grid span{font-size:13px;color:#6d786f;font-weight:700;}
.hero-side-grid strong{font-size:22px;color:#1e2e20;line-height:1.1;}
.hero-side-note{margin:0;color:#617064;line-height:1.6;}
.section-head-row{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:14px;}
.inline-action-form{display:inline-flex;}
.status-cancel_at_period_end{background:#fff5df;color:#8a5b05;}
@media (max-width:860px){.hero-side-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:640px){.hero-side-grid{grid-template-columns:1fr;}}
.dashboard-grid{
    display:grid;
    grid-template-columns:1.2fr .8fr;
    gap:24px;
    margin-top:24px;
}
.panel-card h2,.section-card h2,.form-card h2,.table-card h2,.checkout-card h2{
    font-size:28px;
    margin-bottom:10px;
}
.card-subtitle{
    color:#617064;
    line-height:1.7;
    margin-bottom:18px;
}
.stats-row{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:16px;
    margin-top:16px;
}
.stat-card{
    background:#fff;
    border-radius:22px;
    padding:22px;
    box-shadow:var(--shadow);
}
.stat-card .label{
    color:#6e7a70;
    font-size:14px;
    font-weight:700;
    margin-bottom:8px;
}
.stat-card .value{
    font-size:32px;
    font-weight:900;
    color:#1e2e20;
}
.service-list{
    display:grid;
    gap:16px;
}
.service-card{
    background:white;
    border:1px solid #ebf1e7;
    border-radius:24px;
    padding:22px;
}
.service-top{
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
    gap:16px;
    margin-bottom:16px;
}
.service-top h3{
    font-size:24px;
    margin-bottom:6px;
}
.service-meta{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
}
.meta-pill{
    background:#f3fbef;
    color:#2d7d3c;
    font-size:12px;
    font-weight:900;
    padding:8px 10px;
    border-radius:999px;
}
.service-details{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:12px;
    margin-bottom:18px;
}
.detail-box{
    background:#f8fcf6;
    border:1px solid #ebf0e8;
    border-radius:16px;
    padding:14px;
}
.detail-box .k{
    color:#748176;
    font-size:13px;
    margin-bottom:6px;
    font-weight:700;
}
.detail-box .v{
    color:#1e2a20;
    font-weight:800;
}
.service-actions{
    display:flex;
    gap:12px;
    flex-wrap:wrap;
}
.quick-links{
    display:grid;
    gap:16px;
}
.quick-link{
    background:white;
    border-radius:20px;
    padding:18px;
    box-shadow:var(--shadow);
    text-decoration:none;
    color:inherit;
}
.quick-link strong{
    display:block;
    font-size:18px;
    margin-bottom:6px;
}
.quick-link span{
    color:#617064;
    line-height:1.6;
}
.table-wrap{overflow-x:auto;}
.app-table{
    width:100%;
    border-collapse:collapse;
    background:white;
    border-radius:20px;
    overflow:hidden;
}
.app-table th,.app-table td{
    padding:16px 18px;
    border-bottom:1px solid #edf2ea;
    text-align:left;
    vertical-align:middle;
}
.app-table th{
    background:#eef9ea;
    color:#27402c;
    font-size:14px;
}
.status-badge{
    display:inline-flex;
    align-items:center;
    padding:8px 12px;
    border-radius:999px;
    font-size:12px;
    font-weight:900;
}
.status-active{background:#eafbe7;color:#256932;}
.status-past_due{background:#fff2de;color:#8a5b05;}
.status-cancelled{background:#fdeceb;color:#a23232;}
.status-paid{background:#eafbe7;color:#256932;}
.status-open{background:#edf6ff;color:#245484;}
.status-pending_payment{background:#fff2de;color:#8a5b05;}
.status-failed{background:#fdeceb;color:#a23232;}
.billing-grid,.profile-grid{
    display:grid;
    grid-template-columns:1.1fr .9fr;
    gap:24px;
    margin-top:24px;
}
.form-card form,.checkout-card form{display:grid;gap:16px;}
.field{
    width:100%;
    border:1px solid #dfe8db;
    border-radius:16px;
    padding:16px 18px;
    font-size:15px;
    outline:none;
    background:white;
}
textarea.field{min-height:120px;resize:vertical;}
select.field{
    appearance:none;
    background:white;
}
.form-row-2{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:16px;
}
.form-row-3{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:16px;
}
.form-hint{
    color:#6b776d;
    font-size:13px;
    line-height:1.6;
}
.checkout-layout{
    display:grid;
    grid-template-columns:1.2fr .8fr;
    gap:24px;
    margin-top:24px;
}
.checkout-card{
    background:#f7fff4;
    border-radius:28px;
    padding:30px;
}
.plan-summary{
    display:grid;
    gap:14px;
}
.summary-row{
    display:flex;
    justify-content:space-between;
    gap:10px;
    padding:14px 0;
    border-bottom:1px solid #e5eee1;
}
.mode-picker{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:14px;
}
.mode-choice{
    position:relative;
}
.mode-choice input{
    position:absolute;
    opacity:0;
    pointer-events:none;
}
.mode-choice label{
    display:block;
    background:white;
    border:2px solid #e6ede1;
    border-radius:22px;
    overflow:hidden;
    cursor:pointer;
    transition:.2s ease;
    height:100%;
}
.mode-choice input:checked + label{
    border-color:var(--green);
    transform:translateY(-2px);
}
.mode-choice img{
    width:100%;
    height:170px;
    object-fit:cover;
}
.mode-choice .body{
    padding:16px;
}
.mode-choice .body h4{
    font-size:20px;
    margin-bottom:8px;
}
.mode-choice .body p{
    color:#5f6a61;
    line-height:1.6;
    font-size:14px;
}
.site-footer{
    margin-top:40px;
    padding:0 0 30px;
}
.site-footer-inner{
    width:92%;
    max-width:1400px;
    margin:0 auto;
    background:#fff;
    border-radius:24px;
    padding:24px 28px;
    box-shadow:var(--shadow);
    display:grid;
    grid-template-columns:1fr auto auto;
    gap:20px;
    align-items:center;
}
.footer-links{
    display:flex;
    gap:18px;
    flex-wrap:wrap;
}
.footer-links a{
    text-decoration:none;
    color:#567059;
    font-weight:700;
}
.footer-note{
    color:#6b776d;
    font-size:13px;
    line-height:1.6;
}
.empty-state{
    background:#fff;
    border-radius:22px;
    padding:28px;
    box-shadow:var(--shadow);
}
.empty-state h3{
    font-size:24px;
    margin-bottom:10px;
}
.empty-state p{
    color:#617064;
    line-height:1.7;
    margin-bottom:16px;
}
.muted{color:#617064;}
@media (max-width:1200px){
    .hero,.servers-section,.stats-section,.cards-grid,.features-row,.offers-hero,.pricing-grid,.faq-grid,.servers-hero,.servers-grid-page,.dashboard-hero,.dashboard-grid,.billing-grid,.profile-grid,.checkout-layout,.big-feature-section,.features-grid,.service-details,.mode-picker{
        grid-template-columns:1fr;
    }
    .pricing-card.featured{transform:none;}
    .hero-content h1{font-size:48px;}
    .offers-hero h1,.servers-hero h1,.dashboard-hero h1{font-size:38px;}
    .auth-card{grid-template-columns:1fr;}
}
@media (max-width:900px){
    .navbar{
        flex-direction:column;
        align-items:stretch;
    }
    .logo{justify-content:center;}
    .nav-buttons{justify-content:center;}
    nav ul{justify-content:center;}
    .service-top,.helper-row,.summary-row,.site-footer-inner{
        grid-template-columns:1fr;
        flex-direction:column;
        align-items:flex-start;
    }
    .field-row-2,.form-row-2,.form-row-3{
        grid-template-columns:1fr;
    }
    .stats-row{
        grid-template-columns:1fr;
    }
}
@media (max-width:640px){
    .container,.navbar,.auth-page,.site-footer-inner{width:94%;}
    .hero,.offers-hero,.servers-hero,.dashboard-hero,.section-card,.panel-card,.form-card,.table-card,.checkout-card,.compare-section,.faq-section,.pricing-box,.servers-list,.stats-section{
        padding:22px;
    }
    .hero-content h1{font-size:42px;}
    .auth-panel{padding:22px;}
    .auth-banner{padding:28px;min-height:220px;}
}


/* Shared public UI copied from the home page look */
.public-body {
    background:
        radial-gradient(circle at top right, rgba(83, 197, 78, .12), transparent 22%),
        linear-gradient(180deg, #f9fcf7 0%, #f3f8ee 100%);
}
.public-page-main {
    padding: 0 0 26px;
}
.public-container {
    width: min(calc(100% - 32px), 1220px);
    margin: 0 auto;
}
.public-topbar {
    position: sticky;
    top: 0;
    z-index: 50;
    backdrop-filter: blur(12px);
    background: rgba(249, 252, 247, 0.82);
    border-bottom: 1px solid rgba(192, 217, 173, 0.75);
}
.public-topbar-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    min-height: 82px;
}
.public-brand {
    display: inline-flex;
    align-items: center;
}
.public-brand img {
    width: 200px;
    max-width: 100%;
    display: block;
}
.public-main-nav,
.public-topbar-actions {
    display: flex;
    align-items: center;
    gap: 12px;
}
.public-main-nav a {
    color: #5a7174;
    font-size: 14px;
    font-weight: 700;
    padding: 10px 12px;
    border-radius: 999px;
    text-decoration: none;
}
.public-main-nav a.active,
.public-main-nav a:hover {
    background: rgba(53, 192, 75, .08);
    color: #18343a;
}
.public-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 70px;
    padding: 0 20px;
    border-radius: 14px;
    border: 1px solid transparent;
    font-size: 20px;
    font-weight: 800;
    text-decoration: none;
    transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
}
.public-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 12px 24px rgba(32, 109, 46, .12);
}
.public-btn-primary {
    color: #fff;
    background: linear-gradient(180deg, #35c04b, #25963a);
    box-shadow: inset 0 -4px 0 rgba(0, 0, 0, .1);
}
.public-btn-soft {
    color: #18343a;
    background: rgba(255, 255, 255, .76);
    border-color: #d8e7cc;
}
.public-btn-lg {
    min-height: 54px;
    padding: 0 24px;
    border-radius: 16px;
    font-size: 15px;
}
.public-hero {
    padding: 42px 0 26px;
}
.public-hero-grid {
    display: grid;
    grid-template-columns: 1.02fr .98fr;
    gap: 26px;
    align-items: center;
}
.public-hero-copy {
    padding: 16px 0;
}
.public-hero-copy h1 {
    margin: 0;
    line-height: .98;
    letter-spacing: -.04em;
    font-size: clamp(42px, 7vw, 72px);
    max-width: 11ch;
    color: #18343a;
}
.public-hero-copy p {
    color: #5a7174;
    font-size: 17px;
    line-height: 1.7;
    max-width: 60ch;
    margin: 18px 0 0;
}
.public-hero-actions {
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
    margin-top: 28px;
}
.public-hero-visual img {
    width: 100%;
    max-width: 400px;
    display: block;
    margin: 0 auto;
}
.public-content-shell {
    width: min(calc(100% - 32px), 1220px);
    margin: 0 auto;
}
@media (max-width: 1080px) {
    .public-main-nav {
        display: flex;
        width: 100%;
        order: 3;
        justify-content: center;
        flex-wrap: wrap;
    }
    .public-hero-grid { grid-template-columns: 1fr; }
}
@media (max-width: 720px) {
    .public-topbar-inner,
    .public-topbar-actions,
    .public-main-nav { flex-wrap: wrap; }
    .public-main-nav {
        width: 100%;
        justify-content: center;
        gap: 8px;
    }
    .public-main-nav a {
        text-align: center;
        padding: 8px 10px;
    }
    .public-topbar-actions { width: 100%; }
    .public-topbar-actions .public-btn { flex: 1; min-width: 0; }
    .public-hero-copy h1 { max-width: 100%; }
}

/* Unified immersive background copied from the server list */
.public-body {
    background:
        linear-gradient(180deg, rgba(245, 249, 242, .78), rgba(239, 245, 236, .86)),
        radial-gradient(circle at top left, rgba(53, 192, 75, .18), transparent 24%),
        radial-gradient(circle at right center, rgba(21, 101, 216, .10), transparent 20%),
        url('/images/minecraft.webp') center center / cover no-repeat fixed !important;
    background-attachment: fixed, fixed, fixed, fixed !important;
}

@media (max-width: 1180px) {
    .public-body {
        background-position: center top !important;
    }
}

@media (max-width: 760px) {
    .public-body {
        background:
            linear-gradient(180deg, rgba(245, 249, 242, .86), rgba(239, 245, 236, .92)),
            url('/images/minecraft-liste-serveurs.webp') center top / cover no-repeat fixed !important;
        background-attachment: fixed, fixed !important;
    }
}



/* Patch clarté dashboard client - 2026-05-08 */
.dashboard-grid--clean{
    grid-template-columns:1fr !important;
    max-width:1180px;
    margin-left:auto;
    margin-right:auto;
}
.dashboard-grid--clean .panel-card{
    padding:30px;
    border:1px solid rgba(55, 117, 64, .10);
    box-shadow:0 22px 44px rgba(31, 67, 37, .10);
}
.dashboard-grid--clean .section-head-row{
    display:flex;
    justify-content:space-between;
    gap:18px;
    align-items:flex-start;
    border-bottom:1px solid #e8f1e3;
    padding-bottom:16px;
    margin-bottom:18px;
}
.dashboard-grid--clean .service-list{
    gap:18px;
}
.dashboard-grid--clean .service-card{
    border:1px solid #dfeeda;
    border-radius:26px;
    padding:24px;
    box-shadow:0 14px 32px rgba(30, 65, 35, .08);
    background:linear-gradient(180deg,#ffffff,#fbfff8);
    transition:transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.dashboard-grid--clean .service-card:hover{
    transform:translateY(-2px);
    border-color:#cce6c5;
    box-shadow:0 18px 38px rgba(30, 65, 35, .12);
}
.dashboard-grid--clean .service-top h3{
    font-size:26px;
    line-height:1.15;
}
.dashboard-grid--clean .service-details{
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:14px;
}
.dashboard-grid--clean .detail-box{
    background:#f7fcf3;
    border-color:#e2eedc;
    min-height:82px;
}
.dashboard-grid--clean .detail-box .v{
    font-size:18px;
}
.dashboard-grid--clean .service-actions{
    gap:10px;
    padding-top:2px;
}
.dashboard-grid--clean .service-actions .btn{
    min-height:44px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
}
.dashboard-hero{
    box-shadow:0 24px 60px rgba(31, 67, 37, .10);
    border:1px solid rgba(55, 117, 64, .10);
}
.hero-side-summary{
    box-shadow:0 16px 34px rgba(31, 67, 37, .08);
}
.stats-row{
    max-width:1180px;
    margin-left:auto;
    margin-right:auto;
}
@media (max-width: 900px){
    .dashboard-grid--clean .service-top,
    .dashboard-grid--clean .section-head-row{
        flex-direction:column;
    }
    .dashboard-grid--clean .service-details{
        grid-template-columns:repeat(2,minmax(0,1fr));
    }
}
@media (max-width: 560px){
    .dashboard-grid--clean .service-details,
    .stats-row{
        grid-template-columns:1fr;
    }
    .dashboard-grid--clean .panel-card{
        padding:20px;
    }
}

/* Footer commun Minecraft-Multi */
.mm-footer {
    margin-top: 46px;
    padding: 34px 0 22px;
    border-top: 1px solid rgba(192, 217, 173, .58);
    background: linear-gradient(180deg, rgba(255,255,255,.55), rgba(238,248,232,.78));
}
.mm-footer-grid,
.footer-grid.mm-footer-grid {
    display: grid;
    grid-template-columns: minmax(240px, 1.35fr) repeat(3, minmax(150px, .75fr));
    gap: 24px;
    align-items: start;
}
.mm-footer-brand,
.footer-brand.mm-footer-brand {
    display: inline-flex;
    color: var(--text, #1e2b1f);
    text-decoration: none;
    font-size: 22px;
    font-weight: 950;
    letter-spacing: -.035em;
}
.mm-footer h4 {
    margin: 0 0 12px;
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--text, #1e2b1f);
}
.mm-footer ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 9px;
}
.mm-footer p,
.mm-footer li,
.mm-footer a {
    color: var(--text-soft, #58705d);
}
.mm-footer a {
    text-decoration: none;
    font-weight: 750;
}
.mm-footer a:hover {
    color: var(--text, #1e2b1f);
}
.mm-footer-small {
    margin-top: 10px;
    font-size: 13px;
    opacity: .86;
}
.mm-footer-bottom {
    display: flex;
    justify-content: space-between;
    gap: 14px;
    flex-wrap: wrap;
    margin-top: 22px;
    padding-top: 16px;
    border-top: 1px solid rgba(107,132,103,.16);
    color: var(--text-soft, #58705d);
    font-size: 13px;
    font-weight: 750;
}
@media (max-width: 900px) {
    .mm-footer-grid,
    .footer-grid.mm-footer-grid {
        grid-template-columns: 1fr 1fr;
    }
}
@media (max-width: 620px) {
    .mm-footer-grid,
    .footer-grid.mm-footer-grid {
        grid-template-columns: 1fr;
    }
    .mm-footer-bottom {
        display: grid;
    }
}
