/* ============================================================
   AIDC — Design Éditorial Magazine
   Palette : Navy #0B1120 / Bleu électrique #1E6EFA / Blanc #F8F9FC
   Typo : Bebas Neue (display) + Instrument Serif (titres) + Manrope (corps)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Instrument+Serif:ital@0;1&family=Manrope:wght@300;400;500;600;700&display=swap');

:root {
    --blue:     #00559a;
    --blue-2:   #1966b7;
    --blue-lt:  #257bd5;
    --blue-hac: #89c2eb;
    --white:    #F8F9FC;
    --grey-1:   #888;
    --grey-2:   #ccc;
    --grey-3:   #eee;
    --red:      #dd1e16;
    --orange:   #e67d21;
    --yellow:   #f2c52a;
    --green:    #8bc43f;
    --ff-display: 'Bebas Neue', sans-serif;
    --ff-serif:   'Instrument Serif', Georgia, serif;
    --ff-body:    'Manrope', sans-serif;
    --radius: 4px;
    --shadow: 0 2px 24px rgba(11,17,32,0.18);
    --shadow-lg: 0 8px 48px rgba(11,17,32,0.32);
    --transition: 0.22s cubic-bezier(0.4,0,0.2,1);
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--ff-body);background:var(--white);color:var(--blue);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{line-height:1.15}
.display{font-family:var(--ff-display);letter-spacing:.02em;line-height:.95}
.serif{font-family:var(--ff-serif)}
.container{max-width:1200px;margin:0 auto;padding:0 2rem}
.container-wide{max-width:1400px;margin:0 auto;padding:0 2rem}
.section-pad{padding:6rem 0}
.text-blue{color:var(--blue)}
.text-grey{color:var(--grey-1)}

/* Badge */
.badge{display:inline-block;font-family:var(--ff-body);font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:.3em .75em;border-radius:2px;background:var(--blue-lt);color:var(--blue)}
.badge-navy{background:var(--blue);color:var(--white)}
.badge-outline{background:transparent;border:1px solid var(--grey-2);color:var(--grey-1)}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.75rem;font-family:var(--ff-body);font-size:.85rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;border:none;cursor:pointer;border-radius:var(--radius);transition:var(--transition);text-decoration:none}
.btn-primary{background:var(--blue);color:#fff}
.btn-primary:hover{background:var(--blue-2);transform:translateY(-1px);box-shadow:0 4px 20px rgba(30,110,250,.4)}
.btn-outline{background:transparent;color:var(--blue);border:2px solid var(--blue)}
.btn-outline:hover{background:var(--blue);color:#fff}
.btn-white{background:#fff;color:var(--blue)}
.btn-white:hover{background:var(--grey-3)}
.btn-ghost{background:transparent;color:var(--grey-1)}
.btn-ghost:hover{color:var(--blue)}

/* NAVBAR */
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;background:linear-gradient(to right, rgb(255, 255, 255) 25%, var(--blue) 60%);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(11,17,32,.25);transition:var(--transition)}
.navbar-inner{display:flex;align-items:center;justify-content:space-between;height:80px;padding:0 2rem;max-width:1400px;margin:0 auto}
.navbar-logo{display:flex;align-items:center;gap:.75rem;color:var(--white);font-family:var(--ff-display);font-size:1.6rem;letter-spacing:.08em}
.navbar-logo .logo-dot{width:8px;height:8px;border-radius:50%;background:var(--blue);animation:pulse-dot 2s ease-in-out infinite}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.7)}}
.navbar-links{display:flex;align-items:center;gap:.25rem;list-style:none}
.navbar-links a{color:rgba(248,249,252,.7);font-size:.82rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;padding:.4rem .85rem;border-radius:var(--radius);transition:var(--transition)}
.navbar-links a:hover{color:#fff;background:rgba(255,255,255,.08)}
.navbar-links a.active{color:#fff}
.navbar-cta{margin-left:.5rem;background:var(--blue);color:#fff;padding:.45rem 1.1rem;border-radius:var(--radius);font-size:.8rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;transition:var(--transition)}
.navbar-cta:hover{background:var(--blue-2);color:#fff!important}
.navbar-toggle{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px}
.navbar-toggle span{display:block;width:24px;height:2px;background:var(--white);border-radius:2px;transition:var(--transition)}
.navbar-mobile{display:none;position:fixed;inset:68px 0 0;background:var(--blue);z-index:999;padding:2rem;flex-direction:column;gap:.5rem}
.navbar-mobile.open{display:flex}
.navbar-mobile a{color:rgba(248,249,252,.7);font-size:1.2rem;font-weight:500;padding:.75rem 0;border-bottom:1px solid rgba(255,255,255,.06);transition:var(--transition)}
.navbar-mobile a:hover{color:#fff}

/* HERO */
.hero{min-height:100vh;background:linear-gradient(to bottom, rgba(255,255,222, 0) 10%, var(--blue-hac) 75%), url('/images/bg/home-bg.jpg') no-repeat; background-size: cover;display:grid;grid-template-columns:1fr 1fr;position:relative;overflow:hidden}
.hero::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 80% at 70% 50%,rgba(30,110,250,.12) 0%,transparent 70%);pointer-events:none}
.hero-grid-bg{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:60px 60px;pointer-events:none}
.hero-left{display:flex;flex-direction:column;justify-content:flex-end;padding:8rem 3rem 5rem;position:relative;z-index:1}
.hero-tag{font-family:var(--ff-body);font-size:.72rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--blue);margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem}
.hero-tag::before{content:'';display:block;width:32px;height:1px;background:var(--blue)}
.hero-title{font-family:var(--ff-display);font-size:clamp(2.5rem,5vw,4.5rem);line-height:.9;color:var(--white);letter-spacing:.04em;margin-bottom:2rem}
.hero-title .blue{color:var(--blue)}
.hero-subtitle{font-family:var(--ff-serif);font-size:clamp(1rem,2vw,1.3rem);color:rgba(248,249,252,.6);font-style:italic;max-width:420px;line-height:1.7;margin-bottom:2.5rem}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}
.hero-right{display:flex;flex-direction:column;justify-content:center;align-items:flex-end;padding:8rem 3rem 5rem;position:relative;z-index:1}
.hero-stat-stack{display:flex;flex-direction:column;gap:2rem;width:100%;max-width:280px}
.hero-stat{border-left:2px solid var(--blue);padding:1rem 1.5rem;background:rgba(255,255,255,.03);border-radius:0 var(--radius) var(--radius) 0}
.hero-stat .number{font-family:var(--ff-display);font-size:3rem;color:var(--white);letter-spacing:.04em;line-height:1}
.hero-stat .label{font-size:.75rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--grey-1);margin-top:.25rem}
.hero-scroll{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem;color:rgba(248,249,252,.3);font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;z-index:2;animation:bounce-scroll 2s ease-in-out infinite}
.hero-scroll svg{width:16px;height:16px}
@keyframes bounce-scroll{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(6px)}}

