/* ---------------------------------------------------------------------------
   TourHub — base styles
   Design tokens come from the Ringnes-Ronny design book §9.1 (System B / Document
   palette). Per-tenant theming will override these CSS custom properties at the
   :root level when a tenant has a non-default theme.
   --------------------------------------------------------------------------- */

:root {
    --rr-purple:        #6A1B9A;
    --rr-purple-dark:   #4A0E6E;
    --rr-lavender:      #F3E5F5;
    --rr-grey-light:    #EEEEEE;
    --rr-grey-border:   #BFBFBF;
    --rr-text:          #333333;
    --rr-text-muted:    #808080;
    --rr-white:         #FFFFFF;

    --rr-success:       #2E7D32;
    --rr-warning:       #F2A93B;
    --rr-error:         #C62828;
    --rr-info:          #1565C0;

    --rr-font-body:     Arial, "Helvetica Neue", Helvetica, sans-serif;
    --rr-font-display:  "Bebas Neue", "Oswald", Impact, sans-serif;

    --rr-space-1:       0.25rem;
    --rr-space-2:       0.5rem;
    --rr-space-3:       1rem;
    --rr-space-4:       1.5rem;
    --rr-space-5:       2rem;
    --rr-space-6:       3rem;

    --rr-radius:        6px;
    --rr-tap-target:    44px;
}

* { box-sizing: border-box; }

html, body {
    margin: 0;
    padding: 0;
    background-color: var(--rr-white);
    color: var(--rr-text);
    font-family: var(--rr-font-body);
    font-size: 16px;
    line-height: 1.5;
}

a {
    color: var(--rr-purple);
    text-decoration: underline;
    text-underline-offset: 2px;
}
a:hover, a:focus { color: var(--rr-purple-dark); }

h1, h2, h3, h4 {
    color: var(--rr-purple);
    margin: 0 0 var(--rr-space-3);
    line-height: 1.2;
}

h1 { font-size: 2rem; }
h2 { font-size: 1.5rem; }
h3 { font-size: 1.25rem; }

code {
    background: var(--rr-lavender);
    padding: 0 var(--rr-space-1);
    border-radius: 3px;
    font-size: 0.95em;
}

/* ---------- App shell ---------- */

.rr-app {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

.rr-app__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--rr-space-3) var(--rr-space-4);
    border-bottom: 1px solid var(--rr-grey-border);
    background: var(--rr-white);
}

.rr-app__brand {
    text-decoration: none;
    color: var(--rr-purple);
}

.rr-app__brand-mark {
    font-weight: 700;
    font-size: 1.25rem;
    letter-spacing: 0.02em;
}

.rr-app__nav {
    display: flex;
    gap: var(--rr-space-3);
    align-items: center;
}

.rr-app__nav a {
    text-decoration: none;
    min-height: var(--rr-tap-target);
    display: inline-flex;
    align-items: center;
}

.rr-app__main {
    flex: 1 1 auto;
    width: 100%;
    max-width: 56rem;
    margin: 0 auto;
    padding: var(--rr-space-4) var(--rr-space-4) var(--rr-space-6);
    outline: none;
}

.rr-app__footer {
    border-top: 1px solid var(--rr-grey-light);
    color: var(--rr-text-muted);
    text-align: center;
    padding: var(--rr-space-3);
}

/* ---------- Hero / form pages ---------- */

.rr-hero { max-width: 40rem; }
.rr-hero__lede {
    font-size: 1.25rem;
    color: var(--rr-text-muted);
    margin: 0 0 var(--rr-space-4);
}

.rr-form-page {
    max-width: 28rem;
    margin: 0 auto;
}

.rr-form-page__links { margin-top: var(--rr-space-4); }

/* ---------- Buttons & form controls ---------- */

.rr-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: var(--rr-tap-target);
    padding: 0 var(--rr-space-4);
    border: 1px solid var(--rr-grey-border);
    border-radius: var(--rr-radius);
    background: var(--rr-white);
    color: var(--rr-text);
    font: inherit;
    text-decoration: none;
    cursor: pointer;
    margin-right: var(--rr-space-2);
}
.rr-button:hover, .rr-button:focus { border-color: var(--rr-purple); color: var(--rr-purple); }

.rr-button--primary {
    background: var(--rr-purple);
    border-color: var(--rr-purple);
    color: var(--rr-white);
}
.rr-button--primary:hover, .rr-button--primary:focus {
    background: var(--rr-purple-dark);
    border-color: var(--rr-purple-dark);
    color: var(--rr-white);
}

