:root {
    --primary-gradient: linear-gradient(135deg, #ffa8a8 0%, #8d96ff 100%);
    --glass-bg: rgba(255,255,255,0.55);
    --glass-border: rgba(255,255,255,0.65);
    --glass-shadow: 0 8px 32px rgba(180,130,200,0.13);
    --glass-inset: 0 1px 0 rgba(255,255,255,0.7) inset;
    --blur-amount: 18px;
    --text-primary: #1a1a2e;
    --text-secondary: #4a4a6a;
}

* { margin:0; padding:0; box-sizing:border-box; }

body { font-family:'Poppins',sans-serif; min-height:100vh; background:linear-gradient(135deg,#ffe0e6 0%,#e8e6ff 50%,#d4e8ff 100%); background-attachment:fixed; }

.navbar { height:62px; background:linear-gradient(135deg,rgba(255,168,168,0.78) 0%,rgba(141,150,255,0.78) 100%); backdrop-filter:blur(20px) saturate(200%); -webkit-backdrop-filter:blur(20px) saturate(200%); border-bottom:1px solid rgba(255,255,255,0.45); box-shadow:0 4px 40px rgba(180,130,200,0.22),0 1px 0 rgba(255,255,255,0.6) inset; position:sticky; top:0; z-index:1001; display:flex; align-items:center; padding:0 1.25rem; }
.nav-brand { display:flex; align-items:center; gap:0.6rem; text-decoration:none; flex-shrink:0; }
.nav-brand-icon { width:34px; height:34px; border-radius:10px; background:linear-gradient(135deg,#ffa8a8 0%,#8d96ff 100%); display:flex; align-items:center; justify-content:center; box-shadow:0 4px 12px rgba(141,150,255,0.4); }
.nav-brand-icon i { color:#fff; font-size:0.9rem; -webkit-text-fill-color:#fff; }
.nav-brand-text { font-family:'Inter',sans-serif; font-size:1.25rem; font-weight:800; color:#fff; -webkit-text-fill-color:#fff; }
.nav-spacer { flex:1; }
.nav-actions { display:flex; align-items:center; gap:0.4rem; flex-shrink:0; }
.nav-icon-btn { width:34px; height:34px; border-radius:50%; background:rgba(255,255,255,0.2); border:1px solid rgba(255,255,255,0.4); display:flex; align-items:center; justify-content:center; color:#fff; text-decoration:none; transition:all 0.2s; font-size:0.85rem; }
.nav-icon-btn:hover { background:rgba(255,255,255,0.35); transform:scale(1.05); }
.nav-icon-btn i { color:#fff; -webkit-text-fill-color:#fff; }

.badge-role { display:inline-flex; align-items:center; gap:4px; font-family:'Poppins',sans-serif; font-size:9px; font-weight:700; letter-spacing:0.08em; text-transform:uppercase; padding:4px 10px; border-radius:100px; border:1px solid; white-space:nowrap; flex-shrink:0; line-height:1.2; }
.badge-role.free    { background:rgba(255,255,255,0.35); color:#4a4a6a; -webkit-text-fill-color:#4a4a6a; border-color:rgba(141,150,255,0.3); }
.badge-role.cheap   { background:linear-gradient(135deg,rgba(184,127,13,.95),rgba(184,127,13,.75)); color:#fff; -webkit-text-fill-color:#fff; border-color:rgba(184,127,13,.4); }
.badge-role.premium { background:linear-gradient(135deg,#ffa8a8,#8d96ff); color:#fff; -webkit-text-fill-color:#fff; border-color:rgba(255,168,168,.3); }
.badge-role.vip     { background:linear-gradient(135deg,rgba(255,191,0,.95),rgba(255,191,0,.75)); color:#1a1a1a; -webkit-text-fill-color:#1a1a1a; border-color:rgba(255,191,0,.4); }
.badge-role.supreme { background:linear-gradient(135deg,rgba(238,62,75,.95),rgba(238,62,75,.75)); color:#fff; -webkit-text-fill-color:#fff; border-color:rgba(238,62,75,.4); font-weight:700; }
.badge-role.donator { background:linear-gradient(135deg,#6dd5a0,#2ecc71); color:#fff; -webkit-text-fill-color:#fff; border-color:rgba(46,204,113,.4); }
.badge-role.admin   { background:linear-gradient(135deg,#1a1a2e,#2d1f4e); color:#fff; -webkit-text-fill-color:#fff; border-color:rgba(141,150,255,.5); box-shadow:0 2px 12px rgba(141,150,255,.4); }

.page { max-width:680px; margin:0 auto; padding:1.5rem 1rem 3rem; }

.glass-card { background:var(--glass-bg); backdrop-filter:blur(var(--blur-amount)) saturate(200%); -webkit-backdrop-filter:blur(var(--blur-amount)) saturate(200%); border:1px solid var(--glass-border); border-radius:20px; box-shadow:var(--glass-shadow),var(--glass-inset); padding:1.5rem; margin-bottom:1.25rem; position:relative; overflow:hidden; }
.glass-card::before { content:''; position:absolute; top:0; left:0; right:0; height:40%; background:linear-gradient(180deg,rgba(255,255,255,0.45) 0%,rgba(255,255,255,0) 100%); border-radius:20px 20px 60% 60%; pointer-events:none; }

.card-title { font-family:'Inter',sans-serif; font-size:1rem; font-weight:700; color:var(--text-primary); -webkit-text-fill-color:var(--text-primary); display:flex; align-items:center; gap:0.5rem; margin-bottom:1.25rem; }
.card-title i { background:var(--primary-gradient); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; font-size:1.1rem; }


.profile-main-card { padding:0; overflow:hidden; }
.profile-main-card::before { display:none; }


.profile-banner { position:relative; width:100%; height:150px; background:linear-gradient(135deg,#ffa8a8 0%,#8d96ff 50%,#a8d8ff 100%); overflow:hidden; }
.profile-banner-inner { position:absolute; inset:0; }
.profile-banner img { width:100%; height:100%; object-fit:cover; object-position:center; display:block; }
.banner-gradient-overlay { position:absolute; inset:0; background:linear-gradient(to bottom,transparent 50%,rgba(0,0,0,0.22) 100%); pointer-events:none; }

.banner-edit-btn {
    position:absolute; top:12px; right:12px;
    background:rgba(0,0,0,0.42);
    backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px);
    border:1px solid rgba(255,255,255,0.35);
    border-radius:10px; padding:6px 12px;
    color:#fff; -webkit-text-fill-color:#fff;
    font-size:0.78rem; font-weight:600;
    display:inline-flex; align-items:center; gap:5px;
    cursor:pointer; transition:all 0.2s;
    font-family:'Poppins',sans-serif;
    opacity:0; transform:translateY(-4px); z-index:3;
}
.profile-banner:hover .banner-edit-btn { opacity:1; transform:translateY(0); }
.banner-edit-btn:hover,.banner-edit-btn:active { background:rgba(0,0,0,0.65); }
@media (hover:none) { .banner-edit-btn { opacity:1; transform:translateY(0); } }


.profile-body { padding:0 1.25rem 1.5rem; position:relative; }

.profile-hero {
    display:flex;
    align-items:flex-end;
    gap:1rem;
    margin-top:-45px;
    margin-bottom:1rem;
    position:relative;
    z-index:1;
}


.profile-avatar-wrap {
    position:relative;
    flex-shrink:0;
    width:90px; height:90px;
}
.profile-avatar {
    width:90px; height:90px;
    border-radius:50%;
    background:var(--primary-gradient);
    display:flex; align-items:center; justify-content:center;
    box-shadow:0 0 0 4px rgba(255,255,255,0.92),0 8px 24px rgba(141,150,255,0.25);
    overflow:hidden; cursor:pointer;
}
.profile-avatar i { font-size:2.4rem; color:#fff; -webkit-text-fill-color:#fff; }
.profile-avatar img { width:100%; height:100%; object-fit:cover; object-position:center; border-radius:50%; }

.avatar-edit-overlay {
    position:absolute; inset:0; border-radius:50%;
    cursor:pointer; z-index:2;
    background:transparent;
}


.profile-meta { flex:1; min-width:0; padding-bottom:6px; }

.profile-username {
    font-family:'Inter',sans-serif;
    font-size:1.25rem; font-weight:800;
    color:var(--text-primary); -webkit-text-fill-color:var(--text-primary);
    margin-bottom:0.18rem;
    white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
    line-height:1.25;
    transition:color 0.3s,-webkit-text-fill-color 0.3s,text-shadow 0.3s;
}
.profile-email {
    font-size:0.78rem; font-weight:500;
    color:#6b6b8a; -webkit-text-fill-color:#6b6b8a;
    margin-bottom:0.45rem;
    white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
    transition:color 0.3s,-webkit-text-fill-color 0.3s;
    opacity:0.85;
    letter-spacing:0.01em;
}

.profile-role-badge { display:inline-flex; align-items:center; gap:6px; font-size:11px; font-weight:700; letter-spacing:0.08em; text-transform:uppercase; padding:5px 14px; border-radius:100px; border:1px solid; }
.profile-role-badge.free    { background:rgba(255,255,255,0.35); color:#4a4a6a; -webkit-text-fill-color:#4a4a6a; border-color:rgba(141,150,255,0.3); }
.profile-role-badge.cheap   { background:linear-gradient(135deg,rgba(184,127,13,.95),rgba(184,127,13,.75)); color:#fff; -webkit-text-fill-color:#fff; border-color:rgba(184,127,13,.4); box-shadow:0 2px 8px rgba(184,127,13,.3); }
.profile-role-badge.premium { background:linear-gradient(135deg,#ffa8a8,#8d96ff); color:#fff; -webkit-text-fill-color:#fff; border-color:rgba(255,168,168,.3); box-shadow:0 2px 8px rgba(255,168,168,.3); }
.profile-role-badge.vip     { background:linear-gradient(135deg,rgba(255,191,0,.95),rgba(255,191,0,.75)); color:#1a1a1a; -webkit-text-fill-color:#1a1a1a; border-color:rgba(255,191,0,.4); box-shadow:0 2px 8px rgba(255,191,0,.3); }
.profile-role-badge.supreme { background:linear-gradient(135deg,rgba(238,62,75,.95),rgba(238,62,75,.75)); color:#fff; -webkit-text-fill-color:#fff; border-color:rgba(238,62,75,.4); box-shadow:0 2px 8px rgba(238,62,75,.3); }
.profile-role-badge.donator { background:linear-gradient(135deg,#6dd5a0,#2ecc71); color:#fff; -webkit-text-fill-color:#fff; border-color:rgba(46,204,113,.4); box-shadow:0 2px 8px rgba(46,204,113,.3); }
.profile-role-badge.admin   { background:linear-gradient(135deg,#1a1a2e,#2d1f4e); color:#fff; -webkit-text-fill-color:#fff; border-color:rgba(141,150,255,.5); box-shadow:0 2px 12px rgba(141,150,255,.4); }


.profile-meta.text-on-dark .profile-username { color:#fff; -webkit-text-fill-color:#fff; text-shadow:0 1px 8px rgba(0,0,0,0.5); }
.profile-meta.text-on-dark .profile-email { color:rgba(255,255,255,0.75); -webkit-text-fill-color:rgba(255,255,255,0.75); text-shadow:0 1px 4px rgba(0,0,0,0.4); opacity:1; }
.profile-meta.text-on-light .profile-username { color:#1a1a2e; -webkit-text-fill-color:#1a1a2e; text-shadow:none; }
.profile-meta.text-on-light .profile-email { color:#4a4a6a; -webkit-text-fill-color:#4a4a6a; text-shadow:none; }


.img-editor-overlay {
    position:fixed; inset:0;
    background:rgba(0,0,0,0.75);
    backdrop-filter:blur(12px);
    -webkit-backdrop-filter:blur(12px);
    z-index:9999;
    display:flex; align-items:center; justify-content:center;
    padding:1rem;
    animation:editorFadeIn 0.2s ease;
}
@keyframes editorFadeIn { from{opacity:0} to{opacity:1} }

.img-editor-modal {
    background:rgba(255,255,255,0.96);
    border-radius:24px;
    width:100%; max-width:500px;
    overflow:hidden;
    box-shadow:0 32px 80px rgba(0,0,0,0.35);
    animation:editorSlideUp 0.25s cubic-bezier(.34,1.4,.64,1);
}
@keyframes editorSlideUp { from{opacity:0;transform:translateY(30px) scale(0.96)} to{opacity:1;transform:translateY(0) scale(1)} }

.img-editor-header {
    display:flex; align-items:center; justify-content:space-between;
    padding:1rem 1.25rem 0.75rem;
    border-bottom:1px solid rgba(0,0,0,0.07);
}
.img-editor-title { font-family:'Inter',sans-serif; font-size:1rem; font-weight:700; color:#1a1a2e; }
.img-editor-close { width:32px; height:32px; border-radius:50%; border:none; background:rgba(0,0,0,0.07); cursor:pointer; display:flex; align-items:center; justify-content:center; color:#4a4a6a; font-size:0.9rem; transition:all 0.2s; }
.img-editor-close:hover { background:rgba(0,0,0,0.13); transform:scale(1.05); }

.img-editor-canvas-wrap {
    position:relative;
    background:#111;
    overflow:hidden;
    touch-action:none;
    user-select:none;
    line-height:0;
}
.img-editor-canvas-wrap canvas {
    display:block;
    
}
.img-editor-hint {
    position:absolute; bottom:10px; left:50%; transform:translateX(-50%);
    background:rgba(0,0,0,0.55); color:#fff; -webkit-text-fill-color:#fff;
    font-size:0.7rem; padding:5px 12px; border-radius:20px;
    white-space:nowrap; pointer-events:none;
    font-family:'Poppins',sans-serif;
}

.img-editor-controls { padding:0.9rem 1.25rem 1.1rem; }

.img-editor-zoom-row { display:flex; align-items:center; gap:0.75rem; margin-bottom:0.9rem; }
.img-editor-zoom-btn { width:34px; height:34px; border-radius:10px; border:1.5px solid rgba(141,150,255,0.3); background:rgba(141,150,255,0.08); color:#4a4a6a; font-size:0.85rem; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:all 0.2s; flex-shrink:0; }
.img-editor-zoom-btn:hover { background:rgba(141,150,255,0.18); }
.img-editor-zoom-track { flex:1; height:6px; background:rgba(141,150,255,0.15); border-radius:100px; overflow:hidden; cursor:pointer; position:relative; }
.img-editor-zoom-fill { height:100%; background:var(--primary-gradient); border-radius:100px; transition:width 0.15s; pointer-events:none; }

.img-editor-actions { display:flex; gap:0.75rem; }
.img-editor-cancel { flex:1; padding:0.7rem; border:1.5px solid rgba(141,150,255,0.25); border-radius:12px; background:transparent; color:#4a4a6a; font-family:'Poppins',sans-serif; font-size:0.88rem; font-weight:600; cursor:pointer; transition:all 0.2s; }
.img-editor-cancel:hover { background:rgba(141,150,255,0.08); }
.img-editor-upload { flex:2; padding:0.7rem; border:none; border-radius:12px; background:var(--primary-gradient); color:#fff; -webkit-text-fill-color:#fff; font-family:'Poppins',sans-serif; font-size:0.88rem; font-weight:700; cursor:pointer; transition:all 0.25s; box-shadow:0 4px 16px rgba(141,150,255,0.35); display:flex; align-items:center; justify-content:center; gap:0.4rem; }
.img-editor-upload:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(141,150,255,0.45); }
.img-editor-upload:disabled { opacity:0.6; cursor:not-allowed; transform:none; }


.stats-grid { display:grid; grid-template-columns:1fr 1fr; gap:0.75rem; }
.stat-item { background:rgba(255,255,255,0.5); border:1px solid rgba(255,255,255,0.65); border-radius:14px; padding:1rem; text-align:center; }
.stat-value { display:block; font-family:'Inter',sans-serif; font-size:1.5rem; font-weight:800; background:var(--primary-gradient); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; margin-bottom:0.2rem; }
.stat-label { font-size:0.72rem; font-weight:600; text-transform:uppercase; letter-spacing:0.08em; color:var(--text-secondary); -webkit-text-fill-color:var(--text-secondary); }

.progress-wrap { margin-top:0.5rem; }
.progress-label { display:flex; justify-content:space-between; font-size:0.8rem; color:var(--text-secondary); -webkit-text-fill-color:var(--text-secondary); margin-bottom:0.5rem; }
.progress-track { height:8px; border-radius:100px; background:rgba(141,150,255,0.15); overflow:hidden; }
.progress-fill { height:100%; border-radius:100px; background:var(--primary-gradient); transition:width 0.6s ease; }

.api-key-row { display:flex; align-items:center; gap:0.75rem; background:rgba(255,255,255,0.5); border:1px solid rgba(255,255,255,0.65); border-radius:12px; padding:0.75rem 1rem; }
.api-key-value { font-family:'Inter',monospace; font-size:0.95rem; font-weight:700; color:var(--text-primary); -webkit-text-fill-color:var(--text-primary); flex:1; cursor:pointer; word-break:break-all; }

.form-group { margin-bottom:1rem; }
.form-label { display:block; font-size:0.85rem; font-weight:600; color:var(--text-secondary); -webkit-text-fill-color:var(--text-secondary); margin-bottom:0.5rem; }
.form-input { width:100%; padding:0.75rem 1rem; border:1.5px solid rgba(141,150,255,0.25); border-radius:12px; background:rgba(255,255,255,0.6); color:var(--text-primary); -webkit-text-fill-color:var(--text-primary); font-family:'Poppins',sans-serif; font-size:0.9rem; transition:all 0.3s; outline:none; }
.form-input:focus { border-color:rgba(141,150,255,0.6); background:rgba(255,255,255,0.85); box-shadow:0 0 0 3px rgba(141,150,255,0.12); }
.form-input::placeholder { color:#a0a0c0; }
.form-row { display:flex; gap:0.6rem; }
.form-row .form-input { flex:1; }

.btn { padding:0.7rem 1.25rem; border:none; border-radius:12px; font-family:'Poppins',sans-serif; font-size:0.88rem; font-weight:700; cursor:pointer; transition:all 0.25s; display:inline-flex; align-items:center; gap:0.4rem; }
.btn-primary { background:var(--primary-gradient); color:#fff; -webkit-text-fill-color:#fff; box-shadow:0 4px 16px rgba(141,150,255,0.35); }
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(141,150,255,0.45); }
.btn-warning { background:linear-gradient(135deg,#ffd700,#ffb300); color:#7a4a00; -webkit-text-fill-color:#7a4a00; box-shadow:0 4px 16px rgba(255,179,0,0.3); }
.btn-warning:hover { transform:translateY(-2px); }
.btn-danger { background:linear-gradient(135deg,#ff6b6b,#ee0979); color:#fff; -webkit-text-fill-color:#fff; box-shadow:0 4px 16px rgba(238,9,121,0.3); }
.btn-danger:hover { transform:translateY(-2px); }
.btn-icon { width:38px; height:38px; padding:0; border-radius:10px; justify-content:center; }
.btn-sm { padding:0.5rem 0.9rem; font-size:0.8rem; }

.telegram-card { background:linear-gradient(135deg,rgba(0,136,204,0.85) 0%,rgba(0,85,128,0.85) 100%); backdrop-filter:blur(18px); border:1px solid rgba(255,255,255,0.3); border-radius:20px; padding:1.5rem; margin-bottom:1.25rem; color:#fff; }
.telegram-card .card-title { color:#fff; -webkit-text-fill-color:#fff; margin-bottom:1rem; }
.telegram-card .card-title i { background:none; -webkit-text-fill-color:#fff; color:#fff; }
.tg-status { display:inline-flex; align-items:center; gap:8px; padding:7px 14px; border-radius:100px; font-size:0.82rem; font-weight:600; margin-bottom:1rem; }
.tg-connected    { background:rgba(46,204,113,0.25); border:1px solid rgba(46,204,113,0.5); color:#fff; -webkit-text-fill-color:#fff; }
.tg-disconnected { background:rgba(255,107,107,0.25); border:1px solid rgba(255,107,107,0.5); color:#fff; -webkit-text-fill-color:#fff; }
.tg-bonus { background:rgba(46,204,113,0.2); border-left:3px solid #2ecc71; border-radius:8px; padding:10px 12px; font-size:0.85rem; margin:0.75rem 0; color:#fff; -webkit-text-fill-color:#fff; }
.link-code-box { background:rgba(255,255,255,0.15); border:2px dashed rgba(255,255,255,0.35); border-radius:12px; padding:1.25rem; text-align:center; margin:0.75rem 0; }
.link-code-text { font-size:1.6rem; font-weight:800; letter-spacing:4px; font-family:'Inter',monospace; color:#fff; -webkit-text-fill-color:#fff; }
.link-code-expire { font-size:0.82rem; opacity:0.8; margin-top:6px; color:#fff; -webkit-text-fill-color:#fff; }
.btn-tg { background:rgba(255,255,255,0.2); border:1px solid rgba(255,255,255,0.4); color:#fff; -webkit-text-fill-color:#fff; padding:0.6rem 1.2rem; border-radius:10px; font-family:'Poppins',sans-serif; font-size:0.88rem; font-weight:600; cursor:pointer; transition:all 0.25s; display:inline-flex; align-items:center; gap:0.4rem; }
.btn-tg:hover { background:rgba(255,255,255,0.3); transform:translateY(-2px); }
.btn-tg-danger { background:rgba(231,76,60,0.3); border:1px solid rgba(231,76,60,0.5); }

.activity-list { display:flex; flex-direction:column; gap:0.6rem; max-height:320px; overflow-y:auto; padding-right:4px; scrollbar-width:thin; scrollbar-color:rgba(141,150,255,0.3) transparent; }
.activity-list::-webkit-scrollbar { width:4px; }
.activity-list::-webkit-scrollbar-track { background:transparent; }
.activity-list::-webkit-scrollbar-thumb { background:rgba(141,150,255,0.3); border-radius:99px; }
.activity-item { display:flex; align-items:flex-start; gap:0.75rem; padding:0.75rem; background:rgba(255,255,255,0.45); border:1px solid rgba(255,255,255,0.6); border-radius:12px; font-size:0.85rem; }
.activity-item i { background:var(--primary-gradient); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; font-size:0.9rem; margin-top:2px; flex-shrink:0; }
.activity-item span { color:var(--text-primary); -webkit-text-fill-color:var(--text-primary); }
.activity-item small { display:block; color:var(--text-secondary); -webkit-text-fill-color:var(--text-secondary); font-size:0.75rem; margin-top:2px; }

.ip-toggle-row { display:flex; align-items:center; justify-content:space-between; margin-bottom:0.75rem; }
.toggle-label { font-size:0.88rem; font-weight:600; color:var(--text-primary); -webkit-text-fill-color:var(--text-primary); display:flex; align-items:center; gap:6px; }
.toggle-label i { color:#ff6b9d; -webkit-text-fill-color:#ff6b9d; }
.toggle-switch { position:relative; display:inline-block; width:48px; height:24px; }
.toggle-switch input { opacity:0; width:0; height:0; }
.toggle-slider { position:absolute; cursor:pointer; top:0; left:0; right:0; bottom:0; background:rgba(141,150,255,0.2); border:1px solid rgba(141,150,255,0.3); transition:.3s; border-radius:24px; }
.toggle-slider:before { position:absolute; content:""; height:18px; width:18px; left:2px; bottom:2px; background:white; transition:.3s; border-radius:50%; box-shadow:0 2px 6px rgba(0,0,0,0.15); }
input:checked + .toggle-slider { background:var(--primary-gradient); border-color:transparent; }
input:checked + .toggle-slider:before { transform:translateX(24px); }

.ip-limit-info { margin:0.75rem 0 0.5rem; }
.ip-limit-bar-wrap { background:rgba(0,0,0,0.07); border:1px solid rgba(0,0,0,0.12); border-radius:14px; padding:0.85rem 1rem; }
.ip-limit-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:0.55rem; font-size:0.82rem; }
.ip-limit-plan { color:rgba(0,0,0,0.9); font-weight:600; }
.ip-limit-plan i { margin-right:4px; background:var(--primary-gradient); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.ip-limit-count { color:rgba(0,0,0,0.7); font-size:0.78rem; font-weight:500; }
.ip-limit-count.at-limit { color:#ff6b6b; font-weight:700; }
.ip-limit-track { height:6px; background:rgba(0,0,0,0.1); border-radius:99px; overflow:hidden; margin-bottom:0.45rem; }
.ip-limit-fill { height:100%; border-radius:99px; transition:width 0.5s ease; }
.ip-limit-footer { display:flex; color:rgba(0,0,0,0.9); justify-content:space-between; align-items:center; font-size:0.76rem; margin-top:0.1rem; }
.ip-upgrade-link { color:#fff; background:var(--primary-gradient); border-radius:8px; padding:3px 10px; font-size:0.73rem; font-weight:600; text-decoration:none; transition:opacity .2s; -webkit-text-fill-color:#fff; }
.ip-upgrade-link:hover { opacity:0.85; }
.ip-status-pill { display:inline-flex; align-items:center; gap:5px; font-size:0.78rem; font-weight:600; padding:3px 10px; border-radius:100px; margin-bottom:0.75rem; }
.ip-status-pill.on  { background:rgba(46,204,113,0.15); color:#27ae60; -webkit-text-fill-color:#27ae60; border:1px solid rgba(46,204,113,0.3); }
.ip-status-pill.off { background:rgba(231,76,60,0.1); color:#c0392b; -webkit-text-fill-color:#c0392b; border:1px solid rgba(231,76,60,0.2); }
.ip-forms { max-height:0; overflow:hidden; transition:max-height 0.4s ease,opacity 0.4s ease; opacity:0; }
.ip-forms.show { max-height:1500px; opacity:1; }
.ip-section { background:rgba(255,245,248,0.6); border:1.5px solid rgba(255,168,168,0.25); border-radius:14px; padding:1rem; margin-bottom:0.75rem; }
.ip-section h6 { font-size:0.85rem; font-weight:700; color:var(--text-primary); -webkit-text-fill-color:var(--text-primary); margin-bottom:0.75rem; display:flex; align-items:center; gap:6px; }
.ip-input-row { display:flex; gap:0.5rem; margin-bottom:0.75rem; }
.ip-input-row input { flex:1; }
.ip-btn-white { background:linear-gradient(135deg,#2ecc71,#27ae60); color:#fff; -webkit-text-fill-color:#fff; }
.ip-btn-black { background:linear-gradient(135deg,#e74c3c,#c0392b); color:#fff; -webkit-text-fill-color:#fff; }
.ip-list { max-height:320px; overflow-y:auto; }
.ip-item { display:flex; align-items:flex-start; justify-content:space-between; padding:10px; background:rgba(255,255,255,0.6); border-radius:9px; margin-bottom:6px; font-size:0.83rem; gap:8px; flex-wrap:wrap; }
.ip-item-addr { font-family:'Inter',monospace; font-weight:600; color:var(--text-primary); -webkit-text-fill-color:var(--text-primary); display:flex; align-items:center; gap:6px; flex-wrap:wrap; word-break:break-all; min-width:0; flex:1; }
.ip-badge { font-size:0.65rem; font-weight:700; text-transform:uppercase; padding:2px 6px; border-radius:6px; }
.ip-badge.white { background:rgba(46,204,113,0.2); color:#27ae60; -webkit-text-fill-color:#27ae60; border:1px solid #2ecc71; }
.ip-badge.black { background:rgba(231,76,60,0.15); color:#c0392b; -webkit-text-fill-color:#c0392b; border:1px solid #e74c3c; }
.ip-item-date { font-size:0.72rem; color:var(--text-secondary); -webkit-text-fill-color:var(--text-secondary); width:100%; margin-top:2px; }
.ip-remove-btn { background:linear-gradient(135deg,#e74c3c,#c0392b); color:#fff; -webkit-text-fill-color:#fff; border:none; border-radius:7px; padding:4px 10px; font-size:0.75rem; font-weight:600; cursor:pointer; transition:all 0.2s; flex-shrink:0; align-self:flex-start; white-space:nowrap; }
.ip-remove-btn:hover { transform:scale(1.05); }
.ip-empty { text-align:center; padding:1rem; color:var(--text-secondary); -webkit-text-fill-color:var(--text-secondary); font-size:0.82rem; }
.ip-empty i { display:block; font-size:1.5rem; opacity:0.3; margin-bottom:6px; }

.danger-zone { border-color:rgba(231,76,60,0.25)!important; background:rgba(255,235,235,0.4)!important; }
.danger-zone .card-title { color:#c0392b; -webkit-text-fill-color:#c0392b; }
.danger-zone .card-title i { background:none; -webkit-text-fill-color:#c0392b; color:#c0392b; }
.warning-text { font-size:0.78rem; color:#c0392b; -webkit-text-fill-color:#c0392b; margin-top:0.5rem; }
.divider { height:1px; background:rgba(141,150,255,0.15); margin:1rem 0; }

@media (max-width:480px) {
    .profile-avatar-wrap, .profile-avatar { width:80px; height:80px; }
    .profile-hero { margin-top:-40px; }
    .profile-banner { height:130px; }
    .profile-username { font-size:1.1rem; }
    .stats-grid { grid-template-columns:1fr 1fr; }
    .ip-input-row { flex-direction:column; }
    .img-editor-modal { border-radius:18px; }
}