/* TICKER */
.ticker{background:var(--blue);padding:.65rem 0;overflow:hidden;white-space:nowrap}
.ticker-inner{display:inline-flex;animation:ticker-scroll 30s linear infinite}
.ticker-item{display:inline-flex;align-items:center;gap:1.5rem;padding:0 2rem;font-family:var(--ff-display);font-size:.9rem;letter-spacing:.1em;color:#fff}
.ticker-sep{color:rgba(255,255,255,.4);font-size:1.2rem}
@keyframes ticker-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ABOUT */
.about-strip{padding:6rem 0;background:var(--white)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.about-label{font-size:.72rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--blue);margin-bottom:1rem;display:flex;align-items:center;gap:.75rem}
.about-label::before{content:'';width:24px;height:1px;background:var(--blue);display:block}
.about-title{font-family:var(--ff-display);font-size:clamp(2.5rem,5vw,4.5rem);letter-spacing:.02em;line-height:.95;margin-bottom:1.5rem;color:var(--blue)}
.about-text{font-family:var(--ff-serif);font-size:1.1rem;font-style:italic;color:var(--grey-1);line-height:1.8;margin-bottom:2rem}
.about-text-plain{font-size:.95rem;color:#444;line-height:1.75;margin-bottom:1.5rem}
.piliers-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.pilier{padding:1.5rem;border:1px solid var(--grey-3);border-radius:var(--radius);transition:var(--transition)}
.pilier:hover{border-color:var(--blue);transform:translateY(-2px)}
.pilier-icon{width:36px;height:36px;background:var(--blue-lt);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:1.1rem;margin-bottom:.75rem}
.pilier h4{font-size:.85rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--blue);margin-bottom:.35rem}
.pilier p{font-size:.82rem;color:var(--grey-1);line-height:1.5}

/* MISSION BAND */
.mission-band{background:var(--green);padding:5rem 0;position:relative;overflow:hidden}
.mission-band::before{content:'AIDC';position:absolute;right:-2rem;top:50%;transform:translateY(-50%);font-family:var(--ff-display);font-size:18rem;color:rgba(255,255,255,.03);letter-spacing:.04em;pointer-events:none;line-height:1}
.mission-content{position:relative;z-index:1;text-align:center;max-width:700px;margin:0 auto}
.mission-content .mission-quote{font-family:var(--ff-serif);font-size:clamp(1.3rem,2.5vw,1.9rem);font-style:italic;color:var(--white);line-height:1.6;margin:1.5rem 0 2rem}
.mission-content .mission-quote em{color:var(--blue);font-style:normal}

/* SECTION HEADER */
.section-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:3rem;gap:2rem}
.section-header-left .section-label{font-size:.72rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--blue);margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}
.section-header-left .section-label::before{content:'';width:16px;height:1px;background:var(--blue);display:block}
.section-title{font-family:var(--ff-display);font-size:clamp(2rem,4vw,3.5rem);letter-spacing:.02em;color:var(--blue);line-height:.95}

