﻿.account-menu {
    align-items: center;
    justify-content: flex-end;
    position: relative;
    gap: 0.5em;
    z-index: 10;
}

.account-menu__image {
    display: block;
    width: 2em;
    height: auto;
    border-radius: var(--rounded-full);
    transition: .4s var(--transition-timing-bounce);
    transition-property: transform;
    background: var(--color-green-100);
    padding: 0.5em;
}

    .account-menu__image + svg {
        transition: .4s var(--transition-timing-bounce);
        transition-property: opacity, visibility, transform;
    }

.account-menu__dropdown {
    --flow-space: var(--size-200);
    position: absolute;
    top: 100%;
    right: 0;
    background: var(--color-green-700);
    color: var(--color-green-100);
    border-radius: var(--rounded-xl);
    padding: var(--size-400);
    min-width: min(18rem, 100vw);
    transform: scale(0);
    visibility: hidden;
    opacity: 0;
    transform-origin: top right;
    transition: .4s var(--transition-timing-bounce);
    transition-property: opacity, visibility, transform;
}

    .account-menu__dropdown li {
        border-top: 1px solid var(--color-green-600);
        padding-top: var(--flow-space, var(--size-400));
    }

        .account-menu__dropdown li svg {
            flex: none;
            display: block;
            width: 1em;
            height: auto;
        }

        .account-menu__dropdown li a {
            display: flex;
            align-items: center;
            gap: 0.5em;
            text-decoration: none;
            transition: .4s var(--transition-timing-ease-in-out);
            transition-property: opacity;
            cursor: pointer;
        }

            .account-menu__dropdown li a:hover {
                opacity: 0.6;
            }

.account-menu:hover .account-menu__image {
    transform: scale(0.9);
}

    .account-menu:hover .account-menu__image + svg {
        transform: rotate(180deg);
    }

.account-menu:hover .account-menu__dropdown {
    visibility: visible;
    opacity: 1;
    transform: none;
}

.main-nav__menu {
    --flow-space: var(--size-200);
}

    .main-nav__menu summary {
        list-style: none;
    }

        .main-nav__menu summary::-webkit-details-marker {
            display: none;
        }

.main-nav__items {
    gap: 0;
    align-items: inherit;
}

    .main-nav__items li a {
        display: flex;
        align-items: center;
        gap: 0.5em;
        text-decoration: none;
        padding: 0.5em 1em;
        border-radius: var(--rounded-default);
        transition: .4s var(--transition-timing-ease-in-out);
        transition-property: background;
    }

        .main-nav__items li a svg {
            height: 1em;
            width: auto;
            display: block;
            flex: none;
            transition: .4s var(--transition-timing-bounce);
            transition-property: transform;
        }

        .main-nav__items li a:hover {
            background: var(--color-off-white);
        }

            .main-nav__items li a:hover svg {
                transform: scale(1.25);
            }

        .main-nav__items li a[aria-current="page"] {
            font-weight: var(--font-bold);
            background: var(--color-green-50);
        }

            .main-nav__items li a[aria-current="page"] svg path {
                fill: currentColor;
            }

.site-header {
    position: sticky;
    top: 0;
    left: 0;
    width: 100%;
    row-gap: var(--size-200);
    align-items: center;
    background: var(--color-white);
    z-index: 100;
    padding: var(--size-200) var(--size-400);
    box-shadow: var(--shadow-default);
}

.site-header__divider {
    border: 1px solid var(--color-green-300);
    align-self: stretch;
    transform: scaleY(50%);
    opacity: 0.2;
}

.site-header__navigation {
    display: block;
    width: 100%;
    flex: 1;
}

.title-bar {
    justify-content: space-between;
    align-items: flex-end;
}

    .title-bar .stack {
        gap: var(--size-200);
    }

.inline-alert {
    position: relative;
    align-items: center;
    padding: var(--size-200);
    gap: var(--size-200);
    border: 1px solid var(--color-green-100);
    border-radius: var(--rounded-xl);
    background: var(--color-green-50);
    z-index: 10;
    color: var(--color-green-700);
}

.inline-alert__content {
    flex: 1;
}


.callout-box {
    position: relative;
    text-align: center;
    padding: var(--size-400);
    border: 1px solid var(--color-green-100);
    border-radius: var(--rounded-xl);
    z-index: 10;
    background-color: var(--color-green-700);
    color: var(--color-green-100);
}

.button {
    appearance: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5em;
    padding: 0.5em 1em;
    font-weight: var(--font-bold);
    background: var(--color-green-700);
    color: var(--color-white);
    line-height: var(--leading-none);
    border-radius: var(--rounded-default);
    border: 1px solid rgba(0, 0, 0, 0.1);
    cursor: pointer;
    text-decoration: none;
    padding: 0.75em 1.25em;
    transition: .4s ease-in-out;
    transition-property: color, background, border-color;
}

    .button svg {
        height: 1em;
        width: auto;
    }

    .button:not([disabled]):hover {
        background: var(--color-green-100);
        color: var(--color-green-700);
    }

    .button[disabled] {
        cursor: not-allowed;
        opacity: 0.6;
    }

    .button[size="utility"] {
        font-size: var(--text-300);
        padding: 0.35em 0.75em;
    }

    .button[variant="outline"] {
        color: inherit;
        background: none;
        border-color: currentColor;
    }

        .button[variant="outline"]:hover {
            background: var(--color-green-800);
            border-color: var(--color-green-800);
            color: var(--color-green-200);
        }

    .button[variant="destructive"] {
        background: var(--color-red-100);
        color: var(--color-red-700);
    }

        .button[variant="destructive"]:hover {
            background: var(--color-red-900);
            color: var(--color-red-100);
        }

    .button[variant="light"] {
        background: var(--color-green-100);
        color: var(--color-green-700);
    }

        .button[variant="light"]:hover {
            background: var(--color-green-900);
            color: var(--color-green-100);
        }

button:focus,
.button:focus {
    outline: 2px solid var(--color-green-600);
    outline-offset: 2px;
    --tw-ring-color: transparent;
    --tw-ring-shadow: 0 0 #0000;
    --tw-ring-offset-shadow: 0 0 #0000;
    box-shadow: none;
}

ul li > .button {
    width: 100%;
}

.definition-list {
    display: grid;
}

.definition-list__item {
    --flow-space: var(--size-200);
    align-items: flex-start;
    padding: var(--size-200) 0;
    gap: var(--size-200) var(--size-600);
}

    .definition-list__item svg {
        width: auto;
        height: 0.75em;
        transition: .4s var(--transition-timing-bounce);
        transition-property: transform;
    }

    .definition-list__item[open] svg {
        transform: rotate(180deg);
    }

    .definition-list__item:first-child {
        padding-top: 0;
    }

    .definition-list__item:last-child {
        padding-bottom: 0;
    }

    .definition-list__item + .definition-list__item {
        border-top: 1px solid var(--color-green-100);
    }

.definition-list dt {
    margin-right: auto;
}

.definition-list dd {
    display: inline-flex;
    flex-direction: inherit;
    justify-content: flex-end;
    align-items: inherit;
    gap: var(--size-200);
    color: var(--color-green-700);
    font-weight: var(--font-medium);
}

ul > li + li > accordion-item > .accordion-item {
    border-top: 1px solid var(--color-green-100);
    padding-top: var(--flow-space, var(--size-400));
}

.accordion-item > summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    column-gap: 1em;
    list-style: none;
    cursor: pointer;
}

.accordion-item[disabled] summary {
    pointer-events: none; /* prevents click events */
}

.accordion-item > summary h3 {
    font-weight: var(--font-bold);
    color: var(--color-green-700);
}

.accordion-item > summary > svg {
    height: 1em;
    width: auto;
    flex: none;
    transition: .4s var(--transition-timing-bounce);
    transition-property: transform;
}

.accordion-item[open] > summary > svg {
    transform: rotate(180deg);
}

.accordion-item summary::-webkit-details-marker {
    display: none;
}
/* Style for disabled anchor tags */                                  
a.disabled {                                                          
  /* Change the cursor to indicate it's not clickable */              
  cursor: not-allowed;                                                
                                                                      
  /* Prevent mouse events (like clicks) from triggering */            
  pointer-events: none;                                               
                                                                      
  /* Make the link appear dimmer */                                   
  opacity: 0.6; /* You can adjust this value (e.g., 0.5, 0.7) */      
                                                                      
  /* Optional: Remove underline if desired for disabled links */      
  /* text-decoration: none; */                                        
                                                                      
  /* Optional: Set a specific color for disabled links */             
  /* color: grey; */                                                  
}                                                                     
                                                                                
.group-box {
    position: relative;
    border-radius: var(--rounded-3xl);
    overflow: hidden;
    box-shadow: var(--shadow-default);
    background: var(--color-green-50);
    transition: .4s var(--transition-timing-ease-in-out);
    transition-property: transform;
    padding: var(--size-100);
}

.group-box__header {
    align-items: center;
    gap: 0.75em;
    background: var(--color-green-50);
    padding: var(--size-300) var(--size-400);
    font-size: var(--text-500);
    color: var(--color-green-700);
}

.group-box .group-box .group-box__header {
    font-size: var(--text-400);
}

.group-box__header .icon {
    align-self: flex-start;
}

.group-box__title {
    --flow-space: var(--size-100);
    flex: 1;
    margin-right: auto;
    overflow: hidden;
    padding: 0.25em 0;
}

    .group-box__title details summary {
        list-style: none;
        display: flex;
        align-items: center;
        justify-content: space-between;
        cursor: pointer;
    }

    .group-box__title details > summary::-webkit-details-marker {
        display: none;
    }

    .group-box__title details summary svg {
        height: 1.5em;
        width: auto;
        transition: .4s var(--transition-timing-bounce);
        transition-property: transform;
    }

    .group-box__title details[open] summary svg {
        transform: rotate(-90deg);
    }

    .group-box__title details p {
        font-size: var(--text-400);
    }

.group-box__heading {
    font-size: inherit;
}

.group-box__inner p {
    word-break: break-word;
    /* overflow-wrap: break-word; */
    white-space: normal;
}

.margin1rem {
    margin: 1rem;
}

.margintop1rem {
    margin-top: 1rem;
}

.marginbottom1rem {
    margin-bottom: 1rem;
}
.marginbottomhalfrem {
    margin-bottom: .5rem;
}

.alert-box {
    align-items: flex-start;
    position: relative;
    padding: var(--size-400);
    border: 1px solid var(--color-green-100);
    border-radius: var(--rounded-xl);
    background: var(--color-green-50);
    z-index: 10;
}

    .alert-box h2 {
        margin-top: 0.4em;
    }

        .alert-box h2 + p {
            --flow-space: var(--size-100);
        }

    .alert-box .button {
        --flow-space: var(--size-400);
    }

    .alert-box[data-status="error"] {
        background: var(--color-red-50);
        color: var(--color-red-700);
        border-color: var(--color-red-100);
    }

    .alert-box[data-status="warning"] {
        background: var(--color-white);
        color: var(--color-red-700);
        border-color: var(--color-white);
    }

    .alert-box[data-status="normal"] {
        background: var(--color-green-50);
        color: var(--color-green-700);
        border-color: var(--color-green-100);
    }

.site-footer {
    --flow-space: var(--size-600);
    background: var(--color-green-900);
    color: var(--color-white);
    padding: var(--size-800) var(--size-400);
  }

  .site-footer__nav {
    --flow-space: var(--size-100);
    justify-content: center;
  }

  .site-footer__nav li a {
    text-decoration: none;
  }

  .site-footer h3 + nav {
    --flow-space: var(--size-200);
  }

  .site-footer h3 + p {
    --flow-space: var(--size-200);
  }

