/* All modals: advanced search, auth (sign in/register), captcha, share, report */

/* ── Advanced search modal ── */
/* ---------- ADVANCED SEARCH MODAL ---------- */
.modal-backdrop{
  position:fixed;inset:0;z-index:100;
  background:rgba(6,6,5,.72);
  backdrop-filter:blur(8px);
  display:none;align-items:flex-start;justify-content:center;
  padding:60px 20px 40px;overflow-y:auto;
  opacity:0;transition:opacity .2s;
}
.modal-backdrop.open{display:flex;opacity:1}

.modal{
  background:var(--surface);
  border:1px solid var(--line-strong);
  border-radius:var(--radius-lg);
  width:100%;max-width:760px;
  position:relative;
  box-shadow:0 40px 80px -20px rgba(0,0,0,.8), 0 0 0 1px rgba(212,255,62,.04);
  transform:translateY(12px) scale(.98);
  transition:transform .25s cubic-bezier(.2,.9,.3,1);
  overflow:hidden;
}
.modal-backdrop.open .modal{transform:translateY(0) scale(1)}

.modal-head{
  padding:26px 30px 22px;
  border-bottom:1px solid var(--line);
  display:flex;align-items:flex-start;justify-content:space-between;gap:20px;
  position:relative;
}
.modal-head::before{
  content:"";position:absolute;top:0;left:30px;right:30px;height:1px;
  background:linear-gradient(90deg,transparent,var(--accent),transparent);
  opacity:.4;
}
.modal-head h2{
  font-family:"Fraunces",serif;font-weight:400;font-size:34px;letter-spacing:-0.02em;margin:0;line-height:1;
}
.modal-head h2 em{font-style:italic;color:var(--accent);font-weight:300}
.modal-head .eyebrow-mono{
  font-family:"JetBrains Mono",monospace;font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-dim);margin-bottom:8px;display:block;
}
.modal-close{
  width:36px;height:36px;border-radius:10px;
  display:grid;place-items:center;
  background:var(--bg-2);border:1px solid var(--line);color:var(--ink-soft);
  transition:background .15s, color .15s, border-color .15s;
  flex-shrink:0;cursor:pointer;
}
.modal-close:hover{background:var(--surface-2);color:var(--accent);border-color:var(--accent)}
.modal-close svg{width:16px;height:16px}

.modal-notice{
  margin:18px 30px 0;
  padding:12px 16px;border-radius:10px;
  background:rgba(255,190,85,.08);
  border:1px solid rgba(255,190,85,.25);
  border-left:3px solid var(--warn);
  display:flex;gap:10px;align-items:flex-start;
  font-size:13px;color:#f3e1b8;
}
.modal-notice svg{width:16px;height:16px;color:var(--warn);flex-shrink:0;margin-top:1px}

.modal-body{
  padding:24px 30px 10px;
  max-height:65vh;overflow-y:auto;
}
.modal-body::-webkit-scrollbar{width:8px}
.modal-body::-webkit-scrollbar-track{background:transparent}
.modal-body::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:4px}
.modal-body::-webkit-scrollbar-thumb:hover{background:var(--ink-dim)}

.fld{
  display:grid;grid-template-columns:180px 1fr;gap:18px;align-items:center;
  padding:10px 0;
  border-bottom:1px dashed var(--line);
}
.fld:last-of-type{border-bottom:0}
.fld label{
  font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-soft);font-weight:500;
}
.fld .hint{
  display:block;font-family:"Geist",sans-serif;text-transform:none;letter-spacing:0;
  font-size:11.5px;color:var(--ink-dim);margin-top:3px;font-weight:400;
}
.fld-kbd{
  position:absolute;right:14px;top:50%;transform:translateY(-50%);
  font-family:"JetBrains Mono",monospace;font-size:9.5px;letter-spacing:.08em;
  padding:2px 5px;background:var(--bg-2);border:1px solid var(--line);
  border-radius:4px;color:var(--ink-dim);pointer-events:none;
}

