/* ==========================================================================
   Writers Cottage · stylesheet
   Written slowly, by hand. Every value chosen on purpose.
   ========================================================================== */

/* ---- Tokens --------------------------------------------------------------
   Colour palette pulled from the brief. Cream like aged paper, sage like
   faded shutters, warm grey for quiet body copy, terracotta for the tiniest
   of accents.
*/
:root {
    --cream: #f5efe2;
    --cream-warm: #efe7d4;
    --cream-deep: #e8dfc9;
    --paper-shadow: rgba(94, 72, 40, 0.08);

    --sage: #8a9a7b;
    --sage-deep: #6f8263;
    --sage-soft: #c2ccb6;
    --sage-pale: #e2e7d9;

    --grey-warm: #6b635a;
    --grey-soft: #8a8378;
    --grey-muted: #a89f92;

    --terracotta: #b26a4d;
    --terracotta-soft: #d89579;
    --wax-red: #9c4a3a;

    --ink: #3b352d;

    --font-display: 'Playfair Display', 'Cormorant Garamond', Georgia, 'Times New Roman', serif;
    --font-serif-italic: 'Cormorant Garamond', 'Playfair Display', Georgia, serif;
    --font-body: 'Lato', 'Source Sans Pro', -apple-system, BlinkMacSystemFont, 'Segoe UI', Helvetica, Arial, sans-serif;

    --shadow-soft: 0 1px 2px rgba(94, 72, 40, 0.06), 0 6px 18px rgba(94, 72, 40, 0.06);
    --shadow-lifted: 0 2px 4px rgba(94, 72, 40, 0.08), 0 18px 40px rgba(94, 72, 40, 0.12);

    --radius-sm: 6px;
    --radius-md: 12px;
    --radius-lg: 18px;

    --ease: cubic-bezier(0.22, 0.61, 0.36, 1);
    --ease-settle: cubic-bezier(0.16, 0.8, 0.4, 1);

    --max-width: 1200px;
    --gutter: clamp(1.25rem, 4vw, 2.5rem);
}

/* ---- Reset (gentle) ------------------------------------------------------ */
*, *::before, *::after {
    box-sizing: border-box;
}

html {
    -webkit-text-size-adjust: 100%;
    scroll-behavior: smooth;
}

body, h1, h2, h3, h4, h5, h6, p, figure, blockquote, dl, dd, ul, ol {
    margin: 0;
}

ul, ol {
    padding: 0;
    list-style: none;
}

img, svg, video {
    display: block;
    max-width: 100%;
    height: auto;
}

button {
    font: inherit;
    background: none;
    border: 0;
    cursor: pointer;
    color: inherit;
}

a {
    color: inherit;
    text-decoration: none;
}

input, textarea, select, button {
    font: inherit;
    color: inherit;
}

/* ---- Base ---------------------------------------------------------------- */
html, body {
    background: var(--cream);
}

body {
    font-family: var(--font-body);
    font-weight: 400;
    font-size: 17px;
    line-height: 1.75;
    color: var(--grey-warm);
    background-color: var(--cream);
    /* Subtle paper grain, built from layered SVG noise so no asset is needed.
       Sits over the cream at extremely low opacity. */
    background-image:
        radial-gradient(circle at 20% 10%, rgba(138, 154, 123, 0.05), transparent 45%),
        radial-gradient(circle at 85% 80%, rgba(178, 106, 77, 0.04), transparent 40%),
        url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200' viewBox='0 0 200 200'><filter id='g'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.27  0 0 0 0 0.22  0 0 0 0 0.13  0 0 0 0.18 0'/></filter><rect width='100%' height='100%' filter='url(%23g)' opacity='0.45'/></svg>");
    background-attachment: fixed, fixed, fixed;
    background-size: auto, auto, 220px 220px;
    min-height: 100vh;
    overflow-x: hidden;
}

::selection {
    background: var(--sage-pale);
    color: var(--ink);
}

::-webkit-scrollbar {
    width: 10px;
    height: 10px;
}
::-webkit-scrollbar-track {
    background: var(--cream-warm);
}
::-webkit-scrollbar-thumb {
    background: var(--sage-soft);
    border-radius: 10px;
    border: 2px solid var(--cream-warm);
}
::-webkit-scrollbar-thumb:hover {
    background: var(--sage);
}
html {
    scrollbar-width: thin;
    scrollbar-color: var(--sage-soft) var(--cream-warm);
}

/* ---- Typography ---------------------------------------------------------- */
h1, h2, h3, h4 {
    font-family: var(--font-display);
    color: var(--sage-deep);
    font-weight: 500;
    letter-spacing: 0.01em;
    line-height: 1.15;
}

h1 {
    font-size: clamp(2.4rem, 5.6vw, 4.2rem);
    letter-spacing: 0.005em;
    line-height: 1.08;
}

h2 {
    font-size: clamp(1.9rem, 3.6vw, 2.8rem);
}

h3 {
    font-size: clamp(1.25rem, 2.2vw, 1.55rem);
}

h4 {
    font-size: 1.1rem;
}

p {
    max-width: 62ch;
}

p + p {
    margin-top: 1.1em;
}

a.text-link, .prose a {
    color: var(--sage-deep);
    border-bottom: 1px solid var(--sage-soft);
    transition: color 300ms var(--ease), border-color 300ms var(--ease);
}

a.text-link:hover, .prose a:hover {
    color: var(--sage);
    border-bottom-color: var(--sage);
}

.lede {
    font-family: var(--font-serif-italic);
    font-style: italic;
    font-size: clamp(1.15rem, 1.6vw, 1.35rem);
    color: var(--grey-warm);
    line-height: 1.55;
}

.eyebrow {
    font-family: var(--font-body);
    text-transform: uppercase;
    letter-spacing: 0.22em;
    font-size: 0.72rem;
    color: var(--sage);
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
}

.eyebrow::before {
    content: "";
    width: 22px;
    height: 1px;
    background: var(--sage);
}

/* ---- Layout -------------------------------------------------------------- */
.container {
    width: 100%;
    max-width: var(--max-width);
    margin-inline: auto;
    padding-inline: var(--gutter);
}

.container--narrow {
    max-width: 820px;
}

section {
    padding-block: clamp(4rem, 9vw, 8rem);
    position: relative;
}

.section-title {
    margin-bottom: 1.2rem;
}

.section-intro {
    max-width: 58ch;
    margin-bottom: clamp(2rem, 4vw, 3.5rem);
}

.skip-link {
    position: absolute;
    left: -9999px;
    top: 0;
    background: var(--sage-deep);
    color: var(--cream);
    padding: 0.75rem 1rem;
    border-radius: var(--radius-sm);
    z-index: 1000;
}
.skip-link:focus {
    left: 1rem;
    top: 1rem;
}

