/*!****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[2].use[1]!./node_modules/next/dist/build/webpack/loaders/next-font-loader/index.js??ruleSet[1].rules[14].oneOf[2].use[2]!./node_modules/next/font/google/target.css?{"path":"src/app/layout.tsx","import":"Lato","arguments":[{"subsets":["latin"],"weight":["300","400","700"],"display":"swap"}],"variableName":"lato"} ***!
  \****************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
/* latin-ext */
@font-face {
  font-family: 'Lato';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url(/_next/static/media/9ce3050912c26948-s.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Lato';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url(/_next/static/media/155cae559bbd1a77-s.p.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* latin-ext */
@font-face {
  font-family: 'Lato';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/_next/static/media/cce080f35d014443-s.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Lato';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/_next/static/media/4de1fea1a954a5b6-s.p.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* latin-ext */
@font-face {
  font-family: 'Lato';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/_next/static/media/39969fcf98a3026e-s.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Lato';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/_next/static/media/6d664cce900333ee-s.p.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}@font-face {font-family: 'Lato Fallback';src: local("Arial");ascent-override: 101.03%;descent-override: 21.80%;line-gap-override: 0.00%;size-adjust: 97.69%
}.__className_06d0dd {font-family: 'Lato', 'Lato Fallback';font-style: normal
}

/*!*****************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[5].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[14].oneOf[5].use[3]!./src/app/components/Accessibility/Accessibility.module.css ***!
  \*****************************************************************************************************************************************************************************************************************************************************************************************************/
/* Skip Links - visible only on focus for keyboard users */
.Accessibility_skipLinks__1YFjW {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 9999;
    padding: 0.5rem;
}

.Accessibility_skipLink__oPjEB {
    position: absolute;
    left: -9999px;
    top: auto;
    width: 1px;
    height: 1px;
    overflow: hidden;
    padding: 1rem 1.5rem;
    background: var(--agr-primary);
    color: white;
    font-weight: 600;
    text-decoration: none;
    border-radius: 0 0 4px 0;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}

.Accessibility_skipLink__oPjEB:focus {
    position: fixed;
    left: 0;
    top: 0;
    width: auto;
    height: auto;
    overflow: visible;
    outline: 3px solid var(--agr-accent);
    outline-offset: 2px;
}

/* Screen reader only content */
.Accessibility_srOnly__rpQiS {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* Keyboard shortcuts button */
.Accessibility_shortcutsButton__u3b_9 {
    color: var(--agr-gray-600) !important;
}

.Accessibility_shortcutsButton__u3b_9:hover {
    background: var(--agr-gray-100) !important;
}

.Accessibility_shortcutsButton__u3b_9:focus {
    box-shadow: 0 0 0 3px var(--agr-primary-light) !important;
}

/* Keyboard shortcuts dialog */
.Accessibility_shortcutsDialog__5wkFG {
    max-width: 600px;
}

.Accessibility_shortcutsContent__6FQAs {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.Accessibility_shortcutCategory__MXxl0 h3 {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--agr-gray-500);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin: 0 0 0.75rem 0;
    padding-bottom: 0.5rem;
    border-bottom: 1px solid var(--agr-gray-200);
}

.Accessibility_shortcutList__tf4RT {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    margin: 0;
}

.Accessibility_shortcutItem__P8GLo {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.5rem 0;
}

.Accessibility_shortcutKeys__ccyE5 {
    display: flex;
    align-items: center;
    gap: 0.25rem;
}

.Accessibility_kbd__CaqBn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 1.75rem;
    height: 1.75rem;
    padding: 0 0.5rem;
    font-family: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;
    font-size: 0.75rem;
    font-weight: 500;
    background: var(--agr-gray-100);
    border: 1px solid var(--agr-gray-300);
    border-radius: 4px;
    box-shadow: 0 1px 0 1px var(--agr-gray-200);
    color: var(--agr-gray-700);
}

.Accessibility_keyPlus__nyijj {
    color: var(--agr-gray-400);
    font-size: 0.75rem;
    margin: 0 0.125rem;
}

.Accessibility_shortcutDescription__L69GM {
    color: var(--agr-gray-600);
    font-size: 0.875rem;
    margin: 0;
}

/* High contrast mode adjustments for local styles */
@media (prefers-contrast: high) {
    .Accessibility_skipLink__oPjEB:focus {
        outline: 4px solid #000;
        outline-offset: 2px;
    }

    .Accessibility_kbd__CaqBn {
        border: 2px solid #000;
    }
}

/* Reduced motion preferences for local styles */
@media (prefers-reduced-motion: reduce) {
    .Accessibility_skipLink__oPjEB {
        transition: none;
    }
}

/*!***************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[5].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[14].oneOf[5].use[3]!./src/app/components/Footer/Footer.module.css ***!
  \***************************************************************************************************************************************************************************************************************************************************************************************/
/* Footer Component Styles */

.Footer_footerContent__MEeaN {
    max-width: var(--agr-container-max-width);
    margin: 0 auto;
    padding: 0 var(--agr-spacing-md);
}

.Footer_footerGrid__YUOEr {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--agr-spacing-xl);
    padding-bottom: var(--agr-spacing-lg);
    border-bottom: 1px solid var(--agr-border-color);
}

.Footer_footerSection__pWiTw {
    text-align: left;
}

.Footer_sectionTitle__fFtzZ {
    font-size: var(--agr-font-size-base);
    font-weight: 600;
    color: var(--agr-primary-700);
    margin-bottom: var(--agr-spacing-md);
    margin-top: 0;
}

.Footer_sectionText__VZaw5 {
    font-size: var(--agr-font-size-sm);
    color: var(--agr-text-secondary);
    line-height: 1.6;
    margin: 0;
}

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

.Footer_linkList__ZYEWs li {
    margin-bottom: var(--agr-spacing-sm);
}

.Footer_linkList__ZYEWs a {
    font-size: var(--agr-font-size-sm);
    color: var(--agr-primary-600);
    text-decoration: none;
    transition: color 0.2s ease;
}

.Footer_linkList__ZYEWs a:hover {
    color: var(--agr-primary-800);
    text-decoration: underline;
}

.Footer_funding__FW7sO {
    padding: var(--agr-spacing-md) 0;
    text-align: center;
    border-bottom: 1px solid var(--agr-border-color);
}

.Footer_funding__FW7sO p {
    font-size: var(--agr-font-size-sm);
    color: var(--agr-text-muted);
    margin: 0;
}

.Footer_copyright__SAsag {
    padding-top: var(--agr-spacing-md);
    text-align: center;
}

.Footer_copyright__SAsag p {
    font-size: var(--agr-font-size-sm);
    color: var(--agr-text-secondary);
    margin: 0;
}

.Footer_copyright__SAsag a {
    color: var(--agr-primary-600);
}

/* Tablet */
@media (max-width: 992px) {
    .Footer_footerGrid__YUOEr {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--agr-spacing-lg);
    }

    .Footer_footerSection__pWiTw:first-child {
        grid-column: span 2;
    }
}

/* Mobile */
@media (max-width: 576px) {
    .Footer_footerGrid__YUOEr {
        grid-template-columns: 1fr;
        gap: var(--agr-spacing-lg);
    }

    .Footer_footerSection__pWiTw:first-child {
        grid-column: span 1;
    }

    .Footer_footerSection__pWiTw {
        text-align: center;
    }

    .Footer_linkList__ZYEWs {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        gap: var(--agr-spacing-sm) var(--agr-spacing-md);
    }

    .Footer_linkList__ZYEWs li {
        margin-bottom: 0;
    }
}

/*!***************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[5].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[14].oneOf[5].use[3]!./src/app/components/Header/Header.module.css ***!
  \***************************************************************************************************************************************************************************************************************************************************************************************/
/* Header Component Styles */

.Header_logo__xmjV5 {
    display: flex;
    align-items: center;
    gap: var(--agr-spacing-sm);
    color: white;
    text-decoration: none;
}

.Header_logo__xmjV5:hover {
    color: white;
    text-decoration: none;
}

.Header_logo__xmjV5 svg {
    flex-shrink: 0;
}

.Header_logoText__4bp_H {
    display: flex;
    flex-direction: column;
    line-height: 1.1;
}

.Header_logoTitle___g_p6 {
    font-size: 1.4rem;
    font-weight: 700;
    letter-spacing: 0.05em;
}

.Header_logoSubtitle__YrNoO {
    font-size: 0.7rem;
    font-weight: 400;
    opacity: 0.85;
    letter-spacing: 0.02em;
}

/* Navigation */
.Header_nav__0VWUe {
    display: flex;
    gap: var(--agr-spacing-lg);
}

/* Mobile menu button - hidden on desktop */
.Header_mobileMenuButton__sdX00 {
    display: none;
    flex-direction: column;
    justify-content: space-around;
    width: 28px;
    height: 24px;
    background: transparent;
    border: none;
    cursor: pointer;
    padding: 0;
    z-index: 1001;
}

.Header_hamburgerLine__DwepX {
    display: block;
    width: 100%;
    height: 3px;
    background-color: white;
    border-radius: 2px;
    transition: all 0.3s ease;
    transform-origin: center;
}

/* Hamburger animation when open */
.Header_hamburgerLine__DwepX.Header_open__Rz4Pa:nth-child(1) {
    transform: translateY(7px) rotate(45deg);
}

.Header_hamburgerLine__DwepX.Header_open__Rz4Pa:nth-child(2) {
    opacity: 0;
    transform: scaleX(0);
}

.Header_hamburgerLine__DwepX.Header_open__Rz4Pa:nth-child(3) {
    transform: translateY(-7px) rotate(-45deg);
}

/* Mobile Styles */
@media (max-width: 768px) {
    .Header_logoSubtitle__YrNoO {
        display: none;
    }

    .Header_mobileMenuButton__sdX00 {
        display: flex;
    }

    .Header_nav__0VWUe {
        position: fixed;
        top: var(--agr-header-height);
        left: 0;
        right: 0;
        background-color: var(--agr-primary-800);
        flex-direction: column;
        padding: var(--agr-spacing-md);
        gap: 0;
        transform: translateY(-100%);
        opacity: 0;
        visibility: hidden;
        transition: transform 0.3s ease, opacity 0.3s ease, visibility 0.3s ease;
        box-shadow: var(--agr-shadow-lg);
        z-index: 1000;
    }

    .Header_navOpen__1Ip39 {
        transform: translateY(0);
        opacity: 1;
        visibility: visible;
    }

    .Header_nav__0VWUe a {
        padding: var(--agr-spacing-md) var(--agr-spacing-lg) !important;
        border-bottom: 1px solid rgba(255, 255, 255, 0.1);
        width: 100%;
        text-align: left;
    }

    .Header_nav__0VWUe a:last-child {
        border-bottom: none;
    }
}

/* Tablet adjustments */
@media (max-width: 992px) and (min-width: 769px) {
    .Header_logoSubtitle__YrNoO {
        font-size: 0.6rem;
    }

    .Header_nav__0VWUe {
        gap: var(--agr-spacing-md);
    }
}

/*!************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[10].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[14].oneOf[10].use[3]!./node_modules/primeicons/primeicons.css ***!
  \************************************************************************************************************************************************************************************************************************************************************************************/
@font-face {
    font-family: 'primeicons';
    font-display: block;
    src: url(/_next/static/media/primeicons.8ca441e1.eot);
    src: url(/_next/static/media/primeicons.8ca441e1.eot?#iefix) format('embedded-opentype'), url(/_next/static/media/primeicons.e1a53edb.woff2) format('woff2'), url(/_next/static/media/primeicons.7f772274.woff) format('woff'), url(/_next/static/media/primeicons.310a7310.ttf) format('truetype'), url(/_next/static/media/primeicons.19e14e48.svg?#primeicons) format('svg');
    font-weight: normal;
    font-style: normal;
}

.pi {
    font-family: 'primeicons';
    speak: none;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    display: inline-block;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.pi:before {
    --webkit-backface-visibility:hidden;
    backface-visibility: hidden;
}

.pi-fw {
    width: 1.28571429em;
    text-align: center;
}

.pi-spin {
    -webkit-animation: fa-spin 2s infinite linear;
    animation: fa-spin 2s infinite linear;
}

@media (prefers-reduced-motion: reduce) {
  .pi-spin {
    -webkit-animation-delay: -1ms;
    animation-delay: -1ms;
    -webkit-animation-duration: 1ms;
    animation-duration: 1ms;
    -webkit-animation-iteration-count: 1;
    animation-iteration-count: 1;
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
    -webkit-transition-duration: 0s;
    transition-duration: 0s;
  }
}

@-webkit-keyframes fa-spin {
    0% {
        -webkit-transform: rotate(0deg);
        transform: rotate(0deg);
    }
    100% {
        -webkit-transform: rotate(359deg);
        transform: rotate(359deg);
    }
}

@keyframes fa-spin {
    0% {
        -webkit-transform: rotate(0deg);
        transform: rotate(0deg);
    }
    100% {
        -webkit-transform: rotate(359deg);
        transform: rotate(359deg);
    }
}

.pi-folder-plus:before {
    content: "\ea05";
}

.pi-receipt:before {
    content: "\ea06";
}

.pi-asterisk:before {
    content: "\ea07";
}

.pi-face-smile:before {
    content: "\ea08";
}

.pi-pinterest:before {
    content: "\ea09";
}

.pi-expand:before {
    content: "\ea0a";
}

.pi-pen-to-square:before {
    content: "\ea0b";
}

.pi-wave-pulse:before {
    content: "\ea0c";
}

.pi-turkish-lira:before {
    content: "\ea0d";
}

.pi-spinner-dotted:before {
    content: "\ea0e";
}

.pi-crown:before {
    content: "\ea0f";
}

.pi-pause-circle:before {
    content: "\ea10";
}

.pi-warehouse:before {
    content: "\ea11";
}

.pi-objects-column:before {
    content: "\ea12";
}

.pi-clipboard:before {
    content: "\ea13";
}

.pi-play-circle:before {
    content: "\ea14";
}

.pi-venus:before {
    content: "\ea15";
}

.pi-cart-minus:before {
    content: "\ea16";
}

.pi-file-plus:before {
    content: "\ea17";
}

.pi-microchip:before {
    content: "\ea18";
}

.pi-twitch:before {
    content: "\ea19";
}

.pi-building-columns:before {
    content: "\ea1a";
}

.pi-file-check:before {
    content: "\ea1b";
}

.pi-microchip-ai:before {
    content: "\ea1c";
}

.pi-trophy:before {
    content: "\ea1d";
}

.pi-barcode:before {
    content: "\ea1e";
}

.pi-file-arrow-up:before {
    content: "\ea1f";
}

.pi-mars:before {
    content: "\ea20";
}

.pi-tiktok:before {
    content: "\ea21";
}

.pi-arrow-up-right-and-arrow-down-left-from-center:before {
    content: "\ea22";
}

.pi-ethereum:before {
    content: "\ea23";
}

.pi-list-check:before {
    content: "\ea24";
}

.pi-thumbtack:before {
    content: "\ea25";
}

.pi-arrow-down-left-and-arrow-up-right-to-center:before {
    content: "\ea26";
}

.pi-equals:before {
    content: "\ea27";
}

.pi-lightbulb:before {
    content: "\ea28";
}

.pi-star-half:before {
    content: "\ea29";
}

.pi-address-book:before {
    content: "\ea2a";
}

.pi-chart-scatter:before {
    content: "\ea2b";
}

.pi-indian-rupee:before {
    content: "\ea2c";
}

.pi-star-half-fill:before {
    content: "\ea2d";
}

.pi-cart-arrow-down:before {
    content: "\ea2e";
}

.pi-calendar-clock:before {
    content: "\ea2f";
}

.pi-sort-up-fill:before {
    content: "\ea30";
}

.pi-sparkles:before {
    content: "\ea31";
}

.pi-bullseye:before {
    content: "\ea32";
}

.pi-sort-down-fill:before {
    content: "\ea33";
}

.pi-graduation-cap:before {
    content: "\ea34";
}

.pi-hammer:before {
    content: "\ea35";
}

.pi-bell-slash:before {
    content: "\ea36";
}

.pi-gauge:before {
    content: "\ea37";
}

.pi-shop:before {
    content: "\ea38";
}

.pi-headphones:before {
    content: "\ea39";
}

.pi-eraser:before {
    content: "\ea04";
}

.pi-stopwatch:before {
    content: "\ea01";
}

.pi-verified:before {
    content: "\ea02";
}

.pi-delete-left:before {
    content: "\ea03";
}

.pi-hourglass:before {
    content: "\e9fe";
}

.pi-truck:before {
    content: "\ea00";
}

.pi-wrench:before {
    content: "\e9ff";
}

.pi-microphone:before {
    content: "\e9fa";
}

.pi-megaphone:before {
    content: "\e9fb";
}

.pi-arrow-right-arrow-left:before {
    content: "\e9fc";
}

.pi-bitcoin:before {
    content: "\e9fd";
}

.pi-file-edit:before {
    content: "\e9f6";
}

.pi-language:before {
    content: "\e9f7";
}

.pi-file-export:before {
    content: "\e9f8";
}

.pi-file-import:before {
    content: "\e9f9";
}

.pi-file-word:before {
    content: "\e9f1";
}

.pi-gift:before {
    content: "\e9f2";
}

.pi-cart-plus:before {
    content: "\e9f3";
}

.pi-thumbs-down-fill:before {
    content: "\e9f4";
}

.pi-thumbs-up-fill:before {
    content: "\e9f5";
}

.pi-arrows-alt:before {
    content: "\e9f0";
}

.pi-calculator:before {
    content: "\e9ef";
}

.pi-sort-alt-slash:before {
    content: "\e9ee";
}

.pi-arrows-h:before {
    content: "\e9ec";
}

.pi-arrows-v:before {
    content: "\e9ed";
}

.pi-pound:before {
    content: "\e9eb";
}

.pi-prime:before {
    content: "\e9ea";
}

.pi-chart-pie:before {
    content: "\e9e9";
}

.pi-reddit:before {
    content: "\e9e8";
}

.pi-code:before {
    content: "\e9e7";
}

.pi-sync:before {
    content: "\e9e6";
}

.pi-shopping-bag:before {
    content: "\e9e5";
}

.pi-server:before {
    content: "\e9e4";
}

.pi-database:before {
    content: "\e9e3";
}

.pi-hashtag:before {
    content: "\e9e2";
}

.pi-bookmark-fill:before {
    content: "\e9df";
}

.pi-filter-fill:before {
    content: "\e9e0";
}

.pi-heart-fill:before {
    content: "\e9e1";
}

.pi-flag-fill:before {
    content: "\e9de";
}

.pi-circle:before {
    content: "\e9dc";
}

.pi-circle-fill:before {
    content: "\e9dd";
}

.pi-bolt:before {
    content: "\e9db";
}

.pi-history:before {
    content: "\e9da";
}

.pi-box:before {
    content: "\e9d9";
}

.pi-at:before {
    content: "\e9d8";
}

.pi-arrow-up-right:before {
    content: "\e9d4";
}

.pi-arrow-up-left:before {
    content: "\e9d5";
}

.pi-arrow-down-left:before {
    content: "\e9d6";
}

.pi-arrow-down-right:before {
    content: "\e9d7";
}

.pi-telegram:before {
    content: "\e9d3";
}

.pi-stop-circle:before {
    content: "\e9d2";
}

.pi-stop:before {
    content: "\e9d1";
}

.pi-whatsapp:before {
    content: "\e9d0";
}

.pi-building:before {
    content: "\e9cf";
}

.pi-qrcode:before {
    content: "\e9ce";
}

.pi-car:before {
    content: "\e9cd";
}

.pi-instagram:before {
    content: "\e9cc";
}

.pi-linkedin:before {
    content: "\e9cb";
}

.pi-send:before {
    content: "\e9ca";
}

.pi-slack:before {
    content: "\e9c9";
}

.pi-sun:before {
    content: "\e9c8";
}

.pi-moon:before {
    content: "\e9c7";
}

.pi-vimeo:before {
    content: "\e9c6";
}

.pi-youtube:before {
    content: "\e9c5";
}

.pi-flag:before {
    content: "\e9c4";
}

.pi-wallet:before {
    content: "\e9c3";
}

.pi-map:before {
    content: "\e9c2";
}

.pi-link:before {
    content: "\e9c1";
}

.pi-credit-card:before {
    content: "\e9bf";
}

.pi-discord:before {
    content: "\e9c0";
}

.pi-percentage:before {
    content: "\e9be";
}

.pi-euro:before {
    content: "\e9bd";
}

.pi-book:before {
    content: "\e9ba";
}

.pi-shield:before {
    content: "\e9b9";
}

.pi-paypal:before {
    content: "\e9bb";
}

.pi-amazon:before {
    content: "\e9bc";
}

.pi-phone:before {
    content: "\e9b8";
}

.pi-filter-slash:before {
    content: "\e9b7";
}

.pi-facebook:before {
    content: "\e9b4";
}

.pi-github:before {
    content: "\e9b5";
}

.pi-twitter:before {
    content: "\e9b6";
}

.pi-step-backward-alt:before {
    content: "\e9ac";
}

.pi-step-forward-alt:before {
    content: "\e9ad";
}

.pi-forward:before {
    content: "\e9ae";
}

.pi-backward:before {
    content: "\e9af";
}

.pi-fast-backward:before {
    content: "\e9b0";
}

.pi-fast-forward:before {
    content: "\e9b1";
}

.pi-pause:before {
    content: "\e9b2";
}

.pi-play:before {
    content: "\e9b3";
}

.pi-compass:before {
    content: "\e9ab";
}

.pi-id-card:before {
    content: "\e9aa";
}

.pi-ticket:before {
    content: "\e9a9";
}

.pi-file-o:before {
    content: "\e9a8";
}

.pi-reply:before {
    content: "\e9a7";
}

.pi-directions-alt:before {
    content: "\e9a5";
}

.pi-directions:before {
    content: "\e9a6";
}

.pi-thumbs-up:before {
    content: "\e9a3";
}

.pi-thumbs-down:before {
    content: "\e9a4";
}

.pi-sort-numeric-down-alt:before {
    content: "\e996";
}

.pi-sort-numeric-up-alt:before {
    content: "\e997";
}

.pi-sort-alpha-down-alt:before {
    content: "\e998";
}

.pi-sort-alpha-up-alt:before {
    content: "\e999";
}

.pi-sort-numeric-down:before {
    content: "\e99a";
}

.pi-sort-numeric-up:before {
    content: "\e99b";
}

.pi-sort-alpha-down:before {
    content: "\e99c";
}

.pi-sort-alpha-up:before {
    content: "\e99d";
}

.pi-sort-alt:before {
    content: "\e99e";
}

.pi-sort-amount-up:before {
    content: "\e99f";
}

.pi-sort-amount-down:before {
    content: "\e9a0";
}

.pi-sort-amount-down-alt:before {
    content: "\e9a1";
}

.pi-sort-amount-up-alt:before {
    content: "\e9a2";
}

.pi-palette:before {
    content: "\e995";
}

.pi-undo:before {
    content: "\e994";
}

.pi-desktop:before {
    content: "\e993";
}

.pi-sliders-v:before {
    content: "\e991";
}

.pi-sliders-h:before {
    content: "\e992";
}

.pi-search-plus:before {
    content: "\e98f";
}

.pi-search-minus:before {
    content: "\e990";
}

.pi-file-excel:before {
    content: "\e98e";
}

.pi-file-pdf:before {
    content: "\e98d";
}

.pi-check-square:before {
    content: "\e98c";
}

.pi-chart-line:before {
    content: "\e98b";
}

.pi-user-edit:before {
    content: "\e98a";
}

.pi-exclamation-circle:before {
    content: "\e989";
}

.pi-android:before {
    content: "\e985";
}

.pi-google:before {
    content: "\e986";
}

.pi-apple:before {
    content: "\e987";
}

.pi-microsoft:before {
    content: "\e988";
}

.pi-heart:before {
    content: "\e984";
}

.pi-mobile:before {
    content: "\e982";
}

.pi-tablet:before {
    content: "\e983";
}

.pi-key:before {
    content: "\e981";
}

.pi-shopping-cart:before {
    content: "\e980";
}

.pi-comments:before {
    content: "\e97e";
}

.pi-comment:before {
    content: "\e97f";
}

.pi-briefcase:before {
    content: "\e97d";
}

.pi-bell:before {
    content: "\e97c";
}

.pi-paperclip:before {
    content: "\e97b";
}

.pi-share-alt:before {
    content: "\e97a";
}

.pi-envelope:before {
    content: "\e979";
}

.pi-volume-down:before {
    content: "\e976";
}

.pi-volume-up:before {
    content: "\e977";
}

.pi-volume-off:before {
    content: "\e978";
}

.pi-eject:before {
    content: "\e975";
}

.pi-money-bill:before {
    content: "\e974";
}

.pi-images:before {
    content: "\e973";
}

.pi-image:before {
    content: "\e972";
}

.pi-sign-in:before {
    content: "\e970";
}

.pi-sign-out:before {
    content: "\e971";
}

.pi-wifi:before {
    content: "\e96f";
}

.pi-sitemap:before {
    content: "\e96e";
}

.pi-chart-bar:before {
    content: "\e96d";
}

.pi-camera:before {
    content: "\e96c";
}

.pi-dollar:before {
    content: "\e96b";
}

.pi-lock-open:before {
    content: "\e96a";
}

.pi-table:before {
    content: "\e969";
}

.pi-map-marker:before {
    content: "\e968";
}

.pi-list:before {
    content: "\e967";
}

.pi-eye-slash:before {
    content: "\e965";
}

.pi-eye:before {
    content: "\e966";
}

.pi-folder-open:before {
    content: "\e964";
}

.pi-folder:before {
    content: "\e963";
}

.pi-video:before {
    content: "\e962";
}

.pi-inbox:before {
    content: "\e961";
}

.pi-lock:before {
    content: "\e95f";
}

.pi-unlock:before {
    content: "\e960";
}

.pi-tags:before {
    content: "\e95d";
}

.pi-tag:before {
    content: "\e95e";
}

.pi-power-off:before {
    content: "\e95c";
}

.pi-save:before {
    content: "\e95b";
}

.pi-question-circle:before {
    content: "\e959";
}

.pi-question:before {
    content: "\e95a";
}

.pi-copy:before {
    content: "\e957";
}

.pi-file:before {
    content: "\e958";
}

.pi-clone:before {
    content: "\e955";
}

.pi-calendar-times:before {
    content: "\e952";
}

.pi-calendar-minus:before {
    content: "\e953";
}

.pi-calendar-plus:before {
    content: "\e954";
}

.pi-ellipsis-v:before {
    content: "\e950";
}

.pi-ellipsis-h:before {
    content: "\e951";
}

.pi-bookmark:before {
    content: "\e94e";
}

.pi-globe:before {
    content: "\e94f";
}

.pi-replay:before {
    content: "\e94d";
}

.pi-filter:before {
    content: "\e94c";
}

.pi-print:before {
    content: "\e94b";
}

.pi-align-right:before {
    content: "\e946";
}

.pi-align-left:before {
    content: "\e947";
}

.pi-align-center:before {
    content: "\e948";
}

.pi-align-justify:before {
    content: "\e949";
}

.pi-cog:before {
    content: "\e94a";
}

.pi-cloud-download:before {
    content: "\e943";
}

.pi-cloud-upload:before {
    content: "\e944";
}

.pi-cloud:before {
    content: "\e945";
}

.pi-pencil:before {
    content: "\e942";
}

.pi-users:before {
    content: "\e941";
}

.pi-clock:before {
    content: "\e940";
}

.pi-user-minus:before {
    content: "\e93e";
}

.pi-user-plus:before {
    content: "\e93f";
}

.pi-trash:before {
    content: "\e93d";
}

.pi-external-link:before {
    content: "\e93c";
}

.pi-window-maximize:before {
    content: "\e93b";
}

.pi-window-minimize:before {
    content: "\e93a";
}

.pi-refresh:before {
    content: "\e938";
}
  
.pi-user:before {
    content: "\e939";
}

.pi-exclamation-triangle:before {
    content: "\e922";
}

.pi-calendar:before {
    content: "\e927";
}

.pi-chevron-circle-left:before {
    content: "\e928";
}

.pi-chevron-circle-down:before {
    content: "\e929";
}

.pi-chevron-circle-right:before {
    content: "\e92a";
}

.pi-chevron-circle-up:before {
    content: "\e92b";
}

.pi-angle-double-down:before {
    content: "\e92c";
}

.pi-angle-double-left:before {
    content: "\e92d";
}

.pi-angle-double-right:before {
    content: "\e92e";
}

.pi-angle-double-up:before {
    content: "\e92f";
}

.pi-angle-down:before {
    content: "\e930";
}

.pi-angle-left:before {
    content: "\e931";
}

.pi-angle-right:before {
    content: "\e932";
}

.pi-angle-up:before {
    content: "\e933";
}

.pi-upload:before {
    content: "\e934";
}

.pi-download:before {
    content: "\e956";
}

.pi-ban:before {
    content: "\e935";
}

.pi-star-fill:before {
    content: "\e936";
}

.pi-star:before {
    content: "\e937";
}

.pi-chevron-left:before {
    content: "\e900";
}

.pi-chevron-right:before {
    content: "\e901";
}

.pi-chevron-down:before {
    content: "\e902";
}

.pi-chevron-up:before {
    content: "\e903";
}

.pi-caret-left:before {
    content: "\e904";
}

.pi-caret-right:before {
    content: "\e905";
}

.pi-caret-down:before {
    content: "\e906";
}

.pi-caret-up:before {
    content: "\e907";
}

.pi-search:before {
    content: "\e908";
}

.pi-check:before {
    content: "\e909";
}

.pi-check-circle:before {
    content: "\e90a";
}

.pi-times:before {
    content: "\e90b";
}

.pi-times-circle:before {
    content: "\e90c";
}

.pi-plus:before {
    content: "\e90d";
}

.pi-plus-circle:before {
    content: "\e90e";
}

.pi-minus:before {
    content: "\e90f";
}

.pi-minus-circle:before {
    content: "\e910";
}

.pi-circle-on:before {
    content: "\e911";
}

.pi-circle-off:before {
    content: "\e912";
}

.pi-sort-down:before {
    content: "\e913";
}

.pi-sort-up:before {
    content: "\e914";
}

.pi-sort:before {
    content: "\e915";
}

.pi-step-backward:before {
    content: "\e916";
}

.pi-step-forward:before {
    content: "\e917";
}

.pi-th-large:before {
    content: "\e918";
}

.pi-arrow-down:before {
    content: "\e919";
}

.pi-arrow-left:before {
    content: "\e91a";
}

.pi-arrow-right:before {
    content: "\e91b";
}

.pi-arrow-up:before {
    content: "\e91c";
}

.pi-bars:before {
    content: "\e91d";
}

.pi-arrow-circle-down:before {
    content: "\e91e";
}

.pi-arrow-circle-left:before {
    content: "\e91f";
}

.pi-arrow-circle-right:before {
    content: "\e920";
}

.pi-arrow-circle-up:before {
    content: "\e921";
}

.pi-info:before {
    content: "\e923";
}

.pi-info-circle:before {
    content: "\e924";
}

.pi-home:before {
    content: "\e925";
}

.pi-spinner:before {
    content: "\e926";
}

/*!*****************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[10].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[14].oneOf[10].use[3]!./src/app/globals.css ***!
  \*****************************************************************************************************************************************************************************************************************************************************************/
body {
    font-family: var(--font-family);
}

/* Global accessibility styles - enhanced focus indicators */
*:focus-visible {
    outline: 3px solid var(--agr-primary);
    outline-offset: 2px;
}

button:focus-visible,
.p-button:focus-visible {
    outline: 3px solid var(--agr-primary);
    outline-offset: 2px;
    box-shadow: 0 0 0 4px rgba(0, 123, 255, 0.25);
}

a:focus-visible {
    outline: 3px solid var(--agr-primary);
    outline-offset: 2px;
    border-radius: 2px;
}

input:focus-visible,
textarea:focus-visible,
select:focus-visible,
.p-inputtext:focus-visible {
    outline: 3px solid var(--agr-primary);
    outline-offset: 0;
    border-color: var(--agr-primary);
}

/* High contrast mode - global adjustments */
@media (prefers-contrast: high) {
    *:focus-visible {
        outline: 4px solid #000 !important;
        outline-offset: 3px !important;
    }
}

/* Reduced motion preferences - global adjustments */
@media (prefers-reduced-motion: reduce) {
    *:not(.agr-spinner),
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
}

/* PrimeReact dropdown panel z-index fix */
/* Ensures dropdown panels appear above other page content */
.p-dropdown-panel {
    z-index: 9999 !important;
}

/* Spinner animation for progress indicators */
@keyframes agr-spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

.agr-spinner {
    animation: agr-spin 1s linear infinite !important;
}

i.agr-spinner {
    display: inline-block;
    animation: agr-spin 1s linear infinite !important;
}

/* Fix blurry canvas rendering in Nightingale MSA */
nightingale-msa,
nightingale-msa canvas {
    image-rendering: -webkit-optimize-contrast;
    image-rendering: crisp-edges;
    image-rendering: pixelated;
}

#alignment-view-container canvas {
    image-rendering: -webkit-optimize-contrast;
    image-rendering: crisp-edges;
}

/*!**************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[10].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[14].oneOf[10].use[3]!./src/app/styles/agr-theme.css ***!
  \**************************************************************************************************************************************************************************************************************************************************************************/
/* AGR Design System for PAVI
 * Based on alliance-genome/agr_ui theme
 * https://github.com/alliance-genome/agr_ui
 */

/*
 * Standard Breakpoints (use these in @media queries)
 * ===================================================
 * --breakpoint-xs:  0      (mobile first base)
 * --breakpoint-sm:  576px  (small devices, phones landscape)
 * --breakpoint-md:  768px  (tablets)
 * --breakpoint-lg:  1024px (desktops)
 * --breakpoint-xl:  1280px (large desktops)
 *
 * Example usage:
 * @media (max-width: 768px) { ... }  - tablet and below
 * @media (max-width: 576px) { ... }  - mobile only
 * @media (min-width: 1024px) { ... } - desktop and up
 */

:root {
  /* Primary Color Palette (Blue) */
  --agr-primary-100: #dbeaf3;
  --agr-primary-200: #b6d5e8;
  --agr-primary-300: #8fc0dc;
  --agr-primary-400: #64acd1;
  --agr-primary-500: #2598c5;
  --agr-primary-600: #2681a6;
  --agr-primary-700: #256a88;
  --agr-primary-800: #22546c;
  --agr-primary-900: #1e4050;

  /* Accent Color Palette (Orange) */
  --agr-accent-100: #ffe8dc;
  --agr-accent-200: #ffd1b9;
  --agr-accent-300: #fbba96;
  --agr-accent-400: #f5a475;
  --agr-accent-500: #ed8d54;
  --agr-accent-600: #e47632;
  --agr-accent-700: #d95f02;
  --agr-accent-800: #aa4c0b;
  --agr-accent-900: #7e3a0f;

  /* Tertiary Color Palette (Purple) */
  --agr-tertiary-100: #f0e8f6;
  --agr-tertiary-200: #e1d2ec;
  --agr-tertiary-300: #d2bce3;
  --agr-tertiary-400: #c3a6da;
  --agr-tertiary-500: #b491d0;
  --agr-tertiary-600: #a47cc7;
  --agr-tertiary-700: #9467bd;
  --agr-tertiary-800: #755294;
  --agr-tertiary-900: #573e6d;

  /* Grayscale - WCAG AA compliant contrast ratios */
  --agr-gray-100: #f8f9fa;
  --agr-gray-200: #e9ecef;
  --agr-gray-300: #dee2e6;
  --agr-gray-400: #ced4da;
  --agr-gray-500: #8e959c; /* Darkened from #adb5bd for better contrast (4.5:1 on white) */
  --agr-gray-600: #5a6268; /* Darkened from #7f7f7f for AA compliance (5.9:1 on white) */
  --agr-gray-700: #495057;
  --agr-gray-800: #343a40;
  --agr-gray-900: #212529;

  /* Semantic Colors - WCAG AA compliant */
  --agr-primary: #2069a0; /* Primary brand color, AA compliant on white (4.9:1) */
  --agr-primary-light: #e8f4fc; /* Light primary for backgrounds */
  --agr-link-color: #2069a0; /* Darkened for 4.5:1 contrast on white */
  --agr-link-hover: #1a4f7a;
  --agr-text-primary: #212529;
  --agr-text-secondary: #5a6268; /* Matches gray-600 for AA compliance (5.9:1 on white) */
  --agr-text-muted: #545b62; /* Darkened from #6c757d for AA compliance (6.2:1 on white) */
  --agr-background: #ffffff;
  --agr-background-alt: #f8f9fa;
  --agr-border-color: #dee2e6;

  /* Status Colors - with text variants for WCAG AA compliance */
  --agr-success: #28a745;
  --agr-success-light: #dff0d8;
  --agr-success-dark: #155724; /* For text on success-light background (7:1 contrast) */
  --agr-warning: #ffc107;
  --agr-warning-light: #fff3cd;
  --agr-warning-dark: #856404; /* For text on warning-light background (5.5:1 contrast) */
  --agr-danger: #dc3545;
  --agr-danger-light: #f8d7da;
  --agr-danger-dark: #721c24; /* For text on danger-light background (7.5:1 contrast) */
  --agr-info: #17a2b8;
  --agr-info-light: #d1ecf1;
  --agr-info-dark: #0c5460; /* For text on info-light background (7:1 contrast) */
  --agr-error-light: #f8d7da; /* Alias for danger-light */
  --agr-error-dark: #721c24; /* Alias for danger-dark */

  /* Data Type Colors (for consistency with AGR) */
  --agr-data-gene: #256a88;
  --agr-data-disease: #d95f02;
  --agr-data-go: #9467bd;
  --agr-data-allele: #8c564b;

  /* Typography */
  --agr-font-family: 'Lato', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
  --agr-font-size-base: 0.9rem;
  --agr-font-size-sm: 0.8rem;
  --agr-font-size-lg: 1.1rem;
  --agr-font-size-h1: 2rem;
  --agr-font-size-h2: 1.5rem;
  --agr-font-size-h3: 1.25rem;
  --agr-font-size-h4: 1.1rem;
  --agr-line-height: 1.5;

  /* Spacing */
  --agr-spacing-xs: 0.25rem;
  --agr-spacing-sm: 0.5rem;
  --agr-spacing-md: 1rem;
  --agr-spacing-lg: 1.5rem;
  --agr-spacing-xl: 2rem;
  --agr-spacing-xxl: 3rem;

  /* Border Radius */
  --agr-radius-sm: 0.2rem;
  --agr-radius-md: 0.25rem;
  --agr-radius-lg: 0.5rem;

  /* Shadows */
  --agr-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.05);
  --agr-shadow-md: 0 4px 6px rgba(0, 0, 0, 0.1);
  --agr-shadow-lg: 0 10px 15px rgba(0, 0, 0, 0.1);

  /* Header/Navigation */
  --agr-header-bg: var(--agr-primary-700);
  --agr-header-text: rgba(255, 255, 255, 0.9);
  --agr-header-height: 60px;

  /* Container */
  --agr-container-max-width: 1200px;
}

/* Base Styles */
html {
  font-size: 16px;
}

body {
  font-family: var(--agr-font-family);
  font-size: var(--agr-font-size-base);
  line-height: var(--agr-line-height);
  color: var(--agr-text-primary);
  background-color: var(--agr-background);
  margin: 0;
  padding: 0;
}

/* Typography */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--agr-font-family);
  font-weight: 600;
  margin-bottom: var(--agr-spacing-md);
  color: var(--agr-text-primary);
}

