﻿/* ============================================================
   SAT PAGE — PUZA-IDENTICAL LAYOUT & ANIMATIONS
   Self-contained: includes header, footer, all sections
   ============================================================ */

/* === RESET & BASE === */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Montserrat',sans-serif;color:#333;background:#fff;overflow-x:hidden;line-height:1.6;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit;transition:all .3s ease}
ul{list-style:none}
img{max-width:100%;height:auto;display:block}

/* === HEADER === */

.header.scrolled{background:rgba(255,255,255,.9);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:0 2px 20px rgba(0,0,0,.06)}

.lang-btn.active{background:#333;color:#fff}

.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(6px,6px)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}

/* Side Buttons */
.side-buttons{position:fixed;right:0;top:50%;transform:translateY(-50%);z-index:900;display:flex;flex-direction:column;gap:2px}
.side-btn{display:block;padding:12px 20px;background:rgba(51,51,51,.88);color:#fff;font-size:.68rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;transition:all .3s ease}
.side-btn:hover{background:#e3121a;padding-right:28px}

/* Mobile Nav */

.mobile-nav.open{right:0}

/* ========================
   HERO
   ======================== */
.hero{position:relative;width:100%;height:65vh;min-height:450px;overflow:hidden}
.hero-bg{position:absolute;inset:0}
.hero-img{width:100%;height:100%;object-fit:cover;transition:transform 8s ease}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(0,0,0,.60) 0%,rgba(0,0,0,.3) 50%,rgba(0,0,0,.15) 100%)}
.hero-content{position:absolute;bottom:80px;left:60px;z-index:2;max-width:550px}
.hero-title{font-size:3.2rem;font-weight:900;color:#fff;letter-spacing:4px;margin-bottom:12px;line-height:1.1;opacity:0;transform:translateY(30px);animation:heroFadeIn .8s .3s forwards}
.hero-accent-line{width:80px;height:4px;background:#e3121a;margin-bottom:20px;opacity:0;transform:scaleX(0);transform-origin:left;animation:lineGrow .6s .6s forwards}
.hero-text{font-size:.88rem;color:rgba(255,255,255,.85);line-height:1.7;margin-bottom:8px;opacity:0;transform:translateY(20px);animation:heroFadeIn .8s .9s forwards}
.hero-breadcrumb{position:absolute;bottom:20px;left:60px;z-index:2;font-size:.7rem;color:rgba(255,255,255,.45);letter-spacing:.5px}
.hero-breadcrumb a{color:rgba(255,255,255,.45)}
.hero-breadcrumb a:hover{color:#fff}

@keyframes heroFadeIn{to{opacity:1;transform:translateY(0)}}
@keyframes lineGrow{to{opacity:1;transform:scaleX(1)}}

/* ========================
   YELLOW BANNER
   ======================== */
.yellow-banner{background:linear-gradient(135deg, #fdfdfd 0%, #f8f9fa 100%);padding:12px 40px;overflow:hidden;position:relative;border-top:3px solid #e3121a}
.yellow-inner{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:6px}
.yellow-circle{width:65px;height:65px;border-radius:50%;background:#242841;display:flex;align-items:center;justify-content:center;position:relative;flex-shrink:0;box-shadow:0 0 0 0 rgba(227,18,26,0.4);animation:pulseRed 2s infinite}
.yellow-circle-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px}
.yellow-circle-icon svg{width:100%;height:100%;color:#fff}
.yellow-main-text{font-size:.8rem;font-weight:800;color:#242841;letter-spacing:2px;text-transform:uppercase;margin-top:2px}

@keyframes pulseRed {
    0% { box-shadow: 0 0 15px 0 rgba(227,18,26,0.4); }
    70% { box-shadow: 0 0 25px 15px rgba(227,18,26,0); }
    100% { box-shadow: 0 0 15px 0 rgba(227,18,26,0); }
}

/* ========================
   TABS
   ======================== */
.tabs-section{padding:0 0 60px;background:#fff}
.tabs-container{max-width:1200px;margin:0 auto;padding:60px 40px 0}

.tabs-nav{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-bottom:40px}
.tab-btn{padding:24px 20px;background:#f0f0f0;border:none;border-top:4px solid #ddd;font-family:'Montserrat',sans-serif;font-size:.78rem;font-weight:700;letter-spacing:.5px;color:#555;text-align:left;cursor:pointer;transition:all .3s ease;line-height:1.4;text-transform:uppercase}
.tab-btn:hover{background:#f8f8f8;color:#333}
.tab-btn.active{background:#fff;border-top-color:#e3121a;color:#242841}

/* Tab Panels */
.tab-panel{display:none;opacity:0;transform:translateY(10px);transition:opacity .4s ease,transform .4s ease}
.tab-panel.active{display:block;opacity:1;transform:translateY(0);animation:tabFadeIn .4s ease}
@keyframes tabFadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

.tab-panel p{font-size:.88rem;color:#444;line-height:1.8;margin-bottom:14px}
.tab-panel h3{font-size:1rem;font-weight:700;color:#222;margin:30px 0 12px}

.bullet-list{margin:10px 0 20px;padding-left:0}
.bullet-list li{font-size:.85rem;color:#444;padding:5px 0 5px 16px;position:relative}
.bullet-list li::before{content:'•';position:absolute;left:0;color:#e3121a;font-weight:700}

/* Tables */
.data-table{width:100%;border-collapse:collapse;margin:20px 0 28px;font-size:.8rem}
.data-table thead th{background:#333;color:#fff;padding:12px 14px;text-align:left;font-weight:600;font-size:.72rem;letter-spacing:1px;text-transform:uppercase}
.data-table tbody td{padding:11px 14px;border-bottom:1px solid #eee;color:#444}
.data-table tbody tr:hover{background:#fafafa}
.data-table tbody td strong{color:#222}

/* ========================
   ACCORDIONS
   ======================== */
.accordions{margin-top:40px;border-top:1px solid #e0e0e0}
.accordion{border-bottom:1px solid #e0e0e0}
.accordion-header{width:100%;display:flex;align-items:center;justify-content:space-between;padding:22px 0;background:none;border:none;font-family:'Montserrat',sans-serif;font-size:.95rem;font-weight:400;color:#444;cursor:pointer;transition:all .3s ease;text-align:left}
.accordion-header:hover{color:#222}
.accordion-icon{font-size:1.8rem;font-weight:300;color:#aaa;transition:transform .35s cubic-bezier(.4,0,.2,1);line-height:1}
.accordion.open .accordion-icon{transform:rotate(90deg);color:#e3121a}

.accordion-body{max-height:0;overflow:hidden;transition:max-height .5s cubic-bezier(.4,0,.2,1)}
.accordion.open .accordion-body{max-height:3000px}
.accordion-content{padding:0 0 30px}
.accordion-content p{font-size:.86rem;color:#444;line-height:1.8;margin-bottom:14px}

/* Level Chart */
.level-chart{margin:28px 0;overflow-x:auto}
.level-numbers,.level-names,.level-bars-row{display:grid;grid-template-columns:repeat(17,1fr);gap:1px;margin-bottom:2px}
.level-numbers span{text-align:center;font-size:.6rem;font-weight:700;color:#888;padding:6px 2px;background:#f5f5f5;border-radius:2px}
.level-names div{font-size:.48rem;font-weight:600;text-align:center;padding:6px 2px;background:#f0f0f0;color:#777;border-radius:2px;letter-spacing:.2px}
.level-bars-row div{font-size:.6rem;font-weight:700;text-align:center;padding:10px 2px;border-radius:2px;color:#fff;letter-spacing:.5px}
.bar-general{background:#333}
.bar-sat{background:#e3121a;color:#fff}

/* Detail List */
.detail-list{padding-left:0;margin:16px 0}
.detail-list li{font-size:.84rem;color:#444;line-height:1.7;padding:8px 0 8px 20px;position:relative;border-bottom:1px solid rgba(0,0,0,.04)}
.detail-list li::before{content:'';position:absolute;left:0;top:16px;width:6px;height:6px;border-radius:50%;background:#e3121a}
.detail-list li strong{color:#222}

/* ========================
   YELLOW ACCORDIONS (PUZA-style section dropdowns)
   ======================== */
.yellow-accordion{margin:24px 0 0;border-radius:8px;overflow:hidden;border:1px solid #e0e0e0;box-shadow:0 2px 8px rgba(0,0,0,0.04)}
.yellow-acc-header{width:100%;display:flex;align-items:center;gap:12px;padding:18px 24px;background:#f8f9fa;border:none;border-left:4px solid #e3121a;cursor:pointer;font-family:'Montserrat',sans-serif;transition:all .3s ease}
.yellow-acc-header:hover{background:#f1f2f4}
.yellow-acc-icon{font-size:1.3rem;flex-shrink:0}
.yellow-acc-title{flex:1;text-align:left;font-size:.9rem;font-weight:700;color:#242841;letter-spacing:.3px}
.yellow-acc-arrow{font-size:1.4rem;color:#555;transition:transform .35s cubic-bezier(.4,0,.2,1);flex-shrink:0;line-height:1}
.yellow-accordion.open .yellow-acc-arrow{transform:rotate(180deg)}

.yellow-acc-body{max-height:0;overflow:hidden;transition:max-height .5s cubic-bezier(.4,0,.2,1)}
.yellow-accordion.open .yellow-acc-body{max-height:5000px}
.yellow-acc-content{padding:24px 20px 30px;background:#fff;border:1px solid #eee;border-top:none}
.yellow-acc-content p{font-size:.86rem;color:#444;line-height:1.8;margin-bottom:14px}
.yellow-acc-content h4{font-size:.92rem;font-weight:700;color:#222;margin:20px 0 8px}
.yellow-acc-content .data-table{margin:16px 0 20px}

/* ========================
   RELATED COURSES
   ======================== */
.related-section{padding:60px 0 80px;background:#fff;border-top:1px solid #e8e8e8}
.related-container{max-width:1200px;margin:0 auto;padding:0 40px}
.related-heading{font-size:1.8rem;font-weight:300;color:#ccc;letter-spacing:8px;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid #e8e8e8}
.related-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:30px}
.related-card{position:relative;height:260px;overflow:hidden;display:block;cursor:pointer}
.related-img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease;filter:brightness(.8)}
.related-card:hover .related-img{transform:scale(1.06)}
.related-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.65) 0%,rgba(0,0,0,.15) 100%)}
.related-info{position:absolute;bottom:24px;left:24px;z-index:2}
.related-line{width:60px;height:4px;background:#e3121a;margin-bottom:10px}
.related-info h3{font-size:.82rem;font-weight:800;color:#fff;letter-spacing:1.5px;line-height:1.5;text-transform:uppercase}

.show-more{display:inline-block;padding:12px 28px;border:2px solid #ddd;font-size:.72rem;font-weight:700;letter-spacing:2px;color:#888;transition:all .3s ease}
.show-more:hover{border-color:#e3121a;color:#e3121a}

/* ========================
   FOOTER
   ======================== */
.footer{background:#fff;border-top:1px solid #e8e8e8;padding:50px 0 30px}
.footer-inner{max-width:1200px;margin:0 auto;padding:0 40px;display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:40px}
.footer-brand 
.footer-social{display:flex;gap:10px}
.social-icon{width:36px;height:36px;border-radius:50%;border:1.5px solid #ddd;display:flex;align-items:center;justify-content:center;color:#888;transition:all .3s ease}
.social-icon svg{width:16px;height:16px}
.social-icon:hover{background:#e3121a;border-color:#e3121a;color:#fff}
.footer-title{font-size:.72rem;font-weight:700;letter-spacing:2px;color:#333;margin-bottom:12px;padding-bottom:8px;border-bottom:3px solid #e3121a;display:inline-block}
.footer-col ul{padding:0}
.footer-col li{margin-bottom:6px;font-size:.75rem;color:#888;letter-spacing:.3px}
.footer-col a{color:#888}
.footer-col a:hover{color:#e3121a}

/* ========================
   RESPONSIVE
   ======================== */
@media(max-width:768px){
    
    .side-buttons{display:none}
    .hero{height:50vh;min-height:320px}
    .hero-content{left:20px;bottom:60px;max-width:90%}
    .hero-title{font-size:2rem}
    .hero-breadcrumb{left:20px}
    .yellow-banner{padding:20px}
    .yellow-main-text{font-size:1.2rem}
    .tabs-container{padding:40px 20px 0}
    .tabs-nav{grid-template-columns:repeat(2,1fr)}
    .related-grid{grid-template-columns:1fr}
    .footer-inner{grid-template-columns:1fr;gap:24px}
    .level-numbers,.level-names,.level-bars-row{min-width:600px}
}
@media(max-width:480px){
    .hero-title{font-size:1.6rem;letter-spacing:2px}
    .tabs-nav{grid-template-columns:1fr}
}


