:root{
  --bg:#151515;
  --desktop-bg:#151515;
  --desktop-bg-image:none;
  --icon-name-color:#f2f6ff;
  --icon-name-shadow:0 1px 2px rgba(0,0,0,0.75), 0 0 6px rgba(0,0,0,0.35);
  --desk-zoom:1;
  --panel:#202020;
  --panel2:#2a2a2a;
  --text:#eaeaea;
  --muted:#b8b8b8;
  --accent:#4aa3ff;
  --danger:#e74c3c;
  --folder-color:#ffca28;
  --folder-icon-scale:1;
  --desc-pop-bg:rgba(18,22,30,0.95);
  --desc-pop-text:#f3f7ff;
  --desc-pop-border:rgba(255,255,255,0.12);
}

*{box-sizing:border-box}
body{margin:0;background:var(--desktop-bg);color:var(--text);font-family:Arial, Helvetica, sans-serif;user-select:none; overflow-x:hidden}

/* Full-screen wallpaper layer (dimmed) */
#wallpaper{
  position:fixed;
  inset:0;
  z-index:0;
  pointer-events:none;
  background-image:var(--desktop-bg-image);
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  filter: brightness(0.65) saturate(0.75) contrast(0.92);
}
#wallpaperFx{
  position:fixed;
  inset:0;
  z-index:0;
  width:100%;
  height:100%;
  pointer-events:none;
  display:none;
  opacity:0.95;
}
/* Top bar */
:root{ --topbar-h: 96px; }
#topbar{
  height:var(--topbar-h);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  width:100%;
  max-width:100%;
  /* breathing room on the left + avoid right clipping on some browsers */
  padding:0 12px;
  box-sizing:border-box;
  overflow:visible;
  background:var(--panel);
  border-bottom:1px solid #000;
  position:relative;
  z-index:200;
}

.topbar-left,
.topbar-right{
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
}

.icon-btn{
  padding:6px 10px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
}

/* Topbar hover labels */
.tip-btn{
  position:relative;
}
.tip-btn[data-tip]:hover::after{
  content:attr(data-tip);
  position:absolute;
  left:50%;
  top:calc(100% + 8px);
  transform:translateX(-50%);
  white-space:nowrap;
  max-width:220px;
  overflow:hidden;
  text-overflow:ellipsis;
  padding:5px 8px;
  border-radius:8px;
  border:1px solid rgba(255,255,255,0.18);
  background:rgba(16,20,28,0.96);
  color:rgba(238,241,247,0.95);
  font-size:11px;
  line-height:1.2;
  z-index:1200;
  pointer-events:none;
}

/* Topbar mode switch (bureau / fenêtre) */
.mode-toggle{
  white-space:nowrap;
}

.avatar-btn{
  width:50px;
  height:50px;
  border-radius:999px;
  overflow:hidden;
  padding:0;
  border:1px solid rgba(255,255,255,0.14);
  background:rgba(255,255,255,0.06);
  cursor:pointer;
}
.avatar-wrap{
  display:inline-flex;
  flex-direction:column;
  align-items:center;
  gap:3px;
}
.avatar-subscribe{
  border:0;
  background:transparent;
  color:#9bd5a6;
  font-size:10px;
  line-height:1;
  padding:0;
  cursor:pointer;
  text-transform:lowercase;
}
.avatar-subscribe:hover{
  text-decoration:underline;
  text-underline-offset:2px;
}
.avatar-btn img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.brand{font-weight:700; letter-spacing:1px; margin-right:10px; padding-left:2px}
.project-badge{
  --project-title-w: 14ch;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  justify-content:center;
  gap:8px;
  margin-right:50px;
  padding-top:6px;
  width:var(--project-title-w);
}
.project-title-btn{
  position:relative;
  overflow:visible;
  padding:0;
  margin:0;
  border:0;
  background:transparent;
  color:var(--text);
  font-weight:900;
  letter-spacing:0.8px;
  font-size:24px;
  line-height:1.02;
  cursor:pointer;
  width:var(--project-title-w);
  text-align:left;
  animation: projectGlow 7s ease-in-out infinite;
}
.project-title-label{
  position:relative;
  display:inline-block;
  z-index:2;
}
.project-title-btn:hover{ opacity:0.9; }
@keyframes projectGlow{
  0%, 78%, 100% { text-shadow:none; opacity:1; }
  84% { text-shadow:0 0 10px rgba(255,255,255,0.40), 0 0 18px rgba(255,255,255,0.22); opacity:1; }
  90% { text-shadow:0 0 6px rgba(255,255,255,0.26); opacity:0.96; }
}
.project-title-label .project-star{
  position:absolute !important;
  display:block;
  width:5px;
  height:5px;
  border-radius:999px;
  background:radial-gradient(circle, rgba(255,255,255,0.96) 0%, rgba(249,239,191,0.9) 45%, rgba(249,239,191,0) 75%);
  box-shadow:0 0 6px rgba(249,239,191,0.85), 0 0 12px rgba(255,255,255,0.35);
  opacity:0;
  transform:scale(0.85);
  pointer-events:none;
  z-index:1;
}
.project-title-label .project-star.s1{
  left:-7px;
  top:-6px;
}
.project-title-label .project-star.s2{
  right:-5px;
  top:-9px;
  width:6px;
  height:6px;
}
.project-title-label .project-star.s3{
  right:-8px;
  bottom:-3px;
  width:4px;
  height:4px;
}
.project-title-label .project-star.s4{
  left:56%;
  bottom:-8px;
  width:4px;
  height:4px;
}
.project-title-label .project-star.is-on{
  animation: projectStarTwinkle 1.8s ease-in-out 1;
}
@keyframes projectStarTwinkle{
  0%, 100% { opacity:0; transform:scale(0.9); }
  35% { opacity:0.65; transform:scale(1.08); }
  58% { opacity:0.25; transform:scale(1.0); }
  78% { opacity:0.08; transform:scale(0.95); }
}
#brand.brand{
  display:block;
  font-size:15px;
  font-weight:900;
  letter-spacing:0.4px;
  color:var(--muted);
  margin-right:0;
  padding-left:0;
  line-height:1.1;
  width:var(--project-title-w);
  white-space:normal;
  word-break:normal;
  overflow-wrap:break-word;
  text-align:left;
}
.project-hover-card{
  position:fixed;
  z-index:6200;
  display:none;
  min-width:260px;
  max-width:min(420px, calc(100vw - 24px));
  padding:12px 14px;
  border-radius:14px;
  background:rgba(16,20,28,0.96);
  border:1px solid rgba(255,255,255,0.14);
  box-shadow:0 18px 48px rgba(0,0,0,0.42);
  color:#f4f7ff;
  pointer-events:none;
}
.project-hover-card.is-visible{
  display:block;
}
.project-hover-title{
  font-size:14px;
  font-weight:800;
  margin-bottom:6px;
}
.project-hover-desc{
  font-size:13px;
  line-height:1.45;
  color:rgba(255,255,255,0.92);
  white-space:pre-wrap;
}
.project-hover-meta{
  margin-top:8px;
  font-size:12px;
  color:rgba(255,255,255,0.68);
}
.btn{
  background:var(--panel2); color:var(--text); border:1px solid #000;
  padding:6px 10px; border-radius:8px; cursor:pointer;
}
.btn:hover{border-color:#333}
.btn.small{padding:4px 8px; border-radius:7px; font-size:12px}
.btn.danger{background:#3a1b1b; border-color:#000}
.badge{
  display:inline-block; padding:4px 8px; border-radius:999px; background:#111; border:1px solid #000;
  font-size:12px; color:var(--muted); margin-right:8px;
}
#roleBadge.badge-avatar{
  padding:2px 6px 3px;
  background:transparent;
  border:0;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:2px;
  flex-direction:column;
  position:relative;
}
#roleBadge.badge-avatar img{
  width:28px;
  height:28px;
  object-fit:cover;
  display:block;
  border-radius:999px;
  border:1px solid rgba(255,255,255,0.18);
}
#roleBadge.badge-avatar .badge-sub-label{
  font-size:10px;
  line-height:1;
  color:#9bd5a6;
  text-transform:lowercase;
  margin-top:2px;
}
#roleBadge.badge-avatar .badge-sub-label.clickable{
  cursor:pointer;
  text-decoration:underline;
  text-underline-offset:2px;
}
#roleBadge.badge-avatar .badge-sub-arrow{
  position:absolute;
  top:-6px;
  left:50%;
  width:10px;
  height:10px;
  margin-left:-5px;
  border-radius:999px;
  background:#7ee18e;
  color:#112417;
  font-size:8px;
  line-height:10px;
  text-align:center;
  font-weight:900;
  box-shadow:0 0 3px rgba(126,225,142,0.45);
}
#roleBadge.badge-avatar .badge-sub-arrow::before{
  content:'✓';
}
.path{margin-left:10px; color:var(--muted); font-size:12px}
#desktop{
  position:relative;
  height:calc(100vh - var(--topbar-h));
  width:100%;
  overflow:hidden;
  z-index:1;
}

.icon, .postit, .urlwin{ z-index:2; }
.icon{
  position:absolute;
  width:96px;
  padding:6px 6px 8px;
  border-radius:10px;
  text-align:center;
  cursor:default;
  border:1px solid transparent;
  background:transparent;
  transform: scale(var(--desk-zoom));
  transform-origin: top left;
}

.postit{
  transform: scale(var(--desk-zoom));
  transform-origin: top left;
}
.icon.selected{
  border-color:rgba(255,255,255,0.25);
  background:rgba(255,255,255,0.06);
}
.icon .glyph{
  width:64px; height:64px; margin:0 auto 6px;
  display:flex; align-items:center; justify-content:center;
  border-radius:12px;
  background:rgba(255,255,255,0.06);
  overflow:hidden;
}

/* Desktop thumbnail players (video + YouTube) */
.icon .glyph{ position:relative; }
.icon .glyph video,
.icon .glyph iframe{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:0;
  display:block;
  background:#000;
}
.icon .glyph video{ object-fit:cover; }


.icon .play-overlay{
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%, -50%);
  width:44px;
  height:44px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,0.28);
  background:rgba(0,0,0,0.40);
  backdrop-filter: blur(6px);
  display:none;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  z-index:3;
}
.icon .play-overlay .tri{
  width:0; height:0;
  border-top:9px solid transparent;
  border-bottom:9px solid transparent;
  border-left:14px solid rgba(255,255,255,0.92);
  margin-left:3px;
}
.icon:hover .play-overlay,
.icon.selected .play-overlay{ display:flex; }
.icon.is-video .play-overlay{ display:flex; }
.icon.playing .play-overlay{ display:none; }

/* Folder icon: use colored SVG (settings -> folder color) */
.icon.is-folder .glyph{background:transparent; color:var(--folder-color)}
.icon.is-folder .glyph svg{width:58px; height:46px; display:block}

/* Per-folder color (overrides global folder color when set inline) */
.icon.is-folder .glyph{ color:var(--folder-color); }

/* Folder color palette */
.color-palette{
  position:fixed;
  z-index:9999;
  background:rgba(25,25,28,0.98);
  border:1px solid rgba(255,255,255,0.18);
  border-radius:14px;
  padding:10px;
  box-shadow:0 12px 32px rgba(0,0,0,0.45);
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  width:220px;
}
.color-palette .sw{
  width:26px; height:26px;
  border-radius:8px;
  border:1px solid rgba(255,255,255,0.22);
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:800;
  color:rgba(255,255,255,0.92);
}
.color-palette .sw:focus{ outline:2px solid rgba(255,255,255,0.45); outline-offset:2px; }
.color-palette .sw.default{
  background:rgba(255,255,255,0.10);
}

/* Resizable photo thumbnails */
.icon.photo-resizable{padding:6px; min-width:110px; min-height:110px}
.icon.photo-resizable.is-video{min-width:160px; min-height:100px}
.icon.photo-resizable .glyph{width:100%; height:100%; margin:0}
.icon.photo-resizable .glyph img{width:100%; height:100%; object-fit:cover}
.icon.photo-resizable .glyph video{width:100%; height:100%; object-fit:cover}
.icon.photo-resizable .glyph iframe{width:100%; height:100%}
.icon.photo-resizable .name{
  position:absolute;
  left:6px; right:6px; bottom:6px;
  padding:3px 6px;
  border-radius:10px;
  background:rgba(0,0,0,0.45);
}
.icon.photo-resizable .resize-handle{
  position:absolute;
  width:14px; height:14px;
  right:2px; bottom:2px;
  border-radius:4px;
  background:rgba(0,0,0,0.35);
  border:1px solid rgba(255,255,255,0.25);
  cursor:nwse-resize;
  display:none;
}
.icon.photo-resizable:hover .resize-handle,
.icon.photo-resizable.selected .resize-handle{display:block}
.icon .glyph img{
  width:100%; height:100%; object-fit:cover;
}
.icon.is-shortcut .glyph{ position:relative; }
.icon.is-shortcut-folder .glyph{
  background:transparent;
  color:var(--folder-color);
}
.icon .shortcut-badge{
  position:absolute;
  right:2px;
  bottom:2px;
  width:20px;
  height:20px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:12px;
  font-weight:900;
  color:#fff;
  background:rgba(0,0,0,0.68);
  border:1px solid rgba(255,255,255,0.35);
  box-shadow:0 1px 4px rgba(0,0,0,0.45);
  pointer-events:none;
  z-index:4;
}
.icon .name{
  font-size:12px; line-height:1.1; color:var(--icon-name-color, var(--text));
  text-shadow:var(--icon-name-shadow, none);
  word-break:break-word;
}
/* Photo thumbnails: enforce high-contrast label */
.icon.photo-resizable .name{
  display:inline-block;
  margin-top:2px;
  padding:2px 6px;
  border-radius:7px;
  background:rgba(46,46,46,0.92);
  border:1px solid rgba(255,255,255,0.22);
  color:#ffffff !important;
  text-shadow:none !important;
}

/* ===== Likes (media) ===== */
.icon{ position:absolute; }
.icon .like-btn{
  position:absolute;
  right:6px;
  bottom:6px;
  display:flex;
  align-items:center;
  gap:6px;
  padding:4px 8px;
  border-radius:999px;
  background:rgba(0,0,0,0.55);
  border:1px solid rgba(255,255,255,0.18);
  color:rgba(255,255,255,0.92);
  font-weight:800;
  font-size:12px;
  line-height:1;
  cursor:pointer;
  user-select:none;
  backdrop-filter:blur(6px);
}
.icon .like-btn .like-heart{ font-size:13px; transform:translateY(-0.5px); }
.icon .like-btn .like-heart{ width:13px; display:inline-block; text-align:center; }
.icon .like-btn.like-side{
  /* For standard small icons (non-resizable): avoid covering the filename */
  bottom:auto;
  top:8px;
  right:-8px;
  padding:4px 6px;
  gap:4px;
}
.icon .like-btn.liked{
  background:rgba(255, 0, 80, 0.35);
  border-color:rgba(255, 0, 80, 0.45);
}
.icon .like-btn:active{ transform:scale(0.96); }
.icon:hover .like-btn{ filter:brightness(1.06); }


/* Social stack (like + comment) for multimedia thumbnails */
.icon .icon-social{
  position:absolute;
  right:6px;
  bottom:6px;
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:6px;
  z-index:6;
  opacity:0;
  pointer-events:none;
  transform:translateY(2px);
  transition:opacity .15s ease, transform .15s ease;
}
.icon:hover .icon-social,
.icon.selected .icon-social{
  opacity:1;
  pointer-events:auto;
  transform:translateY(0);
}
.icon .icon-social.icon-social-side{
  bottom:auto;
  top:8px;
  right:-8px;
}

.icon .icon-social.icon-social-top{
  bottom:auto;
  top:6px;
  right:6px;
  flex-direction:row;
  align-items:center;
  gap:6px;
}
.icon .icon-social .like-btn,
.icon .icon-social .comment-btn{
  position:static;
  right:auto;
  bottom:auto;
  top:auto;
  margin:0;
}

/* Post-it notes: like button lives in the header tools (not absolute positioned) */
.postit .like-btn.postit-like{
  position:static;
  padding:2px 6px;
  font-size:11px;
  gap:4px;
  border-radius:999px;
  background:rgba(255,255,255,0.45);
  border:1px solid rgba(0,0,0,0.18);
  color:#111;
  backdrop-filter:none;
}
.postit .like-btn.postit-like.liked{
  background:rgba(255, 0, 80, 0.18);
  border-color:rgba(255, 0, 80, 0.35);
}

/* Post-it notes: social (like + comment) hidden until hover */
.postit .postit-social{
  display:flex;
  flex-direction:row;
  align-items:center;
  gap:6px;
  margin-left:6px;
  opacity:0;
  pointer-events:none;
  transform:translateY(2px);
  transition:opacity .15s ease, transform .15s ease;
}
.postit:hover .postit-social,
.postit.selected .postit-social{
  opacity:1;
  pointer-events:auto;
  transform:translateY(0);
}
.postit .comment-btn.postit-comment{
  position:static;
  padding:2px 6px;
  font-size:11px;
  gap:4px;
  border-radius:999px;
  background:rgba(255,255,255,0.45);
  border:1px solid rgba(0,0,0,0.18);
  color:#111;
  backdrop-filter:none;
}
.postit .comment-btn.postit-comment.open{
  background:rgba(0,0,0,0.08);
}

/* URL widget: social actions in header, hidden until hover */
.urlwin .urlwin-social{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:6px;
  margin-left:6px;
  opacity:0;
  pointer-events:none;
  transform:translateY(2px);
  transition:opacity .15s ease, transform .15s ease;
}
.urlwin:hover .urlwin-social,
.urlwin.selected .urlwin-social{
  opacity:1;
  pointer-events:auto;
  transform:translateY(0);
}
.urlwin .like-btn.urlwin-like,
.urlwin .comment-btn.urlwin-comment{
  position:static;
  padding:2px 6px;
  font-size:11px;
  gap:4px;
  border-radius:999px;
  background:rgba(0,0,0,0.55);
  border:1px solid rgba(255,255,255,0.18);
  color:rgba(255,255,255,0.92);
  backdrop-filter:blur(6px);
}

/* Photos: show title only on hover */
.icon.is-photo .name{
  opacity:0;
  transition:opacity .12s ease;
}
.icon.is-photo:hover .name{ opacity:1; }

/* Videos: smaller title font */
.icon.is-video .name{ font-size:11px; }