.site-footer h3 + p + p{
    --flow-space: var(--size-200);
  }

  .site-footer__logo {
    max-width: 17%;
    color: var(--color-green-400);
  }

  .site-footer__logo svg {
    display: block;
    width: 100%;
    height: auto;
  }.site-frame {
    --flow-space: var(--size-600);
    display: grid;
    width: 100%;
    grid-template-columns: 100%;
}

.site-frame__inner {
    padding: var(--size-400);
}

.site-frame__main {
    width: 100%;
    background: var(--color-white);
}

.site-frame__sidebar {
    color: var(--color-green-700);
    padding: var(--size-400);
}

    .site-frame__sidebar > *:last-child {
        margin-top: auto;
    }
/* Box sizing rules */
*,
*::before,
*::after {
    box-sizing: border-box;
}

/* Remove default margin */
body,
h1,
h2,
h3,
h4,
h5,
h6,
p,
figure,
blockquote,
dl,
dd {
    margin: 0;
}

/* Remove list styles on ul, ol elements with a list role, which suggests default styling will be removed */
:where(ul, ol)[role="list"],
:where(ul, ol)[role="tablist"] {
    list-style: none;
    padding: 0;
    margin: 0;
}

/* Set core root defaults */
html:focus-within {
    scroll-behavior: smooth;
}

/* Set core body defaults */
body {
    text-rendering: optimizeSpeed;
    line-height: 1.5;
}

/* A elements that don't have a class get default styles */
a:not([class]) {
    text-decoration-skip-ink: auto;
}

/* Make images easier to work with */
img,
picture {
    max-width: 100%;
    display: block;
}

/* Inherit fonts for inputs and buttons */
input,
button,
textarea,
select {
    font: inherit;
}

/* Remove all animations, transitions and smooth scroll for people that prefer not to see them */
@media (prefers-reduced-motion: reduce) {
    html:focus-within {
        scroll-behavior: auto;
    }

    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
}

.breakout-button {
    position: static;
}

    .breakout-button,
    .breakout-button::before {
        cursor: pointer;
    }

        .breakout-button::before {
            content: "";
            display: block;
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
        }

.visually-hidden {
    display: block;
    height: 1px;
    width: 1px;
    overflow: hidden;
    clip: rect(1px 1px 1px 1px);
    clip: rect(1px, 1px, 1px, 1px);
    clip-path: inset(1px);
    white-space: nowrap;
    position: absolute;
}

.wrapper {
    display: grid;
    grid-template-columns: [full-start] 1fr [wrapper-start] minmax(0, 72rem) [wrapper-end] 1fr [full-end];
    gap: 0 var(--size-400);
    margin: 0 auto;
}

    .wrapper > * {
        grid-column: var(--wrapper-column, wrapper);
    }

html {
    color: var(--color-gray-900);
}

.ds {
    position: relative;
    background: var(--color-white);
}

.ds__header {
    position: relative;
    z-index: 10;
    padding: var(--size-400);
    box-shadow: var(--shadow-default);
}

    .ds__header h1 a {
        text-decoration: none;
    }

.ds__body {
    display: grid;
    min-height: 100vh;
}

@media (min-width:1024px) {
    .ds__body {
        grid-template-columns: 20rem 1fr;
    }
}

.ds__sidebar {
    background: var(--color-green-50);
    overflow-y: auto;
    padding: var(--size-400);
    font-weight: var(--font-medium);
}

    .ds__sidebar h1 a {
        text-decoration: none;
    }

    .ds__sidebar ul li a,
    .ds__sidebar ul li summary {
        width: 100%;
        display: flex;
        align-items: center;
        justify-content: space-between;
        text-decoration: none;
        padding: 0.25em 0.5em;
        border-left: 4px solid transparent;
        cursor: pointer;
    }

        .ds__sidebar ul li summary::-webkit-details-marker {
            display: none;
        }

        .ds__sidebar ul li summary a {
            padding: 0;
        }

        .ds__sidebar ul li summary svg {
            width: 1.25em;
            height: auto;
            transition: .4s ease-in-out;
            transition-property: transform;
        }

    .ds__sidebar ul li details[open] > summary > svg {
        transform: rotate(45deg);
    }

    .ds__sidebar ul > li > ul {
        padding-left: 1.5em;
    }

    .ds__sidebar > ul > li > ul {
        font-size: 90%;
    }

        .ds__sidebar > ul > li > ul > li > ul {
            color: var(--color-green-700);
        }

    .ds__sidebar ul li a.active {
        background: var(--color-white);
        color: var(--color-green-700);
        font-weight: var(--font-medium);
        box-shadow: var(--shadow-sm);
        border-color: currentColor;
    }

.ds__main {
    padding: var(--size-400);
    overflow-y: auto;
}

.breadcrumbs a {
    text-decoration: none;
}

ol.breadcrumbs__list {
    font-size: var(--text-300);
    gap: 0;
}

.breadcrumbs li:after {
    content: "/";
    margin: 0 .25rem;
    opacity: .5;
}

.breadcrumbs li:last-child:after {
    content: none;
}

.grid {
    gap: var(--size-400);
}

.stack {
    display: flex;
    gap: var(--size-400);
    flex-wrap: wrap;
}

.padding-left-10px {
    padding-left: .625rem;
}

.flow > * + * {
    margin-top: var(--flow-space, var(--size-400));
}

.flow > form > * + * {
    margin-top: var(--flow-space, var(--size-400));
}

.flow > .status-label {
    margin-top: var(--small-space, var(--size-200)); /* Use a smaller default value */
}

.language-bash code:before {
    color: #aaa;
    content: '~/your_project $ ';
}

/**
 * a11y-dark theme for JavaScript, CSS, and HTML
 * Based on the okaidia theme: https://github.com/PrismJS/prism/blob/gh-pages/themes/prism-okaidia.css
 * @author ericwbailey
 */

pre[class*='language-'] {
    display: block;
    width: 100%;
}

code[class*='language-'],
pre[class*='language-'] {
    color: #f8f8f2;
    background: none;
    font-family: Consolas, Monaco, 'Andale Mono', 'Ubuntu Mono', monospace;
    text-align: left;
    white-space: pre;
    word-spacing: normal;
    word-break: normal;
    word-wrap: normal;
    line-height: 1.5;
    -moz-tab-size: 4;
    -o-tab-size: 4;
    tab-size: 4;
    -webkit-hyphens: none;
    -moz-hyphens: none;
    -ms-hyphens: none;
    hyphens: none;
}

/* Code blocks */
pre[class*='language-'] {
    padding: 1em;
    margin-bottom: 2rem;
    overflow: auto;
    border-radius: 0.3em;
}

:not(pre) > code[class*='language-'],
pre[class*='language-'] {
    background: #2b2b2b;
}

/* Inline code */
:not(pre) > code[class*='language-'] {
    padding: 0.1em;
    border-radius: 0.3em;
    white-space: normal;
}

.token.comment,
.token.prolog,
.token.doctype,
.token.cdata {
    color: #d4d0ab;
}

.token.punctuation {
    color: #fefefe;
}

.token.property,
.token.tag,
.token.constant,
.token.symbol,
.token.deleted {
    color: #ffa07a;
}

.token.boolean,
.token.number {
    color: #00e0e0;
}

.token.selector,
.token.attr-name,
.token.string,
.token.char,
.token.builtin,
.token.inserted {
    color: #abe338;
}

.token.operator,
.token.entity,
.token.url,
.language-css .token.string,
.style .token.string,
.token.variable {
    color: #00e0e0;
}

.token.atrule,
.token.attr-value,
.token.function {
    color: #ffd700;
}

.token.keyword {
    color: #00e0e0;
}

.token.regex,
.token.important {
    color: #ffd700;
}

.token.important,
.token.bold {
    font-weight: bold;
}

.token.italic {
    font-style: italic;
}

.token.entity {
    cursor: help;
}

@media screen and (-ms-high-contrast: active) {

    code[class*='language-'],
    pre[class*='language-'] {
        color: windowText;
        background: window;
    }

    :not(pre) > code[class*='language-'],
    pre[class*='language-'] {
        background: window;
    }

    .token.important {
        background: highlight;
        color: window;
        font-weight: normal;
    }

    .token.atrule,
    .token.attr-value,
    .token.function,
    .token.keyword,
    .token.operator,
    .token.selector {
        font-weight: bold;
    }

    .token.attr-value,
    .token.comment,
    .token.doctype,
    .token.function,
    .token.keyword,
    .token.operator,
    .token.property,
    .token.string {
        color: highlight;
    }

    .token.attr-value,
    .token.url {
        font-weight: normal;
    }
}

form [type='text'],
form input:where(:not([type])),
form [type='email'],
form [type='url'],
form [type='password'],
form [type='number'],
form [type='date'],
form [type='datetime-local'],
form [type='month'],
form [type='search'],
form [type='tel'],
form [type='time'],
form [type='week'],
form [multiple],
form textarea,
form select {
    display: block;
    appearance: none;
    -webkit-appearance: none;
    height: 3em;
    display: block;
    width: 100%;
    background-color: var(--color-white);
    color: currentColor;
    text-align: left;
    padding: var(--size-200);
    box-shadow: var(--shadow-default);
    border-radius: var(--rounded-md);
    border-width: 0;
    transition: .4s var(--transition-timing-ease-in-out);
    transition-property: background;
    border: 1px solid var(--color-green-50);
}

/* Ensure textareas honor their rows attribute (don’t force input height) */
form textarea {
  height: auto !important;  /* overrides the earlier height: 3em */
  resize: vertical;         /* allow the user to expand if needed */
}

[type='color']:user-invalid,
[type='date']:user-invalid,
[type='datetime-local']:user-invalid,
[type='datetime']:user-invalid,
[type='email']:user-invalid,
[type='month']:user-invalid,
[type='number']:user-invalid,
[type='password']:user-invalid,
[type='search']:user-invalid,
[type='tel']:user-invalid,
[type='text']:user-invalid,
[type='time']:user-invalid,
[type='url']:user-invalid,
[type='week']:user-invalid,
textarea:user-invalid,
select:user-invalid {
    border-color: var(--color-red-700);
    color: var(--color-red-700);
    outline: none;
}

input.user-invalid {
    border-color: var(--color-red-700);
    color: var(--color-red-700);
    outline: none;
}

[type='color']:hover,
[type='date']:hover,
[type='datetime-local']:hover,
[type='datetime']:hover,
[type='email']:hover,
[type='month']:hover,
[type='number']:hover,
[type='password']:hover,
[type='search']:hover,
[type='tel']:hover,
[type='text']:hover,
[type='time']:hover,
[type='url']:hover,
[type='week']:hover,
textarea:hover,
select:hover {
    background-color: var(--color-off-white);
}

label + input,
label + select,
label + textarea,
legend + * {
    --flow-space: var(--size-100)
}

fieldset {
    display: block;
    border: none;
    width: 100%;
    padding: 0;
}

input::-webkit-date-and-time-value {
    display: flex;
    align-items: center;
    margin: 0px;
    text-align: left;
    width: 100%;
    height: 100%;
    padding: 0;
    line-height: 1;
}

html {
    background: var(--color-green-900);
}

body {
    background: var(--color-green-50);
}

.icon {
    display: inline-block;
    background: var(--color-green-100);
    color: var(--color-green-700);
    border-radius: var(--rounded-full);
    padding: 0.5em;
    line-height: var(--leading-none);
    border: none;
}

button.icon {
    cursor: pointer;
    transition: .4s var(--transition-timing-ease-in-out);
    transition-property: background;
}

    button.icon:hover {
        background: var(--color-green-200);
    }

.icon svg {
    display: block;
    width: 1em;
    height: auto;
}

.icon span {
    display: block;
    text-align: center;
    width: 1em;
    font-weight: var(--font-bold);
}

.icon[data-status="error"] {
    background: var(--color-red-100);
    color: var(--color-red-700);
}

