/*
Theme Name: Double N Family Vietnamese
Theme URI: https://doublenfamily.com
Author: Gia Đình Double N
Description: Theme website gia đình một trang, màu tím lilac lãng mạn, có thể chỉnh nội dung tiếng Việt trong Customizer.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GPLv2 or later
Text Domain: double-n-family
*/

:root{--lilac-light:#f8f1fa;--lilac-soft:#eadcf0;--lilac-main:#b78ac7;--lilac-dark:#7a4f86;--rose-soft:#f7dce8;--rose-main:#d89ab5;--cream:#fffaf5;--white:#fff;--text-dark:#3d2f3f;--text-soft:#6f5f72;}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:Poppins,sans-serif;background:var(--cream);color:var(--text-dark);line-height:1.7}
body.admin-bar .navbar{top:32px}
a{text-decoration:none;color:inherit}
.navbar{width:100%;padding:22px 8%;position:fixed;top:0;left:0;z-index:100;background:rgba(255,250,245,.92);backdrop-filter:blur(10px);box-shadow:0 8px 24px rgba(122,79,134,.08);display:flex;justify-content:space-between;align-items:center}
.logo{font-family:'Great Vibes',cursive;font-size:36px;color:var(--lilac-dark);white-space:nowrap}
.logo span{color:var(--rose-main)}
.nav-links{display:flex;gap:28px;font-size:14px;text-transform:uppercase;letter-spacing:1px;font-weight:500}
.nav-links a:hover{color:var(--lilac-main)}
.menu-toggle{display:none;border:0;background:transparent;color:var(--lilac-dark);font-size:30px;cursor:pointer;line-height:1}
.hero{min-height:100vh;padding:150px 8% 90px;background:radial-gradient(circle at 18% 20%,rgba(247,220,232,.9),transparent 28%),radial-gradient(circle at 82% 18%,rgba(183,138,199,.56),transparent 28%),linear-gradient(135deg,rgba(248,241,250,.92),rgba(255,250,245,.96));display:flex;align-items:center;justify-content:center;text-align:center;position:relative;overflow:hidden}
.hero.has-bg{background-size:cover;background-position:center}
.hero.has-bg:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(248,241,250,.76),rgba(255,250,245,.9));z-index:0}
.hero:after{content:'♡';position:absolute;font-family:'Great Vibes',cursive;color:rgba(122,79,134,.14);line-height:1;font-size:220px;right:-20px;bottom:35px;transform:rotate(15deg);z-index:1}
.hero-heart{position:absolute;font-family:'Great Vibes',cursive;color:rgba(122,79,134,.14);line-height:1;font-size:260px;top:110px;left:-35px;transform:rotate(-18deg);z-index:1}
.hero-box{max-width:850px;padding:60px 40px;border-radius:38px;background:rgba(255,255,255,.62);box-shadow:0 25px 60px rgba(122,79,134,.18);border:1px solid rgba(183,138,199,.28);position:relative;z-index:2}
.small-title{font-family:'Great Vibes',cursive;font-size:38px;color:var(--rose-main);margin-bottom:10px}
.hero h1{font-family:'Playfair Display',serif;font-size:72px;line-height:1.05;color:var(--lilac-dark);margin-bottom:24px}
.hero h1 span{color:var(--rose-main)}
.hero p{max-width:640px;margin:0 auto 34px;color:var(--text-soft);font-size:17px}
.btn{display:inline-block;padding:14px 34px;border-radius:999px;background:linear-gradient(135deg,var(--lilac-dark),var(--lilac-main),var(--rose-main));color:#fff;font-weight:600;box-shadow:0 14px 30px rgba(122,79,134,.32);transition:.3s ease}
.btn:hover{transform:translateY(-3px);box-shadow:0 18px 40px rgba(122,79,134,.42)}
section{padding:95px 8%}
.section-heading{text-align:center;margin-bottom:55px}
.section-heading .script{font-family:'Great Vibes',cursive;font-size:42px;color:var(--rose-main)}
.section-heading h2{font-family:'Playfair Display',serif;font-size:46px;color:var(--lilac-dark);margin-top:4px}
.section-heading p{max-width:660px;margin:16px auto 0;color:var(--text-soft)}
.intro{background:var(--white)}
.intro-grid{display:grid;grid-template-columns:1fr 1fr;gap:45px;align-items:center}
.intro-image{min-height:470px;border-radius:36px;background:linear-gradient(135deg,rgba(183,138,199,.2),rgba(216,154,181,.32)),radial-gradient(circle at 30% 28%,rgba(255,255,255,.92),transparent 13%),radial-gradient(circle at 60% 48%,rgba(255,255,255,.82),transparent 15%),linear-gradient(135deg,#eadcf0,#f7dce8,#fffaf5);box-shadow:0 24px 55px rgba(122,79,134,.18);position:relative;overflow:hidden;background-size:cover;background-position:center}
.intro-image:after{content:'Ảnh Gia Đình';position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:'Great Vibes',cursive;font-size:52px;color:rgba(122,79,134,.42)}
.intro-image.has-image:after{display:none}
.intro-text h3{font-family:'Playfair Display',serif;font-size:38px;color:var(--lilac-dark);margin-bottom:20px}
.intro-text p{color:var(--text-soft);margin-bottom:18px}
.signature{font-family:'Great Vibes',cursive;font-size:38px;color:var(--rose-main);margin-top:22px}
.values{background:linear-gradient(135deg,var(--lilac-light),var(--cream))}
.value-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.value-card{background:var(--white);padding:38px 28px;border-radius:30px;text-align:center;box-shadow:0 18px 45px rgba(122,79,134,.1);border:1px solid rgba(183,138,199,.22)}
.value-icon{font-size:42px;margin-bottom:18px}
.value-card h3{font-family:'Playfair Display',serif;font-size:25px;color:var(--lilac-dark);margin-bottom:12px}
.value-card p{color:var(--text-soft);font-size:15px}
.timeline{background:var(--white)}
.timeline-wrapper{max-width:900px;margin:0 auto;position:relative}
.timeline-wrapper:before{content:'';position:absolute;left:50%;top:0;transform:translateX(-50%);width:2px;height:100%;background:var(--lilac-soft)}
.timeline-item{display:grid;grid-template-columns:1fr 1fr;gap:45px;margin-bottom:50px;position:relative}
.timeline-item:before{content:'♡';position:absolute;left:50%;top:12px;transform:translateX(-50%);width:42px;height:42px;border-radius:50%;background:var(--rose-soft);color:var(--lilac-dark);display:flex;align-items:center;justify-content:center;font-size:23px;box-shadow:0 8px 20px rgba(122,79,134,.15);z-index:2}
.timeline-date{text-align:right;font-family:'Playfair Display',serif;font-size:28px;color:var(--rose-main);padding-top:12px}
.timeline-content{background:var(--lilac-light);padding:28px;border-radius:24px;box-shadow:0 14px 35px rgba(122,79,134,.08)}
.timeline-content h3{font-family:'Playfair Display',serif;color:var(--lilac-dark);margin-bottom:8px;font-size:24px}
.timeline-content p{color:var(--text-soft);font-size:15px}
.gallery{background:linear-gradient(135deg,var(--cream),var(--lilac-light))}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.gallery-item{min-height:260px;border-radius:26px;background-size:cover;background-position:center;box-shadow:0 18px 40px rgba(122,79,134,.14);overflow:hidden;position:relative;background:linear-gradient(135deg,#eadcf0,#f7dce8)}
.gallery-item:before{content:'Kỷ Niệm';position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:'Great Vibes',cursive;font-size:34px;color:rgba(122,79,134,.46);z-index:1}
.gallery-item.has-image:before{display:none}
.g1{background:linear-gradient(135deg,#eadcf0,#f7dce8)}.g2{background:linear-gradient(135deg,#fffaf5,#eadcf0)}.g3{background:linear-gradient(135deg,#f7dce8,#fffaf5)}.g4{background:linear-gradient(135deg,#b78ac7,#f8f1fa)}.g5{background:linear-gradient(135deg,#f8f1fa,#d89ab5)}.g6{background:linear-gradient(135deg,#fffaf5,#b78ac7)}.g7{background:linear-gradient(135deg,#eadcf0,#fffaf5)}.g8{background:linear-gradient(135deg,#f7dce8,#eadcf0)}
.family-note{background:var(--white)}
.note-box{max-width:900px;margin:0 auto;padding:55px;border-radius:36px;background:linear-gradient(135deg,var(--lilac-light),var(--rose-soft));text-align:center;box-shadow:0 20px 55px rgba(122,79,134,.13)}
.note-box h2{font-family:'Playfair Display',serif;color:var(--lilac-dark);font-size:42px;margin-bottom:18px}
.note-box p{color:var(--text-soft);max-width:720px;margin:0 auto 22px}
.contact{background:linear-gradient(135deg,var(--lilac-dark),#9d70aa);color:#fff;text-align:center}
.contact .section-heading h2,.contact .section-heading .script,.contact .section-heading p{color:#fff}
.contact-info{display:flex;justify-content:center;gap:30px;flex-wrap:wrap;margin-top:30px}
.contact-card{padding:24px 34px;border-radius:24px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.25);min-width:220px}
.contact-card h3{font-family:'Playfair Display',serif;font-size:22px;margin-bottom:8px}
footer{padding:28px 8%;background:#3d2f3f;color:#fff;text-align:center;font-size:14px}
@media(max-width:900px){body.admin-bar .navbar{top:46px}.menu-toggle{display:block}.nav-links{display:none;position:absolute;top:78px;left:5%;right:5%;background:rgba(255,250,245,.98);padding:22px;border-radius:22px;box-shadow:0 16px 40px rgba(122,79,134,.14);flex-direction:column;text-align:center;gap:16px}.nav-links.active{display:flex}.hero h1{font-size:52px}.intro-grid,.value-grid{grid-template-columns:1fr}.timeline-wrapper:before{left:20px}.timeline-item{grid-template-columns:1fr;gap:14px;padding-left:55px}.timeline-item:before{left:20px;transform:translateX(-50%)}.timeline-date{text-align:left}.gallery-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.navbar{padding:18px 5%}.logo{font-size:31px}.hero{padding:130px 5% 70px}.hero-box{padding:42px 24px}.hero h1{font-size:42px}section{padding:75px 6%}.section-heading h2{font-size:36px}.gallery-grid{grid-template-columns:1fr}.note-box{padding:38px 24px}}

/* Hero two-column layout with logo */
.hero-two-col{display:flex;align-items:center;justify-content:center;gap:28px;flex-wrap:wrap;width:100%;max-width:1100px;margin:0 auto}
.hero-logo-box{flex:1;min-width:220px;max-width:360px;background:rgba(255,255,255,0.52);border-radius:28px;padding:2.5rem 2rem;display:flex;align-items:center;justify-content:center;min-height:320px;backdrop-filter:blur(6px)}
.hero-logo-box img{max-width:100%;max-height:260px;object-fit:contain;border-radius:16px}
.hero-logo-placeholder{width:140px;height:140px;border-radius:50%;border:2px dashed rgba(122,79,134,0.35);display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-size:18px;color:rgba(122,79,134,0.5)}
.hero-two-col .hero-box{flex:1;min-width:260px}
@media(max-width:700px){.hero-two-col{flex-direction:column}.hero-logo-box{max-width:100%;min-height:200px;padding:1.5rem}}
