/* Bubble Widgets CSS v1.0 — Draggable Widget Boxes */

/* Widget Drawer (right side) */
.bw-drawer{position:fixed;top:60px;right:0;z-index:25;display:flex;flex-direction:column;gap:8px;padding:8px;
  transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);pointer-events:none}
.bw-drawer.bw-open{transform:translateX(-8px);pointer-events:auto}

.bw-drawer-card{width:72px;height:72px;border-radius:14px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
  background:rgba(15,17,32,0.92);border:1px solid rgba(100,150,255,0.1);cursor:grab;user-select:none;
  transition:all .3s;backdrop-filter:blur(12px);box-shadow:0 4px 16px rgba(0,0,0,0.3);position:relative;overflow:hidden}
.bw-drawer-card::before{content:'';position:absolute;inset:0;border-radius:14px;
  background:linear-gradient(135deg,rgba(100,150,255,0.06),transparent 60%);pointer-events:none}
.bw-drawer-card::after{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;
  background:conic-gradient(from 0deg,transparent,rgba(100,150,255,0.08),transparent 30%);
  animation:bwSpin 6s linear infinite;pointer-events:none;opacity:0;transition:opacity .3s}
.bw-drawer-card:hover::after{opacity:1}
@keyframes bwSpin{to{transform:rotate(360deg)}}
.bw-drawer-card:hover{border-color:rgba(100,150,255,0.35);transform:scale(1.08);
  box-shadow:0 6px 24px rgba(100,150,255,0.15),0 0 40px rgba(100,150,255,0.05)}
.bw-drawer-card:active{cursor:grabbing;transform:scale(.95)}
.bw-drawer-card .bw-ico{font-size:22px;line-height:1;filter:drop-shadow(0 0 6px rgba(100,150,255,0.3))}
.bw-drawer-card .bw-lbl{font-size:9px;font-weight:600;color:rgba(200,215,255,0.45);text-transform:uppercase;letter-spacing:.5px}
.bw-drawer-card.bw-placed{opacity:.35;pointer-events:none;transform:scale(.9)}

/* Widget Grid (center) */
.bw-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;width:440px;max-width:100%;margin:0 auto;padding:12px 0;min-height:0}
.bw-grid:empty{display:none}

/* Widget Box in grid */
.bw-box{border-radius:16px;padding:16px;position:relative;overflow:hidden;cursor:grab;user-select:none;
  background:rgba(15,17,32,0.85);border:1px solid rgba(100,150,255,0.08);
  backdrop-filter:blur(12px);box-shadow:0 4px 20px rgba(0,0,0,0.25);
  transition:all .3s;min-height:100px;display:flex;flex-direction:column;
  animation:bwBoxIn .4s cubic-bezier(.4,0,.2,1)}
@keyframes bwBoxIn{from{opacity:0;transform:scale(.85) translateY(12px)}to{opacity:1;transform:none}}
.bw-box::before{content:'';position:absolute;inset:0;border-radius:16px;pointer-events:none;
  background:linear-gradient(135deg,rgba(100,150,255,0.05),transparent 50%)}
.bw-box:hover{border-color:rgba(100,150,255,0.25);box-shadow:0 6px 28px rgba(100,150,255,0.1)}
.bw-box:active{cursor:grabbing;box-shadow:0 10px 40px rgba(100,150,255,0.2);transform:scale(1.03)}
.bw-box.bw-dragging{opacity:.6;transform:scale(.95)}
.bw-box.bw-drop-target{border-color:rgba(100,150,255,0.5);box-shadow:0 0 30px rgba(100,150,255,0.15)}
.bw-box-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.bw-box-title{font-size:11px;font-weight:600;color:rgba(200,215,255,0.5);text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;gap:6px}
.bw-box-title .bw-tico{font-size:16px}
.bw-box-remove{width:20px;height:20px;border-radius:50%;background:none;border:none;cursor:pointer;
  color:rgba(200,215,255,0.2);font-size:14px;display:flex;align-items:center;justify-content:center;
  transition:all .2s;opacity:0}
.bw-box:hover .bw-box-remove{opacity:1}
.bw-box-remove:hover{color:#ef4444;background:rgba(239,68,68,0.1)}
.bw-box-value{font-size:28px;font-weight:700;color:#e8eaf6;line-height:1.1}
.bw-box-sub{font-size:12px;color:rgba(200,215,255,0.35);margin-top:4px}
/* Shimmer loading */
.bw-box-shimmer{height:28px;width:60px;border-radius:6px;background:linear-gradient(90deg,rgba(100,150,255,0.05),rgba(100,150,255,0.12),rgba(100,150,255,0.05));background-size:200% 100%;animation:bwShimmer 1.5s infinite}
@keyframes bwShimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* Pulse accent per widget */
.bw-box[data-type="credits"] .bw-box-value{color:#a78bfa}
.bw-box[data-type="members"] .bw-box-value{color:#34d399}
.bw-box[data-type="courses"] .bw-box-value{color:#60a5fa}
.bw-box[data-type="support"] .bw-box-value{color:#fbbf24}
.bw-box[data-type="posts"] .bw-box-value{color:#f472b6}
.bw-box[data-type="chats"] .bw-box-value{color:#c084fc}

/* Light mode */
body:not(.dark) .bw-drawer-card{background:rgba(255,255,255,0.92);border-color:rgba(59,108,245,0.08);box-shadow:0 4px 16px rgba(0,0,0,0.06)}
body:not(.dark) .bw-drawer-card::before{background:linear-gradient(135deg,rgba(59,108,245,0.04),transparent 60%)}
body:not(.dark) .bw-drawer-card:hover{border-color:rgba(59,108,245,0.25);box-shadow:0 6px 24px rgba(59,108,245,0.1)}
body:not(.dark) .bw-drawer-card .bw-lbl{color:rgba(59,108,245,0.5)}
body:not(.dark) .bw-box{background:rgba(255,255,255,0.9);border-color:rgba(59,108,245,0.06);box-shadow:0 4px 20px rgba(0,0,0,0.04)}
body:not(.dark) .bw-box:hover{border-color:rgba(59,108,245,0.2);box-shadow:0 6px 28px rgba(59,108,245,0.08)}
body:not(.dark) .bw-box-title{color:rgba(30,40,80,0.5)}
body:not(.dark) .bw-box-value{color:#1a1d2e}
body:not(.dark) .bw-box-sub{color:#8891a5}
body:not(.dark) .bw-box[data-type="credits"] .bw-box-value{color:#7c3aed}
body:not(.dark) .bw-box[data-type="members"] .bw-box-value{color:#059669}
body:not(.dark) .bw-box[data-type="courses"] .bw-box-value{color:#2563eb}
body:not(.dark) .bw-box[data-type="support"] .bw-box-value{color:#d97706}
body:not(.dark) .bw-box[data-type="posts"] .bw-box-value{color:#db2777}
body:not(.dark) .bw-box[data-type="chats"] .bw-box-value{color:#7c3aed}

@media(max-width:768px){
  .bw-drawer{top:56px;gap:6px;padding:6px}
  .bw-drawer-card{width:58px;height:58px;border-radius:12px}
  .bw-drawer-card .bw-ico{font-size:18px}
  .bw-drawer-card .bw-lbl{font-size:8px}
  .bw-grid{grid-template-columns:repeat(2,1fr);gap:10px;width:100%}
  .bw-box{min-height:85px;padding:14px}
  .bw-box-value{font-size:24px}
}
