:root {
  --bg: #fef5f3;
  --paper: #ffffff;
  --ink: #1f1216;
  --ink-soft: #6f5860;
  --rule: #f0d8d8;
  --primary: #c2425e;
  --primary-dark: #a02f48;
  --rose-soft: #f4c5d0;
  --gold: #d4a574;
  --serif: 'Iowan Old Style', 'Hoefler Text', Georgia, serif;
  --sans: -apple-system, BlinkMacSystemFont, 'Inter', 'Segoe UI', Helvetica, Arial, sans-serif;
}
* { box-sizing: border-box; margin: 0; padding: 0; }
body { font-family: var(--sans); background: var(--bg); color: var(--ink); line-height: 1.7; -webkit-font-smoothing: antialiased; }
.container { max-width: 1080px; margin: 0 auto; padding: 0 28px; }
a { color: var(--primary); text-decoration: none; }
a:hover { color: var(--primary-dark); }

header.sheep { padding: 24px 0; background: var(--bg); border-bottom: 1px solid var(--rule); text-align: center; }
.sheep-mark { display: inline-block; font-family: var(--serif); font-style: italic; font-size: 11px; letter-spacing: 0.28em; color: var(--gold); text-transform: uppercase; margin-bottom: 8px; }
.brand { display: inline-flex; align-items: center; gap: 8px; font-family: var(--serif); font-style: italic; font-size: 36px; color: var(--primary); text-decoration: none; font-weight: 400; line-height: 1; letter-spacing: -0.005em; }
.brand-icon { width: 24px; height: 24px; flex-shrink: 0; vertical-align: middle; margin-right: 6px; }
header.sheep nav { margin-top: 18px; padding-top: 14px; border-top: 1px solid var(--rule); display: inline-flex; gap: 32px; }
header.sheep nav a { font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-soft); text-decoration: none; font-weight: 500; }
header.sheep nav a:hover { color: var(--primary); }

.gift-hero { padding: 72px 0 56px; text-align: center; position: relative; }
.gift-hero h1 { font-family: var(--serif); font-style: italic; font-size: 48px; line-height: 1.15; color: var(--ink); margin-bottom: 22px; font-weight: 400; max-width: 18ch; margin: 0 auto 22px; }
.gift-hero h1 em { color: var(--primary); }
.gift-hero .lede { font-size: 17px; color: var(--ink-soft); max-width: 56ch; margin: 0 auto 28px; line-height: 1.85; }
.btn-bow { display: inline-block; padding: 14px 32px; background: var(--primary); color: var(--paper); text-decoration: none; font-size: 12px; letter-spacing: 0.22em; text-transform: uppercase; border-radius: 0; font-weight: 600; }
.btn-bow:hover { background: var(--primary-dark); color: var(--paper); }

