.public-body {
    background: var(--color-bg);
}

.coming-soon-page {
    min-height: 100vh;
    background:
        radial-gradient(circle at 20% 10%, rgba(185, 102, 67, 0.14), transparent 32rem),
        radial-gradient(circle at 78% 18%, rgba(31, 59, 45, 0.12), transparent 30rem),
        linear-gradient(135deg, #fbf7ef 0%, #f4efe4 48%, #eef3ef 100%);
}

.coming-soon {
    min-height: 100vh;
    display: grid;
    place-items: center;
    padding: clamp(1.2rem, 4vw, 4rem);
}

.coming-soon__panel {
    width: min(760px, 100%);
    text-align: center;
    padding: clamp(2.4rem, 7vw, 5rem) clamp(1.4rem, 5vw, 4rem);
}

.coming-soon__kicker {
    margin: 0 0 1rem;
    color: var(--color-accent);
    font-size: 0.82rem;
    font-weight: 800;
    letter-spacing: 0.18em;
    text-transform: uppercase;
}

.coming-soon h1 {
    margin: 0 0 1rem;
    font-size: clamp(3rem, 10vw, 7rem);
    line-height: 0.9;
    letter-spacing: 0;
}

.coming-soon p {
    max-width: 560px;
    margin: 0 auto;
    color: var(--color-text-soft);
    font-size: clamp(1.05rem, 2vw, 1.25rem);
    line-height: 1.6;
}

.public-shell {
    width: min(640px, 100%);
    margin: 0 auto;
    padding: 2.5rem 1.2rem 5rem;
    display: flex;
    flex-direction: column;
    gap: 1.8rem;
}

/* ---------- Header ---------- */
.public-header {
    text-align: center;
    padding: 0.5rem 0 0.8rem;
}

.public-header__brand {
    font-size: 0.95rem;
    font-weight: 600;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--color-accent);
    margin-bottom: 0.9rem;
}

.public-header h1 {
    font-size: clamp(2rem, 5vw, 2.8rem);
    margin-bottom: 0.7rem;
}

.public-header p {
    color: var(--color-text-soft);
    max-width: 480px;
    margin: 0 auto;
    font-size: 1.05rem;
    line-height: 1.5;
}

/* ---------- Step indicator ---------- */
.step-indicator {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.8rem;
    margin-bottom: 1.5rem;
    color: var(--color-text-soft);
    font-size: 0.9rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.step-indicator__dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--color-border-strong);
}
.step-indicator__dot.is-active {
    background: var(--color-primary);
}
.step-indicator__dot.is-done {
    background: var(--color-primary);
    opacity: 0.45;
}

/* ---------- Booking card ---------- */
.booking-card {
    background: #fff;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 2rem 1.8rem 2.2rem;
    box-shadow: var(--shadow-sm);
}

.booking-card h2 {
    font-size: 1.55rem;
    margin-bottom: 0.5rem;
}

.booking-card__help {
    color: var(--color-text-soft);
    font-size: 1rem;
    margin-bottom: 2rem;
    line-height: 1.5;
}

.booking-card form { margin-top: 0.4rem; }

/* Erotin ja tuple - välit napin ja form-kenttien */
.booking-card .btn-block.btn-lg { margin-top: 0.5rem; }
.booking-card .inline-message { margin: 0.5rem 0 1rem; }

/* ---------- Time slot grid ---------- */
.time-slot-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(86px, 1fr));
    gap: 0.7rem;
    margin: 0.5rem 0 1.8rem;
}

.time-slot {
    min-height: 62px;
    padding: 0.8rem 0.6rem;
    border: 1.5px solid var(--color-border-strong);
    border-radius: var(--radius);
    background: #fff;
    color: var(--color-text);
    font-size: 1.1rem;
    font-weight: 600;
    cursor: pointer;
    transition: border-color var(--transition), background var(--transition), color var(--transition);
}

.time-slot:hover {
    border-color: var(--color-primary);
    background: var(--color-primary-soft);
}

.time-slot.is-active {
    background: var(--color-primary);
    color: #fff;
    border-color: var(--color-primary);
}

.opening-note {
    text-align: center;
    color: var(--color-text-soft);
    font-size: 0.95rem;
    margin: 0 0 1.3rem;
    padding: 0.7rem 1rem;
    background: var(--color-surface-soft);
    border-radius: var(--radius);
}

/* ---------- Summary panel ---------- */
.summary-panel {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.8rem 1rem;
    padding: 1.2rem 1.4rem;
    margin-bottom: 1.8rem;
    background: var(--color-primary-soft);
    border-radius: var(--radius);
    border: 1px solid rgba(31, 59, 45, 0.15);
}

.summary-panel__item {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
}

.summary-panel__label {
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-primary);
    font-weight: 600;
}

.summary-panel__value {
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--color-text);
}

@media (max-width: 520px) {
    .summary-panel {
        grid-template-columns: 1fr;
        gap: 0.8rem;
    }
}

/* ---------- Form actions ---------- */
.form-actions {
    display: flex;
    gap: 0.8rem;
    margin-top: 1.8rem;
    padding-top: 1.2rem;
    border-top: 1px solid var(--color-border);
}

.form-actions .btn { flex: 1; }
.form-actions .btn-secondary { flex: 0 0 auto; }

@media (max-width: 520px) {
    .form-actions {
        flex-direction: column-reverse;
    }
    .form-actions .btn { width: 100%; }
}

