/* RESET & NORMALIZE */
html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,main,menu,nav,output,ruby,section,summary,time,mark,audio,video {
  margin:0;
  padding:0;
  border:0;
  font-size:100%;
  font:inherit;
  vertical-align:baseline;
  box-sizing:border-box;
}
article,aside,details,figcaption,figure,footer,header,hgroup,main,menu,nav,section {
  display:block;
}
body {
  line-height:1;
  font-family:'Roboto',Arial,sans-serif;
  color:#222;
  background:#FDF6F0;
  min-height:100vh;
}
ul,ol {
  list-style:none;
}
a {
  background:transparent;
  text-decoration:none;
  color:inherit;
  transition:color .2s;
}
a:focus {
  outline:2px solid #61BAA9;
  outline-offset:2px;
}
img {
  max-width:100%;
  display:block;
}
button,input,select,textarea {
  font:inherit;
  border:none;
  background:none;
}
button:focus, input:focus, textarea:focus, select:focus {
  outline:2px solid #005A8D;
}

/* BRAND FONTS */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@700;900&family=Roboto:wght@400;500;700&display=swap');

:root {
  --color-primary: #005A8D;
  --color-secondary: #61BAA9;
  --color-accent: #FDF6F0;
  --color-white: #fff;
  --color-black: #222;
  --color-yellow: #FFE35B;
  --color-orange: #FF8D56;
  --color-pink: #FFA3B7;
  --color-blue: #23A6F0;
  --border-radius: 18px;
  --shadow-lg: 0 8px 24px 0 rgba(0,89,141,0.08);
  --shadow-md:0 2px 10px 0 rgba(97,186,169,0.10);
  --duration: .3s;
}

/* CONTAINER */
.container {
  width:100%;
  max-width:1160px;
  margin-left:auto;
  margin-right:auto;
  padding-left:16px;
  padding-right:16px;
}

.content-wrapper {
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:24px;
}

/* TYPOGRAPHY */
h1 {
  font-family: 'Montserrat', sans-serif;
  font-weight:900;
  font-size:2.5rem;
  line-height:1.1;
  color:var(--color-primary);
  letter-spacing:-1px;
  margin-bottom:8px;
}
h2 {
  font-family: 'Montserrat', sans-serif;
  font-weight:700;
  font-size:2rem;
  color:var(--color-secondary);
  margin-bottom:8px;
}
h3 {
  font-family: 'Montserrat', sans-serif;
  font-weight:700;
  font-size:1.25rem;
  color:var(--color-primary);
  margin-bottom:4px;
}
h4,h5,h6 {
  font-family: 'Montserrat', sans-serif;
  font-weight:700;
  color:var(--color-primary);
}
p, li, td, th {
  font-family: 'Roboto', sans-serif;
  font-size:1rem;
  line-height:1.7;
  color:var(--color-black);
}
.tagline {
  font-family: 'Montserrat', sans-serif;
  color: var(--color-orange);
  font-size: 1.125rem;
  letter-spacing:.5px;
  font-weight:700;
  margin-bottom:8px;
}


/* PLAYFUL DYNAMIC COLOURFUL DECOR */
.hero, #cta-before-footer, #cta-banner, #thank-you {
  background: linear-gradient(100deg, #fffefa 0%, #ffc7ab 65%, #FFA3B7 100%);
  color:var(--color-primary);
  border-radius:var(--border-radius);
  box-shadow:var(--shadow-lg);
  margin-bottom:60px;
  padding:64px 20px;
  position:relative;
  overflow:hidden;
}
.hero h1, #cta-before-footer h2, #cta-banner h2, #thank-you h1 {
  color: var(--color-primary);
  font-size:2.7rem;
  line-height:1.1;
}
.hero .btn-primary, #cta-before-footer .btn-primary, #cta-banner .btn-primary, #thank-you .btn-primary {
  margin-top:32px;
}