/* Videos: always show title below the thumbnail */
.icon.is-video .name{
  opacity:1;
  transition:none;
  display:block;
  max-width:100%;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.icon.is-video:hover .name{ opacity:1; }
/* emoji glyph fallback */
.glyph .emoji{font-size:34px; line-height:1}
.glyph .emoji.file-badge{
  min-width:46px;
  height:28px;
  padding:0 8px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:8px;
  border:1px solid rgba(255,255,255,.28);
  background:linear-gradient(180deg, rgba(120,140,170,.38), rgba(58,68,88,.52));
  font-size:13px;
  line-height:1;
  font-weight:900;
  letter-spacing:.04em;
  color:#f7f9ff;
  text-shadow:0 1px 2px rgba(0,0,0,.5);
}

/* Event icon glyph (calendar with start date) */
.event-date-glyph{
  width:54px;
  height:54px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,0.20);
  background:linear-gradient(180deg, rgba(255,255,255,0.14), rgba(255,255,255,0.05));
  display:flex;
  flex-direction:column;
  overflow:hidden;
  box-shadow:inset 0 -10px 18px rgba(0,0,0,0.22);
}
.event-date-glyph.is-own{
  border-color:rgba(98,203,255,0.52);
}
.event-date-glyph.is-imported{
  border-color:rgba(255,180,96,0.58);
}
.event-date-glyph.is-past{
  border-color:rgba(255,95,95,0.72);
  background:linear-gradient(180deg, rgba(255,105,105,0.24), rgba(120,20,20,0.18));
}
.event-date-glyph-month{
  display:flex;
  align-items:center;
  justify-content:center;
  height:18px;
  font-size:10px;
  letter-spacing:.08em;
  font-weight:800;
  color:var(--event-month-color, #fff);
  background:var(--event-month-bg, rgba(74,163,255,0.86));
}
.event-date-glyph.is-imported .event-date-glyph-month{
  background:var(--event-month-bg, rgba(255,168,74,0.90));
}
.event-date-glyph.is-past .event-date-glyph-month{
  background:var(--event-month-bg, rgba(235,72,72,0.94));
}
.event-date-glyph-day{
  flex:1;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:23px;
  line-height:1;
  font-weight:900;
  color:var(--event-day-color, rgba(255,255,255,0.96));
}
.event-date-glyph.is-past .event-date-glyph-day{
  color:var(--event-day-color, rgba(255,242,242,0.98));
}

.actions{
  /* Positioned by JS next to the selected icon */
  position:fixed;
  left:-9999px; top:-9999px;
  z-index: 1200;
  display:none;
  flex-direction:column;
  gap:8px;
  padding:8px; border-radius:14px;
  background:rgba(0,0,0,0.4); border:1px solid rgba(255,255,255,0.12);
  backdrop-filter: blur(6px);
}

.overlay{
  position:fixed; inset:0;
  background:rgba(0,0,0,0.65);
  display:flex; align-items:center; justify-content:center;
  z-index:1000;
}
.panel{
  width:min(360px, 90vw);
  background:var(--panel);
  border:1px solid #000;
  border-radius:16px;
  overflow:hidden;
  box-shadow:0 18px 60px rgba(0,0,0,0.6);
}
.panel-title{
  padding:10px 12px;
  background:var(--panel2);
  border-bottom:1px solid #000;
  font-weight:700;
}
.panel-body{padding:12px}
.input{
  width:100%; padding:10px 12px;
  border-radius:10px; border:1px solid #000;
  background:#0f0f0f; color:var(--text);
  outline:none;
}

/* Make native date pickers usable/visible on dark inputs */
.input[type="date"]{
  color-scheme: dark;
}
.input[type="date"]::-webkit-calendar-picker-indicator{
  filter: invert(1);
  opacity: 0.85;
  cursor: pointer;
}
.select{
  width:100%; padding:10px 12px;
  border-radius:10px; border:1px solid #000;
  background:#0f0f0f; color:var(--text);
  outline:none;
}
.row{display:flex; gap:8px; margin-top:10px}
.err{margin-top:10px; color:#ffb3ab; font-size:12px; min-height:16px}

.win{
  position:absolute;
  left:10vw; top:10vh;
  width:80vw; height:78vh;
  background:#fff;
  border-radius:16px;
  overflow:hidden;
  border:1px solid #000;
  z-index:900;
  box-shadow:0 18px 60px rgba(0,0,0,0.55);
}
.win-header{
  height:40px;
  background:#262626;
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 10px;
  cursor:move;
}
.win-title{font-weight:700; font-size:13px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:65vw}
.win-body{
  height:calc(100% - 40px);
  background:#f5f5f5;
  overflow:auto;
}
.win-body .pad{padding:12px}
.win-body iframe{width:100%; height:100%; border:0}
.win-body img{max-width:100%; height:auto; display:block; margin:0 auto}
.win-body video{width:100%; height:auto}
.win-body audio{width:100%; margin-top:12px}
.win.resizable{resize:both; overflow:hidden}
.win.maximized{
  left:0 !important; top:44px !important;
  width:100vw !important; height:calc(100vh - 44px) !important;
  border-radius:0 !important;
}

/* Folder window browser */
.fb-bar{
  position:sticky;
  top:0;
  z-index:2;
  display:flex;
  gap:8px;
  align-items:center;
  padding:10px;
  background:#f7f7f7;
  border-bottom:1px solid #ddd;
}
.fb-path{
  font-size:12px;
  color:#444;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.fb-list{padding:8px}
.fb-item{
  display:flex;
  align-items:center;
  gap:10px;
  padding:8px 10px;
  border-radius:10px;
  cursor:pointer;
  user-select:none;
}
.fb-item:hover{background:#efefef}
.fb-item.selected{background:#e6e6e6}
.fb-ic{width:22px; text-align:center}
.fb-name{flex:1; font-size:14px; color:#111}
.fb-kind{font-size:12px; color:#666}
.fb-thumb{width:22px; height:22px; object-fit:cover; border-radius:6px; display:block}

/* Folder color in folder browser */
.fb-ic.fb-folder svg{width:22px; height:18px; display:block}
.fb-list.thumb-view .fb-ic.fb-folder svg{width:64px; height:48px}

/* PDF icon in folder listing */
.fb-ic.pdf{
  width:22px;
  height:22px;
  display:flex;
  align-items:center;
  justify-content:center;
}

.fb-list.thumb-view{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(140px, 1fr));
  gap:10px;
  padding:10px;
}
.fb-list.thumb-view .fb-item{
  flex-direction:column;
  align-items:center;
  gap:6px;
  padding:10px;
}
.fb-list.thumb-view .fb-ic{width:auto; font-size:34px}
.fb-list.thumb-view .fb-thumb{width:96px; height:96px; border-radius:12px}
/* In thumb view, keep PDF icon centered and avoid overflowing (it used to inherit a 22px container) */
.fb-list.thumb-view .fb-ic.pdf{
  width:96px;
  height:96px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.fb-list.thumb-view .fb-ic.pdf .fb-thumb{width:72px; height:72px; border-radius:14px}
.fb-list.thumb-view .fb-name{
  width:100%;
  text-align:center;
  font-size:13px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.fb-list.thumb-view .fb-kind{display:none}

/* Multimedia: cover topbar when maximized so Racine/↑ stay underneath */
.win.cover-topbar{ z-index:1200; }

/* MENU (fix: position fixed to avoid offset when window/desktop is transformed) */
.menu{
  position:fixed; /* <-- CHANGÉ (était absolute) */
  background:rgba(30,30,30,0.95);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:14px;
  padding:6px;
  z-index:950;
  min-width:180px;
  box-shadow:0 18px 60px rgba(0,0,0,0.55);
}
.menu-item{
  width:100%;
  text-align:left;
  padding:10px 10px;
  background:transparent;
  border:0;
  color:var(--text);
  border-radius:10px;
  cursor:pointer;
}
.menu-item:hover{background:rgba(255,255,255,0.08)}

/* QUILL_FIX_START */
.ql-container, .ql-editor{
  color:#000 !important;
}
.ql-toolbar.ql-snow{
  background:#fff;
}
.ql-toolbar.ql-snow .ql-picker-label,
.ql-toolbar.ql-snow .ql-picker-item,
.ql-toolbar.ql-snow button{
  color:#000;
}
/* QUILL_FIX_END */

/* TRASH_START */
/* TRASH_END */

/* DRAG_FIX_START */
.icon.dragging{ opacity:0.95; }
.icon.hit-ignore{ pointer-events:none; }
.postit.dragging{ opacity:0.95; }
.postit.hit-ignore{ pointer-events:none; }

/* Lightweight drag proxy (smooth dragging even with iframes/videos) */
.drag-proxy{
  border: 1px dashed rgba(255,255,255,0.55);
  background: rgba(0,0,0,0.18);
  border-radius: 14px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.25);
  will-change: transform;
}
.drag-proxy-label{
  position: absolute;
  left: 10px;
  top: 8px;
  padding: 4px 8px;
  border-radius: 999px;
  font-size: 12px;
  line-height: 1;
  color: rgba(255,255,255,0.92);
  background: rgba(0,0,0,0.35);
  max-width: calc(100% - 20px);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
/* DRAG_FIX_END */

/* MEDIA_FIT_START */
.win-body{position:relative;}
.win.media-view .win-body{ background:#000; overflow:hidden; }
.media-wrap{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#000;
}
.media-wrap video{
  width:100%;
  height:100%;
  max-width:100%;
  max-height:100%;
  object-fit:cover;
  background:#000;
}
/* Photos : afficher entièrement dans la fenêtre (pas de crop) */
.media-wrap img{
  width:100%;
  height:100%;
  max-width:100%;
  max-height:100%;
  object-fit:contain;
  background:#000;
}
/* MEDIA_FIT_END */

/* DROPZONES_START */
.drop-zones{
  position:fixed;
  left:50%;
  top:70px; /* below topbar */
  transform:translateX(-50%);
  display:flex;
  gap:10px;
  z-index:990;
  pointer-events:none; /* allow click only on zones */
}
.drop-zone{
  pointer-events:auto;
  padding:10px 14px;
  border-radius:999px;
  background:rgba(0,0,0,0.45);
  border:1px solid rgba(255,255,255,0.14);
  color:var(--text);
  font-size:12px;
  backdrop-filter: blur(6px);
  cursor:pointer;
  user-select:none;
}
.drop-zone.hot{
  background:rgba(74, 163, 255, 0.20);
  border-color:rgba(74, 163, 255, 0.55);
}
.upload-overlay{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,0.65);
  display:flex;
  justify-content:center;
  align-items:flex-start;
  padding-top:56px;
  z-index:7000;
}
.upload-box{
  width:min(420px, 90vw);
  background:rgba(32,32,32,0.95);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:18px;
  padding:14px 16px;
  box-shadow:0 18px 60px rgba(0,0,0,0.6);
}
.upload-title{font-weight:700; margin-bottom:8px}
.upload-file{font-size:12px; color:var(--muted); margin-bottom:10px; word-break:break-word}
.upload-bar{height:10px; background:rgba(255,255,255,0.10); border-radius:999px; overflow:hidden; border:1px solid rgba(255,255,255,0.12)}
.upload-bar-fill{height:100%; width:0% ; background:rgba(74,163,255,0.9)}
.upload-pct{margin-top:8px; font-size:12px; color:var(--muted); text-align:right}

/* Indeterminate progress (used for short server sync during drag/drop moves) */
@keyframes indet {
  0% { transform: translateX(-70%); }
  100% { transform: translateX(250%); }
}
.upload-bar-fill.indeterminate{
  width:35% !important;
  animation: indet 1s linear infinite;
}
/* UPLOAD_OVERLAY_END */

/* QUILL_TEXT_COLOR_START */
/* Base text color for editors, but DO NOT force child elements (so Quill color formatting can work). */
.ql-container, .ql-editor{
  color:#000;
}
/* Keep placeholder readable but subtle */
.ql-editor.ql-blank::before{
  color: rgba(0,0,0,0.35) !important;
}
/* Ensure any plain pre blocks are readable */
.win-body pre{
  color:#000;
}
/* QUILL_TEXT_COLOR_END */

/* TXT_EDITOR_START */
.txt-editor{
  width:100%;
  height: calc(78vh - 180px);
  padding:12px;
  border-radius:12px;
  border:1px solid #ddd;
  background:#fff;
  color:#000;
  font-family: Arial, Helvetica, sans-serif;
  font-size:14px;
  line-height:1.4;
  resize: vertical;
}

/* NOTE_WINDOW_START */
.note-win{
  height:100%;
  display:flex;
  flex-direction:column;
  box-sizing:border-box;
}
.note-toolbar{
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
  margin-bottom:10px;
}
.note-field{
  display:flex;
  gap:8px;
  align-items:center;
  font-size:12px;
  color:#333;
}
.note-hint{ font-size:12px; color:#666; }
.note-area{
  flex:1 1 auto;
  width:100%;
  padding:12px;
  border-radius:12px;
  border:1px solid #ddd;
  background:#fff;
  color:#000;
  font-family: Arial, Helvetica, sans-serif;
  font-size:14px;
  line-height:1.4;
  resize:none;
  min-height:220px;
}

.note-format{
  display:flex;
  align-items:center;
  gap:6px;
  padding:8px 10px;
  border:1px solid rgba(255,255,255,0.10);
  border-radius:12px;
  background:rgba(255,255,255,0.04);
}
.note-format .pf-btn{
  height:24px;
  padding:0 10px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,0.14);
  background:rgba(0,0,0,0.18);
  color:var(--text);
  cursor:pointer;
  font-size:12px;
  line-height:1;
}
.note-format .pf-color{
  width:34px;
  height:24px;
  padding:0;
  border-radius:10px;
  border:1px solid rgba(255,255,255,0.14);
  background:rgba(0,0,0,0.18);
}
.note-area-rich{
  min-height:260px;
  padding:12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,0.10);
  background:rgba(255,255,255,0.03);
  overflow:auto;
  user-select:text;
}
.note-area-rich:focus{ outline:none; box-shadow: 0 0 0 3px rgba(255,255,255,0.08); }
.note-area[readonly]{ opacity:0.85; }
/* NOTE_WINDOW_END */
.txt-view{
  white-space:pre-wrap;
  background:#fff;
  padding:12px;
  border-radius:12px;
  border:1px solid #ddd;
  min-height:200px;
  color:#000;
}
/* TXT_EDITOR_END */

/* BREADCRUMB_START */
#path{
  display:flex;
  align-items:center;
  gap:6px;
  flex-wrap:wrap;
  user-select:none;
}
#path .crumb{
  cursor:pointer;
  padding:2px 6px;
  border-radius:8px;
  color:var(--text);
}
#path .crumb:hover{
  background:rgba(255,255,255,0.10);
}
#path .sep{
  opacity:0.55;
}
/* BREADCRUMB_END */

/* UI_POLISH_START */
:root{
  --desktop-bg: #0f0f10;
  --desktop-bg-image: none;
}

/* Desktop background */
#desktop{
  background: var(--desktop-bg);
  background-image: var(--desktop-bg-image);
  background-size: cover;
  background-position: center;
}

/* Topbar layout: single line */
#topbar{
  display:flex;
  align-items:center;
  gap:12px;
}
#topbar .logo, #topbar #logo{
  white-space:nowrap;
}
#path.breadcrumbs{
  flex:1 1 auto;
  min-width: 0;
  display:flex;
  align-items:center;
  gap:6px;
  overflow:hidden;
  white-space:nowrap;
}
#path .crumb, #path .sep{
  flex:0 0 auto;
}
#path .crumb{
  cursor:pointer;
  padding:2px 6px;
  border-radius:8px;
}
#path .crumb:hover{ background:rgba(255,255,255,0.10); }
#path .sep{ opacity:0.55; }

/* Root button is the home icon */
#btn-root{ display:inline-flex; }

/* Folder color: handled by SVG color (see .icon.is-folder) */
.icon[data-kind="folder"] .glyph{ background: transparent; border:0; }

/* Settings modal */
.modal{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,0.55);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:18px 10px;
  overflow:auto;
  z-index:1300;
}
/* Keep quota files manager above settings modal when both are open */
#storageFilesModal{
  z-index:5105;
}
.modal-card{
  width:min(520px, 92vw);
  max-height:86vh;
  display:flex;
  flex-direction:column;
  background:rgba(26,26,26,0.96);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:18px;
  box-shadow:0 18px 60px rgba(0,0,0,0.6);
  overflow:hidden;
}
.modal-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:12px 14px;
  border-bottom:1px solid rgba(255,255,255,0.10);
}
.modal-title{ font-weight:800; }
.modal-body{ padding:14px; display:flex; flex-direction:column; gap:14px; flex:1 1 auto; overflow-y:auto; -webkit-overflow-scrolling:touch; }
/* Draggable settings modal */
.modal.settings-draggable .modal-head{ cursor:move; }
.modal.settings-draggable .modal-head .btn{ cursor:pointer; }
body.dragging-modal{ user-select:none; -webkit-user-select:none; }

/* FAQ */
.faq-card{ width:min(980px, 94vw); }
.faq-intro{ display:flex; flex-direction:column; gap:6px; }
.faq-kicker{
  display:inline-flex;
  align-items:center;
  width:max-content;
  font-size:11px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#121212;
  background:#f5d25c;
  border-radius:999px;
  padding:4px 10px;
}
.faq-lead{
  font-size:20px;
  line-height:1.2;
  font-weight:900;
}
.faq-body{ gap:12px; }
.faq-intro{ flex:0 0 auto; }
.faq-item{
  border:1px solid rgba(255,255,255,0.18);
  background:linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.03));
  border-radius:16px;
  overflow:hidden;
}
.faq-item summary{
  cursor:pointer;
  list-style:none;
  position:relative;
  display:block;
  width:100%;
  min-height:56px;
  margin:0;
  padding:16px 48px 16px 18px;
  white-space:normal;
  overflow-wrap:anywhere;
  color:#f7f7f7;
  font-family:Arial, Helvetica, sans-serif;
  font-size:16px;
  font-weight:900;
  line-height:1.35;
  letter-spacing:0;
  text-transform:none;
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
}
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary::after{
  content:'';
  position:absolute;
  right:18px;
  top:50%;
  flex:0 0 auto;
  width:10px;
  height:10px;
  border-right:2px solid rgba(255,255,255,0.65);
  border-bottom:2px solid rgba(255,255,255,0.65);
  transform:translateY(-65%) rotate(45deg);
  transition:transform .15s ease, opacity .15s ease;
  opacity:.9;
}
.faq-item[open] summary{
  background:rgba(255,255,255,0.08);
  border-bottom:1px solid rgba(255,255,255,0.12);
}
.faq-item[open] summary::after{ transform:translateY(-35%) rotate(-135deg); }
.faq-content{
  padding:16px 18px 18px;
  color:rgba(255,255,255,0.95);
  background:rgba(0,0,0,0.16);
}

/* Keep long answers from pushing other titles off-screen.
   The opened content gets its own internal scroll area. */
.faq-item[open] .faq-content{
  max-height:45vh;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  scrollbar-gutter: stable;
}
@media (max-width: 520px){
  .faq-item[open] .faq-content{ max-height:42vh; }
}
.faq-content ul{ margin:0; padding-left:22px; display:flex; flex-direction:column; gap:8px; }
.faq-content li{ line-height:1.45; word-break:break-word; overflow-wrap:anywhere; }
.faq-content li ul{ margin-top:10px; }
@media (max-width: 640px){
  .faq-lead{ font-size:17px; }
  .faq-item summary{
    font-size:15px;
    min-height:52px;
    padding:13px 42px 13px 14px;
    line-height:1.32;
  }
  .faq-item summary::after{ right:14px; }
  .faq-content{ padding:13px 14px 14px; }
}

/* FAQ custom accordion (JS fallback to avoid summary rendering glitches) */
#helpModal .faq-acc{
  border:1px solid rgba(255,255,255,0.18);
  background:linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.03));
  border-radius:16px;
  overflow:hidden;
}
#helpModal .faq-acc-head{
  width:100%;
  background:transparent;
  color:#f7f7f7;
  text-align:left;
  cursor:pointer;
  position:relative;
  display:block;
  margin:0;
  min-height:56px;
  padding:16px 48px 16px 18px;
  font-family:Arial, Helvetica, sans-serif;
  font-size:16px;
  font-weight:900;
  line-height:1.35;
  user-select:none;
}
#helpModal .faq-acc-head:focus{
  outline:2px solid rgba(255,255,255,0.35);
  outline-offset:-2px;
}
#helpModal .faq-acc-label{
  display:block;
  color:#f7f7f7 !important;
  font:inherit;
  line-height:inherit;
  opacity:1;
  visibility:visible;
}
#helpModal .faq-acc-head::after{
  content:'';
  position:absolute;
  right:18px;
  top:50%;
  width:10px;
  height:10px;
  border-right:2px solid rgba(255,255,255,0.65);
  border-bottom:2px solid rgba(255,255,255,0.65);
  transform:translateY(-65%) rotate(45deg);
  transition:transform .15s ease, opacity .15s ease;
  opacity:.9;
}
#helpModal .faq-acc.is-open .faq-acc-head{
  background:rgba(255,255,255,0.08);
  border-bottom:1px solid rgba(255,255,255,0.12);
}
#helpModal .faq-acc.is-open .faq-acc-head::after{
  transform:translateY(-35%) rotate(-135deg);
}
#helpModal .faq-acc-panel{
  display:none;
  padding:16px 18px 18px;
  color:rgba(255,255,255,0.95);
  background:rgba(0,0,0,0.16);
}
#helpModal .faq-acc.is-open .faq-acc-panel{
  display:block;
  max-height:40vh;
  overflow-y:auto;
  overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
  scrollbar-gutter:stable;
  overscroll-behavior:contain;
}
@media (max-width: 640px){
  #helpModal .faq-acc-head{
    font-size:15px;
    min-height:52px;
    padding:13px 42px 13px 14px;
    line-height:1.32;
  }
  #helpModal .faq-acc-head::after{ right:14px; }
  #helpModal .faq-acc-panel{ padding:13px 14px 14px; }
  #helpModal .faq-acc.is-open .faq-acc-panel{ max-height:34vh; }
}

/* Admin stats cards */
.stats-grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap:10px;
}
@media (max-width: 520px){
  .stats-grid{ grid-template-columns: 1fr; }
}
.stat-card{
  border:1px solid rgba(255,255,255,0.10);
  background:rgba(255,255,255,0.04);
  border-radius:14px;
  padding:10px 12px;
}
.stat-label{ font-size:12px; color:var(--muted); }
.stat-value{ font-size:20px; font-weight:900; margin-top:4px; }
.stat-sub{ margin-top:4px; font-size:12px; color:rgba(255,255,255,0.75); }

/* NEWSLETTER */
.nl-editor{
  height:260px;
  background:#fff;
  border-radius:12px;
  border:1px solid #ddd;
  overflow:hidden;
}
.nl-editor .ql-toolbar{ border-top-left-radius:12px; border-top-right-radius:12px; }
.nl-editor .ql-container{ border-bottom-left-radius:12px; border-bottom-right-radius:12px; }
.form-row{ display:flex; flex-direction:column; gap:8px; }
.form-row label{ font-size:12px; color:var(--muted); }
.form-row input[type="color"]{ width:64px; height:36px; border:none; background:none; padding:0; }
.modal-card.settings-card{
  width:min(1120px,96vw);
  max-width:min(1120px,96vw);
}
.modal-body.settings-body{
  display:grid;
  grid-template-columns:220px minmax(0,1fr);
  gap:18px;
  align-items:start;
}
.settings-nav{
  position:sticky;
  top:0;
  display:flex;
  flex-direction:column;
  gap:8px;
  align-self:start;
}
.settings-nav-link{
  display:block;
  padding:10px 12px;
  border-radius:12px;
  text-decoration:none;
  color:#f5f7fb;
  background:rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.08);
  font-size:13px;
  font-weight:700;
  line-height:1.2;
}
.settings-nav-link:hover{
  background:rgba(255,255,255,0.10);
}
.settings-groups{
  display:flex;
  flex-direction:column;
  gap:18px;
  min-width:0;
}
.settings-group{
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:18px;
  padding:16px;
}
.settings-group-head{
  margin-bottom:14px;
}
.settings-group-head h3{
  margin:0 0 4px;
  font-size:18px;
}
.settings-group-head p{
  margin:0;
  color:rgba(255,255,255,0.68);
  font-size:13px;
}
.settings-group-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px 16px;
}
.settings-span-2{
  grid-column:1 / -1;
}
.settings-group .stats-grid{
  margin-top:4px;
}
@media (max-width: 900px){
  .modal-body.settings-body{
    grid-template-columns:1fr;
  }
  .settings-nav{
    position:static;
    flex-direction:row;
    flex-wrap:wrap;
  }
  .settings-nav-link{
    flex:1 1 140px;
    text-align:center;
  }
  .settings-group-grid{
    grid-template-columns:1fr;
  }
  .settings-span-2{
    grid-column:auto;
  }
}
.hint{ font-size:12px; color:var(--muted); }

/* Quill (modal editor) */
.quill-toolbar{
  border:1px solid rgba(255,255,255,0.10);
  border-radius:12px 12px 0 0;
  background:rgba(255,255,255,0.04);
}
.quill-editor{
  border:1px solid rgba(255,255,255,0.10);
  border-top:0;
  border-radius:0 0 12px 12px;
  background:rgba(255,255,255,0.03);
  min-height:240px;
}
.quill-editor .ql-editor{ min-height:240px; }
/* UI_POLISH_END */

/* POSTIT_START */
.postit{
  position:absolute;
  width:240px;
  height:200px;
  min-width:180px;
  min-height:140px;
  border-radius:14px;
  background: var(--note-bg, #fff59d);
  border:1px solid rgba(0,0,0,0.18);
  box-shadow:0 10px 26px rgba(0,0,0,0.28);
  overflow:hidden;
  resize:both;
  color:#111;
  z-index:850;
}
.postit-resize{
  position:absolute;
  width:14px; height:14px;
  right:6px; bottom:6px;
  border-radius:4px;
  background:rgba(0,0,0,0.22);
  border:1px solid rgba(0,0,0,0.25);
  cursor:nwse-resize;
  z-index:5;
}

.postit.selected{
  outline:2px solid rgba(255,255,255,0.35);
  outline-offset:2px;
}
.postit-head{
  height:34px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 8px;
  border-bottom:1px solid rgba(0,0,0,0.12);
  background: color-mix(in srgb, var(--note-bg, #fff59d) 86%, #000 14%);
  cursor:move;
  user-select:none;
}
.postit-title{
  font-weight:800;
  font-size:12px;
  color:#1a1a1a;
  max-width:150px;
  overflow:hidden;
  white-space:nowrap;
  text-overflow:ellipsis;
}
.postit-tools{
  display:flex;
  align-items:center;
  gap:6px;
}
.postit-color{
  width:30px;
  height:22px;
  border:0;
  background:none;
  padding:0;
}
.postit-btn{
  background:rgba(0,0,0,0.12);
  border:1px solid rgba(0,0,0,0.18);
  border-radius:9px;
  height:22px;
  padding:0 8px;
  cursor:pointer;
  font-size:12px;
  line-height:1;
  color:#111;
}
.postit-btn:disabled{
  opacity:0.45;
  cursor:not-allowed;
}
.postit-body{
  width:100%;
  height:calc(100% - 34px);
  border:0;
  background:transparent;
  padding:10px 10px 12px;
  resize:none;
  outline:none;
  font-family: Arial, Helvetica, sans-serif;
  font-size:13px;
  line-height:1.35;
  color:#111;
  user-select:text; /* override body user-select:none */
}
.postit-body[readonly]{
  opacity:0.85;
}
.postit-format{
  display:flex;
  align-items:center;
  gap:6px;
  padding:6px 8px;
  border-top:1px solid rgba(0,0,0,0.12);
  border-bottom:1px solid rgba(0,0,0,0.10);
  background:rgba(0,0,0,0.06);
}
.postit-format .pf-btn{
  height:24px;
  padding:0 8px;
  border-radius:8px;
  border:1px solid rgba(0,0,0,0.18);
  background:rgba(255,255,255,0.45);
  color:#111;
  cursor:pointer;
  font-size:12px;
  line-height:1;
}
.postit-format .pf-color{
  width:30px;
  height:24px;
  padding:0;
  border-radius:8px;
  border:1px solid rgba(0,0,0,0.18);
  background:rgba(255,255,255,0.45);
}
/* POSTIT_END */

/* URLWIN_START */
.urlwin{
  position:absolute;
  width:340px;
  height:240px;
  min-width:220px;
  min-height:160px;
  border-radius:16px;
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.10);
  box-shadow:0 16px 44px rgba(0,0,0,0.45);
  overflow:hidden;
  z-index:860;
}
.urlwin.selected{
  outline:2px solid rgba(255,255,255,0.35);
  outline-offset:2px;
}
.urlwin-head{
  height:34px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 8px;
  border-bottom:1px solid rgba(255,255,255,0.10);
  background:rgba(0,0,0,0.28);
  cursor:move;
  user-select:none;
}
.urlwin-title{
  font-weight:800;
  font-size:12px;
  max-width:170px;
  overflow:hidden;
  white-space:nowrap;
  text-overflow:ellipsis;
}
.urlwin-tools{ display:flex; align-items:center; gap:6px; }
.urlwin-btn{
  background:rgba(255,255,255,0.08);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:10px;
  height:22px;
  padding:0 8px;
  cursor:pointer;
  font-size:12px;
  line-height:1;
  color:var(--text);
}
.urlwin-btn:disabled{ opacity:0.45; cursor:not-allowed; }
.btn:disabled{ opacity:0.58; cursor:not-allowed; }
.urlwin-body{ height:calc(100% - 34px); background:#111; }
.urlwin-frame{ width:100%; height:100%; border:0; background:#fff; }
.urlwin-resize{
  position:absolute;
  right:6px;
  bottom:6px;
  width:14px;
  height:14px;
  cursor:nwse-resize;
  border-radius:4px;
  background:linear-gradient(135deg, rgba(255,255,255,0.18), rgba(255,255,255,0));
}
/* URLWIN_END */

/* LOG_PANEL_START */
.tree-panel{
  position:fixed;
  top:var(--topbar-h);
  left:0;
  width:280px;
  height:calc(100vh - var(--topbar-h));
  background:var(--panel);
  border-right:1px solid #000;
  z-index:12050;
  display:none;
  flex-direction:column;
}

body.tree-open .tree-panel{display:flex}

body.tree-open #desktop{
  margin-left:280px;
  width:calc(100vw - 280px);
}

/* combine with right panels */
body.tree-open.log-open #desktop{ width:calc(100vw - 280px - 320px); }
body.tree-open.flux-open #desktop{ width:calc(100vw - 280px - 360px); }

body[data-standalone="1"] [data-platform-only="1"]{
  display:none !important;
}

.tree-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:10px;
  border-bottom:1px solid #000;
  background:var(--panel2);
}
.tree-title{font-weight:700}
.tree-body{padding:10px; overflow:auto}
.tree-hint{font-size:12px; color:var(--muted); margin-bottom:10px}
.tree-list{font-size:13px;}
.tree-ul{list-style:none; padding-left:14px; margin:0}
.tree-li{margin:2px 0;}
.tree-row{
  display:flex;
  align-items:center;
  gap:6px;
  padding:6px 8px;
  border-radius:10px;
  cursor:pointer;
}
.tree-row:hover{ background:rgba(255,255,255,0.06); }
.tree-row.active{ background:rgba(74,163,255,0.18); border:1px solid rgba(74,163,255,0.25); }
.tree-twisty{width:16px; text-align:center; opacity:0.85;}
.tree-ic{width:18px; text-align:center; opacity:0.95;}
.tree-name{flex:1; min-width:0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;}
.tree-muted{color:rgba(255,255,255,0.55)}

.log-panel{
  position:fixed;
  top:44px;
  right:0;
  width:320px;
  height:calc(100vh - 44px);
  background:var(--panel);
  border-left:1px solid #000;
  z-index:210;
  display:none;
  flex-direction:column;
}
body.log-open .log-panel{display:flex}

body.log-open #desktop{
  width:calc(100vw - 320px);
}

.log-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:10px;
  border-bottom:1px solid #000;
  background:var(--panel2);
}
.log-title{font-weight:700}
.log-actions{display:flex; gap:8px}
.log-list{
  padding:8px;
  overflow:auto;
  font-size:12px;
  color:var(--muted);
}
.log-item{
  padding:8px;
  border:1px solid rgba(255,255,255,0.06);
  border-radius:10px;
  margin-bottom:8px;
  background:rgba(255,255,255,0.03);
}
.log-item .ts{color:rgba(255,255,255,0.55); margin-bottom:4px}
.log-item .msg{color:var(--text); line-height:1.25}
.log-item .msg a{color:var(--accent); text-decoration:none}
.log-item .msg a:hover{text-decoration:underline}
/* LOG_PANEL_END */

