/* ===== Кланы (Spotlight) ===== */
.cl-wrap{ --c-acc:#29a3ab; --c-acc2:#5fe3ff; --c-blue:#2b7fff; --c-card:rgba(255,255,255,.035); --c-bd:rgba(255,255,255,.06); --c-hi:rgba(41,163,171,.45); --c-head:#eafcff; --c-muted:#9fb2c0; display:block; }
.cl-wrap *{ box-sizing:border-box; }

/* hero */
.cl-hero{ display:flex; align-items:center; gap:18px; background:var(--c-card); border:1px solid var(--c-bd); border-radius:20px; padding:26px 30px; margin-top:14px; box-shadow:0 18px 50px rgba(0,0,0,.3); }
.cl-hero-ic{ width:64px; height:64px; flex-shrink:0; border-radius:18px; display:flex; align-items:center; justify-content:center; background:linear-gradient(120deg,var(--c-acc),var(--c-blue)); box-shadow:0 10px 30px rgba(43,127,255,.35); }
.cl-hero-ic svg{ width:32px; height:32px; fill:#fff; }
.cl-hero-tx{ flex:1; min-width:0; }
.cl-eyebrow{ display:inline-block; font-size:13px; font-weight:800; letter-spacing:.18em; text-transform:uppercase; background:linear-gradient(120deg,var(--c-acc2),var(--c-blue)); -webkit-background-clip:text; background-clip:text; color:transparent; margin-bottom:6px; }
.cl-title{ margin:0; font-family:var(--font-family-1,"Unbounded"),sans-serif; font-size:clamp(26px,3.4vw,40px); font-weight:800; color:var(--c-head); letter-spacing:-.01em; }
.cl-title span{ background:linear-gradient(120deg,var(--c-acc2),var(--c-blue)); -webkit-background-clip:text; background-clip:text; color:transparent; }
.cl-sub{ margin:6px 0 0; color:var(--c-muted); font-size:15px; }
.cl-edit-open{ margin-left:auto; display:inline-flex; align-items:center; gap:8px; padding:11px 18px; border-radius:12px; cursor:pointer; background:rgba(41,163,171,.12); border:1px solid rgba(41,163,171,.3); color:#5fe3ff; font-weight:600; font-size:14px; transition:.2s; }
.cl-edit-open:hover{ background:rgba(41,163,171,.22); } .cl-edit-open svg{ width:15px; height:15px; fill:currentColor; }

/* grid */
.cl-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:18px; margin-top:22px; }
.cl-card{ position:relative; background:var(--c-card); border:1px solid var(--c-bd); border-radius:20px; padding:24px; cursor:pointer; transition:transform .25s, border-color .25s, box-shadow .25s; animation:clIn .4s ease; overflow:hidden; }
.cl-card:hover{ transform:translateY(-5px); border-color:var(--c-hi); box-shadow:0 22px 55px rgba(0,0,0,.4); }
.cl-rank{ position:absolute; top:18px; right:18px; font-family:var(--font-family-1,"Unbounded"),sans-serif; font-weight:800; font-size:15px; color:#5e7585; }
.cl-rank-1{ border-color:rgba(244,202,128,.45); box-shadow:0 0 34px rgba(244,202,128,.14); } .cl-rank-1 .cl-rank{ color:#f4ca80; }
.cl-rank-2{ border-color:rgba(200,210,220,.3); } .cl-rank-2 .cl-rank{ color:#d6dee8; }
.cl-rank-3{ border-color:rgba(205,127,80,.35); } .cl-rank-3 .cl-rank{ color:#e0a878; }
.cl-logo{ width:60px; height:60px; border-radius:16px; display:flex; align-items:center; justify-content:center; font-family:var(--font-family-1,"Unbounded"),sans-serif; font-weight:800; font-size:20px; color:#fff; background:linear-gradient(135deg,#1f8a91,#2b6fff); box-shadow:0 10px 26px rgba(43,127,255,.35); margin-bottom:14px; }
.cl-rank-1 .cl-logo{ background:linear-gradient(135deg,#ffe08a,#f4ca80); color:#1a1206; }
.cl-name{ font-family:var(--font-family-1,"Unbounded"),sans-serif; font-size:19px; font-weight:700; color:var(--c-head); margin-bottom:6px; }
.cl-leader{ display:flex; align-items:center; gap:7px; font-size:13px; color:var(--c-muted); margin-bottom:16px; }
.cl-leader svg{ width:14px; height:14px; fill:#f4ca80; } .cl-leader b{ color:#e7edf2; font-weight:600; }
.cl-rating{ font-family:var(--font-family-1,"Unbounded"),sans-serif; font-size:26px; font-weight:800; background:linear-gradient(120deg,var(--c-acc2),var(--c-blue)); -webkit-background-clip:text; background-clip:text; color:transparent; margin-bottom:14px; }
.cl-rating span{ font-family:Inter,sans-serif; font-size:12px; font-weight:500; color:var(--c-muted); -webkit-text-fill-color:var(--c-muted); margin-left:6px; }
.cl-stats{ display:flex; gap:10px; margin-bottom:12px; }
.cl-stat{ flex:1; text-align:center; padding:10px 6px; border-radius:12px; background:rgba(255,255,255,.03); border:1px solid var(--c-bd); font-size:11px; color:var(--c-muted); }
.cl-stat span{ display:block; font-family:var(--font-family-1,"Unbounded"),sans-serif; font-size:16px; font-weight:800; color:var(--c-head); margin-bottom:2px; }
.cl-wrbar{ height:6px; border-radius:999px; background:rgba(255,255,255,.07); overflow:hidden; margin-bottom:16px; }
.cl-wrbar i{ display:block; height:100%; border-radius:999px; background:linear-gradient(90deg,var(--c-acc),var(--c-blue)); }
.cl-more{ width:100%; padding:11px; border-radius:12px; border:1px solid rgba(41,163,171,.3); background:rgba(41,163,171,.1); color:#5fe3ff; font-weight:700; font-size:14px; cursor:pointer; transition:.2s; }
.cl-more:hover{ background:rgba(41,163,171,.2); }
@keyframes clIn{ from{ opacity:0; transform:translateY(16px); } to{ opacity:1; transform:none; } }

/* модалка состава */
.cl-modal{ position:fixed; inset:0; z-index:9998; display:flex; align-items:center; justify-content:center; padding:20px; background:rgba(5,8,14,.62); backdrop-filter:blur(7px); -webkit-backdrop-filter:blur(7px); opacity:0; visibility:hidden; transition:.25s; }
.cl-modal.open{ opacity:1; visibility:visible; }
.cl-modal-box{ position:relative; width:100%; max-width:440px; background:#11161f; border:1px solid rgba(255,255,255,.08); border-radius:22px; padding:24px; box-shadow:0 40px 100px rgba(0,0,0,.6); transform:translateY(14px) scale(.97); transition:transform .3s cubic-bezier(.2,.9,.3,1); max-height:90vh; overflow:auto; }
.cl-modal.open .cl-modal-box{ transform:none; }
.cl-modal-x{ position:absolute; top:14px; right:14px; width:34px; height:34px; border-radius:50%; border:none; cursor:pointer; background:rgba(255,255,255,.05); color:#9fb2c0; font-size:20px; transition:.2s; }
.cl-modal-x:hover{ background:rgba(255,255,255,.12); color:#fff; transform:rotate(90deg); }
.cl-modal-head{ display:flex; align-items:center; gap:16px; margin-bottom:18px; }
.cl-logo-lg{ width:64px; height:64px; font-size:22px; margin:0; flex-shrink:0; }
.cl-modal-name{ font-family:var(--font-family-1,"Unbounded"),sans-serif; font-size:22px; font-weight:800; color:#fff; }
.cl-modal-leader{ font-size:13px; color:#9fb2c0; margin-top:3px; } .cl-modal-leader b{ color:#f4ca80; }
.cl-modal-stats{ display:grid; grid-template-columns:repeat(3,1fr); gap:10px; margin-bottom:18px; }
.cl-ms{ text-align:center; padding:14px 6px; border-radius:14px; background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.06); font-size:11px; color:#9fb2c0; }
.cl-ms span{ display:block; font-family:var(--font-family-1,"Unbounded"),sans-serif; font-size:18px; font-weight:800; background:linear-gradient(120deg,#5fe3ff,#2b7fff); -webkit-background-clip:text; background-clip:text; color:transparent; margin-bottom:3px; }
.cl-modal-mtitle{ display:flex; align-items:center; gap:8px; font-size:14px; font-weight:700; color:#eafcff; margin-bottom:12px; }
.cl-modal-mtitle svg{ width:16px; height:16px; fill:#5fe3ff; }
.cl-members{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:6px; }
.cl-members li{ display:flex; align-items:center; gap:11px; padding:10px 14px; border-radius:12px; background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.05); font-size:14px; color:#e7edf2; font-weight:600; }
.cl-m-av{ width:32px; height:32px; border-radius:9px; display:flex; align-items:center; justify-content:center; font-family:var(--font-family-1,"Unbounded"),sans-serif; font-weight:700; color:#fff; background:linear-gradient(135deg,#1f8a91,#2b6fff); font-size:14px; flex-shrink:0; }
.cl-m-leader{ margin-left:auto; font-style:normal; font-size:11px; font-weight:700; color:#f4ca80; padding:3px 9px; border-radius:999px; background:rgba(244,202,128,.12); }
.cl-m-empty{ justify-content:center; color:#5e7585; }

/* редактор */
.cl-se-head{ display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; margin:18px 0 14px; }
.cl-se-title{ font-family:var(--font-family-1,"Unbounded"),sans-serif; font-size:22px; font-weight:800; color:#eafcff; }
.cl-se-actions{ display:flex; gap:8px; flex-wrap:wrap; }
.cl-se-btn{ display:inline-flex; align-items:center; gap:7px; padding:10px 18px; border-radius:11px; cursor:pointer; font-weight:600; font-size:14px; background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); color:#e7edf2; transition:.2s; }
.cl-se-btn:hover{ background:rgba(255,255,255,.08); } .cl-se-btn svg{ width:15px; height:15px; fill:currentColor; }
.cl-se-primary{ background:linear-gradient(120deg,#29a3ab,#2b7fff); border:none; color:#fff; box-shadow:0 6px 20px rgba(43,127,255,.3); }
.cl-se-list{ display:flex; flex-direction:column; gap:12px; }
.cl-se-row{ background:rgba(255,255,255,.035); border:1px solid rgba(255,255,255,.06); border-radius:16px; padding:16px 18px; }
.cl-se-rh{ display:flex; align-items:center; justify-content:space-between; margin-bottom:12px; }
.cl-se-title2{ font-family:var(--font-family-1,"Unbounded"),sans-serif; font-weight:700; color:#eafcff; }
.cl-se-del{ width:34px; height:34px; border-radius:10px; cursor:pointer; display:flex; align-items:center; justify-content:center; background:rgba(255,80,80,.1); border:1px solid rgba(255,80,80,.3); color:#ff8585; }
.cl-se-del svg{ width:15px; height:15px; fill:currentColor; }
.cl-se-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(150px,1fr)); gap:12px; }
.cl-se-row label{ display:flex; flex-direction:column; gap:6px; font-size:12px; color:#9fb2c0; }
.cl-se-row label span{ font-weight:600; }
.cl-se-row input, .cl-se-row textarea{ background:rgba(0,0,0,.22); border:1px solid rgba(255,255,255,.07); border-radius:10px; padding:9px 12px; color:#e7edf2; font-size:14px; outline:none; font-family:Inter,sans-serif; }
.cl-se-row input:focus, .cl-se-row textarea:focus{ border-color:rgba(41,163,171,.5); }
.cl-se-row textarea{ resize:vertical; line-height:1.5; }
.cl-se-full{ margin-top:12px; }

@media (max-width:560px){ .cl-hero{ flex-direction:column; text-align:center; } .cl-grid{ grid-template-columns:1fr; } }

/* ===== Аватары и баннеры кланов ===== */
.cl-card{ padding:0 !important; }
.cl-cardtop{ position:relative; height:92px; background:linear-gradient(135deg,rgba(41,163,171,.3),rgba(43,127,255,.22)); background-size:cover; background-position:center; }
.cl-cardtop::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(17,22,31,0) 30%,rgba(17,22,31,.85)); }
.cl-card .cl-rank{ top:14px; right:16px; z-index:2; }
.cl-cardbody{ position:relative; padding:0 24px 24px; margin-top:-30px; }
.cl-logo{ overflow:hidden; border:3px solid #11161f; }
.cl-logo img{ width:100%; height:100%; object-fit:cover; display:block; }
.cl-logo-lg{ border:3px solid #11161f; overflow:hidden; }
/* баннер в модалке */
.cl-modal-banner{ height:0; border-radius:14px; background-size:cover; background-position:center; transition:height .25s, margin .25s; }
.cl-modal-banner.cl-has-banner{ height:120px; margin:0 0 16px; }
/* загрузчики в редакторе */
.cl-se-imgs{ display:flex; gap:14px; margin-bottom:14px; flex-wrap:wrap; align-items:flex-end; }
.cl-se-up{ display:flex; flex-direction:column; gap:6px; }
.cl-se-up > span{ font-size:12px; font-weight:600; color:#9fb2c0; }
.cl-se-prev{ width:64px; height:64px; border-radius:12px; background-color:rgba(0,0,0,.25); background-size:cover; background-position:center; background-repeat:no-repeat; border:1px dashed rgba(255,255,255,.14); }
.cl-se-up-wide .cl-se-prev{ width:200px; height:64px; }
.cl-se-prev.cl-has{ border-style:solid; border-color:rgba(41,163,171,.45); }
.cl-se-upbtn{ display:inline-flex; align-items:center; justify-content:center; gap:6px; padding:8px 12px; border-radius:10px; cursor:pointer; font-size:12px; font-weight:600; background:rgba(41,163,171,.12); border:1px solid rgba(41,163,171,.3); color:#5fe3ff; transition:.2s; }
.cl-se-upbtn:hover{ background:rgba(41,163,171,.22); } .cl-se-upbtn svg{ width:14px; height:14px; fill:currentColor; }
