/* global.css */
/* Core Design System Tokens */

:root {
    /* Brand Colors */
    --color-brand-primary: #0f2027; /* Dark Teal / Navy */
    --color-brand-secondary: #3a4856; /* Lighter Slate / Text Muted */
    --color-brand-accent-teal: #1abc9c;
    --color-brand-accent-pink: #c92a82;
    --color-brand-accent-gold: #ffcc00;

    /* Background Tints */
    --bg-tint-blue: linear-gradient(135deg, #e8f0ff, #cfdcfa);
    --bg-tint-gold: linear-gradient(135deg, #fff7e3, #ffe7a8);
    --bg-tint-teal: linear-gradient(135deg, #e5fff9, #c6f3e7);
    --bg-subtle: #f6faf8;
    --bg-white: #ffffff;
    --bg-light: #f8fafc;

    /* Text Colors */
    --text-main: var(--color-brand-primary);
    --text-muted: var(--color-brand-secondary);

    /* Typography */
    --font-heading: 'Oswald', sans-serif;
    --font-body: 'Noto Serif', serif;

    /* Shadows */
    --shadow-sm: 0 4px 10px rgba(0, 0, 0, 0.05); /* Soft elements */
    --shadow-md: 0 8px 18px rgba(15, 32, 39, 0.08); /* Icons / smaller cards */
    --shadow-lg: 0 16px 30px rgba(0, 0, 0, 0.08); /* Main cards */
    --shadow-lg-hover: 0 20px 36px rgba(0, 0, 0, 0.12); /* Card hover */

    /* Borders */
    --border-subtle: 1px solid rgba(15, 32, 39, 0.08);
    --radius-sm: 8px;
    --radius-md: 12px;
    --radius-lg: 16px;
    --radius-xl: 20px;
    --radius-pill: 999px;

    /* Transitions */
    --transition-fast: 0.2s ease;
    --transition-snappy: 0.25s ease;
    --transition-smooth: 0.3s ease;
    --transition-slow: 0.45s ease;
}

/* Base resets relying on tokens */
body {
    font-family: var(--font-body);
    color: var(--text-main);
    background-color: var(--bg-white);
}

h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
    font-family: var(--font-heading);
    color: var(--text-main);
}

/* Simpler, stable anchor handling: CSS smooth scroll + offset */
html {
    scroll-behavior: smooth;
}

/* Apply top margin to anchored targets so they clear the header */
[id] {
    scroll-margin-top: 104px;
}
@media (max-width: 767px) {
    [id] {
        scroll-margin-top: 88px;
    }
}

/* --- COMPONENTS --- */

.page-hero {
    position: relative;
    background: linear-gradient(135deg, var(--color-brand-primary), #203a43, #2c5364);
    color: var(--bg-white);
    padding: var(--spacing-xxl, 4rem) var(--spacing-md, 1.25rem) var(--spacing-xl, 3rem);
    text-align: center;
    overflow: hidden;
}

.page-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: url('/resources/images/tortuga/pexels-jeremy-bishop_HD.jpg');
    background-size: cover;
    background-position: center top;
    opacity: 0.2;
    pointer-events: none;
}

.page-hero__content {
    max-width: 800px;
    margin: 0 auto;
    position: relative;
    z-index: 1;
}

.page-hero__eyebrow {
    font-family: var(--font-heading);
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--color-brand-accent-gold);
    margin-bottom: var(--spacing-sm, 0.5rem);
}

.page-hero__title {
    font-size: 2.75rem;
    margin-bottom: var(--spacing-md, 1rem);
    line-height: 1.15;
    color: var(--bg-white);
}

.page-hero__lead {
    font-size: 1.15rem;
    color: rgba(255, 255, 255, 0.9);
    line-height: 1.7;
    margin-bottom: var(--spacing-lg, 1.5rem);
}

.page-hero__actions {
    display: flex;
    justify-content: center;
    gap: var(--spacing-sm, 0.5rem);
    flex-wrap: wrap;
    position: relative;
    z-index: 1;
}

.page-hero .btn-primary {
    background: var(--color-brand-accent-gold, #ffcc00);
    border-color: var(--color-brand-accent-gold, #ffcc00);
    color: var(--color-brand-primary, #0f2027);
    font-weight: 600;
}

.page-hero .btn-primary:hover {
    background: #e6b800; /* Darker gold */
    border-color: #e6b800;
    color: var(--color-brand-primary);
}

.page-hero .btn-outline-primary,
.page-hero .btn-outline-light {
    color: var(--bg-white, #fff);
    border-color: rgba(255, 255, 255, 0.4);
    font-weight: 600;
}

.page-hero .btn-outline-primary:hover,
.page-hero .btn-outline-light:hover {
    background: rgba(255, 255, 255, 0.1);
    color: var(--bg-white);
    border-color: var(--bg-white);
}

/* Modifier: Split Layout (e.g., About Us or Calculators) */
.page-hero--split {
    text-align: left;
}

.page-hero--split .page-hero__content {
    max-width: 1100px;
}

@media (max-width: 767px) {
    .page-hero__title {
        font-size: 2rem;
    }
    
    .page-hero__actions {
        flex-direction: column;
        width: 100%;
        max-width: 400px;
        margin: 0 auto;
    }
    
    .page-hero__actions .btn {
        width: 100%;
    }
}