h1 { font-size: var(--agr-font-size-h1); }
h2 { font-size: var(--agr-font-size-h2); }
h3 { font-size: var(--agr-font-size-h3); }
h4 { font-size: var(--agr-font-size-h4); }

a {
  color: var(--agr-link-color);
  text-decoration: none;
}

a:hover {
  color: var(--agr-link-hover);
  text-decoration: underline;
}

/* Layout Components */
.agr-container {
  max-width: var(--agr-container-max-width);
  margin: 0 auto;
  padding: 0 var(--agr-spacing-md);
}

.agr-page-content {
  padding: var(--agr-spacing-xl) 0;
  flex: 1 0 auto; /* Grow to fill space and push footer down, without forcing min-height */
}

/* Header */
.agr-header {
  background-color: var(--agr-header-bg);
  height: var(--agr-header-height);
  display: flex;
  align-items: center;
  position: sticky;
  top: 0;
  z-index: 1000;
  box-shadow: var(--agr-shadow-md);
}

.agr-header-content {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  max-width: var(--agr-container-max-width);
  margin: 0 auto;
  padding: 0 var(--agr-spacing-md);
}

.agr-header-logo {
  display: flex;
  align-items: center;
  gap: var(--agr-spacing-sm);
  color: white;
  font-size: 1.2rem;
  font-weight: 600;
  text-decoration: none;
}

