/*
Theme Name: Pediatric Heart India
Theme URI: https://pedhaertindia.com
Author: Dr. Nikhil K Sunil
Author URI: https://www.linkedin.com/in/tinyheartdoc
Description: A warm, professional personal-brand theme for a pediatric cardiologist. Includes an informative homepage, a native WordPress blog, FAQs and a video section. Built for pedhaertindia.com.
Version: 1.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: pediatric-heart-india
*/

/* ===========================================================================
   1. DESIGN TOKENS
   ======================================================================== */
:root{
  --cream:      #FDF8F2;
  --cream-deep: #F6ECE0;
  --card:       #FFFFFF;
  --coral:      #E0654E;
  --coral-soft: #F2A98F;
  --teal:       #0F4C53;
  --teal-soft:  #2E7C84;
  --gold-warm:  #E5A24A;
  --ink:        #2B3A3C;
  --ink-soft:   #5C6B6C;
  --line:       #E8DECF;
  --shadow:     0 18px 40px -22px rgba(15,76,83,.45);
  --shadow-sm:  0 8px 22px -14px rgba(15,76,83,.40);
  --radius:     22px;
  --radius-sm:  14px;
  --maxw:       1180px;
}

/* ===========================================================================
   2. BASE
   ======================================================================== */
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;scroll-padding-top:96px;}
body{
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  background:var(--cream);
  color:var(--ink);
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;font-weight:600;line-height:1.18;color:var(--teal);}
a{color:inherit;text-decoration:none;}
img{max-width:100%;height:auto;display:block;}
section{padding:96px 0;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 26px;}

/* WordPress admin bar offset */
.admin-bar #header{top:32px;}
@media screen and (max-width:782px){ .admin-bar #header{top:46px;} }

.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:'Inter',sans-serif;font-weight:600;font-size:.78rem;
  letter-spacing:.14em;text-transform:uppercase;color:var(--coral);
  margin-bottom:14px;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--coral);border-radius:2px;}

.section-head{max-width:640px;margin-bottom:52px;}
.section-head h2{font-size:clamp(1.9rem,3.6vw,2.85rem);}
.section-head p{margin-top:14px;color:var(--ink-soft);font-size:1.05rem;}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center;}
.section-head.center .eyebrow::before{display:none;}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:9px;
  font-weight:600;font-size:.96rem;
  padding:14px 26px;border-radius:50px;border:2px solid transparent;
  cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background .2s ease;
}
.btn-primary{background:var(--coral);color:#fff;box-shadow:0 12px 26px -12px rgba(224,101,78,.8);}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 18px 32px -12px rgba(224,101,78,.85);color:#fff;}
.btn-ghost{background:transparent;color:var(--teal);border-color:rgba(15,76,83,.25);}
.btn-ghost:hover{background:var(--teal);color:#fff;border-color:var(--teal);transform:translateY(-3px);}

/* ===========================================================================
   3. NAVIGATION
   ======================================================================== */
#header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  transition:background .3s ease,box-shadow .3s ease,padding .3s ease;
  padding:18px 0;
}
#header.scrolled{background:rgba(253,248,242,.94);backdrop-filter:blur(10px);
  box-shadow:0 6px 24px -18px rgba(15,76,83,.6);padding:10px 0;}
.nav{display:flex;align-items:center;justify-content:space-between;}
.brand{display:flex;align-items:center;gap:11px;font-family:'Fraunces',serif;
  font-weight:600;font-size:1.18rem;color:var(--teal);}
.brand .mark{
  width:40px;height:40px;border-radius:12px;flex-shrink:0;
  background:linear-gradient(135deg,var(--coral),var(--gold-warm));
  display:grid;place-items:center;box-shadow:var(--shadow-sm);overflow:hidden;
}
.brand .mark svg{width:22px;height:22px;}
.brand .mark img{width:100%;height:100%;object-fit:cover;}

/* nav links work both for the theme fallback (plain <a>) and a real WP menu (<ul><li>) */
#navLinks{display:flex;align-items:center;gap:6px;}
#navLinks ul{display:flex;align-items:center;gap:6px;list-style:none;margin:0;padding:0;}
#navLinks li{list-style:none;}
#navLinks a{
  font-weight:500;font-size:.95rem;color:var(--ink);
  padding:9px 15px;border-radius:50px;transition:background .2s,color .2s;
  display:inline-block;
}
#navLinks a:hover,#navLinks a.active,#navLinks .current-menu-item>a{
  background:rgba(224,101,78,.12);color:var(--coral);}