/* ---------- Special requests (collapsible toive-grid) ---------- */
.special-requests {
    margin: 1rem 0 0.4rem;
    border: 1px solid var(--color-border, #e2ddd2);
    border-radius: 10px;
    background: #fbf9f4;
    overflow: hidden;
}

.special-requests > summary {
    list-style: none;
    cursor: pointer;
    padding: 0.85rem 1rem;
    font-weight: 600;
    font-size: 0.95rem;
    color: var(--color-text, #1a1a1a);
    display: flex;
    align-items: center;
    gap: 0.55rem;
    transition: background var(--transition, 0.15s ease);
}

.special-requests > summary::-webkit-details-marker {
    display: none;
}

.special-requests > summary::before {
    content: '+';
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.4rem;
    height: 1.4rem;
    border-radius: 50%;
    background: #fff;
    border: 1px solid var(--color-border, #e2ddd2);
    color: var(--color-accent, #1f3b2d);
    font-weight: 700;
    font-size: 1rem;
    line-height: 1;
    flex: 0 0 auto;
}

.special-requests[open] > summary::before {
    content: '−';
}

.special-requests > summary:hover {
    background: #f4efe2;
}

.special-requests__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.45rem;
    padding: 0.4rem 0.85rem 0.95rem;
    border-top: 1px solid var(--color-border, #e2ddd2);
    background: #fff;
}

.special-requests__grid .checkbox {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.55rem 0.7rem;
    border: 1px solid transparent;
    border-radius: 8px;
    background: #faf7ef;
    cursor: pointer;
    font-size: 0.9rem;
    line-height: 1.3;
    transition: border-color var(--transition, 0.15s ease),
                background var(--transition, 0.15s ease);
}

.special-requests__grid .checkbox:hover {
    border-color: var(--color-accent, #1f3b2d);
    background: #f3efe3;
}

.special-requests__grid .checkbox > input[type="checkbox"] {
    flex: 0 0 auto;
    width: 1.05rem;
    height: 1.05rem;
    accent-color: var(--color-accent, #1f3b2d);
    margin: 0;
}

.special-requests__grid .checkbox > span {
    flex: 1 1 auto;
    color: var(--color-text, #1a1a1a);
}

.special-requests__grid .checkbox:has(> input[type="checkbox"]:checked) {
    border-color: var(--color-accent, #1f3b2d);
    background: #eef2ea;
}

@media (max-width: 480px) {
    .special-requests__grid {
        grid-template-columns: 1fr;
        gap: 0.4rem;
        padding: 0.4rem 0.6rem 0.8rem;
    }
    .special-requests > summary { padding: 0.75rem 0.85rem; }
}

/* ---------- Success card ---------- */
.success-card {
    text-align: center;
    padding: 3rem 1.5rem;
}

.success-card__icon {
    width: 80px;
    height: 80px;
    margin: 0 auto 1.5rem;
    border-radius: 50%;
    background: var(--color-primary-soft);
    color: var(--color-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2.4rem;
    font-weight: 700;
}

.success-card h2 {
    font-size: 1.8rem;
    margin-bottom: 0.8rem;
}

.success-card__intro {
    color: var(--color-text-soft);
    margin-bottom: 2rem;
    line-height: 1.6;
    max-width: 420px;
    margin-left: auto;
    margin-right: auto;
}

.success-card__reference-label {
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-text-soft);
    font-weight: 600;
    margin-bottom: 0.7rem;
}

.success-card__reference {
    display: inline-block;
    padding: 1rem 2.2rem;
    border: 2px dashed var(--color-primary);
    border-radius: var(--radius);
    font-size: 1.8rem;
    font-weight: 700;
    letter-spacing: 0.15em;
    color: var(--color-primary);
    font-family: var(--font-mono);
    margin-bottom: 2.2rem;
}

.success-card__details {
    background: var(--color-surface-soft);
    padding: 1.3rem 1.6rem;
    border-radius: var(--radius);
    margin-bottom: 1.8rem;
    text-align: left;
}

.success-card__details dl {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0.45rem 1.2rem;
    margin: 0;
    font-size: 1rem;
}

.success-card__details dt {
    color: var(--color-text-soft);
    font-weight: 500;
}

.success-card__details dd {
    margin: 0;
    font-weight: 600;
    color: var(--color-text);
}

.success-card__hint {
    color: var(--color-text-soft);
    font-size: 0.95rem;
    margin-bottom: 1.5rem;
}

/* ---------- Footer info ---------- */
.info-section {
    margin-top: 1.5rem;
    padding-top: 2.5rem;
    border-top: 1px solid var(--color-border);
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2.5rem;
}

@media (max-width: 640px) {
    .info-section {
        grid-template-columns: 1fr;
        gap: 1.8rem;
    }
}

.info-section h3 {
    font-size: 1.15rem;
    margin-bottom: 1.1rem;
}

.hours-list {
    display: grid;
    gap: 0.7rem;
    font-size: 0.98rem;
}

.hours-list__row {
    display: flex;
    justify-content: space-between;
    color: var(--color-text-soft);
    padding: 0.25rem 0;
}

.hours-list__row strong {
    color: var(--color-text);
    font-weight: 600;
}

/* ---------- Lookup ---------- */
.lookup-form {
    display: flex;
    gap: 0.6rem;
    margin-bottom: 1rem;
}

.lookup-form .input {
    flex: 1;
    font-family: var(--font-mono);
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

.lookup-form .btn {
    flex: 0 0 auto;
    min-height: 52px;
    padding: 0 1.2rem;
}

.lookup-result {
    padding: 1rem 1.2rem;
    background: var(--color-surface-soft);
    border-radius: var(--radius);
    border: 1px solid var(--color-border);
}

.lookup-result__title {
    font-weight: 600;
    margin-bottom: 0.5rem;
}

.lookup-result__meta {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0.4rem 1rem;
    font-size: 0.95rem;
}

.lookup-result__meta dt {
    color: var(--color-text-soft);
    margin: 0;
}
.lookup-result__meta dd { margin: 0; font-weight: 500; }

/* Julkisen sivun alapalkki */
.public-footer {
    text-align: center;
    padding: 1.5rem 0 0.5rem;
    margin-top: 1rem;
    border-top: 1px solid var(--color-border);
}

.public-footer a {
    color: var(--color-text-soft);
    text-decoration: none;
}

.public-footer a:hover {
    color: var(--color-primary);
    text-decoration: underline;
}

/* Vaihe 40: ennakkokysymykset varauslomakkeella */
.custom-questions {
    display: grid;
    gap: 1rem;
    margin: 1rem 0;
    padding: 1rem;
    background: var(--color-surface-soft);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
}
.custom-question { margin: 0; }
.custom-question .radio-group,
.custom-question .checkbox-group {
    display: grid;
    gap: 0.4rem;
}

/* Vaihe 44: brändin logo ja intro-teksti julkisessa headerissa */
.public-header__logo {
    max-height: 72px;
    max-width: 100%;
    width: auto;
    height: auto;
    display: block;
    margin: 0 auto;
}
.public-header__intro {
    max-width: 40rem;
    margin: 0.8rem auto 0;
    color: var(--color-text-soft);
    white-space: pre-line;
}

/* Vaihe 44: toimipisteen yhteystieto-kortti */
.info-section--contact .contact-list {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0.4rem 1rem;
    margin: 0.4rem 0 0;
}
.info-section--contact .contact-list dt {
    font-weight: 600;
    color: var(--color-text-soft);
    margin: 0;
}
.info-section--contact .contact-list dd {
    margin: 0;
    word-break: break-word;
}

/* Vaihe 45: embed-tila (iframe-upotus). Pienennetään marginalia ja
   paddausta, pienennetään headerin "Varaa pöytä"-otsikko, säilytetään
   booking-card-ulkoasu jotta asiakaspolku (Vaihe 1 → 3) toimii
   identtisesti. Taustaväri läpinäkyväksi, jotta upottava sivu voi
   päättää taustan. */
.public-body.is-embedded {
    background: transparent;
}
.is-embedded .public-shell {
    padding: 1rem 1rem 2rem;
    gap: 1.2rem;
}
.is-embedded .public-header--embed {
    padding: 0;
    margin: 0 0 0.4rem;
    text-align: left;
}
.is-embedded .public-header--embed h1 {
    font-size: 1.4rem;
    margin: 0;
}
.is-embedded .booking-card {
    padding: 1.2rem 1.2rem 1.4rem;
}

/* Ravintolan julkinen etusivu, jossa varauswidget on iframe-upotuksena. */
.restaurant-page {
    background:
        radial-gradient(1600px 900px at 12% -5%, rgba(239, 219, 176, 0.75), transparent 62%),
        radial-gradient(1300px 700px at 110% 10%, rgba(176, 85, 58, 0.12), transparent 60%),
        #f1e7cf;
    background-attachment: fixed;
}

.restaurant-page h1,
.restaurant-page h2,
.restaurant-page h3 {
    letter-spacing: 0;
}

.restaurant-shell {
    width: min(1180px, 100%);
    margin: 0 auto;
    padding: 1rem 1rem 4rem;
}

.restaurant-hero {
    min-height: 640px;
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 430px);
    align-items: center;
    gap: 2rem;
    padding: 1rem 0 4rem;
    border-bottom: 1px solid var(--color-border);
}

.restaurant-nav {
    grid-column: 1 / -1;
    min-height: 56px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.restaurant-brand {
    color: var(--color-text);
    font-weight: 800;
    font-size: 1rem;
}

.restaurant-nav__links {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    flex-wrap: wrap;
}

.restaurant-nav__links a {
    min-height: 40px;
    display: inline-flex;
    align-items: center;
    color: var(--color-text-soft);
    font-weight: 600;
}

.restaurant-nav__links a:hover {
    color: var(--color-text);
    text-decoration: none;
}

.restaurant-nav__reserve {
    padding: 0 0.85rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    background: var(--color-surface);
}

.restaurant-hero__content {
    max-width: 680px;
}

.restaurant-kicker {
    margin-bottom: 0.8rem;
    color: var(--color-accent);
    font-size: 0.9rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0;
}

.restaurant-hero h1 {
    max-width: 11ch;
    margin-bottom: 1rem;
    font-size: 3.25rem;
    line-height: 1;
}

.restaurant-hero__lead {
    max-width: 36rem;
    color: var(--color-text-soft);
    font-size: 1.12rem;
    line-height: 1.65;
}

.restaurant-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 2rem;
}

.restaurant-hero__plate {
    min-height: 380px;
    display: grid;
    place-items: center;
    background: var(--color-surface-soft);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
}

.restaurant-plate {
    position: relative;
    width: min(300px, 75%);
    aspect-ratio: 1;
    border-radius: 50%;
    background: #fff;
    box-shadow: 0 18px 55px rgba(31, 59, 45, 0.14);
}

.restaurant-plate__rim,
.restaurant-plate__leaf,
.restaurant-plate__main,
.restaurant-plate__sauce {
    position: absolute;
    display: block;
}

.restaurant-plate__rim {
    inset: 9%;
    border: 1px solid var(--color-border);
    border-radius: 50%;
}

.restaurant-plate__main {
    left: 30%;
    top: 34%;
    width: 40%;
    height: 32%;
    border-radius: 42% 58% 48% 52%;
    background: var(--color-accent);
}

.restaurant-plate__leaf {
    left: 21%;
    top: 22%;
    width: 34%;
    height: 18%;
    border-radius: 90% 10% 90% 10%;
    background: var(--color-primary);
    transform: rotate(-24deg);
}

.restaurant-plate__sauce {
    right: 20%;
    bottom: 25%;
    width: 32%;
    height: 10%;
    border-radius: 999px;
    background: var(--color-accent-soft);
}

.restaurant-section {
    padding: 4rem 0;
    border-bottom: 1px solid var(--color-border);
}

.restaurant-intro {
    display: grid;
    grid-template-columns: minmax(0, 0.8fr) minmax(0, 1fr);
    gap: 2rem;
    align-items: start;
}

.restaurant-intro p,
.restaurant-section__heading p,
.restaurant-menu-card p,
.restaurant-contact,
.restaurant-hours {
    color: var(--color-text-soft);
}

.restaurant-section__heading {
    max-width: 44rem;
    margin-bottom: 1.5rem;
}

.restaurant-section__heading h2 {
    margin-bottom: 0.7rem;
}

.restaurant-menu-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.restaurant-menu-card {
    min-height: 190px;
    padding: 1.4rem;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
}

.restaurant-menu-card h3 {
    margin-bottom: 0.7rem;
}

.restaurant-info-band {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(260px, 360px);
    gap: 2rem;
    align-items: start;
    background: var(--color-surface-soft);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    padding: 2rem;
}

.restaurant-contact {
    display: grid;
    gap: 1rem;
    margin: 1.5rem 0 0;
}

.restaurant-contact dt {
    color: var(--color-text);
    font-weight: 700;
}

.restaurant-contact dd {
    margin: 0.2rem 0 0;
}

.restaurant-hours {
    display: grid;
    gap: 0.6rem;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    padding: 1rem;
}

.restaurant-hours__row {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    border-bottom: 1px solid var(--color-border);
    padding-bottom: 0.55rem;
}

.restaurant-hours__row:last-child {
    border-bottom: 0;
    padding-bottom: 0;
}

.restaurant-hours__row strong {
    color: var(--color-text);
    text-align: right;
}

.restaurant-booking {
    border-bottom: 0;
    padding-bottom: 0;
}

.restaurant-booking__frame {
    width: 100%;
    min-height: 760px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    display: block;
    background: var(--color-surface);
    box-shadow: var(--shadow-sm);
}

.restaurant-booking__widget {
    width: 100%;
    min-height: 760px;
    display: block;
}

@media (max-width: 900px) {
    .restaurant-hero,
    .restaurant-intro,
    .restaurant-info-band {
        grid-template-columns: 1fr;
    }

    .restaurant-menu-grid {
        grid-template-columns: 1fr;
    }

    .restaurant-hero {
        min-height: auto;
        padding-bottom: 2.5rem;
    }

    .restaurant-hero__plate {
        min-height: 280px;
    }
}

@media (max-width: 640px) {
    .restaurant-shell {
        padding: 0.75rem 0.75rem 3rem;
    }

    .restaurant-nav {
        align-items: flex-start;
        flex-direction: column;
    }

    .restaurant-hero h1 {
        font-size: 2.35rem;
    }

    .restaurant-hero__lead {
        font-size: 1rem;
    }

    .restaurant-hero__actions .btn {
        width: 100%;
    }

    .restaurant-section {
        padding: 2.5rem 0;
    }

    .restaurant-info-band {
        padding: 1.2rem;
    }

    .restaurant-booking__frame {
        min-height: 700px;
    }
}

/* ------------------------------------------------------------------
   Pirjon Pöytä — kortteliravintolan etusivun teema.
   Skooppaa .pirjon-säiliön alle; yleinen .restaurant-* rakenne pysyy
   pohjana, tämä lisää tunnelmaa: lämpimät sävyt, serif-otsikot,
   pieni tekstuuri ja käsintehty tuntuma.
   ------------------------------------------------------------------ */
.pirjon {
    --pirjon-display: "Iowan Old Style", "Palatino Linotype", "Book Antiqua", Palatino, Georgia, serif;
    --pirjon-cream: #f5ecd6;
    --pirjon-paper: #fbf6e8;
    --pirjon-paper-soft: #fefaf0;
    --pirjon-ink: #231b14;
    --pirjon-ink-soft: #5a4e3f;
    --pirjon-line: #d9cfb7;
    --pirjon-line-soft: #ebe1c8;
    --pirjon-moss: #34503a;
    --pirjon-clay: #b0553a;
    --pirjon-butter: #efdbb0;
}

.restaurant-shell.pirjon {
    width: min(1320px, 100%);
    padding: 1.25rem clamp(1rem, 3vw, 2.5rem) 5rem;
    color: var(--pirjon-ink);
    background: transparent;
}

.pirjon h1,
.pirjon h2,
.pirjon h3,
.pirjon blockquote {
    font-family: var(--pirjon-display);
    color: var(--pirjon-ink);
    font-weight: 600;
}

.pirjon h2 { font-size: clamp(1.9rem, 2.4vw, 2.6rem); line-height: 1.15; }
.pirjon h3 { font-size: 1.25rem; }

.pirjon .restaurant-kicker {
    color: var(--pirjon-clay);
    letter-spacing: 0.12em;
    font-size: 0.78rem;
}

.pirjon-ribbon {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.7rem;
    margin: 1rem auto 2rem;
    padding: 0.7rem 1.4rem;
    max-width: 820px;
    background: var(--pirjon-ink);
    color: var(--pirjon-butter);
    border-radius: 999px;
    font-size: 0.92rem;
    letter-spacing: 0.02em;
    box-shadow: 0 18px 40px -28px rgba(35, 27, 20, 0.5);
}

.pirjon-ribbon__dot {
    width: 8px; height: 8px;
    border-radius: 50%;
    background: var(--pirjon-clay);
    box-shadow: 0 0 0 4px rgba(176, 85, 58, 0.2);
}

/* Brand mark (small monogram in nav + footer) */
.pirjon-brand {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
}

.pirjon-brand__mark {
    display: inline-grid;
    place-items: center;
    width: 34px; height: 34px;
    border: 1px solid var(--pirjon-ink);
    border-radius: 50%;
    font-family: var(--pirjon-display);
    font-style: italic;
    font-size: 1.05rem;
    color: var(--pirjon-ink);
    background: var(--pirjon-cream);
}

.pirjon-brand__name {
    font-family: var(--pirjon-display);
    font-size: 1.1rem;
    font-weight: 600;
    letter-spacing: 0.01em;
}

.pirjon .restaurant-nav__links a {
    color: var(--pirjon-ink-soft);
    font-weight: 500;
}

.pirjon .restaurant-nav__links a:hover {
    color: var(--pirjon-ink);
}

.pirjon .restaurant-nav__reserve {
    border: 1px solid var(--pirjon-ink);
    background: transparent;
    color: var(--pirjon-ink);
}

/* Hero */
.pirjon-hero {
    border-bottom: 1px dashed var(--pirjon-line);
    gap: clamp(2.5rem, 5vw, 5rem);
    grid-template-columns: minmax(0, 1.1fr) minmax(320px, 460px);
    padding: 2rem 0 5rem;
    min-height: 680px;
}

.pirjon-hero__content {
    padding-right: clamp(0px, 2vw, 2.5rem);
}

.pirjon-hero h1 {
    font-family: var(--pirjon-display);
    font-size: clamp(2.6rem, 5.2vw, 4.8rem);
    line-height: 0.95;
    letter-spacing: -0.01em;
    color: var(--pirjon-ink);
    max-width: 12ch;
    margin-bottom: 1.4rem;
}

.pirjon .restaurant-hero__lead {
    color: var(--pirjon-ink-soft);
    font-size: 1.18rem;
    max-width: 38rem;
}

.pirjon-hero__facts {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.5rem;
    margin: 3rem 0 0;
    padding-top: 1.8rem;
    border-top: 1px solid var(--pirjon-line);
}

.pirjon-hero__facts > div { margin: 0; }

.pirjon-hero__facts dt {
    font-size: 0.72rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--pirjon-clay);
    margin-bottom: 0.35rem;
}

.pirjon-hero__facts dd {
    margin: 0;
    font-family: var(--pirjon-display);
    font-size: 1.25rem;
    color: var(--pirjon-ink);
}

/* Hero card — korvaa abstraktin lautasen lämpimällä "emännän kortilla" */
.pirjon-hero__card {
    position: relative;
    padding: 3rem 2.8rem 3rem;
    background: var(--pirjon-paper-soft);
    background-image: repeating-linear-gradient(
        0deg,
        rgba(35, 27, 20, 0.025) 0 1px,
        transparent 1px 34px
    );
    background-position: 0 2.6rem;
    border: 1px solid var(--pirjon-line);
    border-radius: 12px;
    box-shadow:
        0 1px 0 rgba(35, 27, 20, 0.04),
        0 30px 70px -40px rgba(35, 27, 20, 0.4);
    transform: rotate(-1deg);
    min-height: 440px;
    display: flex;
    flex-direction: column;
    gap: 1.6rem;
}

.pirjon-hero__card::before {
    content: "";
    position: absolute;
    inset: 14px;
    border: 1px dashed rgba(35, 27, 20, 0.14);
    border-radius: 8px;
    pointer-events: none;
}

.pirjon-hero__stamp {
    align-self: flex-start;
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 86px; height: 86px;
    border: 2px solid var(--pirjon-clay);
    border-radius: 50%;
    color: var(--pirjon-clay);
    transform: rotate(-8deg);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-size: 0.6rem;
    padding-top: 4px;
}

.pirjon-hero__stamp strong {
    font-family: var(--pirjon-display);
    font-size: 1.4rem;
    letter-spacing: 0.02em;
    margin-top: 0.1rem;
}

.pirjon-hero__quote {
    margin: 0;
    color: var(--pirjon-ink);
}

.pirjon-hero__quote p {
    font-family: var(--pirjon-display);
    font-size: 1.28rem;
    line-height: 1.55;
    font-style: italic;
    margin: 0 0 1rem;
    max-width: 26ch;
}

.pirjon-hero__quote cite {
    font-style: normal;
    color: var(--pirjon-ink-soft);
    font-size: 0.92rem;
}

.pirjon-hero__signature {
    margin-top: auto;
    align-self: flex-end;
    font-family: "Brush Script MT", "Segoe Script", cursive;
    font-size: 2.3rem;
    color: var(--pirjon-moss);
    line-height: 1;
    transform: rotate(-5deg);
}

/* Sections — vaihteleva rytmi paperi/kerma, reippaat marginaalit */
.pirjon .restaurant-section {
    padding: clamp(3.5rem, 6vw, 6rem) 0;
    border-bottom: 0;
    position: relative;
}

.pirjon .restaurant-section + .restaurant-section::before {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 42px;
    height: 1px;
    background: var(--pirjon-clay);
    opacity: 0.5;
}

/* Paperikorttimaiset osiot – nousevat kermataustasta omina kortteina */
.pirjon .pirjon-story,
.pirjon .pirjon-experiences,
.pirjon .pirjon-booking {
    background: var(--pirjon-paper-soft);
    border: 1px solid var(--pirjon-line-soft);
    border-radius: 14px;
    padding: clamp(2.5rem, 4vw, 4rem) clamp(1.8rem, 3vw, 3.2rem);
    margin: clamp(2rem, 4vw, 3.5rem) 0;
    box-shadow: 0 1px 0 rgba(35, 27, 20, 0.03);
}

.pirjon .pirjon-story::before,
.pirjon .pirjon-experiences::before,
.pirjon .pirjon-booking::before {
    display: none;
}

/* Story */
.pirjon-story {
    display: grid;
    grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.1fr);
    gap: clamp(2.5rem, 5vw, 5rem);
    align-items: start;
}

.pirjon-story__lead h2 {
    font-size: clamp(1.9rem, 2.6vw, 2.5rem);
    line-height: 1.1;
}

/* Pirjon polaroid-muotokuva tarinan vasemmassa sarakkeessa */
.pirjon-portrait {
    width: 220px;
    max-width: 100%;
    margin: 3.2rem 0 0;
    padding: 0.9rem 0.9rem 1.2rem;
    background: var(--pirjon-paper);
    border: 1px solid var(--pirjon-line);
    border-radius: 6px;
    box-shadow:
        0 1px 0 rgba(35, 27, 20, 0.04),
        0 22px 40px -26px rgba(35, 27, 20, 0.45);
    transform: rotate(-2.5deg);
    display: flex;
    flex-direction: column;
    gap: 0.7rem;
    position: relative;
}

.pirjon-portrait::before {
    /* teipin pala polaroidin yläreunassa */
    content: "";
    position: absolute;
    top: -10px;
    left: 50%;
    width: 52px;
    height: 18px;
    transform: translateX(-50%) rotate(-3deg);
    background: rgba(235, 210, 150, 0.75);
    border: 1px solid rgba(176, 85, 58, 0.15);
    box-shadow: 0 1px 2px rgba(35, 27, 20, 0.08);
}

.pirjon-portrait__frame {
    aspect-ratio: 1;
    border-radius: 50%;
    overflow: hidden;
    background: var(--pirjon-butter);
    border: 1px solid var(--pirjon-line);
}

.pirjon-portrait__frame svg {
    display: block;
    width: 100%;
    height: 100%;
}

.pirjon-portrait figcaption {
    text-align: center;
    font-family: "Brush Script MT", "Segoe Script", "Lucida Handwriting", cursive;
    font-size: 1.1rem;
    color: var(--pirjon-moss);
    letter-spacing: 0.01em;
}

.pirjon-story__body p {
    color: var(--pirjon-ink-soft);
    font-size: 1.05rem;
    line-height: 1.7;
    margin: 0 0 1rem;
}

.pirjon-story__highlights {
    list-style: none;
    padding: 1.8rem 2rem;
    margin: 2rem 0 0;
    background: var(--pirjon-cream);
    border: 1px solid var(--pirjon-line);
    border-radius: 8px;
    display: grid;
    gap: 1rem;
}

.pirjon-story__highlights li {
    color: var(--pirjon-ink-soft);
    font-size: 1rem;
    line-height: 1.6;
    display: grid;
    grid-template-columns: minmax(7rem, max-content) 1fr;
    gap: 1rem;
    align-items: baseline;
}

.pirjon-story__highlights li + li {
    border-top: 1px dotted var(--pirjon-line);
    padding-top: 1rem;
}

.pirjon-story__highlights strong {
    color: var(--pirjon-ink);
    font-family: var(--pirjon-display);
    font-weight: 600;
    margin-right: 0;
    font-size: 1.02rem;
}

/* Menu — à la carte -tuntuma */
.pirjon-menu__heading h2 { font-size: 2.2rem; }

.pirjon-menu__sub {
    color: var(--pirjon-ink-soft);
    font-size: 1rem;
    margin-top: 0.5rem;
}

.pirjon-menu__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: clamp(2rem, 4vw, 4rem);
    margin-top: 2.6rem;
}

.pirjon-menu__course h3 {
    font-family: var(--pirjon-display);
    font-size: 1.05rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--pirjon-clay);
    margin: 0 0 1rem;
    padding-bottom: 0.6rem;
    border-bottom: 1px solid var(--pirjon-line);
}

.pirjon-menu__course ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 0.9rem;
}

.pirjon-menu__course li {
    display: flex;
    align-items: baseline;
    gap: 0.5rem;
    color: var(--pirjon-ink);
    font-family: var(--pirjon-display);
    font-size: 1.08rem;
    line-height: 1.35;
}

.pirjon-menu__name { flex: 0 1 auto; }

.pirjon-menu__dots {
    flex: 1 1 auto;
    min-width: 1.5rem;
    border-bottom: 1px dotted var(--pirjon-line);
    transform: translateY(-0.3em);
}

.pirjon-menu__price {
    flex: 0 0 auto;
    font-variant-numeric: tabular-nums;
    color: var(--pirjon-ink-soft);
}

/* Experiences */
.pirjon-experiences__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.8rem;
    margin-top: 2.2rem;
}

.pirjon-experience {
    background: var(--pirjon-cream);
    border: 1px solid var(--pirjon-line);
    border-radius: 8px;
    padding: 2rem 1.8rem 2.2rem;
    display: flex;
    flex-direction: column;
    gap: 0.7rem;
    position: relative;
    overflow: hidden;
}

.pirjon-experience::before {
    content: "";
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--pirjon-moss), var(--pirjon-clay));
    opacity: 0.85;
}