.agr-header-logo:hover {
  color: white;
  text-decoration: none;
}

.agr-header-nav {
  display: flex;
  gap: var(--agr-spacing-lg);
}

.agr-header-nav a {
  color: var(--agr-header-text);
  font-weight: 500;
  padding: var(--agr-spacing-sm) var(--agr-spacing-md);
  border-radius: var(--agr-radius-md);
  transition: background-color 0.2s;
}

.agr-header-nav a:hover {
  background-color: rgba(255, 255, 255, 0.1);
  color: white;
  text-decoration: none;
}

/* Cards/Panels */
.agr-card {
  background: var(--agr-background);
  border: 1px solid var(--agr-border-color);
  border-radius: var(--agr-radius-lg);
  padding: var(--agr-spacing-lg);
  margin-bottom: var(--agr-spacing-lg);
  box-shadow: var(--agr-shadow-sm);
}

.agr-card-header {
  background-color: var(--agr-gray-100);
  padding: var(--agr-spacing-md) var(--agr-spacing-lg);
  border-bottom: 1px solid var(--agr-border-color);
  margin: calc(-1 * var(--agr-spacing-lg));
  margin-bottom: var(--agr-spacing-lg);
  border-radius: var(--agr-radius-lg) var(--agr-radius-lg) 0 0;
  font-weight: 600;
  color: var(--agr-primary-700);
}