.inp-wrap{position:relative}
.inp,.sel{
  width:100%;padding:11px 42px 11px 14px;
  background:var(--bg-2);
  border:1px solid var(--line);
  border-radius:10px;
  color:var(--ink);font:inherit;font-size:14px;
  outline:0;transition:border-color .15s, background .15s, box-shadow .15s;
}
.inp::placeholder{color:var(--ink-dim)}
.inp:focus,.sel:focus{
  border-color:var(--accent);background:var(--surface-2);
  box-shadow:0 0 0 3px rgba(212,255,62,.12);
}
.sel{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23b9b2a1' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:40px;cursor:pointer;
}
.inp:not(:focus):not(:placeholder-shown) + .fld-kbd,
.inp:focus + .fld-kbd{opacity:0}

.adv-toggle{
  margin:18px 0 8px;
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 14px;border-radius:999px;
  background:rgba(255,92,41,.09);border:1px solid rgba(255,92,41,.3);
  color:var(--accent-2);
  font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.15em;text-transform:uppercase;font-weight:600;
  cursor:pointer;transition:background .15s;
}
.adv-toggle:hover{background:rgba(255,92,41,.15)}
.adv-toggle svg{width:12px;height:12px;transition:transform .2s}
.adv-toggle.open svg{transform:rotate(90deg)}

.adv-pane{
  display:none;padding-top:6px;
}
.adv-pane.open{display:block}

/* Custom checkbox */
.chk{
  display:inline-flex;align-items:center;gap:10px;cursor:pointer;
  padding:6px 0;font-size:13.5px;color:var(--ink-soft);
}
.chk input{display:none}
.chk .box{
  width:18px;height:18px;border-radius:5px;
  background:var(--bg-2);border:1px solid var(--line-strong);
  display:grid;place-items:center;flex-shrink:0;
  transition:background .15s, border-color .15s;
}
.chk input:checked + .box{background:var(--accent);border-color:var(--accent)}
.chk .box svg{width:12px;height:12px;color:#0b0b0a;opacity:0;transition:opacity .15s}
.chk input:checked + .box svg{opacity:1}

/* Radio group */
.radio-group{
  display:flex;gap:4px;background:var(--bg-2);border:1px solid var(--line);
  border-radius:10px;padding:3px;width:fit-content;flex-wrap:wrap;
}
.radio-group label{
  cursor:pointer;display:block;
}
.radio-group input{display:none}
.radio-group span{
  display:block;padding:7px 14px;border-radius:7px;
  font-size:13px;color:var(--ink-soft);
  font-family:"Geist",sans-serif;font-weight:500;
  transition:background .15s, color .15s;
}
.radio-group label:hover span{color:var(--ink);background:var(--surface)}
.radio-group input:checked + span{background:var(--accent);color:#0b0b0a;font-weight:600}

/* Keyboard shortcuts */
.kbd-sec{
  margin-top:18px;padding:16px;
  background:var(--bg-2);border:1px solid var(--line);border-radius:10px;
}
.kbd-sec h5{
  font-family:"JetBrains Mono",monospace;font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-dim);margin:0 0 12px;font-weight:600;
  display:flex;align-items:center;gap:8px;
}
.kbd-sec h5::before{content:"⌘";color:var(--accent);font-size:13px}
.kbd-list{display:flex;flex-direction:column;gap:8px}
.kbd-row{display:flex;align-items:center;gap:14px;font-size:13px;color:var(--ink-soft)}
.kbd-keys{display:flex;gap:4px;min-width:130px}
.kbd-keys kbd{
  font-family:"JetBrains Mono",monospace;font-size:10.5px;font-weight:700;
  padding:3px 8px;background:var(--surface);border:1px solid var(--line-strong);
  border-radius:5px;color:var(--ink);letter-spacing:.05em;
  box-shadow:inset 0 -1px 0 rgba(0,0,0,.4);
}

.modal-foot{
  padding:18px 30px;border-top:1px solid var(--line);
  background:var(--bg-2);
  display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;
}
.foot-info{
  font-family:"JetBrains Mono",monospace;font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-dim);
}
.foot-info b{color:var(--accent)}
.foot-actions{display:flex;gap:10px}