.icon[data-status="normal"] {
    background: var(--color-green-100);
    color: var(--color-green-700);
}

.wavy {
    min-height: 100dvh;
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--color-green-25);
}

@font-face {
    font-display: swap;
    /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
    font-family: 'Plus Jakarta Sans';
    font-style: normal;
    font-weight: 400;
    src: url('/fonts/plus-jakarta-sans-v8-latin-regular.woff2') format('woff2');
    /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

@font-face {
    font-display: swap;
    /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
    font-family: 'Plus Jakarta Sans';
    font-style: normal;
    font-weight: 500;
    src: url('/fonts/plus-jakarta-sans-v8-latin-500.woff2') format('woff2');
    /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

@font-face {
    font-display: swap;
    /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
    font-family: 'Plus Jakarta Sans';
    font-style: normal;
    font-weight: 700;
    src: url('/fonts/plus-jakarta-sans-v8-latin-700.woff2') format('woff2');
    /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

body {
    font-family: var(--font-sans);
    font-size: var(--text-400);
    color: var(--color-green-900);
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-weight: var(--font-bold);
    line-height: var(--leading-none);
}

h1 {
    font-size: var(--text-900);
}

h2 {
    font-size: var(--text-800);
}

h3 {
    font-size: var(--text-600);
}

h4 {
    font-size: var(--text-500);
}

h5 {
    font-size: var(--text-400);
}

a {
    color: currentColor;
}

hr {
    display: block;
    width: 100%;
    height: 1px;
    border: none;
    opacity: 0.1;
    margin-bottom: 0;
    background: currentColor;
}

[type='text'], input:where(:not([type])), [type='email'], [type='url'], [type='password'], [type='number'], [type='date'], [type='datetime-local'], [type='month'], [type='search'], [type='tel'], [type='time'], [type='week'], [multiple], textarea, select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-color: #fff;
    border-color: #6b7280;
    border-width: 1px;
    border-radius: 0px;
    padding-top: 0.5rem;
    padding-right: 0.75rem;
    padding-bottom: 0.5rem;
    padding-left: 0.75rem;
    font-size: 1rem;
    line-height: 1.5rem;
    --tw-shadow: 0 0 #0000;
}

    [type='text']:focus, input:where(:not([type])):focus, [type='email']:focus, [type='url']:focus, [type='password']:focus, [type='number']:focus, [type='date']:focus, [type='datetime-local']:focus, [type='month']:focus, [type='search']:focus, [type='tel']:focus, [type='time']:focus, [type='week']:focus, [multiple]:focus, textarea:focus, select:focus {
        outline: 2px solid var(--color-green-600);
        outline-offset: 2px;
        --tw-ring-inset: var(--tw-empty, /*!*/ /*!*/ );
        --tw-ring-offset-width: 0px;
        --tw-ring-offset-color: #fff;
        --tw-ring-color: transparent;
        --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
        --tw-ring-shadow: 0 0 #0000;
        box-shadow: none;
        border-color: transparent;
    }

    input::-moz-placeholder, textarea::-moz-placeholder {
        color: #6b7280;
        opacity: 1;
    }

    input::placeholder, textarea::placeholder {
        color: #6b7280;
        opacity: 1;
    }

::-webkit-datetime-edit-fields-wrapper {
    padding: 0;
}

::-webkit-date-and-time-value {
    min-height: 1.5em;
    text-align: inherit;
}

::-webkit-datetime-edit {
    display: inline-flex;
}

::-webkit-datetime-edit, ::-webkit-datetime-edit-year-field, ::-webkit-datetime-edit-month-field, ::-webkit-datetime-edit-day-field, ::-webkit-datetime-edit-hour-field, ::-webkit-datetime-edit-minute-field, ::-webkit-datetime-edit-second-field, ::-webkit-datetime-edit-millisecond-field, ::-webkit-datetime-edit-meridiem-field {
    padding-top: 0;
    padding-bottom: 0;
}

select {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");
    background-position: right 0.5rem center;
    background-repeat: no-repeat;
    background-size: 1.5em 1.5em;
    padding-right: 2.5rem;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
}

[multiple], [size]:where(select:not([size="1"])) {
    background-image: initial;
    background-position: initial;
    background-repeat: unset;
    background-size: initial;
    padding-right: 0.75rem;
    -webkit-print-color-adjust: unset;
    print-color-adjust: unset;
}

[type='checkbox'], [type='radio'] {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    padding: 0;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
    display: inline-block;
    vertical-align: middle;
    background-origin: border-box;
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none;
    flex-shrink: 0;
    height: 1rem;
    width: 1rem;
    color: var(--color-green-600);
    background-color: #fff;
    border-color: #6b7280;
    border-width: 1px;
    --tw-shadow: 0 0 #0000;
}

[type='checkbox'] {
    border-radius: 0px;
}

[type='radio'] {
    border-radius: 100%;
}

    [type='checkbox']:focus, [type='radio']:focus {
        outline: 2px solid var(--color-green-600);
        outline-offset: 2px;
        --tw-ring-inset: var(--tw-empty, /*!*/ /*!*/ );
        --tw-ring-offset-width: 2px;
        --tw-ring-offset-color: #fff;
        --tw-ring-color: transparent;
        --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
        --tw-ring-shadow: 0 0 #0000;
        box-shadow: none;
    }

    [type='checkbox']:checked, [type='radio']:checked {
        border-color: transparent;
        background-color: currentColor;
        background-size: 100% 100%;
        background-position: center;
        background-repeat: no-repeat;
    }

[type='checkbox']:checked {
    background-image: url("data:image/svg+xml,%3csvg viewBox='0 0 16 16' fill='white' xmlns='http://www.w3.org/2000/svg'%3e%3cpath d='M12.207 4.793a1 1 0 010 1.414l-5 5a1 1 0 01-1.414 0l-2-2a1 1 0 011.414-1.414L6.5 9.086l4.293-4.293a1 1 0 011.414 0z'/%3e%3c/svg%3e");
}

@media (forced-colors: active) {
    [type='checkbox']:checked {
        -webkit-appearance: auto;
        -moz-appearance: auto;
        appearance: auto;
    }
}

[type='radio']:checked {
    background-image: url("data:image/svg+xml,%3csvg viewBox='0 0 16 16' fill='white' xmlns='http://www.w3.org/2000/svg'%3e%3ccircle cx='8' cy='8' r='3'/%3e%3c/svg%3e");
}

@media (forced-colors: active) {
    [type='radio']:checked {
        -webkit-appearance: auto;
        -moz-appearance: auto;
        appearance: auto;
    }
}

[type='checkbox']:checked:hover, [type='checkbox']:checked:focus, [type='radio']:checked:hover, [type='radio']:checked:focus {
    border-color: transparent;
    background-color: currentColor;
}

[type='checkbox']:indeterminate {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 16 16'%3e%3cpath stroke='white' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M4 8h8'/%3e%3c/svg%3e");
    border-color: transparent;
    background-color: currentColor;
    background-size: 100% 100%;
    background-position: center;
    background-repeat: no-repeat;
}

@media (forced-colors: active) {
    [type='checkbox']:indeterminate {
        -webkit-appearance: auto;
        -moz-appearance: auto;
        appearance: auto;
    }
}

[type='checkbox']:indeterminate:hover, [type='checkbox']:indeterminate:focus {
    border-color: transparent;
    background-color: currentColor;
}

[type='file'] {
    background: unset;
    border-color: inherit;
    border-width: 0;
    border-radius: 0;
    padding: 0;
    font-size: unset;
    line-height: inherit;
}

    [type='file']:focus {
        outline: 1px solid ButtonText;
        outline: 1px auto -webkit-focus-ring-color;
    }

.transform {
    --tw-translate-x: 0;
    --tw-translate-y: 0;
    --tw-rotate: 0;
    --tw-skew-x: 0;
    --tw-skew-y: 0;
    --tw-scale-x: 1;
    --tw-scale-y: 1;
}

.shadow-default {
    --tw-ring-offset-shadow: 0 0 #0000;
    --tw-ring-shadow: 0 0 #0000;
    --tw-shadow: 0 0 #0000;
    --tw-shadow-colored: 0 0 #0000;
}

.blur, .grayscale, .filter {
    --tw-blur:;
    --tw-brightness:;
    --tw-contrast:;
    --tw-grayscale:;
    --tw-hue-rotate:;
    --tw-invert:;
    --tw-saturate:;
    --tw-sepia:;
    --tw-drop-shadow:;
}

.backdrop-filter {
    --tw-backdrop-blur:;
    --tw-backdrop-brightness:;
    --tw-backdrop-contrast:;
    --tw-backdrop-grayscale:;
    --tw-backdrop-hue-rotate:;
    --tw-backdrop-invert:;
    --tw-backdrop-opacity:;
    --tw-backdrop-saturate:;
    --tw-backdrop-sepia:;
}

.container {
    width: 100%;
}

@media (min-width: 640px) {
    .container {
        max-width: 640px;
    }
}

@media (min-width: 768px) {
    .container {
        max-width: 768px;
    }
}

@media (min-width: 1024px) {
    .container {
        max-width: 1024px;
    }
}

@media (min-width: 1280px) {
    .container {
        max-width: 1280px;
    }
}

@media (min-width: 1536px) {
    .container {
        max-width: 1536px;
    }
}

:root {
    --color-green-25: #FDFFFE;
    --color-green-50: #F2F7F4;
    --color-green-100: #E0EBE3;
    --color-green-200: #C3D7CA;
    --color-green-300: #9ABBA8;
    --color-green-400: #6E9981;
    --color-green-500: #4E7B64;
    --color-green-600: #3A614E;
    --color-green-700: #335545;
    --color-green-800: #273E34;
    --color-green-900: #20342B;
    --color-red-50: #FEF2F2;
    --color-red-100: #FEE2E2;
    --color-red-200: #f87171;
    --color-red-300: #FCA5A5;
    --color-red-400: #f87171;
    --color-red-500: #dc2626;
    --color-red-600: #dc2626;
    --color-red-700: #B91C1C;
    --color-red-800: #991b1b;
    --color-red-900: #7f1d1d;
    --color-charcoal: #191919;
    --color-white: #fff;
    --color-transparent: transparent;
    --color-off-white: #F9FAFA;
    --size-0: 0;
    --size-50: clamp(0.0625rem, 0.0381rem + 0.122vi, 0.125rem);
    --size-100: clamp(0.125rem, 0.0762rem + 0.2439vi, 0.25rem);
    --size-200: clamp(0.25rem, 0.1524rem + 0.4878vi, 0.5rem);
    --size-300: clamp(0.5rem, 0.4024rem + 0.4878vi, 0.75rem);
    --size-400: clamp(0.6875rem, 0.5655rem + 0.6098vi, 1rem);
    --size-500: clamp(0.9375rem, 0.718rem + 1.0976vi, 1.5rem);
    --size-600: clamp(1.4375rem, 1.218rem + 1.0976vi, 2rem);
    --size-700: clamp(1.875rem, 1.436rem + 2.1951vi, 3rem);
    --size-800: clamp(2.8125rem, 2.3491rem + 2.3171vi, 4rem);
    --size-900: clamp(3.75rem, 2.872rem + 4.3902vi, 6rem);
    --text-200: clamp(0.6944rem, 0.7588rem + -0.0903vi, 0.7407rem);
    --text-300: clamp(0.8333rem, 0.8333rem + 0vi, 0.8333rem);
    --text-400: clamp(0.9375rem, 0.9131rem + 0.122vi, 1rem);
    --text-500: clamp(1.0547rem, 0.998rem + 0.2835vi, 1.2rem);
    --text-600: clamp(1.1865rem, 1.0876rem + 0.4946vi, 1.44rem);
    --text-700: clamp(1.3348rem, 1.1814rem + 0.7671vi, 1.728rem);
    --text-800: clamp(1.5017rem, 1.2785rem + 1.1159vi, 2.0736rem);
    --text-900: clamp(1.6894rem, 1.3776rem + 1.5589vi, 2.4883rem);
    --font-sans: Plus Jakarta Sans,Inter,system-ui,sans-serif;
    --font-thin: 100;
    --font-extralight: 200;
    --font-light: 300;
    --font-normal: 400;
    --font-medium: 500;
    --font-semibold: 600;
    --font-bold: 700;
    --font-extrabold: 800;
    --font-black: 900;
    --leading-3: .75rem;
    --leading-4: 1rem;
    --leading-5: 1.25rem;
    --leading-6: 1.5rem;
    --leading-7: 1.75rem;
    --leading-8: 2rem;
    --leading-9: 2.25rem;
    --leading-10: 2.5rem;
    --leading-none: 1;
    --leading-tight: 1.25;
    --leading-snug: 1.375;
    --leading-normal: 1.5;
    --leading-relaxed: 1.625;
    --leading-loose: 2;
    --shadow-default: 0px 2px 2px 0px var(--color-green-50), 0px 0px 0px 1px var(--color-green-50);
    --shadow-stronger: 0px 2px 2px 0px var(--color-green-400), 0px 0px 0px 1px var(--color-green-400);
    --rounded-none: 0px;
    --rounded-sm: 0.125rem;
    --rounded-default: 0.25rem;
    --rounded-md: 0.375rem;
    --rounded-lg: 0.5rem;
    --rounded-xl: 0.75rem;
    --rounded-2xl: 1rem;
    --rounded-3xl: 1.5rem;
    --rounded-full: 9999px;
    --transition-timing-ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
    --transition-timing-bounce: cubic-bezier(.47,1.64,.41,.8);
}

.visible {
    visibility: visible;
}

.collapse {
    visibility: collapse;
}

.static {
    position: static;
}

.fixed {
    position: fixed;
}

.absolute {
    position: absolute;
}

.relative {
    position: relative;
}

.sticky {
    position: sticky;
}

.bottom-400 {
    bottom: clamp(0.6875rem, 0.5655rem + 0.6098vi, 1rem);
}

.top-400 {
    top: clamp(0.6875rem, 0.5655rem + 0.6098vi, 1rem);
}

.top-700 {
    top: clamp(1.875rem, 1.436rem + 2.1951vi, 3rem);
}

.top-800 {
    top: clamp(2.8125rem, 2.3491rem + 2.3171vi, 4rem);
}

.top-900 {
    top: clamp(3.75rem, 2.872rem + 4.3902vi, 6rem);
}

.order-first {
    order: -9999;
}

.col-span-full {
    grid-column: 1 / -1;
}

.mx-0 {
    margin-left: 0;
    margin-right: 0;
}

.mx-\[-1em\] {
    margin-left: -1em;
    margin-right: -1em;
}

.mx-auto {
    margin-left: auto;
    margin-right: auto;
}

.mb-100 {
    margin-bottom: clamp(0.125rem, 0.0762rem + 0.2439vi, 0.25rem);
}

.mb-200 {
    margin-bottom: clamp(0.25rem, 0.1524rem + 0.4878vi, 0.5rem);
}

.mb-auto {
    margin-bottom: auto;
}

.ml-auto {
    margin-left: auto;
}

.mr-auto {
    margin-right: auto;
}

.mt-100 {
    margin-top: clamp(0.125rem, 0.0762rem + 0.2439vi, 0.25rem);
}

.mt-200 {
    margin-top: clamp(0.25rem, 0.1524rem + 0.4878vi, 0.5rem);
}

.mt-400 {
    margin-top: clamp(0.6875rem, 0.5655rem + 0.6098vi, 1rem);
}

.block {
    display: block;
}

.inline-block {
    display: inline-block;
}

.inline {
    display: inline;
}

.flex {
    display: flex;
}

.inline-flex {
    display: inline-flex;
}

.table {
    display: table;
}

.grid {
    display: grid;
}

.contents {
    display: contents;
}

.hidden {
    display: none;
}


.aspect-square {
    aspect-ratio: 1 / 1;
}

.w-0 {
    width: 0;
}

.w-100 {
    width: clamp(0.125rem, 0.0762rem + 0.2439vi, 0.25rem);
}

.w-200 {
    width: clamp(0.25rem, 0.1524rem + 0.4878vi, 0.5rem);
}

.w-300 {
    width: clamp(0.5rem, 0.4024rem + 0.4878vi, 0.75rem);
}

.w-400 {
    width: clamp(0.6875rem, 0.5655rem + 0.6098vi, 1rem);
}

.w-50 {
    width: clamp(0.0625rem, 0.0381rem + 0.122vi, 0.125rem);
}

.w-500 {
    width: clamp(0.9375rem, 0.718rem + 1.0976vi, 1.5rem);
}

.w-600 {
    width: clamp(1.4375rem, 1.218rem + 1.0976vi, 2rem);
}

.w-700 {
    width: clamp(1.875rem, 1.436rem + 2.1951vi, 3rem);
}

.w-800 {
    width: clamp(2.8125rem, 2.3491rem + 2.3171vi, 4rem);
}

.w-900 {
    width: clamp(3.75rem, 2.872rem + 4.3902vi, 6rem);
}

.w-full {
  width: 100%;
}

.min-w-0 {
  min-width: 0;
}

.max-w-md {
  max-width: 28rem;
}

.max-w-prose {
  max-width: 65ch;
}

.max-w-sm {
  max-width: 24rem;
}

.max-w-xs {
  max-width: 20rem;
}

.max-w-3xl {
  max-width: 48rem;
}

.max-w-\[1200px\] {
  max-width: 1200px;
}
.flex-1 {
    flex: 1 1 0%;
}

.basis-\[12rem\] {
    flex-basis: 12rem;
}

.border-collapse {
    border-collapse: collapse;
}

.transform {
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.grid-cols-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.grid-cols-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}


.grid-cols-6 {
    grid-template-columns: repeat(6, minmax(0, 1fr));
}

.flex-row {
    flex-direction: row;
}

.flex-col {
    flex-direction: column;
}

.flex-wrap {
    flex-wrap: wrap;
}

.items-start {
    align-items: flex-start;
}

.items-end {
    align-items: flex-end;
}

.items-center {
    align-items: center;
}

.justify-end {
    justify-content: flex-end;
}

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

.justify-between {
    justify-content: space-between;
}

.gap-0 {
    gap: 0;
}

.gap-200 {
    gap: clamp(0.25rem, 0.1524rem + 0.4878vi, 0.5rem);
}

.gap-700 {
  gap: clamp(1.875rem, 1.436rem + 2.1951vi, 3rem);
}

.gap-x-0 {
    -moz-column-gap: 0;
    column-gap: 0;
}

.gap-x-700 {
  -moz-column-gap: clamp(1.875rem, 1.436rem + 2.1951vi, 3rem);
       column-gap: clamp(1.875rem, 1.436rem + 2.1951vi, 3rem);
}

.text-white {
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity));
}
.opacity-100 {
  opacity: 1;
}
.overflow-hidden {
    overflow: hidden;
}

