:root {
    --bg--page: #e5e5e5;
    --color-text: var(--color-primary);
    --color-primary: hsla(219, 52%, 26%, 1);
    --margin-title: var(--margin-inner);
    --color-button: var();
    --color-button: var();
    --color-button: var(--color-primary);
    --color-text-dim: hsla(219, 10%, 55%, 1);
    --border-hr: 1px solid #E5E5E5;
    --margin: 2rem;
    --bg-success: hsla(152, 61%, 89%, 1);
    --bg-highlight: hsla(205, 100%, 96%, 1);
    --bg-error: hsla(344, 100%, 93%, 1);
    --margin-mini: 4px;
    --color-grey: hsla(0, 0%, 90%, 1);
    --bg-alternative: var(--);
    --bg-alternative: var(--white);
    --font-family-text: Inter, Roboto, Arial, sans-serif;
    --font-family-heading: Outfit, Arial, sans-serif;
    --font-text: 400 1rem/1.5rem var(--font-family-text);
    --font-h2: 500 2.25rem/2.625rem var(--font-family-heading);
    --letter-spacing-h2: -0.045rem;
    --font-h3: 600 1.5rem/1.75rem var(--font-family-heading);
    --letter-spacing-h3: -0.015rem;
    --font-caption: 400 var(--font-size-caption)/1.3333 var(--font-family-text);
    --letter-spacing-caption: -0.03rem;
    --font-size-caption: clamp(1.25rem, 0.9783rem + 1.087vw, 1.5rem);
    --padding-inline-main: clamp(1rem, -0.25rem + 3.333vw, 2.75rem);
    --content-max-width: 1024px;
    --details__label-width: 160px;
    --margin-inner: 8px;
    --margin-caption: 12px;
    --margin-inline: 10px;
    --margin-card: 16px;
    --margin-elements: 32px;
    --button-color: var(--ui-colors-white-0);
    --button-background: var(--ui-colors-blue-600);
    --button-padding-inline: 20px;
    --button-padding-block: 12px;
    --button-large-padding-inline: 32px;
    --button-large-padding-block: 16px;
    --button-small-padding-inline: 16px;
    --button-small-padding-block: 8px;
    --layout-bg-accent: var(--ui-colors-lavender-100);
    --layout-bg-main: var(--ui-colors-grey-10);
    --layout-bg-highlight: var(--ui-colors-lavender-50);
    --text-color: var(--ui-colors-blue-600);
    --ui-colors-white-0: var(--base-colors-primary-white);
    --ui-colors-blue-600: var(--base-colors-primary-blue);
    --ui-colors-blue-200: #bacdee;
    --ui-colors-lavender-100: var(--base-colors-primary-lavender);
    --ui-colors-lavender-50: #ebf7ff;
    --ui-colors-orange-400: var(--base-colors-primary-orange);
    --ui-colors-orange-20: #fff0ed;
    --ui-colors-pink-400: var(--base-colors-secondary-pink);
    --ui-colors-pink-50: #ffdde6;
    --ui-colors-grey-50: var(--base-colors-secondary-grey);
    --ui-colors-grey-20: #f2f2f6;
    --ui-colors-grey-10: #f9fafb;
    --ui-colors-green-400: #198754;
    --ui-colors-green-50: #d4f4e5;
    --ui-colors-red-400: #da3d21;
    --ui-colors-red-100: #f3baaf;
    --base-colors-primary-white: #ffffff;
    --base-colors-primary-blue: #213862;
    --base-colors-primary-lavender: #d7e8f4;
    --base-colors-primary-orange: #ff6647;
    --base-colors-secondary-pink: #e74f77;
    --base-colors-secondary-grey: #e5e5e5;
    --main-margin: 2rem;
    --layout-margin: 1.25rem;
    --margin-sections: 2rem;
}

