:root {
  --bg: #050506;
  --panel: rgba(15, 16, 20, .86);
  --text: #f8f8fb;
  --muted: #a9afba;
  --line: rgba(255,255,255,.12);
  --red: #ff1535;
  --red-dark: #8e0014;
  --shadow: 0 24px 70px rgba(0,0,0,.58);
  --radius: 24px;
}
* { box-sizing: border-box; }
body {
  min-width: 320px;
  margin: 0;
  color: var(--text);
  font-family: Inter, system-ui, -apple-system, Segoe UI, sans-serif;
  background-image:
    linear-gradient(135deg, rgba(4,4,5,.94), rgba(4,4,5,.84)),
    url('../assets/img/bg-hero-desktop.png');
  background-image:
    linear-gradient(135deg, rgba(4,4,5,.94), rgba(4,4,5,.84)),
    url('../assets/img/bg-hero-desktop.webp');
  background-size: cover;
  background-position: center top;
  background-attachment: fixed;
}
a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; }
.admin-shell { width: min(1180px, calc(100% - 28px)); margin: 0 auto; padding: clamp(1.2rem, 4vw, 3rem) 0; }
.chrome-card {
  position: relative;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: linear-gradient(145deg, rgba(255,255,255,.09), rgba(255,255,255,.025), rgba(255,21,53,.055)), var(--panel);
  box-shadow: var(--shadow), inset 0 1px 0 rgba(255,255,255,.15);
  backdrop-filter: blur(16px);
}
.brand-row { display: inline-flex; align-items: center; gap: .75rem; font-weight: 900; letter-spacing: -.02em; }
.brand-row span span { color: var(--red); }
.brand-mark {
  width: 46px; height: 46px; display: grid; place-items: center; flex: 0 0 46px;
  border-radius: 50%;
  background: radial-gradient(circle at 28% 22%, #fff 0, #d7dce5 11%, #575d68 26%, #0b0b0d 43%, #09090b 55%, #b5bac3 72%, #f8fbff 79%, #494d55 100%);
  box-shadow: inset 0 0 0 3px rgba(255,255,255,.25), 0 0 0 2px rgba(255,21,53,.45), 0 0 30px rgba(255,21,53,.42);
}
.login-card { max-width: 460px; margin: 8vh auto; padding: clamp(1.4rem, 5vw, 2.2rem); }
h1, h2, p { margin-top: 0; }
h1 { font-size: clamp(2.1rem, 6vw, 4rem); line-height: .98; letter-spacing: -.055em; margin: 1rem 0; }
h2 { font-size: 1.35rem; margin-bottom: .35rem; }
p { color: var(--muted); line-height: 1.65; }
.eyebrow { color: var(--red); font-family: "JetBrains Mono", monospace; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; font-size: .82rem; margin-bottom: .6rem; }
label { display: block; margin: 1rem 0 .45rem; color: #dde2ea; font-weight: 800; }
input, select {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: .8rem .9rem;
  color: white;
  background: rgba(0,0,0,.38);
  outline: none;
}
input:focus, select:focus { border-color: rgba(255,21,53,.62); box-shadow: 0 0 0 4px rgba(255,21,53,.12); }
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .4rem;
  min-height: 46px; padding: .72rem 1rem; border-radius: 999px; border: 1px solid var(--line);
  color: white; cursor: pointer; font-weight: 900; transition: .18s ease; background: rgba(255,255,255,.06);
}
.btn:hover { transform: translateY(-1px); }
.btn.primary { margin-top: 1rem; border-color: rgba(255,21,53,.55); background: linear-gradient(135deg, var(--red), var(--red-dark)); box-shadow: 0 16px 36px rgba(255,21,53,.22); }
.btn.ghost { background: rgba(255,255,255,.06); }
.admin-header { display: grid; grid-template-columns: 1fr auto; gap: 1.25rem; align-items: center; padding: clamp(1.3rem, 4vw, 2rem); margin-bottom: 1rem; }
.header-actions, .toolbar-actions { display: flex; flex-wrap: wrap; gap: .7rem; }
.editor-layout { display: grid; grid-template-columns: minmax(0, 1fr) 320px; gap: 1rem; align-items: start; }
.editor-card, .help-card { padding: clamp(1rem, 3vw, 1.4rem); }
.toolbar { display: flex; align-items: start; justify-content: space-between; gap: 1rem; margin-bottom: 1rem; }
.menu-editor { display: grid; gap: .9rem; }
.menu-item {
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 1rem;
  background: rgba(0,0,0,.34);
}
.item-grid { display: grid; grid-template-columns: 160px 1fr 1fr; gap: .8rem; align-items: end; }
.checkbox-row { display: flex; gap: .5rem; align-items: center; margin-top: .7rem; color: #dbe0e8; }
.checkbox-row input { width: auto; }
.item-actions, .child-actions { display: flex; flex-wrap: wrap; gap: .5rem; margin-top: .85rem; }
.small-btn { min-height: 36px; padding: .45rem .72rem; font-size: .86rem; }
.danger { border-color: rgba(255,21,53,.5); color: #ffb6c0; }
.children { margin-top: 1rem; padding-top: .85rem; border-top: 1px solid var(--line); display: grid; gap: .65rem; }
.child-row { display: grid; grid-template-columns: 1fr 1fr auto; gap: .65rem; align-items: end; }
.save-row { display: flex; justify-content: flex-end; margin-top: 1rem; }
.alert { border-radius: 16px; padding: .95rem 1rem; margin: 1rem 0; border: 1px solid var(--line); }
.alert.success { border-color: rgba(55, 210, 120, .42); background: rgba(55, 210, 120, .12); color: #d8ffe6; }
.alert.error { border-color: rgba(255,21,53,.52); background: rgba(255,21,53,.14); color: #ffd7dd; }
code { color: #ff6a7d; background: rgba(0,0,0,.28); padding: .12rem .25rem; border-radius: 6px; }
@media (max-width: 900px) {
  .admin-header, .editor-layout, .toolbar, .item-grid, .child-row { grid-template-columns: 1fr; }
  .header-actions, .toolbar-actions { width: 100%; }
  .header-actions .btn, .toolbar-actions .btn { flex: 1 1 160px; }
}

/* Content editor / portfolio editor */
textarea {
  width: 100%;
  min-height: 110px;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: .8rem .9rem;
  color: white;
  background: rgba(0,0,0,.38);
  outline: none;
  resize: vertical;
}
textarea:focus { border-color: rgba(255,21,53,.62); box-shadow: 0 0 0 4px rgba(255,21,53,.12); }
.admin-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: .65rem;
  padding: .75rem;
  margin: 1rem 0;
}
.tab-button {
  flex: 1 1 180px;
  min-height: 48px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255,255,255,.055);
  color: #d9dee8;
  cursor: pointer;
  font-weight: 900;
}
.tab-button.is-active {
  color: white;
  border-color: rgba(255,21,53,.55);
  background: linear-gradient(135deg, rgba(255,21,53,.95), rgba(159,0,23,.88));
  box-shadow: 0 16px 36px rgba(255,21,53,.18);
}
.tab-panel { display: none; }
.tab-panel.is-active { display: block; }
.site-editor { display: grid; gap: 1rem; }
.cms-section {
  padding: clamp(1rem, 3vw, 1.45rem);
}
.cms-section + .cms-section { margin-top: .2rem; }
.cms-section h2 { margin-bottom: .2rem; }
.cms-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .85rem;
}
.cms-grid.three { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.cms-grid .full { grid-column: 1 / -1; }
.dynamic-list, .card-editor-list { display: grid; gap: .9rem; margin-top: 1rem; }
.dynamic-item, .portfolio-item {
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 1rem;
  background: rgba(0,0,0,.32);
}
.item-title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .85rem;
  margin-bottom: .6rem;
}
.item-title-row h3 { margin: 0; font-size: 1.08rem; }
.inline-actions { display: flex; flex-wrap: wrap; gap: .45rem; }
.icon-hint { color: #a8adb8; font-size: .88rem; margin-top: .45rem; }
.icon-hint code { margin-right: .3rem; }
.portfolio-preview {
  width: min(360px, 100%);
  aspect-ratio: 16/9;
  border: 1px solid var(--line);
  border-radius: 16px;
  overflow: hidden;
  background: rgba(0,0,0,.4);
  display: grid;
  place-items: center;
  color: var(--muted);
  margin-top: .45rem;
}
.portfolio-preview img { width: 100%; height: 100%; object-fit: cover; }
.upload-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: .8rem;
  align-items: end;
}
.file-input {
  padding: .75rem;
  border: 1px dashed rgba(255,255,255,.24);
  border-radius: 14px;
  background: rgba(255,255,255,.04);
}
.sticky-save {
  position: sticky;
  bottom: .75rem;
  z-index: 20;
  padding: .75rem;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 999px;
  background: rgba(8,8,11,.85);
  backdrop-filter: blur(14px);
}
.help-note {
  margin: .65rem 0 0;
  color: var(--muted);
  font-size: .95rem;
}
@media (max-width: 900px) {
  .cms-grid, .cms-grid.three, .upload-row { grid-template-columns: 1fr; }
  .sticky-save { border-radius: 18px; }
  .sticky-save .btn { width: 100%; }
}

.project-menu-check { align-self: end; min-height: 46px; padding: .65rem .75rem; border: 1px solid var(--line); border-radius: 14px; background: rgba(255,255,255,.045); }


.floating-admin-notice {
  position: sticky;
  top: 12px;
  z-index: 50;
  margin-bottom: 14px;
  box-shadow: 0 16px 34px rgba(0, 0, 0, 0.35);
}