.rounded-lg {
    border-radius: 0.5rem;
}

.rounded-sm {
    border-radius: 0.125rem;
}

.rounded-xl {
    border-radius: 0.75rem;
}

.border {
    border-width: 1px;
}

.border-2 {
    border-width: 2px;
}

.border-solid {
    border-style: solid;
}

.border-green-100 {
    --tw-border-opacity: 1;
    border-color: rgb(224 235 227 / var(--tw-border-opacity));
}

.border-green-700 {
    --tw-border-opacity: 1;
    border-color: rgb(51 85 69 / var(--tw-border-opacity));
}

.bg-green-50 {
    --tw-bg-opacity: 1;
    background-color: rgb(242 247 244 / var(--tw-bg-opacity));
}

.bg-green-700 {
    --tw-bg-opacity: 1;
    background-color: rgb(51 85 69 / var(--tw-bg-opacity));
}

.bg-green-900 {
    --tw-bg-opacity: 1;
    background-color: rgb(32 52 43 / var(--tw-bg-opacity));
}

.bg-off-white {
    --tw-bg-opacity: 1;
    background-color: rgb(249 250 250 / var(--tw-bg-opacity));
}

.bg-red-100 {
    --tw-bg-opacity: 1;
    background-color: rgb(254 226 226 / var(--tw-bg-opacity));
}

.bg-red-50 {
    --tw-bg-opacity: 1;
    background-color: rgb(254 242 242 / var(--tw-bg-opacity));
}

.bg-red-700 {
    --tw-bg-opacity: 1;
    background-color: rgb(185 28 28 / var(--tw-bg-opacity));
}

.p-0 {
    padding: 0;
}

.p-200 {
    padding: clamp(0.25rem, 0.1524rem + 0.4878vi, 0.5rem);
}

.p-300 {
    padding: clamp(0.5rem, 0.4024rem + 0.4878vi, 0.75rem);
}

.p-400 {
    padding: clamp(0.6875rem, 0.5655rem + 0.6098vi, 1rem);
}

.p-700 {
    padding: clamp(1.875rem, 1.436rem + 2.1951vi, 3rem);
}

.px-400 {
    padding-left: clamp(0.6875rem, 0.5655rem + 0.6098vi, 1rem);
    padding-right: clamp(0.6875rem, 0.5655rem + 0.6098vi, 1rem);
}

.py-200 {
    padding-top: clamp(0.25rem, 0.1524rem + 0.4878vi, 0.5rem);
    padding-bottom: clamp(0.25rem, 0.1524rem + 0.4878vi, 0.5rem);
}

.py-700 {
    padding-top: clamp(1.875rem, 1.436rem + 2.1951vi, 3rem);
    padding-bottom: clamp(1.875rem, 1.436rem + 2.1951vi, 3rem);
}

.py-900 {
    padding-top: clamp(3.75rem, 2.872rem + 4.3902vi, 6rem);
    padding-bottom: clamp(3.75rem, 2.872rem + 4.3902vi, 6rem);
}

.pt-200 {
    padding-top: clamp(0.25rem, 0.1524rem + 0.4878vi, 0.5rem);
}

.pt-300 {
    padding-top: clamp(0.5rem, 0.4024rem + 0.4878vi, 0.75rem);
}

.pt-400 {
    padding-top: clamp(0.6875rem, 0.5655rem + 0.6098vi, 1rem);
}

.pt-500 {
    padding-top: clamp(0.9375rem, 0.718rem + 1.0976vi, 1.5rem);
}

.pt-600 {
    padding-top: clamp(1.4375rem, 1.218rem + 1.0976vi, 2rem);
}

.pt-700 {
    padding-top: clamp(1.875rem, 1.436rem + 2.1951vi, 3rem);
}

.pt-800 {
    padding-top: clamp(2.8125rem, 2.3491rem + 2.3171vi, 4rem);
}

.pt-900 {
    padding-top: clamp(3.75rem, 2.872rem + 4.3902vi, 6rem);
}

.text-left {
    text-align: left;
}

.text-center {
    text-align: center;
}

.text-justified {
    text-align: justify;
}


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

.text-200 {
    font-size: clamp(0.6944rem, 0.7588rem + -0.0903vi, 0.7407rem);
}

.text-300 {
    font-size: clamp(0.8333rem, 0.8333rem + 0vi, 0.8333rem);
}

.text-400 {
    font-size: clamp(0.9375rem, 0.9131rem + 0.122vi, 1rem);
}

.text-500 {
    font-size: clamp(1.0547rem, 0.998rem + 0.2835vi, 1.2rem);
}

.text-600 {
    font-size: clamp(1.1865rem, 1.0876rem + 0.4946vi, 1.44rem);
}

.text-700 {
    font-size: clamp(1.3348rem, 1.1814rem + 0.7671vi, 1.728rem);
}