/* Buttons - Override PrimeReact */
.p-button {
  background-color: var(--agr-primary-500) !important;
  border-color: var(--agr-primary-500) !important;
  font-family: var(--agr-font-family) !important;
  font-size: var(--agr-font-size-base) !important;
  border-radius: var(--agr-radius-md) !important;
  padding: var(--agr-spacing-sm) var(--agr-spacing-lg) !important;
}

.p-button:hover {
  background-color: var(--agr-primary-600) !important;
  border-color: var(--agr-primary-600) !important;
}

.p-button:focus {
  box-shadow: 0 0 0 2px var(--agr-primary-200) !important;
}

.p-button.p-button-secondary {
  background-color: var(--agr-gray-600) !important;
  border-color: var(--agr-gray-600) !important;
}

.p-button.p-button-secondary:hover {
  background-color: var(--agr-gray-700) !important;
  border-color: var(--agr-gray-700) !important;
}

.p-button.p-button-outlined {
  background-color: transparent !important;
  color: var(--agr-primary-500) !important;
  border: 1px solid var(--agr-primary-500) !important;
}

.p-button.p-button-outlined:hover {
  background-color: var(--agr-primary-100) !important;
}

/* Form Controls - Override PrimeReact */
.p-inputtext {
  font-family: var(--agr-font-family) !important;
  font-size: var(--agr-font-size-base) !important;
  border-color: var(--agr-border-color) !important;
  border-radius: var(--agr-radius-md) !important;
  padding: var(--agr-spacing-sm) var(--agr-spacing-md) !important;
}

