/* ===========================================
   SHRI YOGA - MOBILE-FIRST RESPONSIVE CSS
   Colors: Primary #0274be | Cyan #01aeb7 | Sky #43b4e7
   =========================================== */

/* --- Reset --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Nunito',sans-serif;color:#3a3a3a;background:#fff;line-height:1.7;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{cursor:pointer}

/* --- CSS Variables --- */
:root{
  --primary:#0274be;
  --primary-dark:#01568a;
  --primary-xdark:#01334e;
  --primary-light:#e8f4fd;
  --cyan:#01aeb7;
  --cyan-dark:#018a92;
  --cyan-light:#e0f7f8;
  --sky:#43b4e7;
  --sky-light:#ddf0fa;
  --orange:#f5a623;
  --green:#5baa4a;
  --text:#3a3a3a;
  --text-light:#666;
  --bg-light:#f4f9fd;
  --white:#fff;
  --radius:12px;
  --radius-sm:8px;
  --shadow:0 4px 20px rgba(2,116,190,0.10);
  --shadow-md:0 8px 32px rgba(2,116,190,0.15);
  --nav-h:64px;
}

/* --- Utilities --- */
.container{width:100%;max-width:1140px;margin:0 auto;padding:0 16px}
.section{padding:48px 0}
.bg-light{background:var(--bg-light)}
.bg-gradient{background:linear-gradient(135deg,var(--primary-xdark) 0%,var(--primary) 55%,var(--sky) 100%);color:#fff}
.text-center{text-align:center}
.center-btn{text-align:center;margin-top:32px}
.eyebrow{font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--cyan);margin-bottom:8px;display:block}

/* --- Typography (fluid) --- */
h1{font-family:'Playfair Display',serif;font-size:clamp(28px,7vw,60px);line-height:1.15}
h2{font-family:'Playfair Display',serif;font-size:clamp(22px,5vw,38px);color:var(--primary);line-height:1.25}
h3{font-size:clamp(18px,4vw,24px);font-weight:700}
h4{font-size:clamp(15px,3.5vw,20px);font-weight:700}
p{font-size:clamp(14px,2.5vw,16px)}