.text-800 {
    font-size: clamp(1.5017rem, 1.2785rem + 1.1159vi, 2.0736rem);
}

.text-900 {
    font-size: clamp(1.6894rem, 1.3776rem + 1.5589vi, 2.4883rem);
}

.font-bold {
    font-weight: 700;
}

.font-medium {
    font-weight: 500;
}

.font-normal {
    font-weight: 400;
}

.capitalize {
    text-transform: capitalize;
}

.italic {
    font-style: italic;
}

.leading-none {
    line-height: 1;
}

.text-green-100 {
    --tw-text-opacity: 1;
    color: rgb(224 235 227 / var(--tw-text-opacity));
}

.text-green-300 {
    --tw-text-opacity: 1;
    color: rgb(154 187 168 / var(--tw-text-opacity));
}

.text-green-400 {
    --tw-text-opacity: 1;
    color: rgb(110 153 129 / var(--tw-text-opacity));
}

.text-green-500 {
    --tw-text-opacity: 1;
    color: rgb(78 123 100 / var(--tw-text-opacity));
}

.text-green-600 {
    --tw-text-opacity: 1;
    color: rgb(58 97 78 / var(--tw-text-opacity));
}

.text-green-700 {
    --tw-text-opacity: 1;
    color: rgb(51 85 69 / var(--tw-text-opacity));
}

.text-green-900 {
    --tw-text-opacity: 1;
    color: rgb(32 52 43 / var(--tw-text-opacity));
}

.text-red-300 {
    --tw-text-opacity: 1;
    color: rgb(252 165 165 / var(--tw-text-opacity));
}

.text-red-700 {
    --tw-text-opacity: 1;
    color: rgb(185 28 28 / var(--tw-text-opacity));
}

.underline {
    text-decoration-line: underline;
}

.no-underline {
    text-decoration-line: none;
}

