/* ===========================================================
   FOTS INTERNATIONAL SCHOOL — Core Stylesheet
   =========================================================== */
:root{
  --bg:#F5F6F8;
  --text:#3B4656;
  --nav:#3B4656;
  --footer:#3B4656;
  --primary:#21B2C6;
  --primary-hover:#4CC9E4;
  --card:#FFFFFF;
  --border:#E5E7EB;
  --muted:#6B7280;
  --white:#FFFFFF;
  --shadow-sm:0 1px 3px rgba(59,70,86,.08);
  --shadow:0 10px 30px -12px rgba(59,70,86,.18);
  --shadow-lg:0 24px 60px -20px rgba(59,70,86,.28);
  --radius:16px;
  --radius-sm:10px;
  --container:1200px;
  --space:clamp(4rem,8vw,7rem);
  --ff-head:'Poppins',system-ui,sans-serif;
  --ff-body:'Inter',system-ui,sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--ff-body);
  background:var(--bg);
  color:var(--text);
  line-height:1.65;
  padding-top:78px;
  font-size:16px;
  overflow-x:hidden;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
ul{list-style:none}
h1,h2,h3,h4,h5{font-family:var(--ff-head);font-weight:700;line-height:1.15;color:var(--text);letter-spacing:-.01em}
h1{font-size:clamp(2.2rem,5.5vw,4rem);font-weight:800}
h2{font-size:clamp(1.7rem,3.6vw,2.6rem)}
h3{font-size:clamp(1.2rem,2vw,1.5rem)}
p{color:var(--muted)}
section{position:relative}

