/* ============================================================
   Goldfish Data B.V. — Custom stylesheet
   Extends Bootstrap 5. All brand variables defined here.
   ============================================================ */

/* ----- Brand color variables ----- */
:root {
    --gfd-white:    #fff;
    --gfd-cream:    #e5e1d1;
    --gfd-slate:    #52616d;
    --gfd-dark:     #2c343b;
    --gfd-red:      #c44741;
    --gfd-gold:     #e5a700;
    --gfd-yellow:   #ffba00;
    --bs-body-font-family: system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
}

/* ----- Global resets ----- */
*,
*::before,
*::after {
    box-sizing: border-box;
}

body {
    overflow-x: hidden;
    background-color: var(--gfd-slate);
}

/* ----- Navbar ----- */
.gfd-navbar {
    background-color: rgba(44, 52, 59, 0.92) !important;
    backdrop-filter: blur(8px);
    border-bottom: 1px solid rgba(229, 167, 0, 0.2);
}

.gfd-navbar .navbar-brand .brand-name {
    color: var(--gfd-cream);
    font-weight: 600;
    letter-spacing: .05em;
}

.gfd-navbar .nav-link {
    color: var(--gfd-cream) !important;
    transition: color .2s, background-color .2s;
    border-radius: 4px;
    padding: .4rem .8rem !important;
}

.gfd-navbar .nav-link:hover,
.gfd-navbar .nav-link.active {
    color: #fff !important;
    background-color: var(--gfd-red);
}

.gfd-red {
    color: var(--gfd-red) !important;
}

/* ----- Hero section ----- */
.gfd-hero {
    position: relative;
    width: 100%;
    height: 30em;
    background:
        url('/layout/images/reef.jpg') center center / cover no-repeat,
        url('/assets/images/hero.svg') center center / cover no-repeat;
    background-color: var(--gfd-dark);
    box-shadow: 0 4px 16px rgba(0, 0, 0, .6);
    overflow: hidden;
}

/* Inner-page hero (no fish grid, just the banner with overlay) */
.gfd-hero-inner {
    height: 16em;
}

.gfd-hero-error {
    height: 12em;
}

.gfd-hero-overlay {
    position: absolute;
    inset: 0;
    background: rgba(27, 38, 46, 0.52);
}

.gfd-hero-title {
    color: #fff;
    font-weight: 700;
    font-size: 2.4rem;
    text-shadow: 0 2px 8px rgba(0, 0, 0, .7);
    letter-spacing: .04em;
}

.gfd-hero-title-red {
    color: var(--gfd-yellow);
}

.gfd-hero-credit {
    position: absolute;
    bottom: 1em;
    right: 1em;
    color: rgba(255, 255, 255, .4);
    font-size: .75em;
}

/* ----- Content wrap — pulls up over the hero ----- */
.gfd-content-wrap {
    background-color: var(--gfd-slate);
    min-height: 60vh;
    padding-bottom: 6rem;
}

.gfd-content {
    position: relative;
    top: -4em;
    background-color: var(--gfd-cream);
    border-radius: 1.5em 4em 4em 1.5em;
    padding: 2.5rem 2.5rem 3rem;
    box-shadow: 0 0 24px rgba(0, 0, 0, .5);
}

/* ----- Section titles ----- */
.gfd-section-title {
    color: var(--gfd-red);
    font-weight: 700;
    margin-bottom: .5rem;
}

/* ----- Service cards ----- */
.gfd-card {
    background-color: #fff;
    border: none;
    border-radius: 1em;
    box-shadow: 0 2px 8px rgba(0, 0, 0, .1);
    transition: transform .2s, box-shadow .2s;
}

.gfd-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, .15);
}

.gfd-card-icon {
    font-size: 3em;
    color: var(--gfd-gold);
    margin-bottom: .4em;
    display: block;
}

/* ----- Expertise badges (company page) ----- */
.gfd-expertise-badge {
    background-color: #fff;
    border: 1px solid rgba(229, 167, 0, 0.3);
    border-radius: .6em;
    padding: .55rem .8rem;
    font-size: .85rem;
    color: var(--gfd-dark);
    box-shadow: 0 1px 4px rgba(0, 0, 0, .08);
    transition: background-color .2s, border-color .2s;
}