/* FLUX_PANEL_START */
.flux-panel{
  position:fixed;
  top:44px;
  right:0;
  width:360px;
  height:calc(100vh - 44px);
  background:var(--panel);
  border-left:1px solid #000;
  z-index:210;
  display:none;
  flex-direction:column;
}
body.flux-open .flux-panel{display:flex}

body.flux-open #desktop{ width:calc(100vw - 360px); }

.flux-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:10px;
  border-bottom:1px solid #000;
  background:var(--panel2);
}
.flux-title{font-weight:800; letter-spacing:0.02em}
.flux-actions{display:flex; gap:8px}

.flux-list{
  padding:10px;
  overflow:auto;
}

.flux-item{
  border:1px solid rgba(255,255,255,0.06);
  border-radius:14px;
  background:rgba(255,255,255,0.03);
  margin-bottom:10px;
  overflow:hidden;
  transition:background 180ms ease, border-color 180ms ease, transform 180ms ease;
}
/* keep header readable: do NOT brighten whole card on hover (it kills contrast on title/date) */
.flux-item:hover{ background:rgba(255,255,255,0.03); border-color:rgba(255,255,255,0.10); }
.flux-item.open{ background:rgba(255,255,255,0.03); border-color:rgba(255,255,255,0.12); }
.flux-item-head{
  padding:10px;
  display:flex;
  flex-direction:column;
  gap:8px;
  align-items:stretch;
}
.flux-title-row{ width:100%; }
.flux-title-row .flux-item-title{ width:100%; text-align:left; }
.flux-item-meta{min-width:0; display:flex; flex-direction:column; align-items:stretch; gap:8px}
.flux-item-meta .flux-item-actions{ align-self:stretch; }
.flux-item-title{    color: #ffffff;
    font-weight: 600;
    font-size: 17px;
    line-height: 1.2;
    background-color: #272727;
    border: 0px;}
.flux-item-date{    
    color: #dfdfdf;
    font-weight: 400;
    font-size: 11px;
    border: 0px;
    background-color: #272727}
.flux-item-tags{font-size:11px; color:#8a8a8a}
.flux-item-actions{display:flex; gap:8px; flex-shrink:0; align-items:center; align-self:flex-start; opacity:0; pointer-events:none; transform:translateY(2px); transition:opacity .15s ease, transform .15s ease}
.flux-item:hover .flux-item-actions,
.flux-item.open .flux-item-actions{opacity:1; pointer-events:auto; transform:translateY(0)}

/* Flux likes */
.flux-item-actions .like-btn{
  position:static;
  display:flex;
  align-items:center;
  gap:6px;
  padding:4px 8px;
  border-radius:999px;
  background:rgba(0,0,0,0.35);
  border:1px solid rgba(255,255,255,0.14);
  color:rgba(255,255,255,0.92);
  font-weight:800;
  font-size:12px;
  line-height:1;
  cursor:pointer;
  user-select:none;
}
.flux-item-actions .like-btn .like-heart{ font-size:13px; transform:translateY(-0.5px); }
.flux-item-actions .like-btn.liked{ background:rgba(255, 0, 80, 0.25); border-color:rgba(255, 0, 80, 0.35); }
.flux-item-actions .like-btn:active{ transform:scale(0.96); }

.flux-body{
  border-top:1px solid rgba(0,0,0,0.5);
  padding:0 10px;
  display:grid;
  grid-template-rows:0fr;
  overflow:hidden;
  opacity:0;
  transform:translateY(-10px);
  transition:grid-template-rows 320ms cubic-bezier(0.22, 1, 0.36, 1), opacity 220ms ease, transform 320ms cubic-bezier(0.22, 1, 0.36, 1), padding 320ms cubic-bezier(0.22, 1, 0.36, 1);
  will-change:transform, opacity;
}
.flux-body .flux-body-inner{min-height:0; overflow:hidden;}
.flux-item.open .flux-body{
  padding:10px;
  grid-template-rows:1fr;
  opacity:1;
  transform:translateY(0);
}

.flux-content{
    font-size: 13px;
    color: #ffffff;
    line-height: 1.35;
    background: #f2f2f2;
    border: 1px solid #e0e0e0;
    border-radius: 12px;
  padding:10px;
}
.flux-item:hover .flux-content{ background:#ededed; }
.flux-item.open .flux-content{ background:#3f3f3f; }
.flux-content img{ max-width:100%; height:auto; border-radius:10px; }
.flux-content a{ color:#111; text-decoration:underline }
.flux-content a:hover{ opacity:0.8 }

/* keep Quill default lists readable inside flux */
.flux-content ol, .flux-content ul{ padding-left:18px; }

/* Flux editor (inside modal window) */
.quill-toolbar{
  border:1px solid rgba(255,255,255,0.10);
  border-radius:12px 12px 0 0;
  /* Must be visible so Quill pickers (color menu) can float above the editor */
  overflow:visible;
  position:relative;
  z-index:5;
}
.quill-editor{
  height:240px;
  background:rgba(255,255,255,0.02);
  border:1px solid rgba(255,255,255,0.10);
  border-top:0;
  border-radius:0 0 12px 12px;
}

/* Flux editor window: keep scroll in modal, but allow Quill dropdowns to render */
.flux-editor-win .win-body{
  overflow:auto;
}
.flux-editor-win .quill-toolbar,
.flux-editor-win .ql-toolbar,
.flux-editor-win .ql-container,
.flux-editor-win .ql-editor,
.flux-editor-win .form-row{
  overflow:visible;
}
.flux-editor-win .ql-picker-options{
  z-index:99999;
}

/* flux modal: smaller editor area */
.flux-quill-small{ height:90px; }

/* FLUX_PANEL_END */

/* FLUX_DRAWER_START */
.flux-drawer{
  position:fixed;
  left:0;
  right:0;
  top:44px;
  z-index:205;
  pointer-events:none;
}
.flux-drawer-inner{
  pointer-events:auto;
  margin:10px 12px 0 12px;
  background:rgba(14,14,16,0.94);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:18px;
  box-shadow:0 20px 60px rgba(0,0,0,0.55);
  overflow:hidden;
  max-height:calc(100vh - 70px);
  display:flex;
  flex-direction:column;
}
.flux-drawer-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
  padding:12px 12px 10px 12px;
  border-bottom:1px solid rgba(255,255,255,0.06);
  background:rgba(255,255,255,0.03);
}
.flux-drawer-title{ font-weight:700; font-size:15px; line-height:1.2; color:#333; }
.flux-drawer-meta{ margin-top:4px; font-size:12px; color:#8a8a8a; font-weight:400; }
.flux-drawer-body{
  padding:12px;
  overflow:auto;
  font-size:14px;
  line-height:1.45;
  color:#111;
  background:#f2f2f2;
}
.flux-drawer-body img{ max-width:100%; height:auto; border-radius:12px; }
.flux-drawer-body a{ color:#111; text-decoration:underline }
.flux-drawer-body a:hover{ opacity:0.8 }
.flux-drawer-body ol, .flux-drawer-body ul{ padding-left:18px; }

/* make list items match current markup */
.flux-item{ padding:10px; }
.flux-item .flux-item-meta{ font-size:11px; color:rgba(255,255,255,0.6); margin-top:4px; }
.flux-item .flux-more{ margin-top:8px; }

/* FLUX_DRAWER_END */

/* Folder window (explorer) */
.folder-win{
  z-index: 60;
  width: 520px;
  height: 420px;
  left: 40px;
  top: 90px;
}
.folder-win .win-body{ overflow:auto; }

/* Resize handle (bottom-right) */
.win-resize{
  position:absolute;
  right:2px;
  bottom:2px;
  width:18px;
  height:18px;
  cursor:nwse-resize;
  opacity:0.35;
}
.win-resize::after{
  content:'';
  position:absolute;
  right:4px;
  bottom:4px;
  width:10px;
  height:10px;
  border-right:2px solid rgba(255,255,255,0.6);
  border-bottom:2px solid rgba(255,255,255,0.6);
}

/* Folder browser list */
.fb-ic{ display:flex; align-items:center; justify-content:center; }
.fb-thumb{
  width:34px;
  height:34px;
  object-fit:cover;
  border-radius:6px;
  border:1px solid rgba(255,255,255,0.12);
}



/* Videos: hide external label (title is inside the thumbnail) */
.icon.is-video .name{display:none;}

/* Souvenirs */
.icon .souvenir-badge{
  position:absolute;
  top:9px;
  left:8px;
  min-width:22px;
  height:18px;
  padding:0 4px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,0.28);
  background:rgba(18,24,38,0.82);
  color:#fff;
  font-size:10px;
  line-height:16px;
  font-weight:800;
  display:inline-flex;
  align-items:center;
  gap:2px;
  pointer-events:none;
  box-shadow:0 2px 6px rgba(0,0,0,0.3);
  z-index:6;
}
.souvenir-badge-icon{
  width:9px;
  height:9px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:#eaf2ff;
}
.souvenir-badge-icon .souvenir-inline-icon{
  width:9px;
  height:9px;
  display:block;
  object-fit:contain;
  filter:grayscale(1) invert(1) brightness(1.15);
}
.souvenir-badge-count{
  font-size:8px;
}
.souvenir-btn-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-right:4px;
  color:#e9f1ff;
}
.souvenir-btn-icon .souvenir-inline-svg{
  width:13px;
  height:13px;
  display:block;
}
.souvenir-btn-icon .souvenir-inline-icon{
  width:13px;
  height:13px;
  display:block;
  object-fit:contain;
  filter:grayscale(1) invert(1) brightness(1.2);
}
.souvenir-date-row{
  display:grid !important;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr) minmax(120px,160px);
  gap:8px;
  align-items:end;
}
.souvenir-graph-card{
  max-width:min(1320px, 98vw);
  width:min(1320px, 98vw);
  max-height:86vh;
  display:flex;
  flex-direction:column;
}
.souvenir-map-card{
  max-width:min(1120px, 96vw);
  width:min(1120px, 96vw);
  max-height:86vh;
  display:flex;
  flex-direction:column;
}
.souvenir-map-body{
  display:flex;
  flex-direction:column;
  gap:10px;
  min-height:0;
}
.souvenir-global-map{
  width:100%;
  min-height:540px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,0.14);
  overflow:hidden;
  background:rgba(0,0,0,0.25);
}
.souvenir-map-arrow-icon{
  background:transparent !important;
  border:none !important;
}
.souvenir-map-arrow{
  width:18px;
  height:18px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#9ac1ff;
  font-size:15px;
  text-shadow:0 1px 3px rgba(0,0,0,0.6);
}
.souvenir-popup{
  min-width:220px;
  max-width:300px;
  font-size:12px;
  line-height:1.35;
}
.souvenir-popup-title{
  font-weight:800;
  margin-bottom:6px;
}
.souvenir-popup-desc{
  margin:0 0 6px;
  color:#3f4b61;
  white-space:pre-wrap;
}
.souvenir-popup-meta{
  color:#5f6d85;
  margin-bottom:6px;
}
.souvenir-popup-items{
  margin:0;
  padding-left:16px;
}
.souvenir-popup-items li{
  margin:2px 0;
}
.souvenir-popup-item-row{
  list-style:disc;
  display:flex;
  align-items:center;
  gap:8px;
}
.souvenir-popup-thumb{
  width:28px;
  height:28px;
  object-fit:cover;
  border-radius:6px;
  border:1px solid rgba(120,140,170,0.35);
  background:rgba(255,255,255,0.06);
  flex:0 0 auto;
}
.souvenir-popup-item-row a{
  color:#6ea8ff;
  text-decoration:underline;
  text-underline-offset:2px;
  word-break:break-word;
}
.souvenir-popup-link{
  color:#6ea8ff;
  text-decoration:underline;
  text-underline-offset:2px;
}
.souvenir-popup-link.secondary{
  color:#9cc1ff;
  font-size:11px;
  opacity:0.9;
}
.souvenir-graph-body{
  overflow:auto;
  padding:12px;
}
.souvenir-graph-top{
  display:grid;
  grid-template-columns:minmax(260px, 340px) minmax(0, 1fr);
  gap:12px;
  align-items:stretch;
}
.souvenir-graph-controls{
  display:flex;
  flex-direction:column;
  gap:10px;
  padding:12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,0.13);
  background:rgba(255,255,255,0.04);
}
.souvenir-field{
  display:flex;
  flex-direction:column;
  gap:6px;
}
.souvenir-field > label{
  font-size:13px;
  color:rgba(255,255,255,0.85);
}
.souvenir-graph-viz-wrap{
  border-radius:14px;
  border:1px solid rgba(255,255,255,0.13);
  background:rgba(255,255,255,0.03);
  overflow:hidden;
}
.souvenir-graph-svg{
  display:block;
  width:100%;
  min-height:560px;
}
.souvenir-graph-svg .sg-bg{
  fill:rgba(13,18,28,0.75);
}
.souvenir-graph-svg .sg-edge line{
  stroke:rgba(133,167,238,0.56);
  stroke-width:1.5;
}
.souvenir-graph-svg .sg-edge text{
  fill:rgba(182,205,255,0.9);
  font-size:11px;
  text-anchor:middle;
  dominant-baseline:middle;
  pointer-events:none;
}
.souvenir-graph-svg .sg-node{
  cursor:pointer;
}
.souvenir-graph-svg .sg-node circle{
  fill:rgba(76,139,245,0.34);
  stroke:rgba(163,194,255,0.92);
  stroke-width:1.4;
}
.souvenir-graph-svg .sg-node:hover circle{
  fill:rgba(76,139,245,0.5);
}
.souvenir-graph-svg .sg-node text{
  fill:rgba(232,242,255,0.98);
  font-size:12px;
  font-weight:700;
  text-anchor:middle;
  dominant-baseline:middle;
}
.souvenir-graph-list{
  display:flex;
  flex-direction:column;
  gap:8px;
  margin-top:12px;
}
.souvenir-edges-wrap{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.souvenir-edge-row{
  display:flex;
  align-items:center;
  gap:8px;
  padding:9px 10px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,0.14);
  background:rgba(255,255,255,0.04);
  color:#dbe6ff;
  font-size:13px;
}
.souvenir-edge-row strong{
  font-weight:700;
  color:#eaf1ff;
}
.souvenir-edge-arrow{
  opacity:0.85;
}
.souvenir-edge-row em{
  color:#8fb0f7;
  font-style:normal;
  margin-left:auto;
}
@media (max-width: 920px){
  .souvenir-date-row{
    grid-template-columns:1fr;
  }
  .souvenir-graph-top{
    grid-template-columns:1fr;
  }
  .souvenir-graph-svg{
    min-height:320px;
  }
  .souvenir-global-map{
    min-height:360px;
  }
}


/* FLUX filters */
.flux-filters{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  padding:8px 10px;
  border-top:1px solid rgba(0,0,0,0.35);
  border-bottom:1px solid rgba(0,0,0,0.35);
}

/* ===== AGENDA / EVENT UI ===== */
.input{
  width:100%;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,0.14);
  background:rgba(255,255,255,0.06);
  color:var(--text);
  outline:none;
}
.input::placeholder{ color:rgba(255,255,255,0.55); }
.input:focus{ box-shadow: 0 0 0 3px rgba(74,163,255,0.20); border-color:rgba(74,163,255,0.55); }
.form-row{ display:flex; flex-direction:column; gap:6px; margin-bottom:12px; }
.form-row label{ font-size:12px; color:rgba(255,255,255,0.75); }
.grid2{ display:grid; grid-template-columns: 1fr 1fr; gap:12px; }
@media (max-width: 820px){ .grid2{ grid-template-columns:1fr; } }
.quill-wrap{ background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.14); border-radius:12px; overflow:hidden; }
.quill-wrap .ql-toolbar{ background:rgba(0,0,0,0.10); border:none; border-bottom:1px solid rgba(255,255,255,0.10); }
.quill-wrap .ql-container{ border:none; color:var(--text); }
.quill-wrap .ql-editor{ min-height:120px;     background-color: white;}
.event-map{ height:280px; border-radius:12px; overflow:hidden; border:1px solid rgba(255,255,255,0.14); }
.thumb-preview{ display:flex; flex-wrap:wrap; gap:10px; margin-top:10px; }
.thumb-chip{ position:relative; width:92px; height:92px; border-radius:14px; overflow:hidden; border:1px solid rgba(255,255,255,0.14); background:rgba(0,0,0,0.25); }
.thumb-chip img{ width:100%; height:100%; object-fit:cover; display:block; }
.thumb-chip .thumb-del{ position:absolute; right:6px; top:6px; width:24px; height:24px; border-radius:999px; border:1px solid rgba(255,255,255,0.18); background:rgba(0,0,0,0.55); color:#fff; cursor:pointer; display:flex; align-items:center; justify-content:center; font-size:14px; line-height:1; }

.agenda-body{ display:flex; gap:14px; }
.agenda-left{ flex: 1 1 60%; min-width: 520px; }
.agenda-right{ flex: 1 1 40%; min-width: 320px; }
@media (max-width: 980px){
  .agenda-body{ flex-direction:column; }
  .agenda-left{ min-width: auto; }
}
.agenda-month{ font-weight:800; margin-bottom:10px; }
.agenda-grid{ display:grid; grid-template-columns: repeat(7, 1fr); gap:6px; user-select:none; }
.agenda-cell{ padding:10px 10px; border-radius:12px; border:1px solid rgba(255,255,255,0.10); background:rgba(255,255,255,0.04); min-height:64px; cursor:pointer; }
.agenda-cell.muted{ opacity:0.45; }
.agenda-cell .d{ font-size:12px; color:rgba(255,255,255,0.8); }
.agenda-cell .dots{ margin-top:6px; display:flex; gap:4px; flex-wrap:wrap; }
.agenda-dot{ width:8px; height:8px; border-radius:999px; background:rgba(74,163,255,0.85); }
.agenda-dot.own{ background:rgba(74,163,255,0.92); }
.agenda-dot.ro{ background:rgba(255,163,74,0.92); }
.agenda-thumb{
  width:18px;
  height:18px;
  border-radius:7px;
  object-fit:cover;
  display:block;
  border:1px solid rgba(255,255,255,0.14);
  background:rgba(0,0,0,0.25);
}
.agenda-thumb.own{ border-color:rgba(84,173,255,0.65); }
.agenda-thumb.ro{ border-color:rgba(255,163,74,0.7); }
.agenda-cell.sel{ outline:3px solid rgba(74,163,255,0.28); border-color:rgba(74,163,255,0.55); }
.agenda-side-title{ font-weight:800; margin-bottom:6px; }
.agenda-day{ font-size:12px; color:rgba(255,255,255,0.70); margin-bottom:10px; }
.agenda-list{ display:flex; flex-direction:column; gap:8px; }
.agenda-item{ padding:10px 10px; border-radius:12px; border:1px solid rgba(255,255,255,0.10); background:rgba(255,255,255,0.04); cursor:pointer; }
.agenda-item-row{ display:flex; align-items:flex-start; gap:8px; }
.agenda-item-avatar{
  width:28px;
  height:28px;
  border-radius:7px;
  object-fit:cover;
  flex:0 0 28px;
  border:1px solid rgba(255,255,255,0.16);
  background:rgba(0,0,0,0.25);
}
.agenda-item-avatar.ph{
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:8px;
  line-height:1.05;
  color:rgba(255,255,255,0.75);
  text-align:center;
  padding:2px;
}
.agenda-item-main{ min-width:0; flex:1; }
.agenda-item .t{ font-weight:700; }
.agenda-item .m{ font-size:12px; color:rgba(255,255,255,0.70); margin-top:2px; }
.agenda-item.own{ border-color:rgba(84,173,255,0.28); background:rgba(84,173,255,0.08); }
.agenda-item.ro{ border-color:rgba(255,163,74,0.32); background:rgba(255,163,74,0.09); }

/* (legacy) Event icon badge: date line */
.icon .meta-date{ font-size:11px; color:rgba(255,255,255,0.72); margin-top:4px; }

/* ===== EVENT VIEWER (viewer mode) ===== */
.event-view .modal-body{ padding-top:14px; }
.event-view-meta{ display:flex; gap:10px; align-items:center; flex-wrap:wrap; margin-bottom:12px; }
.event-view-date{ font-size:13px; color:rgba(255,255,255,0.80); font-weight:700; }
.event-view-address{
  font-size:13px;
  color:rgba(210,224,255,0.9);
  max-width:100%;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.event-view-link{ font-size:13px; color:rgba(74,163,255,0.95); text-decoration:none; max-width:100%; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.event-view-link:hover{ text-decoration:underline; }

.event-view-grid{ display:grid; grid-template-columns: 1.1fr 0.9fr; gap:14px; }
@media (max-width: 980px){ .event-view-grid{ grid-template-columns:1fr; } }

.event-view-summary{
  border:1px solid rgba(255,255,255,0.10);
  background:rgba(255,255,255,0.04);
  border-radius:14px;
  padding:12px;
  min-height:120px;
  overflow:auto;
}
.event-view-summary :where(p,ul,ol){ margin:0 0 10px 0; }
.event-view-summary :where(h1,h2,h3){ margin:0 0 10px 0; }

.event-view-photos{ border:1px solid rgba(255,255,255,0.10); background:rgba(255,255,255,0.04); border-radius:14px; padding:10px; }
.event-view-stage{ position:relative; border-radius:12px; overflow:hidden; background:rgba(0,0,0,0.30); border:1px solid rgba(255,255,255,0.10); }
.event-view-img{ width:100%; height:320px; object-fit:contain; display:block; background:rgba(0,0,0,0.40); cursor:pointer; }
@media (max-width: 980px){ .event-view-img{ height:260px; } }

.event-view-nav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:36px;
  height:44px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,0.16);
  background:rgba(0,0,0,0.55);
  color:#fff;
  font-size:26px;
  line-height:1;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
}
.event-view-nav:hover{ background:rgba(0,0,0,0.70); }
#eventViewPrev{ left:10px; }
#eventViewNext{ right:10px; }

#eventLightboxPrev{ left:10px; z-index:2; }
#eventLightboxNext{ right:10px; z-index:2; }

.event-view-toolbar{ display:flex; align-items:center; gap:8px; margin-top:10px; }

.event-view-thumbs{ display:flex; gap:8px; flex-wrap:wrap; margin-top:10px; }
.event-view-thumb{ width:64px; height:64px; border-radius:12px; overflow:hidden; border:1px solid rgba(255,255,255,0.14); background:rgba(0,0,0,0.25); cursor:pointer; }
.event-view-thumb img{ width:100%; height:100%; object-fit:cover; display:block; }
.event-view-thumb.on{ outline:3px solid rgba(74,163,255,0.28); border-color:rgba(74,163,255,0.55); }

/* ===== EVENT LIGHTBOX (double-click) ===== */
.event-lightbox-card{
  width:min(1100px, 94vw);
  max-height:92vh;
}
.event-lightbox-body{ gap:12px; }
.event-lightbox-stage{
  position:relative;
  border-radius:14px;
  overflow:hidden;
  background:#000;
  border:1px solid rgba(255,255,255,0.10);
}
.event-lightbox-img{
  width:100%;
  height:min(72vh, 760px);
  object-fit:contain;
  display:block;
  background:#000;
}
@media (max-width: 980px){
  .event-lightbox-img{ height:min(62vh, 620px); }
}
.event-lightbox-toolbar{ display:flex; align-items:center; gap:8px; }

/* Fullscreen-style event slideshow (double-click) */
#eventLightboxModal.event-lightbox-fullscreen{
  padding:0;
  align-items:stretch;
  justify-content:stretch;
}
#eventLightboxModal.event-lightbox-fullscreen .event-lightbox-card{
  width:100vw;
  max-width:none;
  height:100vh;
  max-height:none;
  border-radius:0;
  border-left:0;
  border-right:0;
}
#eventLightboxModal.event-lightbox-fullscreen .event-lightbox-body{
  height:calc(100vh - 64px);
  min-height:0;
}
#eventLightboxModal.event-lightbox-fullscreen .event-lightbox-stage{
  flex:1 1 auto;
  min-height:0;
}
#eventLightboxModal.event-lightbox-fullscreen .event-lightbox-img{
  height:100%;
  max-height:none;
}

