
:root{
  --bg:#f6f0e8;
  --surface:#fffdf9;
  --surface-2:#f2e9dc;
  --surface-3:#f9f4ec;
  --ink:#2f2a26;
  --muted:#6f685f;
  --line:#e7dccf;
  --olive:#6e7b52;
  --olive-dark:#4c573b;
  --terracotta:#b36a4c;
  --gold:#c7a86c;
  --danger:#a34f4f;
  --radius:30px;
  --radius-sm:18px;
  --shadow:0 20px 56px rgba(47,42,38,.08);
  --shadow-lg:0 28px 90px rgba(47,42,38,.12);
  --container:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter, Arial, Helvetica, sans-serif;
  color:var(--ink);
  background:
    url('../images/decor/pattern.svg') top right / 320px auto no-repeat,
    radial-gradient(circle at top left, rgba(199,168,108,.18), transparent 18%),
    linear-gradient(180deg, #f1e8dc 0%, #fbf7f1 320px, var(--bg) 100%);
  line-height:1.65;
}
body.admin{
  background:
    url('../images/decor/pattern.svg') top right / 280px auto no-repeat,
    linear-gradient(180deg,#efe5d6 0%,#faf7f2 240px,#f7f2eb 100%);
}
img{max-width:100%; display:block}
a{text-decoration:none;color:inherit}
button,input,select,textarea{font:inherit}
.container{width:min(calc(100% - 2rem), var(--container)); margin-inline:auto}
.section{padding:62px 0}
.section-head{display:flex;justify-content:space-between;align-items:end;gap:1rem;margin-bottom:1.4rem}
.section-head h2,.hero h1,.author-hero h1,.article-hero h1,.split-card h2,.dashboard-layout h1,.post-card h3,.aside-card h3,.stat-card strong,.feature-tile h3,.quote-band blockquote{
  font-family:Georgia, "Times New Roman", serif;
}
.eyebrow{display:inline-block;font-size:.8rem;text-transform:uppercase;letter-spacing:.16em;color:var(--olive);font-weight:700}
.text-muted{color:var(--muted)}
.lead{font-size:1.12rem; color:var(--muted); max-width:65ch}
.site-header{
  position:sticky; top:0; z-index:25;
  background:rgba(246,240,232,.84);
  border-bottom:1px solid rgba(199,168,108,.22);
  backdrop-filter:blur(14px);
}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;padding:14px 0;gap:16px}
.brand img{width:250px}
.nav{display:flex;align-items:center;gap:22px;flex-wrap:wrap}
.nav a{font-size:.96rem;color:var(--muted)}
.nav a:hover{color:var(--olive)}
.nav .nav-cta{padding:11px 16px;border-radius:999px;background:var(--olive);color:#fff;font-weight:700;box-shadow:var(--shadow)}
.nav .nav-cta:hover{background:var(--olive-dark)}
.hero{
  padding:86px 0 50px;
  position:relative;
  overflow:hidden;
}
.hero:after{
  content:""; position:absolute; inset:auto 0 -6px 0; height:170px;
  background:url('../images/decor/skyline.svg') center bottom / cover no-repeat;
  opacity:.14; pointer-events:none;
}
.hero__layout{display:grid;grid-template-columns:1.02fr .98fr;gap:34px;align-items:center;position:relative;z-index:1}
.hero h1{font-size:clamp(2.9rem,5vw,4.9rem);line-height:1.02;margin:.45rem 0 1rem}
.hero-copy{position:relative}
.hero-copy .actions-row{margin-top:1.5rem}
.meta-strip{display:flex;flex-wrap:wrap;gap:10px;margin-top:1.6rem}
.meta-pill, .meta-chip{
  display:inline-flex; align-items:center; gap:8px; padding:10px 14px; border-radius:999px; background:#fff; border:1px solid var(--line); color:var(--muted); font-size:.92rem
}
.meta-chip--soft{background:#fcfaf5}
.meta-chip--link{color:var(--olive);font-weight:700}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:13px 20px;border-radius:999px;border:none;cursor:pointer;
  background:var(--olive);color:#fff;font-weight:700;box-shadow:none
}
.btn:hover{background:var(--olive-dark)}
.btn--ghost{background:transparent;color:var(--olive);border:1px solid var(--line)}
.btn--ghost:hover{background:#fff}
.btn--light{background:#fff;color:var(--ink);border:1px solid var(--line)}
.btn--sm{padding:10px 15px;font-size:.92rem}
.text-link{color:var(--terracotta);font-weight:700}
.hero-visual{position:relative;min-height:560px}
.hero-photo-card{
  position:absolute; right:16px; top:18px; width:min(82%, 450px);
  background:var(--surface); border:1px solid rgba(255,255,255,.6); border-radius:36px; padding:18px; box-shadow:var(--shadow-lg);
  transform:rotate(2deg);
}
.hero-photo-card img{border-radius:26px; aspect-ratio:4/5; object-fit:cover}
.hero-notes{
  position:absolute; left:0; top:76px; z-index:3;
  display:flex; flex-direction:column; gap:16px; width:min(46%,250px)
}
.floating-card{
  position:relative; background:rgba(255,253,249,.95); border:1px solid var(--line);
  border-radius:24px; padding:18px; box-shadow:var(--shadow); backdrop-filter:blur(8px)
}
.floating-card strong{display:block;font-size:1.2rem}
.floating-card p{margin:.4rem 0 0;color:var(--muted);font-size:.95rem}
.floating-card--a,.floating-card--b{left:auto; top:auto; bottom:auto; width:auto}
.floating-thumb{
  position:absolute; right:60px; bottom:20px; width:200px; background:var(--surface); border-radius:24px; padding:10px; border:1px solid var(--line); box-shadow:var(--shadow); transform:rotate(-6deg)
}
.floating-thumb img{border-radius:18px; aspect-ratio:1.1/1; object-fit:cover}
.decor-ring{
  position:absolute; right:-20px; top:-18px; width:140px; height:140px; border:2px solid rgba(199,168,108,.35); border-radius:50%
}
.decor-ring:after{
  content:""; position:absolute; inset:18px; border:1px dashed rgba(199,168,108,.5); border-radius:50%
}
.stats-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}
.stat-card{
  background:linear-gradient(180deg,#fffdf9,#faf6ef); border:1px solid var(--line); border-radius:26px; padding:22px; box-shadow:var(--shadow); position:relative; overflow:hidden
}
.stat-card:after{
  content:""; position:absolute; right:-22px; top:-22px; width:76px; height:76px; border-radius:50%; background:rgba(199,168,108,.12)
}
.stat-card__icon{width:52px; margin-bottom:12px}
.stat-card span{display:block;color:var(--muted);font-size:.95rem}
.stat-card strong{display:block;font-size:2rem;margin-top:.35rem}
.posts-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px}
.post-card{
  display:flex; flex-direction:column; background:var(--surface); border:1px solid var(--line); border-radius:28px; overflow:hidden; box-shadow:var(--shadow); position:relative
}
.post-card:before{
  content:""; position:absolute; left:20px; right:20px; top:20px; height:1px; background:linear-gradient(90deg, transparent, rgba(199,168,108,.65), transparent); opacity:.8
}
.post-card__image{aspect-ratio:16/10; overflow:hidden; background:var(--surface-2)}
.post-card__image img{width:100%;height:100%;object-fit:cover;transition:transform .35s ease}
.post-card:hover .post-card__image img{transform:scale(1.03)}
.post-card__body{padding:20px; display:flex; flex-direction:column; gap:10px; flex:1}
.post-card__body h3{font-size:1.55rem;line-height:1.15;margin:0}
.post-card__body p{margin:0;color:var(--muted)}
.post-card__body .card__subtitle{color:var(--terracotta)}
.post-card__actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:auto;padding-top:8px}
.quote-band{
  display:grid; grid-template-columns:80px 1fr; gap:18px; align-items:start;
  padding:24px; border-radius:30px; background:linear-gradient(135deg,#fbf7ef,#f4eadf); border:1px solid rgba(199,168,108,.36); box-shadow:var(--shadow)
}
.quote-band img{width:72px}
.quote-band blockquote{margin:0;font-size:1.5rem;line-height:1.22}
.quote-band p{margin:.65rem 0 0;color:var(--muted)}
.feature-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px}
.feature-tile{
  background:var(--surface); border:1px solid var(--line); border-radius:28px; padding:22px; box-shadow:var(--shadow)
}
.feature-tile img{width:66px;margin-bottom:12px}
.feature-tile h3{margin:.2rem 0 .55rem;font-size:1.5rem}
.feature-tile p{margin:0;color:var(--muted)}
.split-card{
  display:grid;grid-template-columns:.92fr 1.08fr;gap:28px;align-items:center;
  background:var(--surface); border:1px solid var(--line); border-radius:34px; padding:24px; box-shadow:var(--shadow); position:relative; overflow:hidden
}
.split-card:after{
  content:""; position:absolute; right:-30px; top:-30px; width:180px; height:180px; background:rgba(199,168,108,.12); border-radius:50%
}
.split-card img{border-radius:22px; aspect-ratio:4/5; object-fit:cover; box-shadow:var(--shadow)}
.split-card h2{font-size:2.2rem;margin:.4rem 0 .8rem}
.cta-band{
  background:linear-gradient(135deg, rgba(110,123,82,.98), rgba(81,91,59,.96)); color:#fff; border-radius:34px; padding:34px; box-shadow:var(--shadow-lg); position:relative; overflow:hidden
}
.cta-band:after{
  content:""; position:absolute; inset:auto -40px -40px auto; width:240px; height:240px; background:rgba(255,255,255,.06); border-radius:50%
}
.cta-band h2{margin:.4rem 0 .7rem;font-size:2.3rem;font-family:Georgia,serif}
.cta-band p{max-width:68ch;color:rgba(255,255,255,.88)}
.cta-band .btn{background:#fff;color:var(--olive-dark)}
.footer{padding:28px 0 40px;border-top:1px solid rgba(199,168,108,.28);color:var(--muted);margin-top:40px}
.footer__inner{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap}
.footer-credit{display:inline-block;margin-left:10px}
.footer-credit__link{text-decoration:none}
.footer-credit__name{color:var(--olive);font-weight:800}

.search-bar{
  display:grid; grid-template-columns:1fr auto; gap:14px; align-items:center; margin:0 0 24px;
  background:var(--surface); border:1px solid var(--line); border-radius:24px; padding:16px; box-shadow:var(--shadow)
}
.search-input{
  width:100%; min-width:240px; padding:14px 16px; border-radius:18px; border:1px solid var(--line); background:#fff
}
.filter-chips{display:flex;gap:10px;flex-wrap:wrap}
.filter-chip{
  padding:11px 14px;border-radius:999px;border:1px solid var(--line);background:#fff;color:var(--muted);cursor:pointer
}
.filter-chip.is-active{background:var(--olive);border-color:var(--olive);color:#fff}
.empty-state{
  padding:34px; border:1px dashed var(--line); border-radius:28px; background:rgba(255,255,255,.55); text-align:center; color:var(--muted)
}
.blog-banner{
  padding:64px 0 36px; position:relative; overflow:hidden
}
.blog-banner:before{
  content:""; position:absolute; inset:0; background:
  linear-gradient(135deg, rgba(255,255,255,.25), rgba(255,255,255,0)),
  url('../images/decor/skyline.svg') bottom center / 120% auto no-repeat;
  opacity:.15; pointer-events:none
}
.blog-banner__panel{
  position:relative; background:linear-gradient(135deg,#fffdf9,#f7efe2); border:1px solid var(--line); border-radius:36px; padding:32px; box-shadow:var(--shadow-lg)
}
.blog-banner h1{margin:.35rem 0 1rem;font-size:3.4rem;font-family:Georgia,serif}
.blog-banner__art{
  position:absolute; right:26px; top:26px; width:210px; background:#fff; border-radius:24px; padding:10px; box-shadow:var(--shadow); transform:rotate(5deg)
}
.blog-banner__art img{border-radius:16px; aspect-ratio:1/1; object-fit:cover}
.article-hero{padding:52px 0 24px; position:relative; overflow:hidden}
.article-hero:after{
  content:""; position:absolute; right:0; top:0; width:220px; height:220px; background:rgba(199,168,108,.14); border-radius:50%; transform:translate(25%,-25%)
}
.article-hero__content{max-width:900px; position:relative; z-index:1}
.article-hero h1{font-size:clamp(2.5rem,4.5vw,4.3rem);line-height:1.05;margin:.4rem 0 .8rem}
.article-subtitle{font-family:Georgia,serif;font-size:clamp(1.1rem,2vw,1.4rem);color:#6f685f;font-style:italic;margin:-.2rem 0 1rem;line-height:1.4}
.article-subtitle{font-size:1.12rem;color:var(--terracotta);margin:0 0 1rem}
.article-layout{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:28px;align-items:start;padding-bottom:20px}
.article-panel{
  background:var(--surface); border:1px solid var(--line); border-radius:32px; box-shadow:var(--shadow); overflow:hidden
}
.article-image{padding:16px}
.article-image img{border-radius:24px; aspect-ratio:16/10; object-fit:cover}
.article-body{padding:0 32px 32px}
.article-body p, .article-body blockquote{font-size:1.1rem}
.article-body h2{font-family:Georgia,serif;font-size:1.5rem;line-height:1.25;color:#2f2a26;margin:2rem 0 .75rem;padding-bottom:.4rem;border-bottom:1px solid var(--line)}
.article-body h3{font-family:Georgia,serif;font-size:1.2rem;line-height:1.3;color:#433d38;margin:1.5rem 0 .5rem}
.article-body blockquote{
  margin:0 0 1rem; padding:16px 18px; background:#fbf7ef; border-left:4px solid var(--gold); border-radius:0 18px 18px 0; color:#433d38
}
.aside-card{
  position:sticky; top:96px; background:var(--surface); border:1px solid var(--line); border-radius:28px; padding:20px; box-shadow:var(--shadow); overflow:hidden
}
.aside-card:before{
  content:""; display:block; height:100px; margin:-20px -20px 16px; background:linear-gradient(135deg,#f4eadf,#fff8ee);
  border-bottom:1px solid var(--line)
}
.aside-card img{border-radius:18px; aspect-ratio:4/5; object-fit:cover; margin:-74px 0 16px; position:relative; z-index:1; box-shadow:var(--shadow)}
.aside-card h3{font-size:1.7rem;margin:.35rem 0}
.author-hero{padding:74px 0 36px; position:relative}
.author-hero:after{
  content:""; position:absolute; left:0; right:0; bottom:0; height:160px; background:url('../images/decor/skyline.svg') center bottom/cover no-repeat; opacity:.12
}
.author-layout{display:grid;grid-template-columns:.9fr 1.1fr;gap:34px;align-items:center;position:relative;z-index:1}
.author-layout img{border-radius:28px; aspect-ratio:4/5; object-fit:cover; box-shadow:var(--shadow-lg)}
.author-copy{
  background:var(--surface); border:1px solid var(--line); border-radius:32px; padding:28px; box-shadow:var(--shadow)
}
.author-copy h1{font-size:clamp(2.3rem,4vw,4rem);line-height:1.05;margin:.4rem 0 1rem}
.panel{
  background:var(--surface); border:1px solid var(--line); border-radius:30px; padding:24px; box-shadow:var(--shadow)
}
.login-shell{min-height:calc(100vh - 80px);display:grid;place-items:center;padding:40px 0}
.login-layout{
  width:min(calc(100% - 2rem), 1120px); display:grid; grid-template-columns:1.08fr .92fr; gap:28px; align-items:stretch
}
.login-promo{
  background:
    linear-gradient(135deg, rgba(110,123,82,.97), rgba(179,106,76,.9)),
    url('../images/decor/pattern.svg') right bottom/280px auto no-repeat;
  color:#fff; border-radius:38px; padding:34px; box-shadow:var(--shadow-lg); position:relative; overflow:hidden
}
.login-promo:after{
  content:""; position:absolute; inset:auto -60px -60px auto; width:230px; height:230px; border-radius:50%;
  background:rgba(255,255,255,.08)
}
.login-promo__badge{display:inline-flex;align-items:center;gap:10px;padding:10px 14px;border-radius:999px;background:rgba(255,255,255,.12);backdrop-filter:blur(6px)}
.login-promo__badge img{width:22px}
.login-promo h2{font-size:2.5rem;line-height:1.06;margin:.7rem 0 1rem}
.login-list{padding-left:1.1rem; margin:1.2rem 0 0}
.login-visual{
  margin-top:26px; display:grid; grid-template-columns:1fr 220px; gap:16px; align-items:end
}
.login-visual__card, .login-visual__thumb{
  background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.14); border-radius:24px; padding:14px; backdrop-filter:blur(8px)
}
.login-visual__card img, .login-visual__thumb img{border-radius:16px}
.login-card{
  background:var(--surface); border:1px solid var(--line); border-radius:38px; padding:30px; box-shadow:var(--shadow-lg)
}
.form-grid{display:grid;gap:16px}
.field{display:grid;gap:8px}
.field label{font-size:.94rem;color:var(--muted);font-weight:700}
.field input,.field select,.field textarea{
  width:100%;padding:14px 16px;border-radius:18px;border:1px solid var(--line);background:#fff
}
.field textarea{min-height:120px;resize:vertical}
.error{color:#a33a3a;background:#f9ecec;border:1px solid #eccaca;padding:12px 14px;border-radius:16px}
.login-note{margin-top:16px;color:var(--muted);font-size:.94rem}
.dashboard-layout{padding:34px 0 48px}
.dashboard-layout h1{font-size:2.8rem;line-height:1.08;margin:.4rem 0 0}
.dashboard-grid{display:grid;grid-template-columns:360px minmax(0,1fr);gap:24px;margin-top:24px}
.dashboard-side,.dashboard-main{border-radius:32px; box-shadow:var(--shadow-lg); overflow:hidden}
.dashboard-side{
  background:linear-gradient(180deg,#f7efe3 0%,#fffdf9 180px); border:1px solid var(--line); padding:0 18px 18px; display:grid; gap:18px; align-content:start
}
.admin-brand-card{
  margin:0 -18px; padding:26px 20px 24px; background:linear-gradient(135deg, rgba(110,123,82,.96), rgba(179,106,76,.92)); color:#fff; position:relative; overflow:hidden
}
.admin-brand-card:after{
  content:""; position:absolute; right:-26px; top:-26px; width:150px; height:150px; border-radius:50%; background:rgba(255,255,255,.08)
}
.admin-brand-card img{width:54px; margin-bottom:10px}
.admin-brand-card strong{display:block;font-size:1.35rem}
.admin-brand-card p{margin:.45rem 0 0; color:rgba(255,255,255,.84)}
.dashboard-main{background:var(--surface); border:1px solid var(--line); padding:22px}
.dashboard-posts{display:grid; gap:14px; max-height:880px; overflow:auto; padding-right:4px}
.dashboard-post{
  display:grid; grid-template-columns:1fr auto; gap:14px; padding:16px; border:1px solid var(--line); border-radius:20px; background:#fff
}
.dashboard-post.is-selected{border-color:var(--olive); box-shadow:0 0 0 3px rgba(110,123,82,.08)}
.dashboard-post__meta{font-size:.82rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.dashboard-post h4{margin:.35rem 0 .45rem; font-size:1.1rem}
.dashboard-post p{margin:0;color:var(--muted);font-size:.95rem}
.dashboard-post__actions{display:flex;flex-direction:column;gap:8px}
.icon-btn{padding:9px 12px; border-radius:14px; border:1px solid var(--line); background:#fff; color:var(--ink); cursor:pointer}
.icon-btn.danger{color:var(--danger)}
.toolbar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.toolbar button{padding:7px 14px;border-radius:10px;border:1px solid var(--line);background:#fff;cursor:pointer;font-size:.85rem;font-weight:600;color:#4a443e;transition:background .15s,border-color .15s;min-width:38px;text-align:center}
.toolbar button:hover{background:#f3eadf;border-color:#c7a86c}
.toolbar button.toolbar-active{background:#6e7b52;color:#fff;border-color:#6e7b52}
.wysiwyg-editor{min-height:360px;border:1px solid var(--line);border-radius:14px;padding:18px 20px;background:#fff;font-family:Georgia,serif;font-size:1.05rem;line-height:1.7;color:#2f2a26;outline:none;overflow-y:auto;max-height:600px}
.wysiwyg-editor:focus{border-color:#6e7b52;box-shadow:0 0 0 3px rgba(110,123,82,.15)}
.wysiwyg-editor p{margin:0 0 .8em}
.wysiwyg-editor h2{font-size:1.4rem;font-weight:700;margin:1.2em 0 .4em;color:#2f2a26;border-bottom:1px solid var(--line);padding-bottom:.3em}
.wysiwyg-editor h3{font-size:1.15rem;font-weight:700;margin:1em 0 .3em;color:#433d38}
.wysiwyg-editor strong{font-weight:700}
.wysiwyg-editor em{font-style:italic}
.editor{min-height:300px; padding:16px 18px; border:1px solid var(--line); border-radius:20px; background:#fff; overflow:auto}
.editor:focus{outline:2px solid rgba(110,123,82,.18)}
.editor p{margin:0 0 1rem}
.dashboard-main__grid{display:grid;grid-template-columns:1.08fr .92fr;gap:18px}
.preview-card{background:#fff; border:1px solid var(--line); border-radius:20px; padding:16px}
.preview-card img{width:100%; border-radius:18px; aspect-ratio:16/10; object-fit:cover; margin-bottom:12px; background:var(--surface-2)}
.note{padding:14px 16px; border-radius:18px; background:#fbf7ef; border:1px solid rgba(199,168,108,.32); color:var(--muted)}
.actions-row{display:flex;gap:12px;flex-wrap:wrap}
.results-pill{display:inline-flex;align-items:center;gap:10px}
@media (max-width: 1040px){
  .posts-grid,.feature-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .stats-row{grid-template-columns:repeat(2,minmax(0,1fr))}
  .hero__layout,.split-card,.author-layout,.login-layout,.dashboard-grid,.dashboard-main__grid,.article-layout{grid-template-columns:1fr}
  .aside-card{position:static}
  .hero-visual{min-height:500px}
}
@media (max-width: 720px){
  .brand img{width:205px}
  .nav{gap:14px}
  .hero{padding-top:48px}
  .posts-grid,.stats-row,.feature-grid{grid-template-columns:1fr}
  .site-header__inner{padding:12px 0}
  .dashboard-layout h1{font-size:2.1rem}
  .hero-visual{min-height:430px}
  .hero-photo-card{width:min(88%,420px); right:0}
  .hero-notes{top:26px; width:min(52%,220px); gap:12px}
  .floating-card{padding:14px 15px}
  .floating-card strong{font-size:1.05rem}
  .floating-card p{font-size:.9rem}
  .floating-thumb{width:170px; right:10px}
  .search-bar{grid-template-columns:1fr}
  .blog-banner__art{position:static; width:180px; margin-top:14px}
}

.gallery-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px}
.gallery-card{background:var(--surface);border:1px solid var(--line);border-radius:26px;overflow:hidden;box-shadow:var(--shadow)}
.gallery-card img{width:100%;aspect-ratio:4/3;object-fit:cover}
.gallery-card__body{padding:16px}
.admin-table{width:100%;border-collapse:collapse;background:#fff;border-radius:22px;overflow:hidden;box-shadow:var(--shadow)}
.admin-table th,.admin-table td{padding:14px 16px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}
.admin-table th{background:#f8f1e6;color:var(--muted);font-size:.9rem;text-transform:uppercase;letter-spacing:.08em}
.admin-table tr:last-child td{border-bottom:none}
.form-panel{background:var(--surface);border:1px solid var(--line);border-radius:30px;padding:24px;box-shadow:var(--shadow)}
@media (max-width: 1040px){.gallery-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width: 720px){.gallery-grid{grid-template-columns:1fr}.admin-table{display:block;overflow:auto}}

.ldts-contact-toggle{position:fixed;right:22px;bottom:22px;z-index:999;background:#6e7b52;color:#fff;border:none;border-radius:999px;padding:14px 18px;font-weight:700;box-shadow:0 16px 40px rgba(47,42,38,.18);cursor:pointer}
.ldts-contact-toggle:hover{background:#4c573b}
.ldts-contact-panel{position:fixed;right:22px;bottom:78px;z-index:999;width:min(320px,calc(100vw - 32px));background:#fffdf9;border:1px solid #e7dccf;border-radius:24px;padding:18px;box-shadow:0 22px 56px rgba(47,42,38,.16)}
.ldts-contact-panel__head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:8px}
.ldts-contact-close{border:none;background:transparent;font-size:26px;line-height:1;cursor:pointer;color:#6f685f}
.ldts-contact-panel p{margin:0 0 12px;color:#6f685f}
.ldts-contact-link{display:block;padding:12px 14px;border-radius:16px;background:#f7f1e7;border:1px solid #e7dccf;margin-top:10px;font-weight:700;color:#2f2a26}
.ldts-contact-link--wa{background:#eef7ef;border-color:#d7e8d9}

.share-box{margin:0 32px 32px;padding:22px;border:1px solid var(--line);border-radius:24px;background:linear-gradient(135deg,#fbf7ef,#f6efe3)}
.share-box__head h3{margin:.35rem 0 0;font-family:Georgia,serif;font-size:1.6rem}
.share-buttons{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}
.share-btn{display:inline-flex;align-items:center;justify-content:center;padding:11px 14px;border-radius:999px;border:1px solid var(--line);background:#fff;color:var(--ink);font-weight:700;text-decoration:none;cursor:pointer}
.share-btn--whatsapp{background:#eef7ef}
.share-btn--facebook{background:#eef3fb}
.share-btn--telegram{background:#eef7fb}
.share-btn--x{background:#f5f5f5}
.share-btn--email{background:#fbf4ee}
.share-btn--copy{background:#fff7ef}


.form-grid--2{grid-template-columns:repeat(2,minmax(0,1fr));}
.success{color:#215b33;background:#eef8f0;border:1px solid #cae7d2;padding:12px 14px;border-radius:16px}
.table-wrap{overflow:auto;background:var(--surface);border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow)}
.admin-table{width:100%;border-collapse:collapse;min-width:940px}
.admin-table th,.admin-table td{padding:16px;border-bottom:1px solid var(--line);vertical-align:top;text-align:left}
.admin-table th{font-size:.9rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;background:#fcfaf5}
.table-excerpt{margin-top:6px;color:var(--muted);font-size:.94rem;max-width:360px}
.table-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:flex-start}
.table-actions form{display:flex;gap:8px;flex-wrap:wrap;margin:0}
.status-badge{display:inline-flex;padding:8px 12px;border-radius:999px;font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em}
.status-badge--published{background:#eef8f0;color:#215b33}
.status-badge--draft{background:#fff6ea;color:#975d11}
.gallery-card img{display:block;width:100%;aspect-ratio:4/3;object-fit:cover}
code{font-size:.9rem;background:#fbf7ef;border:1px solid var(--line);padding:4px 8px;border-radius:8px}
small{display:block;color:var(--muted);margin-top:6px}
@media (max-width: 900px){.form-grid--2{grid-template-columns:1fr}}


.app-banner{
  position:sticky;
  top:73px;
  z-index:24;
  background:linear-gradient(135deg, rgba(110,123,82,.97), rgba(179,106,76,.95));
  color:#fff;
  box-shadow:0 18px 40px rgba(47,42,38,.16);
}
.app-banner__content{
  display:grid;
  grid-template-columns:1.3fr auto;
  gap:18px;
  align-items:center;
  padding:14px 0;
}
.app-banner strong{display:block;font-size:1.12rem;margin:.2rem 0 .2rem}
.app-banner p{margin:0;color:rgba(255,255,255,.88);max-width:78ch}
.app-banner .eyebrow{color:#fff7da}
.app-banner__actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.app-banner__dismiss{width:40px;height:40px;border:none;border-radius:999px;background:rgba(255,255,255,.16);color:#fff;cursor:pointer;font-size:1.4rem;line-height:1}
.app-banner .btn{box-shadow:none}
.app-banner .btn--light{border-color:rgba(255,255,255,.3)}
@media (max-width: 900px){
  .app-banner{top:69px}
  .app-banner__content{grid-template-columns:1fr}
  .app-banner__actions{justify-content:flex-start}
}


.newsletter-band{
  padding:26px 0 10px;
}
.newsletter-band__inner{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:22px;
  align-items:center;
  background:linear-gradient(135deg,#fffdf9,#f6eee3);
  border:1px solid var(--line);
  border-radius:30px;
  padding:24px;
  box-shadow:var(--shadow);
}
.newsletter-band h2{margin:.35rem 0 .65rem;font-size:2rem;font-family:Georgia,serif}
.newsletter-band p{margin:0;color:var(--muted);max-width:64ch}
.newsletter-form{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center}
.newsletter-form input{width:100%;padding:14px 16px;border:1px solid var(--line);border-radius:18px;background:#fff}
.newsletter-form__status{grid-column:1/-1;color:var(--olive);font-size:.94rem;min-height:1.3em}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
@media (max-width: 900px){
  .newsletter-band__inner{grid-template-columns:1fr}
  .newsletter-form{grid-template-columns:1fr}
}


.cookie-banner{
  position:fixed;
  left:16px;
  right:16px;
  bottom:16px;
  z-index:40;
  transition:transform .3s ease,opacity .3s ease;
}
.cookie-banner--hidden{
  transform:translateY(20px);
  opacity:0;
  pointer-events:none;
  visibility:hidden;
}
.cookie-banner__inner{
  display:grid;
  grid-template-columns:1fr auto;
  gap:18px;
  align-items:center;
  background:rgba(47,42,38,.97);
  color:#fff;
  border-radius:24px;
  padding:20px 24px;
  box-shadow:0 20px 60px rgba(0,0,0,.22);
}
.cookie-banner p{margin:.35rem 0 0;color:rgba(255,255,255,.82);font-size:.9rem;line-height:1.5}
.cookie-banner a{color:#fff7da;text-decoration:underline}
.cookie-banner__actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
@media (max-width: 900px){
  .cookie-banner__inner{grid-template-columns:1fr}
  .cookie-banner__actions{justify-content:flex-start}
}
@media (max-width: 900px){
  .cookie-banner{left:12px;right:12px;bottom:12px}
}