/* ---- Header / Navigation ------------------------------------------------- */
.site-header {
    position: sticky;
    top: 0;
    z-index: 50;
    background: transparent;
    transition: background 400ms var(--ease), box-shadow 400ms var(--ease), padding 400ms var(--ease);
    padding-block: 1.6rem;
}

.site-header.is-scrolled {
    background: rgba(245, 239, 226, 0.78);
    backdrop-filter: blur(10px) saturate(1.02);
    -webkit-backdrop-filter: blur(10px) saturate(1.02);
    box-shadow: 0 1px 0 rgba(94, 72, 40, 0.06);
    padding-block: 1rem;
}

.header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 2rem;
}

.brandmark {
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
    color: var(--sage-deep);
    font-family: var(--font-display);
    font-size: 1.25rem;
    letter-spacing: 0.04em;
    transition: color 300ms var(--ease);
}
.brandmark:hover {
    color: var(--sage);
}
.brandmark__icon {
    width: 30px;
    height: 30px;
}
.brandmark__text {
    display: inline-block;
}

.brandmark--light {
    color: var(--cream);
}
.brandmark--light:hover {
    color: var(--sage-pale);
}

.primary-nav ul {
    display: flex;
    gap: clamp(1.25rem, 2.4vw, 2.25rem);
    align-items: center;
}

.primary-nav a {
    position: relative;
    color: var(--sage-deep);
    font-size: 0.95rem;
    letter-spacing: 0.04em;
    padding-block: 0.35rem;
    transition: color 350ms var(--ease);
}

.primary-nav a::after {
    content: "";
    position: absolute;
    left: 0;
    right: auto;
    bottom: 0;
    width: 0;
    height: 1px;
    background: var(--sage);
    transition: width 350ms var(--ease);
}

.primary-nav a:hover::after,
.primary-nav a:focus-visible::after {
    width: 100%;
}

.primary-nav a.is-active::after {
    width: 100%;
}

.nav-toggle {
    display: none;
    width: 44px;
    height: 44px;
    padding: 10px;
    border-radius: var(--radius-sm);
    color: var(--sage-deep);
    position: relative;
}
.nav-toggle__bar {
    display: block;
    width: 22px;
    height: 1.5px;
    background: currentColor;
    margin: 5px auto;
    transition: transform 350ms var(--ease), opacity 300ms var(--ease);
    transform-origin: center;
}
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(1) {
    transform: translateY(6.5px) rotate(45deg);
}
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(2) {
    opacity: 0;
}
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(3) {
    transform: translateY(-6.5px) rotate(-45deg);
}

@media (max-width: 860px) {
    .nav-toggle {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        flex-direction: column;
    }
    .primary-nav {
        position: fixed;
        top: 0;
        right: 0;
        bottom: 0;
        width: min(80vw, 340px);
        background: var(--cream);
        border-left: 1px solid var(--sage-pale);
        padding: 6rem 2.5rem 3rem;
        transform: translateX(110%);
        transition: transform 500ms var(--ease-settle);
        box-shadow: -18px 0 40px rgba(94, 72, 40, 0.1);
    }
    .primary-nav.is-open {
        transform: translateX(0);
    }
    .primary-nav ul {
        flex-direction: column;
        align-items: flex-start;
        gap: 1.75rem;
    }
    .primary-nav a {
        font-size: 1.25rem;
        font-family: var(--font-display);
        color: var(--sage-deep);
        letter-spacing: 0.03em;
    }
    body.nav-open {
        overflow: hidden;
    }
}

/* ---- Buttons ------------------------------------------------------------- */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.6rem;
    padding: 0.95rem 1.8rem;
    border-radius: 999px;
    font-family: var(--font-body);
    font-weight: 700;
    font-size: 0.95rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    background: var(--sage);
    color: var(--cream);
    transition: background 350ms var(--ease), transform 350ms var(--ease), box-shadow 400ms var(--ease), color 350ms var(--ease);
    box-shadow: 0 1px 0 rgba(94, 72, 40, 0.08), 0 10px 22px rgba(138, 154, 123, 0.22);
    border: 1px solid transparent;
}

.btn:hover,
.btn:focus-visible {
    background: var(--sage-deep);
    transform: translateY(1px);
    box-shadow: 0 1px 0 rgba(94, 72, 40, 0.1), 0 14px 30px rgba(111, 130, 99, 0.28), 0 0 0 6px rgba(138, 154, 123, 0.14);
    outline: none;
}

.btn--ghost {
    background: transparent;
    color: var(--sage-deep);
    border-color: var(--sage);
    box-shadow: none;
}
.btn--ghost:hover,
.btn--ghost:focus-visible {
    background: var(--sage-pale);
    color: var(--sage-deep);
    box-shadow: 0 0 0 6px rgba(138, 154, 123, 0.14);
}

/* ---- Dividers ------------------------------------------------------------ */
.rule {
    width: 92px;
    height: 2px;
    border: 0;
    background: var(--sage);
    border-radius: 2px;
    margin: 1.6rem 0 2rem;
    position: relative;
    opacity: 0.9;
}
.rule--center {
    margin-inline: auto;
}

.sprig-divider {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1.25rem;
    padding-block: 1.75rem;
    color: var(--sage);
}
.sprig-divider::before,
.sprig-divider::after {
    content: "";
    display: block;
    width: clamp(40px, 12vw, 120px);
    height: 1px;
    background: currentColor;
    opacity: 0.5;
}
.sprig-divider svg {
    width: 38px;
    height: 38px;
    opacity: 0.85;
}

.hand-rule {
    display: block;
    width: min(720px, 80%);
    height: 14px;
    margin: 0 auto;
    color: var(--sage);
    opacity: 0.7;
}

/* ---- Hero ---------------------------------------------------------------- */
.hero {
    min-height: calc(100vh - 120px);
    display: flex;
    align-items: center;
    padding-block: clamp(5rem, 14vw, 9rem);
    position: relative;
    overflow: hidden;
}

.hero__backdrop {
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        radial-gradient(ellipse at 80% 30%, rgba(138, 154, 123, 0.08), transparent 55%),
        radial-gradient(ellipse at 10% 90%, rgba(178, 106, 77, 0.05), transparent 50%);
    will-change: transform;
}

.hero__backdrop svg {
    position: absolute;
    width: min(680px, 70%);
    right: -4%;
    top: 6%;
    opacity: 0.05;
    color: var(--sage-deep);
}

.hero__content {
    position: relative;
    max-width: 760px;
}

.hero h1 {
    font-weight: 500;
    color: var(--sage-deep);
}

.hero__subheading {
    margin-top: 1.75rem;
    font-size: clamp(1.05rem, 1.5vw, 1.2rem);
    color: var(--grey-warm);
    line-height: 1.7;
    max-width: 56ch;
}

