:root{
  --navy: #010637;
  --laser: #aa2526;
  --green: #5fd981;
  --gray: #d9d9d9;
  --yellow: #ffe380;
  --off: #fffff4;
  --muted: rgba(255,255,255,0.82);
  --card-radius: 14px;
  --shadow-1: 0 6px 20px rgba(2,8,20,0.45);
  --max-width: 1200px;
}

/* Reset-ish */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: Inter, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
  background: var(--off);
  color: #0a0a0a;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  line-height:1.45;
}

/* ===== NAV ===== */
.menu-header{
  position:sticky;
  top:0;
  z-index:999;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 10px 20px;
  background: var(--navy);
  color: var(--off);
  box-shadow: 0 2px 12px rgba(0,0,0,0.35);
}
.brand{display:flex;align-items:center;text-decoration:none;color:var(--off)}
.menu-logo{height:80px;width:auto;margin-right:10px}
.brand-text{display: none;}
.menu-list{list-style:none;margin:0;padding:0;display:flex;gap:14px;align-items:center}
.menu-list a{color:var(--off);text-decoration:none;padding:8px 10px;border-radius:8px;font-weight: bold;}
.menu-list a:hover{background:rgba(255,255,255,0.06)}
.menu-toggle{display:none;background:transparent;border:0;color:var(--green);font-size:40px;padding:8px 12px;cursor:pointer;font-weight: bold;}

/* ===== BANNER ===== */
.banner{
  position:relative;
  background:var(--navy);
  color:var(--off);
  padding:36px 16px;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}
.banner .stars{position:absolute;inset:0;width:100%;height:100%;display:block;z-index:0}
.banner-content{
  position:relative;z-index:2;text-align:center;max-width:var(--max-width);padding:48px 16px;
}

  .banner-title{
    font-size:clamp(28px,5vw,56px);
    margin:0 0;
    font-weight:900;
    letter-spacing:0.02em;
  }
  .banner-sub{margin:8px 0 0;font-size:16px;color:rgba(255,255,255,0.85)}

  #call-to-action {
    margin: 0;
    color: var(--green);
  }

  #call-to-action2 {
    margin: 0;
    margin-bottom: 24px;
  }

/* Apply side margins only on wide screens */
@media (min-width: 900px) {
  .banner-title{
    font-size:clamp(28px,5vw,56px);
    margin:0 0;
    font-weight:900;
    letter-spacing:0.02em;
    width: 66.66%;      /* 4/6 of the container */
    margin-left: auto;  /* centers horizontally */
    margin-right: auto;
  }
  .banner-sub{margin:8px 0 0;font-size:16px;color:rgba(255,255,255,0.85)}

  #call-to-action {
    margin: 0;
    color: var(--green);
    width: 66.66%;      /* 4/6 of the container */
    margin-left: auto;  /* centers horizontally */
    margin-right: auto;
  }

  #call-to-action2 {
    margin: 0;
    margin-bottom: 24px;
    width: 66.66%;      /* 4/6 of the container */
    margin-left: auto;  /* centers horizontally */
    margin-right: auto;
  }

  /* separate register button design in the header */
  #register-header {
    background-color: var(--off);
    color: var(--navy);
  }

  #register-header:hover{background-color:var(--green)}

}

