/* =========================================================
   MOVERSPRO  |  style.css
   Glasmorphism + Dynamic Analog Gradients
   Fonts: Montserrat (headings) / Merriweather (body)
   ========================================================= */

/* ---------- ROOT & RESETS ---------- */
:root{
    /* Analog palette: azul – cian – turquesa */
    --color-primary:#0077ff;
    --color-secondary:#00a6ff;
    --color-accent:#00c8ff;
    --color-dark:#0d0d0d;
    --color-light:#f5faff;
    --gradient-main:linear-gradient(135deg,var(--color-primary) 0%,var(--color-accent) 100%);
    --gradient-alt:linear-gradient(135deg,var(--color-secondary) 0%,var(--color-accent) 100%);
    --glass-bg:rgba(255,255,255,0.15);
    --glass-border:rgba(255,255,255,0.25);
    --shadow-main:0 8px 32px rgba(0,0,0,0.2);
    --transition:all .35s ease;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
    font-family:'Merriweather',serif;
    background:var(--gradient-alt) fixed;
    color:#333;
    line-height:1.6;
    -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}

/* ---------- TYPOGRAPHY ---------- */
h1,h2,h3,h4,h5,h6{
    font-family:'Montserrat',sans-serif;
    font-weight:700;
    color:#222;
    text-align:center;
}
.section-title{
    font-size:2.2rem;
    margin-bottom:1.5rem;
    text-shadow:1px 1px 3px rgba(0,0,0,0.5);
}
p{margin-bottom:1rem}