/* --- Buttons --- */
.btn{display:inline-flex;align-items:center;justify-content:center;padding:13px 28px;border-radius:50px;font-weight:700;font-size:15px;letter-spacing:0.3px;transition:all .3s;border:none;min-height:48px;white-space:nowrap}
.btn-primary{background:var(--cyan);color:#fff}
.btn-primary:hover{background:var(--cyan-dark);transform:translateY(-2px);box-shadow:0 6px 20px rgba(1,174,183,.35)}
.btn-blue{background:var(--primary);color:#fff}
.btn-blue:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 6px 20px rgba(2,116,190,.35)}
.btn-outline{background:transparent;color:#fff;border:2px solid #fff}
.btn-outline:hover{background:#fff;color:var(--primary)}
.btn-outline-blue{background:transparent;color:var(--primary);border:2px solid var(--primary)}
.btn-outline-blue:hover{background:var(--primary);color:#fff}
.btn-sm{padding:10px 20px;font-size:13px;min-height:40px}
.btn-block{width:100%;display:flex}

/* --- Section Header --- */
.section-header{text-align:center;margin-bottom:36px}
.section-header h2{margin-bottom:12px}
.section-header p{color:var(--text-light);max-width:580px;margin:0 auto;font-size:clamp(14px,2.5vw,17px)}
.section-header.light h2{color:#fff}
.section-header.light p{color:rgba(255,255,255,.85)}

/* =====================
   ANNOUNCEMENT BAR
   ===================== */
.announcement-bar{background:var(--primary);color:#fff;text-align:center;padding:9px 16px;font-size:13px;font-weight:600;line-height:1.4}
.announcement-bar a{color:var(--orange);text-decoration:underline;margin-left:6px}

/* =====================
   NAVBAR - MOBILE FIRST
   ===================== */
.navbar{position:sticky;top:0;z-index:1000;background:#fff;box-shadow:0 2px 12px rgba(2,116,190,.12);border-bottom:3px solid var(--sky)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:var(--nav-h);padding:0 16px;max-width:1140px;margin:0 auto}
.logo img{height:var(--nav-h);width:auto}

/* Hamburger button */
.hamburger{display:flex;flex-direction:column;justify-content:space-between;width:32px;height:22px;background:none;border:none;padding:0;z-index:1100}
.hamburger span{display:block;height:3px;width:100%;background:var(--primary);border-radius:3px;transition:all .3s}
.hamburger.active span:nth-child(1){transform:translateY(9.5px) rotate(45deg)}
.hamburger.active span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.active span:nth-child(3){transform:translateY(-9.5px) rotate(-45deg)}

/* Nav overlay */
.nav-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:998;backdrop-filter:blur(2px)}
.nav-overlay.open{display:block}

/* Nav links - mobile drawer */
.nav-links{position:fixed;top:0;right:-100%;width:min(280px,80vw);height:100vh;background:#fff;z-index:999;flex-direction:column;padding:80px 24px 40px;gap:0;transition:right .3s cubic-bezier(.4,0,.2,1);overflow-y:auto;box-shadow:-4px 0 20px rgba(0,0,0,.12)}
.nav-links.open{right:0}
.nav-close{position:absolute;top:20px;right:20px;background:none;border:none;font-size:24px;color:var(--text);cursor:pointer;padding:4px;line-height:1}
.nav-links li{border-bottom:1px solid #f0f0f0}
.nav-links a{display:block;padding:14px 4px;font-size:16px;font-weight:600;color:#444;transition:color .2s}
.nav-links a:hover,.nav-links a.active{color:var(--primary)}
.nav-donate-li{border-bottom:none!important;margin-top:20px}
.nav-donate-btn{background:var(--cyan)!important;color:#fff!important;border-radius:50px;padding:13px 20px!important;text-align:center;font-weight:700!important;display:block}

body.menu-open{overflow:hidden}

/* Desktop nav */
@media(min-width:900px){
  .hamburger{display:none}
  .nav-overlay{display:none!important}
  .nav-close{display:none}
  .nav-links{position:static;width:auto;height:auto;background:none;flex-direction:row;padding:0;gap:24px;transition:none;overflow:visible;box-shadow:none;align-items:center;display:flex}
  .nav-links li{border:none}
  .nav-links a{padding:6px 0;font-size:14px}
  .nav-donate-li{margin-top:0}
  .nav-donate-btn{padding:8px 18px!important;font-size:14px!important}
}

/* =====================
   HERO
   ===================== */
.hero{position:relative;background:linear-gradient(135deg,var(--primary-xdark) 0%,var(--primary) 50%,var(--sky) 100%);min-height:90vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:#fff;overflow:hidden;padding:60px 16px 80px}
.hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:60px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 60'%3E%3Cpath fill='%23ffffff' d='M0,40L80,36C160,32,320,24,480,28C640,32,800,48,960,48C1120,48,1280,32,1360,24L1440,16L1440,60L0,60Z'/%3E%3C/svg%3E") bottom/cover no-repeat}
.hero-content{position:relative;z-index:1;max-width:720px;width:100%}
.hero-eyebrow{font-size:12px;font-weight:700;letter-spacing:3px;text-transform:uppercase;opacity:.85;margin-bottom:12px;color:var(--orange)}
.hero h1{margin-bottom:16px}
.hero-sub{font-size:clamp(14px,3vw,18px);opacity:.9;margin-bottom:28px}
.hero-buttons{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.hero-stats{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:0;background:rgba(255,255,255,.15);backdrop-filter:blur(10px);border-radius:var(--radius);margin-top:40px;overflow:hidden;border:1px solid rgba(255,255,255,.2);width:100%;max-width:480px}
.stat{padding:16px 12px;text-align:center;border-right:1px solid rgba(255,255,255,.2);border-bottom:1px solid rgba(255,255,255,.2);display:flex;flex-direction:column;gap:2px}
.stat:nth-child(2n){border-right:none}
.stat:nth-child(3),.stat:nth-child(4){border-bottom:none}
.stat-num{font-size:clamp(24px,6vw,34px);font-weight:800;font-family:'Playfair Display',serif;color:var(--orange)}
.stat-label{font-size:11px;opacity:.9;font-weight:600;letter-spacing:.5px}
@media(min-width:768px){
  .hero{min-height:88vh}
  .hero-stats{grid-template-columns:repeat(4,1fr);max-width:800px}
  .stat{border-right:1px solid rgba(255,255,255,.2);border-bottom:none}
  .stat:last-child{border-right:none}
  .stat-label{font-size:13px}
}

/* =====================
   CARDS GRID
   ===================== */
.card-grid{display:grid;grid-template-columns:1fr;gap:20px}
@media(min-width:500px){.card-grid{grid-template-columns:1fr 1fr}}
@media(min-width:900px){.card-grid{grid-template-columns:repeat(3,1fr)}}
.card{background:#fff;border-radius:var(--radius);padding:24px 20px;box-shadow:var(--shadow);transition:transform .3s,box-shadow .3s;border-top:4px solid var(--cyan)}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md)}
.card-icon{font-size:32px;margin-bottom:12px}
.card h3{font-size:18px;font-weight:700;margin-bottom:8px;color:var(--primary)}
.card p{font-size:14px;color:var(--text-light);margin-bottom:14px}
.card-link{color:var(--cyan);font-weight:700;font-size:13px}

/* =====================
   EVENTS LIST
   ===================== */
.events-list{display:flex;flex-direction:column;gap:16px}
.event-card{background:#fff;border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);display:flex;gap:16px;align-items:flex-start;border-left:4px solid var(--primary)}
.event-date{min-width:58px;text-align:center;background:var(--primary);color:#fff;border-radius:10px;padding:10px 8px;display:flex;flex-direction:column;flex-shrink:0}
.event-month{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase}
.event-day{font-size:28px;font-weight:800;line-height:1}
.event-info{flex:1;min-width:0}
.event-info h4{font-size:15px;font-weight:700;margin-bottom:4px;color:var(--primary)}
.event-info p{font-size:13px;color:var(--text-light);margin-bottom:8px;line-height:1.5}
.event-tag{display:inline-block;background:var(--sky-light);color:var(--primary);font-size:11px;font-weight:700;padding:3px 10px;border-radius:50px}
.event-card .btn-sm{flex-shrink:0;align-self:center}
@media(min-width:640px){
  .event-date{min-width:68px;padding:12px}
  .event-day{font-size:32px}
  .event-info h4{font-size:17px}
}

/* =====================
   ABOUT SPLIT
   ===================== */
.about-split{display:grid;grid-template-columns:1fr;gap:40px;align-items:center}
@media(min-width:768px){.about-split{grid-template-columns:1fr 1fr;gap:56px}}
.about-image{position:relative}
.about-image-placeholder{width:100%;min-height:280px;background:linear-gradient(135deg,var(--primary-light),var(--sky-light));border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:80px}
@media(min-width:768px){.about-image-placeholder{min-height:380px;font-size:100px}}
.about-badge{background:var(--primary);color:#fff;text-align:center;padding:12px 16px;border-radius:0 0 var(--radius) var(--radius);font-weight:700;font-size:13px;width:100%}
.about-text h2{margin-bottom:14px}
.about-text p{color:var(--text-light);margin-bottom:14px}
.about-highlights{margin:16px 0 24px;display:flex;flex-direction:column;gap:8px}
.about-highlights li{font-size:14px;font-weight:600}

/* =====================
   TESTIMONIALS
   ===================== */
.testimonial-grid{display:grid;grid-template-columns:1fr;gap:20px}
@media(min-width:768px){.testimonial-grid{grid-template-columns:repeat(3,1fr)}}
.testimonial-card{background:rgba(255,255,255,.15);border-radius:var(--radius);padding:24px;border:1px solid rgba(255,255,255,.25)}
.testimonial-card p{font-size:15px;font-style:italic;opacity:.95;margin-bottom:14px;line-height:1.6}
.testimonial-author{font-weight:700;font-size:13px;opacity:.85;color:var(--orange)}

/* =====================
   DONATE
   ===================== */
.donate-inner{display:grid;grid-template-columns:1fr;gap:40px}
@media(min-width:768px){.donate-inner{grid-template-columns:1.3fr 0.7fr;gap:56px;align-items:start}}
.donate-text h2{margin:12px 0}
.donate-text p{color:var(--text-light);margin-bottom:24px}
.donate-methods{display:flex;flex-direction:column;gap:14px}
.donate-method{background:var(--primary-light);border-radius:var(--radius-sm);border-left:4px solid var(--primary);padding:14px 16px;font-size:14px;line-height:1.6}
.donate-card{background:linear-gradient(135deg,var(--primary-dark),var(--primary));color:#fff;border-radius:var(--radius);padding:32px 24px;text-align:center;border:3px solid var(--sky)}
@media(min-width:768px){.donate-card{position:sticky;top:calc(var(--nav-h) + 20px)}}
.donate-card h3{margin-bottom:12px}
.donate-card p{opacity:.9;margin-bottom:20px;line-height:1.6;font-size:14px}
.donate-note{font-size:12px;opacity:.75;margin-top:12px;color:var(--orange)}

/* =====================
   NEWSLETTER
   ===================== */
.newsletter-inner{display:flex;flex-direction:column;gap:20px}
@media(min-width:768px){.newsletter-inner{flex-direction:row;align-items:center;justify-content:space-between;gap:40px}}
.newsletter-inner h3{margin-bottom:6px;color:var(--primary)}
.newsletter-inner p{color:var(--text-light);font-size:14px}
.newsletter-form{display:flex;flex-direction:column;gap:10px;width:100%}
@media(min-width:768px){.newsletter-form{flex-direction:row;min-width:380px;width:auto}}
.newsletter-form input{flex:1;padding:12px 18px;border:2px solid #cde5f7;border-radius:50px;font-size:15px;font-family:inherit;outline:none;transition:border .2s;width:100%}
.newsletter-form input:focus{border-color:var(--primary)}
.newsletter-form .btn{width:100%}
@media(min-width:768px){.newsletter-form .btn{width:auto}}

/* =====================
   FOOTER
   ===================== */
.footer{background:var(--primary-xdark);color:#ccc;padding:48px 0 0}
.footer-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px 20px;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.1)}
@media(min-width:768px){.footer-grid{grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:40px}}
.footer-brand img{height:104px;width:auto;margin-bottom:12px}
.footer-brand p{font-size:13px;line-height:1.8;opacity:.7}
.footer-links h4,.footer-contact h4{font-size:14px;font-weight:700;color:#fff;margin-bottom:12px}
.footer-links ul{display:flex;flex-direction:column;gap:7px}
.footer-links a{font-size:13px;color:#aaa;transition:color .2s}
.footer-links a:hover{color:var(--sky)}
.footer-contact p{font-size:13px;margin-bottom:7px;color:#aaa}
.footer-contact a{color:var(--sky)}
.footer-bottom{padding:18px 16px;text-align:center;font-size:12px;color:#666}

/* =====================
   PAGE HERO
   ===================== */
#classes,#teachers,#events,#photos,#videos,#about,#contact{scroll-margin-top:var(--nav-h)}
.page-hero{background:linear-gradient(135deg,var(--primary-xdark) 0%,var(--primary) 60%,var(--sky) 100%);color:#fff;text-align:center;padding:60px 16px 80px;position:relative;overflow:hidden}
.page-hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:40px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 40'%3E%3Cpath fill='%23ffffff' d='M0,24L80,21C160,18,320,12,480,16C640,20,800,32,960,32C1120,32,1280,20,1360,14L1440,8L1440,40L0,40Z'/%3E%3C/svg%3E") bottom/cover no-repeat}
.page-hero h1{margin-bottom:10px}
.page-hero p{opacity:.88;max-width:560px;margin:0 auto;font-size:clamp(14px,3vw,18px)}

/* =====================
   INFO BANNER
   ===================== */
.info-banner{background:var(--primary-light);border-left:5px solid var(--primary);border-radius:var(--radius-sm);padding:16px 20px;margin-bottom:28px;font-size:14px;line-height:1.6}

/* =====================
   CLASS TYPES GRID
   ===================== */
.class-types{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:28px}
@media(min-width:640px){.class-types{grid-template-columns:repeat(4,1fr)}}
.class-type{background:#fff;border-radius:var(--radius-sm);padding:16px 12px;text-align:center;box-shadow:var(--shadow);border-bottom:3px solid var(--cyan)}
.class-type-icon{font-size:24px;margin-bottom:6px}
.class-type h4{font-size:13px;font-weight:700;margin-bottom:4px;color:var(--primary)}
.class-type p{font-size:12px;color:var(--text-light)}

/* =====================
   SCHEDULE TABLE
   ===================== */
.schedule-overflow{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius);border:1px solid #dceef8}
.schedule-overflow::-webkit-scrollbar{height:6px}
.schedule-overflow::-webkit-scrollbar-thumb{background:var(--sky);border-radius:3px}
.schedule-table{width:100%;border-collapse:collapse;font-size:12px;min-width:700px}
.schedule-table th{background:var(--primary);color:#fff;padding:10px 8px;text-align:center;white-space:nowrap;font-size:12px}
.schedule-table td{padding:7px 6px;text-align:center;border:1px solid #dceef8;vertical-align:top}
.schedule-table tr:nth-child(even) td{background:var(--bg-light)}
.class-pill{display:inline-block;background:var(--sky-light);color:var(--primary-dark);font-size:10px;font-weight:700;padding:2px 7px;border-radius:50px;margin:2px;white-space:nowrap;line-height:1.4}
.class-pill.cancelled{background:#ffebee;color:#c62828;text-decoration:line-through}

/* =====================
   TEACHERS GRID
   ===================== */
.teachers-grid{display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:500px){.teachers-grid{grid-template-columns:1fr 1fr}}
@media(min-width:900px){.teachers-grid{grid-template-columns:repeat(3,1fr)}}
.teacher-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;transition:transform .3s,box-shadow .3s;border-top:4px solid var(--primary)}
.teacher-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md)}
.teacher-photo{width:100%;height:200px;background:linear-gradient(135deg,var(--primary-light),var(--sky-light));display:flex;align-items:center;justify-content:center;font-size:60px}
.teacher-info{padding:20px}
.teacher-info h3{font-size:18px;font-weight:700;margin-bottom:4px;color:var(--primary)}
.teacher-specialty{color:var(--cyan);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:10px}
.teacher-info p{font-size:13px;color:var(--text-light);line-height:1.6}
.teacher-cert{display:inline-block;background:var(--primary-light);color:var(--primary);font-size:11px;font-weight:700;padding:3px 10px;border-radius:50px;margin-top:10px}

/* =====================
   EVENTS FULL
   ===================== */
.events-full{display:flex;flex-direction:column;gap:20px}
.event-full-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;border-left:5px solid var(--primary)}
.event-full-layout{display:flex;gap:16px;align-items:flex-start;margin-bottom:14px}
.event-full-date{text-align:center;flex-shrink:0;width:60px}
.event-full-date .month{font-size:10px;font-weight:700;letter-spacing:2px;color:var(--cyan);text-transform:uppercase}
.event-full-date .day{font-size:36px;font-weight:800;line-height:1;color:var(--primary);font-family:'Playfair Display',serif}
.event-full-date .year{font-size:12px;color:#999}
.event-full-info h3{font-size:clamp(15px,3vw,20px);font-weight:700;margin-bottom:6px;color:var(--primary)}
.event-full-info p{font-size:13px;color:#666;line-height:1.5;margin-bottom:10px}
.event-meta{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.meta-tag{font-size:11px;font-weight:600;padding:4px 10px;border-radius:50px}
.tag-location{background:var(--sky-light);color:var(--primary)}
.tag-type{background:#fff8e1;color:#b45309}
.tag-free{background:#e8f5e9;color:#2e7d32}
.past-badge{background:#eee;color:#888;font-size:11px;font-weight:700;padding:4px 10px;border-radius:50px}

/* =====================
   MISSION GRID
   ===================== */
.mission-grid{display:grid;grid-template-columns:1fr;gap:20px;margin-top:36px}
@media(min-width:640px){.mission-grid{grid-template-columns:repeat(3,1fr)}}
.mission-card{text-align:center;padding:28px 20px;border-radius:var(--radius);background:#fff;box-shadow:var(--shadow);border-top:4px solid var(--primary)}
.mission-icon{font-size:36px;margin-bottom:12px}
.mission-card h3{font-size:18px;font-weight:700;margin-bottom:8px;color:var(--primary)}
.mission-card p{font-size:13px;color:var(--text-light)}

/* =====================
   TIMELINE
   ===================== */
.timeline{position:relative;padding-left:28px}
.timeline::before{content:'';position:absolute;left:7px;top:0;bottom:0;width:3px;background:var(--sky-light)}
.timeline-item{position:relative;padding-bottom:32px}
.timeline-dot{position:absolute;left:-24px;top:4px;width:16px;height:16px;background:var(--primary);border-radius:50%;border:3px solid #fff;box-shadow:0 0 0 3px var(--sky)}
.timeline-year{font-size:11px;font-weight:700;color:var(--cyan);letter-spacing:1px;text-transform:uppercase;margin-bottom:4px}
.timeline-item h4{font-size:16px;font-weight:700;margin-bottom:4px;color:var(--primary)}
.timeline-item p{font-size:14px;color:var(--text-light)}

/* =====================
   CONTACT
   ===================== */
.contact-grid{display:grid;grid-template-columns:1fr;gap:32px}
@media(min-width:768px){.contact-grid{grid-template-columns:1fr 1fr;gap:48px}}
.contact-form-wrap{background:#fff;border-radius:var(--radius);padding:28px 24px;box-shadow:var(--shadow)}
@media(min-width:768px){.contact-form-wrap{padding:36px}}
.form-group{margin-bottom:18px}
.form-group label{display:block;font-weight:700;font-size:13px;margin-bottom:6px;color:#444}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 14px;border:2px solid #cde5f7;border-radius:var(--radius-sm);font-size:15px;font-family:inherit;outline:none;transition:border .2s;-webkit-appearance:none;appearance:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary)}
.form-group textarea{min-height:120px;resize:vertical}
.contact-info-cards{display:flex;flex-direction:column;gap:14px}
.contact-info-card{background:#fff;border-radius:var(--radius-sm);padding:18px;box-shadow:var(--shadow);display:flex;gap:14px;align-items:flex-start;border-left:4px solid var(--primary)}
.contact-info-icon{font-size:22px;flex-shrink:0}
.contact-info-card h4{font-size:14px;font-weight:700;margin-bottom:4px;color:var(--primary)}
.contact-info-card p{font-size:13px;color:var(--text-light);line-height:1.6}
.contact-info-card a{color:var(--primary);font-weight:600}

/* =====================
   PHOTOS & VIDEOS
   ===================== */
.photo-gallery{columns:2;gap:12px}
@media(min-width:640px){.photo-gallery{columns:3}}
.photo-item{break-inside:avoid;margin-bottom:12px;border-radius:var(--radius-sm);overflow:hidden;transition:transform .3s}
.photo-item:hover{transform:scale(1.02)}
.photo-placeholder{width:100%;background:linear-gradient(135deg,var(--primary-light),var(--sky-light));display:flex;align-items:center;justify-content:center;font-size:36px;border-radius:var(--radius-sm)}
.photo-filters{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-bottom:28px}
.filter-btn{padding:8px 16px;border-radius:50px;border:2px solid var(--primary);color:var(--primary);font-weight:700;font-size:12px;background:#fff;transition:all .2s;min-height:36px}
.filter-btn.active,.filter-btn:hover{background:var(--primary);color:#fff}

.video-grid{display:grid;grid-template-columns:1fr;gap:20px}
@media(min-width:500px){.video-grid{grid-template-columns:1fr 1fr}}
@media(min-width:900px){.video-grid{grid-template-columns:repeat(3,1fr)}}
.video-card{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);background:#fff;transition:transform .3s;border-top:4px solid var(--cyan)}
.video-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.video-thumb{position:relative;padding-bottom:56.25%;background:linear-gradient(135deg,var(--primary-dark),var(--primary))}
.video-play-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:column;color:#fff;gap:8px}
.play-btn{width:52px;height:52px;background:rgba(255,255,255,.2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;border:3px solid rgba(255,255,255,.6)}
.video-info{padding:16px}
.video-info h4{font-size:15px;font-weight:700;margin-bottom:5px;color:var(--primary)}
.video-info p{font-size:13px;color:var(--text-light)}
.video-tag{display:inline-block;background:var(--primary-light);color:var(--primary);font-size:11px;font-weight:700;padding:3px 10px;border-radius:50px;margin-top:8px}

/* =====================
   CTA BOX
   ===================== */
.cta-box{background:linear-gradient(135deg,var(--primary-dark),var(--primary));border-radius:var(--radius);padding:36px 24px;text-align:center;color:#fff;margin-top:48px}
.cta-box h3{margin-bottom:10px}
.cta-box p{opacity:.9;margin-bottom:20px;font-size:14px;max-width:500px;margin-left:auto;margin-right:auto}

/* =====================
   HELPER BOXES
   ===================== */
.highlight-box{background:var(--primary-light);border-left:5px solid var(--primary);border-radius:var(--radius-sm);padding:20px 24px;border-radius:var(--radius)}
.highlight-box h3{color:var(--primary);margin-bottom:6px}
.highlight-box p{color:#555;font-size:14px}

/* =====================
   ACCESSIBILITY
   ===================== */
:focus-visible{outline:3px solid var(--orange);outline-offset:2px;border-radius:4px}
@media(prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}
