/* ================================================================
   GEORGE W. McDUFFIE — LIGHT BLUE PREMIUM AUTHOR WEBSITE
   Clean, Airy Light-Blue Theme | Cinematic Animations | Fully Responsive
   ================================================================ */

/* CRITICAL: Prevent mobile overflow */
html { overflow-x: hidden; max-width: 100%; }
body { overflow-x: hidden; max-width: 100%; }

/* ---------------------------------------------------------------- CSS VARIABLES ---------------------------------------------------------------- */
:root {
  /* Primary palette — Light Blue */
  --sky-primary:#4AADDB;
  --sky-light:#87CEEB;
  --sky-pale:#E8F4FC;
  --sky-softer:#D0EBFA;
  --sky-dark:#2E8BBF;
  --sky-deep:#1A6FA0;
  --sky-deeper:#145A85;
  --sky-accent:#5BC0F0;

  /* Backgrounds */
  --white:#FFFFFF;
  --off-white:#F5FAFD;
  --light-blue-bg:#EAF5FC;
  --section-alt:#F0F7FC;

  /* Text */
  --text-dark:#0F2B3D;
  --text-mid:#3B6078;
  --text-light:#6E99B0;

  /* Gold accent (minimal) */
  --gold:#C9A84C;
  --gold-light:#E8D5A3;
  --gold-pale:#FDF8EE;

  /* Borders & Glass */
  --border:#B8D9EC;
  --border-light:#D4EAF5;
  --glass-bg:rgba(255,255,255,0.55);
  --glass-border:rgba(255,255,255,0.7);

  /* Shadows */
  --shadow-sm:0 2px 16px rgba(74,173,219,0.08);
  --shadow-md:0 8px 40px rgba(74,173,219,0.12);
  --shadow-lg:0 24px 80px rgba(74,173,219,0.16);
  --shadow-xl:0 40px 120px rgba(26,111,160,0.18);

  /* Radii */
  --radius:14px;
  --radius-lg:28px;
  --radius-xl:40px;

  /* Motion */
  --ease-out:cubic-bezier(0.22,1,0.36,1);
  --ease-spring:cubic-bezier(0.34,1.56,0.64,1);
  --transition:all 0.4s var(--ease-out);
  --nav-height:72px;
}

/* ---------------------------------------------------------------- RESET ---------------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;font-size:16px;overflow-x:hidden;width:100%;}
body{font-family:'Inter',system-ui,-apple-system,sans-serif;background:var(--off-white);color:var(--text-dark);line-height:1.7;overflow-x:hidden;width:100%;}
h1,h2,h3,h4,h5{font-family:'Playfair Display',serif;line-height:1.15;color:var(--sky-deep);}
a{text-decoration:none;color:inherit;transition:var(--transition);}
img{max-width:100%;display:block;}
ul{list-style:none;}
.container{max-width:1220px;margin:0 auto;padding:0 24px;}

/* ---------------------------------------------------------------- SCROLLBAR ---------------------------------------------------------------- */
::-webkit-scrollbar{width:5px;}
::-webkit-scrollbar-track{background:var(--off-white);}
::-webkit-scrollbar-thumb{background:linear-gradient(var(--sky-primary),var(--sky-light));border-radius:10px;}

/* ---------------------------------------------------------------- PAGE LOADER ---------------------------------------------------------------- */
#page-loader{position:fixed;inset:0;z-index:99999;background:linear-gradient(135deg,#D6EFFA,#B8DFF5,#A3D5F0);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:20px;transition:opacity 0.6s ease,visibility 0.6s ease;}
@keyframes loaderFadeIn{to{opacity:1;}}
@keyframes loaderBar{from{width:0;}to{width:100%;}}

/* ---------------------------------------------------------------- CURSOR ---------------------------------------------------------------- */
.cursor-dot,.cursor-ring{position:fixed;pointer-events:none;z-index:99998;border-radius:50%;transform:translate(-50%,-50%);transition:opacity 0.3s;}
.cursor-dot{width:8px;height:8px;background:var(--sky-primary);top:0;left:0;}
.cursor-ring{width:36px;height:36px;border:2px solid rgba(74,173,219,0.5);top:0;left:0;transition:width 0.3s var(--ease-out),height 0.3s var(--ease-out),background 0.3s;}
.cursor-ring.hovered{width:54px;height:54px;background:rgba(74,173,219,0.08);border-color:var(--sky-primary);}
@media(max-width:1024px){.cursor-dot,.cursor-ring{display:none;}}