.pirjon-experience__lead {
    margin: 0;
    color: var(--pirjon-clay);
    font-size: 0.8rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.pirjon-experience h3 {
    margin: 0.1rem 0 0.3rem;
    font-size: 1.35rem;
}

.pirjon-experience p {
    color: var(--pirjon-ink-soft);
    margin: 0;
    line-height: 1.55;
}

/* Voices / press */
.pirjon-voices__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 2rem 2.4rem;
    margin-top: 2rem;
}

.pirjon-voice {
    margin: 0;
    padding: 0.4rem 0 0.4rem 1.6rem;
    background: transparent;
    border-left: 3px solid var(--pirjon-clay);
}

.pirjon-voice blockquote {
    margin: 0 0 0.8rem;
    font-family: var(--pirjon-display);
    font-style: italic;
    font-size: 1.15rem;
    line-height: 1.4;
    color: var(--pirjon-ink);
}

.pirjon-voice figcaption {
    color: var(--pirjon-ink-soft);
    font-size: 0.9rem;
    letter-spacing: 0.06em;
}

/* Info band override */
.pirjon .restaurant-info-band {
    background: var(--pirjon-paper);
    border: 1px solid var(--pirjon-line);
    padding: clamp(2rem, 3.5vw, 3rem);
    gap: clamp(2rem, 4vw, 3.5rem);
    margin: clamp(2rem, 4vw, 3.5rem) 0;
}