.rr-field {
    display: flex;
    flex-direction: column;
    gap: var(--rr-space-1);
    margin-bottom: var(--rr-space-3);
}

.rr-field--inline { flex-direction: row; align-items: center; }

.rr-field label { font-weight: 600; }

.rr-field input[type="text"],
.rr-field input[type="email"],
.rr-field input[type="password"],
.rr-field input[type="tel"],
.rr-field input[type="url"],
.rr-field input[type="number"],
.rr-field input[type="search"],
.rr-field input[type="date"],
.rr-field input[type="time"] {
    /* Explicit width + box-sizing keeps the row consistent regardless of the
       field's input type — browsers render password / number / time inputs with
       slightly different default metrics, and min-height alone wasn't enough to
       force them to the same visual height as text/email. */
    box-sizing: border-box;
    width: 100%;
    height: var(--rr-tap-target);
    padding: 0 var(--rr-space-3);
    border: 1px solid var(--rr-grey-border);
    border-radius: var(--rr-radius);
    font: inherit;
    line-height: 1.2;
    background: var(--rr-white);
    color: var(--rr-text);
}

.rr-field input:focus {
    outline: 2px solid var(--rr-purple);
    outline-offset: 1px;
    border-color: var(--rr-purple);
}

.rr-checkbox {
    display: inline-flex;
    align-items: center;
    gap: var(--rr-space-2);
    font-weight: 400;
    cursor: pointer;
}

.validation-message { color: var(--rr-error); font-size: 0.95em; }

/* ---------- Alerts ---------- */

.rr-alert {
    border: 1px solid var(--rr-grey-border);
    border-left-width: 4px;
    border-radius: var(--rr-radius);
    padding: var(--rr-space-3);
    margin-bottom: var(--rr-space-3);
    background: var(--rr-grey-light);
}