.hero__cta {
    margin-top: 2.4rem;
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
    align-items: center;
}

.hero__postmark {
    font-family: var(--font-serif-italic);
    font-style: italic;
    color: var(--grey-soft);
    font-size: 1rem;
    letter-spacing: 0.02em;
}

/* ---- Writing desk section ------------------------------------------------ */
.writing-desk {
    background:
        linear-gradient(180deg, rgba(245, 239, 226, 0), rgba(231, 218, 194, 0.55) 35%, rgba(212, 191, 154, 0.62) 65%, rgba(188, 163, 119, 0.55) 100%),
        repeating-linear-gradient(93deg, rgba(125, 95, 55, 0.09) 0 3px, rgba(125, 95, 55, 0) 3px 14px),
        repeating-linear-gradient(87deg, rgba(94, 70, 38, 0.08) 0 2px, rgba(94, 70, 38, 0) 2px 22px),
        linear-gradient(180deg, #d6b98b 0%, #b89266 100%);
    color: var(--cream);
    padding-block: clamp(5rem, 12vw, 9rem);
    position: relative;
    overflow: hidden;
}

.writing-desk::before,
.writing-desk::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    height: 28px;
    background: linear-gradient(180deg, var(--cream), rgba(245, 239, 226, 0));
    pointer-events: none;
}
.writing-desk::before { top: 0; }
.writing-desk::after {
    bottom: 0;
    background: linear-gradient(0deg, var(--cream), rgba(245, 239, 226, 0));
}

.desk-scene {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    align-items: center;
    gap: clamp(2rem, 5vw, 4.5rem);
}

@media (max-width: 820px) {
    .desk-scene {
        grid-template-columns: 1fr;
    }
}

.desk-scene__text {
    color: #3b2f1f;
    max-width: 44ch;
}

.desk-scene__text .eyebrow {
    color: #7a5d31;
}
.desk-scene__text .eyebrow::before {
    background: #7a5d31;
}

.desk-scene__text h2 {
    font-family: var(--font-display);
    color: #2f251a;
    font-size: clamp(1.7rem, 2.8vw, 2.3rem);
    line-height: 1.2;
}

.desk-scene__text p {
    color: #4a3c28;
    margin-top: 1.2rem;
}

.desk-scene__stage {
    position: relative;
    min-height: 360px;
    aspect-ratio: 5/4;
}

.desk-scene__paper {
    position: absolute;
    inset: auto;
    top: 8%;
    left: 6%;
    width: 74%;
    transform: rotate(-4deg);
    background: #f2e8d0;
    padding: 1.5rem 1.75rem;
    border-radius: 3px;
    box-shadow: 0 2px 0 rgba(94, 72, 40, 0.12), 0 20px 40px rgba(50, 30, 10, 0.25), 0 60px 80px rgba(50, 30, 10, 0.2);
    font-family: var(--font-serif-italic);
    color: #5a4a35;
    line-height: 2.2;
    background-image: repeating-linear-gradient(180deg, transparent 0 32px, rgba(138, 154, 123, 0.2) 32px 33px);
    font-size: 0.92rem;
}
.desk-scene__paper::before {
    content: "";
    position: absolute;
    top: -5%;
    right: -4%;
    width: 35%;
    height: 18%;
    background: #f2e8d0;
    border-radius: 2px;
    transform: rotate(6deg);
    box-shadow: 0 4px 14px rgba(50, 30, 10, 0.18);
    opacity: 0.85;
}

.desk-scene__paper p {
    margin: 0;
    font-style: italic;
}

.desk-scene__pen {
    position: absolute;
    right: 4%;
    top: 22%;
    width: 58%;
    transform: rotate(28deg);
    filter: drop-shadow(0 10px 14px rgba(40, 22, 6, 0.3));
}

.desk-scene__ink {
    position: absolute;
    right: 10%;
    bottom: 6%;
    width: 22%;
    filter: drop-shadow(0 12px 18px rgba(40, 22, 6, 0.35));
}

.desk-scene__lavender {
    position: absolute;
    left: 2%;
    bottom: 2%;
    width: 40%;
    opacity: 0.95;
    filter: drop-shadow(0 8px 14px rgba(40, 22, 6, 0.25));
}

/* ---- Service cards ------------------------------------------------------- */
.services-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: clamp(1.25rem, 2.5vw, 2rem);
}

@media (max-width: 900px) {
    .services-grid {
        grid-template-columns: 1fr;
    }
}

.service-card {
    background: var(--cream-warm);
    border: 1px solid var(--sage-soft);
    border-radius: var(--radius-lg);
    padding: clamp(1.75rem, 2.6vw, 2.25rem);
    display: flex;
    flex-direction: column;
    gap: 1rem;
    position: relative;
    transition: transform 450ms var(--ease-settle), box-shadow 450ms var(--ease-settle), background 450ms var(--ease);
    box-shadow: var(--shadow-soft);
    background-image:
        url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence baseFrequency='0.9' numOctaves='2'/><feColorMatrix values='0 0 0 0 0.27  0 0 0 0 0.22  0 0 0 0 0.13  0 0 0 0.08 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}

.service-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow-lifted);
    background-color: var(--cream);
}

.service-card__icon {
    width: 48px;
    height: 48px;
    color: var(--sage);
}

.service-card h3 {
    color: var(--sage-deep);
}

.service-card p {
    color: var(--grey-warm);
    flex: 1;
}

.service-card__link {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    margin-top: 0.6rem;
    color: var(--sage-deep);
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    font-size: 0.78rem;
    position: relative;
    padding-bottom: 2px;
    align-self: flex-start;
}
.service-card__link::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 0;
    height: 1px;
    background: var(--sage);
    transition: width 350ms var(--ease);
}
.service-card__link:hover::after,
.service-card__link:focus-visible::after {
    width: 100%;
}
.service-card__link svg {
    transition: transform 350ms var(--ease);
}
.service-card__link:hover svg {
    transform: translateX(4px);
}

/* ---- Writers gallery ----------------------------------------------------- */
.writers-section {
    background:
        linear-gradient(180deg, var(--cream) 0%, var(--cream-warm) 100%);
}

.writers-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: clamp(1.5rem, 3vw, 2.5rem);
}

@media (max-width: 960px) {
    .writers-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 620px) {
    .writers-grid {
        grid-template-columns: 1fr;
        max-width: 360px;
        margin-inline: auto;
    }
}

.writer-card {
    background: var(--cream);
    border-radius: var(--radius-md);
    padding: 1.75rem 1.5rem 1.5rem;
    text-align: center;
    border: 1px solid transparent;
    transition: transform 450ms var(--ease-settle), box-shadow 450ms var(--ease-settle), border-color 450ms var(--ease);
    position: relative;
}