.pirjon .restaurant-contact dt {
    color: var(--pirjon-ink);
    font-weight: 600;
}

.pirjon .restaurant-contact dd {
    color: var(--pirjon-ink-soft);
}

.pirjon-info__hint {
    margin-top: 1.2rem;
    font-size: 0.92rem;
    color: var(--pirjon-ink-soft);
    max-width: 44ch;
}

.pirjon .restaurant-hours {
    background: var(--pirjon-cream);
    border: 1px solid var(--pirjon-line);
}

.pirjon .restaurant-hours__row {
    border-bottom: 1px dotted var(--pirjon-line);
    font-family: var(--pirjon-display);
    font-size: 1rem;
}

.pirjon .restaurant-hours__row strong {
    color: var(--pirjon-ink);
    font-weight: 600;
}

/* Booking — upotus istuu ravintolan sivuun, ei "tuotedemo" */
.pirjon-booking .restaurant-section__heading p {
    color: var(--pirjon-ink-soft);
    max-width: 58ch;
}

.pirjon .restaurant-booking__frame {
    border: 1px solid var(--pirjon-line);
    border-radius: 10px;
    background: #fff;
    box-shadow: 0 24px 60px -40px rgba(35, 27, 20, 0.35);
}

/* Footer */
.pirjon-footer {
    margin-top: 2.5rem;
    padding: 2.5rem 0 0.5rem;
    border-top: 1px solid var(--pirjon-line);
    text-align: center;
    display: grid;
    gap: 0.9rem;
    justify-items: center;
    color: var(--pirjon-ink-soft);
}