/* ---------------------------------------------------------------- UTILITY ---------------------------------------------------------------- */
.section-tag{display:inline-flex;align-items:center;gap:8px;font-family:'Inter',sans-serif;font-size:0.7rem;font-weight:600;letter-spacing:0.22em;text-transform:uppercase;color:var(--sky-dark);background:linear-gradient(135deg,rgba(74,173,219,0.1),rgba(74,173,219,0.05));border:1px solid rgba(74,173,219,0.25);padding:7px 20px;border-radius:50px;margin-bottom:20px;backdrop-filter:blur(10px);}
.section-tag::before{content:'';width:6px;height:6px;background:var(--sky-primary);border-radius:50%;animation:pulse-dot 2s infinite;flex-shrink:0;}
@keyframes pulse-dot{0%,100%{transform:scale(1);opacity:1;}50%{transform:scale(1.5);opacity:0.6;}}
.section-title{font-size:clamp(1.8rem,4.5vw,3.4rem);font-weight:700;margin-bottom:18px;line-height:1.1;}
.section-title .gradient-text,.gradient-text{background:linear-gradient(135deg,var(--sky-deep),var(--sky-primary),var(--sky-accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.section-subtitle{font-family:'Cormorant Garamond',serif;font-size:1.15rem;color:var(--text-mid);font-style:italic;margin-bottom:55px;max-width:580px;margin-left:auto;margin-right:auto;line-height:1.7;}
.divider{width:50px;height:3px;background:linear-gradient(90deg,var(--sky-primary),var(--sky-light));border-radius:3px;margin:20px auto 36px;position:relative;}
.divider::after{content:'';position:absolute;left:60px;top:0;width:8px;height:3px;background:var(--sky-accent);border-radius:3px;}
.text-center{text-align:center;}

/* ---------------------------------------------------------------- BUTTONS ---------------------------------------------------------------- */
.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 30px;border-radius:50px;font-family:'Inter',sans-serif;font-size:0.88rem;font-weight:600;letter-spacing:0.04em;transition:var(--transition);cursor:pointer;border:none;position:relative;overflow:hidden;white-space:nowrap;}
.btn::before{content:'';position:absolute;inset:0;background:rgba(255,255,255,0.15);transform:translateX(-100%) skewX(-15deg);transition:transform 0.5s var(--ease-out);}
.btn:hover::before{transform:translateX(100%) skewX(-15deg);}
.btn-primary{background:linear-gradient(135deg,var(--sky-dark) 0%,var(--sky-primary) 60%,var(--sky-accent) 100%);color:var(--white);box-shadow:0 8px 30px rgba(74,173,219,0.38),inset 0 1px 0 rgba(255,255,255,0.2);}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 16px 50px rgba(74,173,219,0.5);}
.btn-gold{background:linear-gradient(135deg,var(--sky-dark),var(--sky-primary),var(--sky-accent));color:var(--white);box-shadow:0 8px 30px rgba(74,173,219,0.38),inset 0 1px 0 rgba(255,255,255,0.3);}
.btn-gold:hover{transform:translateY(-3px);box-shadow:0 16px 50px rgba(74,173,219,0.5);}
.btn-glass{background:rgba(255,255,255,0.2);border:2px solid rgba(255,255,255,0.45);color:var(--white);backdrop-filter:blur(12px);}
.btn-glass:hover{background:rgba(255,255,255,0.35);transform:translateY(-3px);}
.btn-outline-sky{background:transparent;border:2px solid var(--sky-primary);color:var(--sky-primary);}
.btn-outline-sky:hover{background:var(--sky-primary);color:var(--white);transform:translateY(-2px);}
.btn i{transition:transform 0.3s var(--ease-spring);}
.btn:hover i{transform:translateX(4px);}

/* ---------------------------------------------------------------- NAVBAR ---------------------------------------------------------------- */
#navbar{position:fixed;top:0;left:0;right:0;z-index:1000;background:transparent;border-bottom:1px solid transparent;box-shadow:none;backdrop-filter:none;-webkit-backdrop-filter:none;transition:background 0.35s ease,border-bottom 0.35s ease,box-shadow 0.35s ease;}
#navbar.scrolled{background:rgba(255,255,255,0.96);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid var(--border-light);box-shadow:0 4px 30px rgba(74,173,219,0.1);}
.nav-container{display:flex;align-items:center;justify-content:space-between;padding:20px 32px;max-width:1220px;margin:0 auto;transition:padding 0.4s ease;}
#navbar.scrolled .nav-container{padding:14px 32px;}
.nav-logo{display:flex;flex-direction:column;}
.nav-logo-name{font-family:'Playfair Display',serif;font-size:1.2rem;font-weight:700;color:#fff;-webkit-text-fill-color:#fff;text-shadow:0 1px 3px rgba(0,0,0,0.2);transition:all 0.4s ease;letter-spacing:0.02em;}
#navbar.scrolled .nav-logo-name{color:var(--sky-deep);-webkit-text-fill-color:var(--sky-deep);text-shadow:none;}
.nav-logo-title{font-family:'Cormorant Garamond',serif;font-size:0.7rem;letter-spacing:0.2em;text-transform:uppercase;color:rgba(255,255,255,0.9);text-shadow:0 1px 2px rgba(0,0,0,0.15);transition:color 0.4s ease;}
#navbar.scrolled .nav-logo-title{color:var(--sky-primary);}
.nav-links{display:flex;align-items:center;gap:36px;}
.nav-links a{font-size:0.82rem;font-weight:700;letter-spacing:0.07em;text-transform:uppercase;color:rgba(255,255,255,1);text-shadow:0 1px 3px rgba(0,0,0,0.2);position:relative;padding-bottom:4px;}
#navbar.scrolled .nav-links a{color:var(--text-dark);text-shadow:none;font-weight:600;}
.nav-links a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:#fff;border-radius:2px;transition:width 0.3s var(--ease-out);}
#navbar.scrolled .nav-links a::after{background:var(--sky-primary);}
.nav-links a:hover::after,.nav-links a.active::after{width:100%;}
.nav-links a:hover,.nav-links a.active{color:#fff;text-shadow:0 1px 4px rgba(0,0,0,0.25);}
#navbar.scrolled .nav-links a:hover,#navbar.scrolled .nav-links a.active{color:var(--sky-primary);text-shadow:none;}
.nav-cta{background:linear-gradient(135deg,var(--sky-dark),var(--sky-primary)) !important;color:white !important;padding:10px 24px;border-radius:50px;font-weight:700 !important;box-shadow:0 4px 20px rgba(74,173,219,0.35);}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(74,173,219,0.5) !important;}
.nav-cta::after{display:none !important;}
.hamburger{flex-direction:column;gap:5px;cursor:pointer;padding:10px;background:rgba(255,255,255,0.1);border-radius:8px;border:1px solid rgba(255,255,255,0.2);transition:var(--transition);}
.hamburger span{display:block;width:22px;height:2px;background:white;border-radius:2px;transition:var(--transition);}
#navbar.scrolled .hamburger{background:rgba(74,173,219,0.1);border-color:var(--border);}
#navbar.scrolled .hamburger span{background:var(--sky-deep);}

/* ---------------------------------------------------------------- HERO — LIGHT BLUE ---------------------------------------------------------------- */
.hero{min-height:100vh;background:linear-gradient(135deg,#7EC8E8 0%,#5BB8E0 25%,#4AADDB 50%,#3DA0D0 75%,#5BC0F0 100%);display:flex;align-items:center;position:relative;overflow:hidden;padding-top:var(--nav-height);}
.hero-mesh{position:absolute;inset:0;z-index:0;background:radial-gradient(ellipse 80% 60% at 20% 30%,rgba(255,255,255,0.2) 0%,transparent 60%),radial-gradient(ellipse 60% 80% at 80% 70%,rgba(255,255,255,0.15) 0%,transparent 60%),radial-gradient(ellipse 40% 40% at 50% 90%,rgba(255,255,255,0.1) 0%,transparent 50%);animation:meshShift 12s ease-in-out infinite alternate;pointer-events:none;}
@keyframes meshShift{0%{transform:scale(1) rotate(0deg);}100%{transform:scale(1.08) rotate(2deg);}}
.hero-particles{position:absolute;inset:0;z-index:0;overflow:hidden;pointer-events:none;}
.particle{position:absolute;border-radius:50%;background:rgba(255,255,255,0.12);animation:floatParticle linear infinite;}
@keyframes floatParticle{0%{transform:translateY(100vh) rotate(0deg);opacity:0;}10%{opacity:1;}90%{opacity:1;}100%{transform:translateY(-10vh) rotate(720deg);opacity:0;}}
.hero-grid{position:absolute;inset:0;z-index:0;background-image:linear-gradient(rgba(255,255,255,0.06) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,0.06) 1px,transparent 1px);background-size:60px 60px;pointer-events:none;}
.hero-content{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;position:relative;z-index:2;padding:60px 0;}
.hero-tag{display:inline-flex;align-items:center;gap:10px;background:rgba(255,255,255,0.3);border:1px solid rgba(255,255,255,0.5);color:#fff;padding:7px 18px;border-radius:50px;font-size:0.68rem;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;margin-bottom:18px;backdrop-filter:blur(8px);}
.hero-tag span{width:6px;height:6px;background:var(--white);border-radius:50%;animation:pulse-dot 2s infinite;flex-shrink:0;}
.hero-eyebrow{font-family:'Cormorant Garamond',serif;font-size:1.1rem;color:rgba(255,255,255,0.75);font-style:italic;margin-bottom:12px;}
.hero-name{font-size:clamp(2.4rem,5vw,5rem);font-weight:900;color:var(--white);line-height:1.0;margin-bottom:8px;letter-spacing:-0.02em;text-shadow:0 2px 20px rgba(0,0,0,0.08);}
.hero-name .name-gold{background:linear-gradient(135deg,#fff,#E0F0FF,#fff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.hero-title-line{font-family:'Cormorant Garamond',serif;font-size:1.2rem;color:rgba(255,255,255,0.85);font-style:italic;margin-bottom:26px;}
.hero-desc{font-size:0.97rem;color:rgba(255,255,255,0.88);line-height:1.85;margin-bottom:34px;max-width:500px;}
.hero-badges{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:38px;}
.badge{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,0.18);border:1px solid rgba(255,255,255,0.3);color:rgba(255,255,255,0.95);padding:7px 16px;border-radius:50px;font-size:0.78rem;font-weight:600;letter-spacing:0.04em;backdrop-filter:blur(8px);transition:all 0.3s ease;}
.badge:hover{background:rgba(255,255,255,0.3);transform:translateY(-2px);}
.badge i{color:var(--white);font-size:0.72rem;}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap;}
.hero-img-side{position:relative;display:flex;justify-content:center;align-items:center;}
.hero-img-frame{position:relative;width:100%;max-width:400px;}
.hero-img-glow{position:absolute;inset:-20px;background:radial-gradient(ellipse,rgba(255,255,255,0.25) 0%,transparent 70%);border-radius:var(--radius-xl);z-index:0;animation:glowPulse 4s ease-in-out infinite;pointer-events:none;}
@keyframes glowPulse{0%,100%{opacity:0.6;transform:scale(1);}50%{opacity:1;transform:scale(1.05);}}
.hero-img-border{position:absolute;top:-14px;right:-14px;bottom:14px;left:14px;border:1.5px solid rgba(255,255,255,0.3);border-radius:var(--radius-lg);z-index:0;}
.hero-img-frame img{width:100%;height:500px;object-fit:cover;object-position:top center;border-radius:var(--radius-lg);position:relative;z-index:1;box-shadow:0 30px 80px rgba(0,0,0,0.15);transition:transform 0.5s var(--ease-out);}
.hero-float-badge{position:absolute;bottom:30px;left:-30px;z-index:3;background:rgba(255,255,255,0.95);border-radius:var(--radius);padding:14px 20px;box-shadow:0 10px 40px rgba(0,0,0,0.1);animation:floatBadge 3s ease-in-out infinite;}
@keyframes floatBadge{0%,100%{transform:translateY(0);}50%{transform:translateY(-8px);}}
.hero-float-badge .num{font-family:'Playfair Display',serif;font-size:1.8rem;font-weight:700;background:linear-gradient(135deg,var(--sky-dark),var(--sky-primary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;}
.hero-float-badge .lbl{font-size:0.68rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--text-light);margin-top:2px;}
.hero-float-badge2{position:absolute;top:40px;right:-25px;z-index:3;background:linear-gradient(135deg,var(--sky-dark),var(--sky-primary));border-radius:var(--radius);padding:12px 16px;box-shadow:0 10px 30px rgba(74,173,219,0.3);animation:floatBadge 3.5s ease-in-out infinite 0.5s;color:white;text-align:center;}
.hero-float-badge2 i{font-size:1.4rem;margin-bottom:4px;}
.hero-float-badge2 p{font-size:0.65rem;font-weight:600;letter-spacing:0.08em;opacity:0.9;}
.scroll-indicator{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:5;display:flex;flex-direction:column;align-items:center;gap:8px;color:rgba(255,255,255,0.6);font-size:0.68rem;letter-spacing:0.15em;text-transform:uppercase;font-weight:600;animation:fadeInUp 1s 1.5s ease both;}
.scroll-mouse{width:22px;height:36px;border:2px solid rgba(255,255,255,0.4);border-radius:12px;display:flex;justify-content:center;padding-top:5px;}
.scroll-mouse::before{content:'';width:3px;height:8px;background:rgba(255,255,255,0.7);border-radius:2px;animation:scrollMouse 2s infinite;}
@keyframes scrollMouse{0%{transform:translateY(0);opacity:1;}100%{transform:translateY(12px);opacity:0;}}

/* ---------------------------------------------------------------- STATS BAR — LIGHT BLUE ---------------------------------------------------------------- */
.stats-bar{padding:28px 0;background:linear-gradient(135deg,#B8DFF5,#A3D5F0,#90CCE8);border-bottom:1px solid rgba(255,255,255,0.3);position:relative;overflow:hidden;}
.stats-bar::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 100% at 50% 0%,rgba(255,255,255,0.2) 0%,transparent 60%);}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative;z-index:1;}
.stat-item{text-align:center;padding:14px 16px;border-right:1px solid rgba(255,255,255,0.3);transition:background 0.3s ease;}
.stat-item:last-child{border-right:none;}
.stat-item:hover{background:rgba(255,255,255,0.15);}
.stat-number{font-family:'Playfair Display',serif;font-size:2.2rem;font-weight:700;background:linear-gradient(135deg,var(--white),#E8F6FF);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;}
.stat-label{font-size:0.68rem;font-weight:600;letter-spacing:0.15em;text-transform:uppercase;color:rgba(255,255,255,0.7);margin-top:5px;}

/* ---------------------------------------------------------------- ABOUT SECTION ---------------------------------------------------------------- */
.about-section{padding:100px 0;background:var(--white);position:relative;}
.about-section::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,transparent,var(--sky-primary),var(--sky-light),var(--sky-primary),transparent);}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}
.about-img-wrap{position:relative;}
.about-img-main-wrap{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-xl);}
.about-img-main-wrap img{width:100%;height:520px;object-fit:cover;transition:transform 0.8s var(--ease-out);}
.about-img-main-wrap:hover img{transform:scale(1.04);}
.about-img-accent{position:absolute;bottom:-20px;right:-20px;width:200px;height:185px;border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,0.15);border:5px solid var(--white);transition:transform 0.4s var(--ease-spring);}
.about-img-accent:hover{transform:scale(1.06) rotate(-2deg);}
.about-img-accent img{width:100%;height:100%;object-fit:cover;}
.about-decor{position:absolute;top:-18px;left:-18px;width:90px;height:90px;border:2px solid var(--sky-pale);border-radius:50%;z-index:-1;}
.about-decor2{position:absolute;bottom:60px;left:-30px;width:60px;height:60px;background:linear-gradient(135deg,var(--sky-pale),rgba(74,173,219,0.1));border-radius:50%;z-index:-1;}
.about-text{padding-left:10px;}
.about-text p{font-size:1rem;color:var(--text-mid);margin-bottom:20px;line-height:1.9;}
.about-text p em{font-family:'Cormorant Garamond',serif;font-size:1.05rem;color:var(--sky-primary);}
.about-highlights{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:28px 0 36px;}
.highlight-card{padding:18px;background:var(--sky-pale);border:1px solid var(--border-light);border-radius:var(--radius);transition:all 0.35s var(--ease-out);position:relative;overflow:hidden;}
.highlight-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(74,173,219,0.05),transparent);opacity:0;transition:opacity 0.3s;}
.highlight-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--sky-primary);}
.highlight-card:hover::before{opacity:1;}
.highlight-card i{font-size:1.4rem;color:var(--sky-primary);margin-bottom:8px;display:block;}
.highlight-card h4{font-size:0.88rem;font-weight:700;color:var(--sky-deep);margin-bottom:4px;}
.highlight-card p{font-size:0.78rem;color:var(--text-light);margin:0;line-height:1.5;}

