/* ============================================================
   Cadru - premium design system
   Aesthetic: warm cream paper, deep ink, soft brass, filmic.
   ============================================================ */

:root {
    /* - Palette - */
    --cadru-paper: #faf7f2;
    --cadru-paper-2: #f1ece2;
    --cadru-ink: #1a1410;
    --cadru-ink-soft: #3b332a;
    --cadru-muted: #7a6f60;
    --cadru-line: #ddd3c2;
    --cadru-brass: #b8884b;
    --cadru-brass-soft: #d9b27a;
    --cadru-rose: #c9756a;
    --cadru-leaf: #5e6c4a;
    --cadru-noir: #0d0a08;
    --cadru-overlay: rgba(26, 20, 16, 0.55);

    /* - Type - */
    --font-display: "GT Sectra", "Playfair Display", "Cormorant Garamond", Georgia, serif;
    --font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
    --font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;

    /* - Scale - */
    --space-1: 0.25rem;
    --space-2: 0.5rem;
    --space-3: 0.75rem;
    --space-4: 1rem;
    --space-5: 1.5rem;
    --space-6: 2rem;
    --space-7: 3rem;
    --space-8: 4.5rem;
    --space-9: 7rem;

    --radius-sm: 6px;
    --radius-md: 12px;
    --radius-lg: 22px;
    --radius-pill: 999px;

    --shadow-sm: 0 1px 2px rgba(26, 20, 16, 0.06), 0 1px 3px rgba(26, 20, 16, 0.04);
    --shadow-md: 0 6px 16px rgba(26, 20, 16, 0.08), 0 2px 4px rgba(26, 20, 16, 0.04);
    --shadow-lg: 0 24px 48px rgba(26, 20, 16, 0.12), 0 8px 16px rgba(26, 20, 16, 0.06);

    --duration-fast: 120ms;
    --duration-base: 220ms;
    --duration-slow: 480ms;
    --ease: cubic-bezier(0.2, 0.7, 0.2, 1);
}

* { box-sizing: border-box; }
[hidden] { display: none !important; }

html { -webkit-text-size-adjust: 100%; text-rendering: optimizeLegibility; }

body {
    margin: 0;
    font-family: var(--font-body);
    font-size: 16px;
    line-height: 1.55;
    color: var(--cadru-ink);
    background: var(--cadru-paper);
    /* Subtle paper grain */
    background-image:
        radial-gradient(rgba(184, 136, 75, 0.05) 1px, transparent 1px),
        radial-gradient(rgba(26, 20, 16, 0.03) 1px, transparent 1px);
    background-size: 32px 32px, 24px 24px;
    background-position: 0 0, 16px 16px;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Sticky footer: nav + main fill the viewport so the footer hugs the bottom
   even when content is short (contact, gallery with few photos). */
.cadru-body { display: flex; flex-direction: column; min-height: 100dvh; }
.cadru-body > main { flex: 1 0 auto; }
.cadru-body > .cadru-footer { flex-shrink: 0; margin-top: 0; }

img { max-width: 100%; display: block; }

a { color: var(--cadru-ink); text-decoration-color: var(--cadru-brass); text-decoration-thickness: 1px; text-underline-offset: 3px; transition: color var(--duration-fast) var(--ease); }
a:hover { color: var(--cadru-brass); }

h1, h2, h3, h4 { font-family: var(--font-display); font-weight: 600; letter-spacing: -0.01em; line-height: 1.1; margin: 0 0 var(--space-4); color: var(--cadru-ink); }
h1 { font-size: clamp(2.2rem, 4.2vw + 1rem, 4.4rem); letter-spacing: -0.02em; }
h2 { font-size: clamp(1.6rem, 2.2vw + 0.8rem, 2.6rem); }
h3 { font-size: 1.35rem; }
h4 { font-size: 1.1rem; }

p { margin: 0 0 var(--space-4); color: var(--cadru-ink-soft); }
small, .cadru-eyebrow { font-size: 0.8125rem; }

.cadru-eyebrow {
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--cadru-brass);
    font-weight: 600;
    font-size: 0.75rem;
    margin-bottom: var(--space-2);
    display: inline-block;
}

/* - Layout - */
.cadru-container { max-width: 1180px; margin: 0 auto; padding: 0 clamp(1.25rem, 4vw, 2.5rem); }
.cadru-container--narrow { max-width: 720px; }
.cadru-section { padding: clamp(3rem, 7vw, var(--space-9)) 0; }
.cadru-section--tight { padding: var(--space-7) 0; }
.cadru-grid { display: grid; gap: var(--space-6); }
@media (min-width: 720px) { .cadru-grid--3 { grid-template-columns: repeat(3, 1fr); } .cadru-grid--2 { grid-template-columns: repeat(2, 1fr); } }

/* - Nav - */
.cadru-nav {
    position: sticky; top: 0; z-index: 40;
    backdrop-filter: saturate(120%) blur(14px);
    background: color-mix(in srgb, var(--cadru-paper) 86%, transparent);
    border-bottom: 1px solid var(--cadru-line);
}
/* Pin the row to a fixed height. Every child of .cadru-nav__inner and
   .cadru-nav__links stretches to that height and centers its own content,
   so the brand, the text links and the brass CTA all share the same
   vertical midline regardless of intrinsic size. */
.cadru-nav__inner { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); min-height: 64px; }
.cadru-nav__brand { display: inline-flex; align-items: center; font-family: var(--font-display); font-size: 1.45rem; font-weight: 600; letter-spacing: -0.01em; line-height: 1; color: var(--cadru-ink); text-decoration: none; }
.cadru-nav__brand:hover { color: var(--cadru-brass); }

/* Text links: hidden on mobile, visible at 800px+. The CTA below stays at every breakpoint. */
.cadru-nav__links { display: none; gap: var(--space-5); align-items: center; margin-left: auto; }
@media (min-width: 800px) { .cadru-nav__links { display: flex; } }
.cadru-nav__links a { text-decoration: none; font-size: 0.95rem; line-height: 1; color: var(--cadru-ink); }
.cadru-nav__links a:hover { color: var(--cadru-brass); }

.cadru-nav__cta { box-shadow: none; padding: 0.55rem 1.2rem; font-size: 0.9rem; line-height: 1; flex-shrink: 0; }
.cadru-nav__cta:hover { transform: none; box-shadow: var(--shadow-sm); }
.cadru-nav__actions { display: inline-flex; align-items: center; gap: var(--space-3); }
.cadru-nav__signout-form { margin: 0; padding: 0; display: inline-flex; align-items: center; }
.cadru-nav__signout {
    appearance: none; -webkit-appearance: none;
    background: transparent; border: 0; outline: 0;
    color: var(--cadru-rose);
    font-family: inherit; font-size: 0.85rem; line-height: 1;
    padding: 0.4rem 0.2rem;
    cursor: pointer;
    text-decoration: none;
}
.cadru-nav__signout:hover, .cadru-nav__signout:focus-visible { color: color-mix(in srgb, var(--cadru-rose) 75%, var(--cadru-ink)); text-decoration: underline; text-underline-offset: 3px; }

/* In-copy emphasis for the brand name */
.cadru-emph { font-weight: 600; color: var(--cadru-ink); text-decoration: underline; text-decoration-color: var(--cadru-brass); text-decoration-thickness: 2px; text-underline-offset: 4px; }

