/* ============================================================
   Ortiz Bakery — High-End Earth Tone Theme + Admin Theme (Complete)
   File: assets/css/style.css
   ============================================================ */

/* ------------------------------
   Theme Tokens (Public)
-------------------------------- */
:root{
  /* Earth tones */
  --bg: #f6f1e8;              /* warm parchment */
  --surface: #ffffff;         /* cards */
  --surface-2: #fbf7f1;       /* soft section backgrounds */
  --ink: #1e1b16;             /* deep espresso */
  --muted: #5b5247;           /* warm gray/brown */
  --line: rgba(30, 27, 22, .10);

  --accent: #b07a3f;          /* caramel */
  --accent-2: #6b4a2d;        /* mocha */
  --accent-3: #2e2218;        /* espresso */
  --gold: #d6b483;            /* subtle gold */

  /* Shadows & rounding */
  --radius: 18px;
  --radius-sm: 12px;
  --shadow: 0 18px 46px rgba(30, 27, 22, .12);
  --shadow-soft: 0 12px 30px rgba(30, 27, 22, .10);

  /* Layout */
  --max: 1200px;
}

/* ------------------------------
   Reset & Base
-------------------------------- */
*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; }

body{
  font-family: ui-serif, Georgia, "Times New Roman", Times, serif;
  background:
    radial-gradient(900px 600px at 15% 10%, rgba(176,122,63,.10), transparent 60%),
    radial-gradient(850px 540px at 85% 85%, rgba(107,74,45,.08), transparent 60%),
    linear-gradient(180deg, rgba(214,180,131,.10), transparent 35%),
    var(--bg);
  color: var(--ink);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

a{ color: var(--accent-2); text-decoration: none; }
a:hover{ text-decoration: underline; }

.container{
  width: min(var(--max), 92%);
  margin: 0 auto;
}

.page-offset{ padding-top: 86px; }

.section{ padding: 84px 0; }

/* Section title */
.section-title{
  text-align: center;
  margin-bottom: 22px;
}
.section-title h2{
  font-size: clamp(28px, 4vw, 44px);
  letter-spacing: .2px;
  color: var(--accent-3);
  position: relative;
  display: inline-block;
  padding-bottom: 12px;
}
.section-title h2::after{
  content:"";
  position:absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 0;
  width: 92px;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(214,180,131,.95), transparent);
}
.section-title p{
  color: var(--muted);
  max-width: 820px;
  margin: 12px auto 0;
  font-size: 16px;
}

/* ------------------------------
   Header / Nav (Public)
-------------------------------- */
header{
  position: fixed;
  top:0; left:0;
  width:100%;
  z-index:1000;
  background: rgba(246, 241, 232, .78);
  border-bottom: 1px solid rgba(30,27,22,.10);
  backdrop-filter: blur(14px);
}

.navbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 14px 0;
  gap: 14px;
}

.brand{
  display:flex;
  align-items:center;
  gap: 12px;
  color: var(--ink);
}

.brand-badge{
  width: 42px;
  height: 42px;
  border-radius: 14px;
  background:
    radial-gradient(14px 14px at 35% 35%, rgba(214,180,131,.95), transparent 60%),
    radial-gradient(18px 18px at 70% 70%, rgba(176,122,63,.70), transparent 60%),
    linear-gradient(145deg, #2e2218, #1b140f);
  box-shadow: 0 14px 28px rgba(30,27,22,.22);
  border: 1px solid rgba(214,180,131,.25);
}

.brand-text{
  display:flex;
  flex-direction: column;
  line-height: 1.15;
}
.brand-text strong{
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size: 15px;
  letter-spacing: .6px;
  text-transform: uppercase;
}
.brand-text span{
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size: 12px;
  color: rgba(30,27,22,.70);
  letter-spacing: .3px;
}

nav ul{
  list-style:none;
  display:flex;
  align-items:center;
  gap: 8px;
}

nav a{
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 800;
  font-size: 12px;
  letter-spacing: .55px;
  text-transform: uppercase;
  color: var(--accent-3);
  padding: 10px 12px;
  border-radius: 999px;
  transition: all .18s ease;
  border: 1px solid transparent;
}

nav a:hover{
  background: rgba(214,180,131,.20);
  border-color: rgba(176,122,63,.20);
  text-decoration: none;
}

.menu-toggle{
  display:none;
  border: 1px solid rgba(30,27,22,.14);
  background: rgba(255,255,255,.55);
  padding: 10px 12px;
  border-radius: 999px;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 900;
  letter-spacing: .4px;
}

/* Mobile dropdown when header has .open */
header.open nav ul{
  display:flex;
  position:absolute;
  top: 70px;
  left: 4%;
  right: 4%;
  flex-direction: column;
  gap: 6px;
  background: rgba(246,241,232,.96);
  border: 1px solid rgba(30,27,22,.10);
  border-radius: 18px;
  padding: 12px;
  box-shadow: var(--shadow);
}
header.open nav a{
  padding: 12px 12px;
  border-radius: 14px;
}

/* ------------------------------
   Buttons (Public)
-------------------------------- */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  text-decoration:none;
  padding: 12px 16px;
  border-radius: 999px;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 900;
  letter-spacing: .4px;
  text-transform: uppercase;
  font-size: 12px;
  border: 1px solid rgba(30,27,22,.14);
  transition: transform .18s ease, filter .18s ease, background .18s ease;
  cursor:pointer;
}

