/* ==========================================================
   GLOBAL THEME VARIABLES – Tetrad Color Scheme + Elevations
   ========================================================== */
:root{
    /* Core Palette */
    --clr-primary:#FF6B6B;      /* coral            */
    --clr-secondary:#6BCB77;    /* mint             */
    --clr-tertiary:#4D96FF;     /* azure            */
    --clr-quaternary:#FFD93D;   /* sunny yellow     */

    /* Neutrals */
    --clr-bg:#F1F3F6;
    --clr-surface:#ECEFF4;
    --clr-on-bg:#222222;        /* dark text        */
    --clr-on-surface:#333333;   /* default text     */
    --clr-white:#FFFFFF;

    /* Elevated Shadows  (Neumorphism) */
    --shadow-elev-1:7px 7px 14px rgba(0,0,0,0.15),
                    -7px -7px 14px rgba(255,255,255,0.7);
    --shadow-inset:inset 4px 4px 8px rgba(0,0,0,0.12),
                   inset -4px -4px 8px rgba(255,255,255,0.6);

    /* Transitions & Timing */
    --transition-fast: .25s ease;
    --transition-medium: .4s cubic-bezier(.4,0,.2,1);
}

/* ==========================================================
   TYPOGRAPHY
   ========================================================== */
html{
    scroll-behavior:smooth;
    background:var(--clr-bg);
}
body{
    font-family:'Merriweather', serif;
    color:var(--clr-on-surface);
    line-height:1.6;
    background:var(--clr-bg);
}
h1,h2,h3,h4,h5,h6{
    font-family:'Montserrat', sans-serif;
    color:var(--clr-on-bg);
    letter-spacing:.5px;
}
.title{
    text-shadow:1px 1px 3px rgba(0,0,0,0.5);
}

/* ==========================================================
   REUSABLE UTILS
   ========================================================== */
.neumorphic{
    background:var(--clr-surface);
    box-shadow:var(--shadow-elev-1);
    border-radius:12px;
}
.section-padding{
    padding:3rem 1.5rem;
}
.text-center{
    text-align:center;
}
[data-parallax]{
    background-attachment:fixed;
    background-size:cover;
    background-repeat:no-repeat;
}

/* ==========================================================
   BUTTONS (Global)
   ========================================================== */
.btn,
button,
input[type='submit']{
    font-family:'Montserrat',sans-serif;
    font-weight:600;
    display:inline-block;
    padding:.75rem 2rem;
    border:none;
    border-radius:50px;
    background:var(--clr-primary);
    color:var(--clr-white);
    cursor:pointer;
    box-shadow:var(--shadow-elev-1);
    transition:transform var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-fast);
}
.btn:hover,
button:hover,
input[type='submit']:hover{
    transform:translateY(-2px);
    box-shadow:0 10px 20px rgba(0,0,0,.2);
}
.btn:active,
button:active,
input[type='submit']:active{
    transform:translateY(0);
    box-shadow:var(--shadow-inset);
}
.is-secondary{
    background:var(--clr-secondary);
}
.is-tertiary{
    background:var(--clr-tertiary);
}
.is-quaternary{
    background:var(--clr-quaternary);
    color:var(--clr-on-bg);
}

/* ==========================================================
   NAVBAR
   ========================================================== */
.navbar{
    background:var(--clr-surface);
    box-shadow:var(--shadow-elev-1);
}
.navbar-item,
.navbar-link{
    font-family:'Montserrat',sans-serif;
    color:var(--clr-on-bg) !important;
    transition:color var(--transition-fast);
}
.navbar-item:hover,
.navbar-link:hover{
    color:var(--clr-primary) !important;
}

/* ==========================================================
   HERO
   ========================================================== */
.hero{
    position:relative;
    color:var(--clr-white);
}
.hero .title,
.hero .subtitle{
    color:#FFFFFF;
}
.hero.is-dark::before{
    content:'';
    position:absolute;
    inset:0;
    background:linear-gradient(rgba(0,0,0,0.5),rgba(0,0,0,0.5));
    z-index:0;
}
.hero .hero-body>*{
    position:relative;
    z-index:1;
}

