/* Rich editor modals: image insert, video insert, HTML source, link */

/* ---------- Toasts end ---------- */
.img-insert-modal{
  max-width:860px;width:94vw;max-height:90vh;
  display:flex;flex-direction:column;
}
.link-modal{max-width:480px;width:92vw}
.link-modal .modal-body{padding:18px 24px}

/* HTML source modal */
.html-source-modal{max-width:820px;width:94vw;max-height:85vh;display:flex;flex-direction:column}
.html-source-modal .modal-body{padding:18px 24px;flex:1;overflow:hidden;display:flex;flex-direction:column}
.html-source-text{
  flex:1;min-height:320px;
  font-family:"JetBrains Mono",monospace;font-size:12.5px;line-height:1.55;
  color:var(--ink);background:var(--bg);
  padding:14px;border:1px solid var(--line);border-radius:8px;
  resize:vertical;tab-size:2;
  white-space:pre-wrap;word-wrap:break-word;
}
.html-source-text:focus{outline:0;border-color:var(--accent)}
.html-source-text.no-wrap{white-space:pre;overflow-x:auto}
.img-modal-tabs{
  display:flex;gap:2px;padding:0 20px;
  border-bottom:1px solid var(--line);background:var(--bg-2);
}
.imt-tab{
  padding:12px 16px;background:transparent;border:0;cursor:pointer;
  color:var(--ink-dim);font-size:12.5px;font-weight:500;
  display:inline-flex;align-items:center;gap:7px;
  border-bottom:2px solid transparent;margin-bottom:-1px;
  font-family:inherit;transition:color .12s, border-color .12s;
}
.imt-tab svg{width:15px;height:15px}
.imt-tab:hover{color:var(--ink)}
.imt-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.imt-count{
  background:var(--bg);color:var(--ink-dim);
  padding:1px 7px;border-radius:999px;font-size:10.5px;
  font-family:"JetBrains Mono",monospace;font-weight:700;
}
.imt-tab.active .imt-count{background:var(--accent);color:#0b0b0a}

.img-modal-body{flex:1;overflow-y:auto;padding:20px;min-height:280px;max-height:55vh}
.imt-panel{display:none}
.imt-panel.active{display:block}

.imt-panel .drop-zone{margin:0 0 18px}

.url-upload{
  padding:16px;border:1px solid var(--line);border-radius:10px;background:var(--bg-2);
  margin-bottom:16px;
}
.url-upload label{
  display:block;margin-bottom:8px;
  font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-soft);font-weight:600;
}
.url-row{display:flex;gap:8px}
.url-row .inp{flex:1}
.url-row .btn{flex-shrink:0}

.upload-options{
  display:flex;gap:20px;flex-wrap:wrap;padding:12px 16px;
  border:1px solid var(--line);border-radius:10px;background:var(--bg-2);
}

.img-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;
}
.img-grid-empty{
  grid-column:1/-1;padding:40px 20px;text-align:center;
  color:var(--ink-dim);font-size:13px;line-height:1.6;
}
.img-tile{
  position:relative;aspect-ratio:4/3;border-radius:8px;overflow:hidden;
  border:2px solid var(--line);background:var(--bg-2);cursor:pointer;
  transition:transform .12s, border-color .12s, box-shadow .12s;
}
.img-tile:hover{border-color:var(--line-strong);transform:translateY(-2px)}
.img-tile.selected{
  border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(212,255,62,.2), 0 6px 20px rgba(212,255,62,.2);
}
.img-tile img{width:100%;height:100%;object-fit:cover;display:block}
.img-tile .tile-check{
  position:absolute;top:6px;right:6px;width:22px;height:22px;border-radius:50%;
  background:var(--accent);color:#0b0b0a;display:grid;place-items:center;
  opacity:0;transform:scale(.6);transition:opacity .12s, transform .12s;
}
.img-tile.selected .tile-check{opacity:1;transform:scale(1)}
.img-tile .tile-check svg{width:13px;height:13px}

