/* ==============================================
   HATIRA DEFTERIMIZ — PROFESSIONAL UI
   Inspired by: Linear, Stripe, Vercel
   ============================================== */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:80px}
body{font-family:'Inter',system-ui,sans-serif;color:#0a0a0b;background:#fafaf9;line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.container{max-width:1120px;margin:0 auto;padding:0 24px}
.container-sm{max-width:720px}
.sec{padding:120px 0}
.sec-alt{background:#f5f3f0;box-shadow:inset 0 1px 0 rgba(0,0,0,0.03),inset 0 -1px 0 rgba(0,0,0,0.03)}
.hidden{display:none!important}

:root{
    --accent:#c45e3e;
    --accent-light:#e8a68e;
    --accent-bg:rgba(196,94,62,0.06);
    --accent-border:rgba(196,94,62,0.12);
    --bg:#fafaf9;
    --bg-alt:#f5f3f0;
    --bg-dark:#0c0a09;
    --surface:#fff;
    --border:#e7e5e2;
    --border-light:#f0eeeb;
    --text:#0a0a0b;
    --text-2:#46443e;
    --text-3:#8a8780;
    --radius:12px;
}

/* --- SCROLL PROGRESS --- */
.scroll-progress{
    position:fixed;top:0;left:0;height:2px;
    background:linear-gradient(90deg,var(--accent),var(--accent-light));
    z-index:101;width:0;
    transition:width .15s linear;
    pointer-events:none;
}

/* --- TYPOGRAPHY --- */
h1,h2,h3,h4{font-family:'Playfair Display',serif;font-weight:600;letter-spacing:-0.02em}
h2{font-size:clamp(1.75rem,3.5vw,2.5rem);color:var(--text);line-height:1.15}
.sec-head{text-align:center;margin-bottom:64px}
.sec-label{font-family:'Inter',sans-serif;font-size:0.78rem;font-weight:600;text-transform:uppercase;letter-spacing:0.1em;color:var(--accent);margin-bottom:12px}
.sec-desc{font-size:0.95rem;color:var(--text-3);max-width:480px;margin:12px auto 0;line-height:1.7}

/* --- BUTTONS --- */
.btn-main{
    display:inline-flex;align-items:center;gap:8px;
    padding:12px 24px;border-radius:8px;
    font-size:0.88rem;font-weight:600;font-family:'Inter',sans-serif;
    background:var(--accent);color:#fff;border:none;cursor:pointer;
    transition:all .2s ease;
    box-shadow:0 1px 2px rgba(0,0,0,0.06),0 1px 3px rgba(0,0,0,0.1);
    position:relative;overflow:hidden;
}
.btn-main::before{
    content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;
    background:linear-gradient(90deg,transparent,rgba(255,255,255,0.15),transparent);
    transition:left .6s ease;
}
.btn-main:hover::before{left:100%}
.btn-main:hover{background:#b3533a;transform:translateY(-1px);box-shadow:0 4px 12px rgba(196,94,62,0.25)}
.btn-sec{
    display:inline-flex;align-items:center;gap:8px;
    padding:12px 24px;border-radius:8px;
    font-size:0.88rem;font-weight:600;font-family:'Inter',sans-serif;
    background:transparent;color:var(--text);border:1px solid var(--border);cursor:pointer;
    transition:all .2s ease;
}
.btn-sec:hover{border-color:var(--text-3);background:rgba(0,0,0,0.02);transform:translateY(-1px)}
.btn-full{width:100%;justify-content:center}
.btn-lg{padding:14px 32px;font-size:0.92rem}

/* ==============================================
   PRELOADER
   ============================================== */
#preloader{
    position:fixed;inset:0;z-index:9999;
    background:var(--bg-dark);
    display:flex;align-items:center;justify-content:center;
    transition:opacity .4s ease,visibility .4s ease;
}
#preloader.done{opacity:0;visibility:hidden;pointer-events:none}
.pl-inner{width:160px}
.pl-bar{width:100%;height:1px;background:rgba(255,255,255,0.08);border-radius:1px;overflow:hidden}
.pl-fill{width:30%;height:100%;background:var(--accent-light);border-radius:1px;animation:plSlide 1s ease infinite}
@keyframes plSlide{0%{transform:translateX(-100%)}100%{transform:translateX(500%)}}

/* ==============================================
   CURSOR GLOW
   ============================================== */
.cursor-glow{
    position:fixed;width:600px;height:600px;
    border-radius:50%;pointer-events:none;z-index:0;
    background:radial-gradient(circle,rgba(196,94,62,0.04) 0%,transparent 70%);
    transform:translate(-50%,-50%);
    transition:left .5s ease,top .5s ease;
    display:none;
}
@media(hover:hover){.cursor-glow{display:block}}

/* ==============================================
   NAVBAR
   ============================================== */
#navbar{
    position:fixed;top:0;left:0;right:0;z-index:100;
    padding:0;
    transition:all .3s ease;
}
#navbar.scrolled{
    background:rgba(250,250,249,0.85);
    backdrop-filter:blur(16px) saturate(180%);
    border-bottom:1px solid var(--border-light);
}
.nav-wrap{
    max-width:1120px;margin:0 auto;padding:16px 24px;
    display:flex;align-items:center;justify-content:space-between;
}
.nav-logo{
    display:flex;align-items:center;gap:10px;
    font-family:'Inter',sans-serif;font-size:0.95rem;font-weight:700;
    color:#fff;transition:color .3s;letter-spacing:-0.01em;
}
#navbar.scrolled .nav-logo{color:var(--text)}
.nav-logo-mark{
    width:28px;height:28px;border-radius:7px;
    background:var(--accent);color:var(--accent);
    display:flex;align-items:center;justify-content:center;
    flex-shrink:0;
}
.nav-logo-mark svg{width:100%;height:100%}
.nav-center{display:flex;gap:32px}
.nav-center a{
    font-size:0.85rem;font-weight:500;
    color:rgba(255,255,255,0.6);transition:color .2s;
}
.nav-center a:hover{color:#fff}
#navbar.scrolled .nav-center a{color:var(--text-3)}
#navbar.scrolled .nav-center a:hover{color:var(--text)}
.nav-right .nav-cta{
    padding:8px 18px;border-radius:7px;font-size:0.84rem;font-weight:600;
    background:rgba(255,255,255,0.1);color:rgba(255,255,255,0.9);
    border:1px solid rgba(255,255,255,0.12);transition:all .2s;
}
.nav-cta:hover{background:rgba(255,255,255,0.18)}
#navbar.scrolled .nav-cta{background:var(--accent);color:#fff;border-color:var(--accent)}
#navbar.scrolled .nav-cta:hover{background:#b3533a}
.nav-mobile-btn{
    display:none;background:none;border:none;cursor:pointer;
    padding:6px;position:relative;width:24px;height:18px;
}
.nav-mobile-btn span{
    display:block;width:20px;height:1.5px;background:#fff;
    border-radius:2px;position:absolute;left:2px;transition:all .3s;
}
.nav-mobile-btn span:first-child{top:4px}
.nav-mobile-btn span:last-child{bottom:4px}
.nav-mobile-btn.open span:first-child{transform:rotate(45deg);top:8px}
.nav-mobile-btn.open span:last-child{transform:rotate(-45deg);bottom:8px}
#navbar.scrolled .nav-mobile-btn span{background:var(--text)}

/* Mobile menu */
.mobile-menu{
    position:fixed;inset:0;z-index:99;
    background:rgba(12,10,9,0.97);backdrop-filter:blur(20px);
    display:flex;align-items:center;justify-content:center;
    opacity:0;visibility:hidden;transition:all .3s;
}
.mobile-menu.open{opacity:1;visibility:visible}
.mobile-menu-inner{display:flex;flex-direction:column;align-items:center;gap:20px}
.mobile-menu-inner a{font-size:1.3rem;font-weight:500;color:rgba(255,255,255,0.7);transition:color .2s}
.mobile-menu-inner a:hover{color:#fff}
.mobile-cta{color:var(--accent-light)!important}

/* ==============================================
   HERO
   ============================================== */
#hero{
    min-height:100vh;display:flex;align-items:center;
    background:var(--bg-dark);position:relative;overflow:hidden;
    padding:140px 0 100px;
}
.hero-bg-grid{
    position:absolute;inset:0;
    background-image:
        linear-gradient(rgba(255,255,255,0.025) 1px,transparent 1px),
        linear-gradient(90deg,rgba(255,255,255,0.025) 1px,transparent 1px);
    background-size:64px 64px;
    mask-image:radial-gradient(ellipse 70% 60% at 50% 40%,black,transparent);
}
.hero-glow{position:absolute;border-radius:50%;filter:blur(120px);pointer-events:none}
.hero-glow-1{width:600px;height:600px;background:rgba(196,94,62,0.08);top:-200px;right:-100px}
.hero-glow-2{width:400px;height:400px;background:rgba(196,94,62,0.05);bottom:-150px;left:10%}

.hero-layout{
    display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;
    position:relative;z-index:1;
}
.hero-text{max-width:500px}
.hero-pill{
    display:inline-flex;align-items:center;gap:8px;
    padding:6px 16px 6px 10px;border-radius:100px;
    background:rgba(196,94,62,0.08);border:1px solid rgba(196,94,62,0.12);
    color:var(--accent-light);font-size:0.78rem;font-weight:600;
    margin-bottom:28px;letter-spacing:0.02em;
    animation:fadeUp .8s ease both;
}
.pill-dot{width:6px;height:6px;border-radius:50%;background:#4ade80;box-shadow:0 0 6px rgba(74,222,128,0.5);animation:blink 2s ease infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.4}}

#hero h1{
    font-size:clamp(2.4rem,5vw,3.8rem);
    color:#fff;margin-bottom:20px;line-height:1.1;
    letter-spacing:-0.03em;
    animation:fadeUp .8s ease .1s both;
}
#hero h1 em{
    font-style:italic;
    background:linear-gradient(135deg,var(--accent),var(--accent-light));
    -webkit-background-clip:text;-webkit-text-fill-color:transparent;
    background-clip:text;
}
.hero-sub{
    font-size:1.05rem;color:rgba(255,255,255,0.6);
    line-height:1.8;margin-bottom:36px;
    animation:fadeUp .8s ease .2s both;
}
.hero-btns{display:flex;gap:12px;animation:fadeUp .8s ease .3s both}
.hero-btns .btn-sec{color:rgba(255,255,255,0.7);border-color:rgba(255,255,255,0.12)}
.hero-btns .btn-sec:hover{border-color:rgba(255,255,255,0.3);background:rgba(255,255,255,0.04);color:#fff}

/* Hero Visual */
.hero-visual{display:flex;justify-content:center;animation:fadeUp .8s ease .4s both}
.hv-container{position:relative;width:380px;height:420px}
.hv-card{
    position:absolute;padding:18px;border-radius:14px;
    backdrop-filter:blur(24px);
    box-shadow:0 8px 32px rgba(0,0,0,0.4),inset 0 1px 0 rgba(255,255,255,0.06);
    border:1px solid rgba(255,255,255,0.08);
}
.hv-card-1{
    width:240px;top:0;left:0;z-index:3;
    background:rgba(255,255,255,0.07);
    animation:cardF1 7s ease-in-out infinite;
}
.hv-card-2{
    width:210px;top:140px;right:0;z-index:2;
    background:rgba(255,240,245,0.08);
    animation:cardF2 8s ease-in-out infinite;
}
.hv-card-3{
    width:200px;bottom:0;left:30px;z-index:1;
    background:rgba(245,240,232,0.07);
    animation:cardF3 9s ease-in-out infinite;
}
@keyframes cardF1{0%,100%{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-10px) rotate(0)}}
@keyframes cardF2{0%,100%{transform:translateY(0) rotate(2deg)}50%{transform:translateY(-14px) rotate(1deg)}}
@keyframes cardF3{0%,100%{transform:translateY(0) rotate(-0.5deg)}50%{transform:translateY(-8px) rotate(0.5deg)}}

