/*
  TERRANOVA SOLUTIONS INC - Single Page Website
  Upload all files in this folder to public_html on Namecheap cPanel.
*/
:root{
  --navy:#073b5b;
  --navy-2:#052b43;
  --blue:#0879bd;
  --cyan:#2aa7ff;
  --gold:#d9a525;
  --gold-2:#f0c969;
  --ink:#111820;
  --muted:#617282;
  --soft:#f5f8fb;
  --white:#ffffff;
  --dark:#14191c;
  --panel:#10161a;
  --radius:26px;
  --shadow:0 28px 70px rgba(0,29,50,.24);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--ink);
  background:#f8fbfd;
  line-height:1.65;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:min(1180px,calc(100% - 42px));margin-inline:auto}
.notice-bar{
  background:#0f1519;
  color:#cfeeff;
  font-size:13px;
  letter-spacing:.05em;
  overflow:hidden;
  white-space:nowrap;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.notice-track{display:inline-flex;gap:52px;padding:8px 0;animation:ticker 25s linear infinite}
.notice-track span::before{content:"◆";color:var(--gold);margin-right:10px}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.site-header{
  position:sticky;top:0;z-index:50;
  background:linear-gradient(90deg,#073b5b,#03446d 55%,#073b5b);
  box-shadow:0 14px 42px rgba(0,20,34,.22);
}
.nav{height:78px;display:flex;align-items:center;justify-content:space-between;gap:26px}
.brand{display:flex;align-items:center;gap:12px;color:#fff;font-weight:900;letter-spacing:.08em;text-transform:uppercase}
.brand img{width:55px;height:auto;filter:drop-shadow(0 8px 12px rgba(0,0,0,.2))}
.brand small{display:block;font-size:10px;letter-spacing:.18em;color:#c9e7f7;font-weight:800;line-height:1.05}
.brand span{font-family:Georgia,"Times New Roman",serif;font-size:19px;line-height:1.05}
.nav-links{display:flex;align-items:center;gap:28px;color:#e9f7ff;font-size:14px;font-weight:800}
.nav-links a{opacity:.92;transition:.2s ease}.nav-links a:hover{opacity:1;color:#fff}
.nav-cta,.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  border:0;border-radius:999px;padding:13px 21px;
  font-weight:900;cursor:pointer;transition:.25s ease;
  box-shadow:0 15px 35px rgba(0,0,0,.18)
}
.nav-cta,.btn-gold{background:linear-gradient(135deg,var(--gold),#9b6a00);color:#fff}
.btn-blue{background:linear-gradient(135deg,#0b85cb,#063b60);color:#fff}
.btn-light{background:#fff;color:var(--navy);border:1px solid rgba(7,59,91,.1)}
.btn:hover{transform:translateY(-2px);filter:saturate(1.08)}
.menu-btn{display:none;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.22);color:#fff;border-radius:14px;padding:10px 12px;font-size:20px}
.hero{
  position:relative;overflow:hidden;color:#fff;
  background:radial-gradient(circle at 50% 8%,rgba(42,167,255,.24),transparent 36%),linear-gradient(180deg,#075482 0%,#057abe 48%,#11181b 48%,#11181b 100%);
  min-height:880px;
}
.hero::before{
  content:"TERRANOVA";position:absolute;top:72px;left:50%;transform:translateX(-50%);
  font-family:Georgia,"Times New Roman",serif;font-size:clamp(68px,10vw,150px);font-weight:900;letter-spacing:.06em;
  color:rgba(0,30,54,.22);pointer-events:none;white-space:nowrap
}
.hero-grid{position:absolute;left:0;right:0;top:310px;height:270px;opacity:.18;background-image:linear-gradient(rgba(255,255,255,.25) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.25) 1px,transparent 1px);background-size:42px 42px;transform:perspective(900px) rotateX(63deg);transform-origin:top center}
.hero-inner{position:relative;z-index:2;text-align:center;padding:88px 0 0}
.kicker{display:inline-flex;align-items:center;gap:9px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.08);backdrop-filter:blur(12px);border-radius:999px;padding:9px 16px;color:#e4f6ff;font-weight:800;font-size:13px;letter-spacing:.1em;text-transform:uppercase}
.kicker i{color:var(--gold-2)}
h1,h2,h3{line-height:1.1;margin:0;font-family:Georgia,"Times New Roman",serif}
h1{font-size:clamp(42px,6.2vw,82px);margin:25px auto 14px;max-width:940px;letter-spacing:-.04em;text-shadow:0 18px 48px rgba(0,0,0,.26)}
.hero-sub{max-width:850px;margin:0 auto;color:#daf1ff;font-size:clamp(17px,2vw,22px)}
.hero-actions{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;margin-top:30px}
.hero-stage{position:relative;width:min(1060px,calc(100% - 38px));margin:48px auto 0}
.hero-stage::before{content:"";position:absolute;inset:9% 5% -8%;background:radial-gradient(circle,rgba(42,167,255,.38),transparent 62%);filter:blur(26px)}
.hero-stage img{position:relative;border-radius:28px;border:1px solid rgba(255,255,255,.16);box-shadow:0 36px 120px rgba(0,0,0,.42)}
.float-card{position:absolute;background:rgba(255,255,255,.94);color:#0b2d44;border-radius:20px;padding:17px 18px;box-shadow:0 24px 60px rgba(0,0,0,.25);border:1px solid rgba(255,255,255,.4);text-align:left}
.float-card strong{font-size:27px;display:block;color:var(--navy);line-height:1}
.float-card span{font-size:12px;color:#526878;font-weight:800;text-transform:uppercase;letter-spacing:.08em}
.card-left{left:-20px;bottom:80px}.card-right{right:-12px;top:95px}
.segment{padding:94px 0}.segment-dark{background:#11181b;color:#fff}.segment-light{background:#f7fafc}.section-title{text-align:center;max-width:860px;margin:0 auto 54px}.section-title .eyebrow{color:var(--gold);font-weight:900;letter-spacing:.16em;text-transform:uppercase;font-size:13px}.section-title h2{font-size:clamp(34px,4.7vw,58px);margin:12px 0}.section-title p{color:var(--muted);font-size:18px}.segment-dark .section-title p{color:#b8c7d0}
.authority-layout{display:grid;grid-template-columns:1.05fr .95fr;gap:34px;align-items:stretch}.authority-card{background:#fff;border-radius:var(--radius);padding:36px;box-shadow:var(--shadow);border:1px solid rgba(7,59,91,.08)}.authority-card.dark{background:linear-gradient(155deg,#0d3148,#102331);color:#fff;position:relative;overflow:hidden}.authority-card.dark::after{content:"";position:absolute;right:-85px;bottom:-110px;width:290px;height:290px;border-radius:50%;background:radial-gradient(circle,var(--cyan),transparent 68%);opacity:.24}.authority-card h3{font-size:31px;margin-bottom:17px}.authority-card p{color:#617282}.authority-card.dark p{color:#d6e9f5}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:13px;margin-top:25px}.stat{border-radius:20px;padding:20px;background:#eff7fb;border:1px solid rgba(7,59,91,.07)}.authority-card.dark .stat{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.1)}.stat strong{display:block;font-size:27px;color:var(--navy);font-family:Georgia,"Times New Roman",serif}.authority-card.dark .stat strong{color:#fff}.stat span{display:block;color:#667786;font-weight:800;font-size:12px;letter-spacing:.05em;text-transform:uppercase;line-height:1.35}.authority-card.dark .stat span{color:#c6dbe7}
.procurement{margin-top:34px;background:linear-gradient(135deg,#085d90,#0879bd);color:#fff;border-radius:var(--radius);padding:38px;display:grid;grid-template-columns:1.05fr .95fr;gap:28px;align-items:center;box-shadow:var(--shadow);position:relative;overflow:hidden}.procurement::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.13) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.13) 1px,transparent 1px);background-size:26px 26px;opacity:.4}.procurement>*{position:relative}.procurement h3{font-size:34px;margin-bottom:12px}.procurement p{color:#e1f5ff}.procurement-list{display:grid;gap:12px}.procurement-list div{display:flex;gap:12px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.16);border-radius:16px;padding:14px 16px;font-weight:800}.procurement-list i{color:var(--gold-2);margin-top:4px}
.services{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:34px}.service-card{background:#fff;border-radius:24px;padding:28px 24px;border:1px solid rgba(7,59,91,.08);box-shadow:0 18px 40px rgba(0,32,54,.08);transition:.25s ease;position:relative;overflow:hidden}.service-card::before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,var(--gold),var(--cyan))}.service-card:hover{transform:translateY(-6px);box-shadow:0 28px 70px rgba(0,32,54,.14)}.service-icon{width:54px;height:54px;border-radius:16px;background:#e8f5fc;color:var(--blue);display:grid;place-items:center;font-size:23px;margin-bottom:20px}.service-card h3{font-size:22px;margin-bottom:12px}.service-card p{color:#617282;margin:0}
.faq-policy-wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:38px;align-items:start}.faq-list{display:grid;grid-template-columns:1fr 1fr;gap:14px}.faq-item{background:#151d21;border:1px solid rgba(255,255,255,.06);border-radius:17px;overflow:hidden}.faq-question{width:100%;background:transparent;color:#fff;border:0;text-align:left;padding:20px 20px;display:flex;gap:14px;align-items:center;justify-content:space-between;font-weight:900;cursor:pointer}.faq-question .num{color:#d8edf9;opacity:.85;font-family:Georgia,"Times New Roman",serif}.faq-question i{color:#d1dbe2;transition:.2s}.faq-answer{max-height:0;overflow:hidden;transition:max-height .25s ease}.faq-answer p{margin:0;padding:0 20px 20px 52px;color:#b8c7d0;font-size:14px}.faq-item.active .faq-answer{max-height:180px}.faq-item.active .faq-question i{transform:rotate(90deg);color:var(--gold)}.policy-card{background:linear-gradient(160deg,#f7fbff,#ffffff);color:var(--ink);border-radius:var(--radius);padding:34px;box-shadow:0 24px 70px rgba(0,0,0,.25)}.policy-card h3{font-size:32px;margin-bottom:14px}.policy-card p{color:#617282}.policy-links{display:grid;gap:12px;margin:24px 0}.policy-link{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-radius:17px;background:#edf6fb;color:var(--navy);font-weight:900;border:1px solid rgba(7,59,91,.07);cursor:pointer}.policy-link:hover{background:#e1f1f8}.contact-grid{display:grid;gap:12px;margin-top:22px}.contact-row{display:flex;gap:12px;align-items:flex-start;padding:13px 0;border-top:1px solid #e5eef4}.contact-row i{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;background:#e8f5fc;color:var(--blue);flex:0 0 auto}.contact-row strong{display:block;color:#0c2d43}.contact-row span,.contact-row a{display:block;color:#617282;font-size:14px}
.cta-band{position:relative;overflow:hidden;background:linear-gradient(135deg,#075482,#0879bd);color:#fff;padding:82px 0}.cta-band::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.14) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.14) 1px,transparent 1px);background-size:24px 24px;opacity:.52}.cta-content{position:relative;text-align:center;max-width:820px;margin:auto}.cta-content h2{font-size:clamp(34px,5vw,56px);margin:12px 0}.cta-content p{color:#e1f5ff}.pill-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:28px}.pill{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);padding:10px 15px;border-radius:999px;font-size:13px;font-weight:900;color:#e7f8ff}.site-footer{background:#0d1114;color:#c5d0d6;padding:38px 0}.footer-layout{display:grid;grid-template-columns:1fr auto;gap:28px;align-items:center}.footer-brand{display:flex;align-items:center;gap:13px}.footer-brand img{width:52px}.footer-brand strong{display:block;color:#fff;letter-spacing:.08em}.footer-brand span{font-size:13px}.footer-links{display:flex;gap:18px;flex-wrap:wrap}.footer-links button,.footer-links a{background:transparent;border:0;color:#c5d0d6;font-weight:800;cursor:pointer;font-size:14px}.footer-links button:hover,.footer-links a:hover{color:#fff}.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.66);z-index:90;display:none;align-items:center;justify-content:center;padding:24px}.modal-backdrop.show{display:flex}.modal{background:#fff;border-radius:28px;width:min(760px,100%);max-height:86vh;overflow:auto;box-shadow:0 30px 100px rgba(0,0,0,.44)}.modal-head{position:sticky;top:0;background:#fff;display:flex;justify-content:space-between;align-items:center;gap:16px;padding:24px 28px;border-bottom:1px solid #e6edf2}.modal-head h3{font-size:28px}.modal-close{border:0;background:#eef5f9;color:#0b3551;width:42px;height:42px;border-radius:13px;font-size:20px;cursor:pointer}.modal-body{padding:28px;color:#516373}.modal-body h4{color:#0b3551;margin:22px 0 5px}.modal-body ul{padding-left:20px}.mobile-panel{display:none}
@media (max-width:1020px){.authority-layout,.procurement,.faq-policy-wrap{grid-template-columns:1fr}.services{grid-template-columns:repeat(2,1fr)}.faq-list{grid-template-columns:1fr}.hero{min-height:780px}.float-card{display:none}}
@media (max-width:760px){.container{width:min(100% - 28px,1180px)}.nav{height:70px}.brand small{display:none}.nav-links,.nav-cta{display:none}.menu-btn{display:block}.mobile-panel{display:none;position:absolute;top:70px;left:14px;right:14px;background:#082f49;border:1px solid rgba(255,255,255,.15);border-radius:22px;padding:15px;box-shadow:0 22px 60px rgba(0,0,0,.32)}.mobile-panel.show{display:grid;gap:10px}.mobile-panel a{color:#fff;padding:12px;border-radius:14px;background:rgba(255,255,255,.06);font-weight:900}.hero-inner{padding-top:54px}.hero{min-height:auto;padding-bottom:68px}.hero::before{top:95px}.hero-stage{margin-top:34px}.segment{padding:70px 0}.authority-card,.procurement,.policy-card{padding:26px}.stats-grid{grid-template-columns:1fr}.services{grid-template-columns:1fr}.footer-layout{grid-template-columns:1fr;text-align:left}.footer-links{justify-content:flex-start}h1{font-size:42px}.hero-sub{font-size:17px}.hero-actions .btn{width:100%}.section-title{text-align:left}.section-title h2{font-size:35px}.faq-answer p{padding-left:20px}.brand span{font-size:16px}}