/* - Buttons - */
.cadru-btn {
    --bg: var(--cadru-ink);
    --fg: var(--cadru-paper);
    --bd: var(--cadru-ink);
    display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2);
    padding: 0.85rem 1.4rem;
    border-radius: var(--radius-pill);
    background: var(--bg); color: var(--fg);
    font-family: var(--font-body); font-weight: 600; font-size: 0.95rem; letter-spacing: 0.01em;
    border: 1px solid var(--bd);
    text-decoration: none; cursor: pointer;
    transition: transform var(--duration-fast) var(--ease), box-shadow var(--duration-fast) var(--ease), background var(--duration-fast) var(--ease);
    box-shadow: var(--shadow-sm);
}
.cadru-btn:hover { transform: translateY(-1px); box-shadow: var(--shadow-md); color: var(--fg); }
.cadru-btn:active { transform: translateY(0); }
.cadru-btn[disabled], .cadru-btn[aria-disabled="true"] { opacity: 0.5; pointer-events: none; }
.cadru-btn--ghost { --bg: transparent; --fg: var(--cadru-ink); --bd: var(--cadru-ink); box-shadow: none; }
.cadru-btn--ghost:hover { --bg: var(--cadru-ink); --fg: var(--cadru-paper); }
.cadru-btn--brass { --bg: var(--cadru-brass); --fg: var(--cadru-paper); --bd: var(--cadru-brass); }
.cadru-btn--lg { padding: 1.05rem 1.8rem; font-size: 1rem; }

/* - Cards - */
.cadru-card {
    background: var(--cadru-paper);
    border: 1px solid var(--cadru-line);
    border-radius: var(--radius-lg);
    padding: var(--space-6);
    box-shadow: var(--shadow-sm);
    transition: box-shadow var(--duration-base) var(--ease), transform var(--duration-base) var(--ease);
}
.cadru-card:hover { box-shadow: var(--shadow-md); }
.cadru-card__title { font-family: var(--font-display); font-size: 1.4rem; margin-bottom: var(--space-2); }
.cadru-card__icon { width: 52px; height: 52px; border-radius: 50%; background: var(--cadru-paper-2); display: grid; place-items: center; margin-bottom: var(--space-4); color: var(--cadru-brass); }
.cadru-card__icon svg { display: block; }

/* - Hero - */
.cadru-hero {
    position: relative; overflow: hidden;
    padding: clamp(4rem, 10vw, var(--space-9)) 0 clamp(3rem, 7vw, var(--space-8));
    text-align: center;
}
.cadru-hero::before {
    content: ""; position: absolute; inset: -20% -10% auto auto;
    width: 60vw; height: 60vw; max-width: 720px; max-height: 720px;
    background: radial-gradient(closest-side, rgba(184, 136, 75, 0.22), transparent 70%);
    z-index: 0; pointer-events: none;
}
.cadru-hero__title { position: relative; z-index: 1; max-width: 18ch; margin-inline: auto; }
.cadru-hero__lead { position: relative; z-index: 1; font-size: clamp(1.05rem, 1vw + 0.85rem, 1.2rem); color: var(--cadru-ink-soft); max-width: 36rem; margin: var(--space-4) auto var(--space-6); }
.cadru-hero__cta { position: relative; z-index: 1; display: inline-flex; gap: var(--space-3); flex-wrap: wrap; justify-content: center; }
.cadru-hero__visual { position: relative; z-index: 1; margin-top: var(--space-7); display: flex; justify-content: center; gap: var(--space-3); flex-wrap: wrap; }
.cadru-hero__polaroid { width: clamp(120px, 28vw, 180px); padding: 12px 12px 36px; background: #fff; border: 1px solid var(--cadru-line); box-shadow: var(--shadow-md); transform: rotate(-3deg); transition: transform var(--duration-base) var(--ease); }
.cadru-hero__polaroid + .cadru-hero__polaroid { transform: rotate(2deg) translateY(8px); }
.cadru-hero__polaroid:hover { transform: rotate(0) translateY(-6px); }
.cadru-hero__polaroid > img,
.cadru-hero__polaroid > svg { width: 100%; height: auto; aspect-ratio: 1; display: block; object-fit: cover; border-radius: 2px; filter: saturate(0.92) contrast(1.03); }
.cadru-hero__polaroid span { display: block; margin-top: 10px; font-family: "Caveat", "Patrick Hand", cursive; text-align: center; color: var(--cadru-muted); }

/* - Forms - */
.cadru-pill-group { display: inline-flex; flex-wrap: wrap; gap: 6px; padding: 4px; background: var(--cadru-paper-2); border: 1px solid var(--cadru-line); border-radius: var(--radius-pill); }
.cadru-pill-input { position: absolute; opacity: 0; pointer-events: none; }
.cadru-pill { padding: 8px 16px; border-radius: var(--radius-pill); font-size: 0.9rem; font-weight: 500; color: var(--cadru-muted); cursor: pointer; transition: background var(--duration-fast) var(--ease), color var(--duration-fast) var(--ease); user-select: none; }
.cadru-pill:hover { color: var(--cadru-ink); }
.cadru-pill-input:checked + .cadru-pill { background: var(--cadru-ink); color: var(--cadru-paper); }
.cadru-pill-input:focus-visible + .cadru-pill { outline: 2px solid var(--cadru-brass); outline-offset: 2px; }

.cadru-form { display: grid; gap: var(--space-4); }
.cadru-field { display: grid; gap: var(--space-2); }
.cadru-field label { font-weight: 600; font-size: 0.9rem; color: var(--cadru-ink); }
.cadru-field small { color: var(--cadru-muted); }
.cadru-field__label-with-info { display: inline-flex; align-items: center; gap: 0.5rem; }
.cadru-info { width: 18px; height: 18px; border-radius: 50%; border: 1px solid var(--cadru-line); background: var(--cadru-paper-2); color: var(--cadru-muted); font-size: 0.7rem; font-weight: 700; line-height: 1; cursor: help; display: inline-flex; align-items: center; justify-content: center; font-family: var(--font-body); position: relative; }
.cadru-info:hover, .cadru-info:focus { border-color: var(--cadru-brass); color: var(--cadru-brass); outline: none; }
.cadru-info::after { content: attr(data-cadru-tooltip); position: absolute; bottom: calc(100% + 8px); left: 50%; transform: translateX(-50%); background: var(--cadru-ink); color: var(--cadru-paper); padding: 0.5rem 0.75rem; border-radius: 8px; font-size: 0.78rem; font-weight: 400; line-height: 1.4; white-space: normal; width: max-content; max-width: 240px; text-align: left; opacity: 0; pointer-events: none; transition: opacity 120ms; box-shadow: 0 4px 12px rgba(26,20,16,0.2); }
.cadru-info:hover::after, .cadru-info:focus::after { opacity: 1; }
.cadru-input, .cadru-select, .cadru-textarea {
    width: 100%;
    padding: 0.85rem 1rem;
    border: 1px solid var(--cadru-line);
    border-radius: var(--radius-md);
    background: var(--cadru-paper);
    font: inherit; color: var(--cadru-ink);
    transition: border-color var(--duration-fast) var(--ease), box-shadow var(--duration-fast) var(--ease);
}
.cadru-input:focus, .cadru-select:focus, .cadru-textarea:focus {
    outline: none;
    border-color: var(--cadru-brass);
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--cadru-brass) 18%, transparent);
}
.cadru-textarea { min-height: 140px; resize: vertical; }
.cadru-check { display: flex; gap: var(--space-3); align-items: flex-start; font-size: 0.95rem; color: var(--cadru-ink-soft); }
.cadru-check input { margin-top: 4px; accent-color: var(--cadru-brass); }