.antialiased {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.opacity-60 {
    opacity: 0.6;
}

.shadow-default {
    --tw-shadow: 0px 2px 2px 0px var(--color-green-50), 0px 0px 0px 1px var(--color-green-50);
    --tw-shadow-colored: 0px 2px 2px 0px var(--tw-shadow-color), 0px 0px 0px 1px var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.outline {
    outline-style: solid;
}

.blur {
    --tw-blur: blur(8px);
    filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.grayscale {
    --tw-grayscale: grayscale(100%);
    filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.filter {
    filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

.backdrop-filter {
    -webkit-backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
    backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
}

.transition {
    transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, -webkit-backdrop-filter;
    transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
    transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter, -webkit-backdrop-filter;
    transition-duration: 150ms;
}

.flow-space-0 {
    --flow-space: 0;
}

.flow-space-50 {
    --flow-space: clamp(0.0625rem, 0.0381rem + 0.122vi, 0.125rem);
}

.flow-space-100 {
    --flow-space: clamp(0.125rem, 0.0762rem + 0.2439vi, 0.25rem);
}

.flow-space-200 {
    --flow-space: clamp(0.25rem, 0.1524rem + 0.4878vi, 0.5rem);
}

.flow-space-300 {
    --flow-space: clamp(0.5rem, 0.4024rem + 0.4878vi, 0.75rem);
}

.flow-space-400 {
    --flow-space: clamp(0.6875rem, 0.5655rem + 0.6098vi, 1rem);
}

.flow-space-700 {
    --flow-space: clamp(1.875rem, 1.436rem + 2.1951vi, 3rem);
}

.hover\:bg-green-100:hover {
    --tw-bg-opacity: 1;
    background-color: rgb(224 235 227 / var(--tw-bg-opacity));
}

.col-span-2 {
    grid-column: span 2;
}

@media (min-width: 640px) {
    .sm\:flex-1 {
        flex: 1 1 0%;
    }

    .sm\:text-right {
        text-align: right;
    }
}

@media (min-width: 1024px) {
    .lg\:sticky {
        position: sticky;
    }

    .lg\:order-last {
        order: 9999;
    }

    .lg\:col-span-2 {
        grid-column: span 2 / span 2;
    }

    .lg\:flex {
        display: flex;
    }

    .lg\:hidden {
        display: none;
    }

    .lg\:w-auto {
        width: auto;
    }

    .lg\:flex-1 {
        flex: 1 1 0%;
    }

    .lg\:grid-cols-2 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .lg\:grid-cols-3 {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

.lg\:grid-cols-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
    .lg\:grid-cols-6 {
        grid-template-columns: repeat(6, minmax(0, 1fr));
    }

    .lg\:grid-cols-\[1fr_24rem\] {
        grid-template-columns: 1fr 24rem;
    }

    .lg\:grid-cols-\[repeat\(auto-fit\2c minmax\(12rem\2c 1fr\)\)\] {
        grid-template-columns: repeat(auto-fit,minmax(12rem,1fr));
    }

    .lg\:flex-row {
        flex-direction: row;
    }

    .lg\:items-center {
        align-items: center;
    }
}

@media (min-width: 1280px) {
    .xl\:grid-cols-\[1fr\2c 22rem\] {
        grid-template-columns: 1fr 22rem;
    }
}

.switcher {
    display: flex;
    align-items: center;
    gap: 0;
    list-style: none;
    margin: 0;
    padding: 0;
}

.switcher li {
    display: flex;
    align-items: center;
    transition: margin 0.4s var(--transition-timing-bounce);
    z-index: 3;
}

.switcher li + li {
    margin-left: -2em;
}

.switcher li:nth-child(2) {
    z-index: 2;
}

.switcher li:nth-child(3) {
    z-index: 1;
}

.switcher:hover li + li {
    margin-left: 0;
}

.switcher button,
.switcher a {
    appearance: none;
    -webkit-appearance: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    width: 3.25rem;
    height: 3.25rem;
    margin: 0;
    padding: 0;
    border: 0;
    border-radius: 9999px;
    background: transparent;
    box-shadow: none;
    line-height: 0;
    cursor: pointer;
    overflow: hidden;
    text-decoration: none;
}

.switcher button img,
.switcher button svg,
.switcher a img,
.switcher a svg {
    display: block;
    flex: 0 0 auto;
}

/* Unselected/default white badge button */
.switcher button.product-button,
.switcher button.product-selected--angling,
.switcher a.product-selected--angling {
    background: white;
    box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.10);
}

/* Angling artwork */
.switcher button.product-button img,
.switcher button.product-selected--angling img,
.switcher a.product-selected--angling img {
    width: 2.3rem;
    height: 2.3rem;
    object-fit: contain;
    transform: translateY(1px);
}

/* Creatives selected orange circle */
.switcher button.product-selected--creatives {
    background: transparent;
    box-shadow: none;
}

.switcher button.product-selected--creatives svg {
    width: 2.95rem;
    height: 2.95rem;
    transform: translateY(0);
}

/* Optional keyboard focus */
.switcher button:focus-visible,
.switcher a:focus-visible {
    outline: 2px solid white;
    outline-offset: 2px;
}
.account-menu {
    align-items: center;
    justify-content: flex-end;
    position: relative;
    gap: 0.5em;
    z-index: 10;
}

.account-menu__image {
    display: block;
    width: 2em;
    height: auto;
    border-radius: var(--rounded-full);
    transition: .4s var(--transition-timing-bounce);
    transition-property: transform;
    background: var(--color-green-100);
    padding: 0.5em;
}

    .account-menu__image + svg {
        transition: .4s var(--transition-timing-bounce);
        transition-property: opacity, visibility, transform;
    }

.account-menu__dropdown {
    --flow-space: var(--size-200);
    position: absolute;
    top: 100%;
    right: 0;
    background: var(--color-green-700);
    color: var(--color-green-100);
    border-radius: var(--rounded-xl);
    padding: var(--size-400);
    min-width: min(18rem, 100vw);
    transform: scale(0);
    visibility: hidden;
    opacity: 0;
    transform-origin: top right;
    transition: .4s var(--transition-timing-bounce);
    transition-property: opacity, visibility, transform;
}

    .account-menu__dropdown li {
        border-top: 1px solid var(--color-green-600);
        padding-top: var(--flow-space, var(--size-400));
    }

        .account-menu__dropdown li svg {
            flex: none;
            display: block;
            width: 1em;
            height: auto;
        }

        .account-menu__dropdown li a {
            display: flex;
            align-items: center;
            gap: 0.5em;
            text-decoration: none;
            transition: .4s var(--transition-timing-ease-in-out);
            transition-property: opacity;
            cursor: pointer;
        }

            .account-menu__dropdown li a:hover {
                opacity: 0.6;
            }

.account-menu:hover .account-menu__image {
    transform: scale(0.9);
}

    .account-menu:hover .account-menu__image + svg {
        transform: rotate(180deg);
    }

.account-menu:hover .account-menu__dropdown {
    visibility: visible;
    opacity: 1;
    transform: none;
}

.main-nav__menu {
    --flow-space: var(--size-200);
}

    .main-nav__menu summary {
        list-style: none;
    }

        .main-nav__menu summary::-webkit-details-marker {
            display: none;
        }

.main-nav__items {
    gap: 0;
    align-items: inherit;
}

    .main-nav__items li a {
        display: flex;
        align-items: center;
        gap: 0.5em;
        text-decoration: none;
        padding: 0.5em 1em;
        border-radius: var(--rounded-default);
        transition: .4s var(--transition-timing-ease-in-out);
        transition-property: background;
    }

        .main-nav__items li a svg {
            height: 1em;
            width: auto;
            display: block;
            flex: none;
            transition: .4s var(--transition-timing-bounce);
            transition-property: transform;
        }

        .main-nav__items li a:hover {
            background: var(--color-off-white);
        }

            .main-nav__items li a:hover svg {
                transform: scale(1.25);
            }

        .main-nav__items li a[aria-current="page"] {
            font-weight: var(--font-bold);
            background: var(--color-green-50);
        }

            .main-nav__items li a[aria-current="page"] svg path {
                fill: currentColor;
            }


.title-bar {
    justify-content: space-between;
    align-items: flex-end;
}

    .title-bar .stack {
        gap: var(--size-200);
    }

.checkbox input {
    opacity: 0;
    overflow: hidden;
    position: absolute;
    width: 1px;
}

.checkbox label {
    align-items: flex-start;
    gap: var(--size-300);
    cursor: pointer;
}

    .checkbox label span:first-child {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 1.5rem;
        height: 1.5rem;
        box-shadow: 0 0 0 2px var(--color-green-100);
        border-radius: var(--rounded-md);
        background: var(--color-white);
    }

        .checkbox label span:first-child svg {
            display: block;
            width: 1.25em;
            height: auto;
            opacity: 0;
            visibility: hidden;
            flex: none;
        }

.checkbox__text {
    margin-top: 0;
    flex: 1;
}

.checkbox input:checked + label span:first-child {
    background: var(--color-green-700);
    color: var(--color-green-50);
}

    .checkbox input:checked + label span:first-child svg {
        opacity: 1;
        visibility: visible;
    }

.checkbox label:hover span:first-child {
    box-shadow: var(--shadow-stronger);
}

.checkbox input:focus-visible + label span:first-child {
    outline: 2px solid var(--color-green-600);
    outline-offset: 2px;
    box-shadow: var(--shadow-stronger);
}

.discovery-panel {
    margin-bottom: var(--size-300);
    padding: var(--size-200);
    --flow-space: var(--size-200);
    border: 1px dashed var(--color-green-100);
    border-radius: var(--rounded-lg);
    background: var(--color-white);
}

.discovery-panel .grid {
    row-gap: var(--size-200);
    column-gap: var(--size-300);
    grid-template-columns: auto auto;
    justify-content: flex-start;
    align-items: start;
}

.discovery-panel .other-input {
    width: 100%;
    max-width: 100%;
}

.discovery-panel__other {
    grid-column-start: 2;
    min-width: 0;
}

.discovery-panel__other-source {
    grid-column-start: 2;
    width: min(14rem, 100%);
    min-width: 0;
}

.discovery-panel .checkbox label {
    align-items: center;
    gap: var(--size-200);
}

.discovery-panel .checkbox label span:first-child {
    width: 1.25rem;
    height: 1.25rem;
}

.discovery-panel .checkbox label span:first-child svg {
    width: 1rem;
    height: 1rem;
}

.discovery-panel__other-label {
    display: block;
    margin-bottom: var(--size-100);
    color: var(--color-green-700);
    font-size: var(--text-300);
    font-weight: var(--font-medium);
}

.angling-personal-details .group-box__header,
.angling-organisation-details .group-box__header {
    padding: var(--size-200) var(--size-400);
    border-bottom: 1px solid var(--color-green-100);
    box-shadow: 0 1px 0 rgba(32, 52, 43, 0.05);
}

.angling-personal-details .group-box__header .icon,
.angling-organisation-details .group-box__header .icon {
    align-self: center;
}

.angling-personal-details .group-box__inner > .grid,
.angling-organisation-details .group-box__inner > .grid {
    gap: var(--size-500) var(--size-600);
    align-items: start;
}

.angling-personal-details text-input,
.angling-organisation-details text-input {
    display: block;
    width: 100%;
    max-width: 34rem;
}

.angling-personal-details text-input.col-span-full,
.angling-organisation-details text-input.col-span-full,
.angling-organisation-details .col-span-full text-input {
    max-width: 100%;
}

.angling-personal-details .required-fields-note,
.angling-organisation-details .required-fields-note {
    margin: 0 0 var(--size-300);
    color: var(--color-green-600);
    font-size: var(--text-300);
}

.angling-organisation-details .org-field-hint {
    margin-top: var(--size-200);
    padding: var(--size-200);
    color: var(--color-green-700);
    background: var(--color-green-50);
    border: 1px solid var(--color-green-100);
    border-radius: var(--rounded-md);
}

.angling-organisation-details .org-field-hint .icon {
    color: var(--color-green-600);
}

.angling-organisation-details .org-field-hint p {
    margin: 0;
}

.select-input select:required:invalid {
    color: var(--color-green-300);
}

.select-input select option {
    color: var(--color-green-900);
}

.help-hint {
    display: inline-flex;
    position: relative;
    cursor: help;
    margin-top: 0;
}

    .help-hint > svg {
        display: block;
        width: 1em;
        height: auto;
    }

.option {
    display: inline-flex;
}

    .option input {
        opacity: 0;
        overflow: hidden;
        position: absolute;
        width: 1px;
    }

    .option label {
        padding: 0.75em;
        box-shadow: var(--shadow-default);
        border-radius: var(--rounded-md);
        background: var(--color-white);
        transition: .4s var(--transition-timing-ease-in-out);
        transition-property: background;
        align-items: center;
        gap: 0.75em;
        cursor: pointer;
        border: 1px solid transparent;
    }

        .option label:hover {
            background: var(--color-off-white);
        }

.option__text {
    flex: 1;
    line-height: var(--leading-tight);
}

.option .help-hint {
    color: var(--color-green-400);
    margin-left: auto;
}

.option label span:first-child {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0.25em;
    box-shadow: var(--shadow-default);
    border-radius: var(--rounded-full);
}

    .option label span:first-child svg {
        display: block;
        width: 1em;
        height: auto;
        opacity: 0;
        visibility: hidden;
        flex: none;
    }

.option input:checked + label {
    background: var(--color-green-50);
    border-color: var(--color-green-700);
}

    .option input:checked + label span:first-child {
        background: var(--color-green-700);
        color: var(--color-green-50);
    }

        .option input:checked + label span:first-child svg {
            opacity: 1;
            visibility: visible;
        }

.button {
    appearance: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5em;
    padding: 0.5em 1em;
    font-weight: var(--font-bold);
    background: var(--color-green-700);
    color: var(--color-white);
    line-height: var(--leading-none);
    border-radius: var(--rounded-default);
    border: 1px solid rgba(0, 0, 0, 0.1);
    cursor: pointer;
    text-decoration: none;
    padding: 0.75em 1.25em;
    transition: .4s ease-in-out;
    transition-property: color, background, border-color;
}

.repeater-input__inner {
    padding: var(--size-400);
    background: var(--color-off-white);
    transition: .4s var(--transition-timing-ease-in-out);
    transition-property: opacity, visibility, grid-template-rows;
}

.repeater-input__wrapper {
    display: grid;
    grid-template-rows: 1fr;
    visibility: visible;
    opacity: 1;
}

[status="collapsed"] .repeater-input__wrapper {
    grid-template-rows: 0fr;
    visibility: hidden;
    opacity: 0;
}

.repeater-input__wrapper > * {
    overflow: hidden;
}

.repeater-input__summary {
    position: relative;
    align-items: center;
    padding: var(--size-200) var(--size-400);
    background: var(--color-green-25);
    color: var(--color-green-700);
    border-bottom: 1px solid var(--color-green-100);
}

    .repeater-input__summary .icon:last-child svg {
        transition: .4s var(--transition-timing-ease-in-out);
        transition-property: transform;
    }

[status="default"] .repeater-input__summary .icon:last-child svg {
    transform: rotate(45deg);
}

.repeater-input__add {
    display: block;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--size-200);
    background: var(--color-white);
    width: 100%;
    border: none;
    padding: 1em;
    font-weight: var(--font-bold);
    line-height: var(--leading-none);
    color: var(--color-green-700);
    transition: .4s var(--transition-timing-ease-in-out);
    transition-property: background;
    border-bottom: 1px solid var(--color-green-50);
}

    .repeater-input__add:hover {
        background: var(--color-off-white);
    }

.breakdown-list {
    gap: var(--size-200);
}

    .breakdown-list div:not(:nth-last-child(-n+2)) {
        border-bottom: 1px solid var(--color-green-100);
        padding-bottom: var(--size-200);
    }

    .breakdown-list dt, .breakdown-list dd {
        position: relative;
        z-index: 1;
    }

.checkbox-card {
    display: flex;
    min-height: 100%;
}

    .checkbox-card input {
        opacity: 0;
        overflow: hidden;
        position: absolute;
        width: 1px;
    }

.checkbox-card__inner {
    --flow-space: var(--size-200);
    display: block;
    position: relative;
    box-shadow: var(--shadow-default);
    padding: var(--size-500);
    border-radius: var(--rounded-md);
    background: var(--color-green-25);
    transition: .4s var(--transition-timing-ease-in-out);
    transition-property: background;
    cursor: pointer;
    border: 2px solid transparent;
    cursor: pointer;
    width: 100%;
}

    .checkbox-card__inner .icon {
        transition: .4s var(--transition-timing-bounce);
        transition-property: transform;
    }

.checkbox-card__status {
    display: block;
    padding: 0.5em;
    background: var(--color-green-100);
    border-radius: var(--rounded-full);
    box-shadow: var(--shadow-default);
}

    .checkbox-card__status svg {
        display: block;
        width: 1em;
        height: auto;
        opacity: 0;
        visibility: hidden;
    }

.checkbox-card__inner:hover {
    background: var(--color-green-50);
}

    .checkbox-card__inner:hover .icon {
        transform: scale(1.25);
    }

.checkbox-card input:checked + .checkbox-card__inner {
    background-color: var(--color-green-50);
    border-color: var(--color-green-700);
}

    .checkbox-card input:checked + .checkbox-card__inner .checkbox-card__status {
        background: var(--color-green-700);
        color: var(--color-green-50);
    }

        .checkbox-card input:checked + .checkbox-card__inner .checkbox-card__status svg {
            opacity: 1;
            visibility: visible;
        }

.group-box {
    position: relative;
    border-radius: var(--rounded-3xl);
    overflow: hidden;
    box-shadow: var(--shadow-default);
    background: var(--color-green-50);
    transition: .4s var(--transition-timing-ease-in-out);
    transition-property: transform;
    padding: var(--size-100);
}

.group-box__header {
    align-items: center;
    gap: 0.75em;
    background: var(--color-green-50);
    padding: var(--size-300) var(--size-400);
    font-size: var(--text-500);
    color: var(--color-green-700);
}

.group-box .group-box .group-box__header {
    font-size: var(--text-400);
}

.group-box__header .icon {
    align-self: flex-start;
}

.group-box__title {
    --flow-space: var(--size-100);
    flex: 1;
    margin-right: auto;
    overflow: hidden;
    padding: 0.25em 0;
}

    .group-box__title details summary {
        list-style: none;
        display: flex;
        align-items: center;
        justify-content: space-between;
        cursor: pointer;
    }

    .group-box__title details > summary::-webkit-details-marker {
        display: none;
    }

    .group-box__title details summary svg {
        height: 1.5em;
        width: auto;
        transition: .4s var(--transition-timing-bounce);
        transition-property: transform;
    }

    .group-box__title details[open] summary svg {
        transform: rotate(-90deg);
    }

    .group-box__title details p {
        font-size: var(--text-400);
    }

.group-box__heading {
    font-size: inherit;
}

.group-box__inner {
    overflow: hidden;
    padding: var(--size-400);
    background: var(--color-white);
    border-radius: calc(var(--rounded-3xl) - var(--size-100));
}

.group-box:has(.group-box__footer) .group-box__inner {
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
}

.group-box__footer {
    align-items: center;
    padding: var(--size-300) var(--size-400);
    font-size: var(--text-300);
    column-gap: var(--size-200);
    background: var(--color-green-100);
    border-bottom-left-radius: calc(var(--rounded-3xl) - var(--size-100));
    border-bottom-right-radius: calc(var(--rounded-3xl) - var(--size-100));
}

    .group-box__footer p {
        flex: 1;
        line-height: var(--leading-tight);
    }

    .group-box__footer[variant="warning"] {
        background: var(--color-red-50);
        color: var(--color-red-700);
    }

.group-box[variant="condensed"] .group-box__inner {
    padding: 0;
}

.group-box[variant="highlight"] {
    background: var(--color-green-700);
}

    .group-box[variant="highlight"] > .group-box__header {
        background: var(--color-green-700);
        color: var(--color-green-100);
    }

.group-box:has(.group-box__header .breakout-button):hover {
    transform: scale(1.025);
}

.summary-list {
    display: block;
    position: relative;
    z-index: 1;
}

.summary-list__items {
    --flow-space: var(--size-400);
}

    .summary-list__items li {
        position: relative;
        align-items: flex-start;
        z-index: 1;
        padding-bottom: var(--size-400);
    }

        .summary-list__items li:before {
            content: '';
            position: absolute;
            top: 0;
            left: 1rem;
            bottom: 0;
            background: var(--color-green-100);
            width: 1px;
            z-index: -1;
        }

        .summary-list__items li:last-child {
            padding-bottom: 0;
        }

            .summary-list__items li:last-child::before {
                content: none;
            }

        .summary-list__items li[status="complete"] .icon {
            background: var(--color-green-500);
            color: var(--color-green-50);
        }

        .summary-list__items li[status="error"] div,
        .summary-list__items li[status="error"] .icon span {
            opacity: 0.4;
        }

        .summary-list__items li .icon {
            background: var(--color-green-50);
            border: 1px solid var(--color-green-100);
        }

        .summary-list__items li h3 {
            white-space: normal;
            overflow: hidden;
            text-overflow: ellipsis;
            line-height: var(--leading-normal);
        }

.status-label {
    display: inline-flex;
    align-items: center;
    gap: 0.5em;
    background: var(--color-green-100);
    border: 1px solid var(--color-green-300);
    color: var(--color-green-700);
    font-size: var(--text-300);
    font-weight: var(--font-bold);
    padding: 0.5em 0.75em;
    border-radius: var(--rounded-full);
    line-height: var(--leading-none);
}

    .status-label.field-validation-valid {
        display: none;
    }

    .status-label:before {
        content: '';
        display: block;
        width: 0.5em;
        height: 0.5em;
        border-radius: var(--rounded-full);
        background: currentColor;
    }

    .status-label[data-status="error"] {
        background: var(--color-red-100);
        border: 1px solid var(--color-red-300);
        color: var(--color-red-700);
    }

.currency-input {
    padding-left: 2em; /* Adjust padding to accommodate the currency symbol */
    width: 100%;
    box-sizing: border-box;
    position: relative;
}

    .currency-input::before {
        content: '£';
        position: absolute;
        left: 0.5em; /* Adjust position as needed */
        top: 50%;
        transform: translateY(-50%);
        font-size: 1em;
        pointer-events: none;
        color: #000; /* Optional: Change the color if needed */
    }

/* Media Query for smaller screens */
@media (max-width: 600px) {
    .currency-input {
        padding-left: 1.5em; /* Adjust padding for smaller screens */
    }

        .currency-input::before {
            left: 0.4em; /* Adjust position for smaller screens */
            font-size: 0.9em; /* Adjust font size for smaller screens */
        }
}

.spinner {
    border: 3px solid #f3f3f3;
    border-top: 3px solid var(--color-green-300);
    border-radius: 50%;
    width: 16px;
    height: 16px;
    animation: spin 2s linear infinite;
    margin-left: 8px;
    display: inline-block;
}

.htmx-indicator {
    display: none;
}

.htmx-request .htmx-indicator {
    display: inline;
}



@keyframes spin {
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}

.definition-list {
    display: grid;
}

.definition-list__item {
    --flow-space: var(--size-200);
    align-items: flex-start;
    padding: var(--size-200) 0;
    gap: var(--size-200) var(--size-600);
}

    .definition-list__item svg {
        width: auto;
        height: 0.75em;
        transition: .4s var(--transition-timing-bounce);
        transition-property: transform;
    }

    .definition-list__item[open] svg {
        transform: rotate(180deg);
    }

    .definition-list__item:first-child {
        padding-top: 0;
    }

    .definition-list__item:last-child {
        padding-bottom: 0;
    }

    .definition-list__item + .definition-list__item {
        border-top: 1px solid var(--color-green-100);
    }

.definition-list dt {
    margin-right: auto;
}

.definition-list dd {
    display: inline-flex;
    flex-direction: inherit;
    justify-content: flex-end;
    align-items: inherit;
    gap: var(--size-200);
    color: var(--color-green-700);
    font-weight: var(--font-medium);
}

ul > li + li > accordion-item > .accordion-item {
    border-top: 1px solid var(--color-green-100);
    padding-top: var(--flow-space, var(--size-400));
}

.accordion-item > summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    column-gap: 1em;
    list-style: none;
    cursor: pointer;
}

.accordion-item[disabled] summary {
    pointer-events: none; /* prevents click events */
}

.accordion-item > summary h3 {
    font-weight: var(--font-bold);
    color: var(--color-green-700);
}

.accordion-item > summary > svg {
    height: 1em;
    width: auto;
    flex: none;
    transition: .4s var(--transition-timing-bounce);
    transition-property: transform;
}

.accordion-item[open] > summary > svg {
    transform: rotate(180deg);
}

.accordion-item summary::-webkit-details-marker {
    display: none;
}

.inline-alert {
    position: relative;
    align-items: center;
    padding: var(--size-200);
    gap: var(--size-200);
    border: 1px solid var(--color-green-100);
    border-radius: var(--rounded-xl);
    background: var(--color-green-50);
    z-index: 10;
    color: var(--color-green-700);
}

.inline-alert__content {
    flex: 1;
}

.dialog {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    max-width: initial;
    max-height: initial;
    text-align: left;
    z-index: 100;
    overflow: visible;
    margin: 0;
    transition: 0.4s var(--transition-timing-ease-in-out);
    transition-property: opacity, visibility;
    visibility: visible;
    border: none;
    padding: 0;
    background: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
}

.popup-container.active::before {
    content: "";
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.6);
    z-index: 950;
    pointer-events: none;
}

#email_dialog {
    position: static;
    z-index: 1000;
    pointer-events: auto;
    background: transparent;
}

.my_dialog {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    align-items: center;
    justify-content: center;
    z-index: 999;
    background: rgba(0, 0, 0, 0.3);
}

    #email_dialog .dialog__inner {
        position: fixed;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        max-width: 40rem;
        width: 90%;
        pointer-events: all;
        z-index: 1000;
    }