/* ==========================================================
   CARDS & IMAGE CONTAINERS
   ========================================================== */
.card{
    display:flex;
    flex-direction:column;
    align-items:center;
    text-align:center;
    background:var(--clr-surface);
    border-radius:14px;
    overflow:hidden;
    transition:transform var(--transition-medium), box-shadow var(--transition-medium);
    box-shadow:var(--shadow-elev-1);
}
.card:hover{
    transform:translateY(-6px);
}
.card-image,
.image-container{
    width:100%;
    height:220px;
    overflow:hidden;
}
.card-image img,
.image-container img{
    width:100%;
    height:100%;
    object-fit:cover;
    margin:0 auto;
    transition:transform var(--transition-medium);
}
.card:hover img{
    transform:scale(1.05);
}
.card-content{
    padding:1.5rem;
}

/* ==========================================================
   TESTIMONIALS
   ========================================================== */
.testimonial{
    background:var(--clr-surface);
    padding:1.5rem;
    border-radius:12px;
    box-shadow:var(--shadow-elev-1);
}

/* ==========================================================
   READ MORE LINKS
   ========================================================== */
.read-more{
    color:var(--clr-tertiary);
    font-weight:700;
    position:relative;
    transition:color var(--transition-fast);
}
.read-more::after{
    content:'';
    position:absolute;
    width:0;
    height:2px;
    background:var(--clr-tertiary);
    bottom:-3px;
    left:0;
    transition:width var(--transition-fast);
}
.read-more:hover{
    color:var(--clr-tertiary);
}
.read-more:hover::after{
    width:100%;
}

/* ==========================================================
   FOOTER
   ========================================================== */
.footer{
    background:var(--clr-surface);
    color:var(--clr-on-surface);
    padding:2rem 1.5rem;
    box-shadow:var(--shadow-inset);
}
.footer a{
    color:var(--clr-primary);
    font-weight:600;
    margin:0 .25rem;
    transition:color var(--transition-fast);
}
.footer a:hover{
    color:var(--clr-tertiary);
}
.social-link{
    font-weight:700;
}

/* ==========================================================
   COOKIE POPUP
   ========================================================== */
#cookie-popup{
    backdrop-filter:blur(6px);
    font-family:'Merriweather',serif;
}
#cookie-popup .button{
    margin-left:.5rem;
}

/* ==========================================================
   SUCCESS PAGE
   ========================================================== */
.success-page{
    min-height:100vh;
    display:flex;
    justify-content:center;
    align-items:center;
    background:var(--clr-bg);
}
.success-page .message-box{
    padding:2rem 3rem;
    text-align:center;
    background:var(--clr-surface);
    border-radius:14px;
    box-shadow:var(--shadow-elev-1);
}

/* ==========================================================
   PAGE SPECIFIC PADDING (privacy & terms)
   ========================================================== */
.page-legal{
    padding-top:100px; /* prevent overlap with fixed header */
}

/* ==========================================================
   ANIMATIONS – Microinteractions
   ========================================================== */
@keyframes fadeInUp{
    from{opacity:0;transform:translateY(30px);}
    to{opacity:1;transform:translateY(0);}
}
.sr{
    animation:fadeInUp .7s ease both;
}

/* ==========================================================
   RESPONSIVE TWEAKS
   ========================================================== */
@media (max-width:768px){
    .navbar-menu{
        background:var(--clr-surface);
    }
    .card-image,
    .image-container{
        height:180px;
    }
}

/* ==========================================================
   FORM STYLES
   ========================================================== */
input[type='text'],
input[type='email'],
textarea{
    background:var(--clr-surface);
    border:none;
    border-radius:8px;
    padding:.75rem 1rem;
    width:100%;
    box-shadow:var(--shadow-inset);
    transition:box-shadow var(--transition-fast);
    resize:vertical;
}
input:focus,
textarea:focus{
    outline:none;
    box-shadow:0 0 0 3px var(--clr-tertiary);
}

/* ==========================================================
   MISC
   ========================================================== */
.parallax-banner{
    background-size:cover;
    background-repeat:no-repeat;
    background-attachment:fixed;
}