.flux-filter-pill{
  font-size:12px;
  padding:4px 8px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,0.12);
  background:rgba(255,255,255,0.05);
  cursor:pointer;
  user-select:none;
}

.flux-item-date{color:#d5d5d5; font-weight:400; font-size:11px;margin-left: auto}
.flux-item-date:hover{ text-decoration:underline; }

.flux-item-tags{font-size:11px; color:#8a8a8a}
.flux-tag{
  font-size:12px;
  padding:3px 2px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,0.14);
  background:rgba(255,255,255,0.06);
  cursor:pointer;
  user-select:none;
  line-height: 2.1;
}
.flux-tag:hover{ background:rgba(255,255,255,0.10); }


/* FLUX tag select */
.flux-tag-select{
  appearance:none;
  -webkit-appearance:none;
  -moz-appearance:none;
  background:var(--panel2);
  color:var(--text);
  border:1px solid #000;
  padding:4px 26px 4px 8px;
  border-radius:7px;
  font-size:12px;
  cursor:pointer;
  line-height:1.2;
}
.flux-tag-select:hover{border-color:#333}
.flux-tag-select:focus{outline:none; box-shadow:0 0 0 2px rgba(255,255,255,0.08)}
.flux-tag-select-wrap{position:relative; display:inline-flex; align-items:center}
.flux-tag-select-wrap:after{
  content:"▾";
  position:absolute;
  right:8px;
  pointer-events:none;
  opacity:0.8;
  font-size:11px;
}


/* ===== Topbar Search ===== */
.top-search{ position:relative; display:flex; align-items:center; margin-right:10px; }
.top-search-input{
  width:260px;
  max-width:38vw;
  padding:8px 10px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,0.14);
  background:rgba(0,0,0,0.18);
  color:inherit;
  outline:none;
}
.top-search-input:focus{
  border-color: rgba(255,255,255,0.28);
  box-shadow: 0 0 0 3px rgba(255,255,255,0.08);
}
.top-search-results{
  position:absolute;
  top:44px;
  right:0;
  width:420px;
  max-width:90vw;
  max-height:60vh;
  overflow:auto;
  border-radius:14px;
  background: rgba(15,15,18,0.96);
  border:1px solid rgba(255,255,255,0.14);
  box-shadow: 0 10px 30px rgba(0,0,0,0.45);
  padding:8px;
  z-index: 9999;
}
.search-section-title{
  font-size:12px;
  opacity:0.75;
  padding:8px 10px 4px;
  text-transform:uppercase;
  letter-spacing:0.04em;
}
.search-item{
  display:flex;
  align-items:flex-start;
  gap:10px;
  padding:10px;
  border-radius:12px;
  cursor:pointer;
}
.search-item:hover{ background: rgba(255,255,255,0.08); }
.search-ico{
  width:30px; height:30px;
  border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  background: rgba(255,255,255,0.08);
  flex:0 0 auto;
  font-size:14px;
}
.search-main{ min-width:0; }
.search-title{ font-size:14px; font-weight:600; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.search-sub{ font-size:12px; opacity:0.7; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; margin-top:2px; }
.search-empty{ padding:12px 10px; opacity:0.75; }
.search-pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 10px;
  border-radius:999px;
  background: rgba(255,255,255,0.08);
  cursor:pointer;
  margin:6px 6px 0 0;
  font-size:13px;
}
.search-pill:hover{ background: rgba(255,255,255,0.12); }

.mobile-search-panel{
  display:none;
  position:fixed;
  left:8px;
  right:8px;
  top:calc(var(--topbar-h) + 8px);
  z-index:2760;
  border:1px solid rgba(255,255,255,0.18);
  border-radius:14px;
  background:rgba(20,20,20,0.88);
  backdrop-filter:blur(8px);
  padding:8px;
}
.mobile-search-row{
  display:flex;
  gap:8px;
  align-items:center;
}
.mobile-search-panel .top-search-input{
  width:100%;
  max-width:none;
}
.mobile-search-panel .mobile-search-results{
  position:relative;
  top:auto;
  right:auto;
  width:100%;
  max-width:none;
  margin-top:8px;
  max-height:45vh;
}

.postit-body hr, .note-area-rich hr{
  border:0;
  border-top:1px solid rgba(0,0,0,0.22);
  margin:10px 0;
}

.search-highlight{
  outline:2px solid rgba(255,255,255,0.25);
  outline-offset:3px;
  box-shadow:0 6px 18px rgba(0,0,0,0.22);
  transition: box-shadow 180ms ease, outline-color 180ms ease;
}

/* Topbar retract removed */


/* ensure search dropdown not clipped and topbar contents can shrink */
.topbar-left, .topbar-right{ min-width:0; }


/* ===== Comments UI ===== */
.comment-btn{
  position:absolute;
  right:6px;
  bottom:42px; /* sits above bottom, under like */
  display:flex;
  align-items:center;
  gap:6px;
  padding:4px 8px;
  border-radius:999px;
  background:rgba(0,0,0,0.55);
  border:1px solid rgba(255,255,255,0.18);
  color:rgba(255,255,255,0.92);
  font-weight:800;
  font-size:12px;
  line-height:1;
  cursor:pointer;
  user-select:none;
  backdrop-filter:blur(6px);
}
.comment-btn:hover{ background:rgba(0,0,0,0.68); }
.comment-btn .comment-bubble{ font-size:13px; line-height:1; }
.comment-btn .comment-bubble{ width:13px; display:inline-block; text-align:center; }
.comment-btn .comment-count{ min-width:10px; text-align:center; }

.comment-side{
  bottom:auto;
  top:40px;     /* below like-side */
  right:-8px;
  padding:4px 6px;
  gap:4px;
}

.comments-overlay{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,0.35);
  z-index:9998;
}

.comments-panel{
  position:fixed;
  width:min(520px, 92vw);
  max-height:min(70vh, 560px);
  background:rgba(32,32,32,0.98);
  border:1px solid rgba(255,255,255,0.14);
  border-radius:14px;
  box-shadow:0 20px 60px rgba(0,0,0,0.55);
  z-index:9999;
  display:flex;
  flex-direction:column;
  overflow:hidden;
}

.comments-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:10px 12px;
  background:rgba(0,0,0,0.22);
  border-bottom:1px solid rgba(255,255,255,0.12);
}
.comments-title{ font-weight:900; letter-spacing:.3px; }
.comments-close{
  background:transparent;
  border:0;
  color:rgba(255,255,255,0.85);
  font-size:18px;
  cursor:pointer;
  padding:4px 6px;
}
.comments-close:hover{ color:#fff; }

.comments-list{
  padding:12px;
  overflow:auto;
  flex:1;
}
.comments-empty{
  color:rgba(255,255,255,0.65);
  font-style:italic;
  padding:8px 0;
}

.comment-row{
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.10);
  border-radius:12px;
  padding:8px 10px;
  margin-bottom:8px;
}
.comment-body{
  white-space:pre-wrap;
  font-size:13px;
  line-height:1.35;
}
.comment-meta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-top:6px;
  color:rgba(255,255,255,0.62);
  font-size:12px;
}
.comment-meta-left{display:flex; align-items:center; gap:8px; min-width:0}
.comment-author{font-weight:900; font-size:12px; color:rgba(255,255,255,0.92)}
.comment-reply{
  background:transparent;
  border:0;
  color:var(--accent);
  cursor:pointer;
  font-weight:800;
}
.comment-reply:hover{ text-decoration:underline; }

.comments-replyto{
  padding:8px 12px;
  border-top:1px solid rgba(255,255,255,0.10);
  background:rgba(255,255,255,0.04);
  color:rgba(255,255,255,0.75);
  font-size:12px;
}
.comment-cancel-reply{
  margin-left:8px;
  background:transparent;
  border:1px solid rgba(255,255,255,0.20);
  color:rgba(255,255,255,0.85);
  border-radius:10px;
  padding:2px 8px;
  cursor:pointer;
}
.comment-cancel-reply:hover{ border-color:rgba(255,255,255,0.32); }

.comments-form{
  padding:10px 12px;
  border-top:1px solid rgba(255,255,255,0.12);
  background:rgba(0,0,0,0.18);
}
.comments-input{
  width:100%;
  resize:vertical;
  min-height:60px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,0.14);
  background:rgba(0,0,0,0.25);
  color:var(--text);
  padding:8px 10px;
  outline:none;
}
.comments-input:focus{ border-color:rgba(74,163,255,0.55); }
.comments-actions{
  display:flex;
  justify-content:flex-end;
  margin-top:8px;
}
.comments-send{
  padding:6px 12px;
}
.flux-item-actions{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
}
.flux-item-actions .flux-social{
  display:flex;
  flex-direction:row;
  align-items:center;
  gap:8px;
}
.flux-item-actions .flux-admin{
  display:flex;
  gap:8px;
  align-items:flex-start;
}
.flux-item-actions .comment-btn{
  position:static;
  bottom:auto;
  right:auto;
  margin-top:0;
}


.comment-meta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.comment-meta-actions{
  display:flex;
  align-items:center;
  gap:10px;
}
.comment-del{
  background:transparent;
  border:0;
  color:rgba(255,255,255,0.85);
  cursor:pointer;
  font-size:12px;
  padding:2px 4px;
  border-radius:8px;
}
.comment-del:hover{
  background:rgba(255,255,255,0.10);
}

/* Comments message */
.comments-msg{ margin:8px 0; padding:8px 10px; border-radius:10px; background:rgba(255,255,255,0.08); font-size:13px; }


/* ===== Influence zones (background shapes) ===== */
/* ===== Influence zones (background shapes) ===== */
.zone-influence{
  position:absolute;
  left:40px;
  top:40px;
  width:300px;
  height:220px;
  z-index:1;               /* behind icons by default */
  pointer-events:none;     /* click-through (handles only) */
  box-sizing:border-box;
  border-radius:18px;
}
.zone-influence.shape-circle{ border-radius:50%; }

/* interior fill / border (does not block clicks) */
.zone-influence .zone-fill{
  position:absolute;
  inset:0;
  border:2px dashed rgba(0,0,0,0.25);
  border-radius:inherit;
  background:rgba(0,0,0,0.04);
  pointer-events:none;
}

/* selection + controls */
.zone-influence.selected{ outline:2px solid rgba(0,0,0,0.25); z-index:5; }
.zone-influence .zone-controls{
  position:absolute;
  right:10px;
  top:8px;
  display:none;
  gap:6px;
  z-index:3;
  pointer-events:auto;
}
.zone-influence.selected .zone-controls{ display:flex; }
.zone-influence .zone-btn{
  width:28px;
  height:28px;
  border-radius:10px;
  border:1px solid rgba(0,0,0,0.18);
  background:rgba(255,255,255,0.78);
  cursor:pointer;
  font-size:14px;
  line-height:1;
  display:flex;
  align-items:center;
  justify-content:center;
}
.zone-influence .zone-btn:hover{ background:rgba(255,255,255,0.92); }

.zone-influence .zone-resize{
  position:absolute;
  right:2px;
  bottom:2px;
  width:18px;
  height:18px;
  border-radius:8px;
  background:rgba(0,0,0,0.10);
  cursor:nwse-resize;
  pointer-events:auto;
  z-index:2;
}

/* edge handles (thin hit zones) */
.zone-influence .zone-edges{
  position:absolute;
  inset:0;
  pointer-events:auto;
  z-index:2;
}
.zone-influence .zone-edge{
  position:absolute;
  background:transparent;
}
.zone-influence .edge-top{ left:0; right:0; top:-6px; height:12px; cursor:move; }
.zone-influence .edge-bottom{ left:0; right:0; bottom:-6px; height:12px; cursor:move; }
.zone-influence .edge-left{ top:0; bottom:0; left:-6px; width:12px; cursor:move; }
.zone-influence .edge-right{ top:0; bottom:0; right:-6px; width:12px; cursor:move; }

/* Keep desktop transparent so wallpaper and animated FX remain visible */
#desktop{
  background:transparent !important;
}
/* ===== END Influence zones ===== */

/* Influence zone hover title */
.zone-influence.has-title:hover::after{
  content: attr(data-title);
  position: absolute;
  left: 50%;
  top: -8px;
  transform: translate(-50%,-100%);
  background: rgba(20,20,24,0.85);
  color: rgba(255,255,255,0.95);
  padding: 4px 8px;
  border-radius: 8px;
  font-size: 12px;
  line-height: 1.2;
  white-space: nowrap;
  max-width: 320px;
  overflow: hidden;
  text-overflow: ellipsis;
  pointer-events: none;
  z-index: 10;
}

/* Zone palette opacity controls */
#zoneColorPalette .zone-opacity{
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 8px;
}
#zoneColorPalette .zone-opacity-btn{
  width: 100%;
  border: 1px solid rgba(0,0,0,0.15);
  background: rgba(255,255,255,0.85);
  border-radius: 10px;
  padding: 6px 8px;
  font-size: 12px;
}
#zoneColorPalette .zone-opacity-btn:hover{ background: rgba(255,255,255,0.95); }
#zoneColorPalette .zone-opacity-panel{
  display: none;
  align-items: center;
  gap: 8px;
}
#zoneColorPalette .zone-opacity-range{ flex: 1; }
#zoneColorPalette .zone-opacity-val{
  font-size: 12px;
  min-width: 40px;
  text-align: right;
  color: rgba(0,0,0,0.75);
}

.swatch-palette{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:10px;
}
.swatch-palette button{
  width:26px;
  height:26px;
  border-radius:8px;
  border:1px solid rgba(0,0,0,0.18);
  background:#eee;
  cursor:pointer;
}
.swatch-palette button.transparent{
  background:repeating-linear-gradient(45deg,#eee,#eee 6px,#ddd 6px,#ddd 12px);
}
.swatch-palette button.active{
  outline:2px solid rgba(0,0,0,0.5);
}


root{
  --bg:#151515;
  --desktop-bg:#151515;
  --desktop-bg-image:none;
  --desk-zoom:1;
  --panel:#202020;
  --panel2:#2a2a2a;
  --text:#eaeaea;
  --muted:#b8b8b8;
  --accent:#4aa3ff;
  --danger:#e74c3c;
  --folder-color:#ffca28;
}

*{box-sizing:border-box}
body{margin:0;background:var(--desktop-bg);color:var(--text);font-family:Arial, Helvetica, sans-serif;user-select:none; overflow-x:hidden}

/* Full-screen wallpaper layer (dimmed) */
#wallpaper{
  position:fixed;
  inset:0;
  z-index:0;
  pointer-events:none;
  background-image:var(--desktop-bg-image);
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  filter: brightness(0.65) saturate(0.75) contrast(0.92);
}
/* Top bar */
:root{ --topbar-h: 96px; }
#topbar{
  height:var(--topbar-h);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  width:100%;
  max-width:100%;
  /* breathing room on the left + avoid right clipping on some browsers */
  padding:0 12px;
  box-sizing:border-box;
  overflow:visible;
  background:var(--panel);
  border-bottom:1px solid #000;
  position:relative;
  z-index:200;
}

.topbar-left,
.topbar-right{
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
}

.icon-btn{
  padding:6px 10px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
}

.avatar-btn{
  width:50px;
  height:50px;
  border-radius:999px;
  overflow:hidden;
  padding:0;
  border:1px solid rgba(255,255,255,0.14);
  background:rgba(255,255,255,0.06);
  cursor:pointer;
}
.avatar-btn img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.brand{font-weight:700; letter-spacing:1px; margin-right:10px; padding-left:2px}
.btn{
  background:var(--panel2); color:var(--text); border:1px solid #000;
  padding:6px 10px; border-radius:8px; cursor:pointer;
}
.btn:hover{border-color:#333}
.btn.small{padding:4px 8px; border-radius:7px; font-size:12px}
.btn.danger{background:#3a1b1b; border-color:#000}
.badge{
  display:inline-block; padding:4px 8px; border-radius:999px; background:#111; border:1px solid #000;
  font-size:12px; color:var(--muted); margin-right:8px;
}
.path{margin-left:10px; color:var(--muted); font-size:12px}
#desktop{
  position:relative;
  height:calc(100vh - var(--topbar-h));
  width:100%;
  overflow:hidden;
  z-index:1;
}

.icon{
  position:absolute;
  width:96px;
  padding:6px 6px 8px;
  border-radius:10px;
  text-align:center;
  cursor:default;
  border:1px solid transparent;
  background:transparent;
  transform: scale(var(--desk-zoom));
  transform-origin: top left;
}

.postit{
  transform: scale(var(--desk-zoom));
  transform-origin: top left;
}
.icon.selected{
  border-color:rgba(255,255,255,0.25);
  background:rgba(255,255,255,0.06);
}
.icon .glyph{
  width:64px; height:64px; margin:0 auto 6px;
  display:flex; align-items:center; justify-content:center;
  border-radius:12px;
  background:rgba(255,255,255,0.06);
  overflow:hidden;
}

/* Desktop thumbnail players (video + YouTube) */
.icon .glyph{ position:relative; }
.icon .glyph video,
.icon .glyph iframe{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:0;
  display:block;
  background:#000;
}
.icon .glyph video{ object-fit:cover; }


.icon .play-overlay{
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%, -50%);
  width:44px;
  height:44px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,0.28);
  background:rgba(0,0,0,0.40);
  backdrop-filter: blur(6px);
  display:none;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  z-index:3;
}
.icon .play-overlay .tri{
  width:0; height:0;
  border-top:9px solid transparent;
  border-bottom:9px solid transparent;
  border-left:14px solid rgba(255,255,255,0.92);
  margin-left:3px;
}
.icon:hover .play-overlay,
.icon.selected .play-overlay{ display:flex; }
.icon.is-video .play-overlay{ display:flex; }
.icon.playing .play-overlay{ display:none; }

/* Folder icon: use colored SVG (settings -> folder color) */
.icon.is-folder .glyph{background:transparent; color:var(--folder-color)}
.icon.is-folder .glyph svg{width:58px; height:46px; display:block}

/* Per-folder color (overrides global folder color when set inline) */
.icon.is-folder .glyph{ color:var(--folder-color); }

/* Folder color palette */
.color-palette{
  position:fixed;
  z-index:9999;
  background:rgba(25,25,28,0.98);
  border:1px solid rgba(255,255,255,0.18);
  border-radius:14px;
  padding:10px;
  box-shadow:0 12px 32px rgba(0,0,0,0.45);
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  width:220px;
}
.color-palette .sw{
  width:26px; height:26px;
  border-radius:8px;
  border:1px solid rgba(255,255,255,0.22);
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:800;
  color:rgba(255,255,255,0.92);
}
.color-palette .sw:focus{ outline:2px solid rgba(255,255,255,0.45); outline-offset:2px; }
.color-palette .sw.default{
  background:rgba(255,255,255,0.10);
}

/* Resizable photo thumbnails */
.icon.photo-resizable{padding:6px; min-width:110px; min-height:110px}
.icon.photo-resizable.is-video{min-width:160px; min-height:100px}
.icon.photo-resizable .glyph{width:100%; height:100%; margin:0}
.icon.photo-resizable .glyph img{width:100%; height:100%; object-fit:cover}
.icon.photo-resizable .glyph video{width:100%; height:100%; object-fit:cover}
.icon.photo-resizable .glyph iframe{width:100%; height:100%}
.icon.photo-resizable .name{
  position:absolute;
  left:6px; right:6px; bottom:6px;
  padding:3px 6px;
  border-radius:10px;
  background:rgba(0,0,0,0.45);
}
.icon.photo-resizable .resize-handle{
  position:absolute;
  width:14px; height:14px;
  right:2px; bottom:2px;
  border-radius:4px;
  background:rgba(0,0,0,0.35);
  border:1px solid rgba(255,255,255,0.25);
  cursor:nwse-resize;
  display:none;
}
.icon.photo-resizable:hover .resize-handle,
.icon.photo-resizable.selected .resize-handle{display:block}
.icon .glyph img{
  width:100%; height:100%; object-fit:cover;
}
.icon .name{
  font-size:12px; line-height:1.1; color:var(--icon-name-color, var(--text));
  text-shadow:var(--icon-name-shadow, none);
  word-break:break-word;
}