#navLinks .btn,#navLinks .btn-primary{margin-left:8px;padding:11px 22px;color:#fff;}
#navLinks .btn-primary:hover{color:#fff;}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px;}
.nav-toggle span{display:block;width:25px;height:2.4px;background:var(--teal);
  border-radius:2px;margin:5px 0;transition:.3s;}

/* ===========================================================================
   4. HERO
   ======================================================================== */
.hero{position:relative;padding:170px 0 110px;overflow:hidden;}
.hero::before{content:"";position:absolute;width:520px;height:520px;border-radius:50%;
  top:-180px;right:-160px;
  background:radial-gradient(circle,rgba(229,162,74,.34),transparent 68%);}
.hero::after{content:"";position:absolute;width:460px;height:460px;border-radius:50%;
  bottom:-220px;left:-180px;
  background:radial-gradient(circle,rgba(46,124,132,.22),transparent 68%);}
.hero-grid{position:relative;z-index:2;display:grid;
  grid-template-columns:1.05fr .95fr;gap:60px;align-items:center;}
.hero-text h1{font-size:clamp(2.4rem,5vw,3.85rem);letter-spacing:-.5px;}
.hero-text h1 .accent{color:var(--coral);font-style:italic;font-weight:400;}
.hero-text .lede{margin-top:22px;font-size:1.14rem;color:var(--ink-soft);max-width:33ch;}
.hero-cta{margin-top:34px;display:flex;gap:14px;flex-wrap:wrap;}
.hero-trust{margin-top:40px;display:flex;gap:30px;flex-wrap:wrap;}
.hero-trust .stat .num{font-family:'Fraunces',serif;font-size:1.9rem;
  font-weight:600;color:var(--teal);}
.hero-trust .stat .lab{font-size:.84rem;color:var(--ink-soft);}

.hero-photo{position:relative;}
.photo-frame{position:relative;border-radius:30px;overflow:hidden;
  aspect-ratio:4/5;box-shadow:var(--shadow);
  background:linear-gradient(150deg,var(--teal-soft),var(--teal));
  border:7px solid #fff;}
.photo-frame img{width:100%;height:100%;object-fit:cover;object-position:top center;}
.photo-fallback{position:absolute;inset:0;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:10px;color:#fff;text-align:center;padding:24px;}
.photo-fallback svg{width:60px;height:60px;opacity:.85;}
.photo-fallback small{font-size:.8rem;opacity:.8;max-width:22ch;}
.photo-badge{position:absolute;left:-26px;bottom:42px;z-index:3;
  background:var(--card);border-radius:18px;padding:14px 20px;
  box-shadow:var(--shadow);display:flex;align-items:center;gap:12px;}
.photo-badge .ring{width:42px;height:42px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--coral),var(--gold-warm));
  display:grid;place-items:center;}
.photo-badge .ring svg{width:22px;height:22px;}
.photo-badge .t1{font-weight:700;font-size:.95rem;color:var(--teal);}
.photo-badge .t2{font-size:.78rem;color:var(--ink-soft);}

/* ===========================================================================
   5. INFO STRIP
   ======================================================================== */
.strip{background:var(--teal);color:#fff;padding:30px 0;}
.strip-grid{display:flex;justify-content:space-around;gap:24px;flex-wrap:wrap;text-align:center;}
.strip-item{display:flex;align-items:center;gap:12px;}
.strip-item svg{width:30px;height:30px;flex-shrink:0;color:var(--gold-warm);}
.strip-item b{font-family:'Fraunces',serif;font-weight:600;}
.strip-item span{display:block;font-size:.84rem;opacity:.78;}

/* ===========================================================================
   6. ABOUT
   ======================================================================== */
.about{background:var(--cream-deep);}
.about-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:60px;align-items:center;}
.about-visual{position:relative;}
.about-visual .quote-card{background:var(--card);border-radius:var(--radius);
  padding:38px 34px;box-shadow:var(--shadow);border-left:5px solid var(--coral);}
.about-visual .quote-card .qmark{font-family:'Fraunces',serif;font-size:3.4rem;
  color:var(--coral-soft);line-height:.4;}
.about-visual .quote-card p{font-family:'Fraunces',serif;font-size:1.3rem;
  font-style:italic;color:var(--teal);margin:14px 0 18px;}
