
.artbuild-plugin.abp-profile-os,
.artbuild-plugin.abp-profile-os *{
    box-sizing:border-box;
}

.artbuild-plugin.abp-profile-os{
    max-width:1180px;
    margin:0 auto;
    padding:24px;
    color:#fff;
    font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
    background:
        radial-gradient(circle at top left,rgba(31,111,255,.22),transparent 34%),
        linear-gradient(135deg,#071b2b,#061827);
    border:1px solid rgba(255,255,255,.09);
    border-radius:28px;
    overflow:hidden;
}

.abp-profile-os a{
    text-decoration:none!important;
}

.abp-profile-hero,
.abp-profile-panel,
.abp-profile-form,
.abp-profile-empty{
    border-radius:24px;
    background:
        linear-gradient(180deg,rgba(255,255,255,.075),rgba(255,255,255,.035)),
        #092033;
    border:1px solid rgba(255,255,255,.09);
    box-shadow:0 24px 70px rgba(0,0,0,.18);
}

.abp-profile-hero{
    display:grid;
    grid-template-columns:auto minmax(0,1fr) auto;
    gap:22px;
    align-items:center;
    padding:24px;
    margin-bottom:18px;
}

.abp-profile-avatar{
    width:96px;
    height:96px;
    display:flex;
    align-items:center;
    justify-content:center;
    border-radius:28px;
    background:linear-gradient(135deg,#1f6fff,#0f58d6);
    color:#fff;
    font-size:42px;
    font-weight:950;
    box-shadow:0 16px 36px rgba(31,111,255,.28);
}

.abp-profile-kicker,
.abp-profile-badge,
.abp-profile-tags span{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    border-radius:999px;
    font-weight:900;
}

.abp-profile-kicker{
    padding:8px 13px;
    background:rgba(31,111,255,.12);
    color:#7db6ff;
    font-size:12px;
    letter-spacing:.04em;
    text-transform:uppercase;
}

.abp-profile-main h1,
.abp-profile-settings-hero h1{
    margin:14px 0 10px;
    color:#fff;
    font-size:clamp(34px,5vw,58px);
    line-height:.96;
    font-weight:950;
    letter-spacing:-.045em;
}

.abp-profile-headline{
    max-width:740px;
    margin:0 0 14px;
    color:rgba(255,255,255,.68);
    font-size:16px;
    line-height:1.55;
}

.abp-profile-badges{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
    margin-bottom:10px;
}

.abp-profile-badge{
    padding:7px 11px;
    font-size:12px;
    background:rgba(31,111,255,.12);
    color:#7db6ff;
}

.abp-profile-badge-verified,
.abp-profile-badge-insured,
.abp-profile-badge-licensed{
    background:rgba(35,195,120,.12);
    color:#7ff0b7;
}

.abp-profile-badge-premium{
    background:rgba(242,183,5,.12);
    color:#f2d36b;
}

.abp-profile-badge-risk_flagged{
    background:rgba(255,79,63,.10);
    color:#ffaaa4;
}

.abp-profile-location{
    color:rgba(255,255,255,.58);
    font-weight:800;
}

.abp-profile-actions{
    display:grid;
    gap:10px;
}

.abp-profile-button{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:48px;
    padding:13px 18px;
    border:0;
    border-radius:16px;
    background:linear-gradient(135deg,#1f6fff,#0f58d6);
    color:#fff!important;
    font-size:14px;
    font-weight:900;
    cursor:pointer;
    text-decoration:none!important;
}

.abp-profile-button-secondary{
    background:rgba(255,255,255,.075);
    border:1px solid rgba(255,255,255,.12);
}

.abp-profile-grid{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:18px;
}

.abp-profile-panel{
    padding:22px;
}

.abp-profile-wide{
    grid-column:1/-1;
}

.abp-profile-panel h2{
    margin:0 0 14px;
    color:#fff;
    font-size:24px;
    font-weight:950;
}

.abp-profile-panel p{
    margin:0;
    color:rgba(255,255,255,.68);
    font-size:15px;
    line-height:1.6;
}

.abp-profile-facts{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:12px;
}

.abp-profile-facts div{
    padding:14px;
    border-radius:16px;
    background:rgba(2,12,22,.42);
    border:1px solid rgba(255,255,255,.08);
}

.abp-profile-facts span{
    display:block;
    margin-bottom:6px;
    color:rgba(255,255,255,.48);
    font-size:12px;
    font-weight:900;
}

.abp-profile-facts strong{
    color:#fff;
    font-size:15px;
    font-weight:950;
}

.abp-profile-tags{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
}

.abp-profile-tags span{
    padding:10px 13px;
    background:rgba(31,111,255,.12);
    color:#7db6ff;
    font-size:13px;
}

.abp-profile-listings{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:12px;
}

.abp-profile-listing{
    display:block;
    padding:16px;
    border-radius:18px;
    background:rgba(2,12,22,.42);
    border:1px solid rgba(255,255,255,.08);
    color:#fff!important;
}

.abp-profile-listing strong{
    display:block;
    margin-bottom:8px;
    color:#fff;
    font-size:15px;
    font-weight:950;
}

.abp-profile-listing span,
.abp-profile-listing em{
    display:block;
    color:rgba(255,255,255,.58);
    font-size:13px;
    font-style:normal;
}

.abp-profile-listing em{
    margin-top:8px;
    color:#7db6ff;
    font-weight:900;
}

.abp-profile-form{
    padding:22px;
}

.abp-profile-form-grid{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:14px;
    margin-bottom:18px;
}

.abp-profile-form label{
    display:grid;
    gap:8px;
}

.abp-profile-form label span{
    color:#fff;
    font-size:13px;
    font-weight:900;
}

.abp-profile-form input,
.abp-profile-form select,
.abp-profile-form textarea{
    width:100%;
    min-height:54px;
    border-radius:16px;
    border:1px solid rgba(255,255,255,.10);
    background:rgba(2,12,22,.72);
    color:#fff;
    padding:12px 15px;
    outline:none;
}

.abp-profile-form textarea{
    min-height:140px;
}

.abp-profile-wide-field{
    grid-column:1/-1;
}

.abp-profile-checks{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:8px;
}

.abp-profile-checks label,
.abp-profile-checkline{
    display:flex!important;
    align-items:center;
    gap:8px;
    padding:11px 12px;
    border-radius:14px;
    background:rgba(255,255,255,.055);
    border:1px solid rgba(255,255,255,.08);
    color:rgba(255,255,255,.78);
    font-weight:800;
}

.abp-profile-checks input,
.abp-profile-checkline input{
    width:18px!important;
    min-height:auto!important;
    accent-color:#1f6fff;
}

.abp-profile-empty{
    padding:22px;
    color:rgba(255,255,255,.72);
}

@media(max-width:900px){
    .abp-profile-hero{
        grid-template-columns:1fr;
    }

    .abp-profile-actions{
        grid-template-columns:1fr;
    }

    .abp-profile-grid,
    .abp-profile-form-grid,
    .abp-profile-listings,
    .abp-profile-checks,
    .abp-profile-facts{
        grid-template-columns:1fr;
    }

    .artbuild-plugin.abp-profile-os{
        padding:18px;
        border-radius:22px;
    }
}