/* ---------------------------------------------------------------- BOOK SECTION ---------------------------------------------------------------- */
.book-section{padding:100px 0;background:linear-gradient(180deg,var(--light-blue-bg) 0%,var(--off-white) 100%);position:relative;overflow:hidden;}
.book-section::before{content:'';position:absolute;top:-200px;right:-200px;width:600px;height:600px;background:radial-gradient(circle,rgba(74,173,219,0.06) 0%,transparent 70%);border-radius:50%;pointer-events:none;}
.book-showcase{display:grid;grid-template-columns:380px 1fr;gap:80px;align-items:start;margin-top:60px;}
.book-visual{position:relative;display:flex;justify-content:center;}
.book-pages-effect{position:relative;display:inline-block;}
.book-pages-effect::before,.book-pages-effect::after{content:'';position:absolute;width:100%;height:100%;border-radius:var(--radius);top:0;left:0;}
.book-pages-effect::before{background:var(--sky-pale);transform:translate(-8px,8px) rotate(-1.5deg);z-index:-2;box-shadow:0 5px 20px rgba(0,0,0,0.06);}
.book-pages-effect::after{background:var(--border-light);transform:translate(-4px,4px) rotate(-0.5deg);z-index:-1;box-shadow:0 5px 20px rgba(0,0,0,0.04);}
.book-cover-img{width:280px;height:390px;object-fit:cover;border-radius:var(--radius);box-shadow:0 30px 80px rgba(0,0,0,0.15);transition:transform 0.6s var(--ease-out);cursor:pointer;}
.book-visual:hover .book-cover-img{transform:perspective(800px) rotateY(-10deg) translateY(-8px) scale(1.02);}
.book-new-badge{position:absolute;top:-14px;right:8px;background:linear-gradient(135deg,var(--sky-dark),var(--sky-primary));color:white;font-size:0.65rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;padding:6px 16px;border-radius:50px;box-shadow:0 6px 20px rgba(74,173,219,0.4);animation:floatBadge 3s ease-in-out infinite;z-index:5;}
.book-info h2{font-size:clamp(1.6rem,3vw,2.4rem);font-weight:700;color:var(--sky-deep);line-height:1.2;margin-bottom:10px;}
.book-sub{font-family:'Cormorant Garamond',serif;font-size:1.05rem;color:var(--text-mid);font-style:italic;margin-bottom:22px;display:block;}
.book-meta-row{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:26px;}
.bm-item{display:flex;align-items:center;gap:7px;font-size:0.83rem;color:var(--text-mid);font-weight:600;}
.bm-item i{color:var(--sky-primary);font-size:0.78rem;}
.book-desc{font-size:0.97rem;color:var(--text-mid);line-height:1.9;margin-bottom:18px;}
.book-quote{background:var(--white);border-left:4px solid var(--sky-primary);border-radius:0 var(--radius) var(--radius) 0;padding:22px 26px;margin:28px 0;position:relative;box-shadow:var(--shadow-sm);}
.book-quote::before{content:'\201C';font-family:'Playfair Display',serif;font-size:5rem;color:var(--sky-pale);position:absolute;top:-15px;left:10px;line-height:1;z-index:0;}
.book-quote blockquote{font-family:'Cormorant Garamond',serif;font-size:1.05rem;color:var(--text-dark);font-style:italic;position:relative;z-index:1;margin-bottom:8px;}
.book-quote cite{font-size:0.78rem;color:var(--sky-primary);font-weight:700;font-style:normal;letter-spacing:0.04em;}
.book-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:30px;}