.btn.primary{
  background: linear-gradient(180deg, rgba(214,180,131,.96), rgba(176,122,63,.92));
  color: #1b140f;
  border-color: rgba(176,122,63,.25);
  box-shadow: 0 14px 28px rgba(176,122,63,.18);
}
.btn.primary:hover{ filter: brightness(.98); transform: translateY(-1px); text-decoration:none; }

.btn.ghost{
  background: rgba(255,255,255,.55);
  color: var(--accent-3);
}
.btn.ghost:hover{ background: rgba(255,255,255,.70); transform: translateY(-1px); text-decoration:none; }

/* ------------------------------
   Hero (Public)
-------------------------------- */
.hero{
  position: relative;
  min-height: 560px;
  display:flex;
  align-items:center;
  overflow:hidden;
  background: #1b140f;
}

.hero-bg{
  position:absolute;
  inset:0;
  background-size: cover;
  background-position: center;
  transform: scale(1.06);
  filter: saturate(1.06) contrast(1.05);
}

/* cinematic overlay */
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(800px 520px at 22% 30%, rgba(214,180,131,.18), transparent 62%),
    radial-gradient(900px 560px at 80% 85%, rgba(176,122,63,.12), transparent 62%),
    linear-gradient(90deg, rgba(27,20,15,.78), rgba(27,20,15,.35) 55%, rgba(27,20,15,.62));
  z-index: 1;
}

.hero-inner{
  position: relative;
  z-index: 2;
  width: min(var(--max), 92%);
  margin: 0 auto;
  padding: 118px 0 86px;
}

.hero-card{
  max-width: 760px;
  padding: 28px 26px;
  border-radius: var(--radius);
  border: 1px solid rgba(214,180,131,.22);
  background: linear-gradient(180deg, rgba(0,0,0,.32), rgba(0,0,0,.22));
  box-shadow: 0 28px 80px rgba(0,0,0,.35);
  backdrop-filter: blur(6px);
}

.hero h1{
  color: #fff;
  font-size: clamp(36px, 5vw, 60px);
  line-height: 1.05;
  letter-spacing: .2px;
  text-shadow: 0 18px 48px rgba(0,0,0,.60);
}
.hero p{
  color: rgba(255,255,255,.86);
  margin-top: 12px;
  font-size: 16px;
  max-width: 640px;
}
.hero-actions{
  display:flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 18px;
}

/* ------------------------------
   Info Strip (Public)
-------------------------------- */
.info-strip{
  margin-top: -44px;
  position: relative;
  z-index: 3;
}

.info-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.info-card{
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(30,27,22,.08);
  border-radius: var(--radius);
  box-shadow: var(--shadow-soft);
  padding: 18px 16px;
  display:flex;
  gap: 12px;
  align-items:flex-start;
}

.info-icon{
  width: 44px;
  height: 44px;
  border-radius: 16px;
  background: rgba(214,180,131,.22);
  border: 1px solid rgba(176,122,63,.18);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size: 20px;
}

.info-card strong{
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  letter-spacing: .3px;
}
.info-card span{
  display:block;
  color: var(--muted);
  font-size: 13px;
  margin-top: 4px;
}