.writer-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lifted);
    border-color: var(--sage-soft);
}

.writer-card__portrait {
    width: 140px;
    height: 140px;
    margin: 0 auto 1.2rem;
    border-radius: 50%;
    background: var(--cream-deep);
    border: 4px solid var(--cream);
    box-shadow: 0 0 0 1.5px var(--sage);
    overflow: hidden;
    display: grid;
    place-items: center;
    color: var(--sage-deep);
    font-family: var(--font-display);
    font-size: 2.6rem;
    font-weight: 500;
    letter-spacing: 0.02em;
    transition: filter 450ms var(--ease);
}

.writer-card:hover .writer-card__portrait {
    filter: saturate(1.08) brightness(1.02);
}

.writer-card h3 {
    color: var(--sage-deep);
    font-size: 1.4rem;
    margin-bottom: 0.35rem;
}

.writer-card__meta {
    font-family: var(--font-serif-italic);
    font-style: italic;
    color: var(--grey-soft);
    margin-bottom: 1rem;
}

.writer-card p {
    max-width: none;
    color: var(--grey-warm);
    font-size: 0.95rem;
    line-height: 1.65;
}

.writer-card__sample {
    margin-top: 1.25rem;
    padding: 0.9rem 1rem;
    background: var(--cream-warm);
    border-radius: var(--radius-sm);
    border: 1px dashed rgba(138, 154, 123, 0.45);
    font-family: var(--font-serif-italic);
    font-style: italic;
    color: var(--grey-soft);
    line-height: 1.5;
    opacity: 0.85;
    transition: opacity 500ms var(--ease), color 500ms var(--ease);
    font-size: 0.95rem;
}

.writer-card:hover .writer-card__sample {
    opacity: 1;
    color: var(--grey-warm);
}

.writer-card__sample small {
    display: block;
    font-size: 0.7rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    font-style: normal;
    color: var(--sage);
    margin-bottom: 0.4rem;
    font-family: var(--font-body);
    font-weight: 700;
    opacity: 0.85;
}

/* ---- Pull quote ---------------------------------------------------------- */
.pullquote {
    background: var(--sage-deep);
    color: var(--cream);
    padding-block: clamp(5rem, 10vw, 8rem);
    position: relative;
    overflow: hidden;
}
.pullquote::after {
    content: "";
    position: absolute;
    inset: 0;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='g'><feTurbulence baseFrequency='0.8' numOctaves='2'/><feColorMatrix values='0 0 0 0 0.9 0 0 0 0 0.88 0 0 0 0 0.8 0 0 0 0.06 0'/></filter><rect width='100%' height='100%' filter='url(%23g)'/></svg>");
    opacity: 0.8;
    pointer-events: none;
    mix-blend-mode: soft-light;
}

.pullquote__inner {
    position: relative;
    text-align: center;
    max-width: 860px;
    margin-inline: auto;
}

.pullquote__mark {
    font-family: var(--font-display);
    font-size: clamp(6rem, 14vw, 9rem);
    line-height: 0.6;
    color: var(--terracotta-soft);
    opacity: 0.85;
    display: block;
    margin-bottom: 0.4rem;
}

.pullquote blockquote {
    font-family: var(--font-serif-italic);
    font-style: italic;
    font-size: clamp(1.35rem, 2.6vw, 1.9rem);
    line-height: 1.45;
    color: var(--cream);
    margin: 0 auto;
    letter-spacing: 0.005em;
}

.pullquote__rule {
    width: 80px;
    height: 1px;
    background: rgba(245, 239, 226, 0.6);
    margin: 2rem auto 1.1rem;
}

.pullquote cite {
    font-family: var(--font-body);
    font-style: normal;
    color: rgba(245, 239, 226, 0.82);
    letter-spacing: 0.24em;
    text-transform: uppercase;
    font-size: 0.78rem;
    font-weight: 700;
}

/* ---- Story section ------------------------------------------------------- */
.story-section {
    background: var(--cream);
}

.story-grid {
    display: grid;
    grid-template-columns: 1.1fr 1fr;
    align-items: center;
    gap: clamp(2rem, 5vw, 4.5rem);
}

@media (max-width: 860px) {
    .story-grid {
        grid-template-columns: 1fr;
    }
}

.story-copy h2 {
    margin-bottom: 1.5rem;
}

.story-copy p {
    font-size: 1.04rem;
    color: var(--grey-warm);
}

.story-copy .sign-off {
    font-family: var(--font-serif-italic);
    font-style: italic;
    color: var(--sage-deep);
    margin-top: 1.6rem;
}

.story-figure {
    position: relative;
    border-radius: var(--radius-md);
    background: var(--cream-warm);
    overflow: hidden;
    aspect-ratio: 4/5;
    box-shadow: var(--shadow-lifted);
    transition: filter 400ms var(--ease);
}
.story-figure:hover {
    filter: saturate(1.06);
}
.story-figure__inner {
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse at 70% 25%, rgba(245, 239, 226, 0.8) 0%, rgba(245, 239, 226, 0) 55%),
        linear-gradient(160deg, rgba(138, 154, 123, 0.35), rgba(178, 106, 77, 0.18) 60%, rgba(94, 72, 40, 0.12));
}
.story-figure svg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    color: rgba(59, 53, 45, 0.5);
}
.story-figure figcaption {
    position: absolute;
    bottom: 1rem;
    left: 1.25rem;
    right: 1.25rem;
    color: var(--cream);
    font-family: var(--font-serif-italic);
    font-style: italic;
    font-size: 0.95rem;
    text-shadow: 0 1px 2px rgba(0,0,0,0.25);
}

/* ---- Forms --------------------------------------------------------------- */
.form {
    display: grid;
    gap: 1.25rem;
}

.form-row {
    display: grid;
    gap: 1.25rem;
}

@media (min-width: 720px) {
    .form-row--two {
        grid-template-columns: 1fr 1fr;
    }
}

.field label {
    display: block;
    font-size: 0.78rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--sage-deep);
    margin-bottom: 0.5rem;
    font-weight: 700;
}

.field input,
.field textarea,
.field select {
    width: 100%;
    background: var(--cream);
    border: 1px solid var(--sage-soft);
    border-radius: var(--radius-sm);
    padding: 0.9rem 1rem;
    font-family: var(--font-body);
    color: var(--ink);
    transition: border-color 300ms var(--ease), box-shadow 300ms var(--ease), background 300ms var(--ease);
}

.field textarea {
    min-height: 170px;
    resize: vertical;
    line-height: 1.6;
}

.field input::placeholder,
.field textarea::placeholder {
    color: var(--grey-muted);
    font-style: italic;
    font-family: var(--font-serif-italic);
}