/* ACTIVITY CARDS */
.activities-featured{padding:6rem 0;background:var(--grey-3)}
.activity-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.activity-card{background:var(--white);border-radius:var(--radius);overflow:hidden;border:1px solid var(--grey-3);transition:var(--transition);display:flex;flex-direction:column}
.activity-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.activity-card-img{height:180px;background:linear-gradient(135deg,var(blue-hac),var(--blue));position:relative;overflow:hidden}
.activity-card-img img{width:100%;height:100%;object-fit:cover}
.activity-card-img .card-badge{position:absolute;top:1rem;left:1rem}
.activity-card-body{padding:1.5rem;flex:1;display:flex;flex-direction:column}
.activity-card-meta{font-size:.72rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--grey-1);margin-bottom:.5rem}
.activity-card-title{font-family:var(--ff-serif);font-size:1.1rem;color:var(--blue);line-height:1.4;margin-bottom:.75rem}
.activity-card-desc{font-size:.85rem;color:var(--grey-1);line-height:1.6;flex:1;margin-bottom:1.25rem}
.activity-card-link{font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--blue);display:flex;align-items:center;gap:.4rem;transition:var(--transition)}
.activity-card-link:hover{gap:.7rem}
.activity-card-link svg{width:14px;height:14px}

/* GALLERY PREVIEW */
.gallery-preview{padding:6rem 0;background:var(--white)}
.gallery-mosaic{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:220px 220px;gap:4px;border-radius:var(--radius);overflow:hidden}
.gallery-mosaic .photo{background:var(--blue);position:relative;overflow:hidden;cursor:pointer}
.gallery-mosaic .photo:first-child{grid-row:span 2}
.gallery-mosaic .photo img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.gallery-mosaic .photo:hover img{transform:scale(1.05)}
.gallery-mosaic .photo-overlay{position:absolute;inset:0;background:rgba(11,17,32,.5);display:flex;align-items:center;justify-content:center;opacity:0;transition:var(--transition)}
.gallery-mosaic .photo:hover .photo-overlay{opacity:1}
.photo-overlay svg{color:#fff;width:24px;height:24px}

/* CTA ADHESION */
.cta-join{background:var(--orange);padding:6rem 0;position:relative;overflow:hidden}
.cta-join::before{content:'';position:absolute;top:-60px;right:-60px;width:400px;height:400px;border-radius:50%;border:80px solid rgba(30,110,250,.06);pointer-events:none}
.cta-join-inner{display:flex;align-items:center;justify-content:space-between;gap:3rem;position:relative;z-index:1}
.cta-join-text h2{font-family:var(--ff-display);font-size:clamp(2.5rem,5vw,5rem);color:var(--white);letter-spacing:.02em;line-height:.95;margin-bottom:1rem}
.cta-join-text h2 em{color:var(--blue);font-style:normal}
.cta-join-text p{color:rgba(248,249,252,.55);font-size:1rem;max-width:400px;line-height:1.7}
.cta-join-actions{display:flex;flex-direction:column;gap:1rem;flex-shrink:0}

/* FOOTER */
.footer{background:var(--blue);border-top:1px solid rgba(255,255,255,.06);padding:4rem 0 2rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
.footer-brand .logo-text{font-family:var(--ff-display);font-size:2rem;letter-spacing:.08em;color:var(--white);margin-bottom:.75rem}
.footer-brand p{font-size:.85rem;color:var(--grey-2);line-height:1.7;max-width:260px;margin-bottom:1.5rem}
.footer-socials{display:flex;gap:.5rem}
.footer-social-btn{width:36px;height:36px;border-radius:var(--radius);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:var(--grey-2);transition:var(--transition);font-size:.85rem}
.footer-social-btn:hover{border-color:var(--blue);color:var(--blue)}
.footer-col h5{font-size:.72rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--white);margin-bottom:1.25rem}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:.6rem}
.footer-col ul a{font-size:.85rem;color:var(--grey-2);transition:var(--transition)}
.footer-col ul a:hover{color:var(--white);padding-left:4px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.06);padding-top:1.5rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;font-size:.78rem;color:var(--grey-2)}

