@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,500;9..144,600&family=Inter:wght@400;500;600;700&display=swap');

:root {
  --bg: #f6efe4;
  --panel: #fffaf2;
  --text: #2d211a;
  --muted: #7d6f64;
  --line: #e5d7c7;
  --espresso: #3b291f;
  --clay: #8a543a;
  --sage: #93a66e;
  --danger: #b73737;
  --shadow: 0 18px 50px rgba(59, 41, 31, .10);
  --soft: 0 8px 24px rgba(59, 41, 31, .08);
}

* { box-sizing: border-box; }
body { margin: 0; font-family: Inter, Arial, sans-serif; color: var(--text); background: radial-gradient(circle at top left, rgba(147,166,110,.24), transparent 34rem), var(--bg); }
a { color: inherit; text-decoration: none; }
img, svg { display: block; max-width: 100%; }
button, input, textarea, select { font: inherit; }
code { padding: .18rem .4rem; border-radius: .5rem; background: #f3e7d7; font-size: .84rem; }

.admin-shell { min-height: 100vh; display: grid; grid-template-columns: 292px 1fr; }
.admin-sidebar { position: sticky; top: 0; height: 100vh; padding: 1.1rem; background: rgba(59,41,31,.96); color: rgba(255,255,255,.82); display: flex; flex-direction: column; gap: 1.5rem; }
.admin-brand { display: flex; align-items: center; gap: .85rem; padding: .7rem; border-radius: 1.2rem; background: rgba(255,255,255,.07); }
.admin-brand-mark, .login-mark { width: 48px; height: 48px; display: grid; place-items: center; border-radius: 1rem; background: linear-gradient(135deg, #f6efe4, #93a66e); color: var(--espresso); font-family: Fraunces, serif; font-weight: 700; }
.admin-brand strong { display: block; color: white; }
.admin-brand small { display: block; margin-top: .15rem; color: rgba(255,255,255,.55); font-size: .76rem; }
.admin-nav { display: grid; gap: .35rem; }
.admin-nav a { display: flex; align-items: center; gap: .7rem; padding: .85rem .9rem; border-radius: 999px; color: rgba(255,255,255,.7); font-weight: 700; transition: .2s; }
.admin-nav a:hover, .admin-nav a.active { color: white; background: rgba(255,255,255,.12); }
.admin-nav span { width: 1.4rem; text-align: center; }
.admin-sidebar-footer { margin-top: auto; display: grid; gap: .5rem; }
.admin-sidebar-footer a { padding: .7rem .9rem; border-radius: .85rem; background: rgba(255,255,255,.08); color: rgba(255,255,255,.75); }

.admin-main { padding: 2rem; min-width: 0; }
.admin-topbar { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-bottom: 1.4rem; }
.admin-kicker { margin: 0 0 .35rem; color: var(--sage); font-size: .75rem; font-weight: 800; letter-spacing: .23em; text-transform: uppercase; }
h1, h2, h3 { font-family: Fraunces, Georgia, serif; letter-spacing: -.02em; }
h1 { margin: 0; font-size: clamp(2rem, 4vw, 3rem); }
h2 { margin: 0; font-size: clamp(1.5rem, 3vw, 2.25rem); }
.muted { color: var(--muted); line-height: 1.7; }
.admin-user { min-width: 190px; padding: .9rem 1rem; border-radius: 1rem; background: rgba(255,255,255,.65); border: 1px solid var(--line); text-align: right; box-shadow: var(--soft); }
.admin-user span, .admin-user small { display: block; }
.admin-user span { font-weight: 800; }
.admin-user small { color: var(--muted); }
.alert { padding: 1rem 1.15rem; border-radius: 1rem; margin-bottom: 1rem; font-weight: 700; }
.alert.success { color: #35511f; background: #e7f2d7; border: 1px solid #bfd7a1; }
.alert.error { color: #7d1f1f; background: #fde3df; border: 1px solid #f4b4ab; }

.panel, .stat-card { background: rgba(255,250,242,.88); border: 1px solid rgba(229,215,199,.85); border-radius: 1.6rem; box-shadow: var(--shadow); }
.panel { padding: clamp(1rem, 2.2vw, 1.6rem); margin-bottom: 1.35rem; }
.panel-heading { display: flex; justify-content: space-between; align-items: flex-start; gap: 1rem; margin-bottom: 1.25rem; }
.panel-heading p { margin-bottom: 0; }
.dashboard-grid { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 1rem; margin-bottom: 1.35rem; }
.stat-card { padding: 1.2rem; }
.stat-card span, .stat-card small { display: block; color: var(--muted); }
.stat-card strong { display: block; margin: .35rem 0; font-size: 2.2rem; font-family: Fraunces, serif; }
.two-col { display: grid; grid-template-columns: minmax(0,1.2fr) 360px; gap: 1.4rem; align-items: center; }
.quick-actions, .form-actions { display: flex; gap: .7rem; flex-wrap: wrap; align-items: center; margin-top: 1rem; }
.primary-btn, .ghost-btn, .table-btn { display: inline-flex; align-items: center; justify-content: center; border-radius: 999px; border: 0; cursor: pointer; font-weight: 800; transition: .2s; }
.primary-btn { padding: .88rem 1.25rem; color: #fffaf2; background: var(--espresso); }
.primary-btn:hover { background: var(--clay); transform: translateY(-1px); }
.ghost-btn { padding: .82rem 1.1rem; color: var(--espresso); border: 1px solid var(--line); background: rgba(255,255,255,.65); }
.table-btn { padding: .45rem .75rem; font-size: .82rem; background: #efe2d0; margin-right: .35rem; }
.table-btn.danger { color: white; background: var(--danger); }
.preview-phone { border-radius: 2rem; padding: .8rem; background: var(--espresso); box-shadow: var(--shadow); }
.preview-hero { min-height: 440px; border-radius: 1.4rem; overflow: hidden; background-size: cover; background-position: center; display: flex; align-items: end; padding: 1.4rem; color: #fffaf2; position: relative; }
.preview-hero::before { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, transparent, rgba(0,0,0,.6)); }
.preview-hero > div { position: relative; }
.preview-hero h3 { margin: .3rem 0 0; font-size: 2rem; }
.smart-list { color: var(--muted); line-height: 1.9; }

.settings-layout { display: grid; grid-template-columns: 310px 1fr; gap: 1rem; align-items: start; }
.settings-tabs { position: sticky; top: 1rem; display: grid; gap: .55rem; }
.settings-tabs a { padding: .9rem; border-radius: 1.1rem; background: rgba(255,250,242,.68); border: 1px solid var(--line); transition: .2s; }
.settings-tabs a.active, .settings-tabs a:hover { background: var(--espresso); color: #fffaf2; border-color: var(--espresso); }
.settings-tabs strong, .settings-tabs small { display: block; }
.settings-tabs small { margin-top: .2rem; color: inherit; opacity: .7; line-height: 1.45; }
.smart-form { margin: 0; }
.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 1rem; }
.form-field { display: grid; gap: .45rem; align-content: start; }
.form-field.span-2 { grid-column: 1 / -1; }
.form-field label { font-weight: 800; }
.form-field input:not([type="checkbox"]), .form-field textarea, .form-field select, .table-tools input { width: 100%; border: 1px solid var(--line); border-radius: 1rem; padding: .85rem 1rem; background: rgba(255,255,255,.82); color: var(--text); outline: none; transition: .2s; }
.form-field input:focus, .form-field textarea:focus, .form-field select:focus, .table-tools input:focus { border-color: var(--sage); box-shadow: 0 0 0 4px rgba(147,166,110,.18); }
.form-field textarea { resize: vertical; }
.form-field small { color: var(--muted); line-height: 1.45; }
.check-field { align-content: center; padding: .9rem 1rem; border: 1px solid var(--line); border-radius: 1rem; background: rgba(255,255,255,.52); }
.check-field label { display: flex; align-items: center; gap: .55rem; }
.sticky-actions { position: sticky; bottom: 0; padding-top: 1rem; background: linear-gradient(180deg, transparent, var(--bg) 35%); }

.image-preview-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: .9rem; }
.image-preview { min-height: 220px; border: 1px dashed #ccb9a5; border-radius: 1.25rem; padding: .7rem; background: rgba(255,255,255,.55); display: grid; align-content: start; gap: .5rem; }
.image-preview span { color: var(--muted); font-size: .78rem; font-weight: 900; letter-spacing: .12em; text-transform: uppercase; }
.image-preview img { width: 100%; height: 180px; object-fit: cover; border-radius: .9rem; background: #eadccc; }
.image-preview.new img[src=""], .image-preview.new img:not([src]) { display: none; }
.image-preview em { color: var(--muted); display: grid; place-items: center; min-height: 180px; border-radius: .9rem; background: #f1e6d7; font-style: normal; }
.image-preview.has-image em { display: none; }
input[type=file] { cursor: pointer; }

.table-tools { margin-bottom: .8rem; max-width: 360px; }
.table-wrap { overflow-x: auto; }
.smart-table { width: 100%; border-collapse: collapse; min-width: 780px; }
.smart-table th, .smart-table td { padding: .9rem; border-bottom: 1px solid var(--line); text-align: left; vertical-align: top; }
.smart-table th { color: var(--muted); font-size: .78rem; letter-spacing: .12em; text-transform: uppercase; }
.thumb { width: 78px; height: 78px; object-fit: cover; border-radius: 1rem; }
.badge { display: inline-flex; padding: .3rem .6rem; border-radius: 999px; font-size: .78rem; font-weight: 900; }
.badge.on { color: #365220; background: #e3f0d1; }
.badge.off { color: #7c6753; background: #f0e2d1; }
.gallery-admin-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 1rem; }
.gallery-admin-card { display: grid; grid-template-columns: 170px 1fr; gap: 1rem; padding: .8rem; border-radius: 1.2rem; border: 1px solid var(--line); background: rgba(255,255,255,.54); }
.gallery-admin-card img { width: 170px; height: 140px; object-fit: cover; border-radius: .9rem; }
.gallery-admin-card strong, .gallery-admin-card small { display: block; }
.gallery-admin-card small { color: var(--muted); margin-top: .15rem; }
.gallery-admin-card p { color: var(--muted); margin: .5rem 0; }
.icon-cell svg { width: 24px; height: 24px; fill: none; stroke: currentColor; stroke-width: 1.8; }

.login-body { min-height: 100vh; display: grid; place-items: center; padding: 1rem; background: radial-gradient(circle at 20% 20%, rgba(147,166,110,.35), transparent 28rem), var(--bg); }
.login-card { width: min(100%, 460px); display: grid; gap: .9rem; padding: 2rem; border-radius: 2rem; background: rgba(255,250,242,.9); border: 1px solid var(--line); box-shadow: var(--shadow); }
.login-card h1 { margin: 0; }
.login-card label { display: grid; gap: .45rem; font-weight: 800; }
.login-card input { width: 100%; border: 1px solid var(--line); border-radius: 1rem; padding: .85rem 1rem; }
.login-card small { color: var(--muted); }

@media (max-width: 1180px) {
  .admin-shell { grid-template-columns: 1fr; }
  .admin-sidebar { position: static; height: auto; }
  .admin-nav { grid-template-columns: repeat(3, minmax(0,1fr)); }
  .admin-sidebar-footer { grid-template-columns: repeat(2,1fr); }
  .settings-layout, .two-col { grid-template-columns: 1fr; }
  .settings-tabs { position: static; grid-template-columns: repeat(2, minmax(0,1fr)); }
  .dashboard-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 720px) {
  .admin-main { padding: 1rem; }
  .admin-topbar { display: grid; }
  .admin-user { text-align: left; }
  .admin-nav, .settings-tabs, .dashboard-grid, .form-grid, .image-preview-grid, .gallery-admin-grid { grid-template-columns: 1fr; }
  .form-field.span-2 { grid-column: auto; }
  .gallery-admin-card { grid-template-columns: 1fr; }
  .gallery-admin-card img { width: 100%; }
}

.admin-brand-mark, .login-mark { overflow: hidden; }
.admin-brand-mark .admin-brand-logo, .login-mark .login-logo {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  padding: 6px;
  border-radius: inherit;
}
.admin-brand-fallback {
  display: grid;
  place-items: center;
  width: 100%;
  height: 100%;
}
.login-mark { width: 76px; height: 76px; margin-bottom: 0.25rem; }
.login-mark .login-logo { padding: 8px; }


.menu-admin-tools {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}

.menu-admin-tools input,
.menu-admin-tools select {
  min-height: 44px;
}

.table-subline {
  display: block;
  color: #8a7668;
  font-size: 12px;
  margin-top: 4px;
}

.field-warning {
  display: block;
  color: #9f4f25;
  background: #fff4ea;
  border: 1px solid #f1c6a6;
  border-radius: 12px;
  padding: 8px 10px;
  margin-top: 8px;
}

/* Brand media displayed from the same admin-controlled logo setting */
.dashboard-preview-logo {
  width: auto;
  max-width: 116px;
  height: 44px;
  object-fit: contain;
  margin-bottom: .75rem;
  padding: .35rem;
  border-radius: .85rem;
  background: rgba(255,255,255,.18);
}

/* Demo version additions */
.demo-version-badge {
  position: fixed;
  left: 50%;
  bottom: 14px;
  transform: translateX(-50%);
  z-index: 9999;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: .58rem 1rem;
  border-radius: 999px;
  background: linear-gradient(135deg, #ff8a00, #ffb347);
  color: #fff;
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .1em;
  text-transform: uppercase;
  box-shadow: 0 12px 34px rgba(255, 138, 0, .35);
  animation: demoBadgeFloat 2.8s ease-in-out infinite;
  pointer-events: none;
}

@keyframes demoBadgeFloat {
  0%, 100% { transform: translateX(-50%) translateY(0) scale(1); }
  50% { transform: translateX(-50%) translateY(-3px) scale(1.03); }
}

.demo-login-shortcuts {
  display: grid;
  gap: .55rem;
  margin-top: .35rem;
  padding: .8rem;
  border: 1px dashed #e9b46f;
  border-radius: 1.2rem;
  background: #fff7ef;
}

.demo-login-shortcuts strong {
  font-size: .8rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #9a5b08;
}

.demo-shortcut {
  display: grid;
  gap: .12rem;
  width: 100%;
  padding: .65rem .75rem;
  border: 1px solid #f1d2a8;
  border-radius: .95rem;
  background: #fff;
  color: var(--text);
  text-align: left;
  cursor: pointer;
  font-weight: 900;
}

.demo-shortcut span {
  color: var(--muted);
  font-size: .78rem;
  font-weight: 700;
}

.demo-toast {
  position: fixed;
  left: 50%;
  bottom: 72px;
  transform: translateX(-50%) translateY(12px);
  z-index: 10000;
  padding: .75rem 1rem;
  border-radius: 999px;
  background: rgba(45,31,22,.96);
  color: #fff;
  font-size: .85rem;
  font-weight: 800;
  opacity: 0;
  transition: .25s ease;
  box-shadow: 0 16px 44px rgba(0,0,0,.2);
}

.demo-toast.is-visible {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

.admin-body [data-demo-locked] {
  cursor: not-allowed !important;
}

.admin-body input[readonly],
.admin-body textarea[readonly],
.admin-body select:disabled,
.admin-body input:disabled,
.admin-body button.demo-frozen {
  opacity: 1;
  filter: none;
}

.admin-body button.demo-frozen,
.admin-body a.demo-frozen {
  position: relative;
}

.admin-body button.demo-frozen::after,
.admin-body a.demo-frozen::after {
  content: 'Demo';
  margin-left: .45rem;
  font-size: .68rem;
  padding: .12rem .38rem;
  border-radius: 999px;
  background: #fff0dd;
  color: #9a5b08;
}

@media (max-width: 560px) {
  .demo-version-badge {
    width: calc(100% - 2rem);
    font-size: .62rem;
  }
}