@media (min-width: 768px) {
    #email_dialog .dialog__inner {
        max-width: 50rem;
    }
}

#email_dialog .dialog__body {
    max-height: 80vh;
    overflow-y: auto;
}


.dialog__inner {
    overflow-y: auto;
    max-height: 100%;
    width: 100%;
    max-width: 48rem;
    box-shadow: var(--shadow-default);
    background: var(--color-off-white);
    border-radius: var(--rounded-3xl);
}



.dialog__header {
    align-items: center;
    gap: var(--size-200);
    padding: var(--size-200) var(--size-400);
}

.dialog__body {
    overflow: hidden;
    padding: var(--size-400);
    background: var(--color-white);
    border-top-left-radius: var(--rounded-3xl);
    border-top-right-radius: var(--rounded-3xl);
}

.dialog__footer {
    overflow: hidden;
    padding: var(--size-400);
    background: var(--color-off-white);
    display: flex;
    justify-content: center;
    width: 100%;
}

    .dialog__footer .button-text.hidden {
        display: none;
    }

    .dialog__footer .button-text {
        display: inline-block;
        width: 100%;
        text-align: center;
        cursor: pointer;
    }

.dialog:not([open]) {
    visibility: hidden;
    opacity: 0;
}

.dialog[open] {
    transform: none;
    opacity: 1;
}

.dialog::backdrop {
    opacity: 0;
    visibility: hidden;
}

.dialog + .backdrop {
    opacity: 0;
    visibility: hidden;
}

.quote-box {
    background-color: var(--color-green-50);
    color: var(--color-green-700);
}

.link-card {
    --flow-space: var(--size-200);
    position: relative;
    box-shadow: var(--shadow-default);
    padding: var(--size-500);
    border-radius: calc(var(--rounded-3xl) - var(--size-100) - var(--size-400));
    background: var(--color-green-25);
    transition: .4s var(--transition-timing-ease-in-out);
    transition-property: background;
    cursor: pointer;
}

    .link-card .icon {
        transition: .4s var(--transition-timing-bounce);
        transition-property: transform;
    }

    .link-card:hover {
        background: var(--color-green-50);
    }

        .link-card:hover .icon {
            transform: scale(1.25);
        }

div > iframe[src*="hcaptcha"] {
    z-index: 101 !important;
}

table {
    width: 100%;
    margin-bottom: 1rem;
    color: #212529;
    border-collapse: collapse;
}

.table th {
    background-color: lightblue;
}

.table th,
.table td {
    padding: 0.75rem;
    vertical-align: top;
    border-top: 1px solid #dee2e6;
    text-align: center;
    font-size: .8rem;
}

.table thead th {
    vertical-align: bottom;
    border-bottom: 2px solid #dee2e6;
}

.table tbody + tbody {
    border-top: 2px solid #dee2e6;
}

.table .table {
    background-color: #fff;
}

.theme-tbl {
    font-size: 14px;
    border: 1px solid #e3e3e3;
}

    .theme-tbl thead th {
        background: var(--color-green-700);
        color: #fff;
        font-size: .8rem;
        font-weight: 500;
    }


.flow .quote-box p {
    margin-top: 0;
}

.button-wrapper {
    display: flex;
    justify-content: center; /* Centers the button horizontally */
}

.tippy-box[data-theme~='help-hint'] {
    background: var(--color-green-50);
    color: var(--color-green-700);
    border-radius: var(--rounded-md);
    padding: var(--size-200);
    border: 1px solid var(--color-green-700);
    text-align: center;
    font-weight: 500;
    max-width: 18rem;
    text-align: center;
}

[x-cloak] {
    display: none !important;
}

.tippy-box[data-theme~='help-hint'] .tippy-arrow {
    color: var(--color-green-700);
}

span.icon + h2.text-500 {
  margin-top: 1rem; /* Adjust this value for more/less space */
}

/*popup*/

.popup {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.6);
    display: flex;
    justify-content: center;
    align-items: center;
    transition: opacity 0.3s ease, visibility 0.3s ease;
    padding: 20px 10px;
}

.popup-content {
    background: #fff;
    padding: 12px;
    border-radius: 8px;
    width: calc(80% / 1.5);
    height: calc(75% / 1.5);
    max-width: 100%;
    overflow-y: auto;
    padding-top: 0;

/* scale hack: */
  transform: scale(1.5);             /* 120% “zoom” */
  transition: transform 0.3s ease;   /* animate it if you like */
}


.popup-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    padding-bottom: 18px;
    position: sticky;
    top: 0;
    padding-top: 12px;
    background: #fff;
    z-index: 20;
}

    .popup-header h2 {
        color: #335545;
        font-size: 14px;
        font-style: normal;
        font-weight: 700;
    }

.inner-block {
    padding: 10px 16px;
    border-radius: 8px;
    background: #F9FAFA;
}

.popup-content-block:first-child h4 {
    margin-bottom: 10px;
    margin-top: 0;
}

.popup-content-block h4 {
    margin: 10px 0;
    color: #335545;
    font-size: 12px;
    font-weight: 700;
    line-height: 115%;
}

.inner-block p,
.inner-block ul li {
    color: #191919;
    text-align: justify;
    font-size: 10px;
    font-style: normal;
    font-weight: 400;
    line-height: 150%;
}

.inner-block ul {
    list-style: decimal;
    padding-left: 10px;
}

    .inner-block ul.list-alpha {
        list-style-type: lower-alpha;
    }

    .inner-block ul.list-roman {
        list-style-type: lower-roman;
    }

.closePopupBtn {
    cursor: pointer
}

/********************************/
/*       Data table styles      */
/********************************/

.datatable-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 10px;
    width: 100%;
}

#myDataTable td, #myDataTable th {
    text-align: left !important;
}

#myDataTable_filter > label > input[type=search] {
    min-width: 350px;
    margin-left: 5px;
}

#myDataTable_length > label > select {
    padding-right: 35px;
}

.dataTables_wrapper thead th {
    color: white !important;
    font-family: inherit !important;
    font-size: 1em;
    vertical-align: top !important;
}

.dataTables_wrapper thead th select {
    color: black !important;
    font-family: inherit !important;
    font-size: 1em;
    padding-right: 30px;
    border-radius: 3px;
    border: 1px solid #ccc;
}

#myDataTable thead th {
    text-align: left !important;
    font-weight: bold;
    vertical-align: top !important;
}

#myDataTable tbody tr {
    cursor: pointer;
}

/* Hide sorting icons for non-sortable columns */
#myDataTable thead th.sorting_disabled .sorting {
    display: none !important;
}

/* --- Wizard Step Sliding Animation --- */
.wizard-step {
    position: absolute;
    width: 100%;
    top: 0;
    left: 0;
    transition: transform 0.5s ease-out, opacity 0.5s ease-out;
    opacity: 0;
    transform: translateX(100%);
    z-index: 1;
}
.wizard-step.is-active {
    transform: translateX(0);
    opacity: 1;
    z-index: 10;
}
.wizard-step.enter-from-right {
    transform: translateX(100%);
    opacity: 0;
    z-index: 5;
    will-change: transform, opacity;
}
.wizard-step.enter-from-left {
    transform: translateX(-100%);
    opacity: 0;
    z-index: 5;
    will-change: transform, opacity;
}
.wizard-step.leave-to-left {
    transform: translateX(-100%);
    opacity: 0;
    z-index: 5;
    will-change: transform, opacity;
}
.wizard-step.leave-to-right {
    transform: translateX(100%);
    opacity: 0;
    z-index: 5;
    will-change: transform, opacity;
}