/* Animated energy blobs for playfulness */
.hero::before,
.hero::after,
#cta-before-footer::before,
#cta-before-footer::after,
#cta-banner::before,
#cta-banner::after {
  content:'';
  position:absolute;
  z-index:0;
  border-radius: 50%;
  opacity:.17;
  animation: blobmove 7s infinite alternate ease-in-out;
}
.hero::before {
  width:180px;height:180px;top:-40px;right:-60px;background:var(--color-blue);
  animation-delay:0s;
}
.hero::after {
  width:90px;height:90px;bottom:-30px;left:-25px;background:var(--color-yellow);
  animation-delay:2s;
}
#cta-before-footer::before, #cta-banner::before {width:110px;height:110px;bottom:-20px;right:10px;background:var(--color-pink);animation-delay:.5s;}
#cta-before-footer::after, #cta-banner::after {width:80px;height:80px;top:10px;left:-25px;background:var(--color-blue);animation-delay:1.2s;}
@keyframes blobmove {
  to { transform: scale(1.15) translateY(30px) translateX(20px) rotate(24deg); }
}

/* HEADER & NAVIGATION */
header {
  background:var(--color-white);
  border-bottom:3px solid var(--color-yellow);
  padding:0;
  position:sticky;
  top:0;
  z-index:1000;
}
header .container {
  display:flex;
  align-items:center;
  justify-content:space-between;
  min-height:72px;
}
header nav {
  display:flex;
  align-items:center;
  gap:28px;
}
header nav a {
  font-family:'Montserrat',sans-serif;
  font-weight:600;
  font-size:1rem;
  color:var(--color-primary);
  padding:12px 0;
  border-radius:8px;
  transition:background .2s, color .2s;
}
header nav a:hover {
  background:var(--color-accent);
  color:var(--color-orange);
}
header nav .btn-primary {
  margin-left:14px;
}

/* MOBILE MENU */
.mobile-menu-toggle {
  display:none;
  font-size:2rem;
  color:var(--color-primary);
  background:none;
  border:none;
  line-height:1;
  cursor:pointer;
  z-index:1021;
}
@media (max-width:1024px) {
  header nav {
    display:none;
  }
  .mobile-menu-toggle {
    display:block;
  }
}
.mobile-menu {
  position:fixed;
  top:0;left:0;right:0;bottom:0;
  background:var(--color-accent);
  z-index:1020;
  transform:translateX(100%);
  transition:transform var(--duration) cubic-bezier(.68,-0.55,.27,1.55);
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  padding:32px 24px 24px 28px;
}
.mobile-menu.open {
  transform:translateX(0%);
  box-shadow:0 4px 32px 0 rgba(0,0,0,0.19);
}
.mobile-menu-close {
  align-self:flex-end;
  font-size:2rem;
  color:var(--color-primary);
  background:none;
  border:none;
  margin-bottom:24px;
  cursor:pointer;
  transition:color .2s;
}
.mobile-menu-close:hover {
  color:var(--color-orange);
}
.mobile-nav {
  width:100%;
  display:flex;
  flex-direction:column;
  gap:20px;
}
.mobile-nav a {
  padding:18px 0 12px 0;
  border-radius:8px;
  font-size:1.15rem;
  color:var(--color-primary);
  font-weight:700;
  background:transparent;
  transition:background .2s, color .2s;
}
.mobile-nav a:hover {
  background:var(--color-secondary);
  color:var(--color-white);
}

/* Button Primary */
.btn-primary {
  display:inline-block;
  padding:14px 36px;
  background:var(--color-primary);
  color:var(--color-white);
  box-shadow: 0 6px 24px 0 rgba(0,89,141,0.14);
  font-family:'Montserrat',sans-serif;
  font-weight:700;
  font-size:1.1rem;
  border-radius:28px;
  letter-spacing:.4px;
  cursor:pointer;
  border:none;
  transition:background var(--duration),transform .13s;
  position:relative;
  z-index:3;
  margin-right:10px;
}
.btn-primary:hover,
.btn-primary:focus {
  background:var(--color-secondary);
  color:var(--color-yellow);
  transform:scale(1.06);
}

/* ----------- SECTIONS ----------- */
.section {
  margin-bottom:60px;
  padding:40px 20px;
}