/* - Alerts - */
.cadru-alert { padding: var(--space-3) var(--space-4); border-radius: var(--radius-md); margin-bottom: var(--space-4); border: 1px solid var(--cadru-line); }
.cadru-alert--success { background: color-mix(in srgb, var(--cadru-leaf) 14%, var(--cadru-paper)); border-color: var(--cadru-leaf); }
.cadru-alert--error { background: color-mix(in srgb, var(--cadru-rose) 14%, var(--cadru-paper)); border-color: var(--cadru-rose); }

/* Flash toasts: fixed top-right corner, fade in, auto-dismiss after 6s. */
/* Flashes float top-right, clearing the sticky nav (~64px) so they never
   sit on top of page content like the back link or the eyebrow. */
.cadru-flashes { position: fixed; top: calc(64px + 0.75rem); right: 1.25rem; z-index: 75; display: grid; gap: 0.6rem; max-width: min(28rem, calc(100vw - 2.5rem)); pointer-events: none; }
.cadru-flash { pointer-events: auto; display: flex; align-items: flex-start; gap: 0.75rem; padding: 0.85rem 1rem; background: var(--cadru-ink); color: var(--cadru-paper); border-radius: var(--radius-md); box-shadow: var(--shadow-lg); border-left: 3px solid var(--cadru-brass); font-size: 0.92rem; line-height: 1.45; transform: translateX(0); opacity: 1; transition: transform 280ms var(--ease), opacity 280ms var(--ease); }
.cadru-flash[data-leaving="true"] { transform: translateX(20px); opacity: 0; }
.cadru-flash--success { border-left-color: var(--cadru-leaf); }
.cadru-flash--error { border-left-color: var(--cadru-rose); }
.cadru-flash__close { background: transparent; border: 0; color: color-mix(in srgb, var(--cadru-paper) 70%, transparent); font-size: 1.2rem; line-height: 1; cursor: pointer; padding: 0 0 0 0.5rem; align-self: center; }
.cadru-flash__close:hover { color: var(--cadru-paper); }

/* Field pair: two inputs on one row, optional helper text spans both columns. */
.cadru-field-pair { display: grid; grid-template-columns: 1fr; gap: var(--space-3) var(--space-4); align-items: start; }
@media (min-width: 600px) { .cadru-field-pair { grid-template-columns: 1fr 1fr; } .cadru-field-pair__hint { grid-column: 1 / -1; } }
.cadru-field-pair__hint { color: var(--cadru-muted); font-size: 0.825rem; margin-top: -0.25rem; }

/* Date / datetime fields: equal height, friendlier calendar-style chrome. */
input.cadru-input[type="date"], input.cadru-input[type="datetime-local"], input.cadru-input[type="time"] { min-height: 52px; font-variant-numeric: tabular-nums; cursor: pointer; }
input.cadru-input[type="date"]::-webkit-datetime-edit-fields-wrapper,
input.cadru-input[type="datetime-local"]::-webkit-datetime-edit-fields-wrapper { color: var(--cadru-ink); }
input.cadru-input[type="date"]::-webkit-datetime-edit-text,
input.cadru-input[type="datetime-local"]::-webkit-datetime-edit-text { color: var(--cadru-muted); padding: 0 0.15rem; }
input.cadru-input[type="date"]:not(:focus):invalid::-webkit-datetime-edit,
input.cadru-input[type="datetime-local"]:not(:focus):invalid::-webkit-datetime-edit { color: var(--cadru-muted); }
input.cadru-input[type="date"]::-webkit-calendar-picker-indicator,
input.cadru-input[type="datetime-local"]::-webkit-calendar-picker-indicator { opacity: 0.55; cursor: pointer; padding: 4px; }
input.cadru-input[type="date"]:hover::-webkit-calendar-picker-indicator,
input.cadru-input[type="datetime-local"]:hover::-webkit-calendar-picker-indicator { opacity: 1; }

.cadru-field__opt { color: var(--cadru-muted); font-weight: 400; font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.12em; margin-left: 0.4rem; }

/* - Footer - */
.cadru-footer { border-top: 1px solid var(--cadru-line); padding: var(--space-7) 0; margin-top: var(--space-9); color: var(--cadru-muted); font-size: 0.9rem; }
.cadru-footer__grid { display: grid; gap: var(--space-5); grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); }
.cadru-footer h5 { font-family: var(--font-body); font-size: 0.75rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--cadru-ink); margin-bottom: var(--space-3); }
.cadru-footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: var(--space-2); }
.cadru-footer a { color: var(--cadru-ink-soft); text-decoration: none; }
.cadru-footer a:hover { color: var(--cadru-brass); }
.cadru-footer__bar { display: flex; flex-wrap: wrap; justify-content: space-between; gap: var(--space-3); margin-top: var(--space-6); padding-top: var(--space-4); border-top: 1px solid var(--cadru-line); font-size: 0.825rem; }

/* - Cookie banner -
   Slim row on mobile (one line of copy + two compact buttons) so it never
   parks itself on top of a primary CTA. Two-column on tablet+ for breathing
   room. */
.cadru-cookie {
    position: fixed; left: 0.75rem; right: 0.75rem; bottom: 0.75rem; z-index: 60;
    max-width: 720px; margin-inline: auto;
    background: var(--cadru-ink); color: var(--cadru-paper);
    border-radius: var(--radius-lg); padding: 0.85rem 1rem;
    box-shadow: var(--shadow-lg);
    transform: translateY(140%);
    transition: transform var(--duration-slow) var(--ease);
    display: grid; gap: 0.65rem;
}
@media (min-width: 640px) {
    .cadru-cookie { padding: 1rem 1.25rem; grid-template-columns: 1fr auto; align-items: center; }
}
.cadru-cookie[data-visible="true"] { transform: translateY(0); }
.cadru-cookie h4 { display: none; }
.cadru-cookie p { color: color-mix(in srgb, var(--cadru-paper) 85%, transparent); margin: 0; font-size: 0.86rem; line-height: 1.4; }
.cadru-cookie__actions { display: flex; flex-wrap: nowrap; gap: 0.5rem; justify-content: flex-end; }
.cadru-cookie__actions .cadru-btn { padding: 0.45rem 0.9rem; font-size: 0.82rem; line-height: 1.2; flex: 0 0 auto; min-width: 0; box-shadow: none; }
.cadru-cookie .cadru-btn { background: var(--cadru-paper); color: var(--cadru-ink); border-color: var(--cadru-paper); }
.cadru-cookie .cadru-btn--ghost { background: transparent; color: var(--cadru-paper); border-color: color-mix(in srgb, var(--cadru-paper) 50%, transparent); }