.btn-search{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 22px;border-radius:999px;
  background:var(--accent);color:#0b0b0a;font-weight:700;
  font-size:13.5px;border:0;cursor:pointer;
  transition:background .15s, transform .1s;
}
.btn-search:hover{background:#c3f029}
.btn-search:active{transform:translateY(1px)}
.btn-search svg{width:15px;height:15px}

.btn-reset{
  padding:11px 20px;border-radius:999px;
  background:transparent;border:1px solid var(--line-strong);color:var(--ink-soft);
  font-size:13.5px;cursor:pointer;
  transition:border-color .15s, color .15s;
}
.btn-reset:hover{border-color:var(--ink-dim);color:var(--ink)}

@media (max-width:640px){
  .modal-head{padding:22px 20px 18px;flex-wrap:wrap}
  .modal-head h2{font-size:26px}
  .modal-notice{margin:14px 20px 0}
  .modal-body{padding:18px 20px 6px}
  .fld{grid-template-columns:1fr;gap:6px;align-items:flex-start}
  .modal-foot{padding:16px 20px}
  .kbd-row{flex-wrap:wrap}
}


/* ── Auth modal (Sign In / Register) ── */
/* ---------- AUTH MODAL (Sign In / Register) ---------- */
.auth-backdrop{
  position:fixed;inset:0;z-index:100;
  background:rgba(6,6,5,.72);
  backdrop-filter:blur(8px);
  display:none;align-items:center;justify-content:center;
  padding:40px 20px;overflow-y:auto;
  opacity:0;transition:opacity .2s;
}
.auth-backdrop.open{display:flex;opacity:1}

.auth-modal{
  background:var(--surface);
  border:1px solid var(--line-strong);
  border-radius:var(--radius-lg);
  width:100%;max-width:460px;
  position:relative;
  box-shadow:0 40px 80px -20px rgba(0,0,0,.8);
  transform:translateY(12px) scale(.98);
  transition:transform .25s cubic-bezier(.2,.9,.3,1);
  overflow:hidden;
}
.auth-backdrop.open .auth-modal{transform:translateY(0) scale(1)}

.auth-head{
  padding:26px 30px 0;
  display:flex;align-items:flex-start;justify-content:space-between;gap:16px;
}
.auth-head .eyebrow-mono{
  font-family:"JetBrains Mono",monospace;font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-dim);margin-bottom:10px;display:block;
}
.auth-head h2{
  font-family:"Fraunces",serif;font-weight:400;font-size:32px;letter-spacing:-0.02em;margin:0;line-height:1;
}
.auth-head h2 em{font-style:italic;color:var(--accent);font-weight:300}
.auth-head p{
  margin:12px 0 0;color:var(--ink-soft);font-size:13.5px;line-height:1.5;max-width:340px;
}
.auth-close{
  width:32px;height:32px;border-radius:8px;
  display:grid;place-items:center;
  background:var(--bg-2);border:1px solid var(--line);color:var(--ink-soft);
  transition:background .15s, color .15s, border-color .15s;
  flex-shrink:0;cursor:pointer;
}
.auth-close:hover{background:var(--surface-2);color:var(--accent);border-color:var(--accent)}
.auth-close svg{width:14px;height:14px}