@font-face {
    font-family: "Inter";
    src: url("/Inter/Inter-VariableFont_slnt,wght.ttf");
    font-weight: 125 950;
    font-stretch: 75% 125%;
    font-style: normal;
}

@font-face {
    font-family: "Outfit";
    src: url("/Outfit/Outfit-VariableFont_wght.ttf");
    font-weight: 125 950;
    font-stretch: 75% 125%;
    font-style: normal;
}


html {
    background: var(--bg--page, #F2F2F6);
}

body {
    padding: 0;
    margin: 0;
    color: var(--color-text);
    font-family: var(--font-family-text);

    /* 150% */
    font-size: 1rem;
    min-height: 100%;
}

.button {
    border-radius: 10px;
    background: var(--background);
    color: white;
    text-decoration: none;
    padding: var(--padding-block) var(--padding-inline);
    font-weight: 700;
    cursor: pointer;
    font-size: 1rem;
    font-family: inherit;
    display: inline-block;
    text-align: center;
    --padding-inline: 1.25rem;
    --padding-block: 0.75rem;
    --background: var(--color-primary);
    border: none;
}

.button--caption {
    float: right;
    border-radius: 6.25rem;
    height: 1.5rem;
    font-size: 0.8125rem;
    line-height: 1;
    margin-top: -.25rem;
    display: flex;
    align-items: center;
    padding: 0 var(--margin-inline, 10px);
    text-transform: none;
}

.text-caption {
    font-family: Inter;
    font-size: 0.875rem;
    font-style: normal;
    font-weight: 700;
    line-height: 1rem;
    /* 114.286% */
    letter-spacing: 0.02625rem;
    text-transform: uppercase;
    margin-block: 0 var(--margin-caption);
    color: inherit;
}

.title {
    margin-block: var(--layout-margin);
    font: var(--font-h2);
    letter-spacing: var(--letter-spacing-h2);
}

.title__caption {}

.title__title {
    margin-block: var(--margin-mini);
    font: var(--font-h2);
    letter-spacing: var(--letter-spacing-h2);
}

main {
    padding-inline: var(--main-margin);
    background: #f5f5f5;
    contain: layout;
    border-start-start-radius: 1rem;
    width: auto;
}

main::before {
    margin-top: var(--main-margin);
    display: block;
    content: ' ';
}

main::after {
    margin-bottom: var(--main-margin);
    display: block;
    content: ' ';
}

.card-grid {
    display: flex;
    max-width: var(--content-max-width);
    align-items: flex-start;
    align-content: flex-start;
    gap: var(--margin-sections);
    flex-wrap: wrap;
}


.card {
    padding-inline: var(--margin-card);
    background: #FFF;
    border-radius: var(--margin-inline);
    --margin: var(--margin-card);
    overflow: hidden;
    color: var(--color-text);
    position: relative;
    --max-width: unset;
    max-width: var(--max-width);
}

.card-grid__column {
    display: flex;
    min-width: 300px;
    max-width: 450px;
    flex-direction: column;
    gap: var(--margin-sections);
    flex: 1 0 0;
}

.details {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: var(--margin-inner);
    margin-block: var(--margin);
}

.card-grid__column--wide {
    max-width: unset;
}

.details__value {
    margin: 0;
    min-width: 100px;
    word-wrap: break-word;
    white-space: pre-line;
}

.details__label {
    color: var(--color-text-dim);
}

.hintaerittely {
    width: 100%;
    margin-block: var(--margin);
}

.hintaerittely__cell {
    padding-block: var(--padding-block);
    border-bottom: var(--border-bottom);
}

.hintaerittely__cell--hinta {
    text-align: right;
}

.hintaerittely__cell--nimi {
    color: var(--color-text-dim);
}

.hintaerittely__yhteensä {
    padding: var(--margin-card) 0 0;
}

td.hintaerittely__row.hintaerittely__row--first.hintaerittely__row--last.hintaerittely__row--nimi {}

.hintaerittely__yhteensä--nimi {
    text-align: left;
    color: var(--color-text-dim);
}

.hintaerittely__yhteensä--hinta {
    text-align: right;
}

.card::before {
    content: '';
    display: block;
    margin-bottom: var(--margin-card);
}

.card::after {
    content: '';
    display: block;
    margin-top: var(--margin-card);
}

.button-row {
    display: flex;
    gap: var(--margin);
    --margin-block: var(--margin);
    margin-block: var(--margin-block);
}

.button--secondary {
    background: transparent;
    border: 1px solid;
    color: var(--color-text);
    font-weight: normal;
}

.hintaerittely__row {
    --padding-block: calc(var(--margin-inner) / 2);
    --border-bottom: var(--border-hr);
}

.hintaerittely__row:first-of-type {
    --padding-block: 0 calc(var(--margin-inner) / 2);
}

.hintaerittely__row:last-of-type {
    --border-bottom: none;
    --padding-block: calc(var(--margin-inner) / 2) 0;
}

.input--hintaerittely {
    text-align: right;
    width: 15ch;
}

.status {
    padding: var(--margin);
    background: var(--bg-highlight);
    font-weight: 700;
}

.status--card-header {
    margin: calc(var(--margin) * -1) !important;
    margin-bottom: 0 !important;
}

.status--success {
    background: var(--bg-success);
}

.status--error {
    background: var(--bg-error);
}

.pill {
    border-radius: 10rem;
    height: 1.5rem;
    font-size: 0.8125rem;
    margin-block: -0.25rem;
    display: flex;
    align-items: center;
    padding: 0 var(--margin-inline, 10px);
    text-transform: none;
    background: var(--bg-success);
}

.link {
    color: inherit;
}

.breadcrumb {
    margin: var(--margin) 0;
    padding: 0;
    display: flex;
    gap: var(--margin-inner);
    margin-bottom: calc(var(--margin) - var(--margin-title));
}

.breadcrumb__item {
    display: block;
}

.breadcrumb__item:not(:first-child) {
    --before:
        '/';
}

.breadcrumb__item::before {
    content: var(--before);
    margin-right: var(--margin-inner);
}

.login {
    background: var(--color-primary);
    --content-max-width: 25rem;
    --color-text: white;
    text-align: center;
    padding-inline: var(--margin);
}

.login__logo {
    height: 4.5rem;
    margin: var(--margin-title) auto;
    display: block;
}

.login__card {
    text-align: center;
    --color-text: var(--color-primary);
    margin: auto;
    --max-width: var();
    --max-width: 25rem;
}

.login__label {
    display: block;
    text-align: left;
    margin-block: var(--margin);
}

.login__form {
    margin-bottom: var(--margin-sections);
}

.input--full-width {
    width: 100%;
    box-sizing: border-box;
}

.h2 {
    font-family: var(--font-family-heading);
    font-size: 2.25rem;
    font-style: normal;
    font-weight: 500;
    line-height: 2.625rem;
    /* 116.667% */
    letter-spacing: -0.045rem;
}

h3,
.h3 {
    font-family: var(--font-family-heading);
    font-size: 1.5rem;
    font-style: normal;
    font-weight: 600;
    line-height: 1.75rem;
    /* 116.667% */
    letter-spacing: -0.015rem;
}

.input--textarea {
    box-sizing: border-box;
    max-width: 100%;
    min-height: 3rem;
    min-width: 20ch;
}

.input--wide {
    width: 100%;
    box-sizing: border-box;
}

.button-row--title {
    --margin: var(--main-margin);
}

.login__sso-done {
    display: none;
    margin-block: var(--margin-card);
}

.login__sso:focus-within .login__sso-done {
    display: block;
}

.button:disabled {
    opacity: 0.65;
    cursor: initial;
    box-shadow: none;
}

.button--pill {
    background: var(--bg-highlight);
    border-color: var(--primary);
    color: var(--text-color);
}

.button--pill-active {
    background: var(--color-primary);
    color: white;
}

.tilaukset__row--empty {
    --bg: transparent;
}

.display {
    font-family: var(--font-family-heading);
    font-size: clamp(2rem, 0.913rem + 4.3478vw, 3rem);
    font-style: normal;
    font-weight: 600;
    line-height: 3.375rem;
    /* 112.5% */
    letter-spacing: -0.06rem;
    margin-block: 5rem;
}

.title__subtitle {
    font: var(--font-caption);
    letter-spacing: var(--letter-spacing-caption);
}

.app__footer {
    margin-block: var(--margin);
}

.select-button {
    border-radius: 10px;
    font: inherit;
    color: white;
    font-weight: 700;
    box-shadow: var(--shadow);
    display: flex;
    position: relative;
    align-items: center;
}

.select-button__select {
    padding-block: var(--margin-inner);
    display: block;
    border: none;
    color: inherit;
    font: inherit;
    font-weight: inherit;
    appearance: none;
    border-radius: inherit;
    padding: 0.75rem 1.25rem;
    background: var(--color-button);
    color: white;
    align-self: stretch;
    cursor: pointer;
}


.select-button::after {
    content: '▼';
    position: absolute;
    right: var(--margin-inline);
    font-size: 0.75em;
    pointer-events: none;
}

.select-button__submit {
    position: absolute;
    top: calc(100% + var(--margin-inner));
    left: 50%;
    transform: translateX(-50%);
    display: var(--button-display, none);
}

.select-button:not(.select-button--submitted):not(:has(:checked:default)) {
    --button-display: block;
}


.button.button--primary {
    background-color: var(--color-primary);
    border-color: var(--color-primary);
    color: white;
}

.card-list {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: var(--margin-card);
    padding: 0;
    list-style: none;
    align-items: stretch;
}

.text--tight {
    margin-block: var(--margin-inner);
}

.card__open-icon {
    float: right;
    display: block;
    text-decoration: none;
    color: var(--color-text-dim);
    font-weight: 900;
    width: 1em;
    height: 1em;
    background: url(/share.svg);
    background-position: center;
    background-repeat: no-repeat;
}

.text--muted {
    color: var(--color-text-dim);
}

.button--full-width {
    width: 100%;
}

.button--mini {
    margin: var(--margin-inner) var(--margin-inline);
    border-radius: 6.25rem;
    height: 1.5rem;
    font-size: 0.8125rem;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    padding: 0 var(--margin-inline, 10px);
    text-transform: none;
}

.card-grid__column--center {
    flex-basis: 100%;
    margin: auto;
}

.details--inverted {
    grid-template-columns: 2fr 1fr;
}

.margin-block {
    margin-block: var(--margin);
}

.margin-inner {
    margin-block: var(--margin-inner);
}

.button-row--center {
    justify-content: center;
}

.layout__header {
    margin: var(--margin);
    grid-area: logo;
}

.layout__sidebar {
    grid-area: sidebar;
}

.layout__logo-link {
    display: block;
    height: 2.625rem;
    margin: var(--layout-margin);
    margin-block-end: calc(var(--layout-margin) + var(--main-margin));
}

.layout__logo {
    display: block;
    height: 100%;
}

.sidebar {
    list-style: none;
    padding: 0;
    margin: 0;
}

.sidebar__link {
    text-decoration: none;
    font-weight: 600;
    color: var(--color-text-dim);
    padding-inline: var(--layout-margin);
    padding-block: calc(var(--layout-margin) / 2);
    display: block;
    border-radius: 0 .625rem .625rem 0;
}

.sidebar__item {}

.sidebar__link--active-parent {
    color: var(--color-text);
}

html {
    height: 100%;
}

.layout {
    display: grid;
    grid-template-areas:
        'sidebar main'
        'footer main';
    grid-auto-flow: row;
    grid-template-columns: max-content 1fr;
    gap: var(--main-margin);
    grid-template-rows: 1fr;
}

.layout__main {
    grid-area: main;
    display: grid;
    grid-auto-flow: row;
    grid-template-rows: min-content 1fr;
}

.sidebar__link--active-page,
.sidebar__link--highlight-active[aria-current=page] {
    color: var(--color-text);
    background: var(--bg-highlight);
}

.button--large {
    --padding-inline: 2rem;
    --padding-block: 1rem;
}


.card--fit {
    --max-width: max-content;
}

.card-list__card-bottom {
    margin-block-end: var(--margin-card);
}

.card-list__card {
    padding-inline: var(--margin-card);
    background: #FFF;
    border-radius: var(--margin-inline);
    --margin: var(--margin-card);
    color: var(--color-text);
    position: relative;
    display: flex;
    flex-direction: column;
}

.card-list__card-main::before {
    content: '';
    display: block;
    margin-bottom: var(--margin-card);
}

.card-list__card-main::after {
    content: '';
    display: block;
    margin-top: var(--margin-card);
}


.card-list__card-main {
    flex: 1;
}

.section {
    margin-block-start: var(--margin-sections);
}

.section-title {
    font: var(--font-h3);
    letter-spacing: var(--letter-spacing-h3);
    margin-block-start: var(--margin-elements);
}

.sidebar__link--icon {
    display: grid;
    grid-template-columns: max-content 1fr;
    gap: 0.75rem;
}

.dialog {
    border: none;
    border-radius: var(--margin-card);
    box-shadow: 0 0.5rem 1.25rem 0.5rem hsl(0 0% 40% / 1);
    padding: 0 var(--padding);
    --padding: 2rem;
    color: var(--text-color);
}

.input {
    font-size: inherit;
    font-family: inherit;
}

.dialog__section {
    margin-block: calc(var(--padding) / 2);
}

.dialog__inner {
    margin-block: var(--padding);
}

.cover {
    text-align: center;
}

.cover__img {
    height: 30rem;
    width: auto;
}

.text--pre-line {
    white-space: pre-line;
}

.status-pill {
    display: inline-block;
    padding: 0.25rem 0.75rem;
    border-radius: 1rem;
    font-size: 0.875rem;
    background: var(--bg-color);
    color: var(--color-text);
}

.status-pill--active {
    --bg-color: var(--bg-success);
    --color-text: var(--ui-colors-green-400);
}

.status-pill--ended {
    --bg-color: var(--bg-error);
    --color-text: var(--ui-colors-red-400);
}

.status-pill--signed {
    --bg-color: var(--ui-colors-blue-200);
    --color-text: var(--ui-colors-blue-600);
}

.status-pill--paused {
    --bg-color: var(--ui-colors-orange-20);
    --color-text: var(--ui-colors-orange-400);
}

/* Add new unified table styles */
.table {
    margin: 0;
    border: none;
    border-collapse: collapse;
    width: 100%;
    margin-inline: calc(var(--margin-inline) * -1);
}

.table__cell {
    padding: 0.75rem 1rem;
}

.table__row {
    background: var(--bg, white);
    position: relative;
}

.table__row:nth-of-type(2n) {
    --bg: transparent;
}

.table__row:hover {
    --bg: var(--bg-highlight);
}

.table__head {
    --padding-block: 0 var(--margin-caption);
}

/* For cells that should be right-aligned (like prices) */
.table__cell--right {
    text-align: right;
}

/* For status pills/badges */
.table__cell--status {
}

/* For cells containing dates/times */
.table__cell--datetime {
    text-align: right;
}

/* For creating clickable rows with links */
.table__link {
    color: var(--color-primary);
    text-decoration: none;
}

.table__link::before {
    position: absolute;
    content: '';
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
}

/* For empty state rows */
.table__row--empty {
    --bg: transparent;
}