/* Layout helpers */
.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 24px}
.section{padding:var(--space) 0}
.text-center{text-align:center}
.lead{font-size:1.125rem;color:var(--muted);max-width:60ch}
.eyebrow{
  display:inline-block;font-family:var(--ff-head);font-weight:700;
  font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--primary);margin-bottom:14px;
}
.section-head{max-width:720px;margin:0 auto 56px;text-align:center}
.section-head p{margin-top:14px}
.grid{display:grid;gap:28px}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--ff-head);font-weight:600;font-size:.95rem;
  padding:14px 30px;border-radius:50px;cursor:pointer;border:2px solid transparent;
  transition:.28s ease;white-space:nowrap;min-height:44px;
}
.btn svg{width:18px;height:18px;flex-shrink:0;}
.btn-primary{background:var(--primary);color:#fff;box-shadow:0 8px 22px -8px rgba(33,178,198,.6)}
.btn-primary:hover{background:var(--primary-hover);transform:translateY(-2px);box-shadow:0 14px 30px -10px rgba(76,201,228,.7)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.7)}
.btn-ghost:hover{background:#fff;color:var(--text);transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--text);border-color:var(--border)}
.btn-outline:hover{border-color:var(--primary);color:var(--primary)}
.btn-lg{padding:17px 38px;font-size:1rem;min-height:50px}

.btn svg,
.footer-contact svg,
.socials a svg,
.split .check svg,
.faq .ic svg{width:20px;height:20px;}

.info-tile .icon svg{width:24px;height:24px;}

/* ===================== NAVIGATION ===================== */
.nav{
  position:fixed;top:0;left:0;width:100%;z-index:1000;
  background:rgba(59,70,86,.97);backdrop-filter:blur(10px);
  transition:.3s ease;
}
.nav.scrolled{box-shadow:0 6px 24px -10px rgba(0,0,0,.4)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:78px}
.nav-logo{display:flex;align-items:center;gap:12px;margin-right:12px;z-index:1100}
.nav-logo img{height:50px;width:auto;background:#fff;border-radius:10px;padding:4px}
.nav-logo span{font-family:var(--ff-head);font-weight:700;color:#fff;font-size:1.05rem;line-height:1.1}
.nav-logo small{display:block;font-weight:400;font-size:.68rem;color:rgba(255,255,255,.6);letter-spacing:.12em;text-transform:uppercase}
.nav-links{display:flex;align-items:center;gap:4px}
.nav-links a{
  color:rgba(255,255,255,.82);font-family:var(--ff-head);font-weight:500;
  font-size:.9rem;padding:9px 13px;border-radius:8px;transition:.2s;
}
.nav-links a:hover,.nav-links a.active{color:#fff;background:rgba(255,255,255,.1)}
.nav-cta{margin-left:14px}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;width:42px;height:42px;flex-direction:column;justify-content:center;gap:6px}
.nav-toggle span{display:block;height:2.5px;width:26px;background:#fff;border-radius:2px;transition:.3s}
.nav-toggle.open span:nth-child(1){transform:translateY(8.5px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-8.5px) rotate(-45deg)}

/* ===================== HERO ===================== */
.hero{
  position:relative;min-height:100vh;display:flex;align-items:center;
  color:#fff;overflow:hidden;
}
.hero-media{position:absolute;inset:0;z-index:-2}
.hero-media img,.hero-media video{width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;z-index:-1;
  background:linear-gradient(120deg,rgba(59,70,86,.93) 0%,rgba(59,70,86,.7) 45%,rgba(33,178,198,.45) 100%);}
.hero-content{max-width:760px;padding:120px 0 60px}
.hero .eyebrow{color:#7fe7f5}
.hero h1{color:#fff;margin-bottom:22px}
.hero p{color:rgba(255,255,255,.9);font-size:1.2rem;max-width:54ch;margin-bottom:34px}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap}
.hero-scroll{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.7);font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:8px}
.hero-scroll::after{content:"";width:1px;height:34px;background:rgba(255,255,255,.5);animation:scrollline 1.8s ease-in-out infinite}
@keyframes scrollline{0%,100%{opacity:.3;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}

/* Page hero (interior pages) */
.page-hero{
  position:relative;padding:160px 0 80px;color:#fff;text-align:center;overflow:hidden;
}
.page-hero::before{content:"";position:absolute;inset:0;
  background:linear-gradient(120deg,rgba(59,70,86,.95),rgba(33,178,198,.55));z-index:-1}
.page-hero-bg{position:absolute;inset:0;z-index:-2}
.page-hero-bg img{width:100%;height:100%;object-fit:cover}
.page-hero h1{color:#fff}
.page-hero p{color:rgba(255,255,255,.9);max-width:60ch;margin:16px auto 0;font-size:1.1rem}
.breadcrumb{margin-top:18px;font-size:.85rem;color:rgba(255,255,255,.75)}
.breadcrumb a:hover{color:#fff}

/* ===================== STATS ===================== */
.stats{background:var(--nav);color:#fff}
.stats .grid{gap:20px}
.stat{text-align:center;padding:20px}
.stat-num{font-family:var(--ff-head);font-weight:800;font-size:clamp(2.4rem,5vw,3.4rem);color:#7fe7f5;line-height:1}
.stat-label{margin-top:10px;color:rgba(255,255,255,.8);font-size:.95rem;font-family:var(--ff-head);font-weight:500}

/* ===================== CARDS ===================== */
.card{
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  padding:34px;box-shadow:var(--shadow-sm);transition:.3s ease;height:100%;
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.card .icon{
  width:58px;height:58px;border-radius:14px;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--primary),var(--primary-hover));
  color:#fff;margin-bottom:20px;
}
.card .icon svg{width:28px;height:28px}
.card h3{margin-bottom:10px}
.card p{font-size:.95rem}

/* Programme cards w/ image */
.prog-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:.3s;height:100%}
.prog-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.prog-card .ph{height:200px;overflow:hidden}
.prog-card .ph img{width:100%;height:100%;object-fit:cover;transition:.5s}
.prog-card:hover .ph img{transform:scale(1.07)}
.prog-card .pb{padding:26px}
.prog-card .tag{display:inline-block;font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--primary);margin-bottom:8px}

/* Split media section */
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.split-media img{border-radius:var(--radius);box-shadow:var(--shadow)}
.split h2{margin-bottom:18px}
.split .check{margin-top:22px;display:grid;gap:12px}
.split .check li{display:flex;gap:12px;align-items:flex-start;color:var(--text);font-size:.98rem}
.split .check li svg{flex-shrink:0;color:var(--primary);margin-top:3px;width:18px;height:18px}

/* Principal message */
.principal{display:grid;grid-template-columns:.85fr 1.15fr;gap:56px;align-items:center}
.principal-img{position:relative}
.principal-img img{border-radius:var(--radius);box-shadow:var(--shadow-lg)}
.principal-img .badge{position:absolute;bottom:-18px;left:-18px;background:var(--primary);color:#fff;padding:16px 22px;border-radius:14px;font-family:var(--ff-head);font-weight:600;box-shadow:var(--shadow)}
.quote{font-family:var(--ff-head);font-weight:600;font-size:clamp(1.3rem,2.2vw,1.7rem);line-height:1.4;color:var(--text);margin:18px 0 22px}
.signature{font-family:var(--ff-head);font-weight:700;color:var(--primary);margin-top:8px}

/* Pearson section */
.pearson{background:linear-gradient(135deg,var(--nav),#2c3543);color:#fff;border-radius:24px;padding:clamp(40px,6vw,72px);overflow:hidden;position:relative}
.pearson .eyebrow{color:#7fe7f5}
.pearson h2{color:#fff}
.pearson p{color:rgba(255,255,255,.82)}
.pearson .inner{display:grid;grid-template-columns:1fr 320px;gap:50px;align-items:center}
.pearson-badge{display:grid;place-items:center}
.pearson-badge img{max-width:260px;filter:drop-shadow(0 20px 40px rgba(0,0,0,.35))}
.pearson-list{margin-top:24px;display:grid;gap:14px}
.pearson-list li{display:flex;gap:12px;align-items:flex-start;color:rgba(255,255,255,.9)}
.pearson-list svg{color:#7fe7f5;flex-shrink:0;margin-top:3px;width:18px;height:18px}

/* ===================== GALLERY ===================== */
.gallery-filters{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:40px}
.filter-btn{
  font-family:var(--ff-head);font-weight:500;font-size:.88rem;padding:9px 20px;
  border-radius:50px;border:1px solid var(--border);background:#fff;color:var(--text);cursor:pointer;transition:.25s;
}
.filter-btn:hover{border-color:var(--primary);color:var(--primary)}
.filter-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.masonry{columns:3;column-gap:18px}
.masonry .g-item{break-inside:avoid;margin-bottom:18px;border-radius:14px;overflow:hidden;cursor:pointer;position:relative;box-shadow:var(--shadow-sm)}
.masonry .g-item img{width:100%;transition:.5s;display:block}
.masonry .g-item:hover img{transform:scale(1.06)}
.masonry .g-item::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(59,70,86,.5),transparent 50%);opacity:0;transition:.3s}
.masonry .g-item:hover::after{opacity:1}
.g-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.g-grid .g-item{border-radius:14px;overflow:hidden;aspect-ratio:4/3;cursor:pointer;position:relative;box-shadow:var(--shadow-sm)}
.g-grid .g-item img{width:100%;height:100%;object-fit:cover;transition:.5s}
.g-grid .g-item:hover img{transform:scale(1.07)}

/* Lightbox */
.lightbox{position:fixed;inset:0;background:rgba(33,40,50,.95);display:none;align-items:center;justify-content:center;z-index:2000;padding:30px}
.lightbox.open{display:flex}
.lightbox img{max-width:92%;max-height:88vh;border-radius:10px;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.lightbox-close{position:absolute;top:24px;right:30px;background:none;border:none;color:#fff;font-size:2.4rem;cursor:pointer;line-height:1}

/* ===================== TESTIMONIALS ===================== */
.testi-track{display:flex;transition:transform .5s ease}
.testi-wrap{overflow:hidden}
.testi{flex:0 0 100%;padding:0 8px}
.testi-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:clamp(30px,4vw,56px);text-align:center;box-shadow:var(--shadow-sm);max-width:760px;margin:0 auto}
.testi-card .stars{color:#f5b73d;margin-bottom:18px;font-size:1.1rem}
.testi-card .stars svg{width:18px;height:18px}
.testi-card blockquote{font-family:var(--ff-head);font-weight:500;font-size:clamp(1.1rem,2vw,1.4rem);line-height:1.5;color:var(--text);margin-bottom:22px}
.testi-author{font-family:var(--ff-head);font-weight:700;color:var(--text)}
.testi-role{color:var(--primary);font-size:.88rem}
.testi-nav{display:flex;justify-content:center;gap:10px;margin-top:30px}
.testi-dot{width:10px;height:10px;border-radius:50%;background:var(--border);border:none;cursor:pointer;transition:.25s}
.testi-dot.active{background:var(--primary);width:28px;border-radius:6px}

/* ===================== NEWS ===================== */
.news-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:.3s;height:100%}
.news-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.news-card .ph{height:200px;overflow:hidden}
.news-card .ph img{width:100%;height:100%;object-fit:cover;transition:.5s}
.news-card:hover .ph img{transform:scale(1.07)}
.news-card .nb{padding:24px}
.news-meta{display:flex;gap:14px;font-size:.78rem;color:var(--muted);margin-bottom:10px;font-family:var(--ff-head);font-weight:500}
.news-cat{color:var(--primary);text-transform:uppercase;letter-spacing:.08em}
.news-card h3{font-size:1.15rem;margin-bottom:8px}
.read-more{color:var(--primary);font-family:var(--ff-head);font-weight:600;font-size:.9rem;display:inline-flex;gap:6px;margin-top:6px}

/* ===================== CTA BANNER ===================== */
.cta-banner{background:linear-gradient(135deg,var(--primary),var(--primary-hover));color:#fff;text-align:center;border-radius:24px;padding:clamp(48px,7vw,80px)}
.cta-banner h2{color:#fff}
.cta-banner p{color:rgba(255,255,255,.92);max-width:54ch;margin:14px auto 30px;font-size:1.1rem}
.cta-banner .btn-primary{background:#fff;color:var(--primary)}
.cta-banner .btn-primary:hover{background:var(--nav);color:#fff}
.cta-banner .btn-ghost{border-color:#fff}

/* ===================== FORMS ===================== */
.form-grid{display:grid;gap:18px;grid-template-columns:1fr 1fr}
.form-field{display:flex;flex-direction:column;gap:7px}
.form-field.full{grid-column:1/-1}
.form-field label{font-family:var(--ff-head);font-weight:500;font-size:.88rem;color:var(--text)}
.form-field input,.form-field select,.form-field textarea{
  font-family:var(--ff-body);font-size:.95rem;padding:13px 16px;border:1px solid var(--border);
  border-radius:var(--radius-sm);background:#fff;color:var(--text);transition:.2s;width:100%;
}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(33,178,198,.15)}
.form-field textarea{resize:vertical;min-height:130px}
.form-field .err{color:#dc2626;font-size:.78rem;display:none}
.form-field.invalid input,.form-field.invalid select,.form-field.invalid textarea{border-color:#dc2626}
.form-field.invalid .err{display:block}
.form-note{font-size:.85rem;color:var(--muted)}
.form-success{display:none;background:#ecfdf5;border:1px solid #a7f3d0;color:#047857;padding:16px 20px;border-radius:var(--radius-sm);font-family:var(--ff-head);font-weight:500;margin-bottom:20px}
.form-success.show{display:block}
.form-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:clamp(28px,4vw,44px);box-shadow:var(--shadow-sm)}

/* Multi-step admissions */
.steps-bar{display:flex;gap:10px;margin-bottom:34px;flex-wrap:wrap}
.step-pill{flex:1;min-width:120px;text-align:center;padding:14px;border-radius:var(--radius-sm);border:1px solid var(--border);background:#fff;font-family:var(--ff-head);font-weight:500;font-size:.85rem;color:var(--muted);position:relative}
.step-pill .n{display:inline-grid;place-items:center;width:24px;height:24px;border-radius:50%;background:var(--border);color:var(--text);font-size:.8rem;margin-right:8px;transition:.3s}
.step-pill.active{border-color:var(--primary);color:var(--text)}
.step-pill.active .n{background:var(--primary);color:#fff}
.step-pill.done .n{background:#10b981;color:#fff}
.step-panel{display:none;animation:fadeUp .4s ease}
.step-panel.active{display:block}
.step-actions{display:flex;justify-content:space-between;margin-top:26px;gap:12px}

/* FAQ accordion */
.faq{max-width:820px;margin:0 auto}
.faq-item{background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:14px;overflow:hidden}
.faq-q{width:100%;text-align:left;background:none;border:none;cursor:pointer;padding:20px 24px;font-family:var(--ff-head);font-weight:600;font-size:1rem;color:var(--text);display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq-q .ic{flex-shrink:0;transition:.3s;color:var(--primary)}
.faq-item.open .faq-q .ic{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-a p{padding:0 24px 22px;font-size:.95rem}

/* Values / chips */
.value-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow-sm);transition:.3s}
.value-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.value-card .num{font-family:var(--ff-head);font-weight:800;font-size:2rem;color:var(--primary);opacity:.4}
.value-card h3{margin:8px 0}

/* Leadership / team */
.team-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:.3s;text-align:center}
.team-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.team-card .ph{aspect-ratio:4/5;overflow:hidden}
.team-card .ph img{width:100%;height:100%;object-fit:cover;transition:.5s}
.team-card:hover .ph img{transform:scale(1.05)}
.team-card .tb{padding:22px}
.team-card h3{font-size:1.15rem}
.team-card .role{color:var(--primary);font-family:var(--ff-head);font-weight:500;font-size:.9rem;margin-top:2px}

/* Info / contact tiles */
.info-tile{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-sm);text-align:center}
.info-tile .icon{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;background:rgba(33,178,198,.12);color:var(--primary);margin:0 auto 16px}
.info-tile h3{font-size:1.05rem;margin-bottom:6px}
.info-tile p{font-size:.92rem}
.info-tile a{color:var(--primary)}

.map-embed{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--border);min-height:380px;background:#e8eef0;display:grid;place-items:center}
.map-embed iframe{width:100%;height:100%;min-height:380px;border:0;display:block}

/* Job listings */
.job{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-sm);transition:.3s;display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap}
.job:hover{box-shadow:var(--shadow);border-color:var(--primary)}
.job h3{font-size:1.15rem}
.job .meta{display:flex;gap:18px;flex-wrap:wrap;color:var(--muted);font-size:.85rem;margin-top:8px;font-family:var(--ff-head);font-weight:500}
.job .meta span{display:inline-flex;gap:6px;align-items:center}

/* News search/filter bar */
.news-tools{display:flex;gap:14px;flex-wrap:wrap;justify-content:space-between;align-items:center;margin-bottom:36px}
.news-search{flex:1;min-width:240px;position:relative}
.news-search input{width:100%;padding:13px 16px 13px 48px;border:1px solid var(--border);border-radius:50px;font-family:var(--ff-body);background:#fff}
.news-search svg{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--muted);width:20px;height:20px;pointer-events:none}

/* Back to top */
.to-top{position:fixed;bottom:26px;right:26px;width:50px;height:50px;border-radius:50%;background:var(--primary);color:#fff;border:none;cursor:pointer;display:grid;place-items:center;box-shadow:var(--shadow);opacity:0;visibility:hidden;transform:translateY(14px);transition:.3s;z-index:900}
.to-top.show{opacity:1;visibility:visible;transform:translateY(0)}
.to-top:hover{background:var(--primary-hover)}

/* Preloader */
.preloader{position:fixed;inset:0;background:var(--nav);z-index:5000;display:grid;place-items:center;transition:opacity .5s ease,visibility .5s}
.preloader.hide{opacity:0;visibility:hidden}
.preloader .spinner{width:54px;height:54px;border:4px solid rgba(255,255,255,.2);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ===================== FOOTER ===================== */
.footer{background:var(--footer);color:rgba(255,255,255,.78);padding:72px 0 0}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.4fr;gap:40px;padding-bottom:50px}
.footer h4{color:#fff;font-size:1rem;margin-bottom:18px;letter-spacing:.02em}
.footer-brand img{height:54px;background:#fff;border-radius:10px;padding:5px;margin-bottom:16px}
.footer-brand p{color:rgba(255,255,255,.6);font-size:.9rem;max-width:34ch}
.footer ul li{margin-bottom:11px}
.footer ul a{color:rgba(255,255,255,.72);font-size:.92rem;transition:.2s}
.footer ul a:hover{color:var(--primary)}
.footer-contact li{display:flex;gap:10px;font-size:.9rem;margin-bottom:13px;color:rgba(255,255,255,.72);align-items:flex-start}
.footer-contact svg{color:var(--primary);flex-shrink:0;margin-top:3px;width:20px;height:20px;}
.footer-contact li span{line-height:1.35}
.socials{display:flex;gap:10px;margin-top:18px}
.socials a{width:25px;height:25px;border-radius:50%;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.24);display:grid;place-items:center;color:#fff;transition:.25s}
.socials a img,
.socials a svg{width:20px;height:20px;display:block;}
.socials a img{object-fit:contain}
.socials a:hover{background:var(--primary);transform:translateY(-3px)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding:24px 0;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:.84rem;color:rgba(255,255,255,.55)}
.footer-bottom .credit{color:rgba(255,255,255,.7)}
.footer-bottom .credit strong{color:var(--primary)}

/* Animations on scroll */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