/* ------------------------------
   Grid / Cards (Public)
-------------------------------- */
.grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin-top: 26px;
}

.card{
  background: var(--surface);
  border-radius: var(--radius);
  border: 1px solid rgba(30,27,22,.08);
  box-shadow: var(--shadow);
  overflow:hidden;
  transition: transform .18s ease, box-shadow .18s ease;
}

.card:hover{
  transform: translateY(-3px);
  box-shadow: 0 22px 60px rgba(30,27,22,.14);
}

.card img{
  width:100%;
  height: 230px;
  object-fit: cover;
  display:block;
  filter: saturate(1.03) contrast(1.02);
}

.card-body{
  padding: 16px 16px 18px;
}

.card-body h3{
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-size: 18px;
  margin-bottom: 8px;
  color: var(--accent-3);
}

.card-body p{
  color: var(--muted);
  font-size: 14px;
}

/* Premium price */
.price{
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px solid rgba(30,27,22,.08);
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 950;
  letter-spacing: .4px;
  color: var(--accent);
}

.muted{ color: var(--muted); opacity: .92; }

/* ------------------------------
   Menu Toolbar / Pills / Search (Public)
-------------------------------- */
.menu-toolbar{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap: 12px;
  flex-wrap:wrap;
  margin-top: 22px;
  padding: 14px;
  border-radius: var(--radius);
  background: rgba(255,255,255,.70);
  border: 1px solid rgba(30,27,22,.08);
  box-shadow: var(--shadow-soft);
}

.search{ flex:1; min-width: 240px; }

.search input{
  width:100%;
  padding: 13px 14px;
  border-radius: 999px;
  border: 1px solid rgba(30,27,22,.12);
  background: rgba(255,255,255,.92);
  outline:none;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 750;
  letter-spacing: .2px;
}

.search input:focus{
  border-color: rgba(176,122,63,.35);
  box-shadow: 0 0 0 4px rgba(214,180,131,.22);
}

.pills{
  display:flex;
  flex-wrap:wrap;
  gap: 10px;
}

.pill{
  padding: 10px 13px;
  border-radius: 999px;
  border: 1px solid rgba(30,27,22,.12);
  background: rgba(255,255,255,.78);
  cursor:pointer;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 900;
  font-size: 12px;
  letter-spacing: .35px;
  text-transform: uppercase;
  transition: background .18s ease, transform .18s ease, border-color .18s ease;
}

.pill:hover{
  background: rgba(214,180,131,.22);
  border-color: rgba(176,122,63,.22);
  transform: translateY(-1px);
}

.pill.active{
  background: rgba(176,122,63,.18);
  border-color: rgba(176,122,63,.30);
  box-shadow: 0 10px 24px rgba(176,122,63,.12);
}

/* ------------------------------
   Forms (Public)
-------------------------------- */
.form{
  max-width: 860px;
  margin: 0 auto;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(30,27,22,.08);
  border-radius: var(--radius);
  box-shadow: var(--shadow-soft);
  padding: 18px;
}

.form .row{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.form label{
  display:block;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 900;
  font-size: 12px;
  letter-spacing: .5px;
  text-transform: uppercase;
  margin-bottom: 6px;
  color: var(--accent-3);
}

.form input, .form textarea{
  width:100%;
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid rgba(30,27,22,.12);
  background: rgba(255,255,255,.92);
  outline:none;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 650;
  color: var(--ink);
}

.form textarea{ min-height: 150px; resize: vertical; }

.form input:focus, .form textarea:focus{
  border-color: rgba(176,122,63,.35);
  box-shadow: 0 0 0 4px rgba(214,180,131,.22);
}

.form .actions{
  margin-top: 12px;
  display:flex;
  gap: 12px;
  flex-wrap: wrap;
}

.form button{ border:0; cursor:pointer; }

/* ------------------------------
   Gallery Grid + Lightbox (Public)
-------------------------------- */
.gallery-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin-top: 26px;
}

.gallery-item{
  position: relative;
  border-radius: var(--radius);
  overflow:hidden;
  border: 1px solid rgba(30,27,22,.08);
  box-shadow: var(--shadow-soft);
  background: #fff;
  cursor: pointer;
  transition: transform .18s ease, box-shadow .18s ease;
}

