:root {
    --rose-mauve: #C97B93;
    --nude-rose: #F3E7E9;
    --plum: #6E3B52;
    --off-white: #FAF8F6;
    --warm-gray: #7A6F73;
    --soft-green: #88B7A3;
    --text-main: #3F3538;
    --shadow: 0 18px 40px rgba(110, 59, 82, 0.12);
    --radius-lg: 28px;
    --radius-md: 18px;
}
* { box-sizing: border-box; }
body {
    margin: 0;
    color: var(--text-main);
    background:
        radial-gradient(circle at top right, rgba(201,123,147,0.14), transparent 28%),
        linear-gradient(180deg, #fff 0%, var(--off-white) 100%);
    font-family: "Manrope", sans-serif;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
.container { width: min(1120px, calc(100% - 2rem)); margin: 0 auto; }
.site-header { position: sticky; top: 0; z-index: 20; backdrop-filter: blur(14px); background: rgba(250,248,246,0.8); border-bottom: 1px solid rgba(122,111,115,0.12); }
.nav { display: flex; justify-content: space-between; align-items: center; padding: 1rem 0; gap: 1rem; }
.nav nav { display: flex; gap: 1rem; font-size: .95rem; }
.brand { font-family: "Cormorant Garamond", serif; font-size: 2rem; color: var(--plum); font-weight: 700; }
.hero { padding: 4rem 0 3rem; display: grid; grid-template-columns: 1.1fr .9fr; gap: 2rem; align-items: center; }
.eyebrow { display: inline-flex; align-items: center; gap: .5rem; padding: .5rem .9rem; border-radius: 999px; background: rgba(136,183,163,.18); color: #47695d; font-size: .9rem; font-weight: 700; }
h1, h2, h3 { font-family: "Cormorant Garamond", serif; line-height: .95; margin: 0 0 1rem; color: var(--plum); }
h1 { font-size: clamp(3rem, 6vw, 5.5rem); }
h2 { font-size: clamp(2.2rem, 4vw, 3.6rem); }
h3 { font-size: 1.8rem; }
p { line-height: 1.7; color: var(--warm-gray); }
.hero-copy p { font-size: 1.1rem; max-width: 55ch; }
.actions { display: flex; gap: 1rem; flex-wrap: wrap; margin-top: 1.5rem; }
.btn, button { display: inline-flex; align-items: center; justify-content: center; padding: 1rem 1.4rem; border: 0; border-radius: 999px; background: var(--plum); color: #fff; font-weight: 700; cursor: pointer; box-shadow: var(--shadow); }
.btn-secondary { background: #fff; color: var(--plum); border: 1px solid rgba(110,59,82,.18); box-shadow: none; }
.hero-card, .card, .panel, .stats-grid article, .faq-item, .material-card { background: rgba(255,255,255,.88); border: 1px solid rgba(122,111,115,.12); border-radius: var(--radius-lg); box-shadow: var(--shadow); }
.hero-card { padding: 2rem; }
.price-box { display: flex; justify-content: space-between; align-items: center; gap: 1rem; padding: 1.1rem 1.2rem; background: var(--nude-rose); border-radius: 20px; margin-top: 1.5rem; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem; }
.grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.2rem; }
.section { padding: 2rem 0 3.5rem; }
.card { padding: 1.4rem; }
.list-clean { list-style: none; padding: 0; margin: 0; display: grid; gap: .8rem; }
.list-clean li::before { content: "• "; color: var(--rose-mauve); font-weight: 700; }
.highlight { background: linear-gradient(135deg, rgba(201,123,147,.16), rgba(243,231,233,.8)); border-radius: var(--radius-lg); padding: 2rem; }
.faq-item { padding: 1.3rem 1.4rem; }
.faq-item p { margin: .6rem 0 0; }
form { display: grid; gap: 1rem; }
label { display: grid; gap: .35rem; font-weight: 600; }
input, textarea, select { width: 100%; padding: .95rem 1rem; border-radius: 16px; border: 1px solid rgba(122,111,115,.22); background: #fff; font: inherit; color: var(--text-main); }
.checkline { display: flex; gap: .7rem; align-items: start; font-size: .95rem; color: var(--warm-gray); }
.checkline input { width: auto; margin-top: .2rem; }
.layout-sidebar { display: grid; grid-template-columns: minmax(0, 1.05fr) 360px; gap: 2rem; align-items: start; }
.panel { padding: 1.6rem; }
.status { display: inline-flex; padding: .4rem .75rem; border-radius: 999px; background: rgba(136,183,163,.16); color: #406556; font-size: .85rem; font-weight: 700; }
.status.waiting_payment, .status.pending { background: rgba(201,123,147,.18); color: var(--plum); }
.status.paid, .status.released, .status.confirmed { background: rgba(136,183,163,.18); color: #406556; }
.qr-box { display: grid; gap: 1rem; justify-items: start; }
.qr-box img { width: min(260px, 100%); border-radius: 18px; border: 1px solid rgba(122,111,115,.14); }
.code-box { padding: 1rem; border-radius: 16px; background: var(--off-white); word-break: break-all; border: 1px dashed rgba(122,111,115,.24); }
.table-wrap { overflow: auto; }
table { width: 100%; border-collapse: collapse; }
th, td { padding: .9rem .8rem; border-bottom: 1px solid rgba(122,111,115,.12); text-align: left; white-space: nowrap; }
.admin-grid { display: grid; grid-template-columns: 240px minmax(0, 1fr); gap: 1.5rem; }
.sidebar { position: sticky; top: 88px; display: grid; gap: .75rem; }
.sidebar a { padding: .9rem 1rem; border-radius: 16px; background: #fff; border: 1px solid rgba(122,111,115,.12); }
.stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; }
.stats-grid article { padding: 1.25rem; }
.material-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem; }
.material-card { padding: 1.4rem; }
.toast { position: fixed; right: 1rem; bottom: 1rem; z-index: 30; padding: 1rem 1.2rem; border-radius: 16px; color: #fff; }
.toast-success { background: #406556; }
.toast-error { background: #8e4560; }
.muted { color: var(--warm-gray); font-size: .95rem; }
.center { text-align: center; }
@media (max-width: 900px) {
    .hero, .layout-sidebar, .admin-grid, .grid-3, .grid-2, .stats-grid, .material-grid { grid-template-columns: 1fr; }
    .nav { flex-direction: column; align-items: start; }
    .nav nav { flex-wrap: wrap; }
}
