/* ==========================================================================
   Base, Variables & Utilities
   ========================================================================== */
:root{
  /* Split-Complementary Palette */
  --color-primary:#FF645A;          /* Coral */
  --color-secondary:#4A90E2;        /* Azure */
  --color-accent:#35D1B6;           /* Turquoise */
  --color-bg:#F0F2F5;               /* Light Gray */
  --color-card:#E9ECF1;             /* Card BG */
  --color-text:#333333;             /* Dark Text */
  --color-light:#FFFFFF;            /* Light Text */

  /* Neomorphism Shadows */
  --shadow-lighter:-6px -6px 12px rgba(255,255,255,0.6);
  --shadow-darker:6px 6px 12px rgba(0,0,0,0.12);

  /* Typography */
  --font-heading:'Poppins',sans-serif;
  --font-body:'Work Sans',sans-serif;

  /* Motion */
  --transition:all .35s ease;
  --radius:14px;
}

/* Reset & Global */
*,
*::before,
*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:var(--font-body);
  background:var(--color-bg);
  color:var(--color-text);
  line-height:1.6;
}
img{max-width:100%;display:block;}
a{text-decoration:none;color:var(--color-secondary);transition:color .25s;}
a:hover,a:focus{color:var(--color-primary);}

/* Containers */
.container{width:min(90%,1200px);margin-inline:auto;}
.is-two-thirds{width:66%;margin-inline:auto;}

/* Headings */
h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:600;text-align:center;color:#222;text-shadow:1px 1px 3px rgba(0,0,0,.15);margin-bottom:1rem;}
.section-title{font-size:2.125rem;margin-bottom:2rem;}

/* ==========================================================================
   Header & Navigation
   ========================================================================== */
.site-header{
  position:sticky;top:0;z-index:997;background:var(--color-bg);
  box-shadow:var(--shadow-darker);
}
.site-header .container{
  display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 0;
}
.brand{font-size:1.5rem;font-family:var(--font-heading);color:var(--color-primary);}
.navigation ul{display:flex;gap:1.25rem;list-style:none;}
.navigation a{font-weight:500;}
/* Burger */
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;}
.burger span{display:block;width:22px;height:3px;background:var(--color-text);transition:var(--transition);}

/* ==========================================================================
   Hero
   ========================================================================== */
.hero-section{
  position:relative;color:var(--color-light);display:flex;align-items:center;
  background-size:cover;background-repeat:no-repeat;background-attachment:fixed;
  padding:4.5rem 0 6rem;
}
.hero-title{font-size:2.75rem;text-shadow:1px 1px 4px rgba(0,0,0,.7);}
.hero-subtitle{font-size:1.25rem;margin:1rem 0 2rem;text-align:center;max-width:46ch;margin-inline:auto;}

/* ==========================================================================
   Buttons
   ========================================================================== */
.btn,
button,
input[type='submit']{
  display:inline-block;padding:.75rem 1.75rem;border:none;border-radius:var(--radius);
  font-family:var(--font-heading);font-weight:600;cursor:pointer;
  transition:var(--transition);box-shadow:var(--shadow-lighter),var(--shadow-darker);
  background:var(--color-primary);color:var(--color-light);
}
.btn-primary{background:var(--color-primary);}
.btn:hover,
.btn:focus,
button:hover,
input[type='submit']:hover{transform:translateY(-3px);box-shadow:-4px -4px 8px rgba(255,255,255,.4),4px 4px 8px rgba(0,0,0,.2);}

/* ==========================================================================
   Cards (Global)
   ========================================================================== */
.card{
  background:var(--color-card);border-radius:var(--radius);
  box-shadow:var(--shadow-lighter),var(--shadow-darker);
  padding:1.5rem;text-align:center;display:flex;flex-direction:column;align-items:center;
  transition:var(--transition);position:relative;
}
.card:hover{transform:translateY(-6px) rotateX(3deg);}

.card-image,
.image-container{
  width:100%;height:220px;overflow:hidden;border-radius:var(--radius);
  display:flex;justify-content:center;align-items:center;margin-bottom:1rem;
}
.card-image img,
.image-container img{height:100%;width:100%;object-fit:cover;margin:0 auto;}

/* ==========================================================================
   Features Section
   ========================================================================== */
.features-grid{
  display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
}
.progress-wrapper{margin-top:2.5rem;}
progress{
  width:100%;height:14px;border-radius:7px;overflow:hidden;
  box-shadow:inset var(--shadow-lighter), inset var(--shadow-darker);
  appearance:none;
}
progress::-webkit-progress-bar{background:var(--color-card);}
progress::-webkit-progress-value{background:var(--color-accent);}

