/* ==========================================
   דרך הורד — Design System v5
   Inspired by hadardanan.co.il
   Brand palette: Forest #4A6741, Crimson #B8293D, Gold #C4A265
   Warm therapeutic tones — NOT cold black
   ========================================== */

:root {
    --forest: #4A6741;
    --forest-dark: #2A3A25;
    --forest-deep: #1E2B1A;
    --forest-light: #6B8C62;
    --forest-pale: #E8F0E6;
    --crimson: #B8293D;
    --crimson-dark: #8E1F2E;
    --crimson-soft: #D4606F;
    --crimson-pale: #F5E0E3;
    --gold: #C4A265;
    --gold-soft: #DBC496;
    --gold-pale: #F5EDDF;
    --cream: #FDFAF6;
    --warm: #F4EDE4;
    --warm-mid: #EDE5DA;
    --charcoal: #1A1A1A;
    --dark-warm: #1E2B1A;
    --text: #2D2926;
    --text-mid: #5A524C;
    --text-light: #8A827C;
    --white: #FFFFFF;
    --shadow-sm: 0 2px 16px rgba(0,0,0,0.05);
    --shadow: 0 8px 40px rgba(0,0,0,0.07);
    --shadow-lg: 0 20px 60px rgba(0,0,0,0.10);
    --radius: 24px;
    --radius-lg: 32px;
    --radius-sm: 14px;
    --font: 'Rubik', sans-serif;
    --ease: cubic-bezier(.25,.46,.45,.94);
}

/* ===== Reset ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;scroll-padding-top:90px}
body{font-family:var(--font);color:var(--text);background:var(--cream);direction:rtl;overflow-x:hidden;line-height:1.8;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
.container{max-width:1100px;margin:0 auto;padding:0 28px}
.container-narrow{max-width:720px}
.section{padding:120px 0;position:relative;overflow:hidden}
.section-dark{background:var(--dark-warm);color:var(--white)}
.section-warm{background:var(--warm)}

/* ===== Typography ===== */
.section-title{
    font-size:clamp(2rem,5vw,3rem);
    font-weight:800;
    text-align:center;
    margin-bottom:60px;
    letter-spacing:-.02em;
    line-height:1.3;
}
.section-title.light{color:var(--white)}
.section-title.align-start{text-align:right}
.section-title::after{
    content:'';display:block;width:56px;height:3px;
    background:linear-gradient(90deg,var(--crimson),var(--gold));
    margin:18px auto 0;border-radius:2px;
}
.section-title.align-start::after{margin:18px 0 0}
.section-title.light::after{background:linear-gradient(90deg,var(--gold),var(--crimson-soft))}