.hv-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.hv-card-dot{width:6px;height:6px;border-radius:50%;background:var(--accent)}
.baby-dot{background:#f0b429}
.family-dot{background:#4ade80}
.hv-card-status{
    font-family:'Inter',sans-serif;font-size:0.58rem;font-weight:600;
    padding:2px 8px;border-radius:100px;text-transform:uppercase;letter-spacing:0.04em;
    background:rgba(196,94,62,0.15);color:var(--accent-light);
}
.status-baby{background:rgba(240,180,41,0.15);color:#f0b429}
.status-family{background:rgba(74,222,128,0.12);color:#4ade80}
.hv-card-label{font-family:'Inter',sans-serif;font-size:0.82rem;font-weight:600;color:rgba(255,255,255,0.9)}
.hv-card-meta{font-size:0.7rem;color:rgba(255,255,255,0.4);margin:2px 0 12px}
.hv-card-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px}
.hv-thumb{
    height:40px;border-radius:6px;
    background:rgba(196,94,62,0.12);
    border:1px solid rgba(196,94,62,0.08);
    display:flex;align-items:center;justify-content:center;
    color:rgba(255,255,255,0.3);
}
.hv-thumb.t-baby{background:rgba(240,180,41,0.1);border-color:rgba(240,180,41,0.08);color:rgba(240,180,41,0.4)}
.hv-thumb.t-fam{background:rgba(74,222,128,0.08);border-color:rgba(74,222,128,0.06);color:rgba(74,222,128,0.35)}
.hv-card-bar{height:3px;background:rgba(255,255,255,0.06);border-radius:2px;margin-top:12px;overflow:hidden}
.hv-card-bar-fill{height:100%;border-radius:2px;background:var(--accent);opacity:.6}
.bar-baby{background:#f0b429}
.bar-fam{background:#4ade80}

.hv-float{
    position:absolute;display:flex;align-items:center;gap:6px;
    padding:8px 12px;border-radius:8px;font-size:0.7rem;font-weight:600;
    backdrop-filter:blur(20px);z-index:5;
    box-shadow:0 4px 16px rgba(0,0,0,0.2);
}
.hv-float-1{bottom:90px;right:-20px;background:rgba(196,94,62,0.15);border:1px solid rgba(196,94,62,0.2);color:var(--accent-light);animation:floatB 6s ease-in-out infinite}
.hv-float-2{top:10px;right:20px;background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.12);color:rgba(255,255,255,0.6);animation:floatB 7s ease-in-out 1s infinite}
@keyframes floatB{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}

/* Animations */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}

/* ==============================================
   HOW IT WORKS
   ============================================== */
.steps{display:flex;align-items:flex-start;justify-content:center}
.step{flex:1;max-width:300px;padding:0 28px}
.step-num{
    font-family:'Inter',sans-serif;font-size:0.72rem;font-weight:700;
    color:var(--accent);margin-bottom:16px;
    letter-spacing:0.05em;
}
.step h3{font-size:1.1rem;margin-bottom:8px}
.step p{font-size:0.88rem;color:var(--text-3);line-height:1.65}
.step-sep{width:1px;height:80px;background:var(--border);margin-top:10px;flex-shrink:0}

/* ==============================================
   TEMPLATES
   ============================================== */
.tabs{display:flex;justify-content:center;gap:4px;margin-bottom:48px;background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:4px;width:fit-content;margin-left:auto;margin-right:auto}
.tab{
    padding:8px 24px;border-radius:7px;border:none;
    font-family:'Inter',sans-serif;font-size:0.84rem;font-weight:500;
    color:var(--text-3);background:transparent;cursor:pointer;transition:all .2s;
}
.tab:hover{color:var(--text)}
.tab.active{background:var(--surface);color:var(--text);box-shadow:0 1px 3px rgba(0,0,0,0.06)}

.tpl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.tpl-card{
    background:var(--surface);border:1px solid var(--border);
    border-radius:var(--radius);overflow:hidden;
    transition:all .3s ease;
}
.tpl-card:hover{
    transform:translateY(-4px);
    box-shadow:0 12px 40px rgba(0,0,0,0.08);
    border-color:var(--accent-border);
}
.tpl-preview{
    height:220px;padding:16px;position:relative;
    display:flex;flex-direction:column;
}
.tpl-dots{display:flex;gap:4px;margin-bottom:auto}
.tpl-dots span{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,0.25)}
.tpl-dots span:first-child{background:var(--accent);opacity:.6}
.tpl-demo{display:flex;flex-direction:column;align-items:center;gap:4px}
.tpl-name{font-family:'Playfair Display',serif;font-size:1rem;font-weight:600}
.tpl-sub{font-size:0.7rem}
.tpl-imgs{display:flex;gap:4px;margin-top:8px}
.tpl-imgs div{
    width:40px;height:40px;border-radius:6px;
    position:relative;overflow:hidden;
}
.tpl-imgs div::after{
    content:'';position:absolute;inset:0;
    background:linear-gradient(135deg,transparent 30%,rgba(255,255,255,0.08) 50%,transparent 70%);
}
.tpl-badge{
    position:absolute;top:12px;right:12px;
    padding:3px 10px;border-radius:100px;
    font-size:0.65rem;font-weight:700;font-family:'Inter',sans-serif;
    text-transform:uppercase;letter-spacing:0.05em;
    background:var(--accent);color:#fff;
}
.badge-warm{background:#c9a96e}

/* Template themes */
.tpl-romantic{background:linear-gradient(150deg,#1a0a14,#2d1020)}
.tpl-romantic .tpl-name{color:#f8a4c0}
.tpl-romantic .tpl-sub{color:rgba(248,164,192,0.5)}
.tpl-romantic .tpl-imgs div{background:rgba(231,84,128,0.18);border:1px solid rgba(231,84,128,0.15)}

.tpl-modern{background:linear-gradient(150deg,#f0e6ef,#e8dde6)}
.tpl-modern .tpl-dots span{background:rgba(0,0,0,0.12)}
.tpl-modern .tpl-dots span:first-child{background:#8b6f8e}
.tpl-name-modern{font-family:'Inter',sans-serif!important;color:#4a3550;font-weight:600!important}
.tpl-sub-modern{color:#8b6f8e}
.tpl-modern .tpl-imgs div{background:rgba(139,111,142,0.2);border:1px solid rgba(139,111,142,0.15)}

.tpl-elegant{background:linear-gradient(150deg,#080808,#1a1510)}
.tpl-elegant .tpl-dots span:first-child{background:#c9a96e}
.tpl-name-elegant{color:#e8d5b0;letter-spacing:1px}
.tpl-sub-elegant{color:rgba(201,169,110,0.5)}
.elegant-imgs div{background:rgba(201,169,110,0.15);border:1px solid rgba(201,169,110,0.12);border-radius:3px!important}

.tpl-baby1{background:linear-gradient(150deg,#fef0f5,#fde2ec)}
.tpl-baby1 .tpl-dots span{background:rgba(0,0,0,0.1)}
.tpl-baby1 .tpl-dots span:first-child{background:#e75480}
.tpl-name-baby1{color:#c43e6e}
.tpl-sub-baby1{color:#e75480}
.baby1-imgs div{background:rgba(231,84,128,0.15);border:1px solid rgba(231,84,128,0.1)}

.tpl-baby2{background:linear-gradient(150deg,#0c1445,#1a1a4e)}
.tpl-baby2 .tpl-dots span:first-child{background:#c9b8ff}
.tpl-name-baby2{color:#c9b8ff}
.tpl-sub-baby2{color:rgba(201,184,255,0.5)}
.baby2-imgs div{background:rgba(201,184,255,0.18);border:1px solid rgba(201,184,255,0.12)}

.tpl-baby3{background:linear-gradient(150deg,#fef9e7,#fdebd0)}
.tpl-baby3 .tpl-dots span{background:rgba(0,0,0,0.1)}
.tpl-baby3 .tpl-dots span:first-child{background:#e67e22}
.tpl-name-baby3{color:#c0612b}
.tpl-sub-baby3{color:#e67e22}
.baby3-imgs div{background:rgba(230,126,34,0.15);border:1px solid rgba(230,126,34,0.1)}

.tpl-family1{background:linear-gradient(150deg,#f5f0e8,#ede4d4)}
.tpl-family1 .tpl-dots span{background:rgba(0,0,0,0.1)}
.tpl-family1 .tpl-dots span:first-child{background:#c9a96e}
.tpl-name-fam1{color:#5a4a3a}
.tpl-sub-fam1{color:#c9a96e}
.fam1-imgs div{background:rgba(201,169,110,0.2);border:1px solid rgba(201,169,110,0.12)}

.tpl-family2{background:linear-gradient(150deg,#eef2f5,#dce3ea)}
.tpl-family2 .tpl-dots span{background:rgba(0,0,0,0.1)}
.tpl-family2 .tpl-dots span:first-child{background:#5a8aaa}
.tpl-name-fam2{color:#3a4a5a}
.tpl-sub-fam2{color:#6a8a9a}
.fam2-imgs div{background:rgba(100,150,180,0.18);border:1px solid rgba(100,150,180,0.1)}

.tpl-family3{background:linear-gradient(150deg,#1a1510,#2a2018)}
.tpl-family3 .tpl-dots span:first-child{background:#d4a574}
.tpl-name-fam3{color:#e8c9a0}
.tpl-sub-fam3{color:rgba(212,165,116,0.5)}
.fam3-imgs div{background:rgba(212,165,116,0.18);border:1px solid rgba(212,165,116,0.12)}

.tpl-info{padding:20px}
.tpl-info h3{font-size:1rem;margin-bottom:4px}
.tpl-info p{font-size:0.82rem;color:var(--text-3);margin-bottom:12px;line-height:1.5}
.tpl-tags{display:flex;flex-wrap:wrap;gap:4px}
.tpl-tags span{
    padding:3px 10px;border-radius:100px;
    font-size:0.68rem;font-weight:500;
    background:var(--accent-bg);color:var(--accent);
    border:1px solid var(--accent-border);
}

.tpl-footer{text-align:center;margin-top:48px;padding-top:40px;border-top:1px solid var(--border)}
.tpl-footer p{color:var(--text-3);margin-bottom:16px;font-size:0.92rem}

/* ==============================================
   LIVE EXAMPLES
   ============================================== */
.ex-bento{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.ex-card-lg{grid-column:1 / -1}
.ex-card{
    background:var(--surface);border:1px solid var(--border);
    border-radius:16px;overflow:hidden;
    transition:all .4s ease;
}
.ex-card:hover{transform:translateY(-6px);box-shadow:0 24px 64px rgba(0,0,0,0.1);border-color:var(--accent-border)}

/* Browser chrome */
.ex-browser{overflow:hidden}
.ex-bar{
    display:flex;align-items:center;gap:10px;
    padding:10px 16px;
    background:#1c1b1a;
}
.ex-bar-dots{display:flex;gap:5px}
.ex-bar-dots span{width:8px;height:8px;border-radius:50%}
.ex-bar-dots span:nth-child(1){background:#ff5f57}
.ex-bar-dots span:nth-child(2){background:#febc2e}
.ex-bar-dots span:nth-child(3){background:#28c840}
.ex-bar-url{
    flex:1;display:flex;align-items:center;gap:6px;
    padding:5px 14px;border-radius:6px;
    background:rgba(255,255,255,0.07);
    color:rgba(255,255,255,0.5);
    font-family:'Inter',sans-serif;font-size:0.7rem;font-weight:500;
}
.ex-bar-actions{display:flex;gap:6px;margin-left:auto}
.ex-bar-actions span{width:14px;height:2px;border-radius:1px;background:rgba(255,255,255,0.15)}

/* Screen shared */
.ex-screen{position:relative;overflow:hidden;padding:0;font-family:'Inter',sans-serif}

/* Mini navbar inside screens */
.ex-nav{
    display:flex;align-items:center;justify-content:space-between;
    padding:8px 16px;
}
.ex-nav-logo{display:flex;align-items:center;gap:5px;font-size:0.62rem;font-weight:700}
.ex-nav-logo svg{flex-shrink:0}
.ex-nav-links{display:flex;gap:10px}
.ex-nav-links span{font-size:0.55rem;font-weight:500;opacity:.5}

/* Screen-specific nav colors */
.ex-sc-couple .ex-nav{background:rgba(0,0,0,0.3)}
.ex-sc-couple .ex-nav-logo{color:rgba(248,164,192,0.8)}
.ex-sc-couple .ex-nav-links span{color:rgba(255,255,255,0.3)}
.ex-nav-baby{background:rgba(231,84,128,0.04)}
.ex-nav-baby .ex-nav-logo{color:#c43e6e}
.ex-nav-fam{background:rgba(160,140,100,0.06)}
.ex-nav-fam .ex-nav-logo{color:#6a5a40}

/* Hero banner (shared) */
.ex-hero-banner{
    position:relative;overflow:hidden;
    background-size:cover;background-position:center;
}
.ex-hero-overlay{
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    text-align:center;padding:28px 16px;
    background:linear-gradient(to bottom,rgba(0,0,0,0.15),rgba(0,0,0,0.55));
}
.ex-hero-names{font-family:'Playfair Display',serif;font-weight:600;color:#fff;text-shadow:0 2px 12px rgba(0,0,0,0.4)}
.ex-hero-date{font-size:0.6rem;color:rgba(255,255,255,0.7);margin-top:2px}

/* COUPLE banner */
.cp-banner{
    background-image:url('https://images.unsplash.com/photo-1529333166437-7750a6dd5a70?w=800&h=400&fit=crop&auto=format&q=80');
    background-color:#1a0a14;
}
.cp-banner .ex-hero-names{font-size:1.5rem}
.cp-banner .ex-hero-overlay{padding:36px 16px}

/* Couple counter */
.ex-counter-row{display:flex;gap:10px;margin-top:10px}
.ex-cnt-box{
    display:flex;flex-direction:column;align-items:center;
    padding:6px 10px;border-radius:6px;
    background:rgba(255,255,255,0.08);backdrop-filter:blur(8px);
    border:1px solid rgba(255,255,255,0.08);
    min-width:38px;
}
.ex-cnt-box span{font-size:0.95rem;font-weight:800;color:#fff;line-height:1.1}
.ex-cnt-box{font-size:0.45rem;color:rgba(255,255,255,0.5);text-transform:uppercase;letter-spacing:0.05em;font-weight:600}

/* Section labels inside screens */
.ex-section-label{
    display:flex;align-items:center;gap:5px;
    padding:8px 16px 4px;
    font-size:0.58rem;font-weight:700;text-transform:uppercase;letter-spacing:0.06em;
    color:rgba(255,255,255,0.3);
}
.bb-label{color:rgba(200,60,110,0.35)}
.fm-label{color:rgba(100,80,50,0.35)}

/* Photo grid */
.ex-photo-grid{display:grid;gap:3px;padding:0 16px 10px}
.ex-photo{
    border-radius:4px;background-size:cover;background-position:center;
    min-height:48px;
}

/* COUPLE photos (8 photos, 4-col) */
.cp-photos{grid-template-columns:repeat(4,1fr)}
.cp-p1{background-image:url('https://images.unsplash.com/photo-1522673607200-164d1b6ce486?w=200&h=200&fit=crop&auto=format&q=80');background-color:#3d1a2a}
.cp-p2{background-image:url('https://images.unsplash.com/photo-1518199266791-5375a83190b7?w=200&h=200&fit=crop&auto=format&q=80');background-color:#4a2030}
.cp-p3{background-image:url('https://images.unsplash.com/photo-1516589178581-6cd7833ae3b2?w=200&h=200&fit=crop&auto=format&q=80');background-color:#2d1525}
.cp-p4{background-image:url('https://images.unsplash.com/photo-1474552226712-ac0f0961a829?w=200&h=200&fit=crop&auto=format&q=80');background-color:#3a1828}
.cp-p5{background-image:url('https://images.unsplash.com/photo-1494774157365-9e04c6720e47?w=200&h=200&fit=crop&auto=format&q=80');background-color:#2a1420}
.cp-p6{background-image:url('https://images.unsplash.com/photo-1529333166437-7750a6dd5a70?w=200&h=200&fit=crop&crop=left&auto=format&q=80');background-color:#351a2a}
.cp-p7{background-image:url('https://images.unsplash.com/photo-1518199266791-5375a83190b7?w=200&h=200&fit=crop&crop=top&auto=format&q=80');background-color:#3d1a2a}
.cp-p8{background-image:url('https://images.unsplash.com/photo-1516589178581-6cd7833ae3b2?w=200&h=200&fit=crop&crop=right&auto=format&q=80');background-color:#4a2030}

/* Couple note card */
.ex-note-card{
    margin:0 16px 10px;padding:10px 12px;border-radius:6px;
    background:rgba(255,255,255,0.04);
    border:1px solid rgba(255,255,255,0.06);
}
.ex-note-head{
    display:flex;align-items:center;gap:5px;
    font-size:0.58rem;font-weight:600;color:rgba(248,164,192,0.6);
    margin-bottom:4px;
}
.ex-note-card p{font-size:0.6rem;color:rgba(255,255,255,0.35);font-style:italic;line-height:1.5}

/* Couple player */
.ex-player{
    display:flex;align-items:center;gap:8px;
    margin:0 16px 14px;padding:8px 10px;border-radius:8px;
    background:rgba(255,255,255,0.04);
    border:1px solid rgba(255,255,255,0.06);
}
.ex-player-art{
    width:32px;height:32px;border-radius:4px;flex-shrink:0;
    background-image:url('https://images.unsplash.com/photo-1470225620780-dba8ba36b745?w=100&h=100&fit=crop&auto=format&q=80');
    background-size:cover;background-position:center;
    background-color:rgba(248,164,192,0.15);
}
.ex-player-info{flex:1;min-width:0}
.ex-player-name{font-size:0.6rem;font-weight:600;color:rgba(255,255,255,0.6);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ex-player-artist{font-size:0.5rem;color:rgba(255,255,255,0.25);margin-bottom:4px}
.ex-player-bar{height:2px;background:rgba(255,255,255,0.06);border-radius:1px}
.ex-player-fill{width:42%;height:100%;background:rgba(248,164,192,0.45);border-radius:1px}
.ex-player-btn{
    width:24px;height:24px;border-radius:50%;flex-shrink:0;
    background:rgba(248,164,192,0.12);
    display:flex;align-items:center;justify-content:center;
    color:rgba(248,164,192,0.7);
}

/* Couple screen bg */
.ex-sc-couple{background:linear-gradient(160deg,#0e0810,#1a0a14,#200e18)}

/* ===== BABY ===== */
.ex-sc-baby{background:linear-gradient(160deg,#fef7f9,#fdf0f4,#fce8ee)}

/* Baby banner */
.bb-banner{
    background-image:url('https://images.unsplash.com/photo-1519689680058-324335c77eba?w=600&h=300&fit=crop&auto=format&q=80');
    background-color:#fde2ec;
}
.bb-overlay{background:linear-gradient(to bottom,rgba(255,240,245,0.2),rgba(255,220,235,0.7))}
.bb-hero-name{font-size:1.15rem;color:#a03060;text-shadow:none}
.bb-hero-date{color:rgba(160,48,96,0.5)}

/* Baby milestones */
.ex-milestones{display:flex;flex-direction:column;gap:6px;padding:0 16px 10px}
.ex-mile-item{
    display:flex;align-items:center;gap:8px;
    padding:6px 8px;border-radius:8px;
    background:rgba(200,60,110,0.04);
    border:1px solid rgba(200,60,110,0.06);
}
.ex-mile-photo{
    width:28px;height:28px;border-radius:6px;flex-shrink:0;
    background-size:cover;background-position:center;
}
.bb-m1{
    background-image:url('https://images.unsplash.com/photo-1519689680058-324335c77eba?w=100&h=100&fit=crop&crop=top&auto=format&q=80');
    background-color:rgba(231,84,128,0.1);
}
.bb-m2{
    background-image:url('https://images.unsplash.com/photo-1515488042361-ee00e0ddd4e4?w=100&h=100&fit=crop&crop=top&auto=format&q=80');
    background-color:rgba(231,84,128,0.1);
}
.ex-mile-text strong{font-size:0.58rem;font-weight:600;color:rgba(160,48,96,0.7);display:block}
.ex-mile-text span{font-size:0.48rem;color:rgba(160,48,96,0.35)}

/* Baby photos */
.bb-photos{grid-template-columns:repeat(2,1fr)}
.bb-p1{background-image:url('https://images.unsplash.com/photo-1515488042361-ee00e0ddd4e4?w=200&h=200&fit=crop&auto=format&q=80');background-color:#f8d4e0}
.bb-p2{background-image:url('https://images.unsplash.com/photo-1555252333-9f8e92e65df9?w=200&h=200&fit=crop&auto=format&q=80');background-color:#f0c4d4}
.bb-p3{background-image:url('https://images.unsplash.com/photo-1504151932400-72d4384f04b3?w=200&h=200&fit=crop&auto=format&q=80');background-color:#f4ccd8}
.bb-p4{background-image:url('https://images.unsplash.com/photo-1519689373023-dd07c7988603?w=200&h=200&fit=crop&auto=format&q=80');background-color:#f2c0d0}

/* Baby growth chart */
.ex-growth-card{
    margin:0 16px 14px;padding:10px 12px;border-radius:8px;
    background:rgba(200,60,110,0.03);
    border:1px solid rgba(200,60,110,0.06);
}
.ex-growth-head{font-size:0.55rem;font-weight:700;color:rgba(160,48,96,0.4);margin-bottom:6px;text-transform:uppercase;letter-spacing:0.05em}
.ex-growth-bars{display:flex;align-items:flex-end;gap:6px;height:40px}
.gbar{flex:1;border-radius:3px 3px 0 0;background:rgba(231,84,128,0.1);transition:height .6s ease}
.gbar-active{background:rgba(231,84,128,0.35)}
.ex-growth-labels{display:flex;gap:6px;margin-top:3px}
.ex-growth-labels span{flex:1;text-align:center;font-size:0.42rem;color:rgba(160,48,96,0.25);font-weight:600}

/* ===== FAMILY ===== */
.ex-sc-family{background:linear-gradient(160deg,#f8f4ee,#f2ecde,#ece4d2)}

/* Family banner */
.fm-banner{
    background-image:url('https://images.unsplash.com/photo-1511895426328-dc8714191300?w=600&h=300&fit=crop&auto=format&q=80');
    background-color:#ede4d4;
}
.fm-overlay{background:linear-gradient(to bottom,rgba(245,240,232,0.15),rgba(236,228,210,0.75))}
.fm-hero-name{font-size:1.15rem;color:#4a3a28;text-shadow:none}
.fm-hero-date{color:rgba(100,80,50,0.5)}

/* Family tree */
.ex-fam-tree{padding:0 16px 10px}
.ft-row{display:flex;justify-content:center;gap:10px}
.ft-person{display:flex;flex-direction:column;align-items:center;gap:2px}
.ft-avatar{
    width:28px;height:28px;border-radius:50%;
    background-size:cover;background-position:center;
    border:2px solid rgba(160,140,100,0.15);
}
.fm-av1{background-image:url('https://images.unsplash.com/photo-1566616213894-2d4e1baee5d8?w=80&h=80&fit=crop&auto=format&q=80');background-color:rgba(160,140,100,0.12)}
.fm-av2{background-image:url('https://images.unsplash.com/photo-1581403341630-a6e0b9d2d257?w=80&h=80&fit=crop&auto=format&q=80');background-color:rgba(160,140,100,0.12)}
.fm-av3{background-image:url('https://images.unsplash.com/photo-1506794778202-cad84cf45f1d?w=80&h=80&fit=crop&auto=format&q=80');background-color:rgba(160,140,100,0.12)}
.fm-av4{background-image:url('https://images.unsplash.com/photo-1506794778202-cad84cf45f1d?w=80&h=80&fit=crop&crop=left&auto=format&q=80');background-color:rgba(160,140,100,0.12)}
.fm-av5{background-image:url('https://images.unsplash.com/photo-1494790108377-be9c29b29330?w=80&h=80&fit=crop&auto=format&q=80');background-color:rgba(160,140,100,0.12)}
.ft-person span{font-size:0.45rem;font-weight:600;color:rgba(100,80,50,0.45)}
.ft-connector{width:1px;height:8px;background:rgba(160,140,100,0.2);margin:3px auto}

/* Family photos */
.fm-photos{grid-template-columns:repeat(3,1fr)}
.fm-p1{background-image:url('https://images.unsplash.com/photo-1609220136736-443140cffec6?w=200&h=200&fit=crop&auto=format&q=80');background-color:#e0d4c0}
.fm-p2{background-image:url('https://images.unsplash.com/photo-1517486808906-6ca8b3f04846?w=200&h=200&fit=crop&auto=format&q=80');background-color:#d8ccb8}
.fm-p3{background-image:url('https://images.unsplash.com/photo-1542037104857-ffbb0b9155fb?w=200&h=200&fit=crop&auto=format&q=80');background-color:#dcd0bc}

/* Family events */
.ex-events{display:flex;flex-direction:column;gap:4px;padding:0 16px 14px}
.ex-ev{
    display:flex;align-items:center;gap:10px;
    padding:6px 10px;border-radius:6px;
    background:rgba(160,140,100,0.04);
    border:1px solid rgba(160,140,100,0.06);
}
.ex-ev-date{
    display:flex;flex-direction:column;align-items:center;
    min-width:28px;
}
.ex-ev-date span{font-size:0.75rem;font-weight:800;color:rgba(100,80,50,0.6);line-height:1}
.ex-ev-date{font-size:0.42rem;font-weight:600;color:rgba(100,80,50,0.3);text-transform:uppercase}
.ex-ev strong{font-size:0.58rem;font-weight:600;color:rgba(90,74,58,0.7);display:block}
.ex-ev span{font-size:0.48rem;color:rgba(90,74,58,0.3)}

/* Ex-info */
.ex-info{padding:20px 24px}
.ex-tag{
    display:inline-block;padding:3px 12px;border-radius:100px;
    font-family:'Inter',sans-serif;font-size:0.65rem;font-weight:600;
    text-transform:uppercase;letter-spacing:0.04em;
    background:var(--accent-bg);color:var(--accent);
    border:1px solid var(--accent-border);
    margin-bottom:8px;
}
.tag-baby{background:rgba(231,84,128,0.06);color:#c43e6e;border-color:rgba(231,84,128,0.12)}
.tag-fam{background:rgba(201,169,110,0.08);color:#8a7650;border-color:rgba(201,169,110,0.15)}
.ex-info h3{font-size:1.05rem;margin-bottom:4px}
.ex-info p{font-size:0.84rem;color:var(--text-3);line-height:1.6}

/* Large card overrides */
.ex-card-lg .ex-screen{min-height:auto}
.ex-card-lg .cp-banner .ex-hero-overlay{padding:44px 16px}
.ex-card-lg .cp-banner .ex-hero-names{font-size:1.8rem}
.ex-card-lg .cp-photos{grid-template-columns:repeat(4,1fr)}
.ex-card-lg .ex-photo{min-height:56px}
.ex-card-lg .ex-player{max-width:320px}

/* ==============================================
   FEATURES
   ============================================== */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.feat{padding:32px;background:var(--surface);transition:background .2s}
.feat:hover{background:var(--bg)}
.feat-ico{
    width:40px;height:40px;border-radius:10px;
    background:var(--accent-bg);border:1px solid var(--accent-border);
    display:flex;align-items:center;justify-content:center;
    color:var(--accent);margin-bottom:16px;
}
.feat h3{font-size:0.95rem;margin-bottom:6px}
.feat p{font-size:0.84rem;color:var(--text-3);line-height:1.6}

/* ==============================================
   ADD-ONS
   ============================================== */
.addon-grid{
    display:grid;grid-template-columns:repeat(2,1fr);
    gap:1px;background:var(--border);
    border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;
}
.addon{
    display:flex;align-items:flex-start;gap:14px;
    padding:24px 28px;background:var(--surface);
    transition:background .2s;
}
.addon:hover{background:var(--bg-alt)}
.addon-dot{
    width:6px;height:6px;border-radius:50%;
    background:var(--accent);margin-top:8px;flex-shrink:0;
}
.addon h4{font-family:'Inter',sans-serif;font-size:0.88rem;font-weight:600;margin-bottom:3px}
.addon p{font-size:0.82rem;color:var(--text-3);line-height:1.55}
.addon-footer{text-align:center;margin-top:40px}

/* ==============================================
   TESTIMONIALS
   ============================================== */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.testi{
    padding:28px;border-radius:var(--radius);
    background:var(--surface);border:1px solid var(--border);
    transition:all .3s;
}
.testi:hover{border-color:var(--accent-border);transform:translateY(-2px)}
.testi-stars{color:#f0b429;font-size:0.75rem;letter-spacing:2px;margin-bottom:12px}
.testi-body p{font-size:0.9rem;color:var(--text-2);line-height:1.7;margin-bottom:20px}
.testi-foot{display:flex;align-items:center;gap:10px}
.testi-av{
    width:36px;height:36px;border-radius:8px;
    background:var(--accent-bg);border:1px solid var(--accent-border);
    display:flex;align-items:center;justify-content:center;
    color:var(--accent);font-size:0.72rem;font-weight:700;
}
.testi-foot strong{font-size:0.84rem;display:block}
.testi-foot span{font-size:0.75rem;color:var(--text-3)}

/* ==============================================
   FAQ
   ============================================== */
.faq-list{display:flex;flex-direction:column;gap:4px}
.faq{
    border:1px solid var(--border);border-radius:var(--radius);
    background:var(--surface);overflow:hidden;
    transition:border-color .2s;
}
.faq:hover{border-color:var(--accent-border)}
.faq summary{
    padding:18px 22px;cursor:pointer;
    font-family:'Inter',sans-serif;font-size:0.92rem;font-weight:500;
    color:var(--text);list-style:none;display:flex;align-items:center;
    justify-content:space-between;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
    content:'+';font-size:1.1rem;color:var(--text-3);
    transition:transform .3s ease;font-weight:300;
}
.faq.faq-open summary::after{transform:rotate(45deg)}

/* FAQ smooth animation */
.faq-ans{max-height:0;overflow:hidden;transition:max-height .35s ease-out}
.faq-ans p{padding:0 22px 18px;font-size:0.88rem;color:var(--text-3);line-height:1.7;margin:0}

/* ==============================================
   CTA SECTION
   ============================================== */
.sec-cta{
    padding:100px 0;
    background:var(--bg-dark);
    position:relative;overflow:hidden;
}
.cta-inner{
    text-align:center;position:relative;z-index:1;
    max-width:580px;margin:0 auto;
    border-radius:24px;padding:80px 60px;
    background:linear-gradient(135deg,rgba(196,94,62,0.04),rgba(255,255,255,0.02),rgba(196,94,62,0.04));
    border:1px solid rgba(196,94,62,0.12);
}
.cta-glow{
    position:absolute;width:500px;height:500px;
    border-radius:50%;filter:blur(120px);
    background:rgba(196,94,62,0.1);
    top:50%;left:50%;transform:translate(-50%,-50%);
    pointer-events:none;z-index:-1;
}
.cta-label{color:var(--accent-light)!important}
.sec-cta h2{color:#fff;margin-bottom:16px}
.cta-desc{color:rgba(255,255,255,0.5);font-size:0.95rem;line-height:1.7;margin-bottom:32px}
.cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.btn-sec-light{
    display:inline-flex;align-items:center;gap:8px;
    padding:14px 32px;border-radius:8px;
    font-size:0.92rem;font-weight:600;font-family:'Inter',sans-serif;
    background:rgba(255,255,255,0.06);color:rgba(255,255,255,0.8);
    border:1px solid rgba(255,255,255,0.1);cursor:pointer;
    transition:all .2s ease;
}
.btn-sec-light:hover{background:rgba(255,255,255,0.1);border-color:rgba(255,255,255,0.2);transform:translateY(-1px)}

/* ==============================================
   CONTACT
   ============================================== */
.contact-layout{display:grid;grid-template-columns:1.2fr 1fr;gap:32px;align-items:start}
.c-form{
    padding:36px;border-radius:var(--radius);
    background:var(--surface);border:1px solid var(--border);
}
.c-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.c-field{margin-bottom:16px}
.c-field label{display:block;font-size:0.8rem;font-weight:500;color:var(--text-2);margin-bottom:6px}
.c-field input,.c-field select,.c-field textarea{
    width:100%;padding:10px 14px;border-radius:8px;
    border:1px solid var(--border);background:var(--bg);
    font-family:'Inter',sans-serif;font-size:0.88rem;color:var(--text);
    transition:border-color .2s,box-shadow .2s;
}
.c-field input::placeholder,.c-field textarea::placeholder{color:var(--text-3)}
.c-field input:focus,.c-field select:focus,.c-field textarea:focus{
    outline:none;border-color:var(--accent);
    box-shadow:0 0 0 3px var(--accent-bg);
}
.c-field textarea{resize:vertical;min-height:80px}
.c-field select{cursor:pointer}

.c-side{display:flex;flex-direction:column;gap:10px}
.c-card{
    display:flex;align-items:center;gap:14px;
    padding:18px 20px;border-radius:var(--radius);
    background:var(--surface);border:1px solid var(--border);
    transition:all .2s;
}
.c-card:hover{border-color:var(--accent-border);transform:translateX(4px)}
.c-card-ico{
    width:40px;height:40px;border-radius:10px;
    display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.wa-ico{background:rgba(37,211,102,0.08);color:#25d366}
.phone-ico{background:rgba(59,130,246,0.08);color:#3b82f6}
.mail-ico{background:var(--accent-bg);color:var(--accent)}
.c-card strong{font-size:0.88rem;display:block}
.c-card span{font-size:0.78rem;color:var(--text-3)}
.c-card-arrow{color:var(--text-3);margin-left:auto;flex-shrink:0;opacity:0;transition:opacity .2s,transform .2s}
.c-card:hover .c-card-arrow{opacity:1;transform:translateX(3px)}
.c-wa{border-color:rgba(37,211,102,0.15);background:rgba(37,211,102,0.02)}
.c-wa:hover{border-color:rgba(37,211,102,0.3);background:rgba(37,211,102,0.04)}

/* ==============================================
   FOOTER
   ============================================== */
footer{background:var(--bg-dark);color:rgba(255,255,255,0.4);padding:64px 0 24px;border-top:1px solid rgba(196,94,62,0.12)}
.foot-grid{
    display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:48px;
    padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,0.06);
}
.foot-about{max-width:280px}
.foot-brand{display:flex;align-items:center;gap:10px;font-family:'Inter',sans-serif;font-weight:700;font-size:0.92rem;color:rgba(255,255,255,0.7);margin-bottom:12px}
.foot-desc{font-size:0.84rem;line-height:1.7;margin-bottom:20px}
.foot-social{display:flex;gap:12px}
.foot-social a{
    width:36px;height:36px;border-radius:8px;
    background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.08);
    display:flex;align-items:center;justify-content:center;
    color:rgba(255,255,255,0.4);transition:all .2s;
}
.foot-social a:hover{background:rgba(255,255,255,0.1);color:rgba(255,255,255,0.7);transform:translateY(-2px)}
.foot-col h4{font-family:'Inter',sans-serif;font-size:0.82rem;font-weight:600;color:rgba(255,255,255,0.6);margin-bottom:16px;letter-spacing:-0.01em}
.foot-col a{display:block;font-size:0.82rem;padding:4px 0;transition:color .2s}
.foot-col a:hover{color:rgba(255,255,255,0.7)}
.foot-bottom{padding-top:24px;text-align:center;font-size:0.78rem;color:rgba(255,255,255,0.2)}

/* ==============================================
   FLOATING WA
   ============================================== */
.float-wa{
    position:fixed;bottom:24px;right:24px;
    width:52px;height:52px;border-radius:14px;
    background:#25d366;display:flex;align-items:center;justify-content:center;
    box-shadow:0 4px 16px rgba(37,211,102,0.3);z-index:98;
    transition:all .2s;
}
.float-wa:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(37,211,102,0.4)}

/* ==============================================
   BACK TO TOP
   ============================================== */
.back-to-top{
    position:fixed;bottom:24px;right:88px;
    width:44px;height:44px;border-radius:12px;
    background:var(--surface);border:1px solid var(--border);
    display:flex;align-items:center;justify-content:center;
    color:var(--text-3);cursor:pointer;z-index:98;
    opacity:0;visibility:hidden;transform:translateY(10px);
    transition:all .3s ease;
    box-shadow:0 4px 12px rgba(0,0,0,0.06);
}
.back-to-top.visible{opacity:1;visibility:visible;transform:translateY(0)}
.back-to-top:hover{color:var(--accent);border-color:var(--accent-border);transform:translateY(-2px)}

/* ==============================================
   SCROLL REVEAL
   ============================================== */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.reveal.vis{opacity:1;transform:translateY(0)}

/* ==============================================
   RESPONSIVE
   ============================================== */
@media(max-width:1024px){
    .tpl-grid,.feat-grid{grid-template-columns:repeat(2,1fr)}
    .testi-grid{grid-template-columns:repeat(2,1fr)}
    .foot-grid{grid-template-columns:1fr 1fr;gap:32px}
    .foot-about{max-width:100%}
}
@media(max-width:768px){
    .sec{padding:80px 0}
    .nav-center,.nav-right{display:none}
    .nav-mobile-btn{display:block}
    .hero-layout{grid-template-columns:1fr;text-align:center;gap:48px}
    .hero-text{max-width:100%;margin:0 auto}
    .hero-btns{justify-content:center;flex-wrap:wrap}
    .hv-container{width:300px;height:340px}
    .hv-card-1{width:200px}
    .hv-card-2{width:180px}
    .hv-card-3{width:170px}
    .steps{flex-direction:column;align-items:center;gap:0}
    .step{text-align:center;max-width:100%;padding:24px}
    .step-sep{width:40px;height:1px}
    .tpl-grid,.feat-grid,.addon-grid{grid-template-columns:1fr}
    .ex-bento{grid-template-columns:1fr}
    .ex-card-lg .cp-photos{grid-template-columns:repeat(2,1fr)}
    .ex-card-lg .cp-banner .ex-hero-names{font-size:1.3rem}
    .ex-card-lg .cp-banner .ex-hero-overlay{padding:28px 16px}
    .testi-grid{grid-template-columns:1fr}
    .contact-layout{grid-template-columns:1fr}
    .c-row{grid-template-columns:1fr}
    .foot-grid{grid-template-columns:1fr;gap:32px}
    .foot-top{flex-direction:column;gap:24px;text-align:center}
    .foot-links{flex-wrap:wrap;justify-content:center}
    .tabs{flex-wrap:wrap}
    .sec-cta{padding:64px 0}
    .cta-inner{padding:48px 24px;border-radius:16px}
    .cta-btns{flex-direction:column;align-items:center}
    .back-to-top{right:16px;bottom:88px}
}
@media(max-width:480px){
    .container{padding:0 16px}
    #hero h1{font-size:2rem}
    h2{font-size:1.6rem}
    .hv-container{width:260px;height:300px}
    .hv-card-1{width:180px}
    .hv-card-2{width:160px}
    .hv-card-3{width:150px}
    .hv-float{display:none}
    .c-form{padding:24px}
    .cta-inner{padding:40px 20px}
}