.p-inputtext:focus {
  border-color: var(--agr-primary-500) !important;
  box-shadow: 0 0 0 2px var(--agr-primary-200) !important;
}

.p-dropdown {
  font-family: var(--agr-font-family) !important;
  border-color: var(--agr-border-color) !important;
  border-radius: var(--agr-radius-md) !important;
}

.p-dropdown:focus,
.p-dropdown.p-focus {
  border-color: var(--agr-primary-500) !important;
  box-shadow: 0 0 0 2px var(--agr-primary-200) !important;
}

/* AutoComplete */
.p-autocomplete-input {
  font-family: var(--agr-font-family) !important;
}

.p-autocomplete-panel {
  font-family: var(--agr-font-family) !important;
}

/* Tables */
.p-datatable {
  font-family: var(--agr-font-family) !important;
}

.p-datatable .p-datatable-thead > tr > th {
  background-color: var(--agr-gray-100) !important;
  color: var(--agr-text-primary) !important;
  font-weight: 600 !important;
  border-color: var(--agr-border-color) !important;
}

.p-datatable .p-datatable-tbody > tr > td {
  border-color: var(--agr-border-color) !important;
}

/* Messages/Alerts */
.agr-alert {
  padding: var(--agr-spacing-md) var(--agr-spacing-lg);
  border-radius: var(--agr-radius-md);
  margin-bottom: var(--agr-spacing-md);
}

