:root {
    --ip-cream: #f7f0e4;
    --ip-warm: #fbf7ef;
    --ip-ink: #191817;
    --ip-muted: #6f675f;
    --ip-gold: #c99a4a;
    --ip-gold-dark: #a97824;
    --ip-soft-line: rgba(25, 24, 23, .12);
}

* { box-sizing: border-box; }

/* Sticky footer layout */

html,
body {
    height: 100%;
}

main,
.site-main {
    flex: 1;
}

body {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    font-family: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    color: var(--ip-ink);
    background: #fff;
}

.ip-serif { font-family: 'Cormorant Garamond', Georgia, serif; font-weight: 700; letter-spacing: -.03em; }
.py-lg-6 { padding-top: 6rem; padding-bottom: 6rem; }
.bg-warm { background: var(--ip-warm); }

.ip-nav {
    padding: 1rem 0;
    background: rgba(255, 250, 242, .86);
    backdrop-filter: blur(18px);
    border-bottom: 1px solid rgba(255,255,255,.45);
}

.ip-brand {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 1.8rem;
    font-weight: 700;
    letter-spacing: -.04em;
    color: var(--ip-ink) !important;
}

.ip-brand span { color: var(--ip-gold-dark); }
.footer-brand { font-size: 1.6rem; }

.nav-link { font-weight: 600; color: rgba(25,24,23,.72); }
.nav-link:hover { color: var(--ip-ink); }

.ip-hero {
    min-height: 100vh;
    position: relative;
    overflow: hidden;
    color: #fff;
    background: #1d1a17;
}

.ip-hero-bg {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, rgba(18,15,12,.86) 0%, rgba(18,15,12,.58) 40%, rgba(18,15,12,.14) 74%),
        radial-gradient(circle at 78% 34%, rgba(255,206,126,.38), transparent 24%),
        linear-gradient(130deg, rgba(201,154,74,.30), transparent 42%),
        url('../img/hero-london-couple.jpg') center/cover no-repeat;
    transform: scale(1.02);
}

.ip-kicker {
    display: inline-flex;
    align-items: center;
    gap: .55rem;
    color: #f2c77f;
    font-size: .78rem;
    letter-spacing: .14em;
    text-transform: uppercase;
    font-weight: 800;
}

.ip-kicker::before {
    content: '';
    width: 34px;
    height: 1px;
    background: currentColor;
    opacity: .8;
}

.ip-kicker.dark { color: var(--ip-gold-dark); }
.ip-hero-copy { color: rgba(255,255,255,.84); max-width: 620px; }

.btn-gold {
    background: var(--ip-gold);
    border-color: var(--ip-gold);
    color: #17130d;
    font-weight: 800;
}

.btn-gold:hover {
    background: #d8aa5a;
    border-color: #d8aa5a;
    color: #17130d;
}

.ip-code-card {
    max-width: 650px;
    padding: 1.25rem;
    border-radius: 28px;
    background: rgba(255,255,255,.13);
    border: 1px solid rgba(255,255,255,.22);
    box-shadow: 0 24px 70px rgba(0,0,0,.22);
    backdrop-filter: blur(14px);
}

.ip-code-card .form-label {
    font-weight: 800;
    font-size: .9rem;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: rgba(255,255,255,.86);
}

.ip-code-row {
    display: flex;
    gap: .75rem;
}

.ip-code-row .form-control {
    min-height: 56px;
    border-radius: 999px;
    border: 0;
    padding-left: 1.25rem;
    font-weight: 700;
    letter-spacing: .04em;
}

.ip-code-row .btn {
    min-height: 56px;
    border-radius: 999px;
    white-space: nowrap;
    padding-left: 1.5rem;
    padding-right: 1.5rem;
}

.ip-code-note {
    margin-top: .9rem;
    color: rgba(255,255,255,.72);
    font-size: .94rem;
}

.ip-code-card-light {
    background: #fff;
    color: var(--ip-ink);
    border: 1px solid var(--ip-soft-line);
    box-shadow: 0 24px 60px rgba(25,24,23,.08);
}

.ip-code-card-light .form-label {
    color: var(--ip-muted);
}

.ip-code-card-light .form-control {
    border: 1px solid var(--ip-soft-line);
    background: var(--ip-warm);
}

.ip-code-card-light .ip-code-note {
    color: var(--ip-muted);
}

.ip-hero-secondary {
    color: rgba(255,255,255,.72);
    font-weight: 600;
}

.ip-hero-secondary a {
    color: #f2c77f;
    font-weight: 800;
    margin-left: .35rem;
}