/* ---------------------------------------------------------------- THEMES / CARDS — LIGHT BLUE ---------------------------------------------------------------- */
.themes-section{padding:100px 0;background:linear-gradient(135deg,#B8DFF5 0%,#A3D5F0 50%,#90CCE8 100%);position:relative;overflow:hidden;}
.themes-section::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.08'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");pointer-events:none;}
.themes-section .section-tag{background:rgba(255,255,255,0.25);border-color:rgba(255,255,255,0.45);color:var(--sky-deep);}
.themes-section .section-title{color:var(--sky-deep);}
.themes-section .section-subtitle{color:var(--text-mid);}
.themes-section .divider{background:linear-gradient(90deg,white,var(--sky-deep));}
.theme-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:50px;}
.theme-card{background:rgba(255,255,255,0.55);border:1px solid rgba(255,255,255,0.65);border-radius:var(--radius-lg);padding:36px 26px;text-align:center;backdrop-filter:blur(12px);transition:all 0.4s var(--ease-out);position:relative;overflow:hidden;cursor:pointer;}
.theme-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--sky-primary),var(--sky-accent));transform:scaleX(0);transform-origin:left;transition:transform 0.4s var(--ease-out);}
.theme-card:hover{background:rgba(255,255,255,0.75);transform:translateY(-8px);box-shadow:0 30px 70px rgba(0,0,0,0.1);}
.theme-card:hover::before{transform:scaleX(1);}
.tc-icon{width:68px;height:68px;background:rgba(74,173,219,0.15);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;transition:all 0.4s var(--ease-spring);}
.theme-card:hover .tc-icon{background:var(--sky-primary);transform:scale(1.1) rotate(5deg);}
.tc-icon i{font-size:1.7rem;color:var(--sky-dark);transition:color 0.3s;}
.theme-card:hover .tc-icon i{color:white;}
.theme-card h3{font-size:1.1rem;color:var(--sky-deep);margin-bottom:10px;}
.theme-card p{font-size:0.86rem;color:var(--text-mid);line-height:1.7;}