.field input:focus,
.field textarea:focus,
.field select:focus {
    border-color: var(--sage);
    box-shadow: 0 0 0 4px rgba(138, 154, 123, 0.2);
    outline: none;
    background: #faf4e6;
}

.field .hint {
    font-size: 0.85rem;
    color: var(--grey-soft);
    margin-top: 0.35rem;
    font-family: var(--font-serif-italic);
    font-style: italic;
}

.honeypot {
    position: absolute;
    left: -9999px;
    top: -9999px;
    opacity: 0;
    pointer-events: none;
}

.form-actions {
    display: flex;
    gap: 1rem;
    align-items: center;
    margin-top: 0.4rem;
}

.form-feedback {
    padding: 1rem 1.25rem;
    border-radius: var(--radius-sm);
    font-family: var(--font-serif-italic);
    font-style: italic;
    margin-bottom: 1.5rem;
}
.form-feedback--success {
    background: var(--sage-pale);
    border: 1px solid var(--sage);
    color: var(--sage-deep);
}
.form-feedback--error {
    background: #f4dfd3;
    border: 1px solid var(--terracotta);
    color: #6a3724;
}

.error-text {
    color: var(--wax-red);
    font-size: 0.88rem;
    margin-top: 0.35rem;
    font-family: var(--font-serif-italic);
    font-style: italic;
}

.field.is-invalid input,
.field.is-invalid textarea {
    border-color: var(--terracotta);
    box-shadow: 0 0 0 4px rgba(178, 106, 77, 0.12);
}

/* ---- Footer -------------------------------------------------------------- */
.site-footer {
    background: var(--sage-deep);
    color: var(--cream);
    padding-block: clamp(3rem, 6vw, 5rem) 1.25rem;
    position: relative;
}

.site-footer::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 14px;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 14' preserveAspectRatio='none'><path d='M0 10 Q 60 2 120 8 T 240 9 T 360 7 T 480 10 T 600 6 T 720 9 T 840 7 T 960 10 T 1080 7 T 1200 9 L1200 14 L0 14 Z' fill='%236f8263'/></svg>");
    background-size: 100% 100%;
    pointer-events: none;
}

.footer-inner {
    display: grid;
    grid-template-columns: 1fr auto auto;
    align-items: center;
    gap: clamp(1rem, 3vw, 2rem);
}

@media (max-width: 780px) {
    .footer-inner {
        grid-template-columns: 1fr;
        text-align: center;
        justify-items: center;
    }
}

.footer-brand .footer-line {
    font-family: var(--font-serif-italic);
    font-style: italic;
    color: rgba(245, 239, 226, 0.82);
    margin-top: 0.75rem;
}

.footer-nav ul {
    display: flex;
    flex-wrap: wrap;
    gap: clamp(1rem, 2.4vw, 2rem);
}
.footer-nav a {
    color: rgba(245, 239, 226, 0.88);
    font-size: 0.9rem;
    letter-spacing: 0.05em;
    position: relative;
    padding-block: 0.2rem;
    transition: color 300ms var(--ease);
}
.footer-nav a::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 0;
    height: 1px;
    background: var(--cream);
    transition: width 350ms var(--ease);
}
.footer-nav a:hover {
    color: var(--cream);
}
.footer-nav a:hover::after {
    width: 100%;
}

.footer-social {
    display: flex;
    gap: 0.9rem;
}
.footer-social a {
    width: 34px;
    height: 34px;
    border: 1px solid rgba(245, 239, 226, 0.35);
    border-radius: 50%;
    display: grid;
    place-items: center;
    color: var(--cream);
    transition: background 350ms var(--ease), border-color 350ms var(--ease), transform 350ms var(--ease);
}
.footer-social a:hover {
    background: rgba(245, 239, 226, 0.12);
    border-color: var(--cream);
    transform: translateY(-2px);
}

.footer-copy {
    margin-top: 2.5rem;
    text-align: center;
    font-size: 0.8rem;
    color: rgba(245, 239, 226, 0.58);
    font-family: var(--font-serif-italic);
    font-style: italic;
}

/* ---- Inner page hero ----------------------------------------------------- */
.page-hero {
    padding-block: clamp(4rem, 10vw, 7rem) clamp(2rem, 5vw, 4rem);
    text-align: left;
}
.page-hero h1 {
    max-width: 18ch;
}
.page-hero .lede {
    margin-top: 1.5rem;
    max-width: 58ch;
}
.page-hero .rule {
    margin-top: 2.25rem;
}

/* ---- About / feature strips --------------------------------------------- */
.feature-strip {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: clamp(1.5rem, 3vw, 2.5rem);
}
@media (max-width: 820px) {
    .feature-strip {
        grid-template-columns: 1fr;
    }
}

.feature {
    padding: 1.5rem 0;
}
.feature h3 {
    font-size: 1.25rem;
    margin-bottom: 0.7rem;
}
.feature .feature__icon {
    width: 40px;
    height: 40px;
    color: var(--sage);
    margin-bottom: 0.75rem;
}

/* ---- Service detail page ------------------------------------------------- */
.service-detail {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: clamp(2rem, 5vw, 4rem);
    align-items: start;
    padding-block: clamp(3rem, 6vw, 5rem);
    border-top: 1px solid var(--sage-pale);
}

.service-detail:first-of-type {
    border-top: 0;
}

@media (max-width: 820px) {
    .service-detail {
        grid-template-columns: 1fr;
    }
}

.service-detail__media {
    background: var(--cream-warm);
    border-radius: var(--radius-md);
    padding: 2rem;
    position: relative;
    min-height: 260px;
    display: grid;
    place-items: center;
    color: var(--sage-deep);
    border: 1px solid var(--sage-pale);
}
.service-detail__media svg {
    width: min(220px, 80%);
    height: auto;
    opacity: 0.9;
}

.service-detail__copy h2 {
    margin-bottom: 1rem;
}

.service-detail__list {
    margin-top: 1.25rem;
    display: grid;
    gap: 0.75rem;
}
.service-detail__list li {
    padding-left: 1.4rem;
    position: relative;
    color: var(--grey-warm);
}
.service-detail__list li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.7em;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--sage);
    opacity: 0.8;
}

.service-detail__price {
    margin-top: 2rem;
    padding: 1.25rem 1.5rem;
    border: 1px dashed var(--sage-soft);
    border-radius: var(--radius-md);
    background: var(--cream-warm);
    color: var(--grey-warm);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
}
.service-detail__price strong {
    font-family: var(--font-display);
    color: var(--sage-deep);
    font-size: 1.35rem;
    font-weight: 500;
    letter-spacing: 0.02em;
}