/* ===== HERO CAROUSEL ===== */
.hero-carousel {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 20px;
  margin-top: 24px;
}
.carousel-inner {
  display: flex;
  gap: 40px;
  align-items: center;
  justify-content: center;
}
.cover-wrap {
  flex: 0 0 180px;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.cover-img {
  width: 150px;
  height: 225px;
  object-fit: cover;
  border-radius: 10px;
  box-shadow: var(--shadow-1);
  transition: transform .6s ease, opacity .6s ease;
  display: block;
}
.cta-row {
  display: flex;
  gap: 12px;
  justify-content: center;
  margin-top: 16px;
  flex-wrap: nowrap;
}
.dashboard-wrap {
  flex: 1;
  max-width: 90%;
  text-align: center;
}
.dashboard-card {
  background: transparent;
  border-radius: 14px;
  box-shadow: none;
  display: flex;
  align-items: center;
  justify-content: center;
}
.dashboard-img {
  width: 100%;
  object-fit: cover;
  border-radius: 10px;
  transition: opacity .6s ease, transform .6s ease;
}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 18px;border-radius:10px;text-decoration:none;font-weight:600;cursor:pointer;border:2px solid transparent}
.btn-primary{background:var(--green);color:var(--navy);box-shadow:0 8px 18px rgba(170,37,38,0.18)}
.btn-primary:hover{filter:brightness(1.25)}
.btn-ghost{background:transparent;color:var(--off);border-color:rgba(255,255,255,0.25)}
.btn-ghost:hover{background:rgba(255,255,255,0.08)}
.btn-outline{background:transparent;border:2px solid rgba(15,15,15,0.06);padding:10px 16px}
.btn:active{transform:translateY(0)}
.btn-secondary{background:var(--navy);color:var(--off);box-shadow:0 8px 18px rgba(37, 42, 170, 0.18)}
.btn-secondary:hover{filter:brightness(1.5)}
.btn-tertiary{background:var(--green);color:var(--navy);box-shadow:0 8px 18px rgba(37, 42, 170, 0.18)}
.btn-tertiary:hover{filter:brightness(1.05)}

