/* =============== OpenHorizon — Global Styles =============== */
:root{
  --bg:#ece8f6;
  --bg-alt:#f6f3ff;

  /* Brand */
  --header:#b8abd8;
  --footer:#4e4769;
  --ink:#2b2836;
  --muted:#6f6a85;

  /* Unified brand gradient (purple family) */
  --brand1:#6f5bd7;     /* primary purple */
  --brand2:#9e7bff;     /* lighter purple */

  --card:#ffffff;
  --radius:12px;
  --shadow:0 10px 28px rgba(76,43,120,0.16);
  --glow:0 0 22px rgba(111,91,215,.22), 0 0 34px rgba(158,123,255,.18);

  --container:min(1200px,92vw);
  scroll-behavior:smooth;

  /* Playful extras */
  --wiggle: cubic-bezier(.34,1.56,.64,1);
  --brand3:#ff8ad6;      /* playful accent */
  --radius-xl: 18px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);
  font-family:"Noto Sans",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{width:var(--container);margin-inline:auto}

/* =============== Header / Nav =============== */
.topbar{
  position:sticky;top:0;z-index:60;background:var(--header);
  backdrop-filter:saturate(1.2) blur(6px);box-shadow:0 1px 0 rgba(0,0,0,.05)
}
.nav{width:var(--container);margin:auto;display:flex;align-items:center;gap:28px;padding:12px 0}
.logo{display:flex;align-items:center;gap:10px;font-weight:800;font-size:20px;letter-spacing:.2px;color:#2e2750}
.logo img{height:56px;border-radius:8px}
.spacer{flex:1}
.menu{display:flex;gap:22px;align-items:center;margin:0;padding:0}
.menu>li{list-style:none;position:relative}
.menu>li>a{
  padding:10px 10px;border-radius:10px;color:#3b2c5f;font-weight:800
}
.menu>li:hover>a,.menu>li:focus-within>a{color:#2a1f54}
.caret{margin-left:6px}
/* Γέφυρα hover: κρατάει ανοιχτό το dropdown όταν κατεβαίνει το ποντίκι */
.menu>li::after{
  content:"";
  position:absolute;
  left:0; right:0;
  top:100%;
  height:10px;              /* μικρή ζώνη hover */
}
/* Dropdown */
.dropdown{
  position:absolute;
  left:0;
  top:100%;
  min-width:270px;
  background:rgba(255,255,255,.92);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  backdrop-filter:blur(10px);
  padding:10px;
  display:none;
  z-index:70;
}
.menu>li:hover .dropdown,
.menu>li:focus-within .dropdown,
.dropdown:hover{ display:block; }

.dropdown a{
  display:block;
  padding:12px 14px;
  border-radius:10px;
  color:#4a4163;
  font-weight:700;
}
.dropdown a:hover{ background:#efe9ff; color:#362764; }  /* FIX: removed stray extra brace */

/* =============== Hero =============== */
/* add to style.css */
.page-hero{padding:54px 0 0}
.page-hero .hero-img{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:16px;box-shadow:var(--shadow)}
.feature-illo img{width:100%;aspect-ratio:21/9;object-fit:cover;border-radius:12px}
.svc-hero img{width:100%;aspect-ratio:16/7;object-fit:cover;border-radius:14px;margin:10px 0 20px}
.cta-band{position:relative;padding:0;margin:40px 0}
.cta-band .cta-bg{width:100%;border-radius:16px;object-fit:cover;aspect-ratio:21/9;filter:saturate(.95)}
.cta-band .cta-content{position:absolute;inset:auto 44px 24px 44px;background:rgba(255,255,255,.0);backdrop-filter:blur(3px);padding:18px;border-radius:12px;box-shadow:var(--shadow)}
.typeline{background:linear-gradient(90deg,#6f5bd7,#9e7bff,#6f5bd7);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  animation: hue 12s linear infinite}
@keyframes hue{0%{filter:hue-rotate(0)}100%{filter:hue-rotate(360deg)}}

.cta-band {
  position: relative;
  padding: 0;
  margin: 40px 0;
}

.cta-band .cta-bg {
  display: block;
  width: 100%;
  border-radius: 16px;
  object-fit: cover;
  aspect-ratio: 21/9;
  filter: saturate(.95);
}

/* wrapper around image + content */
.cta-band .cta-wrap {
  position: relative;
  display: inline-block;
  width: 100%;
}

.cta-band .cta-content {
  position: absolute;
  bottom: 0;         /* stick to bottom of image */
  left: 0;
  right: 0;
}

@media (max-width: 980px){
  .cta-band .cta-content {
    left:0;
    right:0;
    bottom:0;
    top:auto;
    inset:auto 0 0 0;   /* spans full width at bottom */
    border-radius:0 0 16px 16px; /* keep only bottom corners rounded */
  }
}


.eyebrow{ display:none; }
.hero{ position:relative; overflow:hidden; padding:96px 0 52px; }
.hero::before,
.hero::after{
  content:""; position:absolute; width:520px; height:520px; border-radius:50%;
  filter:blur(48px); opacity:.28; z-index:0;  /* slightly more alive */
}
.hero::before{
  background:radial-gradient(circle at 30% 30%, var(--brand2), transparent 60%);
  top:-160px; left:-120px; animation:float1 12s ease-in-out infinite;
}
.hero::after{
  background:radial-gradient(circle at 70% 60%, var(--brand1), transparent 60%);
  bottom:-220px; right:-180px; animation:float2 14s ease-in-out infinite;
}
@keyframes float1{ 0%{transform:translateY(0)} 50%{transform:translateY(18px)} 100%{transform:translateY(0)} }
@keyframes float2{ 0%{transform:translateY(0)} 50%{transform:translateY(-16px)} 100%{transform:translateY(0)} }

.hero .reveal, .hero .slide-left{ position:relative; z-index:1; }
.hero-wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:36px;align-items:center}
.h1{
  font-family:"Noto Serif",serif;font-weight:700;line-height:1.08;
  font-size:clamp(34px,4.3vw,56px);color:#2d2250;margin:6px 0 10px
}
.lead{font-size:18px;color:var(--muted);max-width:60ch}
.cta{display:flex;gap:12px;margin-top:22px}

/* Buttons */
.btn{
  padding:12px 18px;border-radius:var(--radius);border:none;cursor:pointer;font-weight:800;
  transition:transform .15s ease, box-shadow .2s ease, background .2s ease, filter .2s ease;
  position:relative; overflow:hidden; transform: translateZ(0);
}
.btn-primary{
  background:linear-gradient(90deg,var(--brand1),var(--brand2));
  color:#fff; box-shadow:var(--glow);
}
.btn-primary:hover{ transform:translateY(-2px) scale(1.02); filter:saturate(1.05); }
.btn-ghost{
  background:#ffffff; color:#3a2d63; border:2px solid #e6defb;
}
.btn-ghost:hover{ background:#f7f4ff; transform: translateY(-2px) scale(1.02); }

/* Shiny sweep + sparkle (playful) */
.btn-primary::before{
  content:""; position:absolute; top:-50%; left:-30%;
  width:40%; height:200%;
  background:linear-gradient(130deg, rgba(255,255,255,0), rgba(255,255,255,.38), rgba(255,255,255,0));
  transform:skewX(-20deg) translateX(-120%);
  transition: transform .6s var(--wiggle);
  pointer-events:none;
}
.btn-primary:hover::before{ transform:skewX(-20deg) translateX(260%); }
.btn-primary .star{
  --s: 16px;
  position:absolute; width:var(--s); height:var(--s); right:12px; top:10px;
  background:
    radial-gradient(circle at 50% 50%, #fff 32%, rgba(255,255,255,0) 33%),
    conic-gradient(from 0deg, rgba(255,255,255,.85), rgba(255,255,255,.2) 20%, rgba(255,255,255,0) 60%, rgba(255,255,255,.85));
  mask: radial-gradient(circle at 50% 50%, #000 60%, transparent 61%);
  opacity:0; transform: scale(.6) rotate(0deg);
  transition: transform .5s var(--wiggle), opacity .3s ease;
  pointer-events:none;
}
.btn-primary:hover .star{ opacity:1; transform: scale(1) rotate(20deg); }

/* =============== Sections / Cards / Grid =============== */
section{padding:70px 0}
.section-title{font-family:"Noto Serif",serif;font-weight:700;font-size:32px;margin:0 0 8px}
.section-lead{color:var(--muted);margin-bottom:26px}
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:20px}

/* ==== Playful Cards ==== */
.card{
  position: relative;
  grid-column: span 4;
  border-radius: var(--radius);
  border: 1px solid #e6defb;
  background:
    linear-gradient(180deg,#ffffff 0%, #f7f3ff 100%); /* base */
  padding: 22px;
  box-shadow: var(--shadow);
  transition:
    transform .22s ease,
    box-shadow .25s ease,
    border-color .25s ease,
    background .25s ease;
  overflow: hidden;
}

/* soft pattern + glow that animates on hover */
.card::before{
  content:"";
  position:absolute; inset:-1px;
  border-radius: inherit;
  background:
    radial-gradient(120% 120% at 0% 0%, rgba(158,123,255,.10) 0%, transparent 55%),
    radial-gradient(140% 140% at 100% 100%, rgba(111,91,215,.10) 0%, transparent 60%);
  opacity:.0; filter: saturate(1.1);
  transition: opacity .25s ease;
  pointer-events:none;
  z-index:0;
}

/* shiny sweep line */
.card::after{
  content:"";
  position:absolute; inset:-60%;
  background: linear-gradient(120deg, transparent 45%, rgba(255,255,255,.55) 50%, transparent 55%);
  transform: translateX(-60%) rotate(15deg);
  opacity:.0; pointer-events:none;
  transition: transform .8s ease, opacity .3s ease;
}

/* text lives above effects */
.card > *{ position:relative; z-index:1; }

.card:hover{
  transform: translateY(-6px);
  border-color:#cfc3f7;
  background: linear-gradient(180deg,#ffffff 0%, #efe9ff 60%, #f5eeff 100%);
  box-shadow:
    0 18px 44px rgba(80,54,170,.22),
    0 0 0 1px rgba(158,123,255,.30) inset;
}
.card:hover::before{ opacity:1; }
.card:hover::after{ transform: translateX(60%) rotate(15deg); opacity:.35; }

/* optional: tiny tilt for cards you marked with .tilt-on */
.tilt-on{ transform-style: preserve-3d; }
.tilt-on:hover{ transform: translateY(-8px) rotateX(.8deg) rotateY(-.8deg); }

/* keep your tags & headings but make hover color pop a bit */
.card h3{ display:flex; align-items:center; gap:8px; color:#2e205c; }
.card:hover h3{ color:#3b22a0; }
.card .tag{
  display:inline-block;
  background: linear-gradient(90deg,#efe9ff,#f6f2ff);
  color:#4a2dbb; border:1px solid #e0d7ff;
  padding:6px 10px; border-radius:999px; font-size:12px; font-weight:800;
}

/* motion safety */
@media (prefers-reduced-motion: reduce){
  .card, .tilt-on:hover{ transform:none !important; }
  .card::after{ display:none; }
}

.tag{
  display:inline-block;
  background:linear-gradient(90deg,#ffe9f7,#efe9ff);
  color:#5a2dbb;
  border:1px solid #e6c7ff;
  padding:6px 10px;border-radius:999px;font-size:12px;font-weight:800
}

/* Card icons */
.card h3{display:flex;align-items:center;gap:8px}
.icon{width:20px;height:20px;vertical-align:-3px;opacity:.95}

.muted{color:var(--muted)}

/* Optional playful tilt */
.tilt-on{ will-change: transform; transform-style: preserve-3d; transition: transform .18s ease; }
.tilt-on:hover{ transform: perspective(700px) rotateX(4deg) rotateY(-4deg) translateY(-4px); }

/* Gradient animated headline (playful) */
.wow-title{
  background: linear-gradient(90deg, var(--brand1), var(--brand3), var(--brand2));
  -webkit-background-clip: text; background-clip: text; color: transparent;
  background-size: 200% 100%; animation: hue-sweep 8s linear infinite;
}
@keyframes hue-sweep { to { background-position: 200% 0; } }

/* Projects (cards + accordion) */
.project{
  background:linear-gradient(180deg,#ffffff 0%, #f7f3ff 100%);
  border:1px solid #e8e1f9;
  border-radius:var(--radius);
  padding:18px 18px 14px;
  box-shadow:var(--shadow);
  outline: none; 
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  cursor:pointer; position:relative;
}
.project + .project{ margin-top:16px; }
.project:hover{
  transform:translateY(-3px);
  box-shadow:0 16px 36px rgba(80,54,170,.16);
  border-color:#dbcff8;
}
.project .head{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
}
.project h4{ margin:4px 0 6px; font-weight:800; }
.project .chev{
  width:20px; height:20px; flex:none; opacity:.8; transition:transform .25s ease;
}
.project.is-open .chev{ transform:rotate(180deg); }
.project:hover h4{ color:#3b22a0; }
.project:hover{
  transform: translateY(-6px);
  border-color:#cfc3f7;
  background: linear-gradient(180deg,#ffffff 0%, #efe9ff 60%, #f5eeff 100%);
  box-shadow:
    0 18px 44px rgba(80,54,170,.22),
    0 0 0 1px rgba(158,123,255,.30) inset;
}
.project:hover::before{ opacity:1; }
.project:hover::after{ transform: translateX(60%) rotate(15deg); opacity:.35; }
/* summary + details */
.project .summary{ color:var(--muted); margin:2px 0 0; }
.project .details{
  height: 0; overflow: hidden; opacity: 0; margin-top: 0;
  transition:
    height 320ms cubic-bezier(.2,.7,.3,1),
    opacity 320ms ease,
    margin-top 320ms ease;
  will-change: height, opacity, margin-top;
}
.project.is-open .details{ margin-top: 8px; }
.project .details h5{ margin:6px 0 8px; font-size:16px; }
.project .details ul{ margin:0; padding-left:18px; color:var(--muted); }
.project:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px rgba(111,91,215,.28), 0 16px 36px rgba(80,54,170,.16);
  border-color: #cfc3f7;
}

/* Footer spacing (keep simple on index) */
section:last-of-type { padding-bottom: 24px; }

/* Footer */
footer{background:var(--footer);color:#d8d3eb;padding:26px 0;margin-top:60px}
.foot{width:var(--container);margin:auto;display:flex;align-items:center;justify-content:space-between}
.foot small{opacity:.85}

/* Contact */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.field{display:flex;flex-direction:column;gap:8px}
input,textarea{
  padding:12px 14px;border-radius:var(--radius);border:1px solid #d7cffe;background:#fff;font:inherit
}
textarea{min-height:140px;resize:vertical}

/* Splash */
.splash{
  position:fixed;inset:0;background:linear-gradient(135deg,#b8abd8 0%, #d9d2ee 100%);
  display:grid;place-items:center;z-index:1000;transition:opacity .6s ease;opacity:1
}
.splash.hidden{opacity:0;pointer-events:none}
.spinner{
  width:74px;height:74px;border-radius:50%;
  border:6px solid rgba(255,255,255,.6);border-top-color:#5b2bd9;animation:spin 1s linear infinite;box-shadow:0 0 40px rgba(91,43,217,.35)
}
@keyframes spin{to{transform:rotate(360deg)}}

/* Scroll reveal */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s ease, transform .7s ease}
.reveal.in{opacity:1;transform:none}
.slide-left{opacity:0;transform:translateX(-24px);transition:.8s ease}
.slide-left.in{opacity:1;transform:none}

/* Breadcrumb */
.breadcrumb{padding:18px 0 0;color:#584b87;font-weight:700;font-size:14px}
.breadcrumb a{opacity:.9}
.breadcrumb a:hover{text-decoration:underline}

/* Mobile drawer – global defs */
.drawer{
  position:fixed;
  inset:70px 0 0 0;
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(6px);
  display:none;
  z-index:55;
}
.drawer.open{ display:block; }
.drawer ul{ list-style:none; margin:0; padding:20px; }
.drawer a{ display:block; padding:12px 8px; font-weight:800; color:#3a2d63; }
.drawer .sub a{ padding-left:18px; font-weight:600; }

/* =============== Mobile =============== */
.burger{display:none}
@media (max-width: 980px){
  .hero-wrap{grid-template-columns:1fr}
  .card{grid-column:span 12}
  .contact{grid-template-columns:1fr}

}
@media (max-width:900px){
  .menu{ display:none; }
  .burger{ display:inline-flex; align-items:center; gap:8px; padding:8px 12px;
           border-radius:10px; background:#cbbef0; font-weight:800; border:0; color:#2e2750; }
}

/* =============== Per-letter typing (no flashes) =============== */
.typeline{
  white-space: pre-wrap;
  contain: content;
  transform: translateZ(0);
  backface-visibility: hidden;
}
.type-char{ visibility: hidden; }      /* occupies space -> no layout shift */
.type-char.show{ visibility: visible; }

@media (prefers-reduced-motion: reduce){
  .type-char{ visibility: visible; }
}







/* ====== Page layout: sticky footer only for pages with .page class ====== */
.page{ min-height:100dvh; display:flex; flex-direction:column; }
.page main{ flex:1 0 auto; }

/* ====== Contact hero tweaks (playful blobs + framed image) ====== */
.page-contact .hero{ padding:82px 0 46px; }
.contact-hero::before,
.contact-hero::after{
  content:""; position:absolute; width:520px; height:520px; border-radius:50%;
  filter:blur(48px); opacity:.25; z-index:0;
}
.contact-hero::before{ background:radial-gradient(circle at 20% 30%, var(--brand2), transparent 60%); top:-180px; left:-140px; animation:float1 12s ease-in-out infinite; }
.contact-hero::after{ background:radial-gradient(circle at 80% 70%, var(--brand1), transparent 60%); bottom:-240px; right:-180px; animation:float2 14s ease-in-out infinite; }
.contact-hero .reveal, .contact-hero .slide-left{ position:relative; z-index:1; }

.contact-hero-img{
  border-radius:16px;
  box-shadow:var(--shadow);
  aspect-ratio:16/10;
  object-fit:cover;
}

/* ====== Grid for contact content ====== */
.contact-grid{
  display:grid; grid-template-columns: 1.2fr .8fr; gap:24px;
}
@media (max-width: 980px){
  .contact-grid{ grid-template-columns: 1fr; }
}

/* ====== Cards reused but with livelier finish ====== */
.card{
  position:relative; overflow:hidden;
  background: linear-gradient(180deg,#ffffff 0%, #f7f3ff 100%);
  border:1px solid #e8e1f9; border-radius: var(--radius-xl, 16px);
  box-shadow: var(--shadow);
  transition: transform .22s ease, box-shadow .25s ease, border-color .25s ease, background .25s ease;
}
.card:hover{ transform: translateY(-6px); border-color:#cfc3f7; box-shadow:0 18px 44px rgba(80,54,170,.22); }

/* ====== Form card ====== */
.form-card{ padding:22px; }
.form-card .field{ display:flex; flex-direction:column; gap:8px; margin-bottom:12px; }
.form-card .field.two{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
@media (max-width: 680px){ .form-card .field.two{ grid-template-columns:1fr; } }

.form-card input, .form-card textarea{
  padding:12px 14px; border-radius:12px; border:1px solid #d7cffe; background:#fff; font:inherit;
  transition: box-shadow .2s ease, border-color .2s ease, transform .06s ease;
}
.form-card input:focus, .form-card textarea:focus{
  outline:none; border-color:#c2b5ff;
  box-shadow: 0 0 0 3px rgba(111,91,215,.18);
}
.form-card input:hover, .form-card textarea:hover{ border-color:#cfc3f7; }

/* ====== Info card ====== */
.info-card{ padding:0 0 18px; }
.info-banner img{ width:100%; aspect-ratio:16/8; object-fit:cover; border-radius:16px 16px 0 0; display:block; }
.info-title{ margin:14px 18px 10px; font-weight:800; }
.info-sub{ margin:6px 18px 6px; font-weight:800; }

.info-card .muted{ margin: 0 18px; }
.info-card .divider{ height:1px; background:#ece6ff; margin:14px 18px; border-radius:1px; }

/* Pills (mail / phone) */
.pill{
  margin: 10px 18px 0;
  display:inline-flex; align-items:center; gap:10px;
  padding:10px 12px; border-radius:999px; font-weight:800; text-decoration:none;
  background: linear-gradient(90deg,#efe9ff,#f7f3ff);
  border:1px solid #e0d7ff; color:#3a2d63;
  transition: transform .18s var(--wiggle), box-shadow .2s ease, border-color .2s;
}
.pill svg{ opacity:.9; }
.pill:hover{ transform: translateY(-2px); border-color:#cfc3f7; box-shadow:0 10px 24px rgba(80,54,170,.14); }

/* Toast for form submit */
.toast{
  position: fixed; left: 50%; bottom: 28px; transform: translate(-50%, 20px);
  background: #2b2836; color:#fff; padding:12px 16px; border-radius:12px;
  box-shadow: var(--shadow); opacity:0; transition: opacity .22s ease, transform .22s var(--wiggle);
  z-index: 9999; font-weight:800;
}
.toast.in{ opacity:1; transform: translate(-50%, 0); }

/* Keep footer tight to content but still full width */
.page footer{ margin-top: 0; width:100%; }



/* ===== Fancy Contact Form ===== */
.fancy-form{
  --ring: rgba(111,91,215,.22);
  --ring-strong: rgba(111,91,215,.42);
  --grad: linear-gradient(135deg, #fff 0%, #f8f5ff 40%, #f2eaff 100%);
  --border: #e6defb;
  padding: 22px;
  border-radius: 18px;
  background: var(--grad);
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
  position: relative;
  overflow: hidden;
}
.fancy-form::before{
  content:"";
  position:absolute; inset:-1px;
  border-radius: inherit;
  background:
    radial-gradient(80% 80% at 20% 0%, rgba(158,123,255,.12), transparent 60%),
    radial-gradient(90% 90% at 100% 100%, rgba(111,91,215,.10), transparent 60%);
  pointer-events:none;
  transition: opacity .3s ease;
  opacity:.9;
}
.fancy-form:hover{ transform: translateY(-4px); transition: transform .2s var(--wiggle); }
.form-header{ margin-bottom: 8px; }

/* quick topic chips */
.chips{ display:flex; flex-wrap:wrap; gap:8px; margin:10px 0 14px; }
.chip{
  border:1px solid #e0d7ff; background:linear-gradient(90deg,#efe9ff,#f7f3ff);
  padding:8px 12px; border-radius:999px; font-weight:800; cursor:pointer;
  transition: transform .15s var(--wiggle), box-shadow .2s ease, border-color .2s ease;
}
.chip:hover{ transform: translateY(-2px); border-color:#cfc3f7; box-shadow:0 8px 20px rgba(80,54,170,.14); }
.chip.active{ background:linear-gradient(90deg,var(--brand1),var(--brand2)); color:#fff; border-color:transparent; }

/* two-column rows */
.fancy-form .field.two{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
@media (max-width: 680px){ .fancy-form .field.two{ grid-template-columns:1fr; } }

/* floating labels */
.control{ position:relative; }
.control input,
.control textarea,
.control select{
  width:100%;
  padding: 14px 14px 14px 42px;   /* leave room for icon */
  border-radius: 12px;
  border:1px solid #d7cffe;
  background:#fff;
  font:inherit; color:inherit;
  transition: border-color .2s ease, box-shadow .2s ease, transform .06s ease;
}
.control textarea{ min-height: 140px; resize: vertical; }
.control select{ appearance:none; background-image:none; }

/* labels */
.control label{
  pointer-events:none;
  position:absolute; left:42px; top:50%;
  transform: translateY(-50%);
  color:#8a83a8; font-weight:700; letter-spacing:.2px;
  transition: transform .15s ease, font-size .15s ease, color .15s ease, top .15s ease, left .15s ease;
  background: transparent;
}

/* when focused or filled */
.control input:focus,
.control textarea:focus,
.control select:focus{ outline:none; border-color:#c2b5ff; box-shadow:0 0 0 4px var(--ring); }
.control input:not(:placeholder-shown) + label,
.control textarea:not(:placeholder-shown) + label,
.control select:valid + label,
.control input:focus + label,
.control textarea:focus + label,
.control select:focus + label{
  top: 0; left: 38px;
  transform: translateY(-50%) scale(.86);
  background: linear-gradient(90deg,#fff,#fff);
  padding: 0 6px;
  color:#5746a6;
}

/* icons inside controls */
.icon-left .ico{
  position:absolute; left:12px; top:50%; transform:translateY(-50%);
  width:18px; height:18px; opacity:.9; color:#6b5aa9;
}

/* selects caret */
.select-wrap .ico{ pointer-events:none; left:auto; right:12px; }

/* checkbox pill */
.pill-check{ display:flex; align-items:center; gap:10px; font-weight:700; margin:14px 0 6px; cursor:pointer; }
.pill-check input{ position:absolute; opacity:0; }
.pill-check span{
  flex:none; width:22px; height:22px; border-radius:6px; border:2px solid #cdbfff; background:#fff;
  display:grid; place-items:center; transition: all .18s var(--wiggle);
  box-shadow: 0 1px 0 rgba(0,0,0,.05);
}
.pill-check input:checked + span{
  border-color: transparent; background: linear-gradient(90deg,var(--brand1),var(--brand2)); box-shadow: var(--glow);
}
.pill-check input:checked + span::after{
  content:""; width:10px; height:10px; border-radius:3px; background:#fff;
}

/* primary button bigger on forms */
.btn-big{ padding:14px 20px; font-size:16px; margin-top: 15px; }

/* success state */
.form-done{
  position:absolute; inset:0; display:grid; place-content:center;
  gap:8px; text-align:center; background:rgba(255,255,255,.92); backdrop-filter: blur(8px);
  border-radius: inherit; opacity:0; pointer-events:none; transform: scale(.98);
  transition: opacity .28s ease, transform .28s var(--wiggle);
}
.form-done .done-mark{
  width:70px; height:70px; border-radius:50%;
  margin:0 auto 4px; display:grid; place-items:center;
  background: linear-gradient(90deg,var(--brand1),var(--brand2)); color:#fff;
  box-shadow: var(--glow);
  animation: pop .5s var(--wiggle) both;
}
.form-done h3{ margin:6px 0 0; }
@keyframes pop{ from{ transform: scale(.5); opacity:.4 } to{ transform: scale(1); opacity:1 } }
.fancy-form.done .form-done{ opacity:1; transform: scale(1); pointer-events:auto; }

/* textarea autosize visual nicety */
.control textarea:focus{ transition: box-shadow .2s ease, border-color .2s ease; }

/* Info card spacing */
.info-card{ padding:0 0 18px; }

/* Contact layout (kept from earlier) */
.contact-grid{ display:grid; grid-template-columns: 1.2fr .8fr; gap:24px; }
@media (max-width: 980px){ .contact-grid{ grid-template-columns: 1fr; } }

/* Strengthen hero image */
.contact-hero-img{ border-radius:16px; box-shadow:var(--shadow); aspect-ratio:16/10; object-fit:cover; }