/* ===== Reveal ===== */
.reveal{opacity:0;transform:translateY(45px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ===== Buttons ===== */
.btn-primary{
    display:inline-flex;align-items:center;justify-content:center;gap:8px;
    padding:20px 52px;
    background:var(--crimson);
    color:var(--white);font-family:var(--font);
    font-size:1.08rem;font-weight:600;
    border:none;border-radius:60px;cursor:pointer;
    transition:all .35s var(--ease);
    box-shadow:0 6px 28px rgba(184,41,61,0.25);
}
.btn-primary:hover{
    background:var(--crimson-dark);
    transform:translateY(-3px);
    box-shadow:0 12px 40px rgba(184,41,61,0.35);
}

/* ===== Petals — Large falling rose petals ===== */
#petals-container{position:fixed;inset:0;pointer-events:none;z-index:9998;overflow:hidden}
.petal{position:absolute;top:-80px;opacity:0;filter:blur(0.3px);animation:fall linear infinite}
@keyframes fall{
    0%{opacity:0;transform:translateX(0) rotate(0deg) scale(1)}
    6%{opacity:.55}
    30%{transform:translateX(40px) rotate(90deg) scale(.97)}
    60%{transform:translateX(-30px) rotate(200deg) scale(.92)}
    88%{opacity:.2}
    100%{opacity:0;transform:translateX(20px) rotate(380deg) scale(.8);top:108vh}
}

/* ===== NAVBAR ===== */
.navbar{
    position:fixed;top:0;left:0;right:0;z-index:9999;
    padding:0 28px;
    background:rgba(253,250,246,0.92);
    backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
    border-bottom:1px solid rgba(0,0,0,0.04);
    transition:all .3s ease;
}
.navbar.scrolled{box-shadow:0 4px 24px rgba(0,0,0,0.06)}
.nav-inner{
    max-width:1100px;margin:0 auto;
    display:flex;align-items:center;justify-content:space-between;
    height:84px;
}
.nav-logo img{
    height:108px;width:auto;
    display:block;
}
.nav-links{display:flex;align-items:center;list-style:none;gap:6px}
.nav-links a{
    padding:10px 20px;font-size:.93rem;font-weight:500;color:var(--text);
    border-radius:50px;transition:all .3s ease;
}
.nav-links a:hover{background:var(--forest-pale);color:var(--forest)}
.nav-cta{background:var(--crimson) !important;color:var(--white) !important;font-weight:600 !important}
.nav-cta:hover{background:var(--crimson-dark) !important}
.nav-toggle{
    display:none;background:none;border:none;cursor:pointer;
    width:32px;height:24px;position:relative;
}
.nav-toggle span{
    display:block;width:100%;height:2.5px;background:var(--text);border-radius:2px;
    position:absolute;left:0;transition:all .3s ease;
}
.nav-toggle span:nth-child(1){top:0}
.nav-toggle span:nth-child(2){top:10px}
.nav-toggle span:nth-child(3){top:20px}
.nav-toggle.open span:nth-child(1){top:10px;transform:rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){top:10px;transform:rotate(-45deg)}

/* ================================================
   HERO — Light with warm gradient + wave divider
   ================================================ */
.hero{
    min-height:100vh;display:flex;align-items:center;
    position:relative;overflow:hidden;
    background:linear-gradient(170deg,
        #FFF5F5 0%,
        #FDF8F4 25%,
        #FDFAF6 55%,
        #F4EDE4 100%
    );
}
.hero-bg-layer{display:none}
.hero-overlay{display:none}
/* Decorative blobs */
.hero::before{
    content:'';position:absolute;
    top:-120px;right:-80px;
    width:500px;height:500px;
    background:radial-gradient(circle, rgba(184,41,61,0.06) 0%, transparent 70%);
    border-radius:50%;
    pointer-events:none;
}
.hero::after{
    content:'';position:absolute;
    bottom:-80px;left:-120px;
    width:400px;height:400px;
    background:radial-gradient(circle, rgba(196,162,101,0.08) 0%, transparent 70%);
    border-radius:50%;
    pointer-events:none;
}
/* Wave divider at bottom — dramatic asymmetric */
.hero-wave{
    position:absolute;bottom:-2px;left:0;right:0;z-index:3;
    line-height:0;
}
.hero-wave svg{
    width:100%;height:140px;
    display:block;
}
.hero-content{
    position:relative;z-index:2;width:100%;
    max-width:1100px;margin:0 auto;padding:100px 28px 140px;
    display:flex;align-items:center;gap:40px;
}
.hero-text{flex:1;color:var(--text)}
.hero-tagline{
    font-size:clamp(1.15rem,2.5vw,1.5rem);
    font-weight:600;color:var(--forest);
    margin-bottom:18px;letter-spacing:.02em;
    line-height:1.6;
}
.hero h1{
    font-size:clamp(2.6rem,6vw,4.2rem);
    font-weight:800;
    line-height:1.15;
    margin-bottom:26px;
    letter-spacing:-.02em;
    color:var(--forest-dark);
}
.hero-desc{
    font-size:1.25rem;font-weight:400;
    color:var(--text-mid);
    margin-bottom:44px;line-height:1.9;
    max-width:500px;
}
.btn-hero{font-size:1.12rem;padding:22px 56px}

/* ===== Hero Visual — Petal Vortex ===== */
.hero-visual{
    flex-shrink:0;
    position:relative;
    width:520px;
    display:flex;
    align-self:stretch;
    align-items:flex-end;
    overflow:visible;
}

/* Vortex wrapper — all petals orbit around this center */
.petal-vortex{
    position:relative;
    width:100%;
    height:auto;
    display:flex;
    align-items:flex-end;
    justify-content:center;
}

/* Portrait image */
.vortex-portrait{
    position:relative;
    z-index:2;
    width:100%;
    animation:roseFloat 8s ease-in-out infinite;
    /* Gentle bottom fade */
    -webkit-mask-image: linear-gradient(to bottom, black 70%, transparent 100%);
    mask-image: linear-gradient(to bottom, black 70%, transparent 100%);
}
.vortex-portrait img{
    width:100%;height:auto;
    display:block;
    object-fit:contain;
}

/* Petal layers */
.petals-behind{
    position:absolute;inset:0;
    z-index:1;
    pointer-events:none;
}
.petals-front{
    position:absolute;inset:0;
    z-index:3;
    pointer-events:none;
}

/* Individual petal — organic shape */
.vortex-petal{
    position:absolute;
    transform-origin:center center;
    will-change:transform,opacity;
    pointer-events:none;
}

/* Keep hero-rose-frame as fallback (unused) */
.hero-rose-frame{ display:none }

@keyframes roseFloat{
    0%,100%{transform:translateY(0)}
    50%{transform:translateY(-12px)}
}


/* Floating particles in hero */
.hero-particles{
    position:absolute;inset:0;z-index:1;
    pointer-events:none;overflow:hidden;
}
.particle{
    position:absolute;
    width:4px;height:4px;
    border-radius:50%;
    background:var(--gold);
    opacity:0;
    animation:particleFloat linear infinite;
}
.p1{right:18%;top:20%;width:3px;height:3px;animation-duration:12s;animation-delay:0s}
.p2{right:35%;top:60%;width:5px;height:5px;animation-duration:16s;animation-delay:2s;background:var(--crimson-soft)}
.p3{right:55%;top:30%;width:2px;height:2px;animation-duration:13s;animation-delay:4s}
.p4{right:70%;top:70%;width:4px;height:4px;animation-duration:18s;animation-delay:1s;background:rgba(255,255,255,0.4)}
.p5{right:25%;top:80%;width:3px;height:3px;animation-duration:14s;animation-delay:6s}
.p6{right:50%;top:15%;width:6px;height:6px;animation-duration:20s;animation-delay:3s;background:var(--crimson-soft)}
@keyframes particleFloat{
    0%{opacity:0;transform:translateY(0) scale(0)}
    15%{opacity:.7;transform:translateY(-30px) scale(1)}
    85%{opacity:.3;transform:translateY(-200px) scale(.6)}
    100%{opacity:0;transform:translateY(-280px) scale(0)}
}

.scroll-indicator{
    position:absolute;bottom:50px;left:50%;transform:translateX(-50%);z-index:4;
    width:24px;height:40px;border:2px solid rgba(74,103,65,0.2);border-radius:12px;
}
.scroll-dot{
    width:3px;height:8px;background:var(--forest-light);
    border-radius:2px;margin:8px auto 0;
    animation:scrollBounce 1.8s ease-in-out infinite;opacity:.5;
}
@keyframes scrollBounce{0%,100%{transform:translateY(0);opacity:1}50%{transform:translateY(14px);opacity:.3}}

/* ===== AUDIENCE ===== */
.audience-list{display:flex;flex-direction:column;gap:16px}
.audience-item{
    display:flex;align-items:flex-start;gap:16px;
    padding:24px 28px;
    background:var(--white);border-radius:var(--radius);
    box-shadow:var(--shadow-sm);
    border-right:3px solid var(--forest-light);
    transition:all .35s var(--ease);
    font-size:1.15rem;color:var(--text-mid);line-height:1.8;
}
.audience-item:hover{transform:translateX(-5px);border-right-color:var(--forest);box-shadow:var(--shadow)}
.audience-item .a-icon{flex-shrink:0;width:28px;height:28px;color:var(--forest);margin-top:3px}

/* ===== WORKSHOP ===== */
.workshop-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.workshop-card{
    text-align:center;padding:44px 24px 38px;
    background:rgba(255,255,255,0.06);
    border:1px solid rgba(255,255,255,0.08);
    border-radius:var(--radius-lg);
    transition:all .4s var(--ease);
}
.workshop-card:hover{transform:translateY(-6px);border-color:rgba(255,255,255,0.18);background:rgba(255,255,255,0.1)}
.workshop-card .w-icon{width:48px;height:48px;margin:0 auto 18px;color:var(--gold);display:block}
.workshop-card h3{font-size:1.2rem;font-weight:700;color:var(--white);margin-bottom:10px}
.workshop-card .card-strong{font-size:.97rem;font-weight:700;color:var(--gold-soft);line-height:1.6;margin-bottom:10px}
.workshop-card p{font-size:1.05rem;color:rgba(255,255,255,0.5);font-weight:300;line-height:1.8}

/* ===== PROGRAM ===== */
.program-intro{
    text-align:center;font-size:1.18rem;color:var(--text-mid);
    margin:-32px auto 56px;max-width:540px;font-weight:400;line-height:1.85;
}
.program-block{
    background:var(--white);border-radius:var(--radius-lg);
    box-shadow:var(--shadow);padding:44px 48px;margin-bottom:36px;
    position:relative;overflow:hidden;
}
.program-block::before{
    content:'';position:absolute;top:0;right:0;width:4px;height:100%;
    background:linear-gradient(180deg,var(--gold),var(--crimson-soft));border-radius:2px;
}
.program-block-header{
    display:flex;align-items:center;gap:22px;margin-bottom:30px;
}
.program-phase-num{
    flex-shrink:0;width:56px;height:56px;
    display:flex;align-items:center;justify-content:center;
    font-size:1.25rem;font-weight:800;color:var(--gold);
    border:2px solid var(--gold);border-radius:50%;
    background:var(--gold-pale);
}
.program-block-header h3{
    font-size:1.5rem;font-weight:700;color:var(--forest-dark);margin-bottom:2px;
}
.program-block-sub{font-size:1.05rem;color:var(--text-mid);font-weight:400}

/* Part One Steps */
.program-steps{display:flex;flex-direction:column;gap:16px}
.program-step{
    display:flex;align-items:flex-start;gap:18px;
    padding:16px 20px;border-radius:var(--radius-sm);
    transition:all .3s var(--ease);
}
.program-step:hover{background:var(--forest-pale)}
.program-step .step-icon{
    flex-shrink:0;width:38px;height:38px;color:var(--forest);
    margin-top:2px;opacity:.7;
}
.program-step p{font-size:1.15rem;color:var(--text-mid);line-height:1.8}

/* Part Two Elements */
.elements-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.element-card{
    text-align:center;padding:30px 18px 26px;
    border-radius:var(--radius);
    position:relative;overflow:hidden;
    transition:all .4s var(--ease);
    cursor:default;
}
.element-card::before{
    content:'';position:absolute;inset:0;opacity:.08;border-radius:inherit;
    transition:opacity .4s ease;
}
.element-card:hover{transform:translateY(-5px)}
.element-card:hover::before{opacity:.14}
.element-card.el-earth{background:linear-gradient(160deg,#eef2ea,#dce8d9);border:1px solid rgba(74,103,65,0.12)}
.element-card.el-earth::before{background:var(--forest)}
.element-card.el-wind{background:linear-gradient(160deg,#fdf7eb,#f0e6cd);border:1px solid rgba(200,165,100,0.15)}
.element-card.el-wind::before{background:var(--gold)}
.element-card.el-water{background:linear-gradient(160deg,#e8eff2,#d0e3eb);border:1px solid rgba(80,130,180,0.12)}
.element-card.el-water::before{background:#4A8CB8}
.element-card.el-fire{background:linear-gradient(160deg,#fcece6,#efd6ca);border:1px solid rgba(184,41,61,0.12)}
.element-card.el-fire::before{background:var(--crimson)}
.element-card .el-icon{width:42px;height:42px;margin:0 auto 14px;display:block}
.element-card.el-earth .el-icon{color:var(--forest)}
.element-card.el-wind .el-icon{color:var(--gold-dark, #C8A564)}
.element-card.el-water .el-icon{color:#4A8CB8}
.element-card.el-fire .el-icon{color:var(--crimson)}
.element-card h4{font-size:1.2rem;font-weight:700;color:var(--text);margin-bottom:5px}
.element-card .el-quality{font-size:1rem;color:var(--text-light);font-weight:500;margin-bottom:10px}
.element-card .el-desc{font-size:1.05rem;color:var(--text-mid);line-height:1.75;font-weight:300}

.elements-closing{
    text-align:center;margin-top:32px;
    font-size:1.12rem;color:var(--forest);font-weight:600;
    font-style:italic;line-height:1.85;
}

/* ===== ABOUT ===== */
.about-layout{display:flex;align-items:flex-start;gap:60px}
.about-images{flex-shrink:0;position:relative;width:380px;height:460px}
.about-img-main{
    width:310px;height:410px;border-radius:var(--radius-lg);overflow:hidden;
    box-shadow:var(--shadow-lg);position:relative;z-index:2;
}
.about-img-main img{width:100%;height:100%;object-fit:cover}
.about-img-accent{
    width:210px;height:260px;border-radius:var(--radius);overflow:hidden;
    box-shadow:var(--shadow-lg);
    position:absolute;bottom:-24px;left:-24px;z-index:3;
    border:5px solid var(--cream);
}
.about-img-accent img{width:100%;height:100%;object-fit:cover}
.about-content{flex:1}
.about-subtitle{
    font-size:1.3rem;font-weight:600;color:var(--crimson);
    margin-bottom:20px;line-height:1.6;
}
.about-bio{font-size:1.2rem;color:var(--text-mid);line-height:1.9;margin-bottom:22px}

/* About Details Grid */
.about-details-grid{
    display:grid;grid-template-columns:repeat(3,1fr);
    gap:28px;margin-top:60px;
}
.about-detail-card{
    background:var(--warm);
    border-radius:var(--radius);
    padding:36px 30px;
    transition:all .35s var(--ease);
    border:1px solid rgba(0,0,0,0.04);
}
.about-detail-card:hover{
    transform:translateY(-4px);
    box-shadow:var(--shadow);
}
.about-detail-icon{
    width:50px;height:50px;
    background:linear-gradient(135deg,var(--crimson-pale),var(--gold-pale));
    border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    margin-bottom:20px;
}
.about-detail-icon .w-icon{
    width:24px;height:24px;color:var(--crimson);
}
.about-detail-card h3{
    font-size:1.18rem;font-weight:700;color:var(--forest-dark);
    margin-bottom:12px;line-height:1.5;
}
.about-detail-card p{
    font-size:1.1rem;color:var(--text-mid);line-height:1.85;
    margin-bottom:16px;
}
.about-list{
    list-style:none;padding:0;margin:0;
}
.about-list li{
    font-size:1.1rem;color:var(--text-mid);line-height:1.85;
    padding:6px 20px 6px 0;position:relative;
}
.about-list li::before{
    content:'✦';position:absolute;right:0;
    color:var(--crimson-soft);font-size:.7rem;top:10px;
}
.about-extra{
    font-size:1.05rem;color:var(--text-light);
    margin-top:12px;font-style:italic;
}

/* About CTA */
.about-cta{
    text-align:center;margin-top:56px;
    padding:40px;
    background:linear-gradient(135deg,var(--crimson-pale),var(--gold-pale));
    border-radius:var(--radius-lg);
}
.about-cta p{
    font-size:1.2rem;font-weight:500;color:var(--forest-dark);
    margin-bottom:24px;line-height:1.7;
}

/* ===== FAQ ===== */
.faq-list{display:flex;flex-direction:column;gap:0}
.faq-item{border-bottom:1px solid rgba(0,0,0,0.06);overflow:hidden}
.faq-q{
    display:flex;align-items:center;justify-content:space-between;
    padding:24px 4px;cursor:pointer;
    font-size:1.12rem;font-weight:600;color:var(--text);
    transition:color .3s ease;
    background:none;border:none;width:100%;text-align:right;
    font-family:var(--font);direction:rtl;
}
.faq-q:hover{color:var(--crimson)}
.faq-arrow{width:18px;height:18px;flex-shrink:0;transition:transform .3s ease;color:var(--text-light)}
.faq-item.open .faq-arrow{transform:rotate(180deg);color:var(--crimson)}
.faq-a{
    max-height:0;overflow:hidden;
    transition:max-height .4s ease,padding .4s ease;
    font-size:1.12rem;color:var(--text-mid);line-height:1.85;padding:0 4px;
}
.faq-item.open .faq-a{max-height:200px;padding:0 4px 24px}

/* ===== DETAILS ===== */
.details-cards{
    display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));
    gap:18px;max-width:920px;margin:0 auto 36px;
}
.detail-card{
    text-align:center;padding:36px 18px;
    background:rgba(255,255,255,0.06);
    border:1px solid rgba(255,255,255,0.08);
    border-radius:var(--radius-lg);
    transition:all .35s var(--ease);
}
.detail-card:hover{background:rgba(255,255,255,0.1);border-color:rgba(255,255,255,0.15)}
.detail-card .d-icon{width:34px;height:34px;margin:0 auto 14px;color:var(--gold)}
.detail-card h3{font-size:.95rem;font-weight:600;color:rgba(255,255,255,0.45);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}
.detail-card p{font-size:1.15rem;color:var(--white);font-weight:600}
.details-notes{
    text-align:center;max-width:620px;margin:0 auto 40px;
    font-size:1.05rem;color:rgba(255,255,255,0.4);line-height:1.85;
}
.details-cta{text-align:center}

/* ===== GALLERY ===== */
.gallery-track{
    display:flex;gap:18px;overflow-x:auto;
    padding-bottom:18px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;
}
.gallery-track::-webkit-scrollbar{height:5px}
.gallery-track::-webkit-scrollbar-track{background:rgba(0,0,0,0.04);border-radius:3px}
.gallery-track::-webkit-scrollbar-thumb{background:var(--gold);border-radius:3px}
.gallery-item{
    flex-shrink:0;width:310px;height:400px;border-radius:var(--radius-lg);overflow:hidden;
    scroll-snap-align:start;box-shadow:var(--shadow);transition:transform .4s var(--ease);
}
.gallery-item:hover{transform:scale(1.03)}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.gallery-item:hover img{transform:scale(1.08)}

/* ===== TESTIMONIALS ===== */
.testimonials-grid{
    display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
    gap:24px;max-width:900px;margin:0 auto;
}
.testimonial-card{
    border-radius:var(--radius-lg);overflow:hidden;
    box-shadow:var(--shadow-lg);background:var(--white);
    transition:transform .4s var(--ease);
}
.testimonial-card:hover{transform:translateY(-6px)}
.testimonial-card video{width:100%;aspect-ratio:9/16;object-fit:cover;background:var(--dark-warm)}
.testimonial-card .t-name{padding:18px 22px;text-align:center;font-weight:600;color:var(--text);font-size:.98rem}

/* ===== CONTACT ===== */
.contact-form{
    background:rgba(255,255,255,0.06);
    border:1px solid rgba(255,255,255,0.1);
    border-radius:var(--radius-lg);
    padding:48px 44px;
    backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
}
.form-row{display:flex;gap:18px}
.form-group{flex:1;margin-bottom:20px}
.form-group input{
    width:100%;padding:20px 24px;
    border:1px solid rgba(255,255,255,0.12);
    border-radius:var(--radius-sm);
    font-family:var(--font);font-size:1.02rem;
    background:rgba(255,255,255,0.05);color:var(--white);
    transition:all .3s ease;outline:none;direction:rtl;
}
.form-group input::placeholder{color:rgba(255,255,255,0.3)}
.form-group input:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(196,162,101,0.12)}
.btn-submit{width:100%;padding:22px;font-size:1.12rem}

/* ===== FOOTER ===== */
.footer{background:var(--forest-deep);padding:72px 28px;text-align:center;border-top:1px solid rgba(255,255,255,0.04)}
.footer-brand{
    margin-bottom:32px;
    display:flex;flex-direction:column;align-items:center;gap:6px;
}
.footer-brand-name{
    font-size:2.2rem;font-weight:700;
    color:var(--gold);
    letter-spacing:2px;
}
.footer-brand-sub{
    font-size:.92rem;font-weight:300;
    color:rgba(255,255,255,0.3);
    letter-spacing:3px;
}
.footer-quote{
    font-size:clamp(1rem,2vw,1.18rem);
    color:var(--gold-soft);
    max-width:600px;margin:0 auto 28px;line-height:1.95;font-style:italic;font-weight:300;
}
.footer-line{width:44px;height:2px;background:var(--crimson-dark);margin:0 auto 18px;border-radius:1px}
.footer-copy{font-size:.82rem;color:rgba(255,255,255,0.2)}

/* ===== FAB ===== */
.fab-whatsapp{
    position:fixed;bottom:24px;left:24px;
    width:62px;height:62px;border-radius:50%;
    background:linear-gradient(135deg,#25D366,#128C7E);
    display:flex;align-items:center;justify-content:center;
    box-shadow:0 6px 24px rgba(37,211,102,0.35);
    z-index:9999;transition:all .3s ease;
    animation:waPulse 2.5s ease-in-out infinite;
}
.fab-whatsapp:hover{transform:scale(1.12);box-shadow:0 8px 32px rgba(37,211,102,0.5)}
@keyframes waPulse{
    0%,100%{box-shadow:0 6px 24px rgba(37,211,102,0.35)}
    50%{box-shadow:0 6px 24px rgba(37,211,102,0.6),0 0 0 10px rgba(37,211,102,0.04)}
}

/* ===== RESPONSIVE ===== */
@media(max-width:968px){
    .nav-toggle{display:block}
    .nav-links{
        position:fixed;top:84px;left:0;right:0;
        background:rgba(253,250,246,0.97);
        backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
        flex-direction:column;align-items:stretch;
        padding:16px 24px;gap:8px;
        transform:translateY(-100%);transition:transform .4s ease, opacity .4s ease;
        box-shadow:var(--shadow);
        opacity: 0;
        pointer-events: none;
    }
    .nav-links.open{
        transform:translateY(0);
        opacity: 1;
        pointer-events: auto;
    }
    .nav-links a{display:block;padding:14px 16px;font-size:1.1rem;border-radius:var(--radius-sm);text-align:right}
    .nav-links a.nav-cta{text-align:center;margin-top:8px;border-radius:60px}
    .hero-content{flex-direction:column-reverse;text-align:center;padding-top:100px;gap:20px}
    .hero-text{align-items:center;display:flex;flex-direction:column}
    .hero-desc{margin-left:auto;margin-right:auto}
    .hero-visual{width:300px}
    .hero-rose-frame{width:300px}
    .nav-logo img{height:80px}
    .workshop-grid{grid-template-columns:repeat(2,1fr)}
    .elements-grid{grid-template-columns:repeat(2,1fr)}
    .program-block{padding:30px 26px}
    .about-layout{flex-direction:column;text-align:center}
    .about-images{width:100%;height:auto;display:flex;justify-content:center;gap:4%}
    .about-img-main{width:55%;height:auto;aspect-ratio:3/4;position:static}
    .about-img-accent{width:40%;height:auto;aspect-ratio:3/4;position:static;border:none}
    .about-content .section-title{text-align:center}
    .about-content .section-title::after{margin:18px auto 0}
    .about-details-grid{grid-template-columns:1fr}
    .about-detail-card{text-align:right}
    .testimonials-grid{grid-template-columns:1fr}
}
@media(max-width:600px){
    .section{padding:88px 0}
    .workshop-grid{grid-template-columns:1fr}
    .elements-grid{grid-template-columns:1fr;gap:20px}
    .program-block{padding:24px 20px}
    .program-block-header{gap:14px}
    .program-phase-num{width:44px;height:44px;font-size:1.05rem}
    .form-row{flex-direction:column;gap:0}
    .hero h1{font-size:2.2rem}
    .hero-visual{width:250px}
    .hero-rose-frame{width:250px}
    .gallery-item{width:270px;height:340px}
    .contact-form{padding:30px 22px}
    .fab-whatsapp{bottom:18px;left:18px;width:56px;height:56px}
    .details-cards{grid-template-columns:1fr; max-width:300px; gap:16px;}
    .detail-card{padding: 24px 16px;}
}