.gallery-item:hover{
  transform: translateY(-2px);
  box-shadow: 0 20px 50px rgba(30,27,22,.14);
}

.gallery-item img{
  width: 100%;
  height: 220px;
  object-fit: cover;
  display:block;
  transition: transform .4s ease;
}

.gallery-item:hover img{
  transform: scale(1.06);
}

/* Hover overlay */
.gallery-item::after{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(
    to top,
    rgba(27,20,15,.75),
    rgba(27,20,15,.35),
    transparent 60%
  );
  opacity:0;
  transition: opacity .35s ease;

  /* ✅ IMPORTANT: never block clicks (fixes admin issue too) */
  pointer-events: none;
}

.gallery-item:hover::after{
  opacity:1;
}

/* Caption */
.gallery-caption{
  position:absolute;
  bottom:16px;
  left:16px;
  right:16px;
  z-index:2;
  color:#fff;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight:900;
  letter-spacing:.4px;
  text-transform:uppercase;
  font-size:12px;
  opacity:0;
  transform: translateY(10px);
  transition: all .35s ease;
  text-shadow: 0 10px 30px rgba(0,0,0,.55);
}

.gallery-item:hover .gallery-caption{
  opacity:1;
  transform: translateY(0);
}

/* Lightbox overlay */
.lightbox{
  position: fixed;
  inset: 0;
  background: rgba(12, 9, 7, .78);
  display:none;
  align-items:center;
  justify-content:center;
  padding: 22px;
  z-index: 9999;
}
.lightbox.open{ display:flex; }

.lightbox-inner{
  width: min(980px, 95%);
  background: rgba(255,255,255,.92);
  border-radius: var(--radius);
  overflow:hidden;
  border: 1px solid rgba(214,180,131,.18);
  box-shadow: 0 40px 120px rgba(0,0,0,.45);
}

.lightbox-inner img{
  width:100%;
  height: auto;
  display:block;
}

.lightbox-bar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
  padding: 12px 14px;
  background: rgba(246,241,232,.92);
  border-top: 1px solid rgba(30,27,22,.10);
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

.lightbox-title{
  font-weight: 900;
  letter-spacing: .3px;
  color: var(--accent-3);
  font-size: 13px;
  text-transform: uppercase;
}

.lightbox-close{
  border: 1px solid rgba(30,27,22,.14);
  background: rgba(255,255,255,.75);
  padding: 10px 12px;
  border-radius: 999px;
  font-weight: 900;
  cursor:pointer;
}

/* ============================================================
   ✅ ADMIN SAFETY OVERRIDES
   Prevent public gallery “tile” effects from breaking admin UI
   Requires: <body class="admin">
   ============================================================ */

/* If admin uses .gallery-item for cards, disable the tile behavior */
body.admin .gallery-item{
  cursor: default;
  transform: none !important;
  box-shadow: 0 16px 40px rgba(0,0,0,.35);
}

body.admin .gallery-item:hover{
  transform: none !important;
}

/* remove overlay + caption on admin so nothing sits above controls */
body.admin .gallery-item::after{
  display: none !important;
  opacity: 0 !important;
}

body.admin .gallery-caption{
  display: none !important;
}

/* stop image zoom on admin (keeps it calm + avoids “clickable” feel) */
body.admin .gallery-item img,
body.admin .gallery-item:hover img{
  transform: none !important;
  transition: none !important;
}

/* make sure admin form controls are always clickable */
body.admin .gallery-item button,
body.admin .gallery-item a,
body.admin .gallery-item input,
body.admin .gallery-item select,
body.admin .gallery-item textarea,
body.admin .gallery-item label{
  position: relative;
  z-index: 5;
}

