
:root{
  --bg:#f6f1e8;
  --bg-soft:#fbf8f2;
  --panel:#fffdf9;
  --panel-2:#f2eadf;
  --line:#d9cdbd;
  --text:#2e2a24;
  --muted:#6e655a;
  --soft:#938979;
  --accent:#8f5f3c;
  --accent-2:#b87e53;
  --accent-soft:#f0dfcf;
  --shadow:0 18px 40px rgba(69,50,32,.08);
  --radius:24px;
  --max:1240px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  color:var(--text);
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background:
    radial-gradient(circle at top left, rgba(184,126,83,.10), transparent 28%),
    linear-gradient(180deg, #fcf8f2 0%, #f6f1e8 100%);
}
body.compact-page{min-height:100vh; display:flex; flex-direction:column}
main{flex:1}
a{color:inherit; text-decoration:none}
img{display:block; max-width:100%}
button,input,textarea,select{font:inherit}
.container{width:min(calc(100% - 40px), var(--max)); margin:0 auto}
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(252,248,242,.82);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(143,95,60,.14);
}
.site-header .container{
  min-height:74px; display:flex; align-items:center; justify-content:space-between; gap:18px;
}
.brand{
  font-family:Georgia, "Times New Roman", serif;
  font-size:1.25rem;
  font-weight:700;
  letter-spacing:.02em;
}
.nav{display:flex; align-items:center; gap:10px; flex-wrap:wrap}
.nav a{
  padding:10px 12px; border-radius:999px; color:var(--muted); transition:.2s ease;
}
.nav a:hover,.nav a.active{background:rgba(143,95,60,.08); color:var(--text)}
.button,.button-secondary{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  border-radius:999px; padding:12px 18px; border:1px solid transparent; cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease;
}
.button{background:linear-gradient(180deg, var(--accent-2), var(--accent)); color:#fff; box-shadow:var(--shadow)}
.button:hover,.button-secondary:hover{transform:translateY(-1px)}
.button-secondary{background:var(--panel); color:var(--text); border-color:var(--line)}
.hero{padding:56px 0 26px}
.hero-grid{
  display:grid; grid-template-columns:1.25fr .9fr; gap:22px; align-items:end;
}
.kicker{
  margin-bottom:12px; color:var(--accent); text-transform:uppercase; letter-spacing:.14em; font-size:.76rem; font-weight:700;
}
.hero h1{
  margin:0 0 12px; font-family:Georgia, "Times New Roman", serif; font-size:clamp(2.5rem, 7vw, 4.8rem); line-height:1.02; max-width:10ch;
}
.hero p{margin:0; color:var(--muted); max-width:64ch; font-size:1.03rem; line-height:1.72}
.hero-actions{display:flex; gap:12px; margin-top:22px; flex-wrap:wrap}
.hero-card,.page-intro,.post-card,.review-card,.detail-shell,.form-shell,.post-shell{
  background:var(--panel);
  border:1px solid rgba(143,95,60,.12);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.hero-card{padding:22px}
.stat-grid{display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:14px; margin-top:16px}
.stat{
  padding:16px; border-radius:18px; background:var(--bg-soft); border:1px solid var(--line); min-height:112px;
}
.stat strong{display:block; font-size:1.7rem; margin-bottom:8px; font-family:Georgia, serif}
.stat span{color:var(--muted); line-height:1.45; font-size:.95rem}
.feed{display:grid; gap:22px; padding:8px 0 60px}
.review-card{
  display:grid; grid-template-columns:minmax(0,1fr) minmax(340px, 460px); gap:24px;
  min-height:62vh; padding:22px;
}
.media-panel,.content-panel{min-width:0}
.carousel{display:flex; flex-direction:column; gap:14px; height:100%}
.carousel-viewport{
  overflow:hidden; border-radius:22px; border:1px solid var(--line); background:var(--bg-soft);
}
.carousel-track{display:flex; transition:transform .35s ease}
.carousel-slide{min-width:100%}
.carousel-slide img{width:100%; aspect-ratio:4/3; object-fit:cover}
.carousel-controls{
  display:flex; justify-content:space-between; align-items:center; gap:10px; flex-wrap:wrap;
}
.dots{display:flex; gap:8px; flex-wrap:wrap}
.dot{
  width:9px; height:9px; border-radius:999px; background:#d2c3b0;
}
.dot.active{background:var(--accent)}
.carousel-buttons{display:flex; gap:8px}
.icon-btn{
  width:42px; height:42px; border-radius:999px; border:1px solid var(--line); background:var(--panel); color:var(--text); cursor:pointer;
}
.content-panel{display:flex; flex-direction:column}
.eyebrow{color:var(--accent); font-size:.8rem; text-transform:uppercase; letter-spacing:.12em; font-weight:700}
.review-title{margin:10px 0 8px; font-family:Georgia, serif; font-size:clamp(1.85rem, 3vw, 2.7rem); line-height:1.08}
.summary{margin:0 0 16px; color:var(--muted); line-height:1.65}
.meta-grid{
  display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:12px;
  padding:16px; border-radius:18px; background:var(--bg-soft); border:1px solid var(--line);
}
.meta-grid div{font-size:.96rem; line-height:1.45}
.meta-grid span{display:block; margin-bottom:4px; color:var(--soft); font-size:.78rem; text-transform:uppercase; letter-spacing:.08em}
.rating-row{
  display:grid; grid-template-columns:repeat(5, minmax(0,1fr)); gap:10px; margin:16px 0;
}
.rating-box{
  padding:12px; border-radius:16px; background:linear-gradient(180deg, #fff, #f8f1e7); border:1px solid var(--line); text-align:center;
}
.rating-box strong{display:block; font-size:1.25rem; margin-bottom:4px}
.rating-box small{color:var(--muted); text-transform:uppercase; letter-spacing:.06em}
.review-copy{margin:0 0 20px; line-height:1.8; color:#4a4339}
.card-actions{display:flex; justify-content:space-between; align-items:center; gap:12px; margin-top:auto; flex-wrap:wrap}
.author-line{color:var(--muted); font-size:.95rem}
.footer{padding:0 0 48px; color:var(--muted); font-size:.95rem}
.detail-layout{padding:42px 0 56px}
.detail-shell{
  display:grid; grid-template-columns:minmax(0,1.05fr) minmax(360px, .95fr); gap:24px; padding:24px;
}
.page-intro{padding:28px; margin:42px auto 26px}
.page-intro h1,.post-shell h1{margin:8px 0 10px; font-family:Georgia, serif; font-size:clamp(2.2rem, 6vw, 3.6rem); line-height:1.06}
.page-intro p,.post-shell p,.about-copy p{color:var(--muted); line-height:1.75}
.post-list{display:grid; gap:18px; padding-bottom:54px}
.post-card{padding:22px}
.post-meta{font-size:.9rem; color:var(--soft); text-transform:uppercase; letter-spacing:.08em}
.post-card h2{margin:8px 0 10px; font-family:Georgia, serif; font-size:1.8rem}
.post-card p{margin:0 0 18px; color:var(--muted); line-height:1.7}
.post-shell{padding:30px; margin:42px auto 56px}
.about-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:22px}
.about-copy,.about-sidebar{
  background:var(--panel); border:1px solid rgba(143,95,60,.12); border-radius:var(--radius); box-shadow:var(--shadow); padding:24px;
}
.about-sidebar ul{margin:0; padding-left:20px; color:var(--muted); line-height:1.9}
.form-shell{
  padding:26px; margin:42px auto 56px;
}
.form-grid{display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:16px}
.field{display:flex; flex-direction:column; gap:8px}
.field label{font-weight:600}
.field input,.field textarea,.field select{
  width:100%; border:1px solid var(--line); background:var(--bg-soft); border-radius:16px; padding:13px 14px; color:var(--text);
}
.field textarea{min-height:150px; resize:vertical}
.field.full{grid-column:1 / -1}
.form-help{margin:10px 0 0; color:var(--muted); font-size:.95rem}
.notice{
  margin-bottom:18px; padding:14px 16px; border-radius:16px; background:#eef8ef; color:#2f5d31; border:1px solid #bddfbe; display:none;
}
.review-empty{
  padding:22px; border-radius:20px; background:var(--panel); border:1px dashed var(--line); color:var(--muted);
}
@media (max-width: 960px){
  .hero-grid,.review-card,.detail-shell,.about-grid{grid-template-columns:1fr}
  .review-card{min-height:auto}
}
@media (max-width: 720px){
  .container{width:min(calc(100% - 24px), var(--max))}
  .site-header .container{padding:10px 0; align-items:flex-start}
  .nav{gap:6px}
  .nav a{padding:8px 10px}
  .hero{padding-top:36px}
  .rating-row{grid-template-columns:repeat(2, minmax(0,1fr))}
  .meta-grid,.form-grid,.stat-grid{grid-template-columns:1fr}
  .card-actions{align-items:flex-start}
}