/* ===== Likes (media) ===== */
.icon{ position:absolute; }
.icon .like-btn{
  position:absolute;
  right:6px;
  bottom:6px;
  display:flex;
  align-items:center;
  gap:6px;
  padding:4px 8px;
  border-radius:999px;
  background:rgba(0,0,0,0.55);
  border:1px solid rgba(255,255,255,0.18);
  color:rgba(255,255,255,0.92);
  font-weight:800;
  font-size:12px;
  line-height:1;
  cursor:pointer;
  user-select:none;
  backdrop-filter:blur(6px);
}
.icon .like-btn .like-heart{ font-size:13px; transform:translateY(-0.5px); }
.icon .like-btn .like-heart{ width:13px; display:inline-block; text-align:center; }
.icon .like-btn.like-side{
  /* For standard small icons (non-resizable): avoid covering the filename */
  bottom:auto;
  top:8px;
  right:-8px;
  padding:4px 6px;
  gap:4px;
}
.icon .like-btn.liked{
  background:rgba(255, 0, 80, 0.35);
  border-color:rgba(255, 0, 80, 0.45);
}
.icon .like-btn:active{ transform:scale(0.96); }
.icon:hover .like-btn{ filter:brightness(1.06); }


/* Social stack (like + comment) for multimedia thumbnails */
.icon .icon-social{
  position:absolute;
  right:6px;
  bottom:6px;
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:6px;
  z-index:6;
  opacity:0;
  pointer-events:none;
  transform:translateY(2px);
  transition:opacity .15s ease, transform .15s ease;
}
.icon:hover .icon-social,
.icon.selected .icon-social{
  opacity:1;
  pointer-events:auto;
  transform:translateY(0);
}
.icon .icon-social.icon-social-side{
  bottom:auto;
  top:8px;
  right:-8px;
}

.icon .icon-social.icon-social-top{
  bottom:auto;
  top:6px;
  right:6px;
  flex-direction:row;
  align-items:center;
  gap:6px;
}
.icon .icon-social .like-btn,
.icon .icon-social .comment-btn{
  position:static;
  right:auto;
  bottom:auto;
  top:auto;
  margin:0;
}

/* Post-it notes: like button lives in the header tools (not absolute positioned) */
.postit .like-btn.postit-like{
  position:static;
  padding:2px 6px;
  font-size:11px;
  gap:4px;
  border-radius:999px;
  background:rgba(255,255,255,0.45);
  border:1px solid rgba(0,0,0,0.18);
  color:#111;
  backdrop-filter:none;
}
.postit .like-btn.postit-like.liked{
  background:rgba(255, 0, 80, 0.18);
  border-color:rgba(255, 0, 80, 0.35);
}

/* Post-it notes: social (like + comment) hidden until hover */
.postit .postit-social{
  display:flex;
  flex-direction:row;
  align-items:center;
  gap:6px;
  margin-left:6px;
  opacity:0;
  pointer-events:none;
  transform:translateY(2px);
  transition:opacity .15s ease, transform .15s ease;
}
.postit:hover .postit-social,
.postit.selected .postit-social{
  opacity:1;
  pointer-events:auto;
  transform:translateY(0);
}
.postit .comment-btn.postit-comment{
  position:static;
  padding:2px 6px;
  font-size:11px;
  gap:4px;
  border-radius:999px;
  background:rgba(255,255,255,0.45);
  border:1px solid rgba(0,0,0,0.18);
  color:#111;
  backdrop-filter:none;
}
.postit .comment-btn.postit-comment.open{
  background:rgba(0,0,0,0.08);
}

/* URL widget: social actions in header, hidden until hover */
.urlwin .urlwin-social{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:6px;
  margin-left:6px;
  opacity:0;
  pointer-events:none;
  transform:translateY(2px);
  transition:opacity .15s ease, transform .15s ease;
}
.urlwin:hover .urlwin-social,
.urlwin.selected .urlwin-social{
  opacity:1;
  pointer-events:auto;
  transform:translateY(0);
}
.urlwin .like-btn.urlwin-like,
.urlwin .comment-btn.urlwin-comment{
  position:static;
  padding:2px 6px;
  font-size:11px;
  gap:4px;
  border-radius:999px;
  background:rgba(0,0,0,0.55);
  border:1px solid rgba(255,255,255,0.18);
  color:rgba(255,255,255,0.92);
  backdrop-filter:blur(6px);
}

/* Photos: show title only on hover */
.icon.is-photo .name{
  opacity:0;
  transition:opacity .12s ease;
}
.icon.is-photo:hover .name{ opacity:1; }

/* Videos: smaller title font */
.icon.is-video .name{ font-size:11px; }

/* Videos: always show title below the thumbnail */
.icon.is-video .name{
  opacity:1;
  transition:none;
  display:block;
  max-width:100%;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.icon.is-video:hover .name{ opacity:1; }
/* emoji glyph fallback */
.glyph .emoji{font-size:34px; line-height:1}
.glyph .emoji.file-badge{
  min-width:46px;
  height:28px;
  padding:0 8px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:8px;
  border:1px solid rgba(255,255,255,.28);
  background:linear-gradient(180deg, rgba(120,140,170,.38), rgba(58,68,88,.52));
  font-size:13px;
  line-height:1;
  font-weight:900;
  letter-spacing:.04em;
  color:#f7f9ff;
  text-shadow:0 1px 2px rgba(0,0,0,.5);
}

.actions{
  /* Positioned by JS next to the selected icon */
  position:fixed;
  left:-9999px; top:-9999px;
  z-index: 1200;
  display:none;
  flex-direction:column;
  gap:8px;
  padding:8px; border-radius:14px;
  background:rgba(0,0,0,0.4); border:1px solid rgba(255,255,255,0.12);
  backdrop-filter: blur(6px);
}

.overlay{
  position:fixed; inset:0;
  background:rgba(0,0,0,0.65);
  display:flex; align-items:center; justify-content:center;
  z-index:1000;
}
.panel{
  width:min(360px, 90vw);
  background:var(--panel);
  border:1px solid #000;
  border-radius:16px;
  overflow:hidden;
  box-shadow:0 18px 60px rgba(0,0,0,0.6);
}
.panel-title{
  padding:10px 12px;
  background:var(--panel2);
  border-bottom:1px solid #000;
  font-weight:700;
}
.panel-body{padding:12px}
.input{
  width:100%; padding:10px 12px;
  border-radius:10px; border:1px solid #000;
  background:#0f0f0f; color:var(--text);
  outline:none;
}
.select{
  width:100%; padding:10px 12px;
  border-radius:10px; border:1px solid #000;
  background:#0f0f0f; color:var(--text);
  outline:none;
}
.row{display:flex; gap:8px; margin-top:10px}
.err{margin-top:10px; color:#ffb3ab; font-size:12px; min-height:16px}

.win{
  position:absolute;
  left:10vw; top:10vh;
  width:80vw; height:78vh;
  background:#fff;
  border-radius:16px;
  overflow:hidden;
  border:1px solid #000;
  z-index:900;
  box-shadow:0 18px 60px rgba(0,0,0,0.55);
}
.win-header{
  height:40px;
  background:#262626;
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 10px;
  cursor:move;
}
.win-title{font-weight:700; font-size:13px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:65vw}
.win-body{
  height:calc(100% - 40px);
  background:#f5f5f5;
  overflow:auto;
}
.win-body .pad{padding:12px}
.win-body iframe{width:100%; height:100%; border:0}
.win-body img{max-width:100%; height:auto; display:block; margin:0 auto}
.win-body video{width:100%; height:auto}
.win-body audio{width:100%; margin-top:12px}
.win.resizable{resize:both; overflow:hidden}
.win.maximized{
  left:0 !important; top:44px !important;
  width:100vw !important; height:calc(100vh - 44px) !important;
  border-radius:0 !important;
}

/* Folder window browser */
.fb-bar{
  position:sticky;
  top:0;
  z-index:2;
  display:flex;
  gap:8px;
  align-items:center;
  padding:10px;
  background:#f7f7f7;
  border-bottom:1px solid #ddd;
}
.fb-path{
  font-size:12px;
  color:#444;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.fb-list{padding:8px}
.fb-item{
  display:flex;
  align-items:center;
  gap:10px;
  padding:8px 10px;
  border-radius:10px;
  cursor:pointer;
  user-select:none;
}
.fb-item:hover{background:#efefef}
.fb-item.selected{background:#e6e6e6}
.fb-ic{width:22px; text-align:center}
.fb-name{flex:1; font-size:14px; color:#111}
.fb-kind{font-size:12px; color:#666}
.fb-thumb{width:22px; height:22px; object-fit:cover; border-radius:6px; display:block}

/* Folder color in folder browser */
.fb-ic.fb-folder svg{width:22px; height:18px; display:block}
.fb-list.thumb-view .fb-ic.fb-folder svg{width:64px; height:48px}

/* PDF icon in folder listing */
.fb-ic.pdf{
  width:22px;
  height:22px;
  display:flex;
  align-items:center;
  justify-content:center;
}

.fb-list.thumb-view{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(140px, 1fr));
  gap:10px;
  padding:10px;
}
.fb-list.thumb-view .fb-item{
  flex-direction:column;
  align-items:center;
  gap:6px;
  padding:10px;
}
.fb-list.thumb-view .fb-ic{width:auto; font-size:34px}
.fb-list.thumb-view .fb-thumb{width:96px; height:96px; border-radius:12px}
/* In thumb view, keep PDF icon centered and avoid overflowing (it used to inherit a 22px container) */
.fb-list.thumb-view .fb-ic.pdf{
  width:96px;
  height:96px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.fb-list.thumb-view .fb-ic.pdf .fb-thumb{width:72px; height:72px; border-radius:14px}
.fb-list.thumb-view .fb-name{
  width:100%;
  text-align:center;
  font-size:13px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.fb-list.thumb-view .fb-kind{display:none}

/* Multimedia: cover topbar when maximized so Racine/↑ stay underneath */
.win.cover-topbar{ z-index:1200; }

/* MENU (fix: position fixed to avoid offset when window/desktop is transformed) */
.menu{
  position:fixed; /* <-- CHANGÉ (était absolute) */
  background:rgba(30,30,30,0.95);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:14px;
  padding:6px;
  z-index:950;
  min-width:180px;
  box-shadow:0 18px 60px rgba(0,0,0,0.55);
}
.menu-item{
  width:100%;
  text-align:left;
  padding:10px 10px;
  background:transparent;
  border:0;
  color:var(--text);
  border-radius:10px;
  cursor:pointer;
}
.menu-item:hover{background:rgba(255,255,255,0.08)}

/* QUILL_FIX_START */
.ql-container, .ql-editor{
  color:#000 !important;
}
.ql-toolbar.ql-snow{
  background:#fff;
}
.ql-toolbar.ql-snow .ql-picker-label,
.ql-toolbar.ql-snow .ql-picker-item,
.ql-toolbar.ql-snow button{
  color:#000;
}
/* QUILL_FIX_END */

/* TRASH_START */
/* TRASH_END */

/* DRAG_FIX_START */
.icon.dragging{ opacity:0.95; }
.icon.hit-ignore{ pointer-events:none; }
.postit.dragging{ opacity:0.95; }
.postit.hit-ignore{ pointer-events:none; }

/* Lightweight drag proxy (smooth dragging even with iframes/videos) */
.drag-proxy{
  border: 1px dashed rgba(255,255,255,0.55);
  background: rgba(0,0,0,0.18);
  border-radius: 14px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.25);
  will-change: transform;
}
.drag-proxy-label{
  position: absolute;
  left: 10px;
  top: 8px;
  padding: 4px 8px;
  border-radius: 999px;
  font-size: 12px;
  line-height: 1;
  color: rgba(255,255,255,0.92);
  background: rgba(0,0,0,0.35);
  max-width: calc(100% - 20px);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
/* DRAG_FIX_END */

/* MEDIA_FIT_START */
.win-body{position:relative;}
.win.media-view .win-body{ background:#000; overflow:hidden; }
.media-wrap{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#000;
}
.media-wrap video{
  width:100%;
  height:100%;
  max-width:100%;
  max-height:100%;
  object-fit:cover;
  background:#000;
}
/* Photos : afficher entièrement dans la fenêtre (pas de crop) */
.media-wrap img{
  width:100%;
  height:100%;
  max-width:100%;
  max-height:100%;
  object-fit:contain;
  background:#000;
}
/* MEDIA_FIT_END */

/* DROPZONES_START */
.drop-zones{
  position:fixed;
  left:50%;
  top:70px; /* below topbar */
  transform:translateX(-50%);
  display:flex;
  gap:10px;
  z-index:990;
  pointer-events:none; /* allow click only on zones */
}
.drop-zone{
  pointer-events:auto;
  padding:10px 14px;
  border-radius:999px;
  background:rgba(0,0,0,0.45);
  border:1px solid rgba(255,255,255,0.14);
  color:var(--text);
  font-size:12px;
  backdrop-filter: blur(6px);
  cursor:pointer;
  user-select:none;
}
.drop-zone.hot{
  background:rgba(74, 163, 255, 0.20);
  border-color:rgba(74, 163, 255, 0.55);
}
.upload-overlay{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,0.65);
  display:flex;
  justify-content:center;
  align-items:flex-start;
  padding-top:56px;
  z-index:7000;
}
.upload-box{
  width:min(420px, 90vw);
  background:rgba(32,32,32,0.95);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:18px;
  padding:14px 16px;
  box-shadow:0 18px 60px rgba(0,0,0,0.6);
}
.upload-title{font-weight:700; margin-bottom:8px}
.upload-file{font-size:12px; color:var(--muted); margin-bottom:10px; word-break:break-word}
.upload-bar{height:10px; background:rgba(255,255,255,0.10); border-radius:999px; overflow:hidden; border:1px solid rgba(255,255,255,0.12)}
.upload-bar-fill{height:100%; width:0% ; background:rgba(74,163,255,0.9)}
.upload-pct{margin-top:8px; font-size:12px; color:var(--muted); text-align:right}

/* Indeterminate progress (used for short server sync during drag/drop moves) */
@keyframes indet {
  0% { transform: translateX(-70%); }
  100% { transform: translateX(250%); }
}
.upload-bar-fill.indeterminate{
  width:35% !important;
  animation: indet 1s linear infinite;
}
/* UPLOAD_OVERLAY_END */

/* QUILL_TEXT_COLOR_START */
/* Base text color for editors, but DO NOT force child elements (so Quill color formatting can work). */
.ql-container, .ql-editor{
  color:#000;
}
/* Keep placeholder readable but subtle */
.ql-editor.ql-blank::before{
  color: rgba(0,0,0,0.35) !important;
}
/* Ensure any plain pre blocks are readable */
.win-body pre{
  color:#000;
}
/* QUILL_TEXT_COLOR_END */

/* TXT_EDITOR_START */
.txt-editor{
  width:100%;
  height: calc(78vh - 180px);
  padding:12px;
  border-radius:12px;
  border:1px solid #ddd;
  background:#fff;
  color:#000;
  font-family: Arial, Helvetica, sans-serif;
  font-size:14px;
  line-height:1.4;
  resize: vertical;
}

/* NOTE_WINDOW_START */
.note-win{
  height:100%;
  display:flex;
  flex-direction:column;
  box-sizing:border-box;
}
.note-toolbar{
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
  margin-bottom:10px;
}
.note-field{
  display:flex;
  gap:8px;
  align-items:center;
  font-size:12px;
  color:#333;
}
.note-hint{ font-size:12px; color:#666; }
.note-area{
  flex:1 1 auto;
  width:100%;
  padding:12px;
  border-radius:12px;
  border:1px solid #ddd;
  background:#fff;
  color:#000;
  font-family: Arial, Helvetica, sans-serif;
  font-size:14px;
  line-height:1.4;
  resize:none;
  min-height:220px;
}

.note-format{
  display:flex;
  align-items:center;
  gap:6px;
  padding:8px 10px;
  border:1px solid rgba(255,255,255,0.10);
  border-radius:12px;
  background:rgba(255,255,255,0.04);
}
.note-format .pf-btn{
  height:24px;
  padding:0 10px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,0.14);
  background:rgba(0,0,0,0.18);
  color:var(--text);
  cursor:pointer;
  font-size:12px;
  line-height:1;
}
.note-format .pf-color{
  width:34px;
  height:24px;
  padding:0;
  border-radius:10px;
  border:1px solid rgba(255,255,255,0.14);
  background:rgba(0,0,0,0.18);
}
.note-area-rich{
  min-height:260px;
  padding:12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,0.10);
  background:rgba(255,255,255,0.03);
  overflow:auto;
  user-select:text;
}
.note-area-rich:focus{ outline:none; box-shadow: 0 0 0 3px rgba(255,255,255,0.08); }
.note-area[readonly]{ opacity:0.85; }
/* NOTE_WINDOW_END */
.txt-view{
  white-space:pre-wrap;
  background:#fff;
  padding:12px;
  border-radius:12px;
  border:1px solid #ddd;
  min-height:200px;
  color:#000;
}
/* TXT_EDITOR_END */

/* BREADCRUMB_START */
#path{
  display:flex;
  align-items:center;
  gap:6px;
  flex-wrap:wrap;
  user-select:none;
}
#path .crumb{
  cursor:pointer;
  padding:2px 6px;
  border-radius:8px;
  color:var(--text);
}
#path .crumb:hover{
  background:rgba(255,255,255,0.10);
}
#path .sep{
  opacity:0.55;
}
/* BREADCRUMB_END */

/* UI_POLISH_START */
:root{
  --desktop-bg: #0f0f10;
  --desktop-bg-image: none;
}

/* Desktop background */
#desktop{
  background: var(--desktop-bg);
  background-image: var(--desktop-bg-image);
  background-size: cover;
  background-position: center;
}

/* Topbar layout: single line */
#topbar{
  display:flex;
  align-items:center;
  gap:12px;
}
#topbar .logo, #topbar #logo{
  white-space:nowrap;
}
#path.breadcrumbs{
  flex:1 1 auto;
  min-width: 0;
  display:flex;
  align-items:center;
  gap:6px;
  overflow:hidden;
  white-space:nowrap;
}
#path .crumb, #path .sep{
  flex:0 0 auto;
}
#path .crumb{
  cursor:pointer;
  padding:2px 6px;
  border-radius:8px;
}
#path .crumb:hover{ background:rgba(255,255,255,0.10); }
#path .sep{ opacity:0.55; }

/* Root button is the home icon */
#btn-root{ display:inline-flex; }

/* Folder color: handled by SVG color (see .icon.is-folder) */
.icon[data-kind="folder"] .glyph{ background: transparent; border:0; }

/* Settings modal */
.modal{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,0.55);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:18px 10px;
  overflow:auto;
  z-index:1300;
}
.modal-card{
  width:min(520px, 92vw);
  max-height:86vh;
  display:flex;
  flex-direction:column;
  background:rgba(26,26,26,0.96);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:18px;
  box-shadow:0 18px 60px rgba(0,0,0,0.6);
  overflow:hidden;
}
.modal-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:12px 14px;
  border-bottom:1px solid rgba(255,255,255,0.10);
}
.modal-title{ font-weight:800; }
.modal-body{ padding:14px; display:flex; flex-direction:column; gap:14px; flex:1 1 auto; overflow-y:auto; -webkit-overflow-scrolling:touch; }
.form-row{ display:flex; flex-direction:column; gap:8px; }
.form-row label{ font-size:12px; color:var(--muted); }
.form-row input[type="color"]{ width:64px; height:36px; border:none; background:none; padding:0; }
.hint{ font-size:12px; color:var(--muted); }

/* Quill (modal editor) */
.quill-toolbar{
  border:1px solid rgba(255,255,255,0.10);
  border-radius:12px 12px 0 0;
  background:rgba(255,255,255,0.04);
}
.quill-editor{
  border:1px solid rgba(255,255,255,0.10);
  border-top:0;
  border-radius:0 0 12px 12px;
  background:rgba(255,255,255,0.03);
  min-height:240px;
}
.quill-editor .ql-editor{ min-height:240px; }
/* UI_POLISH_END */

/* POSTIT_START */
.postit{
  position:absolute;
  width:240px;
  height:200px;
  min-width:180px;
  min-height:140px;
  border-radius:14px;
  background: var(--note-bg, #fff59d);
  border:1px solid rgba(0,0,0,0.18);
  box-shadow:0 10px 26px rgba(0,0,0,0.28);
  overflow:hidden;
  resize:both;
  color:#111;
  z-index:850;
}
.postit-resize{
  position:absolute;
  width:14px; height:14px;
  right:6px; bottom:6px;
  border-radius:4px;
  background:rgba(0,0,0,0.22);
  border:1px solid rgba(0,0,0,0.25);
  cursor:nwse-resize;
  z-index:5;
}

.postit.selected{
  outline:2px solid rgba(255,255,255,0.35);
  outline-offset:2px;
}
.postit-head{
  height:34px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 8px;
  border-bottom:1px solid rgba(0,0,0,0.12);
  background: color-mix(in srgb, var(--note-bg, #fff59d) 86%, #000 14%);
  cursor:move;
  user-select:none;
}
.postit-title{
  font-weight:800;
  font-size:12px;
  color:#1a1a1a;
  max-width:150px;
  overflow:hidden;
  white-space:nowrap;
  text-overflow:ellipsis;
}
.postit-tools{
  display:flex;
  align-items:center;
  gap:6px;
}
.postit-color{
  width:30px;
  height:22px;
  border:0;
  background:none;
  padding:0;
}
.postit-btn{
  background:rgba(0,0,0,0.12);
  border:1px solid rgba(0,0,0,0.18);
  border-radius:9px;
  height:22px;
  padding:0 8px;
  cursor:pointer;
  font-size:12px;
  line-height:1;
  color:#111;
}
.postit-btn:disabled{
  opacity:0.45;
  cursor:not-allowed;
}
.postit-body{
  width:100%;
  height:calc(100% - 34px);
  border:0;
  background:transparent;
  padding:10px 10px 12px;
  resize:none;
  outline:none;
  font-family: Arial, Helvetica, sans-serif;
  font-size:13px;
  line-height:1.35;
  color:#111;
  user-select:text; /* override body user-select:none */
}
.postit-body[readonly]{
  opacity:0.85;
}
.postit-format{
  display:flex;
  align-items:center;
  gap:6px;
  padding:6px 8px;
  border-top:1px solid rgba(0,0,0,0.12);
  border-bottom:1px solid rgba(0,0,0,0.10);
  background:rgba(0,0,0,0.06);
}
.postit-format .pf-btn{
  height:24px;
  padding:0 8px;
  border-radius:8px;
  border:1px solid rgba(0,0,0,0.18);
  background:rgba(255,255,255,0.45);
  color:#111;
  cursor:pointer;
  font-size:12px;
  line-height:1;
}
.postit-format .pf-color{
  width:30px;
  height:24px;
  padding:0;
  border-radius:8px;
  border:1px solid rgba(0,0,0,0.18);
  background:rgba(255,255,255,0.45);
}
/* POSTIT_END */

/* URLWIN_START */
.urlwin{
  position:absolute;
  width:340px;
  height:240px;
  min-width:220px;
  min-height:160px;
  border-radius:16px;
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.10);
  box-shadow:0 16px 44px rgba(0,0,0,0.45);
  overflow:hidden;
  z-index:860;
}
.urlwin.selected{
  outline:2px solid rgba(255,255,255,0.35);
  outline-offset:2px;
}
.urlwin-head{
  height:34px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 8px;
  border-bottom:1px solid rgba(255,255,255,0.10);
  background:rgba(0,0,0,0.28);
  cursor:move;
  user-select:none;
}
.urlwin-title{
  font-weight:800;
  font-size:12px;
  max-width:170px;
  overflow:hidden;
  white-space:nowrap;
  text-overflow:ellipsis;
}
.urlwin-tools{ display:flex; align-items:center; gap:6px; }
.urlwin-btn{
  background:rgba(255,255,255,0.08);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:10px;
  height:22px;
  padding:0 8px;
  cursor:pointer;
  font-size:12px;
  line-height:1;
  color:var(--text);
}
.urlwin-btn:disabled{ opacity:0.45; cursor:not-allowed; }
.urlwin-body{ height:calc(100% - 34px); background:#111; }
.urlwin-frame{ width:100%; height:100%; border:0; background:#fff; }
.urlwin-resize{
  position:absolute;
  right:6px;
  bottom:6px;
  width:14px;
  height:14px;
  cursor:nwse-resize;
  border-radius:4px;
  background:linear-gradient(135deg, rgba(255,255,255,0.18), rgba(255,255,255,0));
}
/* URLWIN_END */

/* LOG_PANEL_START */
.tree-panel{
  position:fixed;
  top:var(--topbar-h);
  left:0;
  width:280px;
  height:calc(100vh - var(--topbar-h));
  background:var(--panel);
  border-right:1px solid #000;
  z-index:12050;
  display:none;
  flex-direction:column;
}

body.tree-open .tree-panel{display:flex}

body.tree-open #desktop{
  margin-left:280px;
  width:calc(100vw - 280px);
}

/* combine with right panels */
body.tree-open.log-open #desktop{ width:calc(100vw - 280px - 320px); }
body.tree-open.flux-open #desktop{ width:calc(100vw - 280px - 360px); }

.tree-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:10px;
  border-bottom:1px solid #000;
  background:var(--panel2);
}
.tree-title{font-weight:700}
.tree-body{padding:10px; overflow:auto}
.tree-hint{font-size:12px; color:var(--muted); margin-bottom:10px}
.tree-list{font-size:13px;}
.tree-ul{list-style:none; padding-left:14px; margin:0}
.tree-li{margin:2px 0;}
.tree-row{
  display:flex;
  align-items:center;
  gap:6px;
  padding:6px 8px;
  border-radius:10px;
  cursor:pointer;
}
.tree-row:hover{ background:rgba(255,255,255,0.06); }
.tree-row.active{ background:rgba(74,163,255,0.18); border:1px solid rgba(74,163,255,0.25); }
.tree-twisty{width:16px; text-align:center; opacity:0.85;}
.tree-ic{width:18px; text-align:center; opacity:0.95;}
.tree-name{flex:1; min-width:0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;}
.tree-muted{color:rgba(255,255,255,0.55)}

.log-panel{
  position:fixed;
  top:44px;
  right:0;
  width:320px;
  height:calc(100vh - 44px);
  background:var(--panel);
  border-left:1px solid #000;
  z-index:210;
  display:none;
  flex-direction:column;
}
body.log-open .log-panel{display:flex}

body.log-open #desktop{
  width:calc(100vw - 320px);
}

.log-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:10px;
  border-bottom:1px solid #000;
  background:var(--panel2);
}
.log-title{font-weight:700}
.log-actions{display:flex; gap:8px}
.log-list{
  padding:8px;
  overflow:auto;
  font-size:12px;
  color:var(--muted);
}
.log-item{
  padding:8px;
  border:1px solid rgba(255,255,255,0.06);
  border-radius:10px;
  margin-bottom:8px;
  background:rgba(255,255,255,0.03);
}
.log-item .ts{color:rgba(255,255,255,0.55); margin-bottom:4px}
.log-item .msg{color:var(--text); line-height:1.25}
.log-item .msg a{color:var(--accent); text-decoration:none}
.log-item .msg a:hover{text-decoration:underline}
/* LOG_PANEL_END */