.agr-alert-info {
  background-color: var(--agr-info-light);
  border: 1px solid var(--agr-info);
  color: var(--agr-info-dark);
}

.agr-alert-success {
  background-color: var(--agr-success-light);
  border: 1px solid var(--agr-success);
  color: var(--agr-success-dark);
}

.agr-alert-warning {
  background-color: var(--agr-warning-light);
  border: 1px solid var(--agr-warning);
  color: var(--agr-warning-dark);
}

.agr-alert-danger {
  background-color: var(--agr-danger-light);
  border: 1px solid var(--agr-danger);
  color: var(--agr-danger-dark);
}

/* Progress/Loading */
.p-progressbar {
  background-color: var(--agr-gray-200) !important;
  border-radius: var(--agr-radius-md) !important;
}

.p-progressbar .p-progressbar-value {
  background-color: var(--agr-primary-500) !important;
}

/* Footer */
.agr-footer {
  background-color: var(--agr-gray-100);
  border-top: 1px solid var(--agr-border-color);
  padding: var(--agr-spacing-lg) 0;
  margin-top: auto;
}

.agr-footer-content {
  max-width: var(--agr-container-max-width);
  margin: 0 auto;
  padding: 0 var(--agr-spacing-md);
  text-align: center;
  color: var(--agr-text-secondary);
  font-size: var(--agr-font-size-sm);
}