/* FLEX LAYOUTS - MANDATORY GAPS & ALIGNMENT */
.card-container, .features-grid, .card-grid, .content-grid {
  display:flex;
  flex-wrap:wrap;
  gap:24px;
}
.card {
  background:var(--color-white);
  border-radius:var(--border-radius);
  margin-bottom:20px;
  box-shadow:var(--shadow-md);
  position:relative;
  overflow:hidden;
  transition:box-shadow var(--duration),transform .12s;
  min-width:270px;
}
.card:hover {
  box-shadow:0 12px 40px 0 rgba(36,163,240,0.07);
  transform:translateY(-4px) scale(1.02);
}
.content-grid {
  display:flex;
  flex-wrap:wrap;
  gap:20px;
  justify-content:space-between;
}
.text-image-section {
  display:flex;
  align-items:center;
  gap:30px;
  flex-wrap:wrap;
}
.testimonial-card {
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:20px;
  background:var(--color-accent);
  padding:20px;
  border-radius:var(--border-radius);
  box-shadow:var(--shadow-md);
  margin-bottom:24px;
  min-width:230px;
  border-left:8px solid var(--color-secondary);
  position:relative;
  z-index:1;
  transition:box-shadow var(--duration),transform .12s;
}
.testimonial-card:hover {
  box-shadow:0 12px 36px 0 rgba(0,90,141,0.13);
  transform:scale(1.025);
}
.testimonial-card p {
  color:var(--color-black);
  font-size:1.08rem;
  font-family:'Roboto',sans-serif;
}
.testimonial-meta {
  font-size:0.98rem;
  color:var(--color-secondary);
  font-weight:700;
}
.feature-item {
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:15px;
}

/* FEATURES-GRID Section Style */
.features-grid > div {
  background:var(--color-white);
  border-radius:var(--border-radius);
  box-shadow:var(--shadow-md);
  padding:28px 20px 22px 20px;
  min-width:220px;
  flex:1 1 240px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:16px;
  position:relative;
  margin-bottom:20px;
  transition:box-shadow var(--duration),transform .12s;
}
.features-grid > div:hover {
  box-shadow:0 10px 30px 0 rgba(255,163,183,0.14);
  transform:scale(1.03);
}
.features-grid img {
  width:56px;
  height:56px;
  margin-bottom:5px;
}
.features-grid h3 {
  color:var(--color-orange);
  margin-bottom:7px;
}
.features-grid p {
  color:#305867;
  font-size:.99rem;
  text-align:center;
}

/* FAQ Section */
.faq-list {
  display:flex;
  flex-direction:column;
  gap:24px;
}
.faq-item {
  background:var(--color-accent);
  border-radius: 13px;
  padding:18px 22px;
  box-shadow: 0 2px 10px 0 rgba(33,181,158,0.11);
  margin-bottom:20px;
  border-left:6px solid var(--color-yellow);
  transition:box-shadow .18s;
}
.faq-item h3 {
  font-size:1.13rem;
  color:var(--color-primary);
}
.faq-item:hover {
  box-shadow:0 8px 24px 0 rgba(255,227,91,0.1), 0 0 0 2px var(--color-yellow);
}

/* PRICING TABLES */
table {
  width:100%;
  background:var(--color-white);
  border-radius:var(--border-radius);
  overflow:hidden;
  box-shadow:var(--shadow-md);
  border-collapse:collapse;
  font-family:'Roboto',sans-serif;
  margin-bottom:24px;
}
thead {
  background:var(--color-secondary);
  color:var(--color-white);
}
th, td {
  padding:15px 14px;
  font-size:1rem;
  text-align:left;
}
tbody tr {
  border-bottom:1px solid #eee;
}
tbody tr:last-child {
  border-bottom:none;
}
td.yes {
  color:var(--color-secondary);
  font-weight:bold;
  font-size:1.12rem;
  text-align:center;
}

/* CONFIRMATION NOTE (special style) */
.confirmation-note {
  font-size:1.1rem;
  font-family:'Montserrat',sans-serif;
  color:var(--color-primary);
  background:var(--color-yellow);
  border-radius:12px;
  padding:12px 20px;
  margin:18px 0 18px 0;
  font-weight:500;
  box-shadow: 0 2px 10px 0 rgba(255,227,91,0.13);
}