/* ==========================================================================
   Timeline (Case Studies)
   ========================================================================== */
.timeline{border-left:4px solid var(--color-secondary);margin-left:1rem;}
.timeline-item{position:relative;padding:1rem 1.5rem;margin-bottom:1.5rem;}
.timeline-item::before{
  content:'';position:absolute;left:-0.8rem;top:1.2rem;width:16px;height:16px;
  background:var(--color-primary);border-radius:50%;box-shadow:0 0 0 4px var(--color-bg);
}
.timeline-item h3{text-align:left;margin-bottom:.5rem;}
.timeline-item p{text-align:left;}

/* ==========================================================================
   Behind the Scenes
   ========================================================================== */
.behind-section,
.vision-section{
  background-size:cover;background-repeat:no-repeat;background-attachment:fixed;
  color:var(--color-light);padding:4rem 0;position:relative;
}
.behind-section::before,
.vision-section::before{
  content:'';position:absolute;inset:0;background:rgba(0,0,0,.45);z-index:0;
}
.behind-section .container,
.vision-section .container{position:relative;z-index:1;}
.behind-section p,
.vision-section p{max-width:60ch;margin-inline:auto;text-align:center;}

/* ==========================================================================
   FAQ
   ========================================================================== */
details{background:var(--color-card);margin-bottom:1rem;border-radius:var(--radius);
  box-shadow:var(--shadow-lighter),var(--shadow-darker);padding:1rem;}
summary{cursor:pointer;font-weight:600;font-family:var(--font-heading);outline:none;}
details[open] summary{color:var(--color-primary);}

/* ==========================================================================
   News & Events
   ========================================================================== */
.news-events-section .card{margin-bottom:1.5rem;}
.news-events-section .card-content h3{margin-bottom:.5rem;font-size:1.35rem;color:var(--color-secondary);}
.read-more{display:inline-block;margin-top:.5rem;font-weight:500;}
.read-more:hover{color:var(--color-accent);}

/* ==========================================================================
   Contact Form
   ========================================================================== */
.contact-form{display:grid;gap:1.25rem;margin-top:2rem;}
.form-group{display:flex;flex-direction:column;gap:.5rem;}
input[type='text'],
input[type='email'],
textarea{
  padding:.75rem 1rem;border:none;border-radius:var(--radius);
  background:var(--color-card);box-shadow:var(--shadow-lighter),var(--shadow-darker);
  font-family:var(--font-body);resize:none;transition:var(--transition);color:var(--color-text);
}
input:focus,textarea:focus{outline:none;box-shadow:inset var(--shadow-darker);}
.contact-section{padding:4rem 0;}

/* ==========================================================================
   Footer
   ========================================================================== */
.site-footer{
  background:var(--color-bg);padding:2rem 0;margin-top:4rem;
  box-shadow:inset 0 4px 8px rgba(0,0,0,.05);
}
.footer-links,
.social-links{
  display:flex;justify-content:center;gap:1.25rem;flex-wrap:wrap;margin-bottom:1rem;
}
.social-links a{font-weight:600;color:var(--color-secondary);}
.social-links a:hover{color:var(--color-primary);}
.site-footer p{text-align:center;font-size:.875rem;}

/* ==========================================================================
   Cookie Popup
   ========================================================================== */
#cookiePopup{
  font-size:.875rem;display:none;align-items:center;justify-content:center;gap:.75rem;
}
#cookiePopup button{box-shadow:none;}

/* ==========================================================================
   Utility & State Classes
   ========================================================================== */
.fade-in{animation:fadeIn .85s ease forwards;}
@keyframes fadeIn{from{opacity:0;transform:translateY(15px);}to{opacity:1;transform:none;}}
.parallax{background-attachment:fixed;}
.text-center{text-align:center;}
.hidden{display:none;}
/* Success Page */
.success-page{min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;}

/* Legal Pages (privacy & terms) */
.legal-page{padding-top:100px;}

/* ==========================================================================
   Responsive & Burger
   ========================================================================== */
@media(max-width:1024px){
  .navigation ul{flex-direction:column;position:absolute;top:100%;right:0;
    background:var(--color-bg);width:240px;padding:1rem;box-shadow:var(--shadow-darker);
    transform:scaleY(0);transform-origin:top;transition:var(--transition);}
  .navigation ul.open{transform:scaleY(1);}
  .burger{display:flex;}
}
/* ==========================================================================
   Hover 3D for Cards
   ========================================================================== */
@media(hover:hover){
  .card:hover{transform:translateY(-10px) rotate3d(1,0,0,6deg);}
}