/* ------------------------------
   Footer (Public)
-------------------------------- */
footer{
  margin-top: 46px;
  background:
    radial-gradient(900px 520px at 25% 20%, rgba(214,180,131,.10), transparent 60%),
    linear-gradient(180deg, #241a12, #16100b);
  color: rgba(255,255,255,.88);
  padding: 54px 0;
  border-top: 1px solid rgba(214,180,131,.12);
}

.footer-grid{
  display:grid;
  grid-template-columns: 1.1fr 1fr 1fr;
  gap: 18px;
}

footer h4{
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  margin-bottom: 10px;
  letter-spacing: .4px;
  text-transform: uppercase;
  font-size: 13px;
}

footer p, footer a{
  color: rgba(255,255,255,.78);
  font-size: 14px;
  text-decoration:none;
}

footer a:hover{
  color: #fff;
  text-decoration: underline;
}

.footer-bottom{
  border-top: 1px solid rgba(255,255,255,.12);
  margin-top: 18px;
  padding-top: 14px;
  display:flex;
  justify-content:space-between;
  gap: 10px;
  flex-wrap:wrap;
  font-size: 13px;
  color: rgba(255,255,255,.65);
}

/* ============================================================
   ADMIN THEME (scoped) — matches your classy dark dashboard
   Use: <body class="admin">
   ============================================================ */

body.admin{
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: #f2f2f2;
  background:
    radial-gradient(1200px 600px at 10% 10%, rgba(255,204,0,.10), transparent 60%),
    radial-gradient(1200px 600px at 90% 90%, rgba(255,204,0,.08), transparent 60%),
    #0f0f10;
  line-height: 1.6;
}

/* prevent public fixed header from affecting admin */
body.admin header{ display:none; }

.admin-container{
  width: min(1200px, 92%);
  margin: 0 auto;
}

.admin-topbar{
  position: sticky;
  top: 0;
  z-index: 1000;
  background: rgba(15,15,16,.78);
  border-bottom: 1px solid rgba(255,255,255,.10);
  backdrop-filter: blur(14px);
}

.admin-topbar .row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 14px;
  padding: 14px 0;
}

.admin-brand{
  display:flex;
  align-items:center;
  gap: 10px;
}

.admin-dot{
  width: 14px;
  height: 14px;
  border-radius: 6px;
  background: #ffcc00;
  box-shadow: 0 0 0 4px rgba(255,204,0,.12);
}

.admin-brand strong{
  font-size: 14px;
  letter-spacing: .4px;
}
.admin-brand span{
  display:block;
  font-size: 12px;
  color: rgba(255,255,255,.65);
  margin-top: 2px;
}

.admin-actions{
  display:flex;
  align-items:center;
  gap: 10px;
}

.admin-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  color: #fff;
  font-weight: 850;
  letter-spacing: .25px;
  text-decoration:none;
  cursor:pointer;
}
.admin-btn:hover{ background: rgba(255,255,255,.10); text-decoration:none; }

.admin-btn.primary{
  background: #ffcc00;
  color: #111;
  border-color: rgba(255,204,0,.35);
}
.admin-btn.primary:hover{ filter: brightness(.97); }

.admin-main{
  padding: 34px 0 60px;
}

.admin-heading h1{
  font-size: 28px;
  margin: 0 0 6px;
}
.admin-heading p{
  color: rgba(255,255,255,.70);
  max-width: 680px;
}

.admin-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 18px;
}

.admin-card{
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 16px;
  padding: 16px;
  box-shadow: 0 16px 40px rgba(0,0,0,.35);
  min-height: 180px;
}

.admin-card h3{
  margin: 0 0 6px;
  font-size: 14px;
  font-weight: 900;
  letter-spacing: .3px;
}
.admin-card p{
  color: rgba(255,255,255,.70);
  font-size: 13px;
  margin: 0 0 12px;
}

.admin-metrics{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
  margin: 8px 0 12px;
}

.metric-pill{
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(0,0,0,.25);
  border: 1px solid rgba(255,255,255,.10);
  font-size: 12px;
  font-weight: 850;
  color: rgba(255,255,255,.85);
}

.admin-card .btn-row{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
}

.admin-note{
  margin-top: 14px;
  padding: 12px 12px;
  border-radius: 12px;
  background: rgba(255,204,0,.08);
  border: 1px solid rgba(255,204,0,.20);
  color: rgba(255,204,0,.92);
  font-size: 12px;
  line-height: 1.45;
  font-weight: 750;
}

/* admin forms */
.admin-form{
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 16px;
  padding: 18px;
  box-shadow: 0 16px 40px rgba(0,0,0,.35);
}

.admin-form label{
  display:block;
  margin: 12px 0 6px;
  font-weight: 900;
  font-size: 12px;
  letter-spacing: .35px;
  color: rgba(255,255,255,.90);
  text-transform: uppercase;
}