.pirjon-footer__brand {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    font-family: var(--pirjon-display);
    font-size: 1.1rem;
    color: var(--pirjon-ink);
}

.pirjon-footer__line {
    margin: 0;
    font-size: 0.95rem;
}

.pirjon-footer__links {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 1.2rem;
    font-size: 0.88rem;
    letter-spacing: 0.04em;
}

.pirjon-footer__links a {
    color: var(--pirjon-ink-soft);
}

.pirjon-footer__links a:hover {
    color: var(--pirjon-ink);
    text-decoration: none;
}

/* Responsive */
@media (max-width: 900px) {
    .pirjon-hero,
    .pirjon-story,
    .pirjon-hero__facts,
    .pirjon-menu__grid,
    .pirjon-experiences__grid,
    .pirjon-voices__grid {
        grid-template-columns: 1fr;
    }

    .pirjon-hero {
        min-height: auto;
        padding: 1rem 0 3rem;
    }

    .pirjon-hero__card {
        transform: none;
        min-height: auto;
        padding: 2.2rem 2rem 2.4rem;
    }

    .pirjon-hero__content {
        padding-right: 0;
    }

    .pirjon-portrait {
        margin-inline: auto;
    }
}

@media (max-width: 640px) {
    .pirjon-ribbon { font-size: 0.8rem; }
    .pirjon-hero h1 { font-size: 2.4rem; }
    .pirjon h2 { font-size: 1.7rem; }
    .pirjon-hero__facts { gap: 0.9rem; }
    .pirjon-hero__facts dd { font-size: 1.1rem; }
    .pirjon-hero__card { padding: 1.5rem 1.3rem 1.8rem; }
}