.featured-locket { padding: 64px 0; background: var(--paper); border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); }
.featured-locket .grid { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
.locket-frame { aspect-ratio: 1; background: var(--rose-soft); border-radius: 50%; padding: 36px; display: flex; align-items: center; justify-content: center; position: relative; max-width: 360px; margin: 0 auto; }
.locket-frame::before { content: ''; position: absolute; inset: 16px; border: 2px solid var(--gold); border-radius: 50%; }
.locket-inner { background: var(--paper); width: 70%; aspect-ratio: 1; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-family: var(--serif); font-style: italic; font-size: 44px; color: var(--gold); border: 4px solid var(--gold); }
.locket-content .eyebrow { font-family: var(--serif); font-style: italic; font-size: 14px; color: var(--gold); margin-bottom: 12px; }
.locket-content h2 { font-family: var(--serif); font-style: italic; font-size: 32px; color: var(--ink); margin-bottom: 16px; font-weight: 400; line-height: 1.25; }
.locket-content p { color: var(--ink-soft); margin-bottom: 14px; font-size: 16px; line-height: 1.8; }
.locket-content .price-tag { font-family: var(--serif); font-style: italic; font-size: 22px; color: var(--primary); margin-top: 16px; }

.types { padding: 80px 0; text-align: center; }
.section-eyebrow { font-family: var(--serif); font-style: italic; font-size: 14px; color: var(--gold); margin-bottom: 8px; }
.section-title { font-family: var(--serif); font-style: italic; font-size: 32px; color: var(--ink); margin-bottom: 40px; font-weight: 400; }
.type-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.type { padding: 0 8px; }
.type-circle { width: 80px; height: 80px; border-radius: 50%; background: var(--rose-soft); margin: 0 auto 16px; position: relative; }
.type-circle::after { content: ''; position: absolute; inset: 12px; border: 2px solid var(--gold); border-radius: 50%; }
.type:nth-child(2) .type-circle { background: var(--gold); }
.type:nth-child(2) .type-circle::after { border-color: var(--paper); }
.type:nth-child(3) .type-circle { background: var(--primary); }
.type:nth-child(3) .type-circle::after { border-color: var(--rose-soft); }
.type h3 { font-family: var(--serif); font-style: italic; font-size: 20px; color: var(--ink); margin-bottom: 6px; font-weight: 400; }
.type p { font-size: 13px; color: var(--ink-soft); line-height: 1.65; }
.type .price { font-family: var(--serif); font-style: italic; color: var(--primary); margin-top: 8px; }

.process-band { padding: 72px 0; background: var(--paper); border-top: 1px solid var(--rule); }
.process-band .container { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
.process-band h2 { font-family: var(--serif); font-style: italic; font-size: 28px; color: var(--ink); margin-bottom: 18px; font-weight: 400; line-height: 1.3; }
.process-band p { color: var(--ink-soft); margin-bottom: 14px; line-height: 1.8; }
.steps-list { list-style: none; padding: 0; counter-reset: stp; }
.steps-list li { padding: 14px 0; padding-left: 48px; counter-increment: stp; position: relative; border-bottom: 1px dotted var(--rule); font-size: 14px; color: var(--ink-soft); }
.steps-list li::before { content: counter(stp); position: absolute; left: 0; top: 14px; width: 32px; height: 32px; border-radius: 50%; background: var(--rose-soft); color: var(--primary); display: flex; align-items: center; justify-content: center; font-family: var(--serif); font-style: italic; font-weight: 400; }
.steps-list strong { color: var(--ink); display: block; margin-bottom: 4px; }

.contact { padding: 72px 0; text-align: center; }
.contact h2 { font-family: var(--serif); font-style: italic; font-size: 28px; color: var(--ink); margin-bottom: 16px; font-weight: 400; }
.contact p { color: var(--ink-soft); max-width: 500px; margin: 0 auto 24px; }

footer { padding: 32px 0; text-align: center; color: var(--ink-soft); font-size: 13px; border-top: 1px solid var(--rule); }
footer p { margin-bottom: 4px; }
footer a { color: var(--primary); text-decoration: none; }

article.page { padding: 64px 0; max-width: 1080px; margin: 0 auto; padding-left: 28px; padding-right: 28px; }
article.page h1 { font-family: var(--serif); font-style: italic; font-size: 40px; color: var(--primary); margin-bottom: 24px; line-height: 1.2; font-weight: 400; }
article.page h2 { font-family: var(--serif); font-style: italic; font-size: 22px; color: var(--ink); margin-top: 36px; margin-bottom: 12px; font-weight: 400; }

/* Site images */
.hero-img { width: 100%; max-width: 900px; height: auto; display: block; margin: 32px auto 0; border-radius: 8px; }
.jewelry-image { padding: 0; }
.full-img { width: 100%; height: auto; display: block; max-height: 400px; object-fit: cover; border-radius: 8px; margin: 0 auto; }
.page-img { width: 100%; max-height: 420px; object-fit: cover; display: block; margin: 24px auto; border-radius: 4px; }

body > header:not([class]) { padding: 22px 0; border-bottom: 1px solid var(--rule); text-align: center; }
body > header:not([class]) .container { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 16px; }
body > header:not([class]) .brand { display: inline-flex; align-items: center; gap: 10px; font-family: var(--serif); font-style: italic; font-size: 36px; color: var(--primary); text-decoration: none; }
body > header:not([class]) .brand-icon { width: 24px; height: 24px; flex-shrink: 0; color: var(--gold); }
body > header:not([class]) nav { display: flex; gap: 26px; }
body > header:not([class]) nav a { font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-soft); text-decoration: none; }

@media (max-width: 800px) {
  .gift-hero h1 { font-size: 32px; }
  .featured-locket .grid { grid-template-columns: 1fr; gap: 24px; }
  .type-grid { grid-template-columns: 1fr; gap: 24px; }
  .process-band .container { grid-template-columns: 1fr; gap: 24px; }
}