/* FLUX_PANEL_START */
.flux-panel{
  position:fixed;
  top:44px;
  right:0;
  width:360px;
  height:calc(100vh - 44px);
  background:var(--panel);
  border-left:1px solid #000;
  z-index:210;
  display:none;
  flex-direction:column;
}
body.flux-open .flux-panel{display:flex}

body.flux-open #desktop{ width:calc(100vw - 360px); }

.flux-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:10px;
  border-bottom:1px solid #000;
  background:var(--panel2);
}
.flux-title{font-weight:800; letter-spacing:0.02em}
.flux-actions{display:flex; gap:8px}

.flux-list{
  padding:10px;
  overflow:auto;
}

.flux-item{
  border:1px solid rgba(255,255,255,0.06);
  border-radius:14px;
  background:rgba(255,255,255,0.03);
  margin-bottom:10px;
  overflow:hidden;
  transition:background 180ms ease, border-color 180ms ease, transform 180ms ease;
}
/* keep header readable: do NOT brighten whole card on hover (it kills contrast on title/date) */
.flux-item:hover{ background:rgba(255,255,255,0.03); border-color:rgba(255,255,255,0.10); }
.flux-item.open{ background:rgba(255,255,255,0.03); border-color:rgba(255,255,255,0.12); }
.flux-item-head{
  padding:10px;
  display:flex;
  flex-direction:column;
  gap:8px;
  align-items:stretch;
}
.flux-title-row{ width:100%; }
.flux-title-row .flux-item-title{ width:100%; text-align:left; }
.flux-item-meta{min-width:0; display:flex; flex-direction:column; align-items:stretch; gap:8px}
.flux-item-meta .flux-item-actions{ align-self:stretch; }
.flux-item-title{    color: #ffffff;
    font-weight: 600;
    font-size: 17px;
    line-height: 1.2;
    background-color: #272727;
    border: 0px;}
.flux-item-date{    
    color: #dfdfdf;
    font-weight: 400;
    font-size: 11px;
    border: 0px;
    background-color: #272727}
.flux-item-tags{font-size:11px; color:#8a8a8a}
.flux-item-actions{display:flex; gap:8px; flex-shrink:0; align-items:center; align-self:flex-start; opacity:0; pointer-events:none; transform:translateY(2px); transition:opacity .15s ease, transform .15s ease}
.flux-item:hover .flux-item-actions,
.flux-item.open .flux-item-actions{opacity:1; pointer-events:auto; transform:translateY(0)}

/* Flux likes */
.flux-item-actions .like-btn{
  position:static;
  display:flex;
  align-items:center;
  gap:6px;
  padding:4px 8px;
  border-radius:999px;
  background:rgba(0,0,0,0.35);
  border:1px solid rgba(255,255,255,0.14);
  color:rgba(255,255,255,0.92);
  font-weight:800;
  font-size:12px;
  line-height:1;
  cursor:pointer;
  user-select:none;
}
.flux-item-actions .like-btn .like-heart{ font-size:13px; transform:translateY(-0.5px); }
.flux-item-actions .like-btn.liked{ background:rgba(255, 0, 80, 0.25); border-color:rgba(255, 0, 80, 0.35); }
.flux-item-actions .like-btn:active{ transform:scale(0.96); }

.flux-body{
  border-top:1px solid rgba(0,0,0,0.5);
  padding:0 10px;
  display:grid;
  grid-template-rows:0fr;
  overflow:hidden;
  opacity:0;
  transform:translateY(-10px);
  transition:grid-template-rows 320ms cubic-bezier(0.22, 1, 0.36, 1), opacity 220ms ease, transform 320ms cubic-bezier(0.22, 1, 0.36, 1), padding 320ms cubic-bezier(0.22, 1, 0.36, 1);
  will-change:transform, opacity;
}
.flux-body .flux-body-inner{min-height:0; overflow:hidden;}
.flux-item.open .flux-body{
  padding:10px;
  grid-template-rows:1fr;
  opacity:1;
  transform:translateY(0);
}

.flux-content{
    font-size: 13px;
    color: #ffffff;
    line-height: 1.35;
    background: #f2f2f2;
    border: 1px solid #e0e0e0;
    border-radius: 12px;
  padding:10px;
}
.flux-item:hover .flux-content{ background:#ededed; }
.flux-item.open .flux-content{ background:#3f3f3f; }
.flux-content img{ max-width:100%; height:auto; border-radius:10px; }
.flux-content a{ color:#111; text-decoration:underline }
.flux-content a:hover{ opacity:0.8 }

/* keep Quill default lists readable inside flux */
.flux-content ol, .flux-content ul{ padding-left:18px; }

/* Flux editor (inside modal window) */
.quill-toolbar{
  border:1px solid rgba(255,255,255,0.10);
  border-radius:12px 12px 0 0;
  /* Must be visible so Quill pickers (color menu) can float above the editor */
  overflow:visible;
  position:relative;
  z-index:5;
}
.quill-editor{
  height:240px;
  background:rgba(255,255,255,0.02);
  border:1px solid rgba(255,255,255,0.10);
  border-top:0;
  border-radius:0 0 12px 12px;
}

/* Flux editor window: keep scroll in modal, but allow Quill dropdowns to render */
.flux-editor-win .win-body{
  overflow:auto;
}
.flux-editor-win .quill-toolbar,
.flux-editor-win .ql-toolbar,
.flux-editor-win .ql-container,
.flux-editor-win .ql-editor,
.flux-editor-win .form-row{
  overflow:visible;
}
.flux-editor-win .ql-picker-options{
  z-index:99999;
}

/* flux modal: smaller editor area */
.flux-quill-small{ height:90px; }

/* FLUX_PANEL_END */

/* FLUX_DRAWER_START */
.flux-drawer{
  position:fixed;
  left:0;
  right:0;
  top:44px;
  z-index:205;
  pointer-events:none;
}
.flux-drawer-inner{
  pointer-events:auto;
  margin:10px 12px 0 12px;
  background:rgba(14,14,16,0.94);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:18px;
  box-shadow:0 20px 60px rgba(0,0,0,0.55);
  overflow:hidden;
  max-height:calc(100vh - 70px);
  display:flex;
  flex-direction:column;
}
.flux-drawer-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
  padding:12px 12px 10px 12px;
  border-bottom:1px solid rgba(255,255,255,0.06);
  background:rgba(255,255,255,0.03);
}
.flux-drawer-title{ font-weight:700; font-size:15px; line-height:1.2; color:#333; }
.flux-drawer-meta{ margin-top:4px; font-size:12px; color:#8a8a8a; font-weight:400; }
.flux-drawer-body{
  padding:12px;
  overflow:auto;
  font-size:14px;
  line-height:1.45;
  color:#111;
  background:#f2f2f2;
}
.flux-drawer-body img{ max-width:100%; height:auto; border-radius:12px; }
.flux-drawer-body a{ color:#111; text-decoration:underline }
.flux-drawer-body a:hover{ opacity:0.8 }
.flux-drawer-body ol, .flux-drawer-body ul{ padding-left:18px; }

/* make list items match current markup */
.flux-item{ padding:10px; }
.flux-item .flux-item-meta{ font-size:11px; color:rgba(255,255,255,0.6); margin-top:4px; }
.flux-item .flux-more{ margin-top:8px; }

/* FLUX_DRAWER_END */

/* Folder window (explorer) */
.folder-win{
  z-index: 60;
  width: 520px;
  height: 420px;
  left: 40px;
  top: 90px;
}
.folder-win .win-body{ overflow:auto; }

/* Resize handle (bottom-right) */
.win-resize{
  position:absolute;
  right:2px;
  bottom:2px;
  width:18px;
  height:18px;
  cursor:nwse-resize;
  opacity:0.35;
}
.win-resize::after{
  content:'';
  position:absolute;
  right:4px;
  bottom:4px;
  width:10px;
  height:10px;
  border-right:2px solid rgba(255,255,255,0.6);
  border-bottom:2px solid rgba(255,255,255,0.6);
}

/* Folder browser list */
.fb-ic{ display:flex; align-items:center; justify-content:center; }
.fb-thumb{
  width:34px;
  height:34px;
  object-fit:cover;
  border-radius:6px;
  border:1px solid rgba(255,255,255,0.12);
}



/* Videos: hide external label (title is inside the thumbnail) */
.icon.is-video .name{display:none;}


/* FLUX filters */
.flux-filters{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  padding:8px 10px;
  border-top:1px solid rgba(0,0,0,0.35);
  border-bottom:1px solid rgba(0,0,0,0.35);
}
.flux-filter-pill{
  font-size:12px;
  padding:4px 8px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,0.12);
  background:rgba(255,255,255,0.05);
  cursor:pointer;
  user-select:none;
}

.flux-item-date{color:#d5d5d5; font-weight:400; font-size:11px;}
.flux-item-date:hover{ text-decoration:underline; }

.flux-item-tags{font-size:11px; color:#8a8a8a}
.flux-tag{
  font-size:12px;
  padding:3px 2px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,0.14);
  background:rgba(255,255,255,0.06);
  cursor:pointer;
  user-select:none;
  line-height: 2.1;
}
.flux-tag:hover{ background:rgba(255,255,255,0.10); }


/* FLUX tag select */
.flux-tag-select{
  appearance:none;
  -webkit-appearance:none;
  -moz-appearance:none;
  background:var(--panel2);
  color:var(--text);
  border:1px solid #000;
  padding:4px 26px 4px 8px;
  border-radius:7px;
  font-size:12px;
  cursor:pointer;
  line-height:1.2;
}
.flux-tag-select:hover{border-color:#333}
.flux-tag-select:focus{outline:none; box-shadow:0 0 0 2px rgba(255,255,255,0.08)}
.flux-tag-select-wrap{position:relative; display:inline-flex; align-items:center}
.flux-tag-select-wrap:after{
  content:"▾";
  position:absolute;
  right:8px;
  pointer-events:none;
  opacity:0.8;
  font-size:11px;
}


/* ===== Topbar Search ===== */
.top-search{ position:relative; display:flex; align-items:center; margin-right:10px; }
.top-search-input{
  width:260px;
  max-width:38vw;
  padding:8px 10px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,0.14);
  background:rgba(0,0,0,0.18);
  color:inherit;
  outline:none;
}
.top-search-input:focus{
  border-color: rgba(255,255,255,0.28);
  box-shadow: 0 0 0 3px rgba(255,255,255,0.08);
}
.top-search-results{
  position:absolute;
  top:44px;
  right:0;
  width:420px;
  max-width:90vw;
  max-height:60vh;
  overflow:auto;
  border-radius:14px;
  background: rgba(15,15,18,0.96);
  border:1px solid rgba(255,255,255,0.14);
  box-shadow: 0 10px 30px rgba(0,0,0,0.45);
  padding:8px;
  z-index: 9999;
}
.search-section-title{
  font-size:12px;
  opacity:0.75;
  padding:8px 10px 4px;
  text-transform:uppercase;
  letter-spacing:0.04em;
}
.search-item{
  display:flex;
  align-items:flex-start;
  gap:10px;
  padding:10px;
  border-radius:12px;
  cursor:pointer;
}
.search-item:hover{ background: rgba(255,255,255,0.08); }
.search-ico{
  width:30px; height:30px;
  border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  background: rgba(255,255,255,0.08);
  flex:0 0 auto;
  font-size:14px;
}
.search-main{ min-width:0; }
.search-title{ font-size:14px; font-weight:600; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.search-sub{ font-size:12px; opacity:0.7; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; margin-top:2px; }
.search-empty{ padding:12px 10px; opacity:0.75; }
.search-pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 10px;
  border-radius:999px;
  background: rgba(255,255,255,0.08);
  cursor:pointer;
  margin:6px 6px 0 0;
  font-size:13px;
}
.search-pill:hover{ background: rgba(255,255,255,0.12); }

.postit-body hr, .note-area-rich hr{
  border:0;
  border-top:1px solid rgba(0,0,0,0.22);
  margin:10px 0;
}

.search-highlight{
  outline:2px solid rgba(255,255,255,0.25);
  outline-offset:3px;
  box-shadow:0 6px 18px rgba(0,0,0,0.22);
  transition: box-shadow 180ms ease, outline-color 180ms ease;
}

/* Topbar retract removed */


/* ensure search dropdown not clipped and topbar contents can shrink */
.topbar-left, .topbar-right{ min-width:0; }


/* ===== Comments UI ===== */
.comment-btn{
  position:absolute;
  right:6px;
  bottom:42px; /* sits above bottom, under like */
  display:flex;
  align-items:center;
  gap:6px;
  padding:4px 8px;
  border-radius:999px;
  background:rgba(0,0,0,0.55);
  border:1px solid rgba(255,255,255,0.18);
  color:rgba(255,255,255,0.92);
  font-weight:800;
  font-size:12px;
  line-height:1;
  cursor:pointer;
  user-select:none;
  backdrop-filter:blur(6px);
}
.comment-btn:hover{ background:rgba(0,0,0,0.68); }
.comment-btn .comment-bubble{ font-size:13px; line-height:1; }
.comment-btn .comment-bubble{ width:13px; display:inline-block; text-align:center; }
.comment-btn .comment-count{ min-width:10px; text-align:center; }

.comment-side{
  bottom:auto;
  top:40px;     /* below like-side */
  right:-8px;
  padding:4px 6px;
  gap:4px;
}

.comments-overlay{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,0.35);
  z-index:9998;
}

.comments-panel{
  position:fixed;
  width:min(520px, 92vw);
  max-height:min(70vh, 560px);
  background:rgba(32,32,32,0.98);
  border:1px solid rgba(255,255,255,0.14);
  border-radius:14px;
  box-shadow:0 20px 60px rgba(0,0,0,0.55);
  z-index:9999;
  display:flex;
  flex-direction:column;
  overflow:hidden;
}

.comments-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:10px 12px;
  background:rgba(0,0,0,0.22);
  border-bottom:1px solid rgba(255,255,255,0.12);
}
.comments-title{ font-weight:900; letter-spacing:.3px; }
.comments-close{
  background:transparent;
  border:0;
  color:rgba(255,255,255,0.85);
  font-size:18px;
  cursor:pointer;
  padding:4px 6px;
}
.comments-close:hover{ color:#fff; }

.comments-list{
  padding:12px;
  overflow:auto;
  flex:1;
}
.comments-empty{
  color:rgba(255,255,255,0.65);
  font-style:italic;
  padding:8px 0;
}

.comment-row{
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.10);
  border-radius:12px;
  padding:8px 10px;
  margin-bottom:8px;
}
.comment-body{
  white-space:pre-wrap;
  font-size:13px;
  line-height:1.35;
}
.comment-meta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-top:6px;
  color:rgba(255,255,255,0.62);
  font-size:12px;
}
.comment-meta-left{display:flex; align-items:center; gap:8px; min-width:0}
.comment-author{font-weight:900; font-size:12px; color:rgba(255,255,255,0.92)}
.comment-reply{
  background:transparent;
  border:0;
  color:var(--accent);
  cursor:pointer;
  font-weight:800;
}
.comment-reply:hover{ text-decoration:underline; }

.comments-replyto{
  padding:8px 12px;
  border-top:1px solid rgba(255,255,255,0.10);
  background:rgba(255,255,255,0.04);
  color:rgba(255,255,255,0.75);
  font-size:12px;
}
.comment-cancel-reply{
  margin-left:8px;
  background:transparent;
  border:1px solid rgba(255,255,255,0.20);
  color:rgba(255,255,255,0.85);
  border-radius:10px;
  padding:2px 8px;
  cursor:pointer;
}
.comment-cancel-reply:hover{ border-color:rgba(255,255,255,0.32); }

.comments-form{
  padding:10px 12px;
  border-top:1px solid rgba(255,255,255,0.12);
  background:rgba(0,0,0,0.18);
}
.comments-input{
  width:100%;
  resize:vertical;
  min-height:60px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,0.14);
  background:rgba(0,0,0,0.25);
  color:var(--text);
  padding:8px 10px;
  outline:none;
}
.comments-input:focus{ border-color:rgba(74,163,255,0.55); }
.comments-actions{
  display:flex;
  justify-content:flex-end;
  margin-top:8px;
}
.comments-send{
  padding:6px 12px;
}
.flux-item-actions{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
}
.flux-item-actions .flux-social{
  display:flex;
  flex-direction:row;
  align-items:center;
  gap:8px;
}
.flux-item-actions .flux-admin{
  display:flex;
  gap:8px;
  align-items:flex-start;
}
.flux-item-actions .comment-btn{
  position:static;
  bottom:auto;
  right:auto;
  margin-top:0;
}


.comment-meta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.comment-meta-actions{
  display:flex;
  align-items:center;
  gap:10px;
}
.comment-del{
  background:transparent;
  border:0;
  color:rgba(255,255,255,0.85);
  cursor:pointer;
  font-size:12px;
  padding:2px 4px;
  border-radius:8px;
}
.comment-del:hover{
  background:rgba(255,255,255,0.10);
}

/* Comments message */
.comments-msg{ margin:8px 0; padding:8px 10px; border-radius:10px; background:rgba(255,255,255,0.08); font-size:13px; }


/* ===== Influence zones (background shapes) ===== */
/* ===== Influence zones (background shapes) ===== */
.zone-influence{
  position:absolute;
  left:40px;
  top:40px;
  width:300px;
  height:220px;
  z-index:1;               /* behind icons by default */
  pointer-events:none;     /* click-through (handles only) */
  box-sizing:border-box;
  border-radius:18px;
}
.zone-influence.shape-circle{ border-radius:50%; }

/* interior fill / border (does not block clicks) */
.zone-influence .zone-fill{
  position:absolute;
  inset:0;
  border:2px dashed rgba(0,0,0,0.25);
  border-radius:inherit;
  background:rgba(0,0,0,0.04);
  pointer-events:none;
}

/* selection + controls */
.zone-influence.selected{ outline:2px solid rgba(0,0,0,0.25); z-index:5; }
.zone-influence .zone-controls{
  position:absolute;
  right:10px;
  top:8px;
  display:none;
  gap:6px;
  z-index:3;
  pointer-events:auto;
}
.zone-influence.selected .zone-controls{ display:flex; }
.zone-influence .zone-btn{
  width:28px;
  height:28px;
  border-radius:10px;
  border:1px solid rgba(0,0,0,0.18);
  background:rgba(255,255,255,0.78);
  cursor:pointer;
  font-size:14px;
  line-height:1;
  display:flex;
  align-items:center;
  justify-content:center;
}
.zone-influence .zone-btn:hover{ background:rgba(255,255,255,0.92); }

.zone-influence .zone-resize{
  position:absolute;
  right:2px;
  bottom:2px;
  width:18px;
  height:18px;
  border-radius:8px;
  background:rgba(0,0,0,0.10);
  cursor:nwse-resize;
  pointer-events:auto;
  z-index:2;
}

/* edge handles (thin hit zones) */
.zone-influence .zone-edges{
  position:absolute;
  inset:0;
  pointer-events:auto;
  z-index:2;
}
.zone-influence .zone-edge{
  position:absolute;
  background:transparent;
}
.zone-influence .edge-top{ left:0; right:0; top:-6px; height:12px; cursor:move; }
.zone-influence .edge-bottom{ left:0; right:0; bottom:-6px; height:12px; cursor:move; }
.zone-influence .edge-left{ top:0; bottom:0; left:-6px; width:12px; cursor:move; }
.zone-influence .edge-right{ top:0; bottom:0; right:-6px; width:12px; cursor:move; }
/* ===== END Influence zones ===== */

.swatch-palette{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:10px;
}
.swatch-palette button{
  width:26px;
  height:26px;
  border-radius:8px;
  border:1px solid rgba(0,0,0,0.18);
  background:#eee;
  cursor:pointer;
}
.swatch-palette button.transparent{
  background:repeating-linear-gradient(45deg,#eee,#eee 6px,#ddd 6px,#ddd 12px);
}
.swatch-palette button.active{
  outline:2px solid rgba(0,0,0,0.5);
}


/* --- Influence zones: click-through interior, admin handles only --- */
.zone-influence{
  pointer-events:none; /* allow clicking items inside */
}
.zone-influence .zone-fill{
  position:absolute;
  inset:0;
  border:2px dashed rgba(0,0,0,0.25);
  border-radius:12px;
  pointer-events:none;
}
.zone-influence.zone-admin-drag{
  pointer-events:auto;
}
.zone-influence.zone-admin-drag .zone-fill,
.zone-influence.zone-admin-drag .zone-text{
  pointer-events:auto;
  cursor:move;
}
.zone-influence.shape-circle .zone-fill{
  border-radius:999px;
}
.zone-influence .zone-controls,
.zone-influence .zone-resize,
.zone-influence .zone-edges,
.zone-influence .zone-edge{
  pointer-events:auto; /* admin UI remains interactive */
}
.zone-influence .zone-edges{
  position:absolute;
  inset:0;
}
.zone-influence .zone-edge{
  position:absolute;
  background:transparent;
}
.zone-influence .edge-top{ left:0; right:0; top:-6px; height:12px; cursor:move; }
.zone-influence .edge-bottom{ left:0; right:0; bottom:-6px; height:12px; cursor:move; }
.zone-influence .edge-left{ top:0; bottom:0; left:-6px; width:12px; cursor:move; }
.zone-influence .edge-right{ top:0; bottom:0; right:-6px; width:12px; cursor:move; }


/* Flux Quill link picker */
.flux-link-picker-overlay{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.35);
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:99999;
}
.flux-link-picker{
  width:min(720px, 92vw);
  max-height:80vh;
  background:#fff;
  border-radius:12px;
  box-shadow:0 10px 30px rgba(0,0,0,.25);
  overflow:hidden;
  display:flex;
  flex-direction:column;
}
.flux-link-picker-head{
  display:flex;
  gap:10px;
  padding:12px;
  border-bottom:1px solid rgba(0,0,0,.1);
}
.flux-link-picker-input{
  flex:1;
  background:#fff;
  color:#000;
}
.flux-link-picker-results{
  padding:10px;
  overflow:auto;
}
.flux-link-item{
  width:100%;
  text-align:left;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:10px 12px;
  margin:6px 0;
  border:1px solid rgba(0,0,0,.12);
  border-radius:10px;
  background:#fff;
  color:#000;
  cursor:pointer;
}
.flux-link-item:hover{
  background:rgba(0,0,0,.04);
}
.flux-link-name{
  color:#000;
}
.flux-link-kind{
  font-size:12px;
  padding:2px 8px;
  border-radius:999px;
  border:1px solid rgba(0,0,0,.18);
  color:#000;
  opacity:.85;
}
.ql-snow .ql-toolbar button.ql-dialoglink{
  width:auto;
  font-weight:700;
}


/* INBOX badge (admin) */
.avatar-btn{ position:relative; }
.inbox-badge{
  position:absolute;
  top:5px;
  right:4px;
  min-width:18px;
  height:18px;
  padding:0 5px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:11px;
  font-weight:800;
  background:rgba(255,60,60,0.92);
  color:#fff;
  border:2px solid rgba(20,20,20,0.95);
  box-shadow:0 6px 18px rgba(0,0,0,0.35);
}

.email-copy-row{display:flex; gap:10px; align-items:center;}
.email-copy-row input{flex:1; padding:10px 12px; border-radius:12px; border:1px solid rgba(255,255,255,0.18); background:rgba(0,0,0,0.25); color:#fff;}
.copy-ico{font-weight:900; margin-right:6px;}

.express-editor{
  height:220px;
  background:#fff;
  border-radius:12px;
  border:1px solid #ddd;
  overflow:hidden;
}
.express-editor .ql-toolbar{ border-top-left-radius:12px; border-top-right-radius:12px; }
.express-editor .ql-container{ border-bottom-left-radius:12px; border-bottom-right-radius:12px; }

.inbox-list{ display:flex; flex-direction:column; gap:10px; margin-top:10px; }
.inbox-item{
  border:1px solid rgba(255,255,255,0.12);
  background:rgba(255,255,255,0.04);
  border-radius:14px;
  padding:10px 12px;
  cursor:pointer;
}
.inbox-item-row{ display:flex; align-items:flex-start; gap:10px; }
.inbox-item-main{ min-width:0; flex:1 1 auto; }
.inbox-avatar{
  width:42px;
  height:42px;
  border-radius:10px;
  overflow:hidden;
  flex:0 0 42px;
  display:block;
}
.inbox-avatar img{ width:100%; height:100%; object-fit:cover; display:block; }
.inbox-item.unread{ border-color:rgba(255,180,60,0.38); background:rgba(255,180,60,0.10); }
.inbox-item .sub{ font-size:12px; color:var(--muted); margin-top:4px; }
.inbox-item .meta{ font-size:12px; color:var(--muted); margin-top:6px; display:flex; justify-content:space-between; gap:10px; flex-wrap:wrap;}
.inbox-item .meta span:last-child{ white-space:pre-line; }
.inbox-detail-body{
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.10);
  border-radius:14px;
  padding:12px;
  color:#f2f2f2;
}
.inbox-detail-body *{ color:#f2f2f2 !important; }
.inbox-detail-body a{ color:#8ec8ff !important; text-decoration:underline; }



/* ===== Flux: thumbnail centered in frame with adaptive background ===== */
.flux-thumb-frame{
  padding:10px 10px 0 10px;
  width:100%;
  height:240px;
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,255,255,0.06);
  cursor:pointer;
}
.flux-thumb{
  max-width:100%;
  max-height:100%;
  object-fit:contain;
  border-radius:12px;
  display:block;
}

.flux-carousel{
  position:relative;
  width:100%;
  height:100%;
  display:flex;
  align-items:center;
  justify-content:center;
}
.flux-carousel .flux-thumb{
  position:absolute;
  inset:0;
  margin:auto;
  width:100%;
  height:100%;
  object-fit:contain;
  opacity:0;
  transition:opacity .18s ease;
}
.flux-carousel .flux-thumb.is-active{ opacity:1; }

.flux-car-btn{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:34px;
  height:34px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,0.15);
  background:rgba(0,0,0,0.35);
  color:rgba(255,255,255,0.9);
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:22px;
  line-height:1;
}
.flux-car-prev{ left:8px; }
.flux-car-next{ right:8px; }

.flux-car-dots{
  position:absolute;
  left:0;
  right:0;
  bottom:8px;
  display:flex;
  gap:6px;
  justify-content:center;
}
.flux-car-dot{
  width:7px;
  height:7px;
  border-radius:999px;
  border:0;
  background:rgba(255,255,255,0.35);
  cursor:pointer;
}
.flux-car-dot.on{ background:rgba(255,255,255,0.85); }

/* ===== Flux: formatted preview + read more toggle ===== */
.flux-preview{
  padding:10px;
  display:flex;
  flex-direction:column;
  gap:8px;
  width:100%;
}
.flux-preview-html{
  font-size:13px;
  line-height:1.35;
  color:rgba(255,255,255,0.92);
  word-break:break-word;
}
.flux-preview-html a{
  color:rgba(220,220,220,0.92);
  text-decoration:underline;
}
.flux-preview-html a:hover{ opacity:0.9; }
.flux-item.expanded .flux-preview-html{ font-size:14px; }
.flux-readmore{
  align-self:flex-start;
  border:0;
  background:transparent;
  color:rgba(255,255,255,0.85);
  text-decoration:underline;
  cursor:pointer;
  padding:0;
  font-weight:700;
}


/* ===== Flux editor form ===== */
.flux-editor-grid{ display:flex; flex-direction:column; gap:12px; }
.flux-editor-field{ display:flex; flex-direction:column; gap:6px; }
.lbl{ font-size:12px; color:black; font-weight:700; }
.flux-share-row{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
.flux-share-status{
  font-size:11px;
  color:rgba(15,23,42,0.78);
  font-weight:700;
}
.flux-share-status.is-alert{
  color:#b91c1c;
}
.flux-editor-actions{ display:flex; justify-content:flex-end; gap:10px; margin-top:6px; position:sticky; bottom:0; padding:10px 0 0 0; background:rgba(0,0,0,0.0); }

/* Multi-selection controls */
#btn-multi.is-active{
  background:#ffd54f;
  color:#111;
  border-color:rgba(0,0,0,0.45);
}
.actions{
  max-height:calc(100vh - 16px);
  overflow:auto;
}

.bulk-move-hint{
  position:fixed;
  left:50%;
  bottom:20px;
  transform:translateX(-50%);
  padding:10px 14px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,0.2);
  background:rgba(0,0,0,0.7);
  color:#fff;
  font-size:12px;
  z-index:1400;
  opacity:0;
  pointer-events:none;
  transition:opacity .15s ease;
}
.bulk-move-hint.show{ opacity:1; }
.align-picker-panel{ width:min(420px, 92vw); }
.align-picker-help{
  font-size:12px;
  color:rgba(255,255,255,0.78);
  margin-bottom:8px;
}
.align-picker-info{
  font-weight:700;
  margin-bottom:8px;
}
.align-picker-grid{
  display:grid;
  grid-template-columns:repeat(8, 1fr);
  gap:4px;
}
.align-cell{
  height:26px;
  border-radius:6px;
  border:1px solid rgba(255,255,255,0.25);
  background:rgba(255,255,255,0.06);
  cursor:pointer;
}
.align-cell.active{
  background:#ffd54f;
  border-color:#ffd54f;
}

/* Advanced labels */
.zone-influence .zone-text{
  position:absolute;
  inset:10px 14px 10px 14px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  white-space:pre-wrap;
  overflow:hidden;
  word-break:break-word;
  pointer-events:none;
  text-shadow:0 1px 2px rgba(0,0,0,0.35);
  z-index:1;
}
.zone-editor-panel{ width:min(560px, 94vw); }

/* Line links */
.line-link{
  position:absolute;
  z-index:1;
  pointer-events:none;
}
.line-link .line-svg{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  overflow:visible;
  pointer-events:none;
}
.line-link .line-path{
  pointer-events:none;
  cursor:pointer;
  opacity:0.95;
}
.line-link .line-hit{
  pointer-events:stroke;
  cursor:pointer;
}
.line-link .line-controls{
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
  display:none;
  gap:6px;
  pointer-events:auto;
}
.line-link.selected .line-controls{ display:flex; }
.line-editor-panel{ width:min(420px, 92vw); }

.flux-thumb-row{ display:flex; gap:10px; align-items:center; }
.flux-thumb-preview-wrap{ width:100%; }
.flux-thumb-preview-list{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  padding:6px 0 0 0;
  max-height:120px;
  overflow:auto;
}
.flux-thumb-thumb{
  width:84px;
  height:84px;
  object-fit:cover;
  border-radius:10px;
  border:1px solid rgba(255,255,255,0.10);
  cursor:pointer;
}
.flux-thumb-thumb.is-main{
  outline:2px solid rgba(255,255,255,0.65);
  outline-offset:1px;
}
.flux-editor-win .win-body{
  padding-bottom:10px;
}
.flux-editor-grid{
  min-height:100%;
}

/* Compact Flux editor so it fits in the window (with scrollbar) */
.flux-editor-win .flux-editor-grid{ gap:8px; }
.flux-editor-win .flux-editor-field{ gap:4px; }
.flux-editor-win .lbl{ font-size:11px; }
.flux-editor-win .hint{ font-size:11px; color:black}
.flux-editor-win .flux-thumb-preview{ max-height:120px; }
.flux-editor-win .ql-editor img{ max-width:100%; height:auto; max-height:220px; object-fit:contain; }

/* Save button busy state */
#fluxSaveBtn.is-busy{ opacity:0.6; pointer-events:none; }

/* ===== V5 Labels + Links ===== */
.zone-influence .zone-text{
  position:absolute;
  inset:10px 14px 10px 14px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  white-space:pre-wrap;
  overflow:hidden;
  word-break:break-word;
  pointer-events:none;
  text-shadow:0 1px 2px rgba(0,0,0,0.35);
  z-index:1;
}
.zone-editor-panel{ width:min(560px, 94vw); }
.line-link{
  position:absolute;
  z-index:1;
  pointer-events:none;
}
.line-link .line-svg{ position:absolute; inset:0; width:100%; height:100%; overflow:visible; pointer-events:none; }
.line-link .line-path{ pointer-events:none; cursor:pointer; opacity:0.95; }
.line-link .line-hit{ pointer-events:stroke; cursor:pointer; }
.line-link .line-controls{ position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); display:none; gap:6px; pointer-events:auto; }
.line-link.selected .line-controls{ display:flex; }
.line-link .line-scale-handle{
  position:absolute;
  width:24px;
  height:24px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,0.7);
  background:rgba(0,0,0,0.75);
  color:#fff;
  font-size:13px;
  line-height:1;
  display:none;
  align-items:center;
  justify-content:center;
  transform:translate(-50%, -50%);
  pointer-events:auto;
  cursor:ew-resize;
  z-index:2;
}
.line-link.selected .line-scale-handle{ display:flex; }
.line-editor-panel{ width:min(420px, 92vw); }
/* ===== END V5 Labels + Links ===== */