/* PAGE HERO */
.page-hero{padding:12rem 0 5rem;background:var(--blue);position:relative;overflow:hidden}
.page-hero::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 50% 100% at 0% 50%,rgba(30,110,250,.1) 0%,transparent 60%);pointer-events:none}
.page-hero-label{font-size:.72rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--blue);margin-bottom:1rem}
.page-hero-title{font-family:var(--ff-display);font-size:clamp(2rem,4vw,3.5rem);color:var(--white);letter-spacing:.04em;line-height:.9;position:relative;z-index:1}
.page-hero-sub{font-family:var(--ff-serif);font-size:1.15rem;font-style:italic;color:rgba(248,249,252,.55);margin-top:1.5rem;max-width:500px;position:relative;z-index:1}
.breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.78rem;color:var(--grey-1);margin-bottom:2rem}
.breadcrumb a{color:var(--grey-1);transition:var(--transition)}
.breadcrumb a:hover{color:var(--white)}
.breadcrumb-sep{font-size:.6rem}

/* VALUES */
.values-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;padding:6rem 0}
.value-card{padding:2rem 1.5rem;border-top:3px solid transparent;background:var(--white);border-radius:var(--radius);transition:var(--transition);box-shadow:0 1px 4px rgba(11,17,32,.06)}
.value-card:hover{border-top-color:var(--blue);transform:translateY(-4px)}
.value-num{font-family:var(--ff-display);font-size:3rem;color:var(--grey-3);letter-spacing:.04em;line-height:1;margin-bottom:1rem}
.value-card h3{font-size:.9rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.5rem;color:var(--blue)}
.value-card p{font-size:.85rem;color:var(--grey-1);line-height:1.6}

/* BUREAU */
.bureau-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;padding:4rem 0 6rem}
.membre-card{background:var(--white);border-radius:var(--radius);overflow:hidden;border:1px solid var(--grey-3);transition:var(--transition)}
.membre-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.membre-avatar{height:120px;background:linear-gradient(135deg,var(blue-hac),var(--blue));display:flex;align-items:center;justify-content:center;font-family:var(--ff-display);font-size:2.5rem;color:rgba(255,255,255,.5)}
.membre-info{padding:1.25rem}
.membre-info h4{font-size:.95rem;font-weight:700;color:var(--blue);margin-bottom:.25rem}
.membre-info .role{font-size:.78rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--blue)}

/* ACTIVITIES PAGE */
.filters-bar{display:flex;gap:.5rem;margin-bottom:2.5rem;flex-wrap:wrap}
.filter-btn{padding:.5rem 1.25rem;border:1px solid var(--grey-2);border-radius:var(--radius);background:transparent;font-family:var(--ff-body);font-size:.8rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--grey-1);cursor:pointer;transition:var(--transition)}
.filter-btn.active,.filter-btn:hover{background:var(--blue);border-color:var(--blue);color:#fff}
.activities-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}

/* ACTIVITY DETAIL */
.activity-detail-hero{padding:11rem 0 4rem;background:var(--blue);position:relative;overflow:hidden}
.activity-detail-hero .hero-img{position:absolute;inset:0;z-index:0}
.activity-detail-hero .hero-img img{width:100%;height:100%;object-fit:cover;opacity:.2}
.activity-detail-hero .overlay{position:absolute;inset:0;background:linear-gradient(to right,var(--blue) 50%,transparent);z-index:1}
.activity-detail-hero .hero-content{position:relative;z-index:2}
.activity-meta-bar{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap;margin:1.5rem 0;font-size:.82rem;color:var(--grey-1)}
.activity-meta-bar .sep{color:var(--grey-2)}
.activity-body{padding:5rem 0}
.activity-body-grid{display:grid;grid-template-columns:2fr 1fr;gap:4rem}
.activity-content-text{font-size:1rem;color:#333;line-height:1.8}
.activity-content-text p{margin-bottom:1.25rem}
.activity-sidebar{display:flex;flex-direction:column;gap:1.5rem}
.activity-info-box{background:var(--grey-3);border-radius:var(--radius);padding:1.5rem}
.activity-info-box h4{font-size:.72rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--blue);margin-bottom:1rem}
.activity-info-row{display:flex;align-items:flex-start;gap:.75rem;padding:.6rem 0;border-bottom:1px solid var(--grey-2);font-size:.85rem}
.activity-info-row:last-child{border-bottom:none}
.activity-info-row .info-label{font-weight:600;color:var(--blue);min-width:80px}
.activity-info-row .info-val{color:var(--grey-1)}