.agr-footer a {
  color: var(--agr-primary-600);
}

/* Page Title */
.agr-page-title {
  font-size: var(--agr-font-size-h2);
  color: var(--agr-primary-700);
  margin-bottom: var(--agr-spacing-lg);
  padding-bottom: var(--agr-spacing-md);
  border-bottom: 2px solid var(--agr-primary-500);
}

/* Form Groups */
.agr-form-group {
  margin-bottom: var(--agr-spacing-lg);
}

.agr-form-label {
  display: block;
  font-weight: 600;
  margin-bottom: var(--agr-spacing-sm);
  color: var(--agr-text-primary);
}

.agr-form-help {
  font-size: var(--agr-font-size-sm);
  color: var(--agr-text-muted);
  margin-top: var(--agr-spacing-xs);
}

/* Utility Classes */
.text-primary { color: var(--agr-primary-500) !important; }
.text-secondary { color: var(--agr-text-secondary) !important; }
.text-muted { color: var(--agr-text-muted) !important; }
.text-success { color: var(--agr-success) !important; }
.text-danger { color: var(--agr-danger) !important; }
.text-warning { color: var(--agr-warning) !important; }

.bg-light { background-color: var(--agr-gray-100) !important; }
.bg-primary { background-color: var(--agr-primary-500) !important; }

.mt-0 { margin-top: 0 !important; }
.mt-1 { margin-top: var(--agr-spacing-sm) !important; }
.mt-2 { margin-top: var(--agr-spacing-md) !important; }
.mt-3 { margin-top: var(--agr-spacing-lg) !important; }
.mt-4 { margin-top: var(--agr-spacing-xl) !important; }

.mb-0 { margin-bottom: 0 !important; }
.mb-1 { margin-bottom: var(--agr-spacing-sm) !important; }
.mb-2 { margin-bottom: var(--agr-spacing-md) !important; }
.mb-3 { margin-bottom: var(--agr-spacing-lg) !important; }
.mb-4 { margin-bottom: var(--agr-spacing-xl) !important; }

.p-0 { padding: 0 !important; }
.p-1 { padding: var(--agr-spacing-sm) !important; }
.p-2 { padding: var(--agr-spacing-md) !important; }
.p-3 { padding: var(--agr-spacing-lg) !important; }
.p-4 { padding: var(--agr-spacing-xl) !important; }

/* Page Section Styles */
.agr-page-section {
  padding: var(--agr-spacing-md) 0;
}

.agr-page-header {
  margin-bottom: var(--agr-spacing-xl);
}

.agr-page-header h1 {
  color: var(--agr-primary-700);
  margin-bottom: var(--agr-spacing-sm);
  font-size: var(--agr-font-size-h1);
}

.agr-page-description {
  color: var(--agr-text-secondary);
  font-size: var(--agr-font-size-lg);
  margin: 0;
}

/* Card Body and Footer */
.agr-card-body {
  padding: var(--agr-spacing-md) 0;
}

.agr-card-header h2 {
  margin: 0;
  font-size: var(--agr-font-size-h3);
}

.agr-card-footer {
  padding-top: var(--agr-spacing-lg);
  border-top: 1px solid var(--agr-border-color);
  margin-top: var(--agr-spacing-lg);
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--agr-spacing-lg);
}

/* Alignment Entry List Styles */
.agr-alignment-list {
  display: flex;
  flex-direction: column;
  gap: var(--agr-spacing-lg);
}