.rr-alert--error  { border-left-color: var(--rr-error);  background: #FDECEA; }
.rr-alert--warning { border-left-color: var(--rr-warning); background: #FFF6E6; }
.rr-alert--success { border-left-color: var(--rr-success); background: #E8F5E9; }
.rr-alert--info    { border-left-color: var(--rr-info);    background: #E3F2FD; }

/* ---------- Spaces list ---------- */

.rr-spaces { list-style: none; padding: 0; margin: 0; display: grid; gap: var(--rr-space-3); }

.rr-spaces__item { border: 1px solid var(--rr-grey-border); border-radius: var(--rr-radius); }

.rr-spaces__link {
    display: flex;
    flex-direction: column;
    padding: var(--rr-space-3) var(--rr-space-4);
    text-decoration: none;
    color: var(--rr-text);
    min-height: var(--rr-tap-target);
}
.rr-spaces__link:hover, .rr-spaces__link:focus {
    background: var(--rr-lavender);
    color: var(--rr-purple);
}

.rr-spaces__name { font-size: 1.125rem; }
.rr-spaces__meta { color: var(--rr-text-muted); font-size: 0.95em; }

.rr-empty { color: var(--rr-text-muted); }

.rr-app__brand-sub {
    display: block;
    color: var(--rr-text-muted);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

/* ---------- Page header (above content) ---------- */

.rr-page-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--rr-space-3);
    margin-bottom: var(--rr-space-4);
    flex-wrap: wrap;
}

.rr-page-header h1 { margin: 0; }
.rr-page-header__lede { color: var(--rr-text-muted); margin: var(--rr-space-1) 0 0; }

/* ---------- Filter row ---------- */

.rr-filters {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: var(--rr-space-3);
    padding: var(--rr-space-3);
    margin-bottom: var(--rr-space-4);
    background: var(--rr-grey-light);
    border-radius: var(--rr-radius);
}

.rr-filters .rr-field { margin: 0; min-width: 12rem; }

.rr-filters select,
.rr-form-page select {
    min-height: var(--rr-tap-target);
    padding: var(--rr-space-2) var(--rr-space-3);
    border: 1px solid var(--rr-grey-border);
    border-radius: var(--rr-radius);
    background: var(--rr-white);
    font: inherit;
    color: var(--rr-text);
}

/* ---------- Event list ---------- */

.rr-events { list-style: none; padding: 0; margin: 0; display: grid; gap: var(--rr-space-3); }

.rr-events__item { border: 1px solid var(--rr-grey-border); border-radius: var(--rr-radius); }

.rr-events__link {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: var(--rr-space-3);
    align-items: center;
    padding: var(--rr-space-3) var(--rr-space-4);
    text-decoration: none;
    color: var(--rr-text);
    min-height: var(--rr-tap-target);
}

.rr-events__link:hover, .rr-events__link:focus {
    background: var(--rr-lavender);
    color: var(--rr-purple);
}

.rr-events__date {
    display: flex;
    flex-direction: column;
    align-items: center;
    min-width: 4rem;
    line-height: 1.1;
}
.rr-events__day { font-size: 1.6rem; font-weight: 700; color: var(--rr-purple); }
.rr-events__month { font-size: 0.75rem; color: var(--rr-text-muted); text-transform: uppercase; }

.rr-events__body { display: flex; flex-direction: column; gap: var(--rr-space-1); }
.rr-events__title { font-size: 1.05rem; }
.rr-events__meta { color: var(--rr-text-muted); font-size: 0.95em; }

/* ---------- Status / billing badges ---------- */

.rr-badge {
    display: inline-block;
    padding: 0.15rem var(--rr-space-2);
    border-radius: 999px;
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    background: var(--rr-grey-light);
    color: var(--rr-text);
    border: 1px solid var(--rr-grey-border);
}

.rr-badge--proposed   { background: var(--rr-grey-light); color: var(--rr-text); }
.rr-badge--confirmed  { background: #E8F5E9; color: var(--rr-success); border-color: var(--rr-success); }
.rr-badge--cancelled  { background: #FDECEA; color: var(--rr-error);   border-color: var(--rr-error); }
.rr-badge--done       { background: var(--rr-lavender); color: var(--rr-purple); border-color: var(--rr-purple); }

/* ---------- Event detail ---------- */

.rr-event-header { margin-bottom: var(--rr-space-4); }
.rr-event-header__back {
    display: inline-block;
    margin-bottom: var(--rr-space-2);
    font-size: 0.95em;
}
.rr-event-header__top {
    display: flex;
    align-items: center;
    gap: var(--rr-space-3);
    margin-bottom: var(--rr-space-1);
}
.rr-event-header__date { font-size: 1.05rem; color: var(--rr-text-muted); }
.rr-event-header__where { color: var(--rr-text-muted); margin: 0; }

.rr-event-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: var(--rr-space-1);
    border-bottom: 2px solid var(--rr-grey-light);
    margin-bottom: var(--rr-space-4);
    overflow-x: auto;
}

.rr-event-tabs__tab {
    display: inline-flex;
    align-items: center;
    min-height: var(--rr-tap-target);
    padding: 0 var(--rr-space-3);
    text-decoration: none;
    color: var(--rr-text);
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
}

.rr-event-tabs__tab--active {
    color: var(--rr-purple);
    border-bottom-color: var(--rr-purple);
    font-weight: 600;
}

.rr-event-tabs__tab--placeholder {
    color: var(--rr-text-muted);
    cursor: not-allowed;
}

.rr-event-section { margin-bottom: var(--rr-space-5); }

.rr-kv {
    display: grid;
    grid-template-columns: minmax(8rem, max-content) 1fr;
    gap: var(--rr-space-2) var(--rr-space-4);
    margin: 0 0 var(--rr-space-4);
}

.rr-kv dt { color: var(--rr-text-muted); font-weight: 600; }
.rr-kv dd { margin: 0; }

.rr-notes {
    white-space: pre-wrap;
    background: var(--rr-grey-light);
    padding: var(--rr-space-3);
    border-radius: var(--rr-radius);
}

.rr-form-page--wide { max-width: 40rem; }
.rr-form-page--inline { max-width: 32rem; margin: 0 0 var(--rr-space-5); padding: var(--rr-space-3); border: 1px solid var(--rr-grey-border); border-radius: var(--rr-radius); }

.rr-event-header__row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--rr-space-3);
    margin-bottom: var(--rr-space-2);
}

/* ---------- Schedule table ---------- */

.rr-schedule {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: var(--rr-space-4);
}

.rr-schedule th, .rr-schedule td {
    padding: var(--rr-space-2) var(--rr-space-3);
    border-bottom: 1px solid var(--rr-grey-light);
    text-align: left;
    vertical-align: top;
}

.rr-schedule th { color: var(--rr-text-muted); font-weight: 600; font-size: 0.85em; }

.rr-schedule__row--highlight td { background: var(--rr-lavender); }

.rr-schedule__time { white-space: nowrap; font-variant-numeric: tabular-nums; }
.rr-schedule__time--empty { color: var(--rr-text-muted); }
.rr-schedule__notes { color: var(--rr-text-muted); }
.rr-schedule__actions { width: 1%; white-space: nowrap; }

.rr-link {
    background: none;
    border: 0;
    color: var(--rr-purple);
    cursor: pointer;
    font: inherit;
    padding: 0;
    text-decoration: underline;
}

.rr-visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
}

/* ---------- Form rows (paired fields side-by-side) ---------- */

.rr-field-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--rr-space-3);
}