/* GALLERY PAGE */
.gallery-page{padding:3rem 0 6rem}
.album-filters{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:2.5rem}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:4px}
.gallery-grid-item{aspect-ratio:1;background:var(--blue);overflow:hidden;cursor:zoom-in;position:relative}
.gallery-grid-item img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.gallery-grid-item:hover img{transform:scale(1.06)}
.gallery-grid-item .grid-overlay{position:absolute;inset:0;background:rgba(11,17,32,.55);opacity:0;transition:var(--transition);display:flex;align-items:center;justify-content:center}
.gallery-grid-item:hover .grid-overlay{opacity:1}
.grid-overlay svg{color:#fff;width:24px}
.lightbox{position:fixed;inset:0;background:rgba(11,17,32,.96);z-index:9000;display:none;align-items:center;justify-content:center;padding:2rem}
.lightbox.open{display:flex}
.lightbox-img{max-width:90vw;max-height:85vh;border-radius:var(--radius)}
.lightbox-close{position:absolute;top:1.5rem;right:1.5rem;width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,255,255,.15);background:transparent;color:#fff;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition)}
.lightbox-close:hover{background:rgba(255,255,255,.1)}
.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);color:#fff;width:48px;height:48px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition);font-size:1.1rem}
.lightbox-nav:hover{background:rgba(255,255,255,.2)}
.lightbox-nav.prev{left:1.5rem}
.lightbox-nav.next{right:1.5rem}
.lightbox-caption{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);color:var(--grey-1);font-size:.85rem;text-align:center}

/* ADHESION PAGE */
.adhesion-intro{padding:4rem 0}
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:4rem}
.pricing-card{background:var(--white);border:1px solid var(--grey-3);border-radius:var(--radius);padding:2.5rem 2rem;transition:var(--transition);position:relative}
.pricing-card.featured{background:var(--blue);border-color:var(--blue)}
.pricing-card.featured .pricing-name,.pricing-card.featured .pricing-desc{color:var(--grey-1)}
.pricing-card.featured .pricing-price{color:var(--white)}
.pricing-card.featured .pricing-features li{color:rgba(248,249,252,.7)}
.pricing-card.featured .pricing-features li::before{background:var(--blue)}
.popular-tag{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--blue);color:#fff;font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:.25em 1em;border-radius:2px}
.pricing-name{font-size:.72rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--grey-1);margin-bottom:.75rem}
.pricing-price{font-family:var(--ff-display);font-size:3.5rem;letter-spacing:.02em;color:var(--blue);line-height:1;margin-bottom:.25rem}
.pricing-price span{font-size:1.2rem}
.pricing-desc{font-size:.85rem;color:var(--grey-1);margin-bottom:1.5rem;line-height:1.5}
.pricing-features{list-style:none;display:flex;flex-direction:column;gap:.6rem;margin-bottom:2rem}
.pricing-features li{font-size:.85rem;color:#444;display:flex;align-items:center;gap:.6rem}
.pricing-features li::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--blue);flex-shrink:0}
.adhesion-form-section{background:var(--grey-3);padding:5rem 0}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
.form-box{background:var(--white);border-radius:var(--radius);padding:2.5rem;box-shadow:0 1px 4px rgba(11,17,32,.08)}
.form-box h3{font-family:var(--ff-display);font-size:1.8rem;letter-spacing:.04em;color:var(--blue);margin-bottom:.5rem}
.form-box .form-intro{font-size:.88rem;color:var(--grey-1);margin-bottom:2rem}
.form-group{margin-bottom:1.25rem}
label{display:block;font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--blue);margin-bottom:.4rem}
input[type="text"],input[type="email"],input[type="tel"],input[type="number"],select,textarea{width:100%;padding:.75rem 1rem;border:1px solid var(--grey-2);border-radius:var(--radius);font-family:var(--ff-body);font-size:.95rem;background:var(--white);color:var(--blue);transition:var(--transition);outline:none}
input:focus,select:focus,textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(30,110,250,.1)}
textarea{min-height:120px;resize:vertical}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-submit{margin-top:1.5rem}
.bank-info-box{background:var(--blue);border-radius:var(--radius);padding:2.5rem;color:var(--white)}
.bank-info-box h3{font-family:var(--ff-display);font-size:1.8rem;letter-spacing:.04em;color:var(--white);margin-bottom:.5rem}
.bank-info-box .subtitle{color:var(--grey-1);font-size:.88rem;margin-bottom:2rem}
.bank-detail{padding:1rem 0;border-bottom:1px solid rgba(255,255,255,.07)}
.bank-detail:last-child{border-bottom:none}
.bank-detail .det-label{font-size:.7rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--grey-1);margin-bottom:.25rem}
.bank-detail .det-val{font-size:.95rem;color:var(--white);font-weight:600}
.bank-note{margin-top:1.5rem;padding:1rem;background:rgba(30,110,250,.12);border-left:2px solid var(--blue);border-radius:0 var(--radius) var(--radius) 0;font-size:.82rem;color:rgba(248,249,252,.7);line-height:1.6}