/* ===== FEATURES ===== */
.features{background:var(--off);padding:36px 20px 20px;margin-top:10px}
.section-title{text-align:center;margin:0 0 22px;font-size:20px;color:#0c1220}
.feature-list{display:grid;grid-template-columns:repeat(5,1fr);gap:22px;max-width:var(--max-width);margin:0 auto;padding:0;list-style:none}
.feature-item{text-align:center}
.feature-icon{width:72px;height:72px;object-fit:contain;border-radius:12px;display:block;margin:0 auto 8px}
.feature-text{font-weight:600}

/* ===== ABOUT PANEL ===== */
.about-panel{background:var(--gray);padding:34px 20px;border-radius:14px;margin:28px auto;max-width:var(--max-width)}
.about-inner{display:flex;gap:18px;align-items:center;flex-wrap: wrap;}
.about-images{flex:2;position:relative;min-height:240px}
.about-img{position:absolute;width:48%;height:240px;object-fit:cover;border-radius:12px;box-shadow:var(--shadow-1)}
.about-img-a{left:0;top:10px;transform:rotate(-6deg)}
.about-img-b{right:0;bottom:10px;transform:rotate(6deg)}
.about-text{flex:1;padding:12px}
.bio-image {
  flex: 1;                 /* let it take space */
  max-width: 50%;        /* prevent it from growing too large */
  height: auto;            /* keep aspect ratio */
  object-fit: contain;     /* fit inside box */
}

/* ===== PRICING ===== */
.pricing{padding:30px 20px;max-width:var(--max-width);margin:0 auto; margin-bottom: 40px;}
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.price-card{background:var(--off);padding:20px;border-radius:12px;box-shadow:var(--shadow-1);min-height:260px;display:flex;flex-direction:column;align-items:start;gap:10px;position:relative}
.price-card .price{display:flex;align-items:baseline;gap:12px}
.price-card .euros{font-size:28px;font-weight:800;}
.price-card .per{font-size:14px;color:#444;}
.price-card .small{font-size:12px;color:#777;margin-left:6px;}
.price-card .price-features{margin:6px 0 12px;padding-left:18px}
.best .badge{position:absolute;top:-12px;left:14px;background:var(--green);color:#222;padding:6px 10px;border-radius:999px;font-weight:800;box-shadow:0 6px 18px rgba(0,0,0,0.1)}

/* ===== BLOG ===== */
.blog{background:var(--off);padding:36px 20px 20px;margin-top:10px}
.section-title{text-align:center;margin:0 0 22px;font-size:20px;color:#0c1220}
.blog-item{text-align:center}
.feature-icon{width:72px;height:72px;object-fit:contain;border-radius:12px;display:block;margin:0 auto 8px}
.blog-list{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;max-width:var(--max-width);margin:0 auto;padding:0;list-style:none}
.feature-text{font-weight:600;margin-bottom:66px;}
.blog-link{color: inherit;text-decoration: none;}
.blog-link:hover{opacity: 0.65;}

/* ===== FOOTER ===== */
.site-footer{background:var(--navy);color:var(--off);padding:20px;border-top:4px solid rgba(255,255,255,0.02)}
.footer-inner{display:flex;justify-content:space-between;align-items:top;max-width:var(--max-width);margin:0 auto}
.footer-logo{height:34px}
.footer-nav a{color:var(--off);text-decoration:none;margin-left:14px}
.footer-nav a:hover{text-decoration:underline}
.address, address{font-style:normal;color:rgba(255,255,255,0.7)}
copyright{display:block}

/* ===== SMALL SCREENS ===== */
@media (max-width: 1000px){
  .blog-list{grid-template-columns:repeat(2,1fr)}
}

@media (max-width: 900px){
  .menu-list{display:none;flex-direction:column;background:var(--navy);position:absolute;right:12px;top:56px;padding:12px;border-radius:8px}
  .menu-toggle{display:inline-block;}
  .carousel-inner{flex-direction:column;align-items:center}
  .cover-wrap{order:2}
  .dashboard-wrap{order:1;width:100%}
  .feature-list{grid-template-columns:repeat(2,1fr)}
  .feature-item:last-child {
    grid-column: 1 / -1;      
    justify-self: center;     
    text-align: center;       
  }
  .about-inner{flex-direction:column}
  .about-images{width:100%;min-height:180px}
  .about-img{position:relative;width:48%;height:160px}
  .about-img-a, .about-img-b{transform:none}
  .pricing-grid{grid-template-columns:1fr;align-items:stretch}
  .brand-text {
    display: block;     
    font-size: 2rem;   
    font-weight: 900;  
    text-align: center;  
  }
  .dashboard-img{max-height:480px;}
  #call-to-action{
    font-size: 1rem;  
  }
  #call-to-action2{
    font-size: 1rem;  
  }
  .bio-image {
    flex: none;       /* don't stretch vertically */
    max-width: 90%;   /* keep width control */
    height: auto;     /* maintain aspect ratio */
    margin: 0 auto;   /* center horizontally */
    display: block;
  }
}

/* Mobile very small */
@media (max-width:580px){
  .feature-list{grid-template-columns:1fr}
  .blog-list{grid-template-columns:repeat(1,1fr)}
}

/* small utilities */
.hidden{display:none}

#cookie-banner {
  position: fixed;
  bottom: 20px;
  right: 20px;
  background: var(--green);
  color: black;
  border-radius: 50%;
  width: 60px;
  height: 60px;
  display: flex;
  justify-content: center;
  align-items: center;
  cursor: pointer;
  z-index: 1000;
  transition: all 0.3s ease-in-out;
  overflow: hidden;
}

#cookie-banner:hover {
  filter:brightness(1.25);
}


#cookie-banner.expanded {
  width: 300px;
  height: auto;
  border-radius: 16px;
  padding: 15px;
  filter:brightness(1);
}

.cookie-content {
  display: none;
  font-size: 14px;
  line-height: 1.4;
}

#cookie-banner.expanded .cookie-content {
  display: block;
}

#cookie-close {
  margin-top: 10px;
  padding: 6px 12px;
  background: var(--navy);
  color: white;
  border: none;
  border-radius: 8px;
  cursor: pointer;
}

#cookie-close:hover {
  filter:brightness(1.5);
}

#cookie-icon {
  width: 90%;              /* scale inside the circle */
  height: 90%;
  object-fit: contain;     /* no stretching */
  pointer-events: none;    /* click goes through to banner */
  transition: opacity 0.3s ease-in-out;
}

#cookie-banner.expanded #cookie-icon {
  display: none;
}

.blog-icon{width:222px;height:auto;object-fit:contain;border-radius:12px;display:flex;margin:0 auto 8px;box-shadow:var(--shadow-1)}