/* FOOTER */
footer {
  background:var(--color-primary);
  color:var(--color-white);
  padding:0;
  margin-top:50px;
}
.footer-content {
  display:flex;
  flex-wrap:wrap;
  gap:28px;
  align-items:flex-start;
  justify-content:space-between;
  padding:36px 0 24px 0;
}
.footer-nav {
  display:flex;
  flex-direction:column;
  gap:14px;
}
.footer-nav a {
  color:var(--color-yellow);
  font-family:'Montserrat',sans-serif;
  font-weight:600;
  font-size:1rem;
  transition:color .18s;
}
.footer-nav a:hover {
  color:var(--color-orange);
}
.contact-short {
  display:flex;
  flex-direction:column;
  gap:12px;
  font-size:.98rem;
  color:#e6faff;
  margin-bottom:8px;
}
.contact-short img {
  width:19px; height:19px; margin-right:8px; vertical-align:middle;
  display:inline-block;
}
.social-links {
  display:flex;
  gap:12px;
  align-items:center;
  margin-top:10px;
}
.social-links a img {
  width:32px;height:32px;transition:transform .17s;}
.social-links a:hover img{transform:scale(1.18) rotate(-10deg);}

/* FORMS, INPUTS ETC. (for possible forms/contact) */
input, textarea, select {
  border:1.5px solid #E5E5E5;
  border-radius:7px;
  padding:11px 15px;
  background:var(--color-white);
  font-size:1rem;
  margin-bottom:14px;
  transition:border .19s;
}
input:focus, textarea:focus, select:focus {
  border:1.5px solid var(--color-secondary);
}
label {
  font-family:'Montserrat',sans-serif;
  font-weight:600;
}

/* ---------------------------------- */
/* COOKIE CONSENT BANNER AND MODAL */
#cookie-banner {
  position:fixed;
  left:0;right:0;bottom:0;
  z-index:20000;
  display:flex;
  flex-direction:row;
  justify-content:center;
  align-items:center;
  background:var(--color-primary);
  color:var(--color-white);
  padding:20px 16px;
  gap:16px;
  box-shadow:0 -2px 30px 0 rgba(0,90,141,0.13);
  font-size:1.06rem;
  border-radius:18px 18px 0 0;
  animation:cookieSlideIn .7s cubic-bezier(.24,1.34,.38,.85);
}
@keyframes cookieSlideIn {
  from {transform:translateY(100%);opacity:0;}
  to {transform:translateY(0);opacity:1;}
}
#cookie-banner .cookie-btn {
  margin-left:19px;
  padding:10px 20px;
  border-radius:17px;
  border:none;
  font-family:'Montserrat',sans-serif;
  font-weight:bold;
  background:var(--color-yellow);
  color:var(--color-primary);
  cursor:pointer;
  font-size:1rem;
  transition:background .2s, color .2s,transform .13s;
}
#cookie-banner .cookie-btn:hover,
#cookie-banner .cookie-btn:focus {
  background:var(--color-orange);
  color:var(--color-white);
  transform:scale(1.07);
}
#cookie-banner .cookie-btn.secondary {
  background:var(--color-white);
  color:var(--color-secondary);
  border:1.5px solid var(--color-secondary);
  margin-right:10px;
}
#cookie-banner .cookie-btn.secondary:hover {
  background:var(--color-blue);
  color:var(--color-white);
}

.cookie-modal-backdrop {
  position:fixed;top:0;left:0;right:0;bottom:0;z-index:20001;background:rgba(0,0,0,0.25);animation:fadeIn .34s;}
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}
.cookie-modal {
  position:fixed;
  left:50%;top:55%;
  transform:translate(-50%,-50%) scale(1);
  z-index:20002;
  max-width:400px;
  width:92vw;
  padding:32px 24px 22px 24px;
  background:var(--color-white);
  color:var(--color-primary);
  border-radius:18px;
  box-shadow:0 8px 40px 0 rgba(36,163,240,0.14);
  animation:popIn .21s cubic-bezier(.41,1.14,.55,0.99);
  display:flex;flex-direction:column;gap:20px;
}
@keyframes popIn{from{transform:translate(-50%,-25%) scale(.75);opacity:0;}to{transform:translate(-50%,-50%) scale(1);opacity:1;}}
.cookie-modal h3{font-size:1.2rem;color:var(--color-primary);margin-bottom:0;}
.cookie-modal label {display:flex;align-items:center;gap:10px;margin-bottom:8px;}
.cookie-modal .category-toggle{width:18px;height:18px;}
.cookie-modal .cookie-btn{margin-top:12px;}