/* V5 arrows visibility */
.line-link{ z-index:3 !important; }

/* ===== V5 Zone Animations ===== */
.zone-influence .zone-stars{
  position:absolute;
  inset:0;
  pointer-events:none;
  display:none;
  z-index:2;
}
.zone-influence .zone-stars i{
  position:absolute;
  width:4px;
  height:4px;
  border-radius:999px;
  background:radial-gradient(circle, rgba(255,255,255,0.98) 0%, rgba(255,240,160,0.9) 55%, rgba(255,240,160,0) 80%);
  box-shadow:0 0 6px rgba(255,240,160,0.75);
  opacity:0;
  animation: zoneStarTwinkle 5.8s ease-in-out infinite;
}
.zone-influence .zone-stars i:nth-child(1){ left:10%; top:16%; animation-delay:0s; }
.zone-influence .zone-stars i:nth-child(2){ right:14%; top:22%; animation-delay:1.6s; }
.zone-influence .zone-stars i:nth-child(3){ left:20%; bottom:20%; animation-delay:3.1s; }
.zone-influence .zone-stars i:nth-child(4){ right:18%; bottom:14%; animation-delay:4.4s; }

.zone-influence.zone-anim-pulse{
  animation: zonePulse 3.8s ease-in-out infinite;
}
.zone-influence.zone-anim-glow .zone-fill{
  animation: zoneGlow 4.2s ease-in-out infinite;
}
.zone-influence.zone-anim-rainbow .zone-text{
  background-image:linear-gradient(90deg, #ff6b6b, #ffd166, #4ecdc4, #5dade2, #b084f5, #ff6b6b);
  background-size:240% 100%;
  color:transparent !important;
  -webkit-background-clip:text;
  background-clip:text;
  animation: zoneRainbowText 5.6s linear infinite;
}
.zone-influence.zone-anim-stars .zone-stars{
  display:block;
}

@keyframes zonePulse{
  0%,100%{ transform:scale(1); }
  50%{ transform:scale(1.02); }
}
@keyframes zoneGlow{
  0%,100%{ filter:brightness(1); box-shadow:none; }
  50%{ filter:brightness(1.08); box-shadow:0 0 18px rgba(255,255,255,0.25); }
}
@keyframes zoneRainbowText{
  0%{ background-position:0% 50%; }
  100%{ background-position:240% 50%; }
}
@keyframes zoneStarTwinkle{
  0%, 86%, 100%{ opacity:0; transform:scale(0.85); }
  18%{ opacity:0.9; transform:scale(1.18); }
  30%{ opacity:0.2; transform:scale(1.0); }
}
/* ===== END V5 Zone Animations ===== */

/* ===== Folder privacy badges ===== */
.icon .glyph .folder-private-badge{
  position:absolute;
  left:2px;
  top:2px;
  width:18px;
  height:18px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:11px;
  line-height:1;
  color:#fff;
  background:rgba(0,0,0,0.72);
  border:1px solid rgba(255,255,255,0.35);
  box-shadow:0 1px 4px rgba(0,0,0,0.45);
  pointer-events:none;
  z-index:4;
}
.icon .glyph .folder-collab-badge{
  position:absolute;
  right:2px;
  top:2px;
  width:18px;
  height:18px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:11px;
  line-height:1;
  color:#fff;
  background:rgba(0,0,0,0.72);
  border:1px solid rgba(255,255,255,0.35);
  box-shadow:0 1px 4px rgba(0,0,0,0.45);
  pointer-events:none;
  z-index:4;
}
.fb-ic.fb-folder{
  position:relative;
}
.fb-ic .fb-private-badge{
  position:absolute;
  left:-2px;
  top:-4px;
  width:14px;
  height:14px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:9px;
  line-height:1;
  color:#fff;
  background:rgba(0,0,0,0.72);
  border:1px solid rgba(255,255,255,0.35);
  box-shadow:0 1px 3px rgba(0,0,0,0.35);
  pointer-events:none;
  z-index:2;
}
.fb-ic .fb-collab-badge{
  position:absolute;
  right:-2px;
  top:-4px;
  width:14px;
  height:14px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:9px;
  line-height:1;
  color:#fff;
  background:rgba(0,0,0,0.72);
  border:1px solid rgba(255,255,255,0.35);
  box-shadow:0 1px 3px rgba(0,0,0,0.35);
  pointer-events:none;
  z-index:2;
}
.fb-list.thumb-view .fb-ic .fb-private-badge{
  left:4px;
  top:2px;
  width:18px;
  height:18px;
  font-size:11px;
}
.fb-list.thumb-view .fb-ic .fb-collab-badge{
  right:4px;
  top:2px;
  width:18px;
  height:18px;
  font-size:11px;
}
/* ===== END Folder privacy badges ===== */

/* ===== Mobile Webapp Mode ===== */
body.mobile-ui{
  --topbar-h:64px;
}
body.mobile-ui #topbar{
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:2600;
  padding:0 8px;
  gap:8px;
}
body.mobile-ui #desktop{
  margin-top:var(--topbar-h);
  height:calc(100vh - var(--topbar-h) - 68px);
}
body.mobile-ui .project-badge{
  margin-right:8px;
  padding-top:0;
  gap:4px;
  --project-title-w: 11ch;
}
body.mobile-ui .project-title-btn{ font-size:22px; }
body.mobile-ui #brand.brand{
  font-size:14px;
  line-height:1.05;
}
body.mobile-ui #path{
  font-size:11px;
  margin-left:4px;
  max-width:40vw;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
body.mobile-ui #topbar .topbar-right{
  gap:6px;
}
body.mobile-ui #btn-up{
  display:none !important;
}
body.mobile-ui #topSearchWrap{
  display:none !important;
}
body.mobile-ui .top-search-input{
  font-size:13px;
  padding:7px 9px;
}
body.mobile-ui .mobile-search-panel{
  display:block;
}
body.mobile-ui .actions{
  max-height:36vh;
}
body.mobile-ui #topbar .topbar-right > #btn-ui-mode,
body.mobile-ui #topbar .topbar-right > #btn-help,
body.mobile-ui #topbar .topbar-right > #btn-cli,
body.mobile-ui #topbar .topbar-right > #btn-newsletter,
body.mobile-ui #topbar .topbar-right > #btn-agenda,
body.mobile-ui #topbar .topbar-right > #btn-multi,
body.mobile-ui #topbar .topbar-right > #btn-undo,
body.mobile-ui #topbar .topbar-right > #btn-settings,
body.mobile-ui #topbar .topbar-right > #roleBadge,
body.mobile-ui #topbar .topbar-right > #zoomOut,
body.mobile-ui #topbar .topbar-right > #zoomIn,
body.mobile-ui #topbar .topbar-right > #btn-flux,
body.mobile-ui #topbar .topbar-right > #btn-flux-add,
body.mobile-ui #topbar .topbar-right > #btn-login,
body.mobile-ui #topbar .topbar-right > #btn-logout{
  display:none !important;
}
body.mobile-ui #deskNav,
body.mobile-ui #minimap,
body.mobile-ui #dropZones{
  display:none !important;
}
body.mobile-ui .icon{
  width:114px;
}
body.mobile-ui .icon .glyph{
  width:72px;
  height:72px;
}
body.mobile-ui .icon.photo-resizable{
  padding:6px;
}
body.mobile-ui .icon.photo-resizable .glyph{
  width:100%;
  height:100%;
  margin:0;
  border-radius:14px;
}
body.mobile-ui .icon.photo-resizable .name{
  left:6px;
  right:6px;
  bottom:6px;
  font-size:11px;
}
body.mobile-ui .actions{
  position:fixed;
  left:auto !important;
  right:8px !important;
  bottom:74px !important;
  top:auto !important;
  transform:none !important;
  width:min(58vw, 220px);
  max-width:min(58vw, 220px);
  z-index:2700;
  justify-content:flex-start;
  overflow:auto;
  gap:6px;
  padding:8px;
  flex-direction:column;
}
body.mobile-ui .actions .btn{
  width:100%;
  padding:5px 8px;
  font-size:12px;
}
body.mobile-ui #newMenu{
  position:fixed;
  left:8px !important;
  right:8px;
  bottom:74px;
  top:auto !important;
  z-index:2750;
  max-height:58vh;
  overflow:auto;
}
body.mobile-ui .tree-panel,
body.mobile-ui .log-panel,
body.mobile-ui .flux-panel{
  top:var(--topbar-h);
  left:0;
  right:0;
  width:100vw;
  height:calc(100vh - var(--topbar-h) - 68px);
  border-left:0;
  border-right:0;
  z-index:2550;
}
body.mobile-ui #settingsModal{
  z-index:5000;
}
body.mobile-ui #storageFilesModal{
  z-index:5105;
}
body.mobile-ui #settingsModal .modal-card{
  width:calc(100vw - 12px);
  max-width:none;
  max-height:calc(100vh - var(--topbar-h) - 76px);
  margin:6px auto;
  border-radius:12px;
}
body.mobile-ui #settingsModal .modal-head{
  position:sticky;
  top:0;
  z-index:2;
  background:var(--panel);
}
body.mobile-ui #settingsModal .modal-body{
  max-height:calc(100vh - var(--topbar-h) - 150px);
  overflow:auto;
}
body.mobile-ui .win{
  left:0 !important;
  top:var(--topbar-h) !important;
  width:100vw !important;
  height:calc(100vh - var(--topbar-h) - 68px) !important;
  border-radius:0;
}
body.mobile-ui #mobileDock{
  display:grid;
}
.mobile-dock{
  position:fixed;
  left:8px;
  right:8px;
  bottom:8px;
  z-index:2800;
  display:none;
  grid-template-columns:repeat(6, minmax(0, 1fr));
  gap:8px;
  padding:8px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,0.18);
  background:rgba(20,20,20,0.78);
  backdrop-filter:blur(8px);
}
.mobile-dock .btn{
  min-height:42px;
  padding:8px 6px;
  font-size:15px;
}

.folder-collab-card{
  width:min(92vw, 640px);
}
.folder-collab-card label{
  font-size:12px;
  opacity:.9;
  display:block;
  margin-bottom:4px;
}
.folder-collab-share-row{
  display:flex;
  gap:8px;
  align-items:center;
}
.folder-collab-share-row .input{
  flex:1 1 auto;
  min-width:0;
}
.folder-collab-check{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:13px;
}
.folder-collab-foot{
  display:flex;
  justify-content:flex-end;
  gap:8px;
  padding:12px 14px;
  border-top:1px solid rgba(255,255,255,0.12);
}
@media (max-width: 680px){
  .folder-collab-card{
    width:min(96vw, 96vw);
    max-height:88vh;
  }
  .folder-collab-share-row{
    flex-direction:column;
    align-items:stretch;
  }
}
/* ===== END Mobile Webapp Mode ===== */

/* Video title fix: always show upload title below local/youtube thumbnails.
   Keep this at end to override duplicated legacy rules above. */