/* ---- CTA band ------------------------------------------------------------ */
.cta-band {
    background: var(--cream-warm);
    text-align: center;
    border-radius: var(--radius-lg);
    padding: clamp(2.5rem, 5vw, 4rem);
    border: 1px solid var(--sage-pale);
    box-shadow: var(--shadow-soft);
}
.cta-band h2 {
    max-width: 22ch;
    margin-inline: auto;
}
.cta-band p {
    margin: 1rem auto 1.75rem;
    max-width: 52ch;
}

/* ---- Contact layout ------------------------------------------------------ */
.contact-grid {
    display: grid;
    grid-template-columns: 1.05fr 1fr;
    gap: clamp(2.5rem, 5vw, 4.5rem);
    align-items: start;
}

@media (max-width: 860px) {
    .contact-grid {
        grid-template-columns: 1fr;
    }
}

.contact-aside {
    background: var(--cream-warm);
    border: 1px solid var(--sage-pale);
    border-radius: var(--radius-md);
    padding: clamp(1.75rem, 3vw, 2.25rem);
}
.contact-aside h3 {
    margin-bottom: 0.6rem;
}
.contact-aside p {
    color: var(--grey-warm);
}

.contact-details {
    margin-top: 1.25rem;
    display: grid;
    gap: 0.75rem;
    font-size: 0.95rem;
}
.contact-details dt {
    font-size: 0.72rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--sage);
    font-weight: 700;
}
.contact-details dd {
    font-family: var(--font-serif-italic);
    font-style: italic;
    color: var(--grey-warm);
    margin: 0.1rem 0 0.6rem;
}

/* ---- Story / About timeline --------------------------------------------- */
.timeline {
    display: grid;
    gap: 1.5rem;
    border-left: 1px solid var(--sage-soft);
    padding-left: 1.75rem;
    margin-top: 2rem;
}
.timeline-item {
    position: relative;
}
.timeline-item::before {
    content: "";
    position: absolute;
    left: -2.1rem;
    top: 0.6rem;
    width: 11px;
    height: 11px;
    border-radius: 50%;
    background: var(--cream);
    border: 2px solid var(--sage);
}
.timeline-item h3 {
    font-size: 1.2rem;
    color: var(--sage-deep);
    margin-bottom: 0.25rem;
}
.timeline-item small {
    font-size: 0.72rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--sage);
    font-weight: 700;
}

/* ---- 404 ----------------------------------------------------------------- */
.page-404 {
    min-height: 70vh;
    display: grid;
    place-items: center;
    text-align: center;
    padding-block: 5rem;
}
.page-404 h1 {
    font-size: clamp(3rem, 10vw, 6rem);
    color: var(--sage-deep);
    margin-bottom: 1rem;
    letter-spacing: 0.05em;
}
.page-404 .lede {
    max-width: 52ch;
    margin: 0 auto 2rem;
}
.page-404__mark {
    font-family: var(--font-serif-italic);
    font-style: italic;
    color: var(--terracotta);
    font-size: 1.1rem;
}

/* ---- Animations ---------------------------------------------------------- */
.fade-up {
    opacity: 0;
    transform: translateY(22px);
    transition: opacity 900ms var(--ease-settle), transform 900ms var(--ease-settle);
    will-change: opacity, transform;
}
.fade-up.is-in,
.no-js .fade-up {
    opacity: 1;
    transform: translateY(0);
}

.fade-up--delay-1 { transition-delay: 120ms; }
.fade-up--delay-2 { transition-delay: 240ms; }
.fade-up--delay-3 { transition-delay: 360ms; }
.fade-up--delay-4 { transition-delay: 480ms; }
.fade-up--delay-5 { transition-delay: 600ms; }

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.001ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.001ms !important;
        scroll-behavior: auto !important;
    }
    .fade-up {
        opacity: 1;
        transform: none;
    }
}

/* ---- Small utilities ----------------------------------------------------- */
.center-text { text-align: center; }
.center-block { margin-inline: auto; }
.mt-1 { margin-top: 0.75rem; }
.mt-2 { margin-top: 1.5rem; }
.mt-3 { margin-top: 2.25rem; }
.mt-4 { margin-top: 3rem; }
.mb-0 { margin-bottom: 0; }
.spread { display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap; }

/* ==========================================================================
   Ordering system styles
   Step indicators, option swatches, live preview, summary cards.
   ========================================================================== */

.order-shell {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);
    gap: clamp(2rem, 4vw, 3.5rem);
    align-items: start;
    padding-block: clamp(2.5rem, 5vw, 4rem);
}
@media (max-width: 900px) {
    .order-shell { grid-template-columns: 1fr; }
}
.order-shell--full { grid-template-columns: 1fr; }

.step-indicator {
    display: flex;
    gap: 0;
    align-items: center;
    margin-bottom: 2rem;
    flex-wrap: wrap;
}
.step-indicator__item {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    font-size: 0.72rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--grey-muted);
    font-weight: 700;
    padding-right: 0.8rem;
}
.step-indicator__item + .step-indicator__item { padding-left: 0.8rem; border-left: 1px solid var(--sage-pale); }
.step-indicator__num {
    width: 26px; height: 26px;
    border-radius: 50%;
    display: inline-grid; place-items: center;
    background: var(--cream-warm); color: var(--grey-muted);
    border: 1px solid var(--sage-pale);
    font-size: 0.75rem;
}
.step-indicator__item.is-done { color: var(--sage-deep); }
.step-indicator__item.is-done .step-indicator__num { background: var(--sage-pale); color: var(--sage-deep); border-color: var(--sage-soft); }
.step-indicator__item.is-current { color: var(--sage-deep); }
.step-indicator__item.is-current .step-indicator__num { background: var(--sage); color: var(--cream); border-color: var(--sage); box-shadow: 0 0 0 4px rgba(138,154,123,0.16); }

/* Option swatches (paper, envelope) */
.swatch-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 0.9rem;
    margin-top: 0.75rem;
}
.swatch {
    position: relative;
    border: 1px solid var(--sage-pale);
    border-radius: var(--radius-md);
    padding: 0.65rem;
    cursor: pointer;
    background: var(--cream);
    transition: border-color 300ms var(--ease), box-shadow 300ms var(--ease), transform 300ms var(--ease);
    display: block;
}
.swatch input { position: absolute; opacity: 0; pointer-events: none; }
.swatch__chip {
    height: 74px;
    border-radius: 8px;
    border: 1px solid rgba(94, 72, 40, 0.08);
    margin-bottom: 0.55rem;
    position: relative;
    overflow: hidden;
}
.swatch__chip.paper-grain::after,
.swatch__chip.paper-aged::after,
.swatch__chip.paper-parch::after {
    content: "";
    position: absolute; inset: 0;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence baseFrequency='0.9' numOctaves='2'/><feColorMatrix values='0 0 0 0 0.27  0 0 0 0 0.22  0 0 0 0 0.13  0 0 0 0.12 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
    opacity: 0.6;
}
.swatch__chip.paper-aged::after { opacity: 0.9; }
.swatch__name {
    display: block;
    font-size: 0.9rem;
    color: var(--sage-deep);
    font-weight: 700;
    letter-spacing: 0.01em;
}
.swatch__note {
    display: block;
    font-size: 0.8rem;
    color: var(--grey-soft);
    font-family: var(--font-serif-italic);
    font-style: italic;
    margin-top: 2px;
    line-height: 1.35;
}
.swatch:hover { border-color: var(--sage-soft); transform: translateY(-1px); }
.swatch input:checked + .swatch__chip,
.swatch.is-selected .swatch__chip { box-shadow: 0 0 0 2px var(--sage); }
.swatch:has(input:checked) { border-color: var(--sage); box-shadow: 0 0 0 3px rgba(138,154,123,0.18); }