/* Wizard Progress Step Indicator Styles */
.step-indicator {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    font-size: 0.875rem;
    line-height: 1.25rem;
    font-weight: 500;
}
.current-step-indicator {
    background-color: #047857;
    color: white;
}
.pending-step-indicator {
    background-color: #D1D5DB;
    color: #374151;
}

.summary-list__items li.completed-step .icon svg {
    color: #059669;
}

.summary-list__items .icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
}
.summary-list__items .icon svg,
.summary-list__items .icon .step-indicator {
    width: 24px;
    height: 24px;
}

/* START: ADD THESE STYLES FOR THE NEW TOP PROGRESS BAR */
.confirm-details-progress-container {
    padding-block: 1rem;
    border-bottom: 1px solid #e0ebe3; /* var(--color-green-100) */
    margin-bottom: 1.5rem;
}

.confirm-details-progress-bar {
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 1rem;
    overflow-x: auto;
    padding-bottom: 0.5rem;
    padding-left: 0.5rem;
    padding-right: 0.5rem;
}

.progress-step-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    flex-basis: auto;
    flex-grow: 0;
    flex-shrink: 0;
    min-width: 90px;
    position: relative;
}

.progress-step-indicator-container {
    display: flex;
    align-items: center;
    width: 100%;
    justify-content: center;
    position: relative;
}

.progress-step-circle {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 500;
    font-size: 0.875rem;
    border: 2px solid #C3D7CA; /* var(--color-green-200) */
    background-color: #FFFFFF; /* var(--color-white) */
    color: #3A614E; /* var(--color-green-600) */
    z-index: 1;
    transition: background-color 0.3s ease, border-color 0.3s ease, color 0.3s ease;
}

.progress-step-item.current .progress-step-circle {
    border-color: #3A614E; /* var(--color-green-600) */
    background-color: #3A614E; /* var(--color-green-600) */
    color: #FFFFFF; /* var(--color-white) */
}

.progress-step-item.completed .progress-step-circle {
    border-color: #3A614E; /* var(--color-green-600) */
    background-color: #3A614E; /* var(--color-green-600) */
    color: #FFFFFF; /* var(--color-white) */
}
.progress-step-item.completed .progress-step-circle svg {
    width: 16px;
    height: 16px;
}

.progress-step-line {
    height: 2px;
    background-color: #C3D7CA; /* var(--color-green-200) */
    position: absolute;
    left: 50%;
    width: calc(100% + 1rem); /* Was right: -50%; Adjusted to item width + gap */
    top: 13px; /* (28px circle height / 2) - (2px line height / 2) = 13px */
    z-index: 0;
    transition: background-color 0.3s ease;
}

.progress-step-item:last-child .progress-step-line {
    display: none;
}

.progress-step-item.completed .progress-step-line {
    background-color: #3A614E; /* var(--color-green-600) */
}

.progress-step-label {
    font-size: 0.8rem; /* Slightly increased for readability */
    color: #4E7B64; /* var(--color-green-500) */
    margin-top: 0.5rem;
    line-height: 1.3; /* Adjusted for better readability */
    max-width: 80px; /* Max width for label on small screens */
    word-wrap: break-word; /* Ensure long words break */
    transition: color 0.3s ease, font-weight 0.3s ease;
}

.progress-step-item.current .progress-step-label {
    color: #335545; /* var(--color-green-700) */
    font-weight: 600;
}

.progress-step-item.completed .progress-step-label {
    color: #273E34; /* var(--color-green-800) */
}

/* Styles for larger devices (e.g., tablets and desktops) */
@media (min-width: 768px) {
    .confirm-details-progress-bar {
        justify-content: space-between; /* Distribute items evenly */
        overflow-x: visible; /* No horizontal scroll needed */
        /* gap: 1rem; */ /* Keep gap or adjust if space-between needs help */
        /* padding-left and padding-right can remain 0.5rem or be adjusted */
    }

    .progress-step-item {
        flex-grow: 1; /* Allow items to grow */
        flex-basis: 0; /* Distribute space based on growth factor */
        min-width: 110px; /* Slightly larger min-width for desktop items */
    }

    /* The progress-step-line width calculation calc(100% + 1rem) should still work
       as 100% refers to the new flexible width of the item. */

    .progress-step-label {
        max-width: 100px; /* Allow more space for labels on larger screens */
    }
}
/* END: ADD THESE STYLES FOR THE NEW TOP PROGRESS BAR */

.wizard-button-bar {
    position: sticky;
    bottom: var(--size-600); /* Increased from 0 */
    background-color: var(--color-white); /* Ensures content doesn't show through */
    padding: var(--size-300) var(--size-400); /* Adjust padding as needed */
    z-index: 50; /* Keeps it above other content */
    box-shadow: 0 -2px 5px rgba(0,0,0,0.1); /* Optional: adds visual separation */
    left: 0;
    right: 0;
    width: 100%; 
}

.wizard-step-content-container {
    min-height: 54vh; /* Re-introduced a responsive min-height */
    padding-bottom: calc(4rem + var(--size-600)); /* Refined padding to reduce overall scroll */
    overflow-y: auto;
}

/* Staff dashboard tabs */
.tabs {
    --tabs-border: var(--color-green-100);
}

.tabs__list {
    display: inline-flex;
    flex-wrap: wrap;
    gap: var(--size-200);
    border-bottom: 1px solid var(--tabs-border);
    margin-bottom: var(--size-400);
}

.tabs__tab {
    appearance: none;
    border: none;
    background: transparent;
    padding: 0.5em 1.25em;
    border-radius: 9999px; /* pill */
    font-weight: var(--font-medium);
    color: var(--color-green-600);
    cursor: pointer;
    line-height: var(--leading-none);
    transition: .3s var(--transition-timing-ease-in-out);
    transition-property: color, background-color, box-shadow, transform;
}

.tabs__tab:hover {
    background: var(--color-green-50);
    transform: translateY(-1px);
}

.tabs__tab.is-active {
    background: var(--color-green-700);
    color: var(--color-white);
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.12);
}

.tabs__panel {
    display: none;
}

.tabs__panel.is-active {
    display: block;
}

/* Trend chart toggle styles */
.trend-toggle-group {
    display: flex;
    flex-wrap: wrap;
    gap: var(--size-200);
}

.trend-toggle-option {
    position: relative;
}

.trend-toggle-option input[type="radio"] {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.trend-toggle-option label {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.4em 0.9em;
    border-radius: 9999px;
    border: 1px solid var(--color-green-200);
    background: var(--color-white);
    cursor: pointer;
    font-size: var(--text-300);
    color: var(--color-green-600);
    transition: .2s var(--transition-timing-ease-in-out);
    transition-property: background-color, color, border-color, box-shadow, transform;
}

.trend-toggle-option label:hover {
    background: var(--color-green-50);
}

.trend-toggle-option input[type="radio"]:checked + label {
    background: var(--color-green-700);
    color: var(--color-white);
    border-color: var(--color-green-700);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.12);
}

.popup-inner-block {
  padding-top: 10px;
}

.popup-definitions-table {
  overflow: hidden;
  overflow-x: auto;
  padding-bottom: 10px;
}

/* ✅ scoped to only this popup table */
.popup-definitions-table table {
  border-collapse: separate;
  border-spacing: 0;
  width: 100%;
  min-width: 500px;
  margin-bottom: 0;
}

.popup-definitions-table th,
.popup-definitions-table td {
  padding: 8px 10px;
  text-align: left;
  font-size: 10px;
}

.popup-definitions-table td {
  background-color: var(--color-green-25);
}

.popup-definitions-table th {
  background-color: var(--color-green-25);;
}

.popup-definitions-table th:nth-child(1),
.popup-definitions-table th:nth-child(4),
.popup-definitions-table td:nth-child(1),
.popup-definitions-table td:nth-child(4) {
  width: 35%;
}

/* Tighten vertical spacing inside Material Damage (QuoteResult) */
.md-tight-spacing { 
  --flow-space: var(--size-100); /* reduce default flow gap globally within MD */
}

/* Make definition lists tighter (used with class 'dl-tight' already in markup) */
.definition-list.dl-tight .definition-list__item,
.md-tight-spacing .definition-list__item {
  padding: var(--size-100) 0;
}

/* Reduce padding of panels only within the MD block */
.md-tight-spacing .p-400 { padding: var(--size-200); }
.md-tight-spacing .p-300 { padding: var(--size-200); }
.md-tight-spacing .p-200 { padding: var(--size-100); }
.md-tight-spacing .p-100 { padding: var(--size-50); }

/* Reduce list item spacing within flows under MD */
.md-tight-spacing ul.flow > li + li { 
  margin-top: var(--size-100);
}

/* Ensure summaries don't introduce extra spacing */
.md-tight-spacing .accordion-item > summary { 
  margin: 0;
}

/* Force-compact spacing in MD section on QuoteResult */
.md-tight-spacing [class*="flow-space-"] { --flow-space: var(--size-50) !important; }
.md-tight-spacing .flow > * + * { margin-top: var(--size-50) !important; }
.md-tight-spacing details > div[class*="p-"] { padding: var(--size-100) !important; }
.md-tight-spacing .definition-list__item { padding: var(--size-100) 0 !important; gap: var(--size-100) !important; }
.md-tight-spacing .accordion-item > summary {
  margin: 0 !important;
  padding: 0 !important;
  justify-content: flex-start !important; /* keep title left; push value+chevron to the right */
}

/* Remove default heading margins inside the compact MD accordion
   Keep horizontal margins so .mr-auto still pushes the value to the right */
.md-tight-spacing h5,
.md-tight-spacing h6,
.md-tight-spacing .accordion-item > summary h5,
.md-tight-spacing .accordion-item > summary h6 {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}
/* Ensure .mr-auto works inside MD summaries even if other rules compete */
.md-tight-spacing .mr-auto { margin-right: auto !important; }

/* Lighter green backgrounds for MD sub-sections */
.bg-md-building { background-color: var(--color-green-25); }
.bg-md-boats    { background-color: var(--color-green-25); }

/* Boats list – name left; mooring + value to the right, compact rows */
.boat-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.boat-list .md-boat-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--size-200) var(--size-200);
  border-top: 1px solid var(--color-green-100);
}
.boat-list .md-boat-row:first-child { border-top: 0; }
.md-boat-row .md-boat-name  { font-weight: var(--font-bold); }
.md-boat-row .md-boat-meta  { display: inline-flex; gap: var(--size-200); color: var(--color-green-700); }
.md-boat-row .md-boat-value { min-width: 7ch; text-align: right; }

.date-parts {
    border: 0;
    padding: 0;
    margin: 0;
}

.date-parts__legend {
    font-weight: var(--font-medium);
    margin-bottom: var(--size-100);
}

.date-parts__hint {
    color: var(--color-green-600);
    font-size: var(--text-300);
    margin-bottom: var(--size-200);
}

.date-parts .status-label {
    margin-bottom: 0;
}

.date-parts__error,
.date-parts__client-error {
    margin-top: var(--size-200);
    margin-bottom: 0;
}

.date-parts .status-label[hidden] {
    display: none !important;
}

.date-parts__row {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
}

.date-parts__item {
    display: flex;
    flex-direction: column;
    gap: var(--size-100);
}

.date-parts__item input {
    width: 3rem;
}

.date-parts__item--year input {
    width: 6rem;
}

.date-parts__item input[aria-invalid="true"] {
    border-color: var(--color-red-700);
    color: var(--color-red-700);
}

@media (max-width: 480px) {
    .date-parts__row {
        gap: 0.75rem;
    }
}

.width100{
    width: 100%;
}