.gfd-expertise-badge:hover {
    background-color: var(--gfd-yellow);
    border-color: var(--gfd-gold);
}

.gfd-expertise-badge .fa {
    color: var(--gfd-gold);
    margin-right: .3em;
}

/* ----- Links ----- */
.gfd-link {
    color: var(--gfd-red);
    text-decoration: none;
    font-weight: 500;
    transition: color .15s;
}

.gfd-link:hover {
    color: var(--gfd-gold);
    text-decoration: underline;
}

/* ----- Buttons ----- */
.gfd-btn {
    background-color: var(--gfd-red);
    color: #fff;
    border: none;
    border-radius: .5em;
    padding: .45rem 1.1rem;
    font-weight: 600;
    transition: background-color .2s, transform .1s;
    text-decoration: none;
    display: inline-block;
}

.gfd-btn:hover {
    background-color: #a33530;
    color: #fff;
    transform: translateY(-1px);
}

.gfd-btn-outline {
    background-color: transparent;
    color: var(--gfd-red);
    border: 2px solid var(--gfd-red);
    border-radius: .5em;
    padding: .4rem 1.1rem;
    font-weight: 600;
    transition: background-color .2s, color .2s;
    text-decoration: none;
    display: inline-block;
}

.gfd-btn-outline:hover {
    background-color: var(--gfd-red);
    color: #fff;
}

.gfd-btn-login {
    background-color: var(--gfd-dark);
    padding: .6rem 1.4rem;
    font-size: 1rem;
}

.gfd-btn-login:hover {
    background-color: #1a2128;
}

/* ----- Login card ----- */
.gfd-login-card {
    border-top: 4px solid var(--gfd-gold);
}

.gfd-form-label {
    color: var(--gfd-dark);
    font-weight: 600;
    margin-bottom: .35rem;
}

.gfd-form-control {
    border: 1.5px solid #ccc;
    border-radius: .5em;
    padding: .6rem .9rem;
    transition: border-color .2s, box-shadow .2s;
}

.gfd-form-control:focus {
    border-color: var(--gfd-gold);
    box-shadow: 0 0 0 3px rgba(229, 167, 0, 0.2);
    outline: none;
}

/* ----- Urgent alert (help page) ----- */
.gfd-alert-urgent {
    background-color: rgba(196, 71, 65, 0.1);
    border: 1.5px solid var(--gfd-red);
    border-radius: .75em;
    color: #6b1c19;
}

.gfd-alert-urgent .fa-exclamation-triangle {
    color: var(--gfd-red);
}

/* ----- SLA table (help page) ----- */
.gfd-table {
    font-size: .88rem;
}