@media (max-width: 640px) {
    .rr-field-row { grid-template-columns: 1fr; gap: 0; }
}

/* ---------- Contacts list ---------- */

.rr-contacts { list-style: none; padding: 0; margin: 0; display: grid; gap: var(--rr-space-3); }

.rr-contacts__item {
    border: 1px solid var(--rr-grey-border);
    border-radius: var(--rr-radius);
    padding: var(--rr-space-3) var(--rr-space-4);
}

.rr-contacts__primary {
    display: flex;
    align-items: baseline;
    flex-wrap: wrap;
    gap: var(--rr-space-2);
}

.rr-contacts__name { font-size: 1.1rem; }

.rr-contacts__role {
    color: var(--rr-purple);
    background: var(--rr-lavender);
    padding: 0 var(--rr-space-2);
    border-radius: 999px;
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.rr-contacts__company { color: var(--rr-text-muted); font-size: 0.95em; }

.rr-contacts__contact { margin-top: var(--rr-space-1); display: flex; gap: var(--rr-space-2); flex-wrap: wrap; }
.rr-contacts__sep { color: var(--rr-text-muted); }

.rr-event-actions {
    display: flex;
    align-items: center;
    gap: var(--rr-space-3);
    margin: var(--rr-space-3) 0 var(--rr-space-4);
}

.rr-event-actions form { margin: 0; }

/* ---------- Links list ---------- */

.rr-links { list-style: none; padding: 0; margin: 0; display: grid; gap: var(--rr-space-3); }

.rr-links__item {
    border: 1px solid var(--rr-grey-border);
    border-radius: var(--rr-radius);
    padding: var(--rr-space-3) var(--rr-space-4);
}

.rr-links__primary {
    display: flex;
    align-items: baseline;
    flex-wrap: wrap;
    gap: var(--rr-space-2);
    text-decoration: none;
    color: var(--rr-text);
}
.rr-links__primary:hover { color: var(--rr-purple); }

.rr-links__kind {
    color: var(--rr-purple);
    background: var(--rr-lavender);
    padding: 0 var(--rr-space-2);
    border-radius: 999px;
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.rr-links__url {
    display: block;
    color: var(--rr-text-muted);
    font-size: 0.9em;
    word-break: break-all;
}

.rr-links__notes { margin: var(--rr-space-1) 0 0; }

/* ---------- Documents list ---------- */

.rr-documents { list-style: none; padding: 0; margin: 0; display: grid; gap: var(--rr-space-2); }

.rr-documents__item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--rr-space-3);
    border: 1px solid var(--rr-grey-border);
    border-radius: var(--rr-radius);
    padding: var(--rr-space-2) var(--rr-space-4);
    min-height: var(--rr-tap-target);
}

.rr-documents__link {
    display: flex;
    flex-direction: column;
    text-decoration: none;
    color: var(--rr-text);
    flex: 1;
}
.rr-documents__link:hover { color: var(--rr-purple); }

.rr-documents__meta { color: var(--rr-text-muted); font-size: 0.9em; }

/* ---------- Map embed ---------- */

.rr-map {
    width: 100%;
    height: 480px;
    border: 1px solid var(--rr-grey-border);
    border-radius: var(--rr-radius);
    margin-bottom: var(--rr-space-3);
}

@media (max-width: 640px) {
    .rr-map { height: 320px; }
}

/* ---------- Crew assignment status badges ---------- */

.rr-badge--pending     { background: var(--rr-grey-light); color: var(--rr-text); }
.rr-badge--unconfirmed { background: #FFF6E6; color: var(--rr-warning); border-color: var(--rr-warning); }
.rr-badge--none        { background: #FDECEA; color: var(--rr-error);   border-color: var(--rr-error); }

/* ---------- Mobile-first refinements ---------- */

@media (max-width: 640px) {
    .rr-app__header { flex-wrap: wrap; gap: var(--rr-space-2); }
    .rr-app__main { padding: var(--rr-space-3); }
    .rr-button { width: 100%; margin-right: 0; margin-bottom: var(--rr-space-2); }
    .rr-button + .rr-button { margin-left: 0; }
}