.auth-tabs{
  display:flex;gap:4px;margin:22px 30px 0;padding:4px;
  background:var(--bg-2);border:1px solid var(--line);border-radius:10px;
}
.auth-tab{
  flex:1;padding:9px 14px;border-radius:7px;
  font-family:"Geist",sans-serif;font-size:13px;font-weight:500;
  color:var(--ink-soft);cursor:pointer;transition:background .15s, color .15s;
  border:0;background:transparent;
}
.auth-tab:hover{color:var(--ink)}
.auth-tab.active{background:var(--accent);color:#0b0b0a;font-weight:600}

.auth-pane{display:none;padding:0}
.auth-pane.active{display:block}

.auth-body{padding:22px 30px 6px}

.auth-field{margin-bottom:13px}
.auth-field label{
  display:block;
  font-family:"JetBrains Mono",monospace;font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-soft);font-weight:500;margin-bottom:6px;
}
.auth-field .inp-wrap{position:relative}
.auth-inp{
  width:100%;padding:11px 14px;
  background:var(--bg-2);border:1px solid var(--line);border-radius:10px;
  color:var(--ink);font:inherit;font-size:14px;outline:0;
  transition:border-color .15s, background .15s, box-shadow .15s;
}
.auth-inp::placeholder{color:var(--ink-dim)}
.auth-inp:focus{
  border-color:var(--accent);background:var(--surface-2);
  box-shadow:0 0 0 3px rgba(212,255,62,.12);
}
.auth-inp.has-icon{padding-right:44px}

.pw-toggle{
  position:absolute;right:8px;top:50%;transform:translateY(-50%);
  width:30px;height:30px;border-radius:6px;
  display:grid;place-items:center;color:var(--ink-dim);cursor:pointer;
  background:transparent;border:0;
  transition:color .15s, background .15s;
}
.pw-toggle:hover{color:var(--ink);background:var(--surface-2)}
.pw-toggle svg{width:15px;height:15px}

.auth-row{
  display:flex;justify-content:space-between;align-items:center;
  margin:14px 0 18px;font-size:13px;gap:10px;flex-wrap:wrap;
}
.auth-row a{color:var(--accent)}
.auth-row a:hover{text-decoration:underline}