.ip-page-hero {
    background: var(--ip-warm);
}

.ip-preview-card {
    background: #fff;
    border: 1px solid var(--ip-soft-line);
    border-radius: 34px;
    padding: 2rem;
    box-shadow: 0 30px 70px rgba(25,24,23,.08);
}

.ip-preview-placeholder {
    min-height: 340px;
    border-radius: 26px;
    background:
        linear-gradient(135deg, rgba(201,154,74,.24), rgba(25,24,23,.08)),
        var(--ip-warm);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--ip-muted);
    font-weight: 800;
    letter-spacing: .1em;
    text-transform: uppercase;
}

.ip-step-card {
    background: #fff;
    border: 1px solid var(--ip-soft-line);
    border-radius: 28px;
    padding: 2rem;
    box-shadow: 0 24px 60px rgba(25,24,23,.07);
}

.ip-step-number {
    color: var(--ip-gold-dark);
    font-weight: 800;
    letter-spacing: .12em;
    margin-bottom: 1rem;
}

.ip-step-card h3 {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 1.9rem;
    font-weight: 700;
    margin-bottom: .75rem;
}

.ip-step-card p { color: var(--ip-muted); margin-bottom: 0; }

.ip-photo-collage {
    position: relative;
    min-height: 580px;
}

.ip-photo {
    position: absolute;
    border-radius: 34px;
    background-size: cover;
    background-position: center;
    box-shadow: 0 35px 80px rgba(25,24,23,.14);
    border: 8px solid #fff;
}

.ip-photo-large {
    inset: 0 12% 8% 0;
    background-image: url('../img/couple-riverside.svg');
}

.ip-photo-small {
    width: 42%;
    height: 35%;
    right: 0;
}

.ip-photo-small.one {
    top: 9%;
    background-image: url('../img/family-london.svg');
}

.ip-photo-small.two {
    bottom: 0;
    background-image: url('../img/photo-card.svg');
}

.ip-trust {
    background: #181613;
    color: #fff;
}

.ip-trust strong {
    display: block;
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 1.8rem;
    margin-bottom: .35rem;
}

.ip-trust span { color: rgba(255,255,255,.68); }
.ip-cta { max-width: 760px; }