/* - Camera page - */
body.cadru-camera-body { overflow: hidden; background: var(--cadru-noir); }
.cadru-camera { min-height: 100dvh; height: 100dvh; display: grid; grid-template-rows: auto 1fr auto; background: var(--cadru-noir); color: var(--cadru-paper); overflow: hidden; }
.cadru-camera__topbar { display: flex; align-items: center; justify-content: space-between; padding: var(--space-3) var(--space-4); color: var(--cadru-paper); font-size: 0.9rem; gap: var(--space-2); }
.cadru-camera__topbar > span:nth-child(2) { flex: 1; text-align: center; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cadru-camera__counter { display: inline-flex; align-items: center; gap: var(--space-2); padding: 4px 10px; border-radius: var(--radius-pill); background: rgba(255,255,255,0.1); }
.cadru-camera__viewport { position: relative; overflow: hidden; display: grid; place-items: center; }
.cadru-camera__viewport video, .cadru-camera__viewport canvas { width: 100%; height: 100%; object-fit: cover; }
.cadru-camera__viewfinder { position: absolute; inset: var(--space-4); border: 1px dashed rgba(255,255,255,0.3); border-radius: var(--radius-md); pointer-events: none; }
/* Camera page: roll of the guest's own photos + floating shutter. */
.cadru-camera__name { color: var(--cadru-paper); font-weight: 600; max-width: 60%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cadru-camera--roll { background: var(--cadru-paper); color: var(--cadru-ink); }
.cadru-camera--roll .cadru-camera__topbar { background: rgba(13,10,8,0.92); color: var(--cadru-paper); }
.cadru-camera__roll { flex: 1 1 auto; overflow-y: auto; padding: var(--space-4) var(--space-4) 120px; }
.cadru-camera__roll-empty { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: var(--space-3); padding: var(--space-8) var(--space-5); text-align: center; min-height: 50vh; color: var(--cadru-ink); }
.cadru-camera__roll-title { margin: 0; font-size: 1.3rem; font-weight: 600; }
.cadru-camera__roll-lead { margin: 0; max-width: 30rem; color: var(--cadru-muted); line-height: 1.5; }
.cadru-camera__grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: var(--space-2); }
.cadru-camera__tile { position: relative; padding: 0; border: 0; background: var(--cadru-paper-2); border-radius: 12px; overflow: hidden; cursor: pointer; aspect-ratio: 1; box-shadow: var(--shadow-sm); transition: transform var(--duration-fast) var(--ease); -webkit-tap-highlight-color: transparent; }
.cadru-camera__tile:active { transform: scale(0.97); }
.cadru-camera__tile img { width: 100%; height: 100%; object-fit: cover; display: block; opacity: 0; transition: opacity 180ms ease; }
.cadru-camera__tile.is-loaded img { opacity: 1; }
.cadru-camera__tile--skeleton { background: linear-gradient(90deg, var(--cadru-paper-2) 0%, color-mix(in srgb, var(--cadru-paper-2) 60%, var(--cadru-paper)) 50%, var(--cadru-paper-2) 100%); background-size: 200% 100%; animation: cadru-skeleton 1.3s linear infinite; }
.cadru-camera__tile.is-uploading { opacity: 0.85; }
.cadru-camera__tile-spinner { position: absolute; top: 50%; left: 50%; width: 32px; height: 32px; margin: -16px 0 0 -16px; border-radius: 50%; border: 3px solid rgba(255,255,255,0.4); border-top-color: var(--cadru-brass); animation: cadru-spin 0.85s linear infinite; pointer-events: none; }
@keyframes cadru-skeleton { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }
/* Floating action button — pinned bottom-centre, safe-area aware. */
.cadru-fab { position: fixed; left: 50%; bottom: calc(var(--space-5) + env(safe-area-inset-bottom)); transform: translateX(-50%); display: inline-flex; align-items: center; gap: var(--space-2); padding: 14px 22px; min-height: 56px; background: var(--cadru-brass); color: var(--cadru-paper); border: 0; border-radius: var(--radius-pill); box-shadow: 0 16px 40px rgba(0,0,0,0.25), 0 4px 12px rgba(0,0,0,0.15); font-size: 1rem; font-weight: 600; cursor: pointer; z-index: 50; transition: transform var(--duration-fast) var(--ease), box-shadow var(--duration-fast) var(--ease); -webkit-tap-highlight-color: transparent; white-space: nowrap; }
.cadru-fab:active { transform: translateX(-50%) scale(0.97); }
.cadru-fab.is-busy { opacity: 0.6; pointer-events: none; }
.cadru-fab svg { flex: 0 0 auto; }
.cadru-camera__panel { padding: var(--space-4); display: grid; gap: var(--space-3); background: linear-gradient(180deg, transparent, rgba(0,0,0,0.8)); }
.cadru-filters { display: flex; gap: var(--space-2); overflow-x: auto; padding: var(--space-2) 0; scroll-snap-type: x mandatory; scrollbar-width: none; -ms-overflow-style: none; }
.cadru-filters::-webkit-scrollbar { display: none; }
.cadru-filter { flex: 0 0 auto; padding: 8px 14px; border-radius: var(--radius-pill); border: 1px solid rgba(255,255,255,0.18); background: rgba(255,255,255,0.06); color: var(--cadru-paper); font-size: 0.85rem; font-weight: 500; scroll-snap-align: start; cursor: pointer; transition: background var(--duration-fast) var(--ease); }
.cadru-filter[aria-pressed="true"] { background: var(--cadru-brass); border-color: var(--cadru-brass); color: var(--cadru-noir); }
.cadru-shutter-row { display: flex; align-items: center; justify-content: space-around; padding: var(--space-3) 0; }
.cadru-shutter { width: 76px; height: 76px; border-radius: 50%; background: var(--cadru-paper); border: 4px solid rgba(255,255,255,0.2); box-shadow: 0 0 0 6px rgba(255,255,255,0.06); cursor: pointer; transition: transform var(--duration-fast) var(--ease); }
.cadru-shutter:active { transform: scale(0.96); }
.cadru-camera__icon-btn { background: transparent; border: 1px solid rgba(255,255,255,0.2); color: var(--cadru-paper); width: 46px; height: 46px; border-radius: 50%; display: grid; place-items: center; cursor: pointer; }

/* - Gallery -
   CSS grid with sane breakpoints so guests on a 390px phone get two columns,
   tablets get three, and desktops get four. Same code on guest & admin views. */
.cadru-gallery { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-4); padding: var(--space-5) 0; }
@media (min-width: 640px) { .cadru-gallery { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1024px) { .cadru-gallery { grid-template-columns: repeat(4, 1fr); } }
.cadru-gallery__item { margin: 0; position: relative; display: flex; flex-direction: column; }
.cadru-gallery__item img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; border-radius: var(--radius-md); box-shadow: var(--shadow-md); cursor: zoom-in; opacity: 0; transition: opacity 200ms ease; }
.cadru-gallery__item.is-loaded img { opacity: 1; }
.cadru-gallery__item--skeleton { aspect-ratio: 4 / 3; border-radius: var(--radius-md); box-shadow: var(--shadow-sm); background: linear-gradient(90deg, var(--cadru-paper-2) 0%, color-mix(in srgb, var(--cadru-paper-2) 60%, var(--cadru-paper)) 50%, var(--cadru-paper-2) 100%); background-size: 200% 100%; animation: cadru-skeleton 1.3s linear infinite; }
.cadru-gallery__meta { display: flex; justify-content: space-between; align-items: center; gap: var(--space-2); padding: var(--space-2) var(--space-1) 0; color: var(--cadru-muted); font-size: 0.8rem; }
.cadru-gallery__meta > span { min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* - Dashboard - */
.cadru-dashboard { display: grid; gap: var(--space-6); }
.cadru-event-card { display: grid; grid-template-columns: 1fr; gap: var(--space-4); padding: var(--space-5); border: 1px solid var(--cadru-line); border-radius: var(--radius-lg); background: var(--cadru-paper); transition: transform var(--duration-fast) var(--ease); }
@media (min-width: 720px) { .cadru-event-card { grid-template-columns: 1fr auto; align-items: center; } }
.cadru-event-card:hover { transform: translateY(-2px); }
.cadru-event-card__cta { display: flex; gap: var(--space-2); align-items: center; flex-wrap: wrap; }
.cadru-event-card__cta .cadru-btn { flex: 1 1 auto; min-width: 8rem; justify-content: center; }
@media (min-width: 720px) { .cadru-event-card__cta .cadru-btn { flex: 0 0 auto; } }
.cadru-event-card__meta { display: flex; gap: var(--space-3); flex-wrap: wrap; color: var(--cadru-muted); font-size: 0.875rem; }
.cadru-event-card__status { display: inline-flex; align-items: center; padding: 2px 10px; border-radius: var(--radius-pill); background: var(--cadru-paper-2); color: var(--cadru-ink-soft); font-size: 0.78rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; }
.cadru-event-card__status[data-state="live"] { background: color-mix(in srgb, var(--cadru-leaf) 22%, var(--cadru-paper)); color: var(--cadru-leaf); }
.cadru-event-card__status[data-state="ended"] { background: color-mix(in srgb, var(--cadru-rose) 22%, var(--cadru-paper)); color: var(--cadru-rose); }

/* - Event admin (share-first redesign) - */
.cadru-admin__back { display: inline-flex; width: max-content; align-items: center; gap: 0.4rem; text-decoration: none; color: var(--cadru-muted); font-size: 0.88rem; margin-bottom: var(--space-5); padding: 0.35rem 0.6rem 0.35rem 0; transition: color 120ms; }
.cadru-admin__back:hover { color: var(--cadru-brass); }
/* Force the eyebrow that follows the back link onto its own row. */
.cadru-admin__back + .cadru-eyebrow { display: block; }
.cadru-admin__head { display: flex; align-items: center; flex-wrap: wrap; gap: var(--space-3); margin-bottom: var(--space-2); }
.cadru-admin__head h1 { margin: 0; }
.cadru-admin__status { display: inline-flex; align-items: center; padding: 4px 12px; border-radius: var(--radius-pill); background: var(--cadru-paper-2); color: var(--cadru-ink-soft); font-size: 0.78rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; }
.cadru-admin__status[data-state="live"] { background: color-mix(in srgb, var(--cadru-leaf) 22%, var(--cadru-paper)); color: var(--cadru-leaf); }
.cadru-admin__status[data-state="live"]::before { content: ""; width: 8px; height: 8px; border-radius: 50%; background: var(--cadru-leaf); margin-right: 0.5rem; box-shadow: 0 0 0 0 currentColor; animation: cadru-pulse 2s infinite; }
.cadru-admin__status[data-state="ended"] { background: color-mix(in srgb, var(--cadru-rose) 22%, var(--cadru-paper)); color: var(--cadru-rose); }
@keyframes cadru-pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.5; } }
.cadru-admin__summary { color: var(--cadru-ink-soft); max-width: 36rem; margin-bottom: var(--space-7); }

