:root {
  --chocolate: #3c2a22;
  --chocolate-light: #5c4038;
  --ivory: #fff8f2;
  --ivory-dark: #f5ede4;
  --deep-blue: #1a2a3a;
  --deep-blue-light: #2c4a6a;
  --rose: #c88f84;
  --rose-light: #e8c2b8;
  --gold: #d8b56d;
  --gold-light: #f0dbaa;
  --ink: #1f1a17;
  --muted: #746a63;
  --line: #e8ddd5;
  --white: #ffffff;
  --shadow-sm: 0 2px 8px rgba(60,42,34,.06);
  --shadow-md: 0 8px 32px rgba(60,42,34,.08);
  --shadow-lg: 0 22px 70px rgba(60,42,34,.10);
  --radius-sm: 12px;
  --radius-md: 20px;
  --radius-lg: 28px;
  --transition: .3s cubic-bezier(.4,0,.2,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  background:var(--ivory);
  color:var(--ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:'Playfair Display',Georgia,serif;font-weight:700;letter-spacing:-.02em;line-height:1.2}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
.container{max-width:1240px;margin:0 auto;padding:0 24px}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* Custom cursor */
@media(hover:hover){

/* Header */
.header{position:fixed;top:0;left:0;right:0;z-index:100;transition:var(--transition)}
.header.scrolled{background:rgba(255,255,255,.92);backdrop-filter:blur(18px);box-shadow:var(--shadow-sm)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.header-logo{display:flex;align-items:center;gap:10px;font-size:20px;font-weight:800;color:var(--chocolate)}
.header-logo img{width:36px;height:36px;border-radius:12px}
.header-nav{display:flex;align-items:center;gap:8px}
.header-nav a{
  padding:8px 16px;border-radius:999px;font-size:14px;font-weight:600;
  color:var(--muted);transition:var(--transition)
}
.header-nav a:hover{background:var(--ivory-dark);color:var(--ink)}
.header-nav a.cta{background:var(--chocolate);color:var(--white)}
.header-nav a.cta:hover{background:var(--chocolate-light);transform:translateY(-1px)}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 24px;border-radius:999px;font-weight:600;font-size:15px;
  border:1.5px solid var(--chocolate);background:var(--chocolate);color:var(--white);
  cursor:pointer;transition:var(--transition);font-family:inherit
}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn-outline{background:transparent;color:var(--chocolate)}
.btn-outline:hover{background:var(--chocolate);color:var(--white)}
.btn-ghost{border-color:transparent;background:transparent;color:var(--muted)}

/* Hero */
.hero{min-height:90vh;display:flex;align-items:center;padding:120px 0 80px;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 80% 40%,var(--rose-light) 0%,transparent 60%),radial-gradient(ellipse at 20% 60%,var(--gold-light) 0%,transparent 50%)}
.hero-content{position:relative;z-index:1;max-width:720px}
.hero h1{font-size:clamp(42px,6vw,80px);color:var(--chocolate);margin-bottom:20px}
.hero h1 span{color:var(--rose)}
.hero p{font-size:18px;color:var(--muted);margin-bottom:36px;max-width:560px;line-height:1.7}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}

/* Sections */
.section{padding:100px 0}
.section-title{font-size:clamp(28px,3.5vw,44px);text-align:center;margin-bottom:16px;color:var(--chocolate)}
.section-subtitle{text-align:center;color:var(--muted);font-size:17px;margin-bottom:48px;max-width:600px;margin-left:auto;margin-right:auto}

/* Cards grid */
.grid{display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}
.card{
  background:var(--white);border-radius:var(--radius-md);overflow:hidden;
  border:1px solid var(--line);transition:var(--transition);
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.card-img{aspect-ratio:4/3;background:var(--ivory-dark);display:flex;align-items:center;justify-content:center;padding:24px;position:relative}
.card-img img{width:100%;height:100%;object-fit:contain}
.card-body{padding:20px}
.card-body h3{font-size:18px;margin-bottom:6px}
.card-body .meta{font-size:13px;color:var(--muted);margin-bottom:8px}
.card-body .price{font-size:20px;font-weight:800;color:var(--chocolate)}
.card-body .row{display:flex;align-items:center;justify-content:space-between;margin-top:12px}

/* Filters */
.filters{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:32px;align-items:center}
.filters select,.filters input{
  padding:10px 16px;border-radius:999px;border:1.5px solid var(--line);
  background:var(--white);font-family:inherit;font-size:14px;color:var(--ink)
}

/* Loading */
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
.skeleton{background:linear-gradient(90deg,var(--ivory-dark) 25%,var(--line) 50%,var(--ivory-dark) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}

/* Animation classes */
.fade-up{opacity:1;transform:none;transition:none}

.fade-in{opacity:0;transition:opacity .6s ease}
.fade-in.visible{opacity:1}

/* Forum */
.forum-topic{padding:20px;background:var(--white);border-radius:var(--radius-sm);border:1px solid var(--line);margin-bottom:12px;transition:var(--transition)}
.forum-topic:hover{border-color:var(--rose)}
.forum-topic h3{font-family:'Inter',sans-serif;font-size:16px;margin-bottom:4px}
.forum-topic .meta{font-size:13px;color:var(--muted)}
.reply{padding:16px;background:var(--ivory-dark);border-radius:var(--radius-sm);margin-bottom:8px;border-left:3px solid var(--rose)}

/* Constructor */
.constructor-layout{display:grid;grid-template-columns:1fr 1fr;gap:32px}
@media(max-width:768px){.constructor-layout{grid-template-columns:1fr}}
.constructor-form{background:var(--white);padding:32px;border-radius:var(--radius-md);border:1px solid var(--line)}
.constructor-form label{display:block;font-weight:600;font-size:14px;margin-bottom:4px;color:var(--chocolate)}
.constructor-form input{width:100%;padding:10px 14px;border:1.5px solid var(--line);border-radius:var(--radius-sm);font-family:inherit;font-size:15px;margin-bottom:16px}

/* Cabinet */
.cabinet-grid{display:grid;grid-template-columns:220px 1fr;gap:32px}
@media(max-width:768px){.cabinet-grid{grid-template-columns:1fr}}
.cabinet-sidebar{background:var(--white);padding:24px;border-radius:var(--radius-md);border:1px solid var(--line);height:fit-content}
.cabinet-sidebar a{display:block;padding:10px 14px;border-radius:var(--radius-sm);margin-bottom:4px;font-weight:500;transition:var(--transition)}
.cabinet-sidebar a:hover,.cabinet-sidebar a.active{background:var(--ivory-dark);color:var(--chocolate)}

/* Breadcrumbs */
.breadcrumbs{display:flex;gap:8px;font-size:13px;color:var(--muted);padding:20px 0;flex-wrap:wrap}
.breadcrumbs a:hover{color:var(--chocolate)}
.breadcrumbs span{color:var(--line)}

/* Footer */
.footer{background:var(--chocolate);color:var(--ivory);padding:60px 0 40px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px}
@media(max-width:768px){.footer-grid{grid-template-columns:1fr 1fr}}
.footer h4{font-family:'Inter',sans-serif;font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:16px;color:var(--gold)}
.footer a{display:block;font-size:14px;color:rgba(255,255,255,.7);margin-bottom:8px;transition:var(--transition)}
.footer a:hover{color:var(--white)}

/* Toast */
.toast{position:fixed;bottom:24px;right:24px;z-index:999;padding:16px 24px;border-radius:var(--radius-sm);background:var(--chocolate);color:var(--white);font-weight:600;transform:translateY(120px);opacity:0;transition:var(--transition)}
.toast.show{transform:translateY(0);opacity:1}
.toast.error{background:#c0392b}
.toast.success{background:#27ae60}

/* Page header */
.page-header{padding:120px 0 40px;text-align:center}
.page-header h1{font-size:clamp(32px,4vw,52px);margin-bottom:12px}
.page-header p{color:var(--muted);font-size:17px}

/* Scroll animations */