/* ---------------------------------------------------------------- TIMELINE ---------------------------------------------------------------- */
.timeline-section{padding:100px 0;background:var(--white);}
.timeline{position:relative;max-width:820px;margin:60px auto 0;}
.timeline::before{content:'';position:absolute;left:50%;transform:translateX(-50%);top:0;bottom:0;width:2px;background:linear-gradient(180deg,var(--sky-primary),var(--sky-light),var(--sky-accent));}
.tl-item{display:grid;grid-template-columns:1fr 70px 1fr;margin-bottom:46px;align-items:start;}
.tl-center{display:flex;justify-content:center;padding-top:12px;}
.tl-dot{width:20px;height:20px;background:linear-gradient(135deg,var(--sky-primary),var(--sky-accent));border:4px solid white;border-radius:50%;box-shadow:0 0 0 4px rgba(74,173,219,0.2),0 0 20px rgba(74,173,219,0.2);transition:transform 0.3s var(--ease-spring);}
.tl-item:hover .tl-dot{transform:scale(1.4);}
.tl-content{background:var(--sky-pale);border:1px solid var(--border-light);border-radius:var(--radius);padding:20px 24px;transition:all 0.35s var(--ease-out);position:relative;}
.tl-content:hover{box-shadow:var(--shadow-md);border-color:var(--sky-primary);transform:translateY(-3px);}
.tl-year{font-size:0.66rem;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--sky-primary);margin-bottom:6px;}
.tl-title{font-family:'Playfair Display',serif;font-size:1rem;font-weight:600;color:var(--sky-deep);margin-bottom:6px;}
.tl-desc{font-size:0.85rem;color:var(--text-mid);line-height:1.65;}

/* ---------------------------------------------------------------- EDUCATION — LIGHT BLUE ---------------------------------------------------------------- */
.edu-section{padding:100px 0;background:linear-gradient(135deg,#A3D5F0,#90CCE8 60%,#7EC8E8);position:relative;overflow:hidden;}
.edu-section::after{content:'';position:absolute;bottom:-100px;right:-100px;width:500px;height:500px;background:radial-gradient(circle,rgba(255,255,255,0.15) 0%,transparent 60%);border-radius:50%;pointer-events:none;}
.edu-section .section-tag{background:rgba(255,255,255,0.3);border-color:rgba(255,255,255,0.5);color:var(--sky-deep);}
.edu-section .section-tag::before{background:var(--sky-deep);}
.edu-section .section-title{color:var(--sky-deep);}
.edu-section .section-subtitle{color:var(--text-mid);}
.edu-section .divider{background:linear-gradient(90deg,white,var(--sky-deep));}
.edu-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:50px;position:relative;z-index:1;}
.edu-card{background:rgba(255,255,255,0.5);border:1px solid rgba(255,255,255,0.6);border-radius:var(--radius-lg);padding:36px 26px;text-align:center;backdrop-filter:blur(16px);transition:all 0.4s var(--ease-out);position:relative;overflow:hidden;}
.edu-card::after{content:'';position:absolute;bottom:-60px;right:-60px;width:150px;height:150px;background:radial-gradient(circle,rgba(255,255,255,0.1) 0%,transparent 70%);border-radius:50%;}
.edu-card:hover{background:rgba(255,255,255,0.7);transform:translateY(-8px);box-shadow:0 30px 70px rgba(0,0,0,0.08);}
.edu-icon{width:64px;height:64px;background:rgba(74,173,219,0.15);border:1px solid rgba(74,173,219,0.25);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;transition:all 0.4s var(--ease-spring);}
.edu-card:hover .edu-icon{background:var(--sky-primary);transform:scale(1.1) rotate(8deg);border-color:var(--sky-primary);}
.edu-icon i{font-size:1.5rem;color:var(--sky-dark);}
.edu-card:hover .edu-icon i{color:white;}
.edu-card h3{font-size:1.05rem;color:var(--sky-deep);margin-bottom:8px;}
.edu-card .degree{font-family:'Cormorant Garamond',serif;font-size:0.92rem;color:var(--text-mid);font-style:italic;margin-bottom:6px;display:block;}
.edu-card .school{font-size:0.76rem;color:var(--text-light);letter-spacing:0.04em;}

/* ---------------------------------------------------------------- FAITH ---------------------------------------------------------------- */
.faith-section{padding:100px 0;background:var(--white);overflow:hidden;}
.faith-grid{display:grid;grid-template-columns:1fr 1fr;gap:55px;align-items:center;}
.faith-img-side{position:relative;border-radius:var(--radius-lg);overflow:hidden;height:480px;box-shadow:var(--shadow-xl);}
.faith-img-side img{width:100%;height:100%;object-fit:cover;transition:transform 0.8s var(--ease-out);}
.faith-img-side:hover img{transform:scale(1.04);}
.faith-img-overlay{position:absolute;inset:0;background:linear-gradient(0deg,rgba(20,90,133,0.6) 0%,transparent 50%);}
.faith-img-label{position:absolute;bottom:26px;left:26px;right:26px;z-index:1;}
.faith-img-label h4{font-family:'Playfair Display',serif;font-size:1.2rem;color:white;margin-bottom:4px;}
.faith-img-label p{font-size:0.8rem;color:rgba(255,255,255,0.7);}
.faith-text h2{margin-bottom:16px;}
.faith-text p{color:var(--text-mid);font-size:0.97rem;line-height:1.9;margin-bottom:18px;}
.faith-list li{display:flex;gap:14px;align-items:flex-start;margin-bottom:14px;font-size:0.93rem;color:var(--text-mid);transition:transform 0.2s ease;}
.faith-list li:hover{transform:translateX(5px);}
.faith-list li i{color:var(--sky-primary);margin-top:3px;flex-shrink:0;}

/* ---------------------------------------------------------------- ENDORSEMENT ---------------------------------------------------------------- */
.endorsement-section{padding:80px 0;background:var(--sky-pale);}
.endorsement-wrap{max-width:800px;margin:0 auto;background:white;border-radius:var(--radius-xl);padding:60px 50px;box-shadow:var(--shadow-xl);position:relative;overflow:hidden;}
.endorsement-wrap::before{content:'';position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,var(--sky-primary),var(--sky-accent),var(--sky-primary));}
.enq-icon{font-family:'Playfair Display',serif;font-size:7rem;line-height:1;color:var(--sky-pale);position:absolute;top:5px;left:22px;z-index:0;}
.endorsement-wrap blockquote{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-style:italic;color:var(--text-dark);line-height:1.7;text-align:center;margin-bottom:28px;position:relative;z-index:1;}
.endorser{text-align:center;}
.endorser-name{font-weight:700;color:var(--sky-deep);font-size:1rem;}
.endorser-title{font-size:0.8rem;color:var(--text-light);letter-spacing:0.04em;margin-top:4px;}

/* ---------------------------------------------------------------- EBOOK CTA — LIGHT BLUE ---------------------------------------------------------------- */
.ebook-cta{padding:100px 0;background:linear-gradient(135deg,#7EC8E8 0%,#5BB8E0 40%,#4AADDB 70%,#3DA0D0 100%);position:relative;overflow:hidden;text-align:center;}
.ebook-cta::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle at 20% 50%,rgba(255,255,255,0.08) 1px,transparent 1px),radial-gradient(circle at 80% 20%,rgba(255,255,255,0.06) 1px,transparent 1px);background-size:55px 55px,80px 80px;pointer-events:none;}
.ebook-cta h2{color:white;font-size:clamp(1.8rem,4vw,3rem);margin-bottom:16px;text-shadow:0 2px 15px rgba(0,0,0,0.08);}
.ebook-desc{color:rgba(255,255,255,0.85);font-size:1rem;max-width:520px;margin:0 auto 40px;}
.ebook-card-wrap{display:inline-flex;align-items:center;gap:26px;background:rgba(255,255,255,0.18);border:1px solid rgba(255,255,255,0.35);border-radius:var(--radius-xl);padding:26px 40px;backdrop-filter:blur(12px);margin-bottom:36px;transition:all 0.35s ease;}
.ebook-card-wrap:hover{background:rgba(255,255,255,0.3);transform:translateY(-4px);}
.ebook-info{text-align:left;}
.ebook-info h3{color:white;font-size:1.15rem;margin-bottom:5px;}
.ebook-info p{color:rgba(255,255,255,0.7);font-size:0.82rem;}

