/* =========================================================
   Content Studio
   ========================================================= */
.studio-backdrop{
  position:fixed; inset:0; z-index:600;
  background:rgba(47,41,69,.4);
  backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px);
  display:flex; align-items:center; justify-content:center;
  padding:24px;
  opacity:0; visibility:hidden;
  transition:opacity .5s var(--ease-soft), visibility .5s;
}
.studio-backdrop.open{ opacity:1; visibility:visible; }

.studio-modal{
  width:100%; max-width:1240px; height:86vh;
  border-radius:var(--radius-lg);
  display:flex;
  position:relative;
  overflow:hidden;
  box-shadow:0 40px 100px -30px rgba(47,41,69,.4);
  transform:scale(.95) translateY(16px);
  opacity:0;
  transition:transform .5s var(--ease-soft), opacity .5s var(--ease-soft);
}
.studio-backdrop.open .studio-modal{ transform:scale(1) translateY(0); opacity:1; }
.studio-modal-close{ top:20px; right:20px; z-index:5; }

.studio-sidebar{
  width:250px; flex-shrink:0;
  background:var(--surface);
  padding:36px 22px;
  display:flex; flex-direction:column;
  border-right:1px solid rgba(47,41,69,.08);
}
.studio-brand{
  font-family:var(--serif); font-size:19px; color:var(--ink);
  margin-bottom:28px;
}
.studio-nav{ display:flex; flex-direction:column; gap:4px; flex:1; }
.studio-nav-divider{ height:1px; background:rgba(47,41,69,.08); margin:8px 4px 10px; }
.studio-nav-item{
  text-align:left;
  padding:11px 14px;
  border-radius:var(--radius-sm);
  font-size:13px; font-weight:500; color:var(--ink-soft);
  transition:background .3s var(--ease-soft), color .3s var(--ease-soft);
}
.studio-nav-item:hover{ background:rgba(255,255,255,.6); color:var(--ink); }
.studio-nav-item.active{ background:#fff; color:var(--accent); font-weight:600; box-shadow:0 6px 16px -10px rgba(47,41,69,.3); }
.studio-nav-item-featured{
  background:linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 100%);
  color:#fff;
  font-weight:600;
  box-shadow:0 8px 20px -10px rgba(89,81,166,.5);
}
.studio-nav-item-featured:hover{ background:linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 100%); color:#fff; }
.studio-nav-item-featured.active{ background:#fff !important; color:var(--accent) !important; }
.studio-hint{ font-size:11px; color:var(--ink-soft); opacity:.7; line-height:1.5; margin-top:20px; }

.studio-main{
  flex:1; min-width:0;
  padding:0 41px 0 46px;
  margin-top:54px;
  margin-bottom:54px;
  margin-right:5px;
  overflow-y:auto;
  overflow-x:hidden;
  scrollbar-width:thin;
  scrollbar-color:rgba(47,41,69,.2) transparent;
}
.studio-main::-webkit-scrollbar{ width:5px; background:transparent; }
.studio-main::-webkit-scrollbar-track{ background:transparent; }
.studio-main::-webkit-scrollbar-thumb{ background:rgba(47,41,69,.2); border-radius:10px; }
.studio-main-head{
  display:flex; align-items:flex-end; justify-content:space-between;
  gap:20px; margin-bottom:32px; flex-wrap:wrap;
}
.studio-title{ font-size:30px; margin-top:6px; }
.studio-section-hint{ font-size:12.5px; color:var(--ink-soft); margin-top:6px; min-height:16px; }

.studio-grid{
  display:grid; grid-template-columns:repeat(auto-fill, minmax(210px, 1fr));
  gap:20px;
}
.studio-card{
  border-radius:var(--radius-md);
  overflow:hidden;
  background:#fff;
  box-shadow:0 14px 34px -22px rgba(47,41,69,.28);
  cursor:grab;
  transition:box-shadow .35s var(--ease-soft), opacity .3s var(--ease-soft);
}
.studio-card.dragging{ opacity:.4; }
.studio-card:hover{ box-shadow:0 22px 46px -20px rgba(47,41,69,.36); }

.studio-card-media{
  aspect-ratio:4/3; position:relative;
}
.studio-status-badge{
  position:absolute; top:10px; left:10px;
  font-size:9.5px; font-weight:700; letter-spacing:.06em; text-transform:uppercase;
  padding:4px 10px; border-radius:var(--radius-pill);
  background:rgba(255,255,255,.9); color:var(--ink);
}
.status-published{ color:#3F7A57; }
.status-draft{ color:#9A7B2E; }
.status-hidden{ color:#A15A4A; }

.studio-card-actions{
  position:absolute; inset:0;
  background:rgba(47,41,69,.5);
  display:flex; align-items:center; justify-content:center; gap:8px;
  opacity:0; transition:opacity .3s var(--ease-soft);
}
.studio-card:hover .studio-card-actions{ opacity:1; }
.studio-icon-btn{
  width:32px; height:32px; border-radius:50%;
  background:rgba(255,255,255,.92);
  display:flex; align-items:center; justify-content:center;
  color:var(--ink);
  transition:transform .25s var(--ease-soft), background .25s var(--ease-soft);
}
.studio-icon-btn:hover{ transform:scale(1.1); background:#fff; }
.studio-icon-danger:hover{ color:#B44B3C; }

.studio-card-body{ padding:14px 16px 16px; }
.studio-card-title{ font-family:var(--serif); font-size:16.5px; margin-bottom:2px; }
.studio-card-meta{ font-size:11px; color:var(--ink-soft); }

.studio-empty{
  text-align:center; padding:70px 20px; color:var(--ink-soft);
}
.studio-empty p{ font-size:15px; margin-bottom:6px; }
.studio-empty-sub{ font-size:13px; opacity:.8; }

@media (max-width:820px){
  .studio-modal{ flex-direction:column; height:92vh; }
  .studio-sidebar{ width:100%; flex-direction:row; overflow-x:auto; padding:18px; border-right:none; border-bottom:1px solid rgba(47,41,69,.08); }
  .studio-brand{ display:none; }
  .studio-nav{ flex-direction:row; }
  .studio-hint{ display:none; }
  .studio-main{ padding:0 22px; margin-top:44px; margin-bottom:24px; }
}

/* ---------- Add/Edit project dialog ---------- */
.dialog-lg{
  width:100%; max-width:640px; max-height:88vh;
  padding:0;
  overflow:hidden;
  display:flex;
  flex-direction:column;
}
.dialog-scroll-inner{
  margin:60px 5px 24px 44px;
  padding:0 31px 0 0;
  overflow-y:auto;
  overflow-x:hidden;
  min-height:0;
  flex:1;
  scrollbar-width:thin;
  scrollbar-color:rgba(47,41,69,.2) transparent;
}
.dialog-scroll-inner::-webkit-scrollbar{ width:5px; background:transparent; }
.dialog-scroll-inner::-webkit-scrollbar-track{ background:transparent; }
.dialog-scroll-inner::-webkit-scrollbar-thumb{ background:rgba(47,41,69,.2); border-radius:10px; }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-row-3{ grid-template-columns:1fr 1fr 1fr; }
.field select, .field textarea{
  padding:14px 18px; border-radius:var(--radius-sm);
  border:1px solid rgba(47,41,69,.12);
  background:var(--surface);
  font-family:var(--sans);
  font-size:14px; color:var(--ink);
  transition:border-color .3s var(--ease);
}
.field select:focus, .field textarea:focus{ border-color:var(--accent-2); outline:none; }
.field textarea{ min-height:88px; resize:vertical; }

.form-subhead{
  font-size:12px; font-weight:600; letter-spacing:.05em; text-transform:uppercase;
  color:var(--ink-soft);
  margin:28px 0 16px;
  padding-top:20px;
  border-top:1px solid rgba(47,41,69,.08);
}
.form-subhead span{ font-weight:400; text-transform:none; letter-spacing:0; opacity:.7; }

.status-toggle{ display:flex; gap:8px; }
.status-option{
  flex:1; padding:11px; border-radius:var(--radius-sm);
  background:var(--surface); color:var(--ink-soft);
  font-size:13px; font-weight:500;
  border:1px solid transparent;
  transition:background .3s var(--ease-soft), color .3s var(--ease-soft);
}
.status-option.active{ background:var(--accent); color:#fff; }

@media (max-width:600px){
  .form-row, .form-row-3{ grid-template-columns:1fr; }
}

/* ---------- Testimonials in Studio ---------- */
.studio-testimonial-actions{ display:flex; gap:8px; margin-top:14px; }

/* ---------- Color Scheme panel ---------- */
.studio-color-panel{
  display:grid; grid-template-columns:1fr 1fr; gap:32px;
}
.color-of-year-label{ font-size:11px; font-weight:600; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:14px; }
.color-of-year-row{ display:flex; align-items:center; gap:14px; margin-bottom:16px; }
.color-of-year-swatch{ width:48px; height:48px; border-radius:50%; border:1px solid rgba(47,41,69,.12); flex-shrink:0; }
.color-of-year-name{ font-family:var(--serif); font-size:19px; }
.color-of-year-code{ font-size:12px; color:var(--ink-soft); margin-top:2px; }
.color-of-year-note{ font-size:11.5px; color:var(--ink-soft); line-height:1.6; opacity:.85; max-width:360px; }
.color-of-year-note code{ background:var(--surface); padding:1px 5px; border-radius:4px; font-size:11px; }
.companion-palette{ display:flex; flex-wrap:wrap; gap:10px; max-width:220px; }
.companion-swatch{ width:30px; height:30px; border-radius:50%; border:1px solid rgba(47,41,69,.12); }

.color-field-row{ display:flex; align-items:center; gap:12px; padding:10px 0; }
.color-field-swatch{ width:24px; height:24px; border-radius:50%; border:1px solid rgba(47,41,69,.12); flex-shrink:0; }
.color-field-label{ flex:1; font-size:13.5px; }
.color-field-input{ width:44px; height:28px; border:none; border-radius:6px; cursor:pointer; background:none; padding:0; }

@media (max-width:820px){
  .studio-color-panel{ grid-template-columns:1fr; }
}

/* ---------- Logo upload button ---------- */
.logo-upload-btn{
  display:flex; align-items:center; justify-content:center; gap:8px;
  padding:14px 18px;
  border-radius:var(--radius-sm);
  border:1.5px dashed rgba(47,41,69,.25);
  background:var(--surface);
  color:var(--ink-soft);
  font-size:13.5px; font-weight:500;
  transition:border-color .3s var(--ease), color .3s var(--ease), background .3s var(--ease);
  width:100%;
  box-sizing:border-box;
}
.logo-upload-btn:hover{ border-color:var(--accent); color:var(--accent); background:#fff; }
.logo-upload-btn.icon-only{ padding:0; height:47px; }
.logo-field-row{ display:flex; flex-direction:column; }
#pf-client-logo-preview, #tf-logo-preview{
  margin-top:10px;
  max-height:40px; max-width:120px;
  object-fit:contain;
  border-radius:6px;
}

/* ---------- Page Content editor ---------- */
.content-panel-note{ font-size:13px; color:var(--ink-soft); line-height:1.6; margin-bottom:24px; max-width:520px; }
.content-field-list{ display:flex; flex-direction:column; gap:2px; }
.content-field-row{
  display:flex; align-items:center; justify-content:space-between; gap:20px;
  padding:16px 4px;
  border-bottom:1px solid rgba(47,41,69,.08);
}
.content-field-row:last-child{ border-bottom:none; }
.content-field-info{ min-width:0; }
.content-field-label{ font-size:12px; font-weight:600; color:var(--ink); margin-bottom:4px; }
.content-field-edited{ font-weight:400; color:var(--accent); font-style:italic; }
.content-field-preview{
  font-size:13px; color:var(--ink-soft);
  overflow:hidden; text-overflow:ellipsis; white-space:nowrap; max-width:520px;
}
.content-field-edit-btn{ padding:9px 18px; font-size:12.5px; flex-shrink:0; }

.richtext-toolbar{
  display:flex; align-items:center; gap:4px;
  padding:8px; margin-bottom:2px;
  background:var(--surface);
  border-radius:var(--radius-sm) var(--radius-sm) 0 0;
}
.richtext-btn{
  width:32px; height:32px; border-radius:8px;
  display:flex; align-items:center; justify-content:center;
  color:var(--ink-soft); font-size:14px;
  transition:background .2s var(--ease), color .2s var(--ease);
}
.richtext-btn:hover{ background:#fff; color:var(--ink); }
.richtext-divider{ width:1px; height:20px; background:rgba(47,41,69,.15); margin:0 4px; }
.richtext-editable{
  min-height:100px;
  padding:16px 18px;
  border:1px solid rgba(47,41,69,.12);
  border-top:none;
  border-radius:0 0 var(--radius-sm) var(--radius-sm);
  background:var(--surface);
  font-size:15px; line-height:1.6; color:var(--ink);
  outline:none;
}
.richtext-editable:focus{ border-color:var(--accent-2); }
.inline-story-image, .story-content img{
  width:100%; height:auto;
  border-radius:var(--radius-md);
  margin:20px 0;
  display:block;
}

/* ---------- Client Logos management ---------- */
.layout-picker{ display:flex; flex-wrap:wrap; gap:8px; }
.layout-option{
  padding:9px 16px;
  border-radius:var(--radius-pill);
  background:var(--surface);
  color:var(--ink-soft);
  font-size:12.5px; font-weight:500;
  border:1px solid transparent;
  transition:background .3s var(--ease-soft), color .3s var(--ease-soft);
}
.layout-option:hover{ background:#fff; color:var(--ink); }
.layout-option.active{ background:var(--accent); color:#fff; }

.logo-manage-grid{
  display:grid; grid-template-columns:repeat(auto-fill, minmax(120px, 1fr));
  gap:14px;
}
.logo-manage-card{
  position:relative;
  min-height:110px;
  background:var(--surface);
  border-radius:var(--radius-sm);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  cursor:grab;
  transition:opacity .3s var(--ease-soft), box-shadow .3s var(--ease-soft);
}
.logo-manage-card.dragging{ opacity:.4; }
.logo-manage-card:hover{ box-shadow:0 10px 26px -14px rgba(47,41,69,.3); }
.logo-manage-thumb{
  display:flex; align-items:center; justify-content:center;
  width:100%; flex:1; padding:14px;
  min-height:60px;
}
.logo-manage-thumb img{ max-width:100%; max-height:100%; object-fit:contain; }
.logo-manage-thumb span{ font-family:var(--serif); font-size:14px; color:var(--ink-soft); text-align:center; }
.logo-manage-delete{
  position:absolute; top:6px; right:6px;
  width:24px; height:24px;
  background:#fff;
  box-shadow:0 4px 10px -4px rgba(47,41,69,.3);
  opacity:0;
  transition:opacity .25s var(--ease-soft);
}
.logo-manage-replace{
  position:absolute; top:6px; left:6px;
  width:24px; height:24px;
  background:#fff;
  box-shadow:0 4px 10px -4px rgba(47,41,69,.3);
  opacity:0;
  transition:opacity .25s var(--ease-soft);
}
.logo-manage-card:hover .logo-manage-delete,
.logo-manage-card:hover .logo-manage-replace{ opacity:1; }

/* ---------- Compact icon action buttons (Save/Reset/Cancel) ---------- */
.compact-actions{
  display:flex; justify-content:flex-end; gap:8px;
}
.icon-action-btn{
  width:34px; height:34px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  background:var(--surface);
  color:var(--ink-soft);
  border:none;
  transition:background .25s var(--ease), color .25s var(--ease);
}
.icon-action-btn:hover{ background:#fff; color:var(--ink); }
.icon-action-primary{ background:var(--accent); color:#fff; }
.icon-action-primary:hover{ background:var(--accent-2); color:#fff; }
.icon-action-lg{ width:42px; height:42px; }
.icon-action-outline{
  background:transparent;
  border:1.5px solid var(--accent);
  color:var(--accent);
}
.icon-action-outline:hover{ background:var(--accent); color:#fff; }
.text-action-btn{
  padding:10px 20px;
  border-radius:var(--radius-pill);
  font-size:12.5px; font-weight:600;
  transition:background .25s var(--ease), color .25s var(--ease);
}

/* ---------- Subtle add button ---------- */
.subtle-add-btn{
  display:inline-flex; align-items:center; gap:7px;
  color:var(--ink-soft);
  font-size:12.5px; font-weight:500;
  padding:6px 2px;
  transition:color .25s var(--ease);
}
.subtle-add-btn:hover{ color:var(--accent); }

/* ---------- Featured Projects panel ---------- */
.featured-block-list{ display:flex; flex-direction:column; gap:28px; }
.featured-block-card{
  display:grid; grid-template-columns:140px 1fr;
  gap:20px;
  padding:20px;
  background:var(--surface);
  border-radius:var(--radius-md);
  align-items:stretch;
}
.featured-block-media{
  position:relative;
  height:100%; min-height:140px;
  border-radius:var(--radius-sm);
  overflow:hidden;
  background:linear-gradient(135deg,#7A69D6,#4A4380);
}
.featured-block-media img{ width:100%; height:100%; object-fit:cover; }
.mini-size-hint{
  position:absolute; left:8px; bottom:8px; z-index:2;
  display:flex; align-items:center; gap:5px;
  padding:4px 9px 4px 6px;
  border-radius:var(--radius-pill);
  background:rgba(255,255,255,.92);
  color:rgba(110,102,133,.85);
  font-size:9px; font-weight:600;
  white-space:nowrap;
}
.mini-size-hint .size-hint-icon{ width:11px; height:11px; font-size:8px; background:rgba(110,102,133,.3); }
.featured-block-fields .field{ margin-bottom:12px; }
.featured-block-fields .field:last-child{ margin-bottom:0; }
.featured-block-fields label{ font-size:10.5px; text-transform:uppercase; letter-spacing:.05em; color:var(--ink-soft); margin-bottom:4px; display:block; }
.featured-block-fields input{
  width:100%; padding:9px 12px;
  border-radius:8px; border:1px solid rgba(47,41,69,.12);
  background:#fff; font-size:13px; color:var(--ink);
}
.featured-history{ margin-top:16px; }
.featured-history-label{ font-size:10.5px; text-transform:uppercase; letter-spacing:.05em; color:var(--ink-soft); margin-bottom:8px; }
.featured-history-row{ display:flex; gap:8px; flex-wrap:wrap; }
.featured-history-thumb{
  position:relative;
  width:56px; height:42px;
  border-radius:6px; overflow:hidden;
  border:2px solid transparent;
  cursor:pointer;
}
.featured-history-thumb img{ width:100%; height:100%; object-fit:cover; }
.featured-history-thumb.active{ border-color:var(--accent); }
.featured-history-thumb .use-label{
  position:absolute; inset:0;
  background:rgba(47,41,69,.55);
  color:#fff; font-size:8.5px; font-weight:600;
  display:flex; align-items:center; justify-content:center;
  text-align:center; opacity:0;
  transition:opacity .2s var(--ease);
}
.featured-history-thumb:hover .use-label{ opacity:1; }

/* ---------- Services management (reuses featured-block-card layout) ---------- */
.services-manage-list{ display:flex; flex-direction:column; gap:16px; }
.service-manage-card{ cursor:grab; }
.service-manage-card.dragging{ opacity:.4; }
.service-icon-media{
  display:flex; align-items:center; justify-content:center;
  background:var(--surface);
}
.service-icon-media img{ width:60%; height:60%; object-fit:contain; }
.service-icon-glyph{ font-size:36px; color:var(--accent); }

/* ---------- Discreet size-hint badge ---------- */
.size-hint-badge{
  position:absolute; left:24px; bottom:20px; z-index:4;
  display:flex; align-items:center; gap:7px;
  padding:7px 13px 7px 9px;
  border-radius:var(--radius-pill);
  border:1px solid rgba(47,41,69,.1);
  background:rgba(247,246,250,.9);
  color:rgba(110,102,133,.75);
  font-size:10.5px; font-weight:500;
  max-width:280px;
}
.size-hint-icon{
  width:14px; height:14px; border-radius:50%;
  background:rgba(110,102,133,.25);
  color:#fff;
  font-size:9.5px; font-weight:700;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0;
}

/* ---------- Project artwork upload ---------- */
.field-inline-hint{ font-size:11px; color:var(--ink-soft); margin-top:6px; line-height:1.5; }
.pf-media-preview{ margin-top:10px; }
.pf-media-preview img{ max-width:160px; max-height:100px; border-radius:8px; object-fit:cover; }
.pf-media-preview .pf-media-file-chip{
  display:inline-flex; align-items:center; gap:6px;
  padding:6px 12px; border-radius:var(--radius-pill);
  background:var(--surface); font-size:11.5px; color:var(--ink);
}

/* ---------- Studio panel subheadings ---------- */
.content-panel-subhead{
  font-size:14px; font-weight:700; color:var(--ink);
  margin-bottom:8px;
  padding-top:20px;
  border-top:1px solid rgba(47,41,69,.08);
}
.content-panel-subhead:first-child{ padding-top:0; border-top:none; }
.logo-manage-name-input{
  width:calc(100% - 12px);
  margin:0 6px 8px;
  padding:5px 6px;
  border:1px solid transparent;
  border-radius:6px;
  background:transparent;
  font-size:10.5px; color:var(--ink-soft); text-align:center;
  transition:border-color .2s var(--ease), background .2s var(--ease);
}
.logo-manage-name-input:hover{ border-color:rgba(47,41,69,.15); background:#fff; }
.logo-manage-name-input:focus{ border-color:var(--accent-2); background:#fff; outline:none; color:var(--ink); }
.program-placeholder-ico{ font-size:20px; color:var(--accent); opacity:.5; }