.gfd-badge-critical { background-color: #7b1a17; color: #fff; }
.gfd-badge-high     { background-color: var(--gfd-red); color: #fff; }
.gfd-badge-medium   { background-color: var(--gfd-gold); color: #fff; }
.gfd-badge-low      { background-color: var(--gfd-slate); color: #fff; }

/* ----- Error page icon ----- */
.gfd-error-icon {
    font-size: 4rem;
    color: var(--gfd-gold);
    display: block;
}

/* ----- Footer ----- */
.gfd-footer {
    background-color: var(--gfd-dark);
    padding: 1.2rem 0;
    margin-top: 0;
}

.gfd-footer .footer-text {
    color: var(--gfd-cream);
    font-size: .85em;
}

/* ============================================================
   Fish grid / animated logo
   All rules preserved exactly from the original style.css
   ============================================================ */

.box {
    position: relative;
    transform: skewY(-15deg);
    color: #fff;
    background-color: #e5a700;
    align-items: center;
}

.box:nth-child(even) {
    transform: skewY(15deg);
    color: #000;
    background-color: #ffba00;
}

.box:hover:nth-child(even) {
    background-color: #e5a700;
}

.box:hover:nth-child(odd) {
    background-color: #ffba00;
}

.box:nth-child(1)   { border-top-left-radius: 1em; }
.box:nth-child(20)  { border-top-right-radius: 1em; }
.box:nth-child(381) { border-bottom-left-radius: 1em; }
.box:nth-child(400) { border-bottom-right-radius: 1em; }

/* Black outline boxes forming the fish shape */
.box:nth-child(42)  { background-color: #000; }
.box:nth-child(43)  { background-color: #000; }
.box:nth-child(55)  { background-color: #000; }
.box:nth-child(51)  { background-color: #000; }
.box:nth-child(52)  { background-color: #000; }
.box:nth-child(53)  { background-color: #000; }
.box:nth-child(54)  { background-color: #000; }
.box:nth-child(61)  { background-color: #000; }
.box:nth-child(64)  { background-color: #000; }
.box:nth-child(65)  { background-color: #000; }
.box:nth-child(69)  { background-color: #000; }
.box:nth-child(70)  { background-color: #000; }
.box:nth-child(76)  { background-color: #000; }
.box:nth-child(77)  { background-color: #000; }
.box:nth-child(81)  { background-color: #000; }
.box:nth-child(86)  { background-color: #000; }
.box:nth-child(88)  { background-color: #000; }
.box:nth-child(98)  { background-color: #000; }
.box:nth-child(101) { background-color: #000; }
.box:nth-child(107) { background-color: #000; }
.box:nth-child(119) { background-color: #000; }
.box:nth-child(121) { background-color: #000; }
.box:nth-child(139) { background-color: #000; }
.box:nth-child(142) { background-color: #000; }
.box:nth-child(148) { background-color: #000; }
.box:nth-child(149) { background-color: #000; }
.box:nth-child(154) { background-color: #000; }
.box:nth-child(155) { background-color: #fff; }
.box:nth-child(160) { background-color: #000; }
.box:nth-child(162) { background-color: #000; }
.box:nth-child(167) { background-color: #000; }
.box:nth-child(170) { background-color: #000; }
.box:nth-child(174) { background-color: #000; }
.box:nth-child(175) { background-color: #000; }
.box:nth-child(180) { background-color: #000; }
.box:nth-child(183) { background-color: #000; }
.box:nth-child(187) { background-color: #000; }
.box:nth-child(200) { background-color: #000; }
.box:nth-child(203) { background-color: #000; }
.box:nth-child(207) { background-color: #000; }
.box:nth-child(220) { background-color: #000; }
.box:nth-child(222) { background-color: #000; }
.box:nth-child(227) { background-color: #000; }
.box:nth-child(230) { background-color: #000; }
.box:nth-child(240) { background-color: #000; }
.box:nth-child(242) { background-color: #000; }
.box:nth-child(248) { background-color: #000; }
.box:nth-child(249) { background-color: #000; }
.box:nth-child(260) { background-color: #000; }
.box:nth-child(261) { background-color: #000; }
.box:nth-child(279) { background-color: #000; }
.box:nth-child(281) { background-color: #000; }
.box:nth-child(287) { background-color: #000; }
.box:nth-child(299) { background-color: #000; }
.box:nth-child(301) { background-color: #000; }
.box:nth-child(306) { background-color: #000; }
.box:nth-child(308) { background-color: #000; }
.box:nth-child(318) { background-color: #000; }
.box:nth-child(321) { background-color: #000; }
.box:nth-child(324) { background-color: #000; }
.box:nth-child(325) { background-color: #000; }
.box:nth-child(329) { background-color: #000; }
.box:nth-child(330) { background-color: #000; }
.box:nth-child(336) { background-color: #000; }
.box:nth-child(337) { background-color: #000; }
.box:nth-child(342) { background-color: #000; }
.box:nth-child(343) { background-color: #000; }
.box:nth-child(351) { background-color: #000; }
.box:nth-child(352) { background-color: #000; }
.box:nth-child(353) { background-color: #000; }
.box:nth-child(354) { background-color: #000; }
.box:nth-child(355) { background-color: #000; }

/* Fish grid wrapper — the animated container */
#wrapper {
    position: absolute;
    z-index: 1500;
    left: -15em;
    display: grid;
    width: 10em;
    height: 10em;
    animation: fish-swim-one 30s infinite linear;
    animation-delay: 2s;
    grid-gap: 0;
    grid-template-columns: repeat(20, 1fr);
    grid-template-rows: repeat(20, 1fr);
}

/* ============================================================
   Keyframe animations (copied verbatim from original style.css)
   ============================================================ */

@-webkit-keyframes fish-swim-one {
    0% {
        z-index: 2000;
        top: 5em;
        left: -40em;
        transform: rotate(-5deg);
    }
    16.49% {
        z-index: 2000;
        top: 2em;
        transform: rotate(0deg);
    }
    32.99% {
        z-index: 2000;
        top: 12em;
        left: calc(100vw + 30em);
        transform: rotate(5deg);
    }
    33% {
        right: -50em;
    }
    33.01% {
        transform: scaleX(-1);
    }
    48% {
        top: 8em;
        left: 50vw;
        transform: scaleX(-1);
    }
    66% {
        z-index: 2000;
        top: 5em;
        left: -30em;
        transform: scaleX(-1);
    }
    66.01% {
        transform: scaleX(1);
        transform: rotate(-45deg);
    }
    84% {
        z-index: 2000;
        top: 25em;
        left: -30em;
    }
    100% {
        z-index: 2000;
        top: -15em;
        left: calc(100vw + 20em);
    }
}

@keyframes fish-swim-one {
    0% {
        z-index: 2000;
        top: 5em;
        left: -40em;
        transform: rotate(-5deg);
    }
    16.49% {
        z-index: 2000;
        top: 2em;
        transform: rotate(0deg);
    }
    32.99% {
        z-index: 2000;
        top: 12em;
        left: calc(100vw + 30em);
        transform: rotate(5deg);
    }
    33% {
        right: -50em;
    }
    33.01% {
        transform: scaleX(-1);
    }
    48% {
        top: 8em;
        left: 50vw;
        transform: scaleX(-1);
    }
    66% {
        z-index: 2000;
        top: 5em;
        left: -30em;
        transform: scaleX(-1);
    }
    66.01% {
        transform: scaleX(1);
        transform: rotate(-45deg);
    }
    84% {
        z-index: 2000;
        top: 25em;
        left: -30em;
    }
    100% {
        z-index: 2000;
        top: -15em;
        left: calc(100vw + 20em);
    }
}

@-webkit-keyframes fish-swim-two {
    0% {
        z-index: 2000;
        top: 2em;
        left: calc(80vw + 30em);
        transform: scaleX(-1);
        transform: rotate(-5deg);
    }
    .01% {
        z-index: 2000;
        top: 4em;
        transform: scaleX(-1);
    }
    50% {
        z-index: 2000;
        top: 2em;
        transform: rotate(-5deg);
        transform: scaleX(-1);
    }
    100% {
        z-index: 2000;
        top: 5em;
        left: -40em;
        transform: scaleX(-1);
    }
}

@keyframes fish-swim-two {
    0% {
        z-index: 2000;
        top: 2em;
        left: calc(80vw + 30em);
        transform: scaleX(-1);
        transform: rotate(-5deg);
    }
    .01% {
        z-index: 2000;
        top: 4em;
        transform: scaleX(-1);
    }
    50% {
        z-index: 2000;
        top: 2em;
        transform: rotate(-5deg);
        transform: scaleX(-1);
    }
    100% {
        z-index: 2000;
        top: 5em;
        left: -40em;
        transform: scaleX(-1);
    }
}

/* ============================================================
   Responsive breakpoints
   ============================================================ */

/* Navbar padding on mobile */
@media (max-width: 991.98px) {
    .gfd-navbar .navbar-nav {
        padding: .5rem 0;
    }

    .gfd-navbar .nav-link {
        padding: .6rem 1rem !important;
    }
}

/* Push content below fixed navbar */
@media (max-width: 575.98px) {
    .gfd-hero {
        height: 22em;
    }

    .gfd-hero-inner {
        height: 12em;
    }

    .gfd-content {
        border-radius: 1em;
        padding: 1.5rem 1rem 2rem;
    }

    .gfd-hero-title {
        font-size: 1.6rem;
    }
}

@media (min-width: 576px) and (max-width: 767.98px) {
    .gfd-content {
        border-radius: 1em 2em 2em 1em;
    }
}

/* Large screen refinements */
@media (min-width: 1440px) {
    .gfd-content {
        padding: 3rem 4rem 4rem;
    }
}