/* ---------------------------------------------------------------- GALLERY ---------------------------------------------------------------- */
.gallery-section{padding:100px 0;background:#F5FAFD;}
.gallery-mosaic{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:200px;gap:14px;margin-top:50px;}
.gm-tile{border-radius:var(--radius);overflow:hidden;position:relative;cursor:zoom-in;box-shadow:var(--shadow-sm);transition:transform 0.4s var(--ease-out),box-shadow 0.4s ease;}
.gm-tile:hover{transform:scale(1.02) translateY(-4px);box-shadow:var(--shadow-lg);}
.gm-tile img{width:100%;height:100%;object-fit:cover;transition:transform 0.6s var(--ease-out);}
.gm-tile:hover img{transform:scale(1.1);}
.gm-overlay{position:absolute;inset:0;background:linear-gradient(0deg,rgba(20,90,133,0.45) 0%,transparent 55%);opacity:0;transition:opacity 0.35s ease;display:flex;align-items:flex-end;padding:18px;}
.gm-tile:hover .gm-overlay{opacity:1;}
.gm-overlay i{color:white;font-size:1.4rem;}
.gm-c8{grid-column:span 8;}.gm-c4{grid-column:span 4;}.gm-c6{grid-column:span 6;}
.gm-c5{grid-column:span 5;}.gm-c7{grid-column:span 7;}.gm-r2{grid-row:span 2;}

/* ---------------------------------------------------------------- CONTACT ---------------------------------------------------------------- */
.contact-section{padding:100px 0;background:var(--off-white);}
.contact-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:80px;align-items:start;}
.contact-info-side h2{margin-bottom:16px;}
.contact-info-side>p{color:var(--text-mid);line-height:1.9;margin-bottom:36px;font-size:1rem;}
.contact-item{display:flex;gap:16px;align-items:flex-start;margin-bottom:24px;}
.ci-icon{width:48px;height:48px;border-radius:var(--radius);background:linear-gradient(135deg,var(--sky-pale),rgba(74,173,219,0.12));border:1px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all 0.3s var(--ease-spring);}
.contact-item:hover .ci-icon{background:var(--sky-primary);transform:scale(1.1) rotate(5deg);border-color:var(--sky-primary);}
.contact-item:hover .ci-icon i{color:white;}
.ci-icon i{color:var(--sky-primary);font-size:1.05rem;transition:color 0.3s;}
.ci-text h4{font-size:0.83rem;font-weight:700;color:var(--sky-deep);margin-bottom:3px;}
.ci-text p{font-size:0.9rem;color:var(--text-mid);}
.contact-form-box{background:white;border-radius:var(--radius-xl);padding:50px;box-shadow:var(--shadow-xl);border:1px solid var(--border-light);position:relative;overflow:hidden;}
.contact-form-box::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--sky-primary),var(--sky-accent),var(--sky-primary));}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.form-group{margin-bottom:20px;}
.form-group label{display:block;font-size:0.76rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:var(--sky-deep);margin-bottom:8px;}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:13px 16px;background:var(--sky-pale);border:1.5px solid var(--border-light);border-radius:var(--radius);font-family:'Inter',sans-serif;font-size:0.93rem;color:var(--text-dark);transition:var(--transition);outline:none;}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--sky-primary);box-shadow:0 0 0 4px rgba(74,173,219,0.12);background:white;}
.form-group textarea{min-height:140px;resize:vertical;}
.form-submit{width:100%;justify-content:center;font-size:0.95rem;padding:16px;}

/* ---------------------------------------------------------------- PAGE HERO — LIGHT BLUE ---------------------------------------------------------------- */
.page-hero{background:linear-gradient(135deg,#7EC8E8 0%,#5BB8E0 35%,#4AADDB 65%,#3DA0D0 100%);padding:140px 0 80px;text-align:center;position:relative;overflow:hidden;}
.page-hero::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle at 30% 40%,rgba(255,255,255,0.1) 1px,transparent 1px),radial-gradient(circle at 70% 70%,rgba(255,255,255,0.06) 1px,transparent 1px);background-size:50px 50px,80px 80px;pointer-events:none;}
.page-hero::after{content:'';position:absolute;top:-100px;right:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(255,255,255,0.15) 0%,transparent 60%);border-radius:50%;pointer-events:none;}
.page-hero h1{color:white;font-size:clamp(2rem,5vw,3.8rem);margin-bottom:14px;position:relative;z-index:1;padding:0 16px;text-shadow:0 2px 15px rgba(0,0,0,0.08);}
.page-hero p{font-family:'Cormorant Garamond',serif;font-size:1.15rem;color:rgba(255,255,255,0.95);font-style:italic;position:relative;z-index:1;padding:0 16px;}
.breadcrumb{display:flex;justify-content:center;align-items:center;gap:8px;margin-top:22px;font-size:0.78rem;color:rgba(255,255,255,0.6);position:relative;z-index:1;flex-wrap:wrap;}
.breadcrumb a{color:rgba(255,255,255,0.8);transition:color 0.3s;}
.breadcrumb a:hover{color:white;}

/* ---------------------------------------------------------------- FOOTER — LIGHT BLUE ---------------------------------------------------------------- */
footer{background:linear-gradient(180deg,#A3D5F0 0%,#8BCAE5 50%,#78C1E0 100%);padding:70px 0 28px;position:relative;overflow:hidden;}
footer::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--sky-primary),white,var(--sky-primary),transparent);}
footer::after{content:'';position:absolute;bottom:-100px;right:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(255,255,255,0.08) 0%,transparent 60%);border-radius:50%;pointer-events:none;}
.footer-grid{display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;gap:44px;margin-bottom:48px;position:relative;z-index:1;}
.footer-brand-name{font-family:'Playfair Display',serif;font-size:1.4rem;font-weight:700;color:var(--sky-deep);margin-bottom:6px;}
.footer-brand-sub{font-family:'Cormorant Garamond',serif;font-size:0.88rem;color:var(--sky-dark);font-style:italic;margin-bottom:18px;}
.footer-brand p{font-size:0.86rem;color:var(--text-mid);line-height:1.8;max-width:280px;}
.footer-col h4{font-family:'Inter',sans-serif;font-size:0.7rem;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--sky-deep);margin-bottom:18px;}
.footer-col ul li{margin-bottom:10px;}
.footer-col ul li a{font-size:0.85rem;color:var(--text-mid);transition:all 0.3s ease;display:inline-block;}
.footer-col ul li a:hover{color:var(--sky-deep);transform:translateX(6px);}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.4);padding-top:26px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;position:relative;z-index:1;}
.footer-bottom p{font-size:0.78rem;color:var(--text-mid);}
.footer-bottom-links{display:flex;gap:20px;flex-wrap:wrap;}
.footer-bottom-links a{font-size:0.78rem;color:var(--text-mid);transition:color 0.3s;}
.footer-bottom-links a:hover{color:var(--sky-deep);}
.footer-powered{text-align:center;padding-top:16px;border-top:1px solid rgba(255,255,255,0.3);margin-top:8px;position:relative;z-index:1;}
.footer-powered p{font-size:0.73rem;color:var(--text-mid);}
.footer-powered a{color:var(--sky-deep);font-weight:600;text-decoration:none;transition:color 0.3s ease;}
.footer-powered a:hover{color:var(--sky-deeper);}