/* CONTACT PAGE */
.contact-section{padding:4rem 0 6rem}
.contact-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:4rem;align-items:start}
.contact-info-panel{display:flex;flex-direction:column;gap:1.5rem}
.contact-info-card{padding:1.5rem;border:1px solid var(--grey-3);border-radius:var(--radius);transition:var(--transition)}
.contact-info-card:hover{border-color:var(--blue)}
.contact-info-card .icon{width:40px;height:40px;background:var(--blue-lt);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:1.1rem;margin-bottom:.75rem}
.contact-info-card h4{font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--blue);margin-bottom:.25rem}
.contact-info-card p{font-size:.88rem;color:var(--grey-1);line-height:1.6}
.contact-form-panel{background:var(--white);border:1px solid var(--grey-3);border-radius:var(--radius);padding:2.5rem}
.contact-form-panel h3{font-family:var(--ff-display);font-size:2rem;letter-spacing:.04em;color:var(--blue);margin-bottom:.5rem}
.contact-form-panel .subtitle{font-size:.88rem;color:var(--grey-1);margin-bottom:2rem}

/* FLASH */
.flash-container{position:fixed;bottom:2rem;right:2rem;z-index:5000;display:flex;flex-direction:column;gap:.75rem}
.flash{padding:1rem 1.5rem;border-radius:var(--radius);font-size:.88rem;font-weight:500;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:.75rem;animation:flash-in .3s ease;max-width:360px}
.flash-success{background:#0f5132;color:#d1e7dd;border-left:3px solid #198754}
.flash-error{background:#842029;color:#f8d7da;border-left:3px solid var(--red)}
@keyframes flash-in{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:none}}

/* ANIMATIONS */
.fade-up{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.fade-up.visible{opacity:1;transform:none}
.fade-up:nth-child(2){transition-delay:.1s}
.fade-up:nth-child(3){transition-delay:.2s}
.fade-up:nth-child(4){transition-delay:.3s}

/* RESPONSIVE */
@media(max-width:1024px){
    .hero{grid-template-columns:1fr;min-height:auto}
    .hero-right{display:none}
    .hero-left{padding:10rem 2rem 5rem}
    .about-grid,.activity-body-grid,.contact-grid,.form-grid{grid-template-columns:1fr}
    .activity-cards,.activities-grid,.pricing-grid{grid-template-columns:1fr 1fr}
    .gallery-mosaic{grid-template-columns:repeat(2,1fr);grid-template-rows:auto}
    .gallery-mosaic .photo:first-child{grid-row:span 1}
    .values-grid,.bureau-grid{grid-template-columns:repeat(2,1fr)}
    .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
    .navbar-links{display:none}
    .navbar-toggle{display:flex}
    .hero-title{font-size:5rem}
    .section-header{flex-direction:column;align-items:flex-start}
    .activity-cards,.activities-grid,.pricing-grid{grid-template-columns:1fr}
    .gallery-grid{grid-template-columns:repeat(2,1fr)}
    .cta-join-inner{flex-direction:column}
    .values-grid,.bureau-grid{grid-template-columns:1fr 1fr}
    .footer-grid{grid-template-columns:1fr}
    .footer-bottom{flex-direction:column;text-align:center}
}