.agr-alignment-entry {
  display: flex;
  align-items: flex-start;
  gap: var(--agr-spacing-md);
  padding: var(--agr-spacing-lg);
  background-color: var(--agr-gray-100);
  border-radius: var(--agr-radius-lg);
  border: 1px solid var(--agr-border-color);
}

.agr-alignment-entry-controls {
  flex-shrink: 0;
  padding-top: var(--agr-spacing-sm);
}

.agr-alignment-entry-fields {
  flex: 1;
  min-width: 0;
}

.agr-alignment-entry-fields .p-inputgroup {
  display: flex;
  flex-wrap: wrap;
  gap: var(--agr-spacing-md);
  justify-content: flex-start;
}

.agr-alignment-entry-fields .p-float-label {
  flex: 1 1 300px;
  min-width: 250px;
}

.agr-alignment-entry-fields .p-float-label:first-child {
  flex: 0 0 200px;
  min-width: 200px;
}

.agr-alignment-entry-fields .p-autocomplete,
.agr-alignment-entry-fields .p-multiselect,
.agr-alignment-entry-fields .p-dropdown {
  width: 100% !important;
  height: 42px !important;
}

.agr-alignment-entry-fields .p-autocomplete-input {
  width: 100% !important;
  height: 42px !important;
  padding: 0.5rem 0.75rem !important;
  box-sizing: border-box !important;
}

.agr-alignment-entry-fields .p-dropdown .p-dropdown-label {
  padding: 0.5rem 0.75rem !important;
  display: flex !important;
  align-items: center !important;
}

.agr-alignment-entry-fields .p-multiselect .p-multiselect-label {
  padding: 0.25rem 0.5rem !important;
  height: 42px !important;
  box-sizing: border-box !important;
  display: flex !important;
  align-items: center !important;
  flex-wrap: nowrap !important;
  overflow: hidden !important;
}

.agr-alignment-add {
  padding: var(--agr-spacing-md);
  text-align: center;
}

.agr-alignment-add .p-button {
  background-color: transparent !important;
  color: var(--agr-primary-600) !important;
  border: 1px dashed var(--agr-primary-400) !important;
}

.agr-alignment-add .p-button:hover {
  background-color: var(--agr-primary-100) !important;
  border-style: solid !important;
}

/* Message Styles */
.agr-message {
  padding: var(--agr-spacing-md) var(--agr-spacing-lg);
  border-radius: var(--agr-radius-md);
  font-size: var(--agr-font-size-base);
}

.agr-message-error {
  background-color: var(--agr-danger-light);
  color: var(--agr-danger-dark);
  border: 1px solid var(--agr-danger);
}

.agr-message-success {
  background-color: var(--agr-success-light);
  color: var(--agr-success-dark);
  border: 1px solid var(--agr-success);
}

.agr-message-info {
  background-color: var(--agr-info-light);
  color: var(--agr-info-dark);
  border: 1px solid var(--agr-info);
}

/* MultiSelect Overrides */
.p-multiselect {
  font-family: var(--agr-font-family) !important;
  border-color: var(--agr-border-color) !important;
  border-radius: var(--agr-radius-md) !important;
  min-width: 200px;
}

.p-multiselect:focus,
.p-multiselect.p-focus {
  border-color: var(--agr-primary-500) !important;
  box-shadow: 0 0 0 2px var(--agr-primary-200) !important;
}

.p-multiselect-panel {
  font-family: var(--agr-font-family) !important;
}

.p-multiselect .p-multiselect-label {
  padding: var(--agr-spacing-sm) var(--agr-spacing-md) !important;
}

/* FloatLabel adjustments */
.p-float-label {
  display: block;
}

.p-float-label > label {
  font-family: var(--agr-font-family) !important;
  color: var(--agr-text-secondary) !important;
}

.p-float-label > .p-inputwrapper-focus ~ label,
.p-float-label > .p-inputwrapper-filled ~ label {
  color: var(--agr-primary-600) !important;
}

/* Button text mode fix */
.p-button.p-button-text {
  background-color: transparent !important;
  border-color: transparent !important;
  color: var(--agr-primary-500) !important;
}

.p-button.p-button-text:hover {
  background-color: var(--agr-primary-100) !important;
}

.p-button.p-button-text.p-button-danger {
  color: var(--agr-danger) !important;
}

.p-button.p-button-text.p-button-danger:hover {
  background-color: var(--agr-danger-light) !important;
}

/* Large button variant */
.p-button.p-button-lg {
  padding: var(--agr-spacing-md) var(--agr-spacing-xl) !important;
  font-size: var(--agr-font-size-lg) !important;
}

/* Progress Page Styles */
.agr-progress-container {
  margin-bottom: var(--agr-spacing-lg);
}

.agr-progress-bar {
  border-radius: var(--agr-radius-md) !important;
}

.agr-progress-status {
  padding: var(--agr-spacing-lg);
  border-radius: var(--agr-radius-md);
  text-align: center;
}

.agr-progress-message {
  font-size: var(--agr-font-size-lg);
  margin: 0 0 var(--agr-spacing-sm) 0;
  font-weight: 500;
}

.agr-progress-timestamp {
  font-size: var(--agr-font-size-sm);
  color: var(--agr-text-muted);
  margin: 0;
}

.agr-status-pending {
  background-color: var(--agr-info-light);
  border: 1px solid var(--agr-info);
}

.agr-status-pending .agr-progress-message {
  color: var(--agr-primary-700);
}

.agr-status-success {
  background-color: var(--agr-success-light);
  border: 1px solid var(--agr-success);
}

.agr-status-success .agr-progress-message {
  color: var(--agr-success-dark);
}

.agr-status-error {
  background-color: var(--agr-danger-light);
  border: 1px solid var(--agr-danger);
}

.agr-status-error .agr-progress-message {
  color: var(--agr-danger-dark);
}

/* Code inline style */
.agr-code {
  background-color: var(--agr-gray-100);
  padding: 0.2em 0.4em;
  border-radius: var(--agr-radius-sm);
  font-family: 'SFMono-Regular', Consolas, 'Liberation Mono', Menlo, monospace;
  font-size: 0.875em;
  color: var(--agr-primary-700);
}

/* Screen reader only - visually hidden but accessible */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* Loading state */
.agr-loading-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--agr-spacing-xl);
  min-height: 200px;
  color: var(--agr-text-secondary);
}

.agr-loading-state p {
  margin-top: var(--agr-spacing-md);
  font-size: var(--agr-font-size-base);
}

/* Empty state */
.agr-empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--agr-spacing-xl);
  min-height: 200px;
  text-align: center;
}

.agr-empty-state h3 {
  margin: var(--agr-spacing-md) 0 var(--agr-spacing-sm) 0;
  color: var(--agr-text-primary);
  font-size: var(--agr-font-size-h3);
}

.agr-empty-state p {
  margin: 0;
  color: var(--agr-text-secondary);
  max-width: 400px;
}

/* Touch target minimum size for mobile (WCAG 2.5.5) */
@media (pointer: coarse) {
  .p-button,
  .p-dropdown,
  .p-inputtext,
  .p-checkbox,
  .p-radiobutton,
  button,
  input[type="button"],
  input[type="submit"],
  a.p-button {
    min-height: 44px;
    min-width: 44px;
  }

  .p-button-icon-only {
    width: 44px;
    height: 44px;
  }
}