.about-visual .quote-card .who{font-weight:600;font-size:.9rem;color:var(--ink-soft);}
.about-text h2{font-size:clamp(1.9rem,3.6vw,2.7rem);}
.about-text>p{margin-top:16px;color:var(--ink-soft);}
.creds{margin-top:30px;display:grid;gap:14px;}
.cred{display:flex;gap:14px;align-items:flex-start;
  background:var(--card);border-radius:var(--radius-sm);padding:16px 18px;
  box-shadow:var(--shadow-sm);}
.cred .ic{width:38px;height:38px;border-radius:10px;flex-shrink:0;
  background:rgba(224,101,78,.12);display:grid;place-items:center;color:var(--coral);}
.cred .ic svg{width:20px;height:20px;}
.cred b{display:block;color:var(--teal);font-size:.98rem;}
.cred span{font-size:.88rem;color:var(--ink-soft);}

/* ===========================================================================
   7. AREAS OF FOCUS
   ======================================================================== */
.focus-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.focus-card{background:var(--card);border-radius:var(--radius);padding:32px 28px;
  box-shadow:var(--shadow-sm);border:1px solid rgba(232,222,207,.9);
  transition:transform .25s ease,box-shadow .25s ease;}
.focus-card:hover{transform:translateY(-7px);box-shadow:var(--shadow);}
.focus-card .ic{width:56px;height:56px;border-radius:16px;display:grid;place-items:center;
  margin-bottom:18px;background:linear-gradient(135deg,rgba(224,101,78,.16),rgba(229,162,74,.16));
  color:var(--coral);}
.focus-card .ic svg{width:28px;height:28px;}
.focus-card h3{font-size:1.22rem;margin-bottom:8px;}
.focus-card p{font-size:.95rem;color:var(--ink-soft);}

/* ===========================================================================
   8. BLOG (cards used on homepage + listing)
   ======================================================================== */
.blog{background:var(--cream-deep);}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;}
.post{background:var(--card);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-sm);transition:transform .25s ease,box-shadow .25s ease;
  display:flex;flex-direction:column;}