.ip-footer { background: #fff; border-top: 1px solid var(--ip-soft-line); }

@media (max-width: 991.98px) {
    .display-1 { font-size: 4.2rem; }
    .ip-photo-collage { min-height: 500px; }
}

@media (max-width: 575.98px) {
    .display-1 { font-size: 3.25rem; }
    .ip-hero { min-height: 760px; }
    .ip-code-row { flex-direction: column; }
    .ip-code-row .btn { width: 100%; }
    .ip-photo-collage { min-height: 430px; }
    .ip-photo-large { inset: 0 0 26% 0; }
    .ip-photo-small { width: 50%; height: 28%; }
}

 /* ======================================================================
   Photographer recruitment page
   Add this whole block to the bottom of public_html/assets/css/site.css
   ====================================================================== */

.ip-photog-hero {
    padding-top: 8rem;
    padding-bottom: 4.5rem;
    background:
        radial-gradient(circle at 85% 20%, rgba(201,154,74,.24), transparent 30%),
        linear-gradient(135deg, #fffaf2 0%, var(--ip-warm) 55%, #fff 100%);
    overflow: hidden;
}

.ip-photog-title {
    font-size: clamp(2.55rem, 5vw, 5rem);
    line-height: .96;
    letter-spacing: -.055em;
    max-width: 760px;
}

.ip-photog-lead {
    font-size: clamp(1.08rem, 1.5vw, 1.28rem);
    line-height: 1.65;
    color: var(--ip-muted);
    max-width: 640px;
}

.ip-photog-small {
    color: var(--ip-muted);
    font-weight: 600;
}

.ip-photog-visual {
    position: relative;
    min-height: 560px;
}

.ip-photog-photo {
    position: absolute;
    background-size: cover;
    background-position: center;
    border: 8px solid #fff;
    box-shadow: 0 28px 80px rgba(25,24,23,.16);
}

.ip-photog-photo-main {
    inset: 2% 12% 8% 0;
    border-radius: 36px;
    background-image: url('../img/hero-london-couple.jpg');
}

.ip-photog-photo-card {
    width: 42%;
    height: 34%;
    right: 0;
    border-radius: 28px;
}

.ip-photog-photo-top {
    top: 9%;
    background-image: url('../img/family-london.svg');
}

.ip-photog-photo-bottom {
    bottom: 2%;
    background-image: url('../img/photo-card.svg');
}

.ip-photog-badge {
    position: absolute;
    left: 7%;
    bottom: 5%;
    display: inline-flex;
    flex-direction: column;
    gap: .15rem;
    padding: 1rem 1.15rem;
    border-radius: 22px;
    background: rgba(25,24,23,.92);
    color: #fff;
    box-shadow: 0 18px 55px rgba(25,24,23,.28);
}

.ip-photog-badge span {
    color: #f2c77f;
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .13em;
    font-weight: 800;
}

.ip-photog-badge strong {
    font-size: 1.05rem;
}

.ip-photog-card,
.ip-photog-panel,
.ip-photog-standard {
    background: #fff;
    border: 1px solid var(--ip-soft-line);
    box-shadow: 0 24px 65px rgba(25,24,23,.07);
}

.ip-photog-card {
    padding: 2rem;
    border-radius: 30px;
}

.ip-photog-card h3 {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 2rem;
    font-weight: 700;
    letter-spacing: -.03em;
    margin-bottom: .75rem;
}

.ip-photog-card p,
.ip-photog-panel li,
.ip-photog-standard p {
    color: var(--ip-muted);
}

.ip-photog-icon {
    width: 48px;
    height: 48px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1.2rem;
    background: rgba(201,154,74,.18);
    color: var(--ip-gold-dark);
    font-weight: 900;
    letter-spacing: .08em;
}

.ip-photog-split {
    background: #181613;
}

.ip-photog-panel {
    padding: 2.3rem;
    border-radius: 34px;
}

.ip-photog-panel h2 {
    font-size: clamp(2rem, 3vw, 3rem);
}

.ip-photog-panel-good {
    background: #fffaf2;
}

.ip-photog-panel-not {
    background: #fff;
}

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

.ip-photog-list li {
    position: relative;
    padding-left: 1.8rem;
    margin-bottom: 1rem;
    line-height: 1.55;
}

.ip-photog-list li::before {
    content: '';
    position: absolute;
    left: 0;
    top: .52rem;
    width: .55rem;
    height: .55rem;
    border-radius: 999px;
    background: var(--ip-gold);
}

.ip-photog-standard {
    padding: 1.6rem;
    border-radius: 28px;
}

.ip-photog-standard span {
    display: block;
    color: var(--ip-gold-dark);
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .12em;
    font-weight: 900;
    margin-bottom: .35rem;
}

.ip-photog-standard strong {
    display: block;
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 2rem;
    line-height: 1;
    letter-spacing: -.035em;
    margin-bottom: .8rem;
}

.ip-photog-frame {
    min-height: 460px;
    border-radius: 38px;
    border: 8px solid #fff;
    box-shadow: 0 28px 80px rgba(25,24,23,.14);
    background:
        linear-gradient(180deg, rgba(25,24,23,.08), rgba(25,24,23,.16)),
        url('../img/couple-riverside.svg') center/cover no-repeat;
}

.ip-photog-quote {
    display: inline-block;
    padding: 1rem 1.25rem;
    border-left: 4px solid var(--ip-gold);
    background: var(--ip-warm);
    border-radius: 0 18px 18px 0;
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 1.8rem;
    font-weight: 700;
    letter-spacing: -.03em;
}

.ip-photog-cta {
    background: #181613;
    color: #fff;
}

.ip-photog-cta-inner {
    max-width: 780px;
}

.ip-photog-cta p {
    color: rgba(255,255,255,.72);
}

@media (max-width: 991.98px) {
    .ip-photog-hero {
        padding-top: 7.25rem;
        padding-bottom: 3rem;
    }

    .ip-photog-visual {
        min-height: 470px;
    }

    .ip-photog-photo-main {
        inset: 0 8% 10% 0;
    }
}

@media (max-width: 575.98px) {
    .ip-photog-hero {
        padding-top: 6.75rem;
    }

    .ip-photog-title {
        font-size: 2.55rem;
        line-height: 1.02;
    }

    .ip-photog-visual {
        min-height: 390px;
    }

    .ip-photog-photo {
        border-width: 6px;
    }

    .ip-photog-photo-main {
        inset: 0 0 26% 0;
    }

    .ip-photog-photo-card {
        width: 50%;
        height: 28%;
    }

    .ip-photog-photo-top {
        top: 48%;
        right: 43%;
    }

    .ip-photog-photo-bottom {
        bottom: 0;
        right: 0;
    }

    .ip-photog-badge {
        left: 1rem;
        bottom: 1rem;
    }

    .ip-photog-panel,
    .ip-photog-card,
    .ip-photog-standard {
        border-radius: 24px;
    }
}

/* End photographer recruitment page */