/* Selection order badge (multi-select) */
.img-tile .tile-order{
  position:absolute;bottom:6px;right:6px;
  min-width:22px;height:22px;padding:0 6px;border-radius:999px;
  background:var(--accent);color:#0b0b0a;
  font-family:"JetBrains Mono",monospace;font-size:11px;font-weight:700;
  display:grid;place-items:center;
  border:2px solid var(--bg);
  box-shadow:0 2px 8px rgba(212,255,62,.4);
}

/* Inline clear-selection link in footer */
.link-btn{
  background:transparent;border:0;color:var(--accent);cursor:pointer;
  font:inherit;font-size:inherit;padding:0;margin-left:6px;
  text-decoration:underline;text-underline-offset:2px;
}
.link-btn:hover{color:#b8e835}
.img-tile .tile-del{
  position:absolute;top:6px;left:6px;width:22px;height:22px;border-radius:6px;
  background:rgba(0,0,0,.75);color:#fff;border:0;cursor:pointer;
  display:grid;place-items:center;opacity:0;transition:opacity .12s;
}
.img-tile:hover .tile-del{opacity:1}
.img-tile .tile-del:hover{background:var(--accent-2)}
.img-tile .tile-del svg{width:11px;height:11px}
.img-tile .tile-info{
  position:absolute;bottom:0;left:0;right:0;
  padding:5px 8px;background:linear-gradient(transparent, rgba(0,0,0,.85));
  font-family:"JetBrains Mono",monospace;font-size:9.5px;color:#fff;letter-spacing:.08em;
  display:flex;justify-content:space-between;
}

/* Video tile: play icon overlay */
.img-tile.video-tile::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg, rgba(0,0,0,.1), rgba(0,0,0,.55));
  pointer-events:none;z-index:1;
}
.img-tile.video-tile::after{
  content:"";position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:44px;height:44px;border-radius:50%;
  background:rgba(212,255,62,.92);
  box-shadow:0 4px 20px rgba(0,0,0,.4);
  pointer-events:none;z-index:2;
  /* Play triangle using clip-path */
  background-image:radial-gradient(circle, rgba(212,255,62,.92) 100%, transparent 100%);
}
.img-tile.video-tile .play-triangle{
  position:absolute;top:50%;left:calc(50% + 2px);
  transform:translate(-50%,-50%);
  width:0;height:0;
  border-left:14px solid #0b0b0a;
  border-top:9px solid transparent;
  border-bottom:9px solid transparent;
  pointer-events:none;z-index:3;
}
.img-tile.video-tile .video-duration{
  position:absolute;top:6px;left:6px;z-index:2;
  padding:2px 6px;border-radius:4px;
  background:rgba(0,0,0,.75);color:#fff;
  font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.04em;font-weight:600;
}

.img-modal-foot{
  display:flex;align-items:center;gap:12px;
  padding:14px 20px;border-top:1px solid var(--line);background:var(--bg-2);
  flex-wrap:wrap;
}
.foot-spacer{flex:1;min-width:10px}
.align-picker{display:flex;align-items:center;gap:4px}
.align-label{
  font-family:"JetBrains Mono",monospace;font-size:10.5px;letter-spacing:.12em;
  color:var(--ink-dim);text-transform:uppercase;margin-right:6px;
}
.align-btn{
  width:30px;height:30px;border-radius:6px;
  background:transparent;border:1px solid var(--line);cursor:pointer;
  color:var(--ink-dim);display:grid;place-items:center;
  transition:background .12s, color .12s, border-color .12s;
}
.align-btn:hover{color:var(--ink);border-color:var(--line-strong)}
.align-btn.active{background:var(--accent);color:#0b0b0a;border-color:var(--accent)}
.align-btn svg{width:14px;height:14px}
.selected-label{
  font-size:12px;color:var(--ink-dim);font-family:"JetBrains Mono",monospace;
  letter-spacing:.04em;
}

@media (max-width:600px){
  .img-insert-modal{width:100vw;height:100vh;max-height:100vh;border-radius:0}
  .img-modal-tabs{overflow-x:auto;white-space:nowrap}
  .imt-tab{padding:10px 12px;font-size:12px}
  .imt-tab svg{display:none}
  .img-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px}
  .img-modal-foot{padding:10px 14px}
  .selected-label{display:none}
}
.media-item .mi-tag{
  position:absolute;top:6px;left:6px;padding:2px 7px;border-radius:4px;
  background:rgba(0,0,0,.7);color:var(--accent);
  font-family:"JetBrains Mono",monospace;font-size:9px;letter-spacing:.1em;font-weight:700;
  text-transform:uppercase;
}