/* Cookie toggles (simple switch style) */
.cookie-switch {
  position:relative;display:inline-block;width:38px;height:22px;margin-right:8px;
}
.cookie-switch input {opacity:0;width:0;height:0;}
.cookie-slider {
  position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;
  background:var(--color-secondary);transition:.3s;border-radius:14px;
}
.cookie-switch input:checked+.cookie-slider {background:var(--color-blue);}
.cookie-slider:before {
  position:absolute;content:"";height:16px;width:16px;left:3px;bottom:3px;
  background:var(--color-white);transition:.3s;border-radius:50%;
}
.cookie-switch input:checked+.cookie-slider:before {transform:translateX(16px);}

/* -------- RESPONSIVE --------- */
@media (max-width:1024px) {
  .container {max-width:96vw;}
  .footer-content{gap:20px;}
  .features-grid > div,.card{min-width:180px;}
}
@media (max-width:768px) {
  h1{font-size:2.1rem;}
  h2{font-size:1.32rem;}
  .hero,.section,#cta-before-footer,#cta-banner {padding:40px 8px;}
  .footer-content {flex-direction:column;gap:22px;align-items:flex-start;}
  .features-grid,.card-container,.content-grid{gap:12px;}
  .features-grid > div, .card{padding:14px 10px 14px 10px;}
  .testimonial-card{padding:15px 10px;}
  .card{min-width:140px;}
  .content-wrapper{gap:16px;}
  section, .section {padding:28px 7px;}
}
@media (max-width:520px){
  h1{font-size:1.4rem;}
  h2{font-size:1.1rem;}
  .btn-primary{padding:11px 18px;font-size:.97rem;}
}
@media (max-width:768px){
  .text-image-section{flex-direction:column;align-items:flex-start;gap:18px;}
}

/* GENERAL ANIMATED MICRO-INTERACTIONS */
.btn-primary, .cookie-btn, .footer-nav a, .mobile-nav a {
  will-change: transform;
  transition:transform 0.13s, box-shadow .19s;
}
.btn-primary:active, .cookie-btn:active {
  transform:scale(0.98);
  box-shadow:none;
}

/* Links in main body */
main a {
  color:var(--color-blue);
  text-decoration:underline dotted 2px var(--color-pink);
  transition:color .18s;
}
main a:hover {
  color:var(--color-orange);
}

/* Util classes */
.text-section {
  display:flex;
  align-items:center;
  gap:20px;
  margin-bottom:10px;
}

/* Fix logo display and nav */
header a img {display:block;max-height:48px;}
footer a img {display:block;max-height:44px;}

/* Hide scroll on mobile menu open (for script to use) */
body.mobile-menu-open {
  height:100vh;overflow-y:hidden;
}

/* Ensures min vertical spacing everywhere */
section, .section, .content-wrapper>*, .footer-content>* {
  margin-bottom:20px;
}
.content-wrapper> :last-child, .footer-content> :last-child, section:last-child, .section:last-child {
  margin-bottom:0;
}

/* Misc (strip) backgrounds for strips */
#about-strip, #info-strip {
  background:var(--color-yellow);
  border-radius:var(--border-radius);
  padding:32px 20px;
  margin-bottom:36px;
  box-shadow:0 2px 12px 0 rgba(255,140,86,0.08);
}
#about-strip h2, #info-strip h2 {
  color:var(--color-primary);
}

/* MAP/CONTACT PAGE tiny adjustments */
#contact-details ul li {
  display:flex;align-items:center;gap:13px;margin-bottom:9px;font-size:1.01rem;
}
#static-map .text-section {gap:8px;}

/* Hide cookie elements initially */
#cookie-banner, .cookie-modal-backdrop, .cookie-modal {
  display:none;
}

/* --- END --- */
