﻿:root {
      --ink: #20231f;
      --muted: #60665b;
      --line: #dfe3d6;
      --leaf: #315c3f;
      --moss: #6f8f5a;
      --clay: #b76f43;
      --paper: #f7f5ee;
      --white: #ffffff;
      --soft: #ece6d7;
    }

    * { box-sizing: border-box; }
    html { scroll-behavior: smooth; }
    body {
      margin: 0;
      font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
      color: var(--ink);
      background: var(--paper);
      line-height: 1.55;
    }

    a { color: inherit; text-decoration: none; }
    img { max-width: 100%; display: block; }

    .topbar {
      background: var(--leaf);
      color: #fff;
      font-size: 14px;
      padding: 9px 5vw;
      display: flex;
      justify-content: space-between;
      gap: 16px;
      flex-wrap: wrap;
    }

    header {
      position: sticky;
      top: 0;
      z-index: 20;
      background: rgba(247, 245, 238, .94);
      backdrop-filter: blur(16px);
      border-bottom: 1px solid var(--line);
    }

    .nav {
      height: 72px;
      padding: 0 5vw;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 24px;
    }

    .brand {
      display: flex;
      align-items: center;
      gap: 12px;
      font-weight: 800;
      letter-spacing: 0;
      font-size: 24px;
    }


    .brand-logo {
      width: 160px;
      height: auto;
      display: block;
    }
    .brand-mark {
      width: 38px;
      height: 38px;
      border-radius: 8px;
      background: linear-gradient(135deg, var(--leaf), var(--moss));
      display: grid;
      place-items: center;
      color: #fff;
      font-weight: 900;
      font-size: 18px;
    }

    nav ul {
      margin: 0;
      padding: 0;
      display: flex;
      align-items: center;
      gap: 28px;
      list-style: none;
      color: #384033;
      font-size: 15px;
      font-weight: 600;
    }

    .nav-cta, .button {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 44px;
      padding: 0 18px;
      border-radius: 6px;
      background: var(--clay);
      color: #fff;
      font-weight: 700;
      border: 0;
    }

    .hero {
      min-height: calc(100vh - 110px);
      padding: 64px 5vw 48px;
      display: grid;
      grid-template-columns: minmax(0, 1.02fr) minmax(320px, .98fr);
      gap: 56px;
      align-items: center;
    }

    .eyebrow {
      margin: 0 0 14px;
      color: var(--leaf);
      font-weight: 800;
      text-transform: uppercase;
      font-size: 13px;
      letter-spacing: 0;
    }

    h1 {
      margin: 0;
      font-size: clamp(42px, 7vw, 84px);
      line-height: .98;
      letter-spacing: 0;
      max-width: 800px;
    }

    .hero-copy {
      margin: 24px 0 0;
      color: var(--muted);
      font-size: 19px;
      max-width: 620px;
    }

    .hero-actions {
      display: flex;
      gap: 14px;
      flex-wrap: wrap;
      margin-top: 34px;
    }

    .button.secondary {
      background: transparent;
      color: var(--leaf);
      border: 1px solid var(--leaf);
    }

    .hero-media {
      min-height: 560px;
      border-radius: 8px;
      overflow: hidden;
      position: relative;
      background:
        linear-gradient(180deg, rgba(32,35,31,.04), rgba(32,35,31,.1)),
        url('../images/hero-luxury-full-length-mirror.jpg') center/cover;
      box-shadow: 0 24px 70px rgba(32, 35, 31, .16);
    }

    .hero-note {
      position: absolute;
      left: 22px;
      right: 22px;
      bottom: 22px;
      background: rgba(255,255,255,.92);
      border-radius: 8px;
      padding: 18px;
      display: grid;
      grid-template-columns: 1fr auto;
      gap: 12px;
      align-items: center;
    }

    .hero-note strong { display: block; font-size: 18px; }
    .hero-note span { color: var(--muted); font-size: 14px; }
    .hero-note b { color: var(--leaf); font-size: 28px; }

    section { padding: 72px 5vw; }
    .section-head {
      display: flex;
      justify-content: space-between;
      align-items: end;
      gap: 28px;
      margin-bottom: 28px;
    }

    h2 { margin: 0; font-size: clamp(30px, 4vw, 48px); line-height: 1.08; letter-spacing: 0; }
    .section-head p { margin: 0; max-width: 520px; color: var(--muted); }

    .category-grid {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 18px;
    }

    .category {
      min-height: 260px;
      border-radius: 8px;
      overflow: hidden;
      position: relative;
      background: var(--soft);
    }

    .category::before {
      content: "";
      position: absolute;
      inset: 0;
      background: linear-gradient(180deg, transparent 22%, rgba(0,0,0,.62));
      z-index: 1;
    }

    .category.mirrors { background: url('../images/category-full-length-mirrors.webp') center/cover; }
    .category.stands { background: url('../images/category-rolling-mirrors.webp') center/cover; }
    .category.pots { background: url('../images/category-fitness-mirrors.jpg') center/cover; }

    .category div {
      position: absolute;
      z-index: 2;
      left: 20px;
      right: 20px;
      bottom: 20px;
      color: #fff;
    }

    .category h3 { margin: 0 0 8px; font-size: 24px; }
    .category p { margin: 0; color: rgba(255,255,255,.82); }

    .products {
      background: #fff;
      border-top: 1px solid var(--line);
      border-bottom: 1px solid var(--line);
    }

    .product-grid {
      display: grid;
      grid-template-columns: repeat(4, minmax(0, 1fr));
      gap: 18px;
    }

    .product {
      background: var(--paper);
      border: 1px solid var(--line);
      border-radius: 8px;
      overflow: hidden;
      min-width: 0;
    }

    .product .photo {
      aspect-ratio: 1 / 1;
      background-size: cover;
      background-position: center;
    }

    .p1 { background-image: url('../images/products/baroque-inspired-floor-mirror.jpg'); }
    .p2 { background-image: url('../images/products/trifold-full-length-mirror.jpg'); }
    .p3 { background-image: url('../images/products/arched-stainless-standing-mirror.webp'); }
    .p4 { background-image: url('../images/products/home-fitness-mirror.jpg'); }

    .product-body { padding: 16px; }
    .product-body h3 { margin: 0 0 8px; font-size: 17px; line-height: 1.3; }
    .product-body p { margin: 0; color: var(--muted); font-size: 14px; }

    .about {
      display: grid;
      grid-template-columns: .9fr 1.1fr;
      gap: 50px;
      align-items: center;
    }

    .about-image {
      min-height: 430px;
      border-radius: 8px;
      background: url('../images/about-modern-mirror-interior.jpg') center/cover;
    }

    .values {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 16px;
      margin-top: 28px;
    }

    .value {
      padding: 18px;
      border: 1px solid var(--line);
      border-radius: 8px;
      background: rgba(255,255,255,.6);
    }

    .value strong { display: block; margin-bottom: 6px; }
    .value span { color: var(--muted); font-size: 14px; }

    footer {
      background: #1f2a20;
      color: #fff;
      padding: 48px 5vw 28px;
    }

    .footer-grid {
      display: grid;
      grid-template-columns: 1.2fr .8fr .8fr;
      gap: 30px;
      border-bottom: 1px solid rgba(255,255,255,.18);
      padding-bottom: 34px;
    }

    footer p, footer a { color: rgba(255,255,255,.76); }
    footer h3 { margin: 0 0 14px; }
    .copyright { margin: 22px 0 0; color: rgba(255,255,255,.55); font-size: 14px; }

    @media (max-width: 980px) {
      nav ul { display: none; }
      .hero, .about { grid-template-columns: 1fr; }
      .hero { padding-top: 44px; }
      .hero-media { min-height: 430px; }
      .category-grid, .product-grid, .values, .footer-grid { grid-template-columns: 1fr 1fr; }
    }

    @media (max-width: 640px) {
      .topbar { font-size: 12px; }
      .nav { height: 66px; }
      .nav-cta { display: none; }
      .brand { font-size: 21px; }
      .hero { min-height: auto; padding-bottom: 34px; gap: 34px; }
      .hero-copy { font-size: 17px; }
      .hero-note { grid-template-columns: 1fr; }
      section { padding: 52px 5vw; }
      .section-head { display: block; }
      .section-head p { margin-top: 12px; }
      .category-grid, .product-grid, .values, .footer-grid { grid-template-columns: 1fr; }
    }



