
    :root {
      --color-primary: #5B7E3C;
      --color-secondary: #3D5A1E;
      --color-accent: #D4A847;
      --color-background: #FAF8F5;
      --color-text: #2D2D2D;
    }
    * { margin: 0; padding: 0; box-sizing: border-box; }
    body {
      font-family: 'Georgia', 'Times New Roman', serif;
      background-color: var(--color-background);
      color: var(--color-text);
      line-height: 1.6;
    }
    a { color: var(--color-primary); }
    .container { max-width: 1200px; margin: 0 auto; padding: 0 20px; }

    /* Navigation */
    .site-nav {
      background: var(--color-primary);
      padding: 0;
      position: sticky;
      top: 0;
      z-index: 100;
      box-shadow: 0 2px 8px rgba(0,0,0,0.15);
    }
    .site-nav .container {
      display: flex;
      align-items: center;
      justify-content: space-between;
    }
    .site-nav .nav-brand {
      color: white;
      font-weight: 700;
      font-size: 1.2rem;
      text-decoration: none;
      padding: 15px 0;
    }
    .site-nav .nav-links {
      display: flex;
      list-style: none;
      gap: 0;
    }
    .site-nav .nav-links a {
      color: rgba(255,255,255,0.9);
      text-decoration: none;
      padding: 18px 16px;
      display: block;
      font-size: 0.95rem;
      transition: background 0.2s;
    }
    .site-nav .nav-links a:hover,
    .site-nav .nav-links a.active {
      background: rgba(255,255,255,0.15);
      color: white;
    }
    .nav-toggle { display: none; background: none; border: none; color: white; font-size: 1.5rem; cursor: pointer; padding: 15px; }

    /* Header */
    header {
      background: linear-gradient(135deg, var(--color-primary), var(--color-secondary));
      color: white;
      padding: 80px 20px;
      text-align: center;
    }
    header h1 { font-size: 3rem; margin-bottom: 1rem; }
    header p { font-size: 1.5rem; opacity: 0.9; }
    .logo { max-width: 200px; height: auto; margin-bottom: 2rem; }

    /* Sections */
    section { padding: 60px 20px; }
    section:nth-child(even) { background: rgba(0,0,0,0.02); }
    h2 {
      font-size: 2rem;
      margin-bottom: 2rem;
      color: var(--color-primary);
      text-align: center;
    }
    .about-text {
      max-width: 800px;
      margin: 0 auto;
      text-align: center;
      font-size: 1.1rem;
    }

    /* Services Grid */
    .services-grid {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
      gap: 30px;
      max-width: 1000px;
      margin: 0 auto;
    }
    .service-card {
      background: white;
      border-radius: 12px;
      padding: 30px;
      box-shadow: 0 4px 6px rgba(0,0,0,0.1);
      transition: transform 0.3s, box-shadow 0.3s;
    }
    .service-card:hover {
      transform: translateY(-5px);
      box-shadow: 0 8px 20px rgba(0,0,0,0.15);
    }
    .service-card h3 {
      color: var(--color-primary);
      margin-bottom: 1rem;
      font-size: 1.3rem;
    }
    .service-card .price {
      color: var(--color-accent);
      font-weight: bold;
      margin-top: 1rem;
      font-size: 1.2rem;
    }

    /* Contact Grid */
    .contact-grid {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
      gap: 40px;
      max-width: 800px;
      margin: 0 auto;
    }
    .contact-item h3 {
      color: var(--color-primary);
      margin-bottom: 0.5rem;
    }
    .contact-item a {
      color: var(--color-secondary);
      text-decoration: none;
    }
    .contact-item a:hover { text-decoration: underline; }

    /* Social Links */
    .social-links {
      display: flex;
      gap: 15px;
      margin-top: 20px;
      justify-content: center;
    }
    .social-link {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 40px;
      height: 40px;
      background: var(--color-primary);
      color: white;
      border-radius: 50%;
      text-decoration: none;
      font-weight: bold;
      font-size: 0.8rem;
      transition: background 0.3s;
    }
    .social-link:hover { background: var(--color-secondary); }

    /* Block styles */
    .block { margin-bottom: 2rem; }
    .block-text { max-width: 800px; margin-left: auto; margin-right: auto; font-size: 1.1rem; }
    .block-text.align-center { text-align: center; }
    .block-text.align-right { text-align: right; }
    .block-text.size-small { font-size: 0.9rem; }
    .block-text.size-large { font-size: 1.25rem; }
    .block-heading { text-align: center; }
    .block-heading.align-left { text-align: left; }
    .block-heading.align-right { text-align: right; }
    .block-image { text-align: center; }
    .block-image img { max-width: 100%; height: auto; border-radius: 8px; }
    .block-image.width-wide img { max-width: 90%; }
    .block-image.width-medium img { max-width: 60%; }
    .block-image.width-small img { max-width: 40%; }
    .block-image figcaption { color: #666; font-size: 0.9rem; margin-top: 0.5rem; font-style: italic; }
    .block-button { text-align: center; }
    .block-button.align-left { text-align: left; }
    .block-button.align-right { text-align: right; }
    .block-button a {
      display: inline-block;
      padding: 12px 32px;
      border-radius: 8px;
      text-decoration: none;
      font-weight: 600;
      transition: opacity 0.2s;
    }
    .block-button a:hover { opacity: 0.9; }
    .block-button.style-primary a { background: var(--color-primary); color: white; }
    .block-button.style-secondary a { background: var(--color-secondary); color: white; }
    .block-button.style-outline a { border: 2px solid var(--color-primary); color: var(--color-primary); background: transparent; }
    .block-button.size-small a { padding: 8px 20px; font-size: 0.9rem; }
    .block-button.size-large a { padding: 16px 40px; font-size: 1.1rem; }
    .block-spacer-small { height: 20px; }
    .block-spacer-medium { height: 40px; }
    .block-spacer-large { height: 60px; }
    .block-divider { border: none; margin: 2rem auto; max-width: 80%; }
    .block-divider.style-solid { border-top: 1px solid #ddd; }
    .block-divider.style-dashed { border-top: 1px dashed #ddd; }
    .block-divider.style-dotted { border-top: 1px dotted #ddd; }
    .block-columns { display: grid; gap: 30px; max-width: 1100px; margin: 0 auto; }
    .block-columns.layout-2-equal { grid-template-columns: 1fr 1fr; }
    .block-columns.layout-3-equal { grid-template-columns: 1fr 1fr 1fr; }
    .block-columns.layout-1-2 { grid-template-columns: 1fr 2fr; }
    .block-columns.layout-2-1 { grid-template-columns: 2fr 1fr; }
    .block-video { text-align: center; }
    .block-video .video-wrapper { position: relative; padding-bottom: 56.25%; height: 0; overflow: hidden; max-width: 800px; margin: 0 auto; border-radius: 8px; }
    .block-video .video-wrapper.ratio-4-3 { padding-bottom: 75%; }
    .block-video .video-wrapper.ratio-1-1 { padding-bottom: 100%; }
    .block-video .video-wrapper iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
    .block-cta {
      text-align: center;
      padding: 60px 40px;
      border-radius: 12px;
      background: linear-gradient(135deg, var(--color-primary), var(--color-secondary));
      color: white;
      max-width: 900px;
      margin: 0 auto;
    }
    .block-cta h2 { color: white; margin-bottom: 1rem; }
    .block-cta p { font-size: 1.1rem; opacity: 0.9; margin-bottom: 2rem; }
    .block-cta a { display: inline-block; padding: 14px 36px; background: white; color: var(--color-primary); border-radius: 8px; text-decoration: none; font-weight: 600; }
    .block-feature {
      text-align: center;
      padding: 30px;
      background: white;
      border-radius: 12px;
      box-shadow: 0 2px 8px rgba(0,0,0,0.08);
    }
    .block-feature .feature-icon { font-size: 2rem; margin-bottom: 1rem; }
    .block-feature h3 { color: var(--color-primary); margin-bottom: 0.5rem; }
    .features-grid {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
      gap: 24px;
      max-width: 1000px;
      margin: 0 auto;
    }

    /* FAQ Accordion */
    .faq-section { max-width: 800px; margin: 0 auto; }
    .faq-item { border-bottom: 1px solid #e5e7eb; }
    .faq-question {
      width: 100%;
      text-align: left;
      padding: 20px 0;
      background: none;
      border: none;
      font-size: 1.1rem;
      font-weight: 600;
      color: var(--color-text);
      cursor: pointer;
      display: flex;
      justify-content: space-between;
      align-items: center;
      font-family: inherit;
    }
    .faq-question:hover { color: var(--color-primary); }
    .faq-question::after { content: "+"; font-size: 1.5rem; transition: transform 0.3s; }
    .faq-item.open .faq-question::after { transform: rotate(45deg); }
    .faq-answer {
      max-height: 0;
      overflow: hidden;
      transition: max-height 0.3s ease, padding 0.3s ease;
      padding: 0 0;
      font-size: 1rem;
      line-height: 1.7;
      color: #4b5563;
    }
    .faq-item.open .faq-answer { max-height: 500px; padding: 0 0 20px 0; }

    /* Pricing Table */
    .pricing-grid {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
      gap: 30px;
      max-width: 1100px;
      margin: 0 auto;
    }
    .pricing-card {
      background: white;
      border-radius: 12px;
      padding: 40px 30px;
      box-shadow: 0 4px 6px rgba(0,0,0,0.1);
      text-align: center;
      position: relative;
      transition: transform 0.3s;
    }
    .pricing-card:hover { transform: translateY(-5px); }
    .pricing-card.highlighted {
      border: 2px solid var(--color-primary);
      box-shadow: 0 8px 25px rgba(0,0,0,0.15);
    }
    .pricing-card h3 { font-size: 1.3rem; margin-bottom: 1rem; color: var(--color-primary); }
    .pricing-card .price { font-size: 2.5rem; font-weight: 700; color: var(--color-text); margin-bottom: 0.5rem; }
    .pricing-card .period { color: #6b7280; font-size: 0.9rem; margin-bottom: 1.5rem; }
    .pricing-card ul { list-style: none; margin-bottom: 2rem; text-align: left; }
    .pricing-card ul li { padding: 8px 0; border-bottom: 1px solid #f3f4f6; }
    .pricing-card ul li::before { content: "\2713"; color: var(--color-primary); font-weight: bold; margin-right: 8px; }
    .pricing-card .pricing-btn {
      display: inline-block;
      padding: 12px 32px;
      background: var(--color-primary);
      color: white;
      border-radius: 8px;
      text-decoration: none;
      font-weight: 600;
    }

    /* Image Gallery */
    .gallery-grid {
      display: grid;
      gap: 16px;
      max-width: 1100px;
      margin: 0 auto;
    }
    .gallery-grid.cols-2 { grid-template-columns: repeat(2, 1fr); }
    .gallery-grid.cols-3 { grid-template-columns: repeat(3, 1fr); }
    .gallery-grid.cols-4 { grid-template-columns: repeat(4, 1fr); }
    .gallery-item { overflow: hidden; border-radius: 8px; }
    .gallery-item img { width: 100%; height: 250px; object-fit: cover; transition: transform 0.3s; }
    .gallery-item:hover img { transform: scale(1.05); }
    .gallery-item figcaption { padding: 8px 12px; font-size: 0.85rem; color: #666; }

    /* Embed */
    .block-embed { max-width: 1000px; margin: 0 auto; }
    .block-embed iframe { width: 100%; border: none; border-radius: 8px; }

    /* Legal pages */
    .legal-content { max-width: 800px; margin: 0 auto; line-height: 1.8; }
    .legal-content h2 { text-align: left; font-size: 1.5rem; margin-top: 2rem; }
    .legal-content h3 { font-size: 1.2rem; margin-top: 1.5rem; color: var(--color-text); }
    .legal-content p { margin-bottom: 1rem; }

    /* Footer */
    footer {
      background: var(--color-text);
      color: var(--color-background);
      text-align: center;
      padding: 30px 20px;
    }
    footer a { color: var(--color-accent); text-decoration: none; }
    footer a:hover { text-decoration: underline; }
    .footer-links { display: flex; justify-content: center; gap: 24px; margin-bottom: 1rem; flex-wrap: wrap; }
    .footer-links a { color: rgba(255,255,255,0.8); font-size: 0.9rem; }

    /* Responsive */
    @media (max-width: 768px) {
      header h1 { font-size: 2rem; }
      header p { font-size: 1.2rem; }
      section { padding: 40px 15px; }
      .site-nav .nav-links { display: none; flex-direction: column; position: absolute; top: 100%; left: 0; right: 0; background: var(--color-primary); }
      .site-nav .nav-links.open { display: flex; }
      .nav-toggle { display: block; }
      .block-columns.layout-2-equal,
      .block-columns.layout-3-equal,
      .block-columns.layout-1-2,
      .block-columns.layout-2-1 { grid-template-columns: 1fr; }
      .gallery-grid.cols-3,
      .gallery-grid.cols-4 { grid-template-columns: repeat(2, 1fr); }
    }
  