.cadru-admin { display: grid; gap: var(--space-5); }

.cadru-admin__share { display: grid; grid-template-columns: 1fr; gap: var(--space-5); padding: var(--space-6); background: linear-gradient(135deg, var(--cadru-paper-2), var(--cadru-paper)); border: 1px solid var(--cadru-line); border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); align-items: center; }
@media (min-width: 720px) { .cadru-admin__share { grid-template-columns: auto 1fr; gap: var(--space-7); } }
.cadru-admin__share-qr { display: flex; justify-content: center; }
.cadru-admin__qr-frame { width: 220px; height: 220px; padding: 16px; background: #fff; border-radius: var(--radius-md); border: 1px solid var(--cadru-line); box-shadow: var(--shadow-md); display: grid; place-items: center; }
.cadru-admin__qr-frame img { width: 100%; height: 100%; image-rendering: pixelated; }
.cadru-admin__share-body { display: grid; gap: var(--space-3); }
.cadru-admin__share-body .cadru-eyebrow { margin-bottom: 0; }
.cadru-admin__code { font-family: var(--font-mono); font-size: clamp(1.6rem, 2vw + 1rem, 2.4rem); letter-spacing: 0.08em; color: var(--cadru-ink); font-weight: 700; margin: 0; }
.cadru-admin__url { font-family: var(--font-mono); font-size: 0.92rem; color: var(--cadru-ink-soft); margin: 0; word-break: break-all; padding: 0.6rem 0.85rem; background: var(--cadru-paper); border: 1px solid var(--cadru-line); border-radius: var(--radius-md); }
.cadru-admin__share-actions { display: flex; gap: var(--space-2); flex-wrap: wrap; margin-top: var(--space-2); }
.cadru-admin__share-actions .cadru-btn { box-shadow: none; flex: 1 1 auto; min-width: max-content; justify-content: center; }
@media (min-width: 600px) { .cadru-admin__share-actions .cadru-btn { flex: 0 0 auto; } }

.cadru-admin__actions { display: flex; gap: var(--space-2); flex-wrap: wrap; padding: var(--space-5); background: var(--cadru-paper); border: 1px solid var(--cadru-line); border-radius: var(--radius-lg); align-items: center; }
.cadru-admin__actions > .cadru-btn { flex: 1 1 14rem; min-width: 12rem; justify-content: center; }
@media (min-width: 720px) { .cadru-admin__actions > .cadru-btn { flex: 0 0 auto; } }
.cadru-admin__actions .cadru-btn[data-cadru-action="end"] { color: var(--cadru-rose); border-color: var(--cadru-rose); }
.cadru-admin__actions .cadru-btn[data-cadru-action="end"]:hover { background: var(--cadru-rose); color: var(--cadru-paper); }

.cadru-admin__gallery { margin-top: var(--space-3); }
.cadru-admin__gallery-head { display: flex; align-items: baseline; gap: var(--space-3); margin-bottom: var(--space-4); }
.cadru-admin__gallery-head h2 { margin: 0; }
.cadru-admin__gallery-count { color: var(--cadru-muted); font-size: 0.9rem; }

/* - Toast for in-camera feedback - */
.cadru-toast { position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%); padding: 0.85rem 1.4rem; border-radius: var(--radius-pill); background: var(--cadru-ink); color: var(--cadru-paper); box-shadow: var(--shadow-lg); z-index: 70; font-size: 0.9rem; opacity: 0; pointer-events: none; transition: opacity var(--duration-base) var(--ease), transform var(--duration-base) var(--ease); }
.cadru-toast[data-visible="true"] { opacity: 1; transform: translate(-50%, -8px); }

/* - Photo cap overlay (camera "Pelicula s-a terminat") -
   Fullscreen overlay above the camera with a soft blurred backdrop. Without
   this the cap card renders below the camera in document flow and the guest
   still sees the shutter. */