/* Video section */
.video-section{
  margin:10px 20px 18px;padding:14px;
  border:1px solid var(--line);border-radius:10px;background:var(--bg-2);
}
.video-tabs{display:flex;gap:2px;margin-bottom:10px}
.vt-btn{
  padding:6px 14px;border-radius:6px;background:transparent;border:1px solid var(--line);
  font-family:"JetBrains Mono",monospace;font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-dim);cursor:pointer;font-weight:600;
  transition:background .12s, color .12s, border-color .12s;
}
.vt-btn:hover{color:var(--ink)}
.vt-btn.active{background:var(--accent);color:#0b0b0a;border-color:var(--accent)}
.video-preview{margin-top:12px;position:relative}
.video-remove{
  position:absolute;top:10px;right:10px;
  background:rgba(0,0,0,.75);backdrop-filter:blur(6px);
  color:#fff;border-color:rgba(255,255,255,.2);
  display:inline-flex;align-items:center;gap:6px;padding:6px 12px;
}
.video-remove:hover{background:var(--accent-2);border-color:var(--accent-2);color:#fff}
.video-remove svg{width:12px;height:12px}

/* Tags */
.tags-box{
  margin:10px 20px 18px;padding:16px;
  border:1px solid var(--line);border-radius:10px;background:var(--bg-2);
  min-height:80px;
  display:flex;flex-wrap:wrap;gap:8px;
}
.tags-box.inline{
  margin:0;padding:14px;min-height:auto;
}
.tags-empty{
  color:var(--ink-dim);font-size:13px;font-style:italic;
  width:100%;text-align:center;padding:12px 0;
}
.tag-chip{
  padding:6px 12px;border-radius:999px;
  background:transparent;border:1px solid var(--line-strong);color:var(--ink-soft);
  font-size:12px;cursor:pointer;font-family:inherit;
  transition:background .12s, color .12s, border-color .12s;
}
.tag-chip:hover{border-color:var(--accent);color:var(--ink)}
.tag-chip.on{
  background:var(--accent);color:#0b0b0a;border-color:var(--accent);font-weight:600;
}
.tag-chip.on::before{content:"✓ ";font-weight:700}

/* Sub-category specific tags get subtle cyan accent to differentiate */
.tag-chip.tag-sub{
  border-color:rgba(0,212,255,.35);color:#90e6ff;
  background:rgba(0,212,255,.04);
}
.tag-chip.tag-sub:hover{border-color:#00d4ff;color:#d3f4ff}
.tag-chip.tag-sub.on{
  background:var(--accent);color:#0b0b0a;border-color:var(--accent);
}

/* Checkbox custom */
.checkbox-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px 18px;padding-top:2px}
.checkbox-row{
  display:inline-flex;align-items:center;gap:9px;cursor:pointer;
  font-size:13px;color:var(--ink);
}
.checkbox-row.compact{font-size:12px;color:var(--ink-soft)}
.checkbox-row input{display:none}
.checkbox-row .checkbox-box{
  width:18px;height:18px;border:1.5px solid var(--line-strong);border-radius:4px;
  display:grid;place-items:center;transition:background .12s, border-color .12s;
  flex-shrink:0;
}
.checkbox-row .checkbox-box svg{width:11px;height:11px;color:#0b0b0a;opacity:0;transition:opacity .1s}
.checkbox-row input:checked + .checkbox-box{background:var(--accent);border-color:var(--accent)}
.checkbox-row input:checked + .checkbox-box svg{opacity:1}
.checkbox-row:hover .checkbox-box{border-color:var(--ink-soft)}
.checkbox-row .chief-only{
  margin-left:auto;font-family:"JetBrains Mono",monospace;font-size:9px;letter-spacing:.12em;
  padding:1px 6px;border-radius:4px;text-transform:uppercase;font-weight:700;
  background:rgba(165,148,247,.15);color:#a594f7;border:1px solid rgba(165,148,247,.35);
}

.date-row{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.date-row input[type="datetime-local"]{max-width:240px}
.date-row input[type="datetime-local"]:disabled{opacity:.5}

/* Role-based visibility for publish checkbox */
body[data-role="editor"] .checkbox-row[data-show-for~="chief"],
body[data-role="member"] .checkbox-row[data-show-for~="chief"],
body[data-role="guest"] .checkbox-row[data-show-for]{display:none !important}

/* Add News form */
.addnews-form{display:flex;flex-direction:column;gap:20px}
.form-group{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;
}
.form-group h3{
  padding:14px 20px;margin:0;
  font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ink-soft);font-weight:600;
  border-bottom:1px solid var(--line);background:var(--bg-2);
}
.form-group .f-row{padding:14px 20px;border-bottom:1px solid var(--line)}
.form-group .f-row:last-child{border-bottom:0}
.form-group .f-row label{
  display:block;font-size:12px;color:var(--ink-soft);margin-bottom:8px;
  font-family:"JetBrains Mono",monospace;letter-spacing:.1em;text-transform:uppercase;font-weight:600;
}
.form-group .f-row label .req{color:var(--accent-2)}
.form-group .f-row.cols-2{display:grid;grid-template-columns:1fr 1fr;gap:20px;padding:14px 20px}
.form-group .f-row.cols-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px;padding:14px 20px}
.form-group .f-row.cols-2 > div,
.form-group .f-row.cols-3 > div{padding:0}

/* f-row-split: 2 column layout (left flexible, right content) */
.form-group .f-row.f-row-split{
  display:grid;grid-template-columns:1fr auto;gap:24px;align-items:end;padding:14px 20px;
}
.form-group .f-row.f-row-split .f-col{min-width:0}
.form-group .f-row.f-row-split .f-col-dl-type{min-width:260px}
@media (max-width:600px){
  .form-group .f-row.f-row-split{grid-template-columns:1fr}
  .form-group .f-row.f-row-split .f-col-dl-type{min-width:0}
}

/* Download type toggle (Premium / Free) */
.dl-type-toggle{
  display:flex;gap:8px;
}
.dl-type-opt{
  flex:1;cursor:pointer;user-select:none;
}
.dl-type-opt input[type="radio"]{
  position:absolute;opacity:0;pointer-events:none;
}
.dl-type-box{
  display:flex;align-items:center;gap:8px;
  padding:9px 12px;border-radius:7px;
  border:1px solid var(--line);background:var(--bg-2);
  transition:border-color .15s, background .15s, transform .1s;
}
.dl-type-opt:hover .dl-type-box{transform:translateY(-1px)}
.dl-type-check{
  display:inline-grid;place-items:center;
  width:16px;height:16px;border-radius:4px;
  border:1.5px solid var(--line-strong);background:transparent;
  color:transparent;transition:all .15s;flex-shrink:0;
}
.dl-type-check svg{width:11px;height:11px;display:block}
.dl-type-opt b{
  font-family:"JetBrains Mono",monospace;font-size:12px;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;color:var(--ink);
}

/* Premium (blue) — selected state */
.dl-type-premium input:checked ~ .dl-type-box,
.dl-type-premium.on .dl-type-box{
  border-color:#3b82f6;background:rgba(59,130,246,.12);
}
.dl-type-premium input:checked ~ .dl-type-box .dl-type-check,
.dl-type-premium.on .dl-type-box .dl-type-check{
  background:#3b82f6;border-color:#3b82f6;color:#fff;
}

/* Free (green) — selected state */
.dl-type-free input:checked ~ .dl-type-box,
.dl-type-free.on .dl-type-box{
  border-color:#22c55e;background:rgba(34,197,94,.12);
}
.dl-type-free input:checked ~ .dl-type-box .dl-type-check,
.dl-type-free.on .dl-type-box .dl-type-check{
  background:#22c55e;border-color:#22c55e;color:#fff;
}
.form-group textarea.inp{resize:vertical;min-height:100px;font-family:"Geist",sans-serif}
.form-group select.inp{
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23b9b2a1' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;
  padding-right:34px;
}

.thumb-upload{
  margin:18px 20px;padding:28px;
  border:2px dashed var(--line-strong);border-radius:var(--radius);
  display:flex;align-items:center;gap:16px;
  background:var(--bg-2);cursor:pointer;
  transition:border-color .15s, background .15s;
}
.thumb-upload:hover{border-color:var(--accent);background:var(--surface-2)}
.thumb-upload svg{width:40px;height:40px;color:var(--ink-dim);flex-shrink:0}
.thumb-upload > div{flex:1}
.thumb-upload b{display:block;color:var(--ink);font-weight:500;font-size:14px;margin-bottom:4px}
.thumb-upload span{font-size:12px;color:var(--ink-dim)}

#linksWrap{padding:14px 20px 0}
.link-row{display:flex;gap:8px;margin-bottom:10px;align-items:center}
.link-del{
  padding:9px;flex-shrink:0;color:var(--ink-dim);border-color:var(--line);
}
.link-del:hover{color:var(--accent-2);border-color:var(--accent-2);background:rgba(255,92,41,.06)}
.link-del svg{width:14px;height:14px}
.add-link{
  margin:0 20px 14px;display:inline-flex;align-items:center;gap:6px;
  color:var(--accent);border-color:var(--accent);
}
.add-link:hover{background:rgba(212,255,62,.08)}
.add-link svg{width:14px;height:14px}
.helper{
  margin:0;padding:0 20px 16px;
  font-size:12px;color:var(--ink-dim);line-height:1.5;
}

.form-actions{
  display:flex;gap:10px;justify-content:flex-end;padding-top:6px;
}
.form-actions .btn{padding:10px 20px}

@media (max-width:700px){
  .form-group .f-row.cols-2,
  .form-group .f-row.cols-3{grid-template-columns:1fr;gap:14px}
  .thumb-upload{flex-direction:column;text-align:center}
  .form-actions{flex-wrap:wrap}
}
.settings-group h3{
  padding:16px 20px;margin:0;
  font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ink-soft);font-weight:600;
  border-bottom:1px solid var(--line);background:var(--bg-2);
}
.s-field{
  display:grid;grid-template-columns:200px 1fr;gap:18px;align-items:center;
  padding:14px 20px;border-bottom:1px solid var(--line);
}
.s-field:last-child{border-bottom:0}
.s-field label{
  font-size:13px;color:var(--ink-soft);font-weight:500;
}
.s-field label span{display:block;font-size:11px;color:var(--ink-dim);margin-top:3px;font-weight:400}
.s-field .inp{
  width:100%;padding:10px 14px;
  background:var(--bg-2);border:1px solid var(--line);border-radius:8px;
  color:var(--ink);font:inherit;font-size:13.5px;outline:0;
  transition:border-color .15s, background .15s;
}
.s-field .inp:focus{border-color:var(--accent);background:var(--surface-2)}

/* Responsive */
@media (max-width:1100px){
  .profile-body{grid-template-columns:1fr}
  .profile-side{order:-1}
  .overview-grid{grid-template-columns:1fr}
  .p-cards{grid-template-columns:repeat(2,1fr)}
  .friends-grid{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:700px){
  .profile-hero-inner{grid-template-columns:auto 1fr;gap:18px}
  .profile-actions{grid-column:1/-1;padding-bottom:20px}
  .profile-identity h1{font-size:34px}
  .profile-avatar-xl{width:80px;height:80px;font-size:36px}
  .profile-stats{grid-template-columns:repeat(2,1fr)}
  .p-stat:nth-child(n){border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
  .p-cards{grid-template-columns:1fr}
  .friends-grid{grid-template-columns:repeat(2,1fr)}
  .s-field{grid-template-columns:1fr;gap:8px}
}