/* Ink dots */
.ink-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    margin-top: 0.75rem;
}
.ink-dot {
    position: relative;
    border: 1px solid var(--sage-pale);
    border-radius: 999px;
    padding: 0.4rem 0.95rem 0.4rem 0.5rem;
    cursor: pointer;
    background: var(--cream);
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    transition: border-color 300ms var(--ease), box-shadow 300ms var(--ease);
    font-size: 0.88rem;
    color: var(--grey-warm);
}
.ink-dot input { position: absolute; opacity: 0; pointer-events: none; }
.ink-dot__chip { width: 18px; height: 18px; border-radius: 50%; border: 1px solid rgba(0,0,0,0.1); }
.ink-dot:has(input:checked) { border-color: var(--sage); box-shadow: 0 0 0 3px rgba(138,154,123,0.18); color: var(--sage-deep); }
.ink-dot__recommended { font-size: 0.7rem; color: var(--sage); letter-spacing: 0.14em; text-transform: uppercase; font-weight: 700; }

/* Toggle */
.toggle {
    display: inline-flex; align-items: center; gap: 0.9rem;
    padding: 0.6rem 1rem;
    background: var(--cream-warm);
    border: 1px solid var(--sage-pale);
    border-radius: 999px;
    cursor: pointer;
    font-size: 0.92rem;
    color: var(--grey-warm);
    transition: border-color 300ms var(--ease), background 300ms var(--ease);
}
.toggle input { position: absolute; opacity: 0; pointer-events: none; }
.toggle__switch {
    width: 38px; height: 22px; background: var(--cream-deep); border-radius: 999px; position: relative;
    transition: background 300ms var(--ease);
}
.toggle__switch::after {
    content: ""; position: absolute; top: 2px; left: 2px;
    width: 18px; height: 18px; border-radius: 50%;
    background: var(--cream);
    box-shadow: 0 1px 3px rgba(0,0,0,0.12);
    transition: transform 300ms var(--ease);
}
.toggle:has(input:checked) { border-color: var(--sage); background: var(--sage-pale); color: var(--sage-deep); }
.toggle:has(input:checked) .toggle__switch { background: var(--sage); }
.toggle:has(input:checked) .toggle__switch::after { transform: translateX(16px); }

/* Writer cards for selection */
.writer-select-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: clamp(1rem, 2vw, 1.5rem);
    margin-top: 1.5rem;
}
.writer-select {
    background: var(--cream);
    border: 1px solid var(--sage-pale);
    border-radius: var(--radius-md);
    padding: 1.4rem 1.25rem;
    text-align: center;
    transition: transform 400ms var(--ease-settle), box-shadow 400ms var(--ease-settle), border-color 400ms var(--ease);
    position: relative;
}
.writer-select:hover { transform: translateY(-3px); box-shadow: var(--shadow-lifted); border-color: var(--sage-soft); }
.writer-select.is-selected { border-color: var(--sage); box-shadow: 0 0 0 3px rgba(138,154,123,0.15), var(--shadow-lifted); }
.writer-select__portrait {
    width: 96px; height: 96px; margin: 0 auto 0.9rem;
    border-radius: 50%; background: var(--cream-deep);
    border: 3px solid var(--cream);
    box-shadow: 0 0 0 1.5px var(--sage);
    display: grid; place-items: center;
    color: var(--sage-deep);
    font-family: var(--font-display);
    font-size: 1.9rem; font-weight: 500;
    overflow: hidden;
}
.writer-select h3 { font-size: 1.2rem; margin-bottom: 0.15rem; }
.writer-select__where { font-family: var(--font-serif-italic); font-style: italic; color: var(--grey-soft); font-size: 0.9rem; margin-bottom: 0.8rem; }
.writer-select__bio { font-size: 0.9rem; line-height: 1.55; color: var(--grey-warm); }
.writer-select__sample {
    margin-top: 1rem;
    padding: 0.8rem 0.9rem;
    border-radius: 6px;
    background: var(--cream-warm);
    border: 1px dashed rgba(138, 154, 123, 0.5);
    font-family: var(--font-serif-italic);
    font-style: italic;
    color: var(--grey-warm);
    font-size: 0.9rem;
}
.writer-select__btn {
    display: inline-block; margin-top: 1rem;
    padding: 0.6rem 1.25rem;
    background: var(--sage);
    color: var(--cream);
    border-radius: 999px;
    font-size: 0.78rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    font-weight: 700;
    transition: background 300ms var(--ease), transform 300ms var(--ease);
    cursor: pointer;
    border: 0;
}
.writer-select__btn:hover { background: var(--sage-deep); }
.writer-select.is-selected .writer-select__btn { background: var(--sage-deep); }
.writer-select.is-selected .writer-select__btn::before { content: "✓ "; }

/* Writer style filter */
.style-filters {
    display: flex;
    gap: 0.4rem;
    flex-wrap: wrap;
    margin: 1.25rem 0 0.75rem;
}
.style-filter {
    padding: 0.4rem 0.9rem;
    background: var(--cream-warm);
    border: 1px solid var(--sage-pale);
    border-radius: 999px;
    font-size: 0.82rem;
    color: var(--grey-warm);
    cursor: pointer;
    transition: all 300ms var(--ease);
}
.style-filter.is-active { background: var(--sage); color: var(--cream); border-color: var(--sage); }

