﻿/*
  Future extraction target for admin mode controls, floating admin panel, modals,
  sortable lists, catalog order tools, and editor-specific form layouts.
*/

/* ===== Admin toggle + panel ===== */
    .admin-toggle{
      position: static;
      right: auto;
      top: auto;
      padding: 13px 22px;
      border-radius: 999px;
      cursor:pointer;
      font-size: 13px;
      font-weight:900;
      text-transform:uppercase;
      letter-spacing:.55px;
      z-index: 1;
      display:none;
      white-space:nowrap;
    }

    .admin-float-toggle{
      position: fixed;
      left: 18px;
      top: 50%;
      transform: translateY(-50%);
      z-index: 10005;
      display: none;
      align-items: center;
      gap: 9px;
      min-height: 46px;
      padding: 8px 14px 8px 9px;
      border-radius: 999px;
      border: 1px solid rgba(255,255,255,.13);
      background: rgba(7,9,12,.72);
      color: rgba(244,246,248,.86);
      backdrop-filter: blur(16px);
      box-shadow: 0 14px 46px rgba(0,0,0,.44), inset 0 1px 0 rgba(255,255,255,.10);
      cursor: pointer;
      font-size: 11px;
      font-weight: 900;
      letter-spacing: .7px;
      text-transform: uppercase;
      white-space: nowrap;
      transition: border-color .18s ease, background .18s ease, color .18s ease, transform .18s ease;
    }
    .admin-float-toggle::before{
      content: "A";
      display: grid;
      place-items: center;
      width: 30px;
      height: 30px;
      border-radius: 50%;
      background: rgba(255,255,255,.08);
      color: rgba(244,246,248,.94);
      box-shadow: inset 0 1px 0 rgba(255,255,255,.10);
      font-size: 12px;
      letter-spacing: 0;
    }
    .admin-float-toggle:hover{
      background: rgba(12,15,20,.86);
      border-color: rgba(255,255,255,.22);
      color: #fff;
      transform: translateY(-50%) translateX(2px);
    }
    .admin-float-toggle.active{
      background: rgba(var(--accent-rgb),.18);
      border-color: rgba(var(--accent-rgb),.38);
      color: #fff;
    }
    .admin-float-toggle.active::before{
      background: var(--accent);
      color: #071017;
    }

    .admin-panel{
      position: fixed;
      right: 20px;
      top: 120px;
      width: 320px;
      max-height: calc(100vh - 150px);
      overflow:auto;
      border-radius: var(--radius-xl);
      border: 1px solid rgba(255,255,255,.10);
      background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
      backdrop-filter: blur(16px);
      box-shadow: 0 22px 90px rgba(0,0,0,.65);
      padding: 12px;
      z-index: 10015;
      display:none;
      transform: translateX(var(--admin-x, 0px));
      transition: transform .22s ease;
    }
    .admin-panel-bar{
      position: sticky;
      top: 0;
      z-index: 2;
      display:flex; align-items:center; justify-content:space-between; gap:8px;
      margin: -12px -12px 8px;
      padding: 8px 10px;
      background: rgba(20,20,22,.92);
      border-bottom: 1px solid rgba(255,255,255,.08);
      border-radius: var(--radius-xl) var(--radius-xl) 0 0;
    }
    .admin-panel-bar-title{
      font-size: 11px; letter-spacing: 1.2px; text-transform: uppercase;
      font-weight: 800; color: rgba(244,246,248,.8);
    }
    .admin-panel-move{
      width: 32px; height: 27px; border-radius: 7px; cursor: pointer;
      border: 1px solid rgba(255,255,255,.16); background: rgba(255,255,255,.07);
      color: #f4f6f8; font-size: 11px;
      display:flex; align-items:center; justify-content:center;
      transition: background .15s ease;
    }
    .admin-panel-move:hover{ background: rgba(255,225,26,.2); }
    .admin-panel-move:active{ background: var(--bundle-yellow); color:#1a1500; }
    .admin-panel h3{
      font-size: 11px;
      letter-spacing: 1.2px;
      text-transform: uppercase;
      color: rgba(244,246,248,.75);
      margin: 4px 6px 10px;
    }
    .admin-section{
      border:1px solid rgba(255,255,255,.10);
      border-radius: 12px;
      background:rgba(0,0,0,.12);
      margin: 8px 0;
      overflow:hidden;
    }
    .admin-section-title{
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:10px;
      padding: 11px 12px;
      cursor:pointer;
      user-select:none;
      list-style:none;
      font-size: 11px;
      letter-spacing: 1.15px;
      text-transform: uppercase;
      font-weight:900;
      color: rgba(244,246,248,.80);
      background:rgba(255,255,255,.035);
    }
    .admin-section-title::-webkit-details-marker{ display:none; }
    .admin-section-title:hover{
      background:rgba(255,255,255,.055);
      color:#fff;
    }
    .admin-section-chevron{
      width:8px;
      height:8px;
      border-right:2px solid currentColor;
      border-bottom:2px solid currentColor;
      opacity:.68;
      transform:rotate(45deg);
      transition:transform .16s ease;
      flex:0 0 auto;
    }
    .admin-section[open] .admin-section-chevron{
      transform:rotate(225deg) translate(-2px, -2px);
    }
    .admin-section-body{
      padding: 4px 12px 12px;
    }
    .admin-section-body > div[style*="border-top"]{
      display:none;
    }

    .field{ display:flex; flex-direction:column; gap:6px; margin: 10px 0; }
    .field label{ font-size: 12px; color: rgba(244,246,248,.70); }
    input[type="text"], input[type="url"], textarea, select{
      width: 100%;
      border-radius: 14px;
      border: 1px solid rgba(255,255,255,.10);
      background: rgba(0,0,0,.26);
      padding: 10px 12px;
      color: rgba(244,246,248,.90);
      outline:none;
      font-size: 13px;
    }
    textarea{ min-height: 120px; resize: vertical; }
    input[type="checkbox"]{ accent-color: var(--accent); }
    .rowbtns{ display:flex; gap:8px; flex-wrap:wrap; }
    .hero-admin-controls{
      display:flex;
      flex-direction:column;
      gap:12px;
    }
    .hero-admin-group{
      border:1px solid rgba(255,255,255,.10);
      border-radius:16px;
      padding:10px;
      background:rgba(0,0,0,.16);
    }
    .hero-admin-group h4{
      margin:0 0 8px;
      color:rgba(244,246,248,.78);
      font-size:11px;
      letter-spacing:1px;
      text-transform:uppercase;
    }
    .hero-admin-grid{
      display:grid;
      grid-template-columns:repeat(2, minmax(0, 1fr));
      gap:8px;
    }
    .hero-admin-grid .field{ margin:0; }
    .hero-admin-feature,
    .hero-admin-button{
      border-top:1px solid rgba(255,255,255,.10);
      margin-top:10px;
      padding-top:10px;
    }
    .hero-admin-controls small{
      display:block;
      color:rgba(244,246,248,.52);
      font-size:11px;
      line-height:1.35;
      margin-top:5px;
    }
    .tech-admin{
      margin:14px 0;
      border:1px solid rgba(255,255,255,.10);
      border-radius:14px;
      background:rgba(255,255,255,.025);
      padding:12px;
    }
    .tech-admin-title{
      margin:0 0 10px;
      color:rgba(244,246,248,.86);
      font-size:12px;
      font-weight:950;
      letter-spacing:1.3px;
      text-transform:uppercase;
    }
    .tech-admin-section{
      border-top:1px solid rgba(255,255,255,.08);
      padding-top:10px;
      margin-top:10px;
    }
    .tech-admin-section:first-of-type{
      border-top:0;
      padding-top:0;
      margin-top:0;
    }
    .tech-admin-section b{
      display:block;
      margin-bottom:8px;
      color:rgba(244,246,248,.72);
      font-size:11px;
      letter-spacing:1px;
      text-transform:uppercase;
    }
    .tech-admin-compat{
      display:grid;
      gap:7px;
    }
    .tech-admin-compat-row{
      display:grid;
      grid-template-columns:24px minmax(120px,1.2fr) minmax(72px,.7fr) minmax(42px,.35fr);
      gap:6px;
      align-items:center;
    }
    .tech-admin-compat-row input{
      min-width:0;
      border-radius:10px;
      padding:8px 9px;
      font-size:12px;
    }
    .tech-admin-checks{
      display:grid;
      grid-template-columns:repeat(2, minmax(0,1fr));
      gap:8px;
    }
    .tech-admin-check{
      display:flex;
      gap:8px;
      align-items:center;
      min-width:0;
      color:rgba(244,246,248,.78);
      font-size:12px;
      font-weight:800;
    }
    .tech-admin-format-row{
      display:grid;
      grid-template-columns:minmax(96px, 1fr) minmax(78px, .85fr);
      gap:8px;
      align-items:center;
    }
    .tech-admin-format-row .tech-admin-check{
      min-height:34px;
    }
    .tech-admin-format-row input[type="text"]{
      border-radius:10px;
      padding:8px 9px;
      font-size:12px;
    }
    .tech-admin-poly{
      display:grid;
      grid-template-columns:1fr 1fr;
      gap:8px;
    }

/* ===== Modal (admin) ===== */
    .modal-backdrop{
      position:fixed; inset:0;
      background: rgba(0,0,0,.65);
      backdrop-filter: blur(12px);
      display:none;
      align-items:center;
      justify-content:center;
      z-index: 10060;
      padding: 18px;
    }
    .modal-backdrop.open{ display:flex; }
    .modal{
      width: min(980px, 96vw);
      max-height: calc(100vh - 36px);
      border-radius: var(--radius-xl);
      border:1px solid rgba(255,255,255,.12);
      background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.04));
      box-shadow: 0 30px 120px rgba(0,0,0,.65);
      overflow:hidden;
      display:flex;
      flex-direction:column;
    }
    .modal.line-editor-modal{
      width: min(1360px, 96vw);
    }
    .field textarea.tall{ min-height: 120px; font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; font-size:12px; }
    .modal header{
      padding: 14px 16px;
      display:flex;
      align-items:center;
      justify-content:space-between;
      border-bottom:1px solid rgba(255,255,255,.10);
    }
    .modal header b{
      font-size: 13px;
      letter-spacing: 1px;
      text-transform: uppercase;
      color: rgba(244,246,248,.86);
    }
    .modal .content{
      padding: 16px;
      display:grid;
      grid-template-columns: 1.1fr .9fr;
      gap: 14px;
      overflow:auto;
      min-height:0;
      flex:1 1 auto;
    }
    .modal .content.single{ grid-template-columns: 1fr; }
    .modal .content.line-editor-content{
      grid-template-columns: minmax(300px, 420px) minmax(0, 1fr);
      align-content:start;
      align-items:start;
    }
    .line-settings-editor{
      display:grid;
      grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
      gap: 12px 14px;
      align-items:end;
      min-width:0;
    }
    .line-settings-editor .field{
      margin:0;
      min-width:0;
    }
    .line-pack-editor{
      grid-column:1 / -1;
      border-top:1px solid rgba(255,255,255,.10);
      margin-top:4px;
      padding-top:14px;
      display:grid;
      grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
      gap:12px 14px;
      min-width:0;
    }
    .line-pack-editor .tech-admin,
    .line-pack-editor .line-pack-wide{
      grid-column:1 / -1;
    }
    .line-pack-preview{
      border-radius:12px;
      border:1px solid rgba(255,255,255,.10);
      background:rgba(0,0,0,.24);
      aspect-ratio:16/9;
      overflow:hidden;
    }
    .line-pack-preview img{
      width:100%;
      height:100%;
      display:block;
      object-fit:cover;
    }
    .line-pack-editor-compact{
      align-items:end;
    }
    .line-pack-summary{
      display:grid;
      grid-template-columns: 86px minmax(0, 1fr) auto;
      gap:12px;
      align-items:center;
      padding:10px;
      border-radius:14px;
      border:1px solid rgba(255,255,255,.10);
      background:rgba(255,255,255,.035);
    }
    .line-pack-summary-thumb{
      aspect-ratio:1/1;
      border-radius:10px;
      overflow:hidden;
      border:1px solid rgba(255,255,255,.10);
      background:rgba(0,0,0,.25);
    }
    .line-pack-summary-thumb img{
      width:100%;
      height:100%;
      display:block;
      object-fit:cover;
    }
    .line-pack-summary-copy{
      min-width:0;
      display:flex;
      flex-direction:column;
      gap:4px;
    }
    .line-pack-summary-copy b{
      color:#fff;
      font-size:13px;
      font-weight:950;
      white-space:nowrap;
      overflow:hidden;
      text-overflow:ellipsis;
    }
    .line-pack-summary-copy span{
      color:rgba(244,246,248,.62);
      font-size:12px;
      line-height:1.35;
    }
    .line-assets-editor{
      grid-column: 2;
      grid-row: 1;
      min-width:0;
      align-self:stretch;
    }
    @media (max-width: 980px){
      .modal .content.line-editor-content{
        grid-template-columns: 1fr;
      }
      .line-assets-editor{
        grid-column:auto;
        grid-row:auto;
      }
    }
    .preview{
      border-radius: var(--radius-lg);
      border:1px solid rgba(255,255,255,.10);
      overflow:hidden;
      aspect-ratio: 16/9 !important;
      background: rgba(0,0,0,.35);
    }
    .preview img{width:100%;height:100%;object-fit:cover;display:block}
    .modal footer{
      padding: 14px 16px;
      display:flex;
      justify-content:flex-end;
      gap: 10px;
      border-top: 1px solid rgba(255,255,255,.10);
      flex:0 0 auto;
      background:rgba(9,10,12,.82);
    }