.admin-form input,
.admin-form textarea,
.admin-form select{
  width: 100%;
  padding: 12px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.30);
  color: #fff;
  outline: none;
}

.admin-form input:focus,
.admin-form textarea:focus,
.admin-form select:focus{
  border-color: rgba(255,204,0,.45);
  box-shadow: 0 0 0 4px rgba(255,204,0,.12);
}

.admin-form textarea{ min-height: 140px; resize: vertical; }

.admin-alert{
  margin: 0 0 12px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,0,0,.22);
  background: rgba(255,0,0,.10);
  color: #ffd5d5;
  font-size: 13px;
}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 1100px){
  .gallery-grid{ grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 980px){
  .grid{ grid-template-columns: repeat(2, 1fr); }
  .info-grid{ grid-template-columns: 1fr; }
  .footer-grid{ grid-template-columns: 1fr; }
  .gallery-grid{ grid-template-columns: repeat(2, 1fr); }

  .admin-grid{ grid-template-columns: 1fr; }
}

@media (max-width: 720px){
  nav ul{ display:none; }
  .menu-toggle{ display:inline-flex; }
  .grid{ grid-template-columns: 1fr; }
  .form .row{ grid-template-columns: 1fr; }
  .hero-inner{ padding: 110px 0 70px; }
  .hero{ min-height: 520px; }
  .gallery-grid{ grid-template-columns: 1fr; }
}
/* ============================================================
   ADMIN LIGHT MODE (for gallery page)
   Use: <body class="admin admin-light">
   Keeps admin click-safety, but uses the public earth-tone look
   ============================================================ */

body.admin.admin-light{
  /* restore the public look */
  font-family: ui-serif, Georgia, "Times New Roman", Times, serif;
  color: var(--ink);
  background:
    radial-gradient(900px 600px at 15% 10%, rgba(176,122,63,.10), transparent 60%),
    radial-gradient(850px 540px at 85% 85%, rgba(107,74,45,.08), transparent 60%),
    linear-gradient(180deg, rgba(214,180,131,.10), transparent 35%),
    var(--bg);
}

/* show the header again on light admin pages */
body.admin.admin-light header{ display:block; }

/* make sure text is readable */
body.admin.admin-light .section-title p,
body.admin.admin-light .muted{
  color: var(--muted);
}

/* keep admin cards behaving like admin (no overlay / no “tile click”) */
body.admin.admin-light .gallery-item{ cursor: default; }
body.admin.admin-light .gallery-item::after{ display:none !important; }
body.admin.admin-light .gallery-caption{ display:none !important; }

/* =========================
   ABOUT PAGE ENHANCEMENTS
   ========================= */

.about-notes{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:14px;
  margin-top:-28px; /* pulls cards closer to hero like homepage */
}

@media (max-width: 980px){
  .about-notes{ grid-template-columns: 1fr; margin-top:12px; }
}

.note-card{
  display:flex;
  gap:12px;
  align-items:flex-start;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(30,27,22,.10);
  border-radius: 14px;
  padding: 14px 14px;
  box-shadow: 0 10px 22px rgba(0,0,0,.08);
  backdrop-filter: blur(8px);
}

.note-ico{
  width:38px;
  height:38px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(214,180,131,.18);
  border: 1px solid rgba(176,122,63,.18);
  font-size:18px;
  flex: 0 0 auto;
}

.note-card h3{
  margin:0 0 4px;
  font-size:15px;
  font-weight:900;
  letter-spacing:.2px;
}

.note-card p{
  margin:0;
  font-size:13px;
  color: rgba(30,27,22,.70);
  line-height:1.45;
}

.about-grid{
  display:grid;
  grid-template-columns: 1.35fr .65fr;
  gap:14px;
}

@media (max-width: 980px){
  .about-grid{ grid-template-columns: 1fr; }
}

.about-prose p{
  margin:0 0 14px;
  line-height:1.8;
  font-size:16px;
}

.about-h3{
  margin:0 0 10px;
  font-size:18px;
  font-weight:900;
}

.about-kv{
  display:flex;
  flex-direction:column;
  gap:8px;
  font-size:14px;
  line-height:1.5;
}

.about-side-actions{
  margin-top:12px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.about-socials{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:10px;
}

.about-list{
  margin:0;
  padding-left:18px;
}

.about-list li{
  margin:8px 0;
  line-height:1.6;
}