.cadru-cap { position: fixed; inset: 0; z-index: 90; display: grid; place-items: center; padding: 1.5rem; background: rgba(13, 10, 8, 0.72); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); color: var(--cadru-ink); animation: cadru-cap-in 280ms var(--ease); }
.cadru-cap[hidden] { display: none !important; }
.cadru-cap__card { max-width: 26rem; width: 100%; background: var(--cadru-paper); border: 1px solid var(--cadru-line); border-radius: var(--radius-lg); padding: 2.25rem 1.75rem; text-align: center; box-shadow: 0 24px 48px rgba(0,0,0,0.35); }
.cadru-cap__title { font-family: var(--font-display); font-size: 1.6rem; margin: 0 0 0.6rem; color: var(--cadru-ink); }
.cadru-cap__lead { color: var(--cadru-ink-soft); margin: 0 0 1.5rem; font-size: 0.98rem; line-height: 1.55; }
@keyframes cadru-cap-in { from { opacity: 0; } to { opacity: 1; } }

/* - Reveal countdown - */
.cadru-countdown { display: inline-flex; gap: var(--space-3); font-family: var(--font-display); font-size: 2rem; }
.cadru-countdown__cell { padding: var(--space-3); background: var(--cadru-paper-2); border-radius: var(--radius-md); min-width: 70px; text-align: center; }
.cadru-countdown__cell small { display: block; font-family: var(--font-body); font-size: 0.7rem; letter-spacing: 0.18em; color: var(--cadru-muted); text-transform: uppercase; margin-top: 2px; }

/* - Sections specific to landing - */
.cadru-how { counter-reset: step; }
.cadru-how__step { counter-increment: step; padding: var(--space-5); border-left: 2px solid var(--cadru-brass); position: relative; }
.cadru-how__step::before { content: counter(step, decimal-leading-zero); position: absolute; left: -36px; top: -8px; font-family: var(--font-display); font-size: 2.2rem; color: var(--cadru-brass); }
.cadru-faq summary { font-family: var(--font-display); font-size: 1.2rem; padding: var(--space-3) 0; cursor: pointer; border-bottom: 1px solid var(--cadru-line); list-style: none; display: flex; justify-content: space-between; }
.cadru-faq summary::after { content: "+"; color: var(--cadru-brass); font-size: 1.4rem; transition: transform var(--duration-base) var(--ease); }
.cadru-faq details[open] summary::after { transform: rotate(45deg); }
.cadru-faq p { padding: var(--space-3) 0; color: var(--cadru-ink-soft); }