/* ---------------------------------------------------------------- LIGHTBOX ---------------------------------------------------------------- */
#lb-overlay{position:fixed;inset:0;z-index:99999;background:rgba(15,60,90,0.92);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity 0.35s ease,visibility 0.35s ease;}
#lb-overlay.open{opacity:1;visibility:visible;}
#lb-img{max-width:88vw;max-height:84vh;object-fit:contain;border-radius:10px;box-shadow:0 40px 120px rgba(0,0,0,0.4);transform:scale(0.85);transition:transform 0.45s var(--ease-spring);cursor:zoom-out;}
#lb-overlay.open #lb-img{transform:scale(1);}
#lb-caption{position:absolute;bottom:70px;left:50%;transform:translateX(-50%);font-family:'Cormorant Garamond',serif;font-size:0.95rem;color:rgba(255,255,255,0.6);font-style:italic;white-space:nowrap;max-width:80vw;overflow:hidden;text-overflow:ellipsis;}
.lb-btn{position:fixed;width:50px;height:50px;background:rgba(255,255,255,0.12);border:1.5px solid rgba(255,255,255,0.25);border-radius:50%;color:white;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all 0.3s var(--ease-spring);z-index:100000;}
.lb-btn:hover{background:var(--sky-primary);border-color:var(--sky-primary);transform:scale(1.1);}
#lb-close{top:20px;right:20px;font-size:1rem;}
#lb-close:hover{background:#e53935;border-color:#e53935;transform:rotate(90deg) scale(1.1);}
#lb-prev{top:50%;left:16px;transform:translateY(-50%);}
#lb-next{top:50%;right:16px;transform:translateY(-50%);}
#lb-prev:hover{transform:translateY(-50%) scale(1.1);}
#lb-next:hover{transform:translateY(-50%) scale(1.1);}
#lb-counter{position:fixed;top:26px;left:50%;transform:translateX(-50%);font-size:0.75rem;font-weight:700;letter-spacing:0.15em;color:rgba(255,255,255,0.5);z-index:100000;}

/* ---------------------------------------------------------------- ALERTS ---------------------------------------------------------------- */
.alert{padding:14px 20px;border-radius:var(--radius);margin-bottom:20px;font-weight:600;display:flex;align-items:center;gap:10px;}
.alert-success{background:#e8f5e9;color:#2e7d32;border:1px solid #a5d6a7;}
.alert-error{background:#fdecea;color:#c62828;border:1px solid #ef9a9a;}

/* ---------------------------------------------------------------- SCROLL ANIMATIONS ---------------------------------------------------------------- */
.reveal{opacity:0;transform:translateY(40px);transition:opacity 0.75s var(--ease-out),transform 0.75s var(--ease-out);}
.reveal.visible{opacity:1;transform:translateY(0);}
.reveal-left{opacity:0;transform:translateX(-40px);transition:opacity 0.75s var(--ease-out),transform 0.75s var(--ease-out);}
.reveal-left.visible{opacity:1;transform:translateX(0);}
.reveal-right{opacity:0;transform:translateX(40px);transition:opacity 0.75s var(--ease-out),transform 0.75s var(--ease-out);}
.reveal-right.visible{opacity:1;transform:translateX(0);}
.reveal-scale{opacity:0;transform:scale(0.92);transition:opacity 0.75s var(--ease-out),transform 0.75s var(--ease-spring);}
.reveal-scale.visible{opacity:1;transform:scale(1);}
.d1{transition-delay:0.1s;}.d2{transition-delay:0.2s;}.d3{transition-delay:0.3s;}.d4{transition-delay:0.4s;}.d5{transition-delay:0.5s;}

/* ---------------------------------------------------------------- KEYFRAMES ---------------------------------------------------------------- */
@keyframes fadeInUp{from{opacity:0;transform:translateY(40px);}to{opacity:1;transform:translateY(0);}}
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}
@keyframes slideInLeft{from{opacity:0;transform:translateX(-40px);}to{opacity:1;transform:translateX(0);}}
@keyframes slideInRight{from{opacity:0;transform:translateX(40px);}to{opacity:1;transform:translateX(0);}}

/* ================================================================
   FULLY RESPONSIVE — ALL BREAKPOINTS
   ================================================================ */

/* ── LARGE DESKTOP (≤1400px) ── */
@media (max-width:1400px){
  .container{max-width:1100px;}
}

/* ── TABLET (≤1100px) ── */
@media (max-width:1100px){
  .hero-content{grid-template-columns:1fr;gap:40px;text-align:center;padding:50px 0;}
  .hero-img-side{order:-1;}
  .hero-img-frame{max-width:320px;margin:0 auto;}
  .hero-img-frame img{height:380px;}
  .hero-btns,.hero-badges{justify-content:center;}
  .hero-desc{margin-left:auto;margin-right:auto;}
  .hero-float-badge,.hero-float-badge2{display:none;}
  .about-grid{grid-template-columns:1fr;gap:50px;}
  .about-img-accent{width:170px;height:155px;}
  .book-showcase{grid-template-columns:1fr;gap:50px;text-align:center;}
  .book-visual{justify-content:center;}
  .book-actions{justify-content:center;}
  .book-meta-row{justify-content:center;}
  .faith-grid{grid-template-columns:1fr;gap:40px;}
  .contact-grid{grid-template-columns:1fr;gap:50px;}
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px;}
  .edu-cards,.theme-cards{grid-template-columns:1fr 1fr;}
  .stats-grid{grid-template-columns:repeat(2,1fr);}
}

