:root{
  --ink:#2e221a;
  --paper:#f2ede5;
  --tan:#d2b892;
  --dark:#24303b;
  --teal:#2f6469;
  --line:#c9c0b2;
}
*{box-sizing:border-box}
body{margin:0;font-family:Georgia,"Times New Roman",serif;background:#ebe7e1;color:var(--ink)}
a{color:inherit}
.container{max-width:1140px;margin:0 auto;padding:0 18px}
.topbar{background:#2c2621;padding:16px 0;border-top-left-radius:34px;border-top-right-radius:34px;margin:24px auto 0;max-width:1180px}
.nav-row{display:flex;align-items:center;justify-content:space-between;gap:20px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:#f3e9da;font-weight:700}
.brand img{width:72px;height:auto}
nav{display:flex;gap:20px;align-items:center;flex-wrap:wrap}
nav a{text-decoration:none;color:#f3e9da;font-size:14px;text-transform:uppercase;letter-spacing:.04em}
.nav-btn{padding:10px 14px;background:#476a67;border-radius:4px}
.hero{position:relative;max-width:1180px;margin:0 auto;background:linear-gradient(rgba(255,255,255,.32),rgba(255,255,255,.32)),repeating-linear-gradient(0deg,#d7d1c8 0,#d7d1c8 2px,#cec6bc 2px,#cec6bc 78px);overflow:hidden}
.hero-overlay{position:absolute;inset:0;background:radial-gradient(circle at top, rgba(255,255,255,.25), transparent 45%);pointer-events:none}
.hero-inner{position:relative;padding:34px 18px 28px}
.hero-signs{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:end;margin-bottom:18px}
.hero-signs img{width:100%;max-height:260px;object-fit:contain;filter:drop-shadow(0 8px 14px rgba(0,0,0,.12))}
.hero-copy{text-align:center;max-width:760px;margin:0 auto}
.eyebrow{margin:0 0 8px;text-transform:uppercase;letter-spacing:.05em;font-size:13px;color:#73543f;font-weight:700}
.hero-copy h1,.contact-band h2,.coaster-copy h2,.intro-band h2{margin:0 0 10px;font-size:42px;line-height:1.05}
.hero-copy p,.intro-band p,.coaster-copy p,.contact-band p{font-size:19px;line-height:1.55;margin:0}
.hero-actions{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;margin-top:20px}
.btn{display:inline-block;text-decoration:none;padding:13px 22px;border-radius:4px;font-size:18px;font-weight:700;cursor:pointer;border:none}
.btn-dark{background:var(--teal);color:#fff}
.btn-light{background:var(--tan);color:var(--ink)}
.main-content{padding:28px 18px 40px}
.intro-band{display:grid;grid-template-columns:1.2fr .8fr;gap:20px;background:#f6f3ee;border:1px solid var(--line);padding:18px;border-radius:12px;margin-bottom:28px}
.section-head{text-align:center;margin-bottom:18px}
.section-head h2{margin:0 0 8px;font-size:34px;color:#497b80}
.section-head p{margin:0;font-size:18px;color:#675448}
.products-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px 18px}
.product-card{text-align:center;background:#f7f4ef;border:1px solid var(--line);border-radius:14px;padding:14px 10px}
.product-card img{width:100%;max-width:170px;max-height:170px;object-fit:contain;display:block;margin:0 auto 10px}
.product-card h3{margin:0 0 6px;font-size:18px;line-height:1.15}
.product-card p{margin:0 0 10px;font-size:15px;color:#665548}
.product-card a{display:inline-block;background:var(--teal);color:#fff;padding:9px 12px;border-radius:4px;text-decoration:none;font-size:14px;font-weight:700}
.coaster-block{display:grid;grid-template-columns:.9fr 1.1fr;gap:26px;align-items:center;background:#f6f3ee;border:1px solid var(--line);border-radius:16px;padding:20px;margin:32px 0}
.coaster-image img{width:100%;max-height:420px;object-fit:contain}
.contact-band{display:grid;grid-template-columns:1.1fr .9fr;gap:24px;background:linear-gradient(rgba(243,235,224,.88),rgba(243,235,224,.88)),repeating-linear-gradient(0deg,#d7d1c8 0,#d7d1c8 2px,#cec6bc 2px,#cec6bc 78px);border:1px solid var(--line);border-radius:18px;padding:24px}
.contact-side{display:flex;flex-direction:column;gap:10px;align-items:flex-start;justify-content:center}
.contact-side a{text-decoration:none;font-weight:700}
.site-footer{padding:18px 0 28px}
.footer-row{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;font-size:14px;color:#655347}
.order-page-body{background:#ebe7e1}
.order-shell{padding:24px 18px 40px}
.back-link{display:inline-block;margin-bottom:14px;text-decoration:none}
.order-panel{background:#f7f4ef;border:1px solid var(--line);border-radius:16px;padding:24px}
.order-panel h1{margin:0 0 10px;font-size:42px}
.order-form{margin-top:18px}
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
label{display:flex;flex-direction:column;gap:6px;font-size:15px;font-weight:700}
label.full{grid-column:1/-1}
input,select,textarea{padding:12px 14px;border:1px solid #cfc3b2;border-radius:10px;font:inherit;background:#fff}
.totals-box{margin:18px 0;background:#ede5d9;border-radius:14px;padding:14px}
.totals-box>div{display:flex;justify-content:space-between;padding:6px 0}
.grand{font-size:20px;font-weight:700}
@media (max-width:980px){.products-grid{grid-template-columns:repeat(3,1fr)}.coaster-block,.contact-band,.intro-band{grid-template-columns:1fr}}
@media (max-width:760px){.hero-signs,.products-grid,.form-grid{grid-template-columns:repeat(2,1fr)}.nav-row{flex-direction:column;align-items:flex-start}.hero-copy h1,.contact-band h2,.coaster-copy h2,.intro-band h2,.order-panel h1{font-size:32px}}
@media (max-width:560px){.hero-signs,.products-grid,.form-grid{grid-template-columns:1fr}}