/* Sorting (Admin) */
    .admin-active .asset-wrap{ cursor: grab; }
    .admin-active .asset-wrap.dragging{ opacity: .55; cursor: grabbing; }
    .admin-active .asset-wrap.drop-target{ outline: 2px solid rgba(var(--accent-rgb),.55); outline-offset: 4px; }

    .line-tools{
      position:absolute;
      top: 14px;
      left: 14px;
      display:flex;
      gap: 8px;
      z-index: 50;
    }

/* v9: Line editor assets order list */
.assets-order-list{
  max-height: min(72vh, 980px);
  overflow-y: auto;
  overflow-x: hidden;
  padding: 12px;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 14px;
  background: rgba(0,0,0,.18);
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(154px, 1fr));
  gap: 12px;
  align-items:start;
}
.assets-order-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:10px;
}
.assets-order-head-title{
  color:rgba(244,246,248,.72);
  font-size:12px;
  font-weight:850;
}
.assets-order-undo{
  width:34px;
  height:34px;
  border-radius:50%;
  padding:0;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:17px;
}
.assets-order-row{
  display:grid;
  grid-template-columns: 1fr;
  align-items:start;
  gap:9px;
  padding:10px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
  cursor:grab;
  min-width:0;
}
.assets-order-row.dragover{
  outline: 2px solid var(--bundle-yellow);
  outline-offset: 2px;
}
.assets-order-row.dragging{
  opacity:.48;
  cursor:grabbing;
}
.assets-order-thumb{
  width: 100%;
  aspect-ratio: 1/1 !important;
  border-radius: 10px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  background-size: cover;
  background-position: center;
  min-width:0;
}
.assets-order-title{
  min-width: 0;
}
.assets-order-title input{
  width:100%;
  height:36px;
  border-radius:11px;
  font-size:12px;
  font-weight:850;
  padding: 0 9px;
}
.assets-order-id{ min-width:0; }
.assets-order-id input{
  width:100%;
  height:32px;
  border-radius:11px;
  font-size:12px;
  font-weight:650;
  padding: 0 9px;
  opacity:.92;
}
.assets-order-thumb{ cursor:pointer; }
.assets-order-thumb:hover{ box-shadow:inset 0 0 0 2px var(--bundle-yellow); }
.assets-order-controls{
  display:flex;
  gap:8px;
  width:100%;
}
.assets-order-controls .btn:not(.assets-order-delete){
  flex: 1 1 auto;
  min-width:0;
}
.assets-order-delete{
  width:34px;
  height:34px;
  border-radius:50%;
  padding:0;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:18px;
  line-height:1;
}
.catalog-order-list{
  max-height:min(68vh, 760px);
  overflow:auto;
  padding:12px;
  border:1px solid rgba(255,255,255,.10);
  border-radius:14px;
  background:rgba(0,0,0,.18);
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(210px, 1fr));
  gap:12px;
}
.catalog-order-row{
  display:grid;
  grid-template-columns:1fr;
  gap:9px;
  min-width:0;
  padding:10px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.035);
  cursor:grab;
}
.catalog-order-row.dragging{ opacity:.48; cursor:grabbing; }
.catalog-order-row.dragover{ outline:2px solid var(--bundle-yellow); outline-offset:2px; }
.catalog-order-thumb{
  width:100%;
  aspect-ratio:1/1 !important;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.06);
  overflow:hidden;
}
.catalog-order-thumb img{ width:100%; height:100%; object-fit:cover; display:block; }
.catalog-order-title{
  min-width:0;
  font-size:13px;
  font-weight:900;
  color:#fff;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.catalog-order-meta{
  min-height:18px;
  color:rgba(244,246,248,.58);
  font-size:11px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.06em;
}
.catalog-manager{
  gap:14px;
}
.catalog-manager-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
}
.catalog-manager-list{
  max-height:min(68vh, 760px);
  overflow:auto;
  display:grid;
  gap:10px;
  padding:10px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.18);
}
.catalog-manager-row{
  display:grid;
  grid-template-columns:72px minmax(150px, 1fr) minmax(420px, 1.6fr) auto;
  gap:12px;
  align-items:center;
  padding:10px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.035);
}
.catalog-manager-thumb{
  aspect-ratio:1/1;
  border-radius:10px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.24);
}
.catalog-manager-thumb img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
}
.catalog-manager-main{
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:4px;
}
.catalog-manager-main b{
  color:#fff;
  font-size:13px;
  font-weight:950;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.catalog-manager-main span{
  color:rgba(244,246,248,.58);
  font-size:11px;
  font-weight:850;
  text-transform:uppercase;
  letter-spacing:.05em;
}
.catalog-manager-controls{
  min-width:0;
  display:grid;
  grid-template-columns: 72px 1fr 1.4fr 72px;
  gap:8px;
}
.catalog-manager-controls label{
  min-width:0;
  color:rgba(244,246,248,.64);
  font-size:11px;
  display:flex;
  flex-direction:column;
  gap:5px;
}
.catalog-manager-controls input,
.catalog-manager-controls select{
  height:38px;
  border-radius:11px;
  padding:0 10px;
}
.catalog-manager-actions{
  display:flex;
  gap:8px;
  justify-content:flex-end;
}
@media (max-width: 980px){
  .line-pack-summary,
  .catalog-manager-row{
    grid-template-columns:1fr;
  }
  .catalog-manager-controls{
    grid-template-columns:1fr 1fr;
  }
  .catalog-manager-actions{
    justify-content:flex-start;
  }
}
.btn.small{
  padding: 8px 10px;
  border-radius: 999px;
  font-size: 12px;
}