/* ── MOBILE (≤768px) ── */
@media (max-width:768px){
  .nav-links{display:none !important;}
  .hamburger{display:flex !important;}
  .nav-container{padding:12px 16px;}
  #navbar:not(.scrolled){background:rgba(90,180,220,0.92);}
  .hero{min-height:auto;padding:70px 0 50px;}
  .hero-content{gap:28px;padding:30px 0;}
  .hero-img-frame{max-width:250px;}
  .hero-img-frame img{height:290px;}
  .hero-name{font-size:clamp(1.9rem,7vw,2.6rem);}
  .hero-title-line{font-size:0.95rem;}
  .hero-desc{font-size:0.9rem;}
  .hero-btns .btn{padding:12px 22px;font-size:0.82rem;}
  .hero-img-glow,.scroll-indicator{display:none;}
  .stats-grid{grid-template-columns:1fr 1fr;}
  .stat-number{font-size:1.8rem;}
  .stat-label{font-size:0.62rem;}
  .about-section,.faith-section,.timeline-section,.edu-section,
  .endorsement-section,.ebook-cta,.gallery-section,.contact-section,
  .themes-section{padding:65px 0;}
  .about-img-main-wrap img{height:300px;}
  .about-img-accent{width:120px;height:112px;right:-8px;bottom:-8px;}
  .about-highlights{grid-template-columns:1fr 1fr;gap:10px;}
  .highlight-card{padding:14px;}
  .book-cover-img{width:200px;height:280px;}
  .timeline::before{left:16px;}
  .tl-item{grid-template-columns:36px 1fr;gap:0;}
  .tl-item:nth-child(odd) .tl-content,
  .tl-item:nth-child(even) .tl-content{grid-column:2;text-align:left;margin-left:10px;}
  .tl-item:nth-child(odd) .tl-center,
  .tl-item:nth-child(even) .tl-center{grid-column:1;}
  .tl-empty{display:none;}
  .edu-cards,.theme-cards{grid-template-columns:1fr;gap:14px;}
  .faith-img-side{height:300px;}
  .endorsement-wrap{padding:32px 22px;}
  .endorsement-wrap blockquote{font-size:1.1rem;}
  .enq-icon{font-size:4rem;}
  .ebook-card-wrap{flex-direction:column;padding:22px;gap:14px;text-align:center;}
  .ebook-info{text-align:center;}
  .gallery-mosaic{grid-template-columns:1fr 1fr;grid-auto-rows:150px;gap:8px;}
  .gm-c8,.gm-c4,.gm-c6,.gm-c5,.gm-c7{grid-column:span 1;}
  .gm-r2{grid-row:span 1;}
  .contact-form-box{padding:26px 18px;}
  .form-row{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;gap:28px;}
  .footer-bottom{flex-direction:column;text-align:center;gap:10px;}
  .footer-bottom-links{justify-content:center;}
  .page-hero{padding:100px 0 55px;}
  .page-hero h1{font-size:clamp(1.6rem,5.5vw,2.2rem);}
  body,html{overflow-x:hidden;width:100%;}
  .hero,.hero-content,.hero-text,.hero-img-side{overflow:visible;}
  section,.container{overflow-x:hidden;max-width:100%;}
  [style*="animation:slideInLeft"],
  [style*="animation:slideInRight"]{animation:fadeInUp 0.8s ease both !important;}
}

/* ── SMALL PHONES (≤480px) ── */
@media (max-width:480px){
  .container{padding:0 14px;}
  .hero-img-frame{max-width:210px;}
  .hero-img-frame img{height:250px;}
  .hero-name{font-size:clamp(1.7rem,6vw,2.1rem);}
  .hero-badges{gap:6px;}
  .badge{padding:6px 11px;font-size:0.7rem;}
  .about-highlights{grid-template-columns:1fr;}
  .section-title{font-size:clamp(1.5rem,4.5vw,1.9rem);}
  .section-subtitle{font-size:0.97rem;margin-bottom:30px;}
  .endorsement-wrap blockquote{font-size:1rem;}
  .contact-form-box{padding:20px 14px;}
  .book-cover-img{width:170px;height:245px;}
  .ebook-card-wrap{padding:18px 14px;}
  .gallery-mosaic{grid-template-columns:1fr;grid-auto-rows:200px;}
  .gm-c8,.gm-c4,.gm-c6,.gm-c5,.gm-c7,.gm-r2{grid-column:span 1;grid-row:span 1;}
  .edu-cards,.theme-cards{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;}
  .page-hero{padding:90px 0 45px;}
  .page-hero h1{font-size:clamp(1.4rem,5vw,1.8rem);}
  [style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr !important;}
  [style*="grid-template-columns:2fr 1fr"]{grid-template-columns:1fr !important;}
  [style*="grid-template-columns:1fr 2fr"]{grid-template-columns:1fr !important;}
  [style*="grid-template-columns:1fr 1.5fr"]{grid-template-columns:1fr !important;}
  [style*="grid-template-columns:1fr 1.6fr"]{grid-template-columns:1fr !important;}
  [style*="grid-template-columns:1fr 1fr 1fr"]{grid-template-columns:1fr !important;}
}

/* ── XS PHONES (≤380px) ── */
@media (max-width:380px){
  .hero-btns{flex-direction:column;align-items:center;}
  .hero-btns .btn{width:100%;justify-content:center;}
  .book-actions{flex-direction:column;align-items:stretch;}
  .book-actions .btn{justify-content:center;}
  .about-highlights{grid-template-columns:1fr;}
  .stats-grid{grid-template-columns:1fr 1fr;}
}

/* ================================================================
   OVERFLOW & WHITESPACE FIX — MOBILE
   ================================================================ */
html, body {overflow-x: hidden !important;width: 100% !important;max-width: 100vw !important;margin: 0 !important;padding-top: 0 !important;}
*, *::before, *::after {max-width: 100%;}
#page-loader { top: 0 !important; left: 0 !important; }

@media (max-width: 768px) {
  html, body { overflow-x: hidden !important; }
  .hero-img-border      { display: none !important; }
  .hero-img-glow        { display: none !important; }
  .about-decor          { display: none !important; }
  .about-decor2         { display: none !important; }
  .about-img-accent     { display: none !important; }
  .hero-mesh, .hero-grid, .hero-particles { overflow: hidden !important; }
  .hero { overflow: hidden !important; max-width: 100vw !important; }
  #navbar { width: 100% !important; left: 0 !important; right: 0 !important; }
  .nav-container { width: 100% !important; padding: 12px 16px !important; }
  .container { padding-left: 16px !important; padding-right: 16px !important; width: 100% !important; }
  .book-pages-effect::before,
  .book-pages-effect::after { display: none !important; }
  .book-new-badge { right: 0 !important; }
  section { width: 100% !important; overflow: hidden !important; }
  .endorsement-wrap { margin-left: 0 !important; margin-right: 0 !important; }
  div[style*="grid-template-columns"] { grid-template-columns: 1fr !important; }
  .ebook-card-wrap { max-width: calc(100vw - 32px) !important; flex-direction: column !important; text-align: center !important; }
  footer { width: 100% !important; overflow-x: hidden !important; }
  .hero-float-badge, .hero-float-badge2 { display: none !important; }
  .scroll-indicator { display: none !important; }
  .book-visual, .book-pages-effect { width: 100% !important; text-align: center !important; }
  .book-cover-img { margin: 0 auto !important; display: block !important; }
}
@media (max-width: 480px) {
  html, body { overflow-x: hidden !important; }
  .container { padding-left: 14px !important; padding-right: 14px !important; }
  .nav-container { padding: 10px 14px !important; }
  section { overflow: hidden !important; }
}