/* Live preview desk */
.preview-panel {
    position: sticky;
    top: 110px;
    padding: 1.75rem;
    border-radius: var(--radius-md);
    background: linear-gradient(180deg, #d6b98b 0%, #b89266 100%);
    color: var(--cream);
    box-shadow: var(--shadow-lifted);
}
.preview-panel__title {
    font-family: var(--font-serif-italic); font-style: italic; font-size: 0.95rem;
    color: rgba(245, 239, 226, 0.85);
    margin-bottom: 0.9rem;
}
.preview-envelope {
    border-radius: 6px;
    padding: 1.25rem 1.1rem;
    margin-bottom: 1.1rem;
    position: relative;
    box-shadow: 0 8px 24px rgba(40,22,6,0.25);
    transition: background 400ms var(--ease);
    background: #efe7d4;
}
.preview-envelope__label {
    font-family: var(--font-serif-italic);
    font-style: italic;
    color: rgba(59, 53, 45, 0.7);
    font-size: 0.88rem;
    line-height: 1.4;
}
.preview-wax {
    width: 28px; height: 28px;
    border-radius: 50%;
    background: #8a9a7b;
    position: absolute;
    right: 14px; bottom: 14px;
    transition: background 400ms var(--ease), opacity 400ms var(--ease);
    box-shadow: inset -1px -2px 4px rgba(0,0,0,0.25);
    opacity: 0;
}
.preview-wax.is-on { opacity: 1; }
.preview-paper {
    border-radius: 4px;
    padding: 1.1rem 1.25rem;
    font-family: var(--font-serif-italic);
    font-style: italic;
    line-height: 2.2;
    min-height: 200px;
    background: #f1e7d0;
    color: #1b2a4a;
    transition: background 400ms var(--ease), color 400ms var(--ease);
    background-image: repeating-linear-gradient(180deg, transparent 0 32px, rgba(138, 154, 123, 0.16) 32px 33px);
    position: relative;
    box-shadow: 0 6px 16px rgba(40,22,6,0.22);
}
.preview-paper__line { height: 1em; border-radius: 2px; background: currentColor; opacity: 0.5; margin-bottom: 0.4em; }
.preview-paper__line:nth-child(1) { width: 88%; }
.preview-paper__line:nth-child(2) { width: 74%; }
.preview-paper__line:nth-child(3) { width: 82%; }
.preview-paper__line:nth-child(4) { width: 64%; }
.preview-paper__line:nth-child(5) { width: 70%; }
.preview-botanical {
    position: absolute; right: -18px; top: 50%;
    transform: translateY(-50%) rotate(12deg);
    opacity: 0; transition: opacity 400ms var(--ease);
    width: 60px; color: #5e6b4f;
}
.preview-botanical.is-on { opacity: 0.95; }

/* Summary list */
.summary-card {
    background: var(--cream-warm);
    border: 1px solid var(--sage-pale);
    border-radius: var(--radius-md);
    padding: 1.5rem;
    margin-bottom: 1.25rem;
}
.summary-card h3 {
    font-size: 0.78rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--sage);
    font-family: var(--font-body);
    font-weight: 700;
    margin-bottom: 0.6rem;
}
.summary-card p { max-width: none; }
.summary-card dt {
    font-size: 0.75rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--sage);
    font-weight: 700;
    margin-top: 0.6rem;
}
.summary-card dt:first-child { margin-top: 0; }
.summary-card dd {
    margin: 0.1rem 0 0;
    color: var(--grey-warm);
}
.price-lines {
    display: grid; gap: 0.4rem;
    border-top: 1px dashed var(--sage-pale);
    margin-top: 1rem; padding-top: 1rem;
    font-size: 0.95rem;
}
.price-lines .row { display: flex; justify-content: space-between; gap: 0.5rem; color: var(--grey-warm); }
.price-lines .row.total {
    margin-top: 0.6rem; padding-top: 0.8rem;
    border-top: 1px solid var(--sage-soft);
    color: var(--sage-deep);
    font-weight: 700;
    font-size: 1.05rem;
    font-family: var(--font-display);
    letter-spacing: 0.01em;
}

/* Word counter / tier indicator */
.word-counter {
    display: flex; justify-content: space-between; gap: 1rem;
    margin-top: 0.5rem;
    font-size: 0.88rem;
    color: var(--grey-soft);
    transition: color 400ms var(--ease);
    font-family: var(--font-serif-italic);
    font-style: italic;
}
.word-counter .tier {
    color: var(--sage-deep);
    font-family: var(--font-body);
    font-style: normal;
    font-weight: 700;
    font-size: 0.8rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    transition: all 400ms var(--ease);
}
.word-counter.is-over .tier { color: var(--terracotta); }

/* Flash messages */
.flash {
    padding: 1rem 1.25rem;
    margin-bottom: 1.5rem;
    border-radius: var(--radius-sm);
    font-family: var(--font-serif-italic);
    font-style: italic;
}
.flash--info    { background: var(--sage-pale);  border: 1px solid var(--sage);      color: var(--sage-deep); }
.flash--error   { background: #f4dfd3;           border: 1px solid var(--terracotta); color: #6a3724; }
.flash--success { background: var(--sage-pale);  border: 1px solid var(--sage-deep); color: var(--sage-deep); }

/* Dashboard cards */
.dash-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 1.25rem;
    margin-top: 1.5rem;
}
.dash-card {
    background: var(--cream-warm);
    border: 1px solid var(--sage-pale);
    border-radius: var(--radius-md);
    padding: 1.5rem;
    transition: border-color 300ms var(--ease), box-shadow 300ms var(--ease);
}
.dash-card:hover { border-color: var(--sage-soft); box-shadow: var(--shadow-soft); }
.dash-card h3 { font-size: 1.2rem; margin-bottom: 0.6rem; }
.dash-status {
    display: inline-block;
    font-size: 0.7rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    font-weight: 700;
    padding: 0.25rem 0.7rem;
    border-radius: 999px;
    background: var(--sage-pale);
    color: var(--sage-deep);
}
.dash-status--paused { background: #f0e8d0; color: #8a6b1a; }
.dash-status--canceled { background: #f4dfd3; color: #8a4a30; }
.dash-status--past_due { background: #f4dfd3; color: #8a4a30; }

/* Admin table */
.admin-table {
    width: 100%;
    border-collapse: collapse;
    background: var(--cream);
    border: 1px solid var(--sage-pale);
    border-radius: var(--radius-md);
    overflow: hidden;
    margin-top: 1.25rem;
}
.admin-table th, .admin-table td {
    padding: 0.8rem 1rem;
    border-bottom: 1px solid var(--sage-pale);
    text-align: left;
    font-size: 0.92rem;
    vertical-align: top;
}
.admin-table th {
    background: var(--cream-warm);
    font-size: 0.7rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--sage);
}
.admin-table tr:last-child td { border-bottom: 0; }
.admin-table tr:hover td { background: var(--cream-warm); }

/* Nav with account link */
.primary-nav a.nav-cta {
    padding: 0.45rem 1rem;
    border-radius: 999px;
    background: var(--sage);
    color: var(--cream) !important;
    font-weight: 700;
    transition: background 300ms var(--ease);
}
.primary-nav a.nav-cta:hover { background: var(--sage-deep); }
.primary-nav a.nav-cta::after { display: none; }

/* Make narrow forms stackable on mobile */
.narrow-form { max-width: 520px; }