.auth-remember,.auth-terms{
  display:inline-flex;align-items:flex-start;gap:9px;cursor:pointer;
  color:var(--ink-soft);line-height:1.5;
}
.auth-remember{align-items:center;font-size:13px}
.auth-terms{font-size:12.5px;margin:2px 0 18px}
.auth-remember input,.auth-terms input{display:none}
.auth-remember .box,.auth-terms .box{
  width:17px;height:17px;border-radius:5px;flex-shrink:0;
  background:var(--bg-2);border:1px solid var(--line-strong);
  display:grid;place-items:center;transition:background .15s, border-color .15s;
}
.auth-terms .box{margin-top:1px}
.auth-remember input:checked + .box,.auth-terms input:checked + .box{background:var(--accent);border-color:var(--accent)}
.auth-remember .box svg,.auth-terms .box svg{width:11px;height:11px;color:#0b0b0a;opacity:0;transition:opacity .15s}
.auth-remember input:checked + .box svg,.auth-terms input:checked + .box svg{opacity:1}
.auth-terms a{color:var(--accent);text-decoration:underline}

.auth-submit{
  width:100%;padding:13px;border-radius:10px;
  background:var(--accent);color:#0b0b0a;
  font-family:inherit;font-weight:700;font-size:14px;border:0;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  transition:background .15s, transform .1s;
}
.auth-submit:hover{background:#c3f029}
.auth-submit:active{transform:translateY(1px)}
.auth-submit svg{width:15px;height:15px}

.auth-foot{
  padding:18px 30px;border-top:1px solid var(--line);background:var(--bg-2);
  text-align:center;font-size:13px;color:var(--ink-soft);
  margin-top:20px;
}
.auth-foot a{color:var(--accent);font-weight:500}
.auth-foot a:hover{text-decoration:underline}

@media (max-width:500px){
  .auth-head{padding:22px 20px 0}
  .auth-body{padding:20px 20px 4px}
  .auth-tabs{margin:20px 20px 0}
  .auth-foot{padding:16px 20px}
}


/* ── Captcha widget ── */
/* ---------- CAPTCHA (Turnstile-style demo widget) ---------- */
.captcha{
  display:flex;align-items:center;gap:14px;
  padding:14px 16px;margin:4px 0 16px;
  background:var(--bg-2);
  border:1px solid var(--line);
  border-radius:10px;
  transition:border-color .2s, background .2s;
  position:relative;overflow:hidden;
}
.captcha.verified{border-color:rgba(212,255,62,.35);background:rgba(212,255,62,.04)}
.captcha.error{border-color:rgba(255,92,41,.4);background:rgba(255,92,41,.04);animation:captcha-shake .4s ease}
@keyframes captcha-shake{
  0%,100%{transform:translateX(0)}
  25%{transform:translateX(-4px)}
  75%{transform:translateX(4px)}
}

.captcha-check{
  width:26px;height:26px;border-radius:6px;flex-shrink:0;
  background:var(--surface);border:2px solid var(--line-strong);
  display:grid;place-items:center;cursor:pointer;
  transition:border-color .2s, background .2s;
  position:relative;
}
.captcha-check:hover{border-color:var(--ink-dim)}
.captcha-check input{
  position:absolute;opacity:0;width:100%;height:100%;cursor:pointer;margin:0;
}
.captcha-check .mark{
  width:16px;height:16px;color:#0b0b0a;opacity:0;transform:scale(.4);
  transition:opacity .2s, transform .2s;
}
.captcha.verified .captcha-check{background:var(--accent);border-color:var(--accent)}
.captcha.verified .captcha-check .mark{opacity:1;transform:scale(1)}

/* Loading spinner */
.captcha-spinner{
  position:absolute;inset:-2px;border-radius:6px;
  border:2px solid transparent;
  border-top-color:var(--accent);border-right-color:var(--accent);
  opacity:0;animation:captcha-spin .7s linear infinite;
  pointer-events:none;
}
.captcha.loading .captcha-spinner{opacity:1}
.captcha.loading .captcha-check .mark{opacity:0}
@keyframes captcha-spin{
  to{transform:rotate(360deg)}
}

.captcha-label{
  flex:1;font-size:13.5px;color:var(--ink);line-height:1.3;font-weight:500;
}
.captcha-label .sub{
  display:block;font-size:11px;color:var(--ink-dim);margin-top:3px;
  font-family:"JetBrains Mono",monospace;letter-spacing:.1em;
}
.captcha.verified .captcha-label .sub{color:var(--accent)}
.captcha.error .captcha-label .sub{color:var(--accent-2)}

.captcha-brand{
  display:flex;flex-direction:column;align-items:flex-end;gap:2px;
  flex-shrink:0;opacity:.7;
}
.captcha-brand .logo{
  font-family:"Fraunces",serif;font-weight:600;font-size:13px;
  font-style:italic;letter-spacing:-0.01em;color:var(--ink-soft);
  display:flex;align-items:center;gap:4px;
}
.captcha-brand .logo svg{width:14px;height:14px;color:var(--accent)}
.captcha-brand .links{
  font-family:"JetBrains Mono",monospace;font-size:9px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--ink-dim);display:flex;gap:6px;
}
.captcha-brand .links a{color:var(--ink-dim)}
.captcha-brand .links a:hover{color:var(--accent)}


/* ── Share modal ── */
/* ═══ SHARE MODAL ═══ */
#shareModal{display:none;position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.75);backdrop-filter:blur(8px);align-items:center;justify-content:center;padding:20px}
#shareModal.open{display:flex}
.share-modal{
  width:100%;max-width:520px;max-height:90vh;
  background:var(--surface);border:1px solid var(--line-strong);border-radius:14px;
  display:flex;flex-direction:column;overflow:hidden;
  box-shadow:0 30px 80px -20px rgba(0,0,0,.9);
}
.share-body{padding:20px 22px;display:flex;flex-direction:column;gap:16px;overflow-y:auto}
.share-preview{
  display:flex;gap:12px;padding:10px;border:1px solid var(--line);border-radius:8px;background:var(--bg-2);
  font-size:13px;color:var(--ink-soft);line-height:1.4;
}
.share-preview b{color:var(--ink);display:block;margin-bottom:3px}
.share-options{
  display:grid;grid-template-columns:repeat(3,1fr);gap:8px;
}
.share-opt{
  display:flex;flex-direction:column;align-items:center;gap:8px;
  padding:14px 10px;border-radius:10px;
  background:var(--bg-2);border:1px solid var(--line);color:var(--ink-soft);
  font-family:inherit;font-size:12px;cursor:pointer;
  transition:all .15s;
}
.share-opt:hover{
  background:var(--surface);border-color:var(--c);color:var(--c);transform:translateY(-2px);
}
.share-opt svg{width:22px;height:22px;color:var(--c)}
.share-opt span{font-weight:500}
.share-url-wrap{
  margin-top:4px;
}
.share-url-wrap .inp{font-size:12px;font-family:"JetBrains Mono",monospace;color:var(--ink-dim)}
@media (max-width:480px){.share-options{grid-template-columns:repeat(2,1fr)}}


/* ── Report modal ── */
/* ═══ REPORT MODAL ═══ */
#reportModal{display:none;position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.75);backdrop-filter:blur(8px);align-items:center;justify-content:center;padding:20px}
#reportModal.open{display:flex}
.report-reasons{
  display:flex;flex-direction:column;gap:6px;
}
.report-reason{
  display:flex;align-items:flex-start;gap:10px;
  padding:12px 14px;border-radius:8px;
  background:var(--bg-2);border:1px solid var(--line);
  cursor:pointer;transition:border-color .12s, background .12s;
}
.report-reason:hover{border-color:var(--line-strong);background:var(--surface)}
.report-reason:has(input:checked){border-color:var(--accent-2);background:rgba(255,92,41,.05)}
.report-reason input[type="radio"]{margin-top:3px;flex-shrink:0;accent-color:var(--accent-2)}
.report-reason div{flex:1;min-width:0}
.report-reason b{display:block;color:var(--ink);font-size:13px;font-weight:600;margin-bottom:2px}
.report-reason span{display:block;color:var(--ink-dim);font-size:11.5px;line-height:1.45}
.detail-tags{display:flex;flex-wrap:wrap;gap:7px}
.detail-tags .dt{
  font-family:"JetBrains Mono",monospace;font-size:11.5px;letter-spacing:.04em;
  padding:6px 14px;border-radius:999px;
  background:rgba(212,255,62,.08);color:var(--accent);border:1px solid rgba(212,255,62,.3);
  cursor:pointer;transition:all .12s;font-weight:500;
}
.detail-tags .dt:hover{background:var(--accent);color:#0b0b0a;border-color:var(--accent);transform:translateY(-1px)}

/* Rating block */
.detail-rating-block{
  padding:22px 24px;margin-bottom:30px;border-radius:12px;
  background:var(--surface);border:1px solid var(--line);
}
.drb-top{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:center}
@media (max-width:560px){.drb-top{grid-template-columns:1fr;gap:20px}}
.drb-score{text-align:center;padding-right:20px;border-right:1px solid var(--line)}
@media (max-width:560px){.drb-score{border-right:0;border-bottom:1px solid var(--line);padding:0 0 16px}}
.drb-big{
  font-family:"Fraunces",serif;font-weight:400;font-size:56px;line-height:1;color:var(--accent);
  display:block;margin-bottom:8px;
}
.drb-stars{display:flex;justify-content:center;gap:3px;margin-bottom:6px;color:var(--accent)}
.drb-stars svg{width:18px;height:18px}
.drb-count{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--ink-dim);letter-spacing:.08em}
.drb-count b{color:var(--ink);font-weight:700}
.drb-vote h4{margin:0 0 6px}
.drb-vote p{margin:0 0 12px;font-size:12px;color:var(--ink-dim)}
.drb-interactive{display:flex;gap:4px;color:var(--ink-dim)}
.drb-interactive svg{width:28px;height:28px;cursor:pointer;transition:color .15s, transform .1s}
.drb-interactive svg:hover{color:var(--accent);transform:scale(1.15)}
.drb-interactive svg.filled{color:var(--accent)}

/* Comments */
.detail-comments h3{font-family:"Fraunces",serif;font-weight:500;font-size:22px;text-transform:none;letter-spacing:-0.01em;color:var(--ink)}
.detail-comments h3 em{color:var(--ink-dim);font-style:normal;font-weight:400;font-size:16px}
.dc-new{
  display:flex;flex-direction:column;gap:10px;margin-bottom:22px;
  padding:14px;border-radius:10px;background:var(--surface);border:1px solid var(--line);
}
.dc-new textarea{resize:vertical;min-height:72px}
.dc-new .btn{align-self:flex-start}
.dc-list{display:flex;flex-direction:column;gap:14px}
.dc-item{
  padding:14px 16px;border-radius:10px;background:var(--surface);border:1px solid var(--line);
}
.dc-item-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;flex-wrap:wrap;gap:8px}
.dc-author{display:inline-flex;align-items:center;gap:8px;font-size:12.5px;color:var(--ink);font-weight:600}
.dc-author .dc-avatar{
  width:26px;height:26px;border-radius:50%;
  background:linear-gradient(135deg,var(--accent),#99c930);
  display:grid;place-items:center;
  font-family:"Fraunces",serif;font-size:11px;font-weight:700;color:#0b0b0a;
  font-style:italic;
}
.dc-time{font-family:"JetBrains Mono",monospace;font-size:10.5px;color:var(--ink-dim);letter-spacing:.06em;text-transform:uppercase}
.dc-text{margin:0;font-size:13.5px;line-height:1.55;color:var(--ink-soft)}

/* Comment actions (reply button, like, etc.) */
.dc-actions{
  display:flex;gap:14px;margin-top:10px;padding-top:10px;
  border-top:1px dashed var(--line);
}
.dc-action-btn{
  display:inline-flex;align-items:center;gap:6px;
  background:transparent;border:0;padding:2px 0;
  font-family:inherit;font-size:11.5px;color:var(--ink-dim);
  cursor:pointer;transition:color .12s;
}
.dc-action-btn:hover{color:var(--accent)}
.dc-action-btn svg{width:13px;height:13px}
.dc-action-btn.liked{color:var(--accent-2)}
.dc-action-btn.liked svg{fill:var(--accent-2)}
.dc-like-count{
  display:inline-grid;place-items:center;
  min-width:18px;height:16px;padding:0 4px;margin-left:3px;border-radius:8px;
  background:var(--bg-2);color:var(--ink-dim);
  font-family:"JetBrains Mono",monospace;font-size:10px;font-weight:700;
}
.dc-action-btn.liked .dc-like-count{background:rgba(255,92,41,.15);color:#ff8c65}

/* Replies container (nested) */
.dc-replies{
  display:flex;flex-direction:column;gap:10px;
  margin-top:12px;padding-left:18px;
  border-left:2px solid var(--line);
}
.dc-replies .dc-item{
  padding:12px 14px;background:var(--bg-2);border-color:var(--line);
}
.dc-replies .dc-author .dc-avatar{
  width:22px;height:22px;font-size:10px;
  background:linear-gradient(135deg,#a594f7,#c1b5fa); /* different color for replies */
}
.dc-replies .dc-text{font-size:12.5px}

/* Reply input (inline) */
.dc-reply-form{
  display:none;margin-top:10px;padding-top:10px;
  border-top:1px dashed var(--line);
  flex-direction:column;gap:8px;
}
.dc-reply-form.open{display:flex}
.dc-reply-form textarea{
  font-size:12.5px;min-height:60px;resize:vertical;
}
.dc-reply-form-actions{
  display:flex;gap:8px;justify-content:flex-end;
}
.dc-reply-form .btn{padding:6px 12px;font-size:11.5px}

/* Sidebar */
.detail-side{
  display:flex;flex-direction:column;gap:16px;min-width:0;
  position:sticky;top:80px;align-self:start;
}
@media (max-width:960px){.detail-side{position:static;order:-1}}
.ds-card{
  padding:18px 20px;border-radius:12px;
  background:var(--surface);border:1px solid var(--line);
}
.ds-card-title{
  font-family:"JetBrains Mono",monospace;font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-soft);font-weight:600;margin:0 0 14px;
}
.ds-author{display:flex;align-items:center;gap:12px}
.ds-avatar{
  width:44px;height:44px;border-radius:50%;
  background:linear-gradient(135deg,#00d4ff,#0099cc);
  display:grid;place-items:center;
  font-family:"Fraunces",serif;font-size:18px;font-weight:600;color:#0b0b0a;
  font-style:italic;flex-shrink:0;
}
.ds-author-info{min-width:0}
.ds-author-name{font-size:14px;color:var(--ink);font-weight:600;text-decoration:none;display:block;margin-bottom:2px}
.ds-author-name:hover{color:var(--accent)}
.ds-author-role{
  font-family:"JetBrains Mono",monospace;font-size:10px;
  letter-spacing:.1em;text-transform:uppercase;font-weight:600;
  display:inline-flex;align-items:center;gap:4px;
  padding:2px 7px;border-radius:4px;
}
.ds-author-role.role-admin{background:rgba(255,92,41,.15);color:#ff8c65}
.ds-author-role.role-chief{background:rgba(165,148,247,.15);color:#c1b5fa}
.ds-author-role.role-editor{background:rgba(0,212,255,.15);color:#8be7ff}
.ds-author-role.role-member{background:var(--bg-2);color:var(--ink-soft)}
.ds-action{
  display:flex;align-items:center;gap:10px;width:100%;
  padding:10px 12px;border-radius:7px;
  background:transparent;border:1px solid var(--line);color:var(--ink-soft);
  cursor:pointer;font-family:inherit;font-size:12.5px;text-align:left;
  transition:all .12s;margin-bottom:6px;
}
.ds-action:last-child{margin-bottom:0}
.ds-action:hover{border-color:var(--line-strong);color:var(--ink);background:var(--surface-2)}
.ds-action.active{color:var(--accent-2);border-color:var(--accent-2);background:rgba(255,92,41,.06)}
.ds-action.active svg{fill:var(--accent-2);stroke:var(--accent-2)}
.ds-action svg{width:14px;height:14px;flex-shrink:0}

/* Similar posts */
.ds-similar{display:flex;flex-direction:column;gap:10px}
.ds-similar .dss-item{
  display:flex;gap:10px;padding:8px;border-radius:7px;cursor:pointer;
  transition:background .12s;text-decoration:none;color:inherit;
}
.ds-similar .dss-item:hover{background:var(--bg-2)}
.ds-similar .dss-thumb{
  width:60px;height:45px;border-radius:5px;flex-shrink:0;
  background-size:cover;background-position:center;background-color:var(--bg-2);
}
.ds-similar .dss-title{
  font-size:12px;line-height:1.35;color:var(--ink);font-weight:500;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;
  overflow:hidden;text-overflow:ellipsis;
}
.ds-similar .dss-meta{
  font-family:"JetBrains Mono",monospace;font-size:9.5px;color:var(--ink-dim);
  margin-top:3px;letter-spacing:.06em;
}