.post:hover{transform:translateY(-7px);box-shadow:var(--shadow);}
.post .thumb{height:190px;position:relative;display:grid;place-items:center;overflow:hidden;}
.post .thumb svg{width:54px;height:54px;color:#fff;opacity:.92;}
.post .thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.post .thumb.g1{background:linear-gradient(140deg,#E0654E,#E5A24A);}
.post .thumb.g2{background:linear-gradient(140deg,#2E7C84,#0F4C53);}
.post .thumb.g3{background:linear-gradient(140deg,#E5A24A,#E0654E);}
.post .thumb.g4{background:linear-gradient(140deg,#0F4C53,#2E7C84);}
.post .thumb.g5{background:linear-gradient(140deg,#E0654E,#2E7C84);}
.post .thumb.g6{background:linear-gradient(140deg,#E5A24A,#2E7C84);}
.post .body{padding:24px 24px 26px;display:flex;flex-direction:column;flex:1;}
.post .tag{font-size:.74rem;font-weight:600;letter-spacing:.08em;
  text-transform:uppercase;color:var(--coral);}
.post h3{font-size:1.16rem;margin:8px 0 10px;line-height:1.32;}
.post h3 a{color:var(--teal);}
.post h3 a:hover{color:var(--coral);}
.post p{font-size:.92rem;color:var(--ink-soft);flex:1;}
.post .more{margin-top:16px;font-weight:600;font-size:.9rem;color:var(--teal);
  display:inline-flex;align-items:center;gap:7px;}
.post .more svg{width:16px;height:16px;transition:transform .2s;}
.post:hover .more svg{transform:translateX(4px);}
.blog-foot{margin-top:44px;text-align:center;}
.blog-empty{grid-column:1/-1;text-align:center;background:var(--card);
  border-radius:var(--radius);padding:54px 30px;box-shadow:var(--shadow-sm);}
.blog-empty h3{font-size:1.3rem;margin-bottom:8px;}
.blog-empty p{color:var(--ink-soft);}

/* ===========================================================================
   9. VIDEOS
   ======================================================================== */
.video-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;}
.video-card{background:var(--card);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-sm);transition:transform .25s ease,box-shadow .25s ease;}
.video-card:hover{transform:translateY(-7px);box-shadow:var(--shadow);}
.video-embed{position:relative;width:100%;aspect-ratio:16/9;background:#0c2e32;}
.video-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0;}
.video-card .vcap{padding:18px 22px 22px;}
.video-card .vcap h3{font-size:1.05rem;}
.video-card .vcap p{font-size:.86rem;color:var(--ink-soft);margin-top:5px;}

/* ===========================================================================
   10. FAQ
   ======================================================================== */
.faq{background:var(--cream-deep);}
.faq-wrap{max-width:820px;margin:0 auto;}
.faq-item{background:var(--card);border-radius:var(--radius-sm);margin-bottom:14px;
  box-shadow:var(--shadow-sm);overflow:hidden;border:1px solid rgba(232,222,207,.9);}
.faq-q{width:100%;background:none;border:0;cursor:pointer;text-align:left;
  padding:22px 24px;display:flex;justify-content:space-between;align-items:center;
  gap:18px;font-family:'Fraunces',serif;font-size:1.08rem;font-weight:600;color:var(--teal);}
.faq-q .sign{flex-shrink:0;width:30px;height:30px;border-radius:50%;
  background:rgba(224,101,78,.12);color:var(--coral);display:grid;place-items:center;
  font-size:1.3rem;transition:transform .3s ease,background .3s ease;}
.faq-item.open .faq-q .sign{transform:rotate(45deg);background:var(--coral);color:#fff;}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease;}
.faq-a p{padding:0 24px 22px;color:var(--ink-soft);font-size:.96rem;}

/* ===========================================================================
   11. CONTACT
   ======================================================================== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;}
.contact-card{background:var(--teal);color:#fff;border-radius:var(--radius);
  padding:44px 40px;box-shadow:var(--shadow);}
.contact-card h2{color:#fff;font-size:1.9rem;}
.contact-card>p{color:rgba(255,255,255,.8);margin-top:12px;font-size:.98rem;}
.contact-list{margin-top:28px;display:grid;gap:18px;}
.contact-list .row{display:flex;gap:14px;align-items:flex-start;}
.contact-list .row .ic{width:42px;height:42px;border-radius:12px;flex-shrink:0;
  background:rgba(255,255,255,.1);display:grid;place-items:center;color:var(--gold-warm);}
.contact-list .row .ic svg{width:21px;height:21px;}
.contact-list .row b{font-size:.95rem;}
.contact-list .row span,.contact-list .row a{font-size:.88rem;color:rgba(255,255,255,.72);}
.contact-list .row a:hover{color:#fff;}
.socials{margin-top:30px;display:flex;gap:12px;}
.socials a{width:44px;height:44px;border-radius:12px;background:rgba(255,255,255,.1);
  display:grid;place-items:center;transition:background .2s,transform .2s;}
.socials a:hover{background:var(--coral);transform:translateY(-3px);}
.socials a svg{width:20px;height:20px;color:#fff;}
.notice{background:var(--card);border-radius:var(--radius);padding:38px 36px;
  box-shadow:var(--shadow-sm);border:1px solid rgba(232,222,207,.9);}
.notice .flag{display:inline-flex;align-items:center;gap:8px;font-weight:600;
  font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--coral);margin-bottom:14px;}
.notice .flag svg{width:18px;height:18px;}
.notice h3{font-size:1.4rem;margin-bottom:10px;}
.notice p{color:var(--ink-soft);font-size:.96rem;margin-bottom:14px;}
.notice ul{list-style:none;display:grid;gap:10px;}
.notice li{display:flex;gap:10px;font-size:.93rem;color:var(--ink-soft);}
.notice li svg{width:19px;height:19px;flex-shrink:0;color:var(--teal-soft);margin-top:3px;}

/* ===========================================================================
   12. PAGE BANNER (blog listing, single, page, 404)
   ======================================================================== */
.page-banner{position:relative;padding:160px 0 70px;overflow:hidden;
  background:var(--cream-deep);text-align:center;}
.page-banner::before{content:"";position:absolute;width:480px;height:480px;border-radius:50%;
  top:-200px;right:-140px;
  background:radial-gradient(circle,rgba(229,162,74,.30),transparent 68%);}
.page-banner .wrap{position:relative;z-index:2;}
.page-banner h1{font-size:clamp(2rem,4.2vw,3rem);}
.page-banner p{margin-top:12px;color:var(--ink-soft);max-width:60ch;
  margin-left:auto;margin-right:auto;}
.crumb{font-size:.85rem;color:var(--coral);font-weight:600;letter-spacing:.04em;
  margin-bottom:10px;}

/* ===========================================================================
   13. SINGLE POST / PAGE CONTENT
   ======================================================================== */
.content-section{padding:70px 0 96px;}
.article-wrap{max-width:780px;margin:0 auto;}
.article-meta{display:flex;flex-wrap:wrap;gap:8px 18px;align-items:center;
  font-size:.88rem;color:var(--ink-soft);margin-bottom:22px;}
.article-meta .cat{color:var(--coral);font-weight:600;text-transform:uppercase;
  letter-spacing:.07em;font-size:.78rem;}
.article-feat{border-radius:var(--radius);overflow:hidden;margin-bottom:34px;
  box-shadow:var(--shadow-sm);}
.entry-content{font-size:1.05rem;color:var(--ink);}
.entry-content > *{margin-bottom:1.15em;}
.entry-content h2{font-size:1.7rem;margin-top:1.6em;}
.entry-content h3{font-size:1.32rem;margin-top:1.4em;}
.entry-content h4{font-size:1.1rem;margin-top:1.2em;}
.entry-content p{line-height:1.8;}
.entry-content a{color:var(--coral);text-decoration:underline;text-underline-offset:3px;}
.entry-content ul,.entry-content ol{padding-left:1.4em;}
.entry-content li{margin-bottom:.5em;}
.entry-content img{border-radius:var(--radius-sm);}
.entry-content blockquote{border-left:4px solid var(--coral);
  background:var(--cream-deep);padding:18px 24px;border-radius:0 12px 12px 0;
  font-family:'Fraunces',serif;font-style:italic;color:var(--teal);}
.entry-content blockquote p:last-child{margin-bottom:0;}
.entry-content code{background:var(--cream-deep);padding:2px 7px;border-radius:6px;
  font-size:.92em;}
.entry-content pre{background:#0b3a40;color:#fff;padding:18px 20px;border-radius:12px;
  overflow:auto;}
.entry-content figure{margin:1.4em 0;}
.entry-content figcaption,.wp-caption-text{font-size:.85rem;color:var(--ink-soft);
  text-align:center;margin-top:8px;}
.entry-content .wp-block-embed,.entry-content iframe{max-width:100%;}
.entry-content table{width:100%;border-collapse:collapse;}
.entry-content th,.entry-content td{border:1px solid var(--line);padding:10px 12px;text-align:left;}

/* Disclaimer box below posts */
.post-disclaimer{margin-top:40px;background:var(--cream-deep);
  border-radius:var(--radius-sm);padding:22px 26px;font-size:.9rem;
  color:var(--ink-soft);border-left:4px solid var(--gold-warm);}

/* Tags + share */
.article-tags{margin-top:34px;display:flex;flex-wrap:wrap;gap:9px;}
.article-tags a{font-size:.82rem;background:var(--cream-deep);color:var(--teal);
  padding:6px 14px;border-radius:50px;font-weight:500;}
.article-tags a:hover{background:var(--coral);color:#fff;}

/* Post navigation */
.post-nav{max-width:780px;margin:48px auto 0;display:flex;justify-content:space-between;
  gap:18px;flex-wrap:wrap;}
.post-nav a{background:var(--card);border-radius:var(--radius-sm);padding:16px 22px;
  box-shadow:var(--shadow-sm);font-weight:600;color:var(--teal);font-size:.92rem;
  max-width:48%;transition:transform .2s;}
.post-nav a:hover{transform:translateY(-3px);color:var(--coral);}
.post-nav .nav-next{margin-left:auto;text-align:right;}

/* Author card */
.author-card{max-width:780px;margin:46px auto 0;background:var(--card);
  border-radius:var(--radius);padding:30px 32px;box-shadow:var(--shadow-sm);
  display:flex;gap:20px;align-items:center;}
.author-card .ava{width:70px;height:70px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--teal-soft),var(--teal));
  display:grid;place-items:center;color:#fff;overflow:hidden;}
.author-card .ava svg{width:34px;height:34px;}
.author-card .ava img{width:100%;height:100%;object-fit:cover;}
.author-card b{color:var(--teal);font-size:1.05rem;}
.author-card p{font-size:.9rem;color:var(--ink-soft);margin-top:3px;}

/* ===========================================================================
   14. PAGINATION
   ======================================================================== */
.pagination{margin-top:54px;}
.pagination .nav-links{display:flex;justify-content:center;gap:8px;flex-wrap:wrap;}
.pagination .page-numbers{display:grid;place-items:center;min-width:44px;height:44px;
  padding:0 12px;border-radius:12px;background:var(--card);color:var(--teal);
  font-weight:600;font-size:.92rem;box-shadow:var(--shadow-sm);transition:.2s;}
.pagination .page-numbers:hover,.pagination .page-numbers.current{
  background:var(--coral);color:#fff;}
.pagination .dots{box-shadow:none;background:none;}

/* ===========================================================================
   15. FOOTER
   ======================================================================== */
.site-footer{background:#0b3a40;color:rgba(255,255,255,.7);padding:60px 0 26px;}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;margin-bottom:40px;}
.foot-brand .brand{color:#fff;margin-bottom:14px;}
.foot-brand p{font-size:.9rem;max-width:34ch;}
.foot-col h4{color:#fff;font-size:1rem;margin-bottom:14px;}
.foot-col a{display:block;font-size:.9rem;padding:5px 0;transition:color .2s;}
.foot-col a:hover{color:var(--gold-warm);}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:22px;
  display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:.82rem;}
.foot-disclaimer{margin-top:14px;font-size:.78rem;color:rgba(255,255,255,.45);line-height:1.6;}

/* ===========================================================================
   16. SCROLL-REVEAL
   ======================================================================== */
.reveal{opacity:0;transform:translateY(28px);
  transition:opacity .7s ease,transform .7s ease;}
.reveal.visible{opacity:1;transform:none;}

/* ===========================================================================
   17. WORDPRESS HELPERS
   ======================================================================== */
.screen-reader-text{border:0;clip:rect(1px,1px,1px,1px);clip-path:inset(50%);
  height:1px;width:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;word-wrap:normal!important;}
.alignleft{float:left;margin:6px 26px 14px 0;}
.alignright{float:right;margin:6px 0 14px 26px;}
.aligncenter{margin-left:auto;margin-right:auto;display:block;}
.wp-caption{max-width:100%;}
.sticky,.bypostauthor{}
.entry-content .alignwide{margin-left:-60px;margin-right:-60px;max-width:none;width:auto;}
.entry-content .alignfull{margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);
  max-width:100vw;width:100vw;}

/* ===========================================================================
   18. RESPONSIVE
   ======================================================================== */
@media(max-width:960px){
  .hero-grid,.about-grid,.contact-grid{grid-template-columns:1fr;gap:44px;}
  .hero-photo{max-width:420px;margin:0 auto;}
  .about-visual{max-width:520px;}
  .focus-grid,.blog-grid,.video-grid{grid-template-columns:repeat(2,1fr);}
  .foot-grid{grid-template-columns:1fr 1fr;}
  .entry-content .alignwide{margin-left:0;margin-right:0;}
}
@media(max-width:680px){
  section{padding:70px 0;}
  .hero{padding:140px 0 80px;}
  .page-banner{padding:130px 0 56px;}
  #navLinks{
    position:fixed;top:0;right:0;height:100vh;width:78%;max-width:320px;
    background:var(--cream);flex-direction:column;align-items:flex-start;
    justify-content:center;gap:6px;padding:40px;
    transform:translateX(100%);transition:transform .35s ease;
    box-shadow:-20px 0 50px -30px rgba(0,0,0,.5);
  }
  #navLinks.open{transform:translateX(0);}
  #navLinks ul{flex-direction:column;align-items:flex-start;gap:6px;width:100%;}
  #navLinks a{width:100%;font-size:1.05rem;padding:12px 15px;}
  #navLinks .btn,#navLinks .btn-primary{margin-left:0;}
  .nav-toggle{display:block;z-index:120;}
  .nav-toggle.open span:nth-child(1){transform:translateY(7.4px) rotate(45deg);}
  .nav-toggle.open span:nth-child(2){opacity:0;}
  .nav-toggle.open span:nth-child(3){transform:translateY(-7.4px) rotate(-45deg);}
  .focus-grid,.blog-grid,.video-grid,.foot-grid{grid-template-columns:1fr;}
  .photo-badge{left:50%;transform:translateX(-50%);bottom:-26px;}
  .hero-trust{gap:22px;}
  .strip-grid{gap:18px;}
  .contact-card,.notice{padding:32px 26px;}
  .post-nav a{max-width:100%;}
}
