.win{
  position:absolute;
  width: min(920px, calc(100vw - 80px));
  height: min(640px, calc(100vh - 140px));
  background: var(--glass);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow:hidden;
  backdrop-filter: blur(10px);
}

.win.active{
  outline: 1px solid rgba(58,160,255,0.35);
}

.win.minimized{
  display:none;
}

.win.maximized{
  left: 8px !important;
  top: 8px !important;
  width: calc(100vw - 16px) !important;
  height: calc(100vh - 64px) !important;
  border-radius: 14px;
}

.win-titlebar{
  height: 40px;
  display:flex;
  align-items:center;
  justify-content: space-between;
  padding: 0 10px 0 12px;
  border-bottom: 1px solid rgba(255,255,255,0.10);
  background: rgba(10,12,16,0.35);
  cursor: grab;
}
.win-titlebar:active{ cursor: grabbing; }

.win-title{
  font-size: 13px;
  color: rgba(255,255,255,0.92);
  overflow:hidden;
  white-space:nowrap;
  text-overflow: ellipsis;
  max-width: 65%;
}

.win-btns{ display:flex; gap: 6px; }
.win-btn{
  width: 34px;
  height: 28px;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.06);
  color: var(--text);
  cursor:pointer;
}
.win-btn:hover{
  background: rgba(255,255,255,0.12);
}
.win-btn.danger:hover{
  background: rgba(255,77,77,0.18);
  border-color: rgba(255,77,77,0.35);
}

.win-content{
  height: calc(100% - 40px);
  display:flex;
}

.win-framewrap{
  position:relative;
  width:100%;
  height:100%;
}

.win-iframe{
  width:100%;
  height:100%;
  border:0;
  background: rgba(0,0,0,0.35);
}

.win-blocked{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(5,8,12,0.65);
}
.win-blocked.hidden{ display:none; }

.blocked-card{
  width: min(560px, 92%);
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 16px;
  background: rgba(20,24,32,0.85);
  padding: 18px;
  box-shadow: var(--shadow);
}
.blocked-title{ font-size: 16px; margin-bottom: 8px; }
.blocked-sub{ color: var(--muted); font-size: 13px; margin-bottom: 14px; }
.blocked-open{
  border: 1px solid rgba(255,255,255,0.14);
  background: rgba(58,160,255,0.18);
  color: var(--text);
  padding: 10px 12px;
  border-radius: 12px;
  cursor:pointer;
}
.blocked-open:hover{ background: rgba(58,160,255,0.26); }


.win-resizer{
  position:absolute;
  right: 6px;
  bottom: 6px;
  width: 18px;
  height: 18px;
  cursor: nwse-resize;
  opacity: 0.75;
  border-radius: 8px;
  background: linear-gradient(135deg, rgba(255,255,255,0.0) 35%, rgba(255,255,255,0.20) 36%, rgba(255,255,255,0.20) 42%, rgba(255,255,255,0.0) 43%);
}
.win:hover .win-resizer{ opacity: 1; }
.win.maximized .win-resizer{ display:none; }


.snap-overlay{
  position: fixed;
  border-radius: 14px;
  border: 1px solid rgba(58,160,255,0.55);
  background: rgba(58,160,255,0.14);
  box-shadow: 0 14px 32px rgba(0,0,0,0.35);
  z-index: 200000;
  pointer-events: none;
}
.snap-overlay.hidden{ display:none; }


.win-resize-e,.win-resize-s,.win-resize-w,.win-resize-n{
  position:absolute;
  z-index: 5;
}
.win-resize-e{ top: 38px; right: -2px; width: 8px; height: calc(100% - 44px); cursor: ew-resize; }
.win-resize-w{ top: 38px; left: -2px; width: 8px; height: calc(100% - 44px); cursor: ew-resize; }
.win-resize-s{ left: 6px; bottom: -2px; height: 8px; width: calc(100% - 12px); cursor: ns-resize; }
.win-resize-n{ left: 6px; top: -2px; height: 8px; width: calc(100% - 12px); cursor: ns-resize; }
.win.maximized .win-resize-e,
.win.maximized .win-resize-s,
.win.maximized .win-resize-w,
.win.maximized .win-resize-n{ display:none; }


/* Resize handles */
.window .resize-handle{
  position:absolute;
  background:transparent;
  z-index: 50;
}
.window .resize-n{top:-6px;left:10px;right:10px;height:12px;cursor:n-resize;}
.window .resize-s{bottom:-6px;left:10px;right:10px;height:12px;cursor:s-resize;}
.window .resize-e{right:-6px;top:10px;bottom:10px;width:12px;cursor:e-resize;}
.window .resize-w{left:-6px;top:10px;bottom:10px;width:12px;cursor:w-resize;}
.window .resize-ne{top:-6px;right:-6px;width:14px;height:14px;cursor:ne-resize;}
.window .resize-nw{top:-6px;left:-6px;width:14px;height:14px;cursor:nw-resize;}
.window .resize-se{bottom:-6px;right:-6px;width:14px;height:14px;cursor:se-resize;}
.window .resize-sw{bottom:-6px;left:-6px;width:14px;height:14px;cursor:sw-resize;}

.window .window-titlebar{ user-select:none; }