/* ---------- GLOBAL CONTAINERS ---------- */
.container{
    width:90%;
    max-width:1200px;
    margin:0 auto;
}
.alt-bg{
    background:var(--gradient-main);
    color:#fff;
}
.alt-bg h2,.alt-bg h3{color:#fff}

/* ---------- GLASS SECTIONS & ELEMENTS ---------- */
.glass-section,
.glass-header,
.glass-footer,
.glass-form{
    background:var(--glass-bg);
    backdrop-filter:blur(10px);
    -webkit-backdrop-filter:blur(10px);
    border:1px solid var(--glass-border);
    border-radius:16px;
    box-shadow:var(--shadow-main);
}
.glass-section{padding:4rem 0;margin:2rem 0}
.glass-footer{padding:2rem 0}
.glass-header{position:fixed;top:0;left:0;width:100%;z-index:999;padding:.8rem 0}

/* ---------- HEADER & NAV ---------- */
.site-title{font-size:1.5rem;font-weight:800;color:#fff;text-decoration:none}
.main-nav ul{display:flex;gap:1rem;list-style:none}
.main-nav a{color:#fff;text-decoration:none;font-weight:600;position:relative;padding:.3rem .6rem}
.main-nav a::after{
    content:'';position:absolute;left:0;bottom:-4px;width:0;height:2px;background:var(--color-accent);
    transition:var(--transition)
}
.main-nav a:hover::after{width:100%}
.burger-btn{
    display:none;flex-direction:column;gap:4px;background:none;border:none;cursor:pointer
}
.burger-btn span{width:24px;height:3px;background:#fff;border-radius:2px;transition:var(--transition)}
@media(max-width:900px){
    .main-nav{position:fixed;top:70px;left:-100%;width:70%;height:calc(100vh - 70px);
        background:var(--glass-bg);flex-direction:column;padding:2rem;transition:var(--transition)}
    .main-nav.open{left:0}
    .burger-btn{display:flex}
}

/* ---------- HERO ---------- */
.hero-section{
    position:relative;
    background-position:center;
    background-size:cover;
    background-repeat:no-repeat;
    color:#fff;
    padding:120px 0 80px;
    text-align:center;
}
.hero-container{max-width:800px;margin:0 auto}
.hero-subtitle{margin:1rem 0 2rem;font-size:1.1rem}
.progress-wrapper{margin-top:2rem;color:#fff}
.progress-wrapper progress{width:100%;height:8px;border-radius:4px}
.progress-label{display:inline-block;margin-top:.4rem}

/* ---------- BUTTONS ---------- */
.btn,
button,
input[type='button'],
input[type='submit']{
    background:var(--color-primary);
    color:#fff;
    border:none;
    padding:.8rem 1.8rem;
    border-radius:30px;
    cursor:pointer;
    font-family:'Montserrat',sans-serif;
    font-weight:600;
    letter-spacing:.5px;
    transition:var(--transition);
    display:inline-block;
}
.btn:hover,
button:hover,
input[type='submit']:hover{background:var(--color-accent);transform:translateY(-2px)}
.btn:active{transform:scale(.97)}

/* ---------- CARDS UNIVERSAL ---------- */
.cards-wrapper{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
    gap:2rem;
}
.card{
    display:flex;
    flex-direction:column;
    align-items:center;
    background:var(--glass-bg);
    backdrop-filter:blur(8px);
    border:1px solid var(--glass-border);
    border-radius:16px;
    box-shadow:var(--shadow-main);
    overflow:hidden;
    transition:var(--transition);
    text-align:center;
}
.card:hover{transform:translateY(-6px)}
.card-image{
    width:100%;
    height:240px;
    overflow:hidden;
}
.card-image img{
    width:100%;
    height:100%;
    object-fit:cover;
    margin:0 auto;
}
.card-content{padding:1.5rem}

/* ---------- FEATURES GRID ---------- */
.features-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
    gap:2rem;
}

/* ---------- READ MORE LINK ---------- */
.read-more{
    color:var(--color-primary);
    font-weight:600;
    text-decoration:none;
    position:relative;
}
.read-more::after{
    content:'→';
    margin-left:6px;
    transition:var(--transition)
}
.read-more:hover{color:var(--color-accent)}
.read-more:hover::after{transform:translateX(4px)}

/* ---------- PROGRESS BAR OVERRIDE (Native) ---------- */
progress{
    appearance:none;
    -webkit-appearance:none;
}
progress::-webkit-progress-bar{background:#ccc;border-radius:4px}
progress::-webkit-progress-value{background:var(--color-primary);border-radius:4px}
progress::-moz-progress-bar{background:var(--color-primary);border-radius:4px}

/* ---------- FORM ---------- */
.glass-form{
    max-width:600px;
    margin:0 auto;
    padding:2rem;
}
.form-group{margin-bottom:1.2rem;text-align:left}
.form-group label{display:block;margin-bottom:.3rem;font-weight:600}
.form-group input,
.form-group textarea{
    width:100%;
    padding:.8rem 1rem;
    border:1px solid rgba(0,0,0,0.1);
    border-radius:8px;
    font-family:'Merriweather',serif;
    resize:none;
    transition:var(--transition)
}
.form-group input:focus,
.form-group textarea:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px rgba(0,170,255,0.25)}

/* ---------- NEWS & ARTICLES ---------- */
.news-item{margin-bottom:1.5rem;padding:1rem;background:var(--glass-bg);border-radius:12px}
.news-item h3{margin-bottom:.5rem}

/* ---------- FOOTER ---------- */
.site-footer .container{display:flex;flex-direction:column;align-items:center;gap:1rem;text-align:center}
.footer-nav{display:flex;gap:1.2rem;flex-wrap:wrap}
.footer-nav a{color:#fff;text-decoration:none;transition:var(--transition)}
.footer-nav a:hover{color:var(--color-accent)}
.social-links a{color:#fff;text-decoration:none;font-weight:600;transition:var(--transition)}
.social-links a:hover{color:var(--color-accent)}

/* ---------- SECTIONS PADDING OVERRIDES ---------- */
#history,#projects,#research,#features,#services,#blog,#instructors,#news{padding-top:4rem}

/* ---------- SUCCESS PAGE ---------- */
.page-success{
    min-height:100vh;
    display:flex;
    flex-direction:column;
    justify-content:center;
    align-items:center;
    background:var(--gradient-main);
    color:#fff;
    text-align:center;
}
.page-success h1{font-size:2.5rem;margin-bottom:1rem}
.page-success a.btn{margin-top:1.5rem}

/* ---------- PRIVACY & TERMS PAGE ---------- */
.page-legal{
    padding-top:100px;
    padding-bottom:4rem;
}
.page-legal .container{max-width:800px}

/* ---------- UTILITIES ---------- */
.text-center{text-align:center}
.mb-1{margin-bottom:1rem}
.mb-2{margin-bottom:2rem}

/* ---------- AOS ANIMATION TWEAKS ---------- */
[data-aos]{transform:translateY(30px);opacity:0;transition:opacity .6s ease,var(--transition)}
[data-aos].aos-animate{transform:translateY(0);opacity:1}

/* ---------- COOKIE POPUP BUTTON OVERRIDE ---------- */
#acceptCookies:hover{background:var(--color-secondary)}

/* ---------- MEDIA QUERIES ---------- */
@media(max-width:600px){
    .hero-title{font-size:2rem}
    .section-title{font-size:1.8rem}
}

section{
    padding: 5rem 0;
}

.glass-section{
    padding: 5rem 2rem;
}
.page-success{
    justify-content: center;
}