/* - Pricing - */
.cadru-pricing { display: grid; gap: var(--space-5); grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
.cadru-pricing__card { padding: var(--space-6); border: 1px solid var(--cadru-line); border-radius: var(--radius-lg); background: var(--cadru-paper); }
.cadru-pricing__card--feature { background: var(--cadru-ink); color: var(--cadru-paper); }
.cadru-pricing__card--feature h3 { color: var(--cadru-paper); }
.cadru-pricing__price { font-family: var(--font-display); font-size: 2.4rem; margin: var(--space-2) 0; }
.cadru-pricing__features { list-style: none; margin: var(--space-4) 0; padding: 0; display: grid; gap: var(--space-2); }
.cadru-pricing__features li::before { content: "·"; color: var(--cadru-brass); margin-right: 0.5rem; font-weight: 700; }

/* - Admin views - */
.cadru-admin-nav { display: flex; align-items: center; gap: var(--space-3); margin-bottom: var(--space-5); padding-bottom: var(--space-3); border-bottom: 1px solid var(--cadru-line); }
.cadru-admin-nav ul { list-style: none; margin: 0; padding: 0; display: flex; gap: var(--space-3); flex: 1; align-items: center; }
.cadru-admin-nav__link { color: var(--cadru-ink-soft); text-decoration: none; padding: 0.3rem 0.6rem; border-radius: var(--radius-sm); }
.cadru-admin-nav__link:hover { color: var(--cadru-ink); background: var(--cadru-paper-2); }
.cadru-admin-nav__link.is-active { color: var(--cadru-ink); font-weight: 600; background: var(--cadru-paper-2); }
.cadru-admin-list { list-style: none; margin: 0; padding: 0; display: grid; gap: var(--space-2); }
.cadru-admin-list li { padding: var(--space-2) 0; border-bottom: 1px dashed var(--cadru-line); font-size: 0.92rem; }
.cadru-admin-list li:last-child { border-bottom: 0; }
.cadru-admin-filters { display: flex; flex-wrap: wrap; gap: var(--space-2); align-items: center; }
.cadru-pill { display: inline-block; padding: 0.3rem 0.7rem; border: 1px solid var(--cadru-line); border-radius: 999px; text-decoration: none; color: var(--cadru-ink-soft); font-size: 0.85rem; background: var(--cadru-paper); }
.cadru-pill:hover { background: var(--cadru-paper-2); }
.cadru-pill.is-active { background: var(--cadru-ink); color: var(--cadru-paper); border-color: var(--cadru-ink); }
.cadru-tag { display: inline-block; padding: 0.15rem 0.5rem; font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.08em; border-radius: var(--radius-sm); background: var(--cadru-paper-2); color: var(--cadru-ink-soft); margin-right: 0.5rem; }
.cadru-tag--high { background: #c2540a; color: #fff; }
.cadru-table { width: 100%; border-collapse: collapse; font-size: 0.9rem; }
.cadru-table th, .cadru-table td { padding: 0.5rem 0.75rem; text-align: left; border-bottom: 1px solid var(--cadru-line); }
.cadru-table th { background: var(--cadru-paper-2); font-weight: 600; }
.cadru-table tr.is-used { opacity: 0.55; }
.cadru-table tr.is-expired td:first-child { text-decoration: line-through; }
.cadru-table tr.is-cancelled { background: #ffeded; opacity: 0.7; }
.cadru-table tr.is-cancelled td:first-child code { text-decoration: line-through; }
.cadru-table tr.is-refunded { background: #fff5f5; }
.cadru-table tr.is-comp { background: #fff8e0; }
.cadru-table tr.is-failed { opacity: 0.4; }
.cadru-inbox { list-style: none; margin: 0; padding: 0; display: grid; gap: var(--space-3); }
.cadru-inbox__item { padding: var(--space-3) var(--space-4); border: 1px solid var(--cadru-line); border-radius: var(--radius-md); background: var(--cadru-paper); }
.cadru-inbox__item--high { border-left: 4px solid #c2540a; }
.cadru-inbox__head { display: flex; align-items: center; gap: var(--space-2); flex-wrap: wrap; }
.cadru-btn--sm { padding: 0.35rem 0.75rem; font-size: 0.85rem; }

/* - Tier table (event-create live pricing) - */
.cadru-tiers { border: 1px solid var(--cadru-line); border-radius: var(--radius-lg); padding: var(--space-3) var(--space-4); background: var(--cadru-paper-2); margin: var(--space-3) 0 var(--space-2); }
.cadru-tiers__row { display: flex; justify-content: space-between; align-items: baseline; padding: var(--space-2) 0; border-bottom: 1px dashed var(--cadru-line); transition: opacity 0.15s ease; opacity: 0.55; }
.cadru-tiers__row:last-of-type { border-bottom: 0; }
.cadru-tiers__row.is-active { opacity: 1; }
.cadru-tiers__row.is-active .cadru-tiers__price { color: var(--cadru-brass); font-weight: 700; }
.cadru-tiers__row { gap: var(--space-3); flex-wrap: wrap; }
.cadru-tiers__label { font-size: 0.95rem; color: var(--cadru-ink); min-width: 7rem; }
.cadru-tiers__range { font-size: 0.95rem; color: var(--cadru-ink-soft); flex: 1; }
.cadru-tiers__price { font-family: var(--font-display); font-size: 1.1rem; }
.cadru-tiers__current { font-size: 0.9rem; color: var(--cadru-ink); margin: var(--space-3) 0 0; font-weight: 600; min-height: 1.25rem; }

/* - Landing pricing cards - */
.cadru-pricing__lead { max-width: 540px; margin: var(--space-3) auto 0; color: var(--cadru-ink-soft); }
.cadru-pricing__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: var(--space-4);
    max-width: 980px;
    margin: var(--space-7) auto 0;
}
.cadru-pricing-card {
    position: relative;
    background: var(--cadru-paper);
    border: 1px solid var(--cadru-line);
    border-radius: var(--radius-lg);
    padding: var(--space-6) var(--space-4) var(--space-5);
    text-align: center;
    transition: transform var(--duration-base) var(--ease), box-shadow var(--duration-base) var(--ease);
}
.cadru-pricing-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.cadru-pricing-card.is-featured { border-color: var(--cadru-brass); box-shadow: 0 0 0 1px var(--cadru-brass), var(--shadow-sm); }
.cadru-pricing-card__badge {
    position: absolute; top: -0.75rem; left: 50%; transform: translateX(-50%);
    background: var(--cadru-brass); color: var(--cadru-paper);
    font-family: var(--font-body); font-size: 0.7rem; font-weight: 600;
    letter-spacing: 0.08em; text-transform: uppercase;
    padding: 0.3rem 0.75rem; border-radius: var(--radius-pill); white-space: nowrap;
}
.cadru-pricing-card__name {
    margin: 0 0 var(--space-4); font-family: var(--font-body); font-size: 0.85rem;
    font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase;
    color: var(--cadru-muted);
}
.cadru-pricing-card__price { margin: 0; font-family: var(--font-display); line-height: 1; }
.cadru-pricing-card__price-num { font-size: 3rem; font-weight: 700; color: var(--cadru-ink); }
.cadru-pricing-card__price-unit { font-size: 1rem; color: var(--cadru-ink-soft); margin-left: 0.35rem; font-family: var(--font-body); font-weight: 500; }
.cadru-pricing-card__price-custom { font-size: 1.5rem; color: var(--cadru-ink); }
.cadru-pricing-card__range { margin: var(--space-3) 0 0; color: var(--cadru-ink-soft); font-size: 0.9rem; }

.cadru-pricing__included {
    max-width: 560px; margin: var(--space-7) auto 0; text-align: left;
    background: var(--cadru-paper);
}
.cadru-pricing__included-title { margin: 0 0 var(--space-3); font-family: var(--font-display); font-size: 1.2rem; }
.cadru-pricing__features { list-style: none; padding: 0; margin: 0; display: grid; gap: var(--space-2); }
.cadru-pricing__features li {
    position: relative; padding-left: 1.75rem;
    color: var(--cadru-ink-soft);
}
.cadru-pricing__features li::before {
    content: ""; position: absolute; left: 0; top: 0.45rem;
    width: 1.1rem; height: 1.1rem;
    background: var(--cadru-brass);
    -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'><path fill='black' d='M16.7 5.3a1 1 0 0 1 0 1.4l-7.5 7.5a1 1 0 0 1-1.4 0L3.3 9.7a1 1 0 1 1 1.4-1.4L8.5 12 15.3 5.3a1 1 0 0 1 1.4 0Z'/></svg>") no-repeat center / contain;
            mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'><path fill='black' d='M16.7 5.3a1 1 0 0 1 0 1.4l-7.5 7.5a1 1 0 0 1-1.4 0L3.3 9.7a1 1 0 1 1 1.4-1.4L8.5 12 15.3 5.3a1 1 0 0 1 1.4 0Z'/></svg>") no-repeat center / contain;
}
.cadru-pricing__topup {
    margin: var(--space-6) auto 0; max-width: 720px;
    color: var(--cadru-ink-soft); font-size: 0.95rem;
    display: flex; flex-wrap: wrap; justify-content: center; align-items: center; gap: var(--space-2);
}
.cadru-pricing__topup-pill {
    background: var(--cadru-paper); border: 1px solid var(--cadru-line);
    border-radius: var(--radius-pill); padding: 0.3rem 0.75rem;
    font-size: 0.85rem; color: var(--cadru-ink);
}

.cadru-card--muted { background: var(--cadru-paper-2); }

.cadru-voucher-toggle { margin-top: var(--space-3); padding: var(--space-2) var(--space-3); border: 1px dashed var(--cadru-line); border-radius: var(--radius-md); background: var(--cadru-paper-2); }
.cadru-voucher-toggle summary { cursor: pointer; font-size: 0.9rem; color: var(--cadru-ink-soft); user-select: none; }
.cadru-voucher-toggle[open] summary { color: var(--cadru-ink); font-weight: 600; }

/* - Utilities - */
.cadru-text-center { text-align: center; }
.cadru-text-muted { color: var(--cadru-muted); }
.cadru-mt-0 { margin-top: 0; }
.cadru-mt-6 { margin-top: var(--space-6); }
.cadru-mb-0 { margin-bottom: 0; }
.cadru-skip-link { position: absolute; left: -9999px; }
.cadru-skip-link:focus { left: 1rem; top: 1rem; background: var(--cadru-ink); color: var(--cadru-paper); padding: 0.5rem 1rem; border-radius: var(--radius-md); z-index: 100; }

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { animation: none !important; transition: none !important; }
}

/* — Camera permission gate (full-screen overlay) — */
.cadru-camera-gate { position: fixed; inset: 0; z-index: 80; display: grid; place-items: center; padding: 1.5rem; background: linear-gradient(160deg, var(--cadru-paper), var(--cadru-paper-2)); color: var(--cadru-ink); overflow-y: auto; }
.cadru-camera-gate[hidden],
.cadru-camera-gate.is-hidden { display: none !important; }
.cadru-camera-gate__card { max-width: 28rem; width: 100%; background: var(--cadru-paper); border: 1px solid var(--cadru-line); border-radius: var(--radius-lg); padding: 2.5rem 1.75rem; text-align: center; box-shadow: 0 24px 48px rgba(26,20,16,0.12); }
.cadru-camera-gate__title { font-family: var(--font-display); font-size: 1.8rem; margin: 0 0 0.75rem; }
.cadru-camera-gate__lead { color: var(--cadru-ink-soft); margin-bottom: 1.5rem; font-size: 0.98rem; line-height: 1.55; }
.cadru-camera-gate__error { color: var(--cadru-rose); background: color-mix(in srgb, var(--cadru-rose) 12%, var(--cadru-paper)); border: 1px solid var(--cadru-rose); border-radius: var(--radius-md); padding: 0.65rem 0.8rem; margin: 1rem 0 0; font-size: 0.9rem; text-align: left; }
.cadru-camera-gate__help { margin-top: 1.5rem; text-align: left; font-size: 0.88rem; color: var(--cadru-ink-soft); }
.cadru-camera-gate__help summary { cursor: pointer; color: var(--cadru-brass); list-style: none; padding: 0.4rem 0; }
.cadru-camera-gate__help summary::-webkit-details-marker { display: none; }
.cadru-camera-gate__help ol { padding-left: 1.2rem; margin-top: 0.5rem; line-height: 1.6; }

/* — Lightbox — full-screen photo viewer with arrows + counter.
   z-index sits above .cadru-nav (which has its own stacking context) so the
   site header never bleeds through. The image is centered by flex so it
   doesn't drift left on wide viewports, and the arrow buttons are absolute
   so they line up to the viewport center, not to the bar above. */
.cadru-lightbox { position: fixed; inset: 0; z-index: 200; background: rgb(13, 10, 8); display: none; flex-direction: column; align-items: stretch; }
.cadru-lightbox[data-open="true"] { display: flex; touch-action: pan-y; }
/* Stop the browser from kicking in image drag, callout, or text-selection
   when the user starts a horizontal swipe over the photo. Without this iOS
   Safari shows the share sheet / drags the image and our gesture handler
   never gets a clean touchend. */
.cadru-lightbox__img { -webkit-user-drag: none; user-select: none; -webkit-touch-callout: none; pointer-events: none; }
/* When the lightbox is open, hide the sticky nav so its CTA can't peek
   through the lightbox top bar. */
body:has(.cadru-lightbox[data-open="true"]) .cadru-nav { display: none; }
.cadru-lightbox__bar { display: flex; justify-content: space-between; align-items: center; padding: 1rem 1.25rem; color: var(--cadru-paper); font-size: 0.9rem; flex: 0 0 auto; }
.cadru-lightbox__counter { font-family: var(--font-mono); color: color-mix(in srgb, var(--cadru-paper) 70%, transparent); }
.cadru-lightbox__img { display: block; flex: 1 1 auto; min-height: 0; align-self: center; max-width: min(100%, 1200px); max-height: 100%; margin: 0 auto; padding: 0 4.5rem; box-sizing: border-box; object-fit: contain; }
/* Spinner while a not-yet-cached photo loads after a swipe. */
.cadru-lightbox__spinner { display: none; position: absolute; top: 50%; left: 50%; width: 44px; height: 44px; margin: -22px 0 0 -22px; border-radius: 50%; border: 3px solid rgba(255,255,255,0.18); border-top-color: var(--cadru-brass); animation: cadru-spin 0.85s linear infinite; pointer-events: none; }
@keyframes cadru-spin { to { transform: rotate(360deg); } }
.cadru-lightbox__close, .cadru-lightbox__prev, .cadru-lightbox__next { background: rgba(255,255,255,0.14); border: 0; color: var(--cadru-paper); width: 44px; height: 44px; border-radius: 50%; display: grid; place-items: center; cursor: pointer; font-size: 1.4rem; line-height: 1; transition: background 120ms; }
.cadru-lightbox__close:hover, .cadru-lightbox__prev:hover, .cadru-lightbox__next:hover { background: rgba(255,255,255,0.24); }
.cadru-lightbox__prev, .cadru-lightbox__next { position: absolute; top: 50%; transform: translateY(-50%); z-index: 1; }
.cadru-lightbox__prev { left: 0.75rem; }
.cadru-lightbox__next { right: 0.75rem; }
.cadru-lightbox__meta { padding: 1rem 1.25rem; color: color-mix(in srgb, var(--cadru-paper) 80%, transparent); font-size: 0.92rem; text-align: center; flex: 0 0 auto; }
@media (max-width: 600px) {
    .cadru-lightbox__img { padding: 0 3.5rem; }
    .cadru-lightbox__prev { left: 0.4rem; }
    .cadru-lightbox__next { right: 0.4rem; }
}

/* — Modal — */
.cadru-modal { position: fixed; inset: 0; z-index: 90; display: grid; place-items: center; padding: 1rem; background: rgba(13, 10, 8, 0.55); opacity: 0; pointer-events: none; transition: opacity 220ms ease; }
.cadru-modal[data-open="true"] { opacity: 1; pointer-events: auto; }
.cadru-modal__card { max-width: 28rem; width: 100%; background: var(--cadru-paper); border-radius: var(--radius-lg); padding: 1.75rem; box-shadow: 0 24px 48px rgba(26,20,16,0.25); transform: translateY(8px); transition: transform 220ms ease; }
.cadru-modal[data-open="true"] .cadru-modal__card { transform: none; }
.cadru-modal__title { font-family: var(--font-display); font-size: 1.4rem; margin: 0 0 0.75rem; }
.cadru-modal__body { color: var(--cadru-ink-soft); margin-bottom: 1.25rem; line-height: 1.55; }
.cadru-modal__actions { display: flex; gap: 0.5rem; justify-content: flex-end; flex-wrap: wrap; }

/* — Printable QR card —
   Hidden on screen, occupies a single A5 page when printed.

   The key trick to avoid blank trailing pages is:
     1. Hide html/body backgrounds and the whole page tree (display:none) so
        the browser doesn't try to lay them out into pages.
     2. Render the print card as the *only* in-flow element on the page,
        sized to fit within the @page area without overflow.
*/
.cadru-print-card { display: none !important; }
@media print {
    @page { size: A5 portrait; margin: 0; }
    html, body { margin: 0 !important; padding: 0 !important; background: #faf7f2 !important; height: auto !important; }
    body > *:not(.cadru-print-card) { display: none !important; }
    .cadru-print-card {
        display: flex !important; flex-direction: column; align-items: center; justify-content: center;
        page-break-inside: avoid; break-inside: avoid;
        page-break-after: avoid; break-after: avoid;
        width: 148mm; min-height: 210mm; box-sizing: border-box;
        padding: 18mm 16mm;
        text-align: center;
        background: #faf7f2;
        color: #1a1410;
        font-family: var(--font-body);
        margin: 0 auto;
    }
    .cadru-print-card__brand { font-family: var(--font-display); font-size: 28pt; font-weight: 600; letter-spacing: -0.01em; border-bottom: 1.5pt solid #b8884b; display: inline-block; padding-bottom: 3pt; margin-bottom: 14pt; }
    .cadru-print-card__title { font-family: var(--font-display); font-size: 18pt; margin: 0 0 10pt; font-weight: 600; max-width: 110mm; }
    .cadru-print-card__qr { margin: 8pt auto; width: 70mm; height: 70mm; display: grid; place-items: center; }
    .cadru-print-card__qr img { width: 100%; height: 100%; image-rendering: pixelated; }
    .cadru-print-card__code { font-size: 10pt; margin-top: 6pt; letter-spacing: 0.08em; text-transform: uppercase; color: #7a6f60; }
    .cadru-print-card__code strong { font-family: var(--font-mono); font-size: 16pt; color: #1a1410; letter-spacing: 0.06em; }
    .cadru-print-card__url { font-size: 9pt; margin-top: 5pt; word-break: break-all; color: #3b332a; max-width: 110mm; }
    .cadru-print-card__footer { font-size: 9pt; margin-top: 14pt; color: #7a6f60; max-width: 110mm; }
}
