/* ==========================================================================
   PASTEL LUXURY TRAVEL PORTAL THEME
   Palette:
   #fdc5f5 #f7aef8 #b388eb #8093f1 #72ddf7
   ========================================================================== */

:root {
    --brand-50:  #fef2fe;
    --brand-100: #fde4fd;
    --brand-200: #fdc5f5;
    --brand-300: #f7aef8;
    --brand-400: #b388eb;
    --brand-500: #8093f1;
    --brand-600: #6d7fe8;
    --brand-700: #5667d8;
    --brand-800: #444fb5;
    --brand-900: #323a85;

    --accent-400: #72ddf7;
    --accent-500: #4bcbe9;

    --surface: #ffffff;
    --surface-alt: #fcfaff;
    --surface-2: #f7f4fd;

    --border: #ede9fe;

    --text: #1f2937;
    --text-muted: #6b7280;

    --success: #10b981;
    --warn: #f59e0b;
    --danger: #ef4444;

    --shadow-sm: 0 4px 10px rgba(15,23,42,.04);
    --shadow-md: 0 10px 30px rgba(15,23,42,.08);
    --shadow-lg: 0 20px 50px rgba(15,23,42,.12);

    --radius: 18px;
    --radius-lg: 28px;
}

/* ==========================================================================
   BASE
   ========================================================================== */

html {
    scroll-behavior: smooth;
}

body {
    font-family: 'Inter', sans-serif;
    color: var(--text);
    letter-spacing: -0.015em;
    -webkit-font-smoothing: antialiased;
    background:
        radial-gradient(circle at 10% 10%, rgba(247,174,248,.25), transparent 30%),
        radial-gradient(circle at 90% 10%, rgba(114,221,247,.25), transparent 30%),
        radial-gradient(circle at 50% 100%, rgba(179,136,235,.18), transparent 35%),
        linear-gradient(180deg, #fcfaff 0%, #ffffff 100%);
}

/* ==========================================================================
   GLASS
   ========================================================================== */

.glass {
    background: rgba(255,255,255,.72);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    border: 1px solid rgba(255,255,255,.7);
    box-shadow: var(--shadow-sm);
}

/* ==========================================================================
   NAVBAR
   ========================================================================== */

[data-navbar] {
    transition: all .25s ease;
}

[data-navbar].is-scrolled .glass {
    background: rgba(255,255,255,.84);
    box-shadow: var(--shadow-md);
}

/* ==========================================================================
   LINKS
   ========================================================================== */

.nav-link {
    color: var(--text-muted);
    font-weight: 500;
    transition: .2s ease;
    text-decoration: none;
}

.nav-link:hover,
.nav-link.active {
    color: var(--brand-700);
}

/* ==========================================================================
   BUTTONS
   ========================================================================== */

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    padding: .85rem 1.25rem;
    border-radius: 14px;
    font-size: .9rem;
    font-weight: 600;
    border: none;
    cursor: pointer;
    transition: .25s ease;
    text-decoration: none;
}

.btn:hover {
    transform: translateY(-2px);
}

.btn-sm {
    padding: .65rem 1rem;
    font-size: .82rem;
}

.btn-primary {
    background: linear-gradient(
        135deg,
        var(--brand-500) 0%,
        var(--accent-400) 100%
    );
    color: white;
    box-shadow: 0 10px 25px rgba(128,147,241,.28);
}

.btn-primary:hover {
    box-shadow: 0 16px 30px rgba(128,147,241,.35);
}

.btn-accent {
    background: linear-gradient(
        135deg,
        var(--brand-300) 0%,
        var(--brand-400) 100%
    );
    color: white;
}

.btn-outline {
    background: white;
    border: 1px solid var(--brand-200);
    color: var(--brand-700);
}

.btn-outline:hover {
    background: var(--brand-50);
}

/* ==========================================================================
   CARDS
   ========================================================================== */

.card {
    background: rgba(255,255,255,.88);
    border: 1px solid rgba(255,255,255,.8);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border-radius: var(--radius);
    box-shadow: var(--shadow-md);
}

.card-hover {
    transition: .25s ease;
}

.card-hover:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow-lg);
}

/* ==========================================================================
   FORMS
   ========================================================================== */

.input,
.select,
.textarea {
    width: 100%;
    padding: .9rem 1rem;
    border-radius: 14px;
    border: 1px solid var(--border);
    background: white;
    color: var(--text);
    font-size: .95rem;
    transition: .2s ease;
}

.input:focus,
.select:focus,
.textarea:focus {
    outline: none;
    border-color: var(--brand-500);
    box-shadow: 0 0 0 4px rgba(128,147,241,.15);
}

/* ==========================================================================
   ALERTS
   ========================================================================== */

.alert {
    padding: 1rem 1.2rem;
    border-radius: 16px;
    font-size: .9rem;
    font-weight: 500;
    border: 1px solid transparent;
}

.alert-success {
    background: #ecfdf5;
    color: #065f46;
    border-color: #a7f3d0;
}

.alert-warn {
    background: #fffbeb;
    color: #92400e;
    border-color: #fde68a;
}

.alert-danger {
    background: #fef2f2;
    color: #991b1b;
    border-color: #fecaca;
}

/* ==========================================================================
   BADGES
   ========================================================================== */

.badge {
    display: inline-flex;
    align-items: center;
    padding: .35rem .75rem;
    border-radius: 999px;
    font-size: .75rem;
    font-weight: 600;
    background: var(--brand-50);
    color: var(--brand-700);
}

/* ==========================================================================
   HERO BACKGROUND
   ========================================================================== */

.bg-hero-travel {
    background:
        radial-gradient(circle at 15% 20%, rgba(247,174,248,.35), transparent 35%),
        radial-gradient(circle at 85% 10%, rgba(114,221,247,.30), transparent 35%),
        radial-gradient(circle at 50% 80%, rgba(179,136,235,.25), transparent 35%),
        linear-gradient(135deg, #fcfaff 0%, #f7f4fd 100%);
}

/* ==========================================================================
   TEXT GRADIENT
   ========================================================================== */

.text-gradient {
    background: linear-gradient(
        135deg,
        var(--brand-500) 0%,
        var(--brand-400) 50%,
        var(--accent-400) 100%
    );
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

/* ==========================================================================
   FOOTER
   ========================================================================== */

footer {
    backdrop-filter: blur(12px);
}

/* ==========================================================================
   SCROLLBAR
   ========================================================================== */

::-webkit-scrollbar {
    width: 10px;
}

::-webkit-scrollbar-thumb {
    background: #d8b4fe;
    border-radius: 999px;
}

::-webkit-scrollbar-thumb:hover {
    background: #c084fc;
}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */

@media (max-width: 768px) {
    .btn {
        width: 100%;
    }

    .card {
        border-radius: 16px;
    }
}