.icon.is-video .name{
  display:block !important;
  opacity:1 !important;
  position:static !important;
  margin-top:6px;
  padding:3px 8px !important;
  background:rgba(25,25,28,0.88) !important;
  color:#fff !important;
  border:1px solid rgba(255,255,255,0.14);
  border-radius:999px !important;
  max-width:100%;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
body.mobile-ui .icon.is-video .name{
  display:block !important;
  opacity:1 !important;
}

/* Slideshow side navigation zones (desktop window media viewer) */
.win.media-view .slideshow-side-nav{
  position:absolute;
  top:0;
  bottom:0;
  width:clamp(44px, 9vw, 92px);
  border:0;
  background:transparent;
  color:#fff;
  opacity:1;
  cursor:pointer;
  z-index:6;
  padding:0;
}
.win.media-view .slideshow-side-nav.left{ left:0; }
.win.media-view .slideshow-side-nav.right{ right:0; }
.win.media-view .slideshow-side-arrow{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:34px;
  height:34px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  border:1px solid rgba(255,255,255,0.35);
  background:rgba(0,0,0,0.40);
  opacity:0;
  transition:opacity .18s ease, transform .18s ease;
  pointer-events:none;
  font-size:16px;
  line-height:1;
}
.win.media-view .slideshow-side-nav.left .slideshow-side-arrow{ left:8px; }
.win.media-view .slideshow-side-nav.right .slideshow-side-arrow{ right:8px; }
.win.media-view .slideshow-side-nav:hover .slideshow-side-arrow{
  opacity:1;
  transform:translateY(-50%) scale(1.03);
}
body.mobile-ui .win.media-view .slideshow-side-arrow{
  opacity:.7;
}

/* Folder icon sizing + recursive file counter overlay */
.icon.is-folder .glyph svg{
  width:calc(58px * var(--folder-icon-scale, 1));
  height:calc(46px * var(--folder-icon-scale, 1));
}
.icon .glyph .folder-count-badge{
  position:absolute;
  left:50%;
  top:62%;
  transform:translate(-50%, -50%);
  pointer-events:none;
  user-select:none;
  color:rgba(42,42,42,0.48);
  font-weight:800;
  font-size:calc((58px * var(--folder-icon-scale, 1)) / 3);
  line-height:1;
}
.icon.folder-icon-person .glyph .folder-count-badge{
  top:74%;
}
.icon.folder-icon-notebook .glyph .folder-count-badge{
  left:46%;
  top:66%;
}

/* Direct resize for folders */
.icon.folder-resizable{
  padding:6px;
  min-width:72px;
  min-height:72px;
  height:auto !important;
  display:block;
}
.icon.folder-resizable .glyph{
  width:100%;
  height:auto;
  aspect-ratio:64 / 48;
  margin:0;
  background:transparent;
}
.icon.folder-resizable .glyph svg{
  width:100%;
  height:100%;
  display:block;
}
.icon.is-dialogz-link .glyph{
  color:var(--folder-color);
}
.icon .name.dialogz-link-name{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
  text-align:center;
  line-height:1.05;
}
.icon .name .dialogz-link-line1{
  font-size:11px;
  font-weight:800;
  letter-spacing:.02em;
  opacity:.92;
  display:block;
}
.icon .name .dialogz-link-line2{
  font-size:12px;
  font-weight:700;
}
.icon.folder-resizable .name{
  width:100%;
  margin-top:4px;
  display:block;
}
.icon.folder-resizable .resize-handle{
  display:none;
  position:absolute;
  right:3px;
  bottom:3px;
  width:14px;
  height:14px;
  border-radius:4px;
  background:rgba(255,255,255,0.88);
  border:1px solid rgba(0,0,0,0.45);
  cursor:nwse-resize;
  z-index:4;
}
.icon.folder-resizable:hover .resize-handle,
.icon.folder-resizable.selected .resize-handle{
  display:block;
}

/* Quota files manager */
.storage-files-body{
  padding:12px;
}
.storage-files-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(170px, 1fr));
  gap:10px;
}
.storage-files-toolbar{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
  margin-bottom:12px;
  flex-wrap:wrap;
}
.storage-files-toolbar-left{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
.storage-manage-btn{
  padding:12px 18px;
  font-size:15px;
  font-weight:800;
  border-radius:12px;
  background:rgba(255,255,255,0.14);
  border-color:rgba(255,255,255,0.22);
}
.storage-manage-btn:hover{
  background:rgba(255,255,255,0.2);
}
.storage-sort-wrap{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:13px;
  color:rgba(255,255,255,0.88);
  font-weight:700;
}
.storage-sort-select{
  min-width:180px;
}
.storage-files-more{
  display:flex;
  justify-content:center;
  margin-top:14px;
}
.storage-section-title{
  margin:18px 0 10px;
  font-size:22px;
  font-weight:700;
}
.storage-files-filter{
  margin-bottom:12px;
}
.storage-select-all{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:13px;
  color:rgba(255,255,255,0.88);
}
.storage-delete-selected{
  font-weight:800;
}
.storage-file-card{
  border:1px solid rgba(255,255,255,0.14);
  border-radius:12px;
  background:rgba(255,255,255,0.03);
  padding:8px;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.storage-file-card.is-selected{
  border-color:rgba(255,215,120,0.72);
  box-shadow:0 0 0 1px rgba(255,215,120,0.28) inset;
}
.storage-file-check{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:12px;
  color:rgba(255,255,255,0.84);
}
.storage-file-thumb{
  width:100%;
  aspect-ratio:16/10;
  border-radius:8px;
  overflow:hidden;
  background:rgba(0,0,0,0.32);
  display:flex;
  align-items:center;
  justify-content:center;
}
.archive-card .storage-file-thumb{
  min-height:140px;
}
.storage-file-thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.storage-file-fallback{
  font-size:30px;
  opacity:0.88;
}
.storage-file-name{
  font-size:12px;
  line-height:1.25;
  min-height:30px;
  overflow:hidden;
  word-break:break-word;
}
.storage-file-meta{
  font-size:12px;
  opacity:0.82;
}
.storage-file-usage{
  display:inline-flex;
  align-items:center;
  width:fit-content;
  max-width:100%;
  padding:5px 9px;
  border-radius:999px;
  font-size:11px;
  font-weight:700;
  line-height:1.2;
}
.storage-file-usage.usage-root{
  background:rgba(88,174,255,0.16);
  color:#9ed4ff;
}
.storage-file-usage.usage-folder{
  background:rgba(92,214,124,0.16);
  color:#9ff0aa;
}
.storage-file-usage.usage-orphan{
  background:rgba(255,160,90,0.16);
  color:#ffc188;
}
.storage-file-refs{
  font-size:11px;
  font-weight:700;
  color:#b7dcff;
}
.storage-file-path{
  font-size:11px;
  line-height:1.35;
  color:rgba(255,255,255,0.72);
  word-break:break-word;
  padding:6px 8px;
  border-radius:8px;
  background:rgba(255,255,255,0.04);
}
.storage-file-storepath{
  font-size:10px;
  line-height:1.35;
  color:rgba(255,255,255,0.52);
  word-break:break-all;
}
.storage-file-dup{
  font-size:11px;
  font-weight:700;
  line-height:1.3;
}
.storage-file-dup.dup-name{
  color:#ffd88a;
}
.storage-file-dup.dup-path{
  color:#ff9b9b;
}
.storage-open-btn{
  padding:9px 14px;
  font-size:13px;
  font-weight:800;
  border-radius:10px;
  background:rgba(255,255,255,0.12);
  border-color:rgba(255,255,255,0.22);
}
.storage-open-btn:hover{
  background:rgba(255,255,255,0.18);
}

/* Label editor readability + new menu width clamp */
.zone-editor-panel .panel-title{
  color:#fff;
  font-size:17px;
  font-weight:800;
  letter-spacing:0.02em;
}
.zone-editor-panel .form-row label{
  color:rgba(255,255,255,0.92);
  font-weight:700;
}
.zone-editor-panel .hint{
  color:rgba(255,255,255,0.86);
}

/* Keep desktop double-click creation menu compact */
body:not(.mobile-ui) #newMenu{
  right:auto !important;
  bottom:auto !important;
  width:min(260px, calc(100vw - 24px));
  max-width:min(260px, calc(100vw - 24px));
  max-height:70vh;
  overflow:auto;
}
body:not(.mobile-ui) #newMenu .menu-item{
  white-space:normal;
  line-height:1.25;
}

.shortcut-picker-card{
  width:min(700px, 94vw);
  max-height:84vh;
  display:flex;
  flex-direction:column;
}
.shortcut-picker-results{
  margin-top:10px;
  border:1px solid rgba(255,255,255,0.14);
  border-radius:10px;
  background:rgba(0,0,0,0.22);
  max-height:min(52vh, 420px);
  overflow:auto;
}
.shortcut-picker-row{
  width:100%;
  border:0;
  border-bottom:1px solid rgba(255,255,255,0.08);
  background:transparent;
  color:inherit;
  text-align:left;
  padding:9px 12px;
  display:flex;
  align-items:center;
  gap:10px;
  cursor:pointer;
}
.shortcut-picker-row:last-child{
  border-bottom:0;
}
.shortcut-picker-row:hover{
  background:rgba(255,255,255,0.08);
}
.shortcut-picker-row.is-selected{
  background:rgba(76,175,80,0.26);
}
.shortcut-picker-ico{
  width:22px;
  text-align:center;
  font-size:16px;
  flex:0 0 22px;
}
.shortcut-picker-main{
  min-width:0;
  display:flex;
  flex-direction:column;
}
.shortcut-picker-title{
  font-weight:700;
  line-height:1.2;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.shortcut-picker-sub{
  opacity:0.82;
  font-size:12px;
  line-height:1.2;
}
.shortcut-picker-empty{
  padding:12px;
  opacity:0.86;
  font-size:13px;
}

/* Audio stream icon */
.icon .glyph svg.audio-stream-svg{
  width:62px;
  height:62px;
}
.icon.is-audio-stream .glyph{
  background:transparent;
}
.icon.is-audio-stream .glyph .audio-wave-bar{
  transform-origin:center 32px;
  transition:transform .22s ease;
}
.icon.is-audio-stream:hover .glyph .audio-wave-bar.b1{ animation:audioWave .95s ease-in-out infinite; }
.icon.is-audio-stream:hover .glyph .audio-wave-bar.b2{ animation:audioWave .78s ease-in-out infinite .05s; }
.icon.is-audio-stream:hover .glyph .audio-wave-bar.b3{ animation:audioWave .66s ease-in-out infinite .08s; }
.icon.is-audio-stream:hover .glyph .audio-wave-bar.b4{ animation:audioWave .78s ease-in-out infinite .04s; }
.icon.is-audio-stream:hover .glyph .audio-wave-bar.b5{ animation:audioWave .95s ease-in-out infinite .02s; }
.icon.is-audio-stream:hover .glyph svg.audio-stream-svg{
  filter:drop-shadow(0 0 4px rgba(125,235,255,0.38));
}
@keyframes audioWave{
  0%{ transform:scaleY(.65); }
  50%{ transform:scaleY(1.28); }
  100%{ transform:scaleY(.72); }
}

/* Flux panel: split header in 2 lines (tabs/close + tools) */
.flux-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.flux-actions{
  display:flex;
  align-items:center;
  gap:8px;
}
.flux-tools-row{
  display:flex;
  align-items:center;
  gap:8px;
  padding:8px 10px 10px;
  border-top:1px solid rgba(255,255,255,0.10);
  border-bottom:1px solid rgba(255,255,255,0.08);
  flex-wrap:wrap;
}

/* + Billet visible in blue */
#btn-flux-add{
  background:linear-gradient(180deg,#4f9dff 0%, #2f6fe8 100%) !important;
  border-color:#1f56bb !important;
  color:#f7fbff !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.24), 0 5px 14px rgba(41,95,208,0.34);
}
#btn-flux-add:hover{
  filter:brightness(1.06);
}

/* Chat (messenger-like) */
.chat-top-btn{
  position:relative;
}
.chat-badge-top{
  position:absolute;
  top:-6px;
  right:-6px;
  min-width:16px;
  height:16px;
  padding:0 4px;
  border-radius:999px;
  font-size:10px;
  line-height:16px;
  font-weight:800;
  color:#fff;
  background:#ff4d5a;
  border:1px solid rgba(0,0,0,0.35);
}
.chat-card{
  max-width:980px;
  width:min(980px, calc(100vw - 24px));
  height:min(76vh, 760px);
}
.chat-modal-body{
  display:grid;
  grid-template-columns:minmax(240px, 300px) 1fr;
  gap:12px;
  overflow:hidden;
}
.chat-side{
  border:1px solid rgba(255,255,255,0.16);
  border-radius:12px;
  background:rgba(255,255,255,0.03);
  min-width:0;
  display:flex;
  flex-direction:column;
  overflow:hidden;
}
.chat-side-head{
  padding:10px;
  border-bottom:1px solid rgba(255,255,255,0.10);
}
.chat-threads{
  flex:1 1 auto;
  overflow:auto;
  padding:8px;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.chat-thread{
  border:1px solid rgba(255,255,255,0.12);
  border-radius:10px;
  padding:8px;
  display:flex;
  align-items:center;
  gap:10px;
  cursor:pointer;
  background:rgba(255,255,255,0.04);
}
.chat-thread:hover{
  background:rgba(255,255,255,0.09);
}
.chat-thread.is-active{
  border-color:rgba(87,154,255,0.72);
  background:rgba(87,154,255,0.16);
}
.chat-thread.unread{
  border-color:rgba(255,180,60,0.46);
}
.chat-thread-avatar{
  width:42px;
  height:42px;
  border-radius:999px;
  overflow:hidden;
  flex:0 0 42px;
  background:rgba(255,255,255,0.12);
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:800;
  color:#d7e8ff;
}
.chat-thread-avatar img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.chat-thread-main{
  min-width:0;
  flex:1 1 auto;
}
.chat-thread-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
}
.chat-thread-name{
  font-weight:800;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.chat-thread-time{
  color:var(--muted);
  font-size:12px;
  flex:0 0 auto;
}
.chat-thread-last{
  color:var(--muted);
  font-size:12px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.chat-thread-unread{
  margin-left:6px;
  min-width:18px;
  height:18px;
  border-radius:999px;
  font-size:11px;
  line-height:18px;
  text-align:center;
  background:#ff4d5a;
  color:#fff;
  font-weight:700;
  flex:0 0 auto;
}
.chat-main{
  border:1px solid rgba(255,255,255,0.16);
  border-radius:12px;
  background:rgba(255,255,255,0.02);
  min-width:0;
  display:flex;
  flex-direction:column;
  overflow:hidden;
}
.chat-header{
  padding:10px 12px;
  border-bottom:1px solid rgba(255,255,255,0.10);
  font-weight:700;
}
.chat-messages{
  flex:1 1 auto;
  overflow:auto;
  padding:12px;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.chat-row{
  display:flex;
}
.chat-row.mine{
  justify-content:flex-end;
}
.chat-bubble{
  max-width:min(78%, 620px);
  border-radius:12px;
  padding:8px 10px;
  border:1px solid rgba(255,255,255,0.18);
  background:rgba(255,255,255,0.08);
  color:#f2f2f2;
  white-space:pre-wrap;
  word-break:break-word;
}
.chat-row.mine .chat-bubble{
  background:rgba(87,154,255,0.28);
  border-color:rgba(87,154,255,0.52);
}
.chat-bubble-time{
  margin-top:4px;
  font-size:11px;
  color:var(--muted);
}
.chat-compose{
  border-top:1px solid rgba(255,255,255,0.10);
  padding:10px;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.chat-compose-actions{
  display:flex;
  justify-content:flex-end;
  gap:8px;
}

@media (max-width: 920px){
  .chat-card{
    height:min(86vh, 860px);
  }
  .chat-modal-body{
    grid-template-columns:1fr;
    gap:10px;
    overflow:auto;
  }
  .chat-side{
    max-height:34vh;
  }
}

/* Chat window behavior (v6.4): compact bubbles + draggable/resizable card */
#chatModal .chat-card{
  position:fixed;
  left:50%;
  top:50%;
  transform:none;
  max-width:calc(100vw - 20px);
  width:min(760px, calc(100vw - 24px));
  height:min(66vh, 560px);
  min-width:520px;
  min-height:300px;
  overflow:hidden;
  resize:none;
}
#chatModal .chat-modal-body{
  height:calc(100% - 56px);
}
#chatModal .chat-card .modal-head{
  cursor:move;
  user-select:none;
}
#chatModal .chat-card .modal-head button{
  cursor:pointer;
}
#chatModal .chat-head-actions{
  display:flex;
  align-items:center;
  gap:8px;
}
#chatModal .chat-row{
  display:flex;
  align-items:flex-start;
  width:100%;
  flex:0 0 auto;
}
#chatModal .chat-row.mine{
  justify-content:flex-end;
}
#chatModal .chat-bubble{
  display:inline-flex;
  flex-direction:column;
  gap:6px;
  width:auto;
  max-width:min(64%, 460px);
  flex:0 0 auto;
  border-radius:12px;
  padding:10px 12px;
  border:1px solid rgba(255,255,255,0.18);
  background:rgba(255,255,255,0.08);
  color:#f2f2f2;
  white-space:pre-wrap;
  overflow-wrap:anywhere;
  word-break:break-word;
  min-height:unset !important;
  height:fit-content !important;
}
#chatModal .chat-row.mine .chat-bubble{
  background:rgba(87,154,255,0.28);
  border-color:rgba(87,154,255,0.52);
}
#chatModal .chat-bubble > div:first-child{
  display:block;
  line-height:1.35;
  margin:0;
}
#chatModal .chat-bubble-time{
  margin-top:0;
  font-size:11px;
  color:var(--muted);
}
#chatModal .chat-settings-panel{
  border-bottom:1px solid rgba(255,255,255,0.12);
  padding:10px;
  display:flex;
  flex-direction:column;
  gap:8px;
  background:rgba(255,255,255,0.03);
}
#chatModal .chat-settings-panel[hidden]{
  display:none !important;
}
#chatModal .chat-settings-row{
  display:flex;
  align-items:center;
  gap:8px;
}
#chatModal .chat-settings-row label{
  font-size:13px;
  color:#d8e8ff;
}
#chatModal .chat-settings-actions{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
#chatModal .chat-resize-handle{
  position:absolute;
  right:8px;
  bottom:8px;
  width:16px;
  height:16px;
  border:0;
  background:
    linear-gradient(135deg, transparent 0 42%, rgba(255,255,255,.42) 43% 48%, transparent 49% 60%, rgba(255,255,255,.34) 61% 66%, transparent 67% 100%);
  opacity:.82;
  cursor:nwse-resize;
  border-radius:3px;
  padding:0;
}
#chatModal .chat-resize-handle:hover{ opacity:1; }

@media (max-width:920px){
  #chatModal .chat-card{
    position:relative;
    left:auto;
    top:auto;
    transform:none;
    width:min(100%, calc(100vw - 16px));
    max-width:100%;
    min-width:0;
    min-height:0;
    height:min(86vh, 860px);
  }
  #chatModal .chat-modal-body{
    height:auto;
  }
  #chatModal .chat-card .modal-head{
    cursor:default;
  }
  #chatModal .chat-resize-handle{
    display:none;
  }
  .cli-card{
    min-width:0;
    width:min(100%, calc(100vw - 12px));
    max-width:100%;
    min-height:0;
    height:min(88vh, 760px);
  }
  #cliModal .modal-head{
    cursor:default;
  }
  .cli-resize-handle{
    display:none;
  }
}

.cli-card{
  width:min(1100px, 96vw);
  max-width:min(1100px, 96vw);
  min-width:420px;
  min-height:260px;
  position:relative;
  display:flex;
  flex-direction:column;
}
.cli-body{
  flex:1 1 auto;
  min-height:0;
  display:flex;
  flex-direction:column;
  gap:10px;
  padding-top:10px;
}
.cli-output{
  min-height:280px;
  max-height:min(62vh, 540px);
  overflow:auto;
  border-radius:10px;
  border:1px solid rgba(151,255,171,0.25);
  background:#0a0f12;
  color:#cbf8d1;
  font:13px/1.35 "JetBrains Mono","Fira Sans","SFMono-Regular",Consolas,monospace;
  padding:10px;
}
.cli-line{
  white-space:pre-wrap;
  word-break:break-word;
  margin:0 0 4px;
}
.cli-line.cmd{
  color:#e4f8ff;
}
.cli-line.ok{
  color:#98f7aa;
}
.cli-line.err{
  color:#ff9aa2;
}
.cli-line.dim{
  color:rgba(203,248,209,0.72);
}
.cli-form{
  display:flex;
  align-items:center;
  gap:8px;
}
.cli-prompt{
  flex:0 0 auto;
  min-width:96px;
  max-width:38%;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  color:#d5f2ff;
  font:12px/1.2 "JetBrains Mono","Fira Sans","SFMono-Regular",Consolas,monospace;
}
.cli-input{
  flex:1 1 auto;
  min-width:120px;
  border:1px solid rgba(151,255,171,0.30);
  background:#0b1216;
  color:#e9fff0;
  border-radius:9px;
  padding:9px 10px;
  font:13px/1.2 "JetBrains Mono","Fira Sans","SFMono-Regular",Consolas,monospace;
}
.cli-input:focus{
  outline:none;
  border-color:rgba(151,255,171,0.72);
  box-shadow:0 0 0 2px rgba(151,255,171,0.15);
}
#cliModal .modal-head{
  cursor:move;
}
#cliModal .modal-head .btn{
  cursor:pointer;
}
.cli-resize-handle{
  position:absolute;
  right:8px;
  bottom:8px;
  width:16px;
  height:16px;
  border:0;
  background:
    linear-gradient(135deg, transparent 0 42%, rgba(151,255,171,.52) 43% 48%, transparent 49% 60%, rgba(151,255,171,.44) 61% 66%, transparent 67% 100%);
  opacity:.9;
  cursor:nwse-resize;
  border-radius:3px;
  padding:0;
}
.cli-resize-handle:hover{
  opacity:1;
}

.folder-desc-input{
  min-height:88px;
  resize:vertical;
}

.description-char-count{
  margin-top:-8px;
  font-size:12px;
  line-height:1.2;
  color:var(--muted);
  text-align:right;
}

.description-date-range{
  display:flex;
  gap:8px;
}

.description-date-range .input{
  flex:1 1 0;
}

.icon[data-folder-description],
.fb-item[data-folder-description]{
  position:relative;
}

.icon[data-folder-description]:hover{
  z-index:2147483000 !important;
}

.folder-hover-tip{
  position:absolute;
  left:50%;
  bottom:calc(100% + 8px);
  transform:translateX(-50%);
  min-width:160px;
  max-width:240px;
  padding:8px 10px;
  border-radius:10px;
  background:var(--desc-pop-bg);
  color:var(--desc-pop-text);
  border:1px solid var(--desc-pop-border);
  font-size:12px;
  line-height:1.35;
  white-space:pre-wrap;
  text-align:left;
  box-shadow:0 10px 24px rgba(0,0,0,0.3);
  pointer-events:none;
  opacity:0;
  visibility:hidden;
  transition:opacity .14s ease, visibility .14s ease;
  z-index:30;
}

.desktop-floating-hover-tip{
  position:fixed;
  left:0;
  top:0;
  bottom:auto;
  transform:translate(-50%, -100%);
  z-index:2147483000;
}

.folder-hover-tip::after{
  content:"";
  position:absolute;
  left:50%;
  top:100%;
  transform:translateX(-50%);
  border-width:6px 6px 0 6px;
  border-style:solid;
  border-color:var(--desc-pop-bg) transparent transparent transparent;
}

.icon[data-folder-description]:hover .folder-hover-tip,
.fb-item[data-folder-description]:hover .folder-hover-tip{
  opacity:1;
  visibility:visible;
}

.desktop-floating-hover-tip.is-visible{
  opacity:1;
  visibility:visible;
}

.icon.dragging .folder-hover-tip,
.fb-item.dragging .folder-hover-tip{
  opacity:0 !important;
  visibility:hidden !important;
}

.folder-hover-tip-inline{
  left:18px;
  bottom:calc(100% - 2px);
  transform:none;
}

.folder-hover-tip-inline::after{
  left:18px;
  transform:none;
}

.folder-hover-tip-date{
  display:block;
  margin-top:7px;
  font-size:11px;
  font-weight:700;
  letter-spacing:.02em;
  text-align:left;
}

.folder-hover-tip-body{
  white-space:pre-wrap;
}