/* ---------- Vaihe 51: kustomi varauskalenteri ----------
 * Prefiksoidut .dtw-calendar-luokat, jotta tyylit toimivat sekä
 * varauspolun (booking.php) että dynaamisen Shadow DOM -widgetin
 * (dealtables-widget.js) sisällä eivätkä vuoda muille sivuille.
 * Globaaleja selektoreita (button, input, h2 ym.) vältetään tarkoituksella.
 */
.dtw-calendar {
    margin: 0.5rem 0 0.4rem;
    padding: 0.85rem 0.85rem 1rem;
    border: 1px solid var(--color-border, #e2ddd2);
    border-radius: 10px;
    background: #fff;
    display: flex;
    flex-direction: column;
    gap: 0.7rem;
    font: 500 0.95rem/1.4 inherit;
}

.dtw-calendar__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.8rem;
}

.dtw-calendar__title {
    font-weight: 700;
    font-size: 1rem;
    letter-spacing: 0.01em;
}

.dtw-calendar__nav {
    display: flex;
    gap: 0.35rem;
}

.dtw-calendar__nav-btn {
    appearance: none;
    border: 1px solid var(--color-border, #e2ddd2);
    background: #fff;
    color: var(--color-text, #1a1a1a);
    width: 2rem;
    height: 2rem;
    border-radius: 50%;
    font-size: 1.05rem;
    line-height: 1;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.dtw-calendar__nav-btn:hover:not(:disabled) {
    border-color: var(--color-accent, #1f3b2d);
    color: var(--color-accent, #1f3b2d);
}

.dtw-calendar__nav-btn:disabled {
    opacity: 0.35;
    cursor: not-allowed;
}

.dtw-calendar__weekdays {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 0.3rem;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #6c6a64;
    text-align: center;
}

.dtw-calendar__weekday {
    padding: 0.25rem 0;
}

.dtw-calendar__grid {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 0.3rem;
}

.dtw-calendar__day {
    appearance: none;
    border: 1px solid transparent;
    background: #f3f0e8;
    color: var(--color-text, #1a1a1a);
    border-radius: 8px;
    min-height: 3.1rem;
    padding: 0.3rem 0.2rem;
    cursor: pointer;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.1rem;
    text-align: center;
    transition: transform 0.06s ease;
}

.dtw-calendar__day:hover:not(:disabled) {
    transform: translateY(-1px);
    border-color: var(--color-accent, #1f3b2d);
}

.dtw-calendar__day:focus-visible {
    outline: 2px solid var(--color-accent, #1f3b2d);
    outline-offset: 1px;
}

.dtw-calendar__day:disabled {
    cursor: not-allowed;
}

.dtw-calendar__day-number {
    font-weight: 700;
    font-size: 0.95rem;
    line-height: 1;
}

.dtw-calendar__day-label {
    font-size: 0.65rem;
    line-height: 1.1;
    letter-spacing: 0.02em;
    color: inherit;
    opacity: 0.85;
}

.dtw-calendar__day--blank {
    background: transparent;
    border-color: transparent;
    cursor: default;
    pointer-events: none;
    min-height: 0;
}

.dtw-calendar__day--available {
    background: #e6f0e1;
    color: #1f3b2d;
}

.dtw-calendar__day--limited {
    background: #fff1d1;
    color: #6f4a0e;
}

.dtw-calendar__day--full {
    background: #f5dcdc;
    color: #7c2d2d;
}

.dtw-calendar__day--closed,
.dtw-calendar__day--out-of-range {
    background: #ece9e2;
    color: #99948a;
}

.dtw-calendar__day--closed .dtw-calendar__day-number,
.dtw-calendar__day--out-of-range .dtw-calendar__day-number {
    text-decoration: line-through;
    opacity: 0.6;
}

.dtw-calendar__day--today {
    box-shadow: inset 0 0 0 1px var(--color-accent, #1f3b2d);
}

.dtw-calendar__day--selected {
    background: var(--color-accent, #1f3b2d);
    color: #fff;
    border-color: var(--color-accent, #1f3b2d);
}

.dtw-calendar__day--selected .dtw-calendar__day-label {
    opacity: 0.9;
}

.dtw-calendar__status {
    margin: 0;
    font-size: 0.85rem;
    color: #6c6a64;
    min-height: 1.2em;
}

.dtw-calendar__status.is-error {
    color: #8b2d2d;
}

/* Native date-input on oletuksena näkyvä, jotta no-JS, JS-load-failure
 * ja JS-init-failure -tilanteissa varauspolku ei pysähdy. Booking.js
 * lisää `--enhanced`-luokan vasta kun custom kalenteri on aidosti
 * renderöitynyt onnistuneesti. Calendar API -virheessä luokka poistetaan
 * uudelleen, jolloin native-input palaa visuaalisesti näkyviin. Sama
 * logiikka kattaa myös `is-fallback-visible`-luokan vanhan rajapinnan
 * sellaisenaan, ettei muu sivuston JS regressoi tätä invarianttia.
 */
.dtw-calendar__fallback--enhanced {
    position: absolute;
    width: 1px;
    height: 1px;
    margin: -1px;
    border: 0;
    padding: 0;
    overflow: hidden;
    clip: rect(0 0 0 0);
}

.dtw-calendar__fallback--enhanced.is-fallback-visible {
    position: static;
    width: 100%;
    height: auto;
    margin: 0.6rem 0 0;
    border: 1px solid var(--color-border, #e2ddd2);
    padding: 0.6rem 0.7rem;
    overflow: visible;
    clip: auto;
}

@media (max-width: 480px) {
    .dtw-calendar { padding: 0.7rem 0.55rem 0.85rem; }
    .dtw-calendar__day { min-height: 2.7rem; padding: 0.25rem 0.1rem; }
    .dtw-calendar__day-number { font-size: 0.9rem; }
    .dtw-calendar__day-label { font-size: 0.6rem; }
}
