* {
      margin: 0;
      padding: 0;
      box-sizing: border-box;
    }

    :root, [data-theme="light"] {
      --bg:#f6f1e8; --surface:#fcfaf5; --surface2:#efe6d8; --ink:#2f261d; --muted:#6f655a; --faint:#a0978b;
      --primary:#52745c; --accent:#b77b42; --line:#d7ccbb; --inverse:#fffaf3;
      --shadow:0 16px 40px rgba(47,38,29,.10); --radius:24px; --radius-sm:14px;
      --font-display:'EB Garamond', serif; --font-body:'Manrope', sans-serif;
      --error:#c25a5a;
    }
    [data-theme="dark"] {
      --bg:#181411; --surface:#221d18; --surface2:#302821; --ink:#efe5d6; --muted:#c3b8aa; --faint:#8f8477;
      --primary:#90b497; --accent:#d59e69; --line:#4a4035; --inverse:#1c1712; --shadow:0 18px 42px rgba(0,0,0,.35);
      --error:#d67a7a;
    }

    body {
      font-family: var(--font-body);
      background: var(--bg);
      color: var(--ink);
      line-height: 1.65;
      background-image: radial-gradient(circle at 10% 10%, rgba(183,123,66,.08), transparent 18%), radial-gradient(circle at 90% 80%, rgba(82,116,92,.10), transparent 20%);
    }

    .wrap {
      max-width: 1280px;
      margin: 0 auto;
      padding: 20px 16px 32px;
    }

    .top {
      display: flex;
      justify-content: space-between;
      align-items: center;
      gap: 16px;
      padding: 8px 0 20px;
      flex-wrap: wrap;
    }

    .brand {
      display: flex;
      gap: 12px;
      align-items: center;
      flex: 1;
      min-width: 180px;
    }

    .brand img {
      width: 50px;
      height: auto;
      flex-shrink: 0;
    }

    .brand h1 {
      font: 600 clamp(1.4rem, 5vw, 2.2rem)/1.2 var(--font-display);
    }

    .brand p {
      font-size: 0.75rem;
      color: var(--muted);
      line-height: 1.3;
    }

    .top-actions {
      display: flex;
      gap: 8px;
      align-items: center;
      flex-wrap: wrap;
    }

    .quick-link, .toggle {
      min-width: 42px;
      min-height: 42px;
      border: 1px solid var(--line);
      border-radius: 999px;
      background: var(--surface);
      color: var(--ink);
      display: inline-flex;
      align-items: center;
      justify-content: center;
      text-decoration: none;
      padding: 0 14px;
      font-weight: 600;
      font-size: 0.85rem;
      cursor: pointer;
    }

    .hero {
      background: linear-gradient(135deg, var(--surface), var(--surface2));
      border: 1px solid var(--line);
      border-radius: 32px;
      padding: 24px 20px;
      box-shadow: var(--shadow);
      margin-bottom: 32px;
    }

    .hero h2 {
      font: 600 clamp(1.6rem, 5vw, 2.5rem)/1.1 var(--font-display);
      margin: 0.2em 0;
    }

    .eyebrow {
      letter-spacing: .16em;
      text-transform: uppercase;
      font-size: 0.7rem;
      font-weight: 700;
      color: var(--accent);
      margin-bottom: 12px;
    }

    .form-card {
      background: var(--surface);
      border: 1px solid var(--line);
      border-radius: var(--radius);
      padding: 28px 24px;
      box-shadow: var(--shadow);
      margin-bottom: 32px;
    }

    .form-grid {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 24px;
    }

    @media (max-width: 700px) {
      .form-grid {
        grid-template-columns: 1fr;
        gap: 20px;
      }
    }

    .form-field {
      display: flex;
      flex-direction: column;
      gap: 8px;
    }

    .form-field.full-width {
      grid-column: span 2;
    }

    @media (max-width: 700px) {
      .form-field.full-width {
        grid-column: span 1;
      }
    }

    .phone-group {
      display: grid;
      grid-template-columns: 100px 1fr;
      gap: 12px;
      align-items: start;
    }

    @media (max-width: 480px) {
      .phone-group {
        grid-template-columns: 1fr;
        gap: 8px;
      }
    }

    label {
      font-weight: 600;
      font-size: 0.85rem;
      color: var(--ink);
    }

    label .required {
      color: var(--accent);
      margin-left: 4px;
    }

    input, select, textarea {
      background: var(--bg);
      border: 1px solid var(--line);
      border-radius: 14px;
      padding: 12px 14px;
      font-family: var(--font-body);
      font-size: 0.9rem;
      color: var(--ink);
      transition: 0.2s;
    }

    input[type="file"] {
      padding: 8px;
      background: var(--bg);
    }

    textarea {
      resize: vertical;
      min-height: 120px;
    }

    input:focus, select:focus, textarea:focus {
      outline: none;
      border-color: var(--primary);
      box-shadow: 0 0 0 3px rgba(82,116,92,0.2);
    }

    input.error, select.error, textarea.error {
      border-color: var(--error);
      background-color: rgba(194,90,90,0.05);
    }

    .error-message {
      color: var(--error);
      font-size: 0.75rem;
      margin-top: 4px;
      display: flex;
      align-items: center;
      gap: 4px;
    }

    .address-group {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 12px;
      margin-top: 8px;
    }

    @media (max-width: 500px) {
      .address-group {
        grid-template-columns: 1fr;
      }
    }

    .checkbox-group {
      display: flex;
      align-items: flex-start;
      gap: 12px;
      margin: 12px 0;
    }

    .checkbox-group input {
      width: 20px;
      height: 20px;
      margin-top: 2px;
      accent-color: var(--primary);
    }

    .checkbox-group.error .checkbox-label {
      color: var(--error);
    }

    .radio-group {
      display: flex;
      gap: 24px;
      align-items: center;
      margin-top: 6px;
    }

    .radio-option {
      display: flex;
      align-items: center;
      gap: 8px;
    }

    .radio-option input {
      width: 18px;
      height: 18px;
      margin: 0;
    }

    .conditional-field {
      display: none;
      margin-top: 12px;
      padding: 16px;
      background: rgba(82,116,92,0.08);
      border-radius: 16px;
      border-left: 3px solid var(--primary);
    }

    .conditional-field.visible {
      display: block;
    }

    .conditional-field .form-field {
      margin-bottom: 16px;
    }

    .conditional-field .form-field:last-child {
      margin-bottom: 0;
    }

    .btn-row {
      display: flex;
      gap: 16px;
      flex-wrap: wrap;
      margin-top: 24px;
      justify-content: flex-start;
    }

    .btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 48px;
      padding: 0 28px;
      border-radius: 999px;
      text-decoration: none;
      font-weight: 700;
      border: 1px solid var(--line);
      font-size: 0.9rem;
      transition: 0.2s;
      cursor: pointer;
      background: var(--surface);
      color: var(--ink);
    }

    .btn-primary {
      background: var(--primary);
      color: var(--inverse);
      border-color: transparent;
    }

    .btn-primary:hover {
      opacity: 0.9;
      transform: translateY(-1px);
    }

    .alert {
      padding: 16px 20px;
      border-radius: 20px;
      margin-bottom: 24px;
      font-weight: 500;
    }

    .alert-success {
      background: #d4edda;
      color: #155724;
      border: 1px solid #c3e6cb;
    }

    .alert-error {
      background: #f8d7da;
      color: #721c24;
      border: 1px solid #f5c6cb;
    }

    .footer {
      margin: 32px 0 10px;
      text-align: center;
      color: var(--muted);
      font-size: 0.8rem;
      border-top: 1px solid var(--line);
      padding-top: 20px;
    }

    .small-note {
      font-size: 0.8rem;
      color: var(--muted);
      margin-top: 8px;
    }

    .word-count {
      font-size: 0.7rem;
      color: var(--muted);
      text-align: right;
      margin-top: 4px;
    }

    .photo-preview {
      margin-top: 10px;
      display: none;
    }

    .photo-preview img {
      max-width: 150px;
      border-radius: 12px;
      border: 2px solid var(--primary);
    }