/* InTeLab — Shared cartoon design system
   Loaded by: index, paidia, enilikes, scholeia, diagonismoi, sxetika, epikoinonia
*/
:root{
  --bg:#FAF7F2; --bg-alt:#FFFFFF; --bg-dark:#0a0612;
  --fg:#0a0612; --fg-dim:#5a5160; --fg-mute:#8a818f;
  --cyan:#1FC0DC; --cyan-deep:#0E8FA6;
  --magenta:#EC048C; --magenta-deep:#A8035F;
  --yellow:#FFE94A;
  --border:rgba(10,6,18,.1);
  --shadow-cartoon:6px 6px 0 var(--fg);
  --shadow-cartoon-lg:10px 10px 0 var(--fg);
  --radius-md:14px; --radius-lg:24px;
  --easing-bounce:cubic-bezier(.34,1.56,.64,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg); color:var(--fg); font-family:'DM Sans',system-ui,sans-serif; font-weight:400; line-height:1.55; overflow-x:hidden; min-height:100vh}
img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
button{font-family:inherit; cursor:pointer; border:none; background:none}
::selection{background:var(--magenta); color:#fff}

[hidden]{display:none !important}

.skip{position:absolute; left:-9999px; top:0; padding:12px 18px; background:var(--magenta); color:#fff; font-weight:700; z-index:200}
.skip:focus{left:12px; top:12px}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; scroll-behavior:auto !important}
  .marquee, .tickerband__row{animation:none !important}
}

/* ═════════════════ NAVIGATION ═════════════════ */
.nav{position:fixed; top:0; left:0; right:0; z-index:80; display:flex; align-items:center; justify-content:space-between; padding:14px 28px; background:rgba(250,247,242,.85); backdrop-filter:blur(20px); border-bottom:1px solid var(--border); transition:transform .3s ease}
.nav.is-hidden{transform:translateY(-100%)}
.nav__brand{display:flex; align-items:center; gap:12px; font-family:'Bricolage Grotesque'; font-weight:800; font-size:22px; letter-spacing:-.025em; color:var(--fg)}
.nav__brand img{height:38px; width:auto; transition:transform .3s var(--easing-bounce)}
.nav__brand:hover img{transform:rotate(-8deg) scale(1.08)}
.nav__menu{display:flex; gap:28px; font-size:15px; font-weight:500}
.nav__menu a{position:relative; padding:6px 0; transition:color .2s}
.nav__menu a::after{content:""; position:absolute; left:0; right:0; bottom:-2px; height:3px; background:var(--magenta); transform:scaleX(0); transform-origin:right; transition:transform .3s var(--easing-bounce)}
.nav__menu a:hover{color:var(--magenta)}
.nav__menu a:hover::after, .nav__menu a.is-active::after{transform:scaleX(1); transform-origin:left}
.nav__right{display:flex; align-items:center; gap:14px}
.lang-toggle{display:flex; align-items:center; padding:5px; background:var(--fg); border-radius:100px; font-family:'Bricolage Grotesque'; font-weight:700; font-size:12px}
.lang-toggle button{padding:6px 12px; color:rgba(250,247,242,.5); border-radius:100px; transition:all .25s; letter-spacing:.05em}
.lang-toggle button.is-active{background:var(--magenta); color:#fff}
.nav__cta{padding:11px 22px; font-size:14px; font-weight:700; background:var(--magenta); color:#fff; border-radius:100px; transition:transform .25s var(--easing-bounce), box-shadow .25s; display:inline-flex; align-items:center; gap:8px}
.nav__cta:hover{transform:translateY(-3px) rotate(-2deg); box-shadow:0 8px 24px rgba(236,4,140,.4)}
.hamburger{display:none; flex-direction:column; gap:5px; width:42px; height:42px; align-items:center; justify-content:center; border-radius:50%; background:var(--fg); border:none; transition:transform .3s var(--easing-bounce)}
.hamburger span{display:block; width:18px; height:2px; background:var(--bg); border-radius:2px; transition:all .3s}
.hamburger:hover{transform:rotate(90deg)}
@media (max-width:1080px){
  .nav__menu, .nav__cta{display:none}
  .hamburger{display:flex}
}

.sidebar-overlay{position:fixed; inset:0; z-index:90; background:rgba(10,6,18,.6); backdrop-filter:blur(8px); opacity:0; pointer-events:none; transition:opacity .3s}
.sidebar-overlay.is-open{opacity:1; pointer-events:auto}
.sidebar{position:fixed; top:0; left:0; bottom:0; z-index:100; width:min(360px,85vw); background:var(--bg); border-right:3px solid var(--fg); padding:24px; transform:translateX(-100%); transition:transform .4s var(--easing-bounce); display:flex; flex-direction:column; gap:8px; overflow-y:auto}
.sidebar.is-open{transform:translateX(0)}
.sidebar__head{display:flex; justify-content:space-between; align-items:center; margin-bottom:24px}
.sidebar__brand{display:flex; align-items:center; gap:10px; font-family:'Bricolage Grotesque'; font-weight:800; font-size:20px}
.sidebar__brand img{height:32px}
.sidebar__close{width:42px; height:42px; border-radius:50%; background:var(--fg); color:var(--bg); display:flex; align-items:center; justify-content:center; transition:transform .25s}
.sidebar__close:hover{transform:rotate(90deg)}
.sidebar__close svg{width:18px; height:18px}
.sidebar__menu{display:flex; flex-direction:column; gap:4px}
.sidebar__menu a{padding:14px 16px; font-family:'Bricolage Grotesque'; font-weight:600; font-size:18px; border-radius:12px; transition:all .2s; display:flex; justify-content:space-between; align-items:center}
.sidebar__menu a::after{content:"→"; opacity:.4; font-size:20px}
.sidebar__menu a:hover, .sidebar__menu a.is-active{background:var(--magenta); color:#fff; transform:translateX(4px)}
.sidebar__menu a:hover::after, .sidebar__menu a.is-active::after{opacity:1}
.sidebar__lang{margin-top:20px; padding-top:20px; border-top:1px dashed var(--border); display:flex; gap:10px; justify-content:center}
.sidebar__lang button{padding:10px 22px; font-family:'Bricolage Grotesque'; font-weight:700; border:2px solid var(--fg); border-radius:100px; transition:all .2s}
.sidebar__lang button.is-active{background:var(--magenta); color:#fff; border-color:var(--magenta)}
.sidebar__cta{margin-top:20px; padding:18px; background:var(--magenta); color:#fff; border-radius:14px; font-family:'Bricolage Grotesque'; font-weight:700; font-size:16px; text-align:center; transition:transform .25s var(--easing-bounce)}
.sidebar__cta:hover{transform:scale(1.03) rotate(-1deg)}

/* ═════════════════ PAGE HEADER (smaller hero for inner pages) ═════════════════ */
.page-hero{position:relative; padding:140px 32px 80px; overflow:hidden; text-align:center; background:var(--bg)}
.page-hero__bg{position:absolute; inset:0; z-index:0; pointer-events:none; overflow:hidden}
.page-hero__blob{position:absolute; border-radius:50%; filter:blur(90px); opacity:.45}
.page-hero__blob--1{width:520px; height:520px; background:var(--cyan); top:-180px; right:-150px; animation:float1 14s ease-in-out infinite}
.page-hero__blob--2{width:440px; height:440px; background:var(--magenta); bottom:-160px; left:-140px; animation:float2 18s ease-in-out infinite}
.page-hero__content{position:relative; z-index:2; max-width:900px; margin:0 auto}
.page-hero__pill{display:inline-flex; align-items:center; gap:10px; padding:8px 18px; margin-bottom:24px; background:var(--fg); color:var(--bg); border-radius:100px; font-family:'Bricolage Grotesque'; font-weight:700; font-size:13px; letter-spacing:.05em}
.page-hero__pill::before{content:""; width:8px; height:8px; border-radius:50%; background:var(--yellow); animation:blink 1.4s infinite}
.page-hero__title{font-family:'Bricolage Grotesque'; font-weight:800; font-size:clamp(44px,7vw,96px); line-height:1; letter-spacing:-.04em; margin-bottom:24px}
.page-hero__title .pop{color:var(--magenta); font-style:italic}
.page-hero__title .pop-cyan{color:var(--cyan-deep); font-style:italic}
.page-hero__title .stroke{-webkit-text-stroke:3px var(--fg); color:transparent; font-style:italic}
.page-hero__sub{font-size:clamp(17px,1.4vw,20px); color:var(--fg-dim); max-width:640px; margin:0 auto; font-weight:400}
.page-hero__crumbs{display:inline-flex; gap:8px; align-items:center; margin-top:30px; font-family:'Caveat',cursive; font-size:18px; color:var(--fg-mute)}
.page-hero__crumbs a:hover{color:var(--magenta)}
.page-hero__crumbs span{opacity:.5}
@media(max-width:768px){.page-hero{padding:110px 20px 60px}}

/* ═════════════════ HOMEPAGE HERO (split) ═════════════════ */
.hero{position:relative; min-height:100vh; min-height:100dvh; padding:120px 32px 60px; display:grid; grid-template-columns:1.05fr 1fr; align-items:center; gap:40px; overflow:hidden}
@media(max-width:980px){.hero{grid-template-columns:1fr; padding:110px 20px 50px; text-align:center; min-height:auto}}
.hero__bg{position:absolute; inset:0; z-index:0; pointer-events:none; overflow:hidden}
.hero__blob{position:absolute; border-radius:50%; filter:blur(90px); opacity:.45}
.hero__blob--1{width:600px; height:600px; background:var(--cyan); top:-200px; right:-180px; animation:float1 14s ease-in-out infinite}
.hero__blob--2{width:520px; height:520px; background:var(--magenta); bottom:-180px; left:-160px; animation:float2 18s ease-in-out infinite}
.hero__blob--3{width:280px; height:280px; background:var(--yellow); top:40%; left:30%; animation:float3 12s ease-in-out infinite; opacity:.25}
@keyframes float1{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(60px,40px) scale(1.1)}}
@keyframes float2{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-50px,-30px) scale(1.15)}}
@keyframes float3{0%,100%{transform:translate(0,0)}33%{transform:translate(20px,-15px)}66%{transform:translate(-15px,10px)}}
.deco{position:absolute; pointer-events:none; z-index:1}
.deco--star1{top:18%; right:46%; width:48px; animation:wobble 4s ease-in-out infinite}
.deco--star2{bottom:22%; left:8%; width:34px; animation:wobble 5s ease-in-out infinite reverse}
.deco--bolt{top:30%; right:8%; width:64px; animation:swing 3s ease-in-out infinite}
.deco--sparkle1{top:8%; left:42%; width:24px; animation:twinkle 2s ease-in-out infinite}
.deco--sparkle2{bottom:30%; right:55%; width:20px; animation:twinkle 2.5s ease-in-out infinite .3s}
@keyframes wobble{0%,100%{transform:rotate(-8deg) scale(1)}50%{transform:rotate(8deg) scale(1.08)}}
@keyframes swing{0%,100%{transform:rotate(-12deg)}50%{transform:rotate(12deg)}}
@keyframes twinkle{0%,100%{opacity:.3; transform:scale(.8)}50%{opacity:1; transform:scale(1.2)}}

.hero__content{position:relative; z-index:3}
.hero__pill{display:inline-flex; align-items:center; gap:10px; padding:8px 18px; margin-bottom:28px; background:var(--fg); color:var(--bg); border-radius:100px; font-family:'Bricolage Grotesque'; font-weight:700; font-size:13px; letter-spacing:.05em; opacity:0; animation:rise .8s .3s forwards}
.hero__pill::before{content:""; width:8px; height:8px; border-radius:50%; background:var(--yellow); animation:blink 1.4s infinite}
@keyframes blink{0%,100%{opacity:1; transform:scale(1)}50%{opacity:.4; transform:scale(.7)}}
.hero__title{font-family:'Bricolage Grotesque'; font-weight:800; font-size:clamp(48px,8.5vw,120px); line-height:.93; letter-spacing:-.045em; margin-bottom:28px; opacity:0; animation:rise .9s .5s forwards}
.hero__title .stroke{-webkit-text-stroke:3px var(--fg); color:transparent; font-style:italic}
.hero__title .pill{display:inline-block; background:var(--magenta); color:var(--bg); padding:0 24px; border-radius:100px; transform:rotate(-2deg)}
.hero__title .underline{position:relative; white-space:nowrap}
.hero__title .underline svg{position:absolute; left:-4%; right:-4%; bottom:-12%; width:108%; height:.4em; pointer-events:none; z-index:-1}
.hero__title .underline svg path{fill:none; stroke:var(--cyan); stroke-width:8; stroke-linecap:round}
.hero__sub{font-size:clamp(17px,1.5vw,21px); color:var(--fg-dim); font-weight:400; max-width:520px; margin-bottom:34px; opacity:0; animation:rise .9s .7s forwards}
@media(max-width:980px){.hero__sub{margin-left:auto; margin-right:auto}}
.hero__ctas{display:flex; gap:14px; flex-wrap:wrap; opacity:0; animation:rise .9s .9s forwards}
@media(max-width:980px){.hero__ctas{justify-content:center}}
.btn{padding:18px 30px; font-size:15px; font-weight:700; border-radius:100px; font-family:inherit; display:inline-flex; align-items:center; gap:10px; transition:all .25s var(--easing-bounce)}
.btn--primary{background:var(--fg); color:var(--bg)}
.btn--primary:hover{background:var(--magenta); transform:translateY(-3px) rotate(-2deg); box-shadow:0 12px 26px rgba(236,4,140,.35)}
.btn--ghost{background:transparent; color:var(--fg); border:2px solid var(--fg)}
.btn--ghost:hover{background:var(--fg); color:var(--bg); transform:translateY(-3px) rotate(2deg)}
.btn--accent{background:var(--magenta); color:#fff}
.btn--accent:hover{background:var(--fg); transform:translateY(-3px) rotate(-2deg)}
@keyframes rise{from{opacity:0; transform:translateY(28px)}to{opacity:1; transform:translateY(0)}}

.hero__visual{position:relative; z-index:2; display:flex; align-items:center; justify-content:center}
.hero__canvas-wrap{position:relative; width:100%; max-width:560px; min-height:580px; display:flex; align-items:center; justify-content:center}
.hero__canvas-wrap canvas{position:absolute; inset:0; display:none}
.hero__mascot{position:absolute; width:34%; z-index:6; top:-5%; right:-6%; filter:drop-shadow(0 24px 50px rgba(236,4,140,.42)); animation:bob 4s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0) rotate(-3deg)}50%{transform:translateY(-12px) rotate(4deg)}}
.hero__video-badge{position:absolute; bottom:-8%; left:0; z-index:5; background:var(--yellow); color:var(--fg); padding:14px 22px; border-radius:18px; border:3px solid var(--fg); font-family:'Caveat',cursive; font-weight:700; font-size:22px; line-height:1; transform:rotate(-6deg); display:flex; align-items:center; gap:10px; animation:wobble 6s ease-in-out infinite; white-space:nowrap}
.hero__video-badge::before{content:"▶"; font-family:inherit; font-size:18px; color:var(--magenta)}
.hero__sticker{position:absolute; width:120px; height:120px; background:var(--yellow); border:3px solid var(--fg); border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:'Bricolage Grotesque'; font-weight:800; font-size:13px; text-align:center; line-height:1.15; z-index:7; bottom:-4%; left:-4%; animation:wobble 5s linear infinite}
@media(max-width:980px){.hero__mascot{width:28%; top:-4%; right:-2%} .hero__sticker{width:96px; height:96px; font-size:11px; bottom:-2%; left:-2%}}
.hero__sticker .inner{transform:rotate(-12deg)}
.hero__scroll{position:absolute; bottom:20px; left:50%; transform:translateX(-50%); z-index:3; font-family:'Caveat',cursive; font-size:18px; color:var(--fg-dim); opacity:0; animation:fadeIn 1s 1.4s forwards; display:flex; align-items:center; gap:8px}
.hero__scroll::before{content:"⬇"; animation:arrowdown 1.4s ease-in-out infinite}
@keyframes arrowdown{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}
@keyframes fadeIn{to{opacity:1}}
@media(max-width:980px){.hero__scroll{display:none}}

/* ═════════════════ KINETIC TICKER ═════════════════ */
.tickerband{background:var(--fg); color:var(--bg); padding:22px 0; overflow:hidden; border-top:3px solid var(--fg); border-bottom:3px solid var(--fg)}
.tickerband__row{display:flex; width:max-content; gap:48px; animation:tick 32s linear infinite; font-family:'Bricolage Grotesque'; font-weight:800; font-size:38px; letter-spacing:-.02em}
@keyframes tick{to{transform:translateX(-50%)}}
.tickerband__row span{display:inline-flex; align-items:center; gap:48px; white-space:nowrap}
.tickerband__star{width:36px; height:36px; flex:none; background:var(--magenta); clip-path:polygon(50% 0,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%); animation:spin 4s linear infinite}
.tickerband__row span:nth-child(2n) .tickerband__star{background:var(--cyan)}
.tickerband__row span:nth-child(3n) .tickerband__star{background:var(--yellow)}
@keyframes spin{to{transform:rotate(1turn)}}

/* ═════════════════ SECTION SHELL ═════════════════ */
section.s{padding:120px 32px; position:relative}
.wrap{max-width:1340px; margin:0 auto}
.eyebrow{font-family:'Caveat',cursive; font-weight:700; font-size:24px; color:var(--magenta); margin-bottom:8px; display:inline-flex; align-items:center; gap:10px}
.eyebrow::before{content:"✦"; font-size:20px}
.eyebrow--cyan{color:var(--cyan-deep)}
.h2{font-family:'Bricolage Grotesque'; font-weight:800; font-size:clamp(40px,6vw,80px); line-height:1; letter-spacing:-.04em; margin-bottom:24px}
.h2 .pop{color:var(--magenta); font-style:italic}
.h2 .pop-cyan{color:var(--cyan-deep); font-style:italic}
.h2 .underline-sq{position:relative; white-space:nowrap}
.h2 .underline-sq svg{position:absolute; left:0; right:0; bottom:-15%; width:100%; height:.35em; z-index:-1}
.h2 .underline-sq svg path{fill:none; stroke:var(--yellow); stroke-width:10; stroke-linecap:round}
.h3{font-family:'Bricolage Grotesque'; font-weight:700; font-size:clamp(24px,2.8vw,36px); letter-spacing:-.02em; line-height:1.1; margin-bottom:14px}
.lead{font-size:clamp(16px,1.2vw,19px); color:var(--fg-dim); max-width:600px; font-weight:400}
.prose p{font-size:17px; color:var(--fg-dim); line-height:1.75; margin-bottom:16px}
.prose strong{color:var(--fg); font-weight:700}
.prose ul{margin:14px 0 18px 0; padding-left:0; list-style:none}
.prose ul li{position:relative; padding-left:30px; margin-bottom:10px; color:var(--fg-dim); line-height:1.65}
.prose ul li::before{content:"✦"; position:absolute; left:0; top:0; color:var(--magenta); font-weight:700; font-size:18px}
@media(max-width:768px){section.s{padding:80px 20px}}

.section-head{display:grid; grid-template-columns:1.2fr 1fr; gap:60px; align-items:end; margin-bottom:60px}
@media(max-width:980px){.section-head{grid-template-columns:1fr; gap:24px}}

/* ═════════════════ SERVICE CARDS ═════════════════ */
.services-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:16px}
@media(max-width:1100px){.services-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.services-grid{grid-template-columns:1fr}}
.svc{position:relative; padding:28px 24px; background:var(--bg-alt); border:2.5px solid var(--fg); border-radius:var(--radius-lg); display:flex; flex-direction:column; justify-content:space-between; min-height:300px; transition:transform .3s var(--easing-bounce), box-shadow .3s, rotate .3s}
.svc:hover{transform:translate(-5px,-5px) rotate(-1deg); box-shadow:var(--shadow-cartoon)}
.svc--cyan{background:var(--cyan)}
.svc--magenta{background:var(--magenta); color:var(--bg)}
.svc--yellow{background:var(--yellow)}
.svc--magenta .svc__num, .svc--magenta .svc__desc, .svc--magenta .svc__more{color:rgba(255,255,255,.92)}
.svc__num{font-family:'Caveat',cursive; font-weight:700; font-size:20px; color:var(--fg-mute); margin-bottom:14px}
.svc__icon{width:44px; height:44px; background:var(--fg); color:var(--bg); border-radius:50%; display:flex; align-items:center; justify-content:center; margin-bottom:20px; transition:transform .3s var(--easing-bounce)}
.svc:hover .svc__icon{transform:rotate(-12deg) scale(1.15)}
.svc--magenta .svc__icon{background:var(--bg); color:var(--magenta)}
.svc--cyan .svc__icon, .svc--yellow .svc__icon{background:var(--fg); color:var(--bg)}
.svc__icon svg{width:22px; height:22px; stroke-width:2}
.svc__title{font-family:'Bricolage Grotesque'; font-weight:700; font-size:23px; line-height:1.05; letter-spacing:-.02em; margin-bottom:10px}
.svc__desc{font-size:14px; color:var(--fg-dim); line-height:1.55; margin-bottom:18px}
.svc__bottom{display:flex; justify-content:space-between; align-items:center; gap:8px; flex-wrap:wrap}
.svc__age{font-family:'Bricolage Grotesque'; font-weight:700; font-size:11px; letter-spacing:.06em; display:inline-block; padding:5px 11px; background:var(--fg); color:var(--bg); border-radius:100px}
.svc--magenta .svc__age{background:var(--bg); color:var(--magenta)}
.svc__more{font-family:'Bricolage Grotesque'; font-weight:700; font-size:13px; transition:transform .25s}
.svc:hover .svc__more{transform:translateX(4px)}

/* ═════════════════ DETAIL BLOCKS (used on inner pages) ═════════════════ */
.detail-block{padding:90px 32px; background:var(--bg-alt); border-top:1px solid var(--border)}
.detail-block:nth-of-type(2n){background:var(--bg)}
.detail-grid{display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; max-width:1340px; margin:0 auto}
@media(max-width:980px){.detail-grid{grid-template-columns:1fr; gap:40px}}
.detail-grid--reverse .detail-grid__visual{order:2}
@media(max-width:980px){.detail-grid--reverse .detail-grid__visual{order:0}}
.detail-grid__visual{position:relative}
.detail-tag{display:inline-flex; align-items:center; gap:8px; padding:6px 14px; margin-bottom:14px; background:var(--magenta); color:#fff; border-radius:100px; font-family:'Bricolage Grotesque'; font-weight:700; font-size:12px; letter-spacing:.05em}
.detail-tag--cyan{background:var(--cyan-deep)}
.detail-tag--yellow{background:var(--yellow); color:var(--fg)}

/* ═════════════════ PHOTO PLACEHOLDERS ═════════════════ */
.photo-placeholder{position:relative; aspect-ratio:1/1.05; border-radius:var(--radius-lg); background:linear-gradient(135deg, var(--magenta) 0%, var(--cyan) 100%); border:3px solid var(--fg); box-shadow:14px 14px 0 var(--fg); display:flex; align-items:center; justify-content:center; flex-direction:column; gap:10px; overflow:hidden; color:var(--bg); text-align:center; padding:24px}
.photo-placeholder::before{content:""; position:absolute; inset:14px; border:2px dashed rgba(255,255,255,.5); border-radius:18px}
.photo-placeholder__id{font-family:'Caveat',cursive; font-weight:700; font-size:30px; line-height:1}
.photo-placeholder__sub{font-family:'Bricolage Grotesque'; font-weight:600; font-size:13px; opacity:.85; max-width:80%}
.photo-placeholder--small{aspect-ratio:1/1; box-shadow:8px 8px 0 var(--fg)}
.photo-placeholder--wide{aspect-ratio:16/10; box-shadow:10px 10px 0 var(--fg)}
.photo-placeholder--cyan{background:var(--cyan)}
.photo-placeholder--magenta{background:var(--magenta)}
.photo-placeholder--yellow{background:var(--yellow); color:var(--fg)}
.photo-placeholder--yellow::before{border-color:rgba(10,6,18,.4)}

/* ═════════════════ STATS ═════════════════ */
.about-stats{display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-top:32px}
@media(max-width:600px){.about-stats{grid-template-columns:repeat(2,1fr)}}
.stat{padding:18px 14px; border:2.5px solid var(--fg); border-radius:14px; background:var(--bg); text-align:center; transition:transform .25s var(--easing-bounce)}
.stat:hover{transform:translate(-2px,-2px) rotate(-1deg); box-shadow:4px 4px 0 var(--fg)}
.stat__num{font-family:'Bricolage Grotesque'; font-weight:800; font-size:38px; letter-spacing:-.04em; line-height:1; color:var(--magenta)}
.stat__num.cyan{color:var(--cyan-deep)}
.stat__label{font-size:11px; color:var(--fg-dim); margin-top:6px; font-weight:600; line-height:1.3}

/* ═════════════════ COMPETITIONS ═════════════════ */
.comp-section{background:var(--bg-dark); color:var(--bg); padding:130px 32px; position:relative; overflow:hidden}
.comp-section::before{content:""; position:absolute; inset:0; background-image:radial-gradient(circle at 80% 20%, rgba(31,192,220,.15), transparent 40%), radial-gradient(circle at 20% 80%, rgba(236,4,140,.12), transparent 40%); pointer-events:none}
.comp-section .h2{color:var(--bg)}
.comp-section .lead{color:rgba(255,255,255,.7)}
.comp-section .eyebrow{color:var(--cyan)}
.comp-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:50px; position:relative}
@media(max-width:1000px){.comp-grid{grid-template-columns:1fr 1fr}}
@media(max-width:680px){.comp-grid{grid-template-columns:1fr}}
.comp{background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.1); border-radius:20px; overflow:hidden; transition:all .3s var(--easing-bounce)}
.comp:hover{background:rgba(255,255,255,.08); transform:translateY(-5px); border-color:var(--magenta)}
.comp__media{aspect-ratio:16/9; position:relative; background:linear-gradient(135deg,var(--magenta),var(--cyan)); display:flex; align-items:center; justify-content:center; overflow:hidden}
.comp__media::before{content:""; position:absolute; inset:0; background:radial-gradient(circle at center, transparent 0, rgba(0,0,0,.35) 100%)}
.comp__placeholder{position:absolute; top:14px; left:14px; z-index:3; padding:6px 12px; border-radius:8px; background:var(--yellow); color:var(--bg-dark); font-family:'Caveat',cursive; font-weight:700; font-size:18px; transform:rotate(-3deg)}
.comp__play{width:72px; height:72px; border-radius:50%; background:rgba(255,255,255,.18); backdrop-filter:blur(8px); border:2px solid rgba(255,255,255,.5); display:flex; align-items:center; justify-content:center; position:relative; z-index:2; transition:transform .25s var(--easing-bounce), background .25s}
.comp:hover .comp__play{background:#fff; transform:scale(1.15)}
.comp__play::after{content:""; width:0; height:0; border-left:16px solid #fff; border-top:11px solid transparent; border-bottom:11px solid transparent; margin-left:5px; transition:border-color .25s}
.comp:hover .comp__play::after{border-left-color:var(--bg-dark)}
.comp__body{padding:26px}
.comp__year{font-family:'Bricolage Grotesque'; font-weight:700; font-size:12px; color:var(--cyan); letter-spacing:.1em; margin-bottom:10px; text-transform:uppercase}
.comp__title{font-family:'Bricolage Grotesque'; font-weight:700; font-size:24px; letter-spacing:-.02em; margin-bottom:10px}
.comp__desc{font-size:14px; color:rgba(255,255,255,.7); line-height:1.6}
.comp-cta{margin-top:48px; text-align:center}
.comp-cta .btn{background:var(--magenta); color:#fff; border:2px solid var(--magenta)}
.comp-cta .btn:hover{background:#fff; color:var(--magenta); transform:translateY(-3px) rotate(-2deg)}

/* ═════════════════ PARTNERS MARQUEE ═════════════════ */
.partners{padding:80px 0; background:var(--yellow); overflow:hidden; border-top:3px solid var(--fg); border-bottom:3px solid var(--fg)}
.partners__head{text-align:center; margin-bottom:36px; padding:0 32px}
.partners__title{font-family:'Bricolage Grotesque'; font-weight:700; font-size:18px; color:var(--fg)}
.marquee{display:flex; width:max-content; animation:slide 36s linear infinite; gap:64px; align-items:center}
.marquee:hover{animation-play-state:paused}
@keyframes slide{to{transform:translateX(-50%)}}
.marquee__item{flex:none; font-family:'Bricolage Grotesque'; font-weight:800; font-size:30px; letter-spacing:-.02em; color:var(--fg); white-space:nowrap; padding:0 16px; transition:color .3s, transform .3s}
.marquee__item:hover{color:var(--magenta); transform:scale(1.06) rotate(-2deg)}
.marquee__star{flex:none; width:24px; height:24px; background:var(--magenta); border-radius:50%}
.marquee__star:nth-child(4n){background:var(--cyan-deep)}

/* ═════════════════ BIG CTA BAND ═════════════════ */
.cta-band{padding:140px 32px; background:var(--bg); text-align:center; position:relative; overflow:hidden}
.cta-band__inner{position:relative; z-index:2; max-width:900px; margin:0 auto; padding:60px 40px; background:var(--magenta); color:#fff; border:3px solid var(--fg); border-radius:32px; box-shadow:14px 14px 0 var(--fg); transform:rotate(-1deg)}
.cta-band__eyebrow{font-family:'Caveat',cursive; font-weight:700; font-size:30px; margin-bottom:8px; color:var(--yellow)}
.cta-band__title{font-family:'Bricolage Grotesque'; font-weight:800; font-size:clamp(40px,5vw,68px); line-height:1; letter-spacing:-.04em; margin-bottom:18px}
.cta-band__sub{font-size:17px; opacity:.92; max-width:520px; margin:0 auto 32px}
.cta-band__btns{display:flex; gap:14px; justify-content:center; flex-wrap:wrap}
.cta-band__btns .btn{background:var(--bg); color:var(--fg)}
.cta-band__btns .btn:hover{background:var(--yellow); transform:translateY(-3px) rotate(-2deg)}
.cta-band__btns .btn--ghost{background:transparent; color:#fff; border-color:#fff}
.cta-band__btns .btn--ghost:hover{background:#fff; color:var(--magenta)}
.cta-band__deco{position:absolute; pointer-events:none; opacity:.85}
.cta-band__deco--star1{top:8%; left:10%; width:60px; animation:wobble 4s ease-in-out infinite}
.cta-band__deco--star2{bottom:15%; right:12%; width:48px; animation:wobble 5s ease-in-out infinite reverse}
.cta-band__deco--bolt{top:20%; right:8%; width:48px; animation:swing 3s ease-in-out infinite}

/* ═════════════════ TEAM GRID ═════════════════ */
.team-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:50px}
@media(max-width:980px){.team-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.team-grid{grid-template-columns:1fr}}
.team-card{background:var(--bg-alt); border:2.5px solid var(--fg); border-radius:var(--radius-lg); overflow:hidden; transition:transform .3s var(--easing-bounce), box-shadow .3s}
.team-card:hover{transform:translate(-4px,-4px) rotate(-1deg); box-shadow:var(--shadow-cartoon)}
.team-card__photo{aspect-ratio:1/1; background:linear-gradient(135deg, var(--cyan), var(--magenta)); position:relative; display:flex; align-items:center; justify-content:center; color:#fff; font-family:'Caveat',cursive; font-weight:700; font-size:28px; text-align:center; padding:14px}
.team-card__photo::before{content:""; position:absolute; inset:10px; border:2px dashed rgba(255,255,255,.5); border-radius:14px}
.team-card__body{padding:20px}
.team-card__name{font-family:'Bricolage Grotesque'; font-weight:700; font-size:18px; line-height:1.15; margin-bottom:6px}
.team-card__role{font-size:13px; color:var(--fg-dim); font-weight:500}

/* ═════════════════ LOCATION CARDS ═════════════════ */
.locations-grid{display:grid; grid-template-columns:1fr 1fr; gap:24px; margin-top:40px}
@media(max-width:768px){.locations-grid{grid-template-columns:1fr}}
.location-card{background:var(--bg-alt); border:2.5px solid var(--fg); border-radius:var(--radius-lg); padding:32px; transition:transform .3s var(--easing-bounce), box-shadow .3s}
.location-card:hover{transform:translate(-4px,-4px) rotate(-1deg); box-shadow:var(--shadow-cartoon)}
.location-card--magenta{background:var(--magenta); color:#fff}
.location-card--cyan{background:var(--cyan)}
.location-card__num{display:inline-flex; width:48px; height:48px; align-items:center; justify-content:center; background:var(--fg); color:#fff; border-radius:50%; font-family:'Bricolage Grotesque'; font-weight:800; font-size:24px; margin-bottom:18px}
.location-card--magenta .location-card__num{background:#fff; color:var(--magenta)}
.location-card__name{font-family:'Bricolage Grotesque'; font-weight:700; font-size:24px; letter-spacing:-.02em; margin-bottom:10px}
.location-card__addr{font-size:15px; line-height:1.55; margin-bottom:18px}
.location-card--magenta .location-card__addr{opacity:.92}
.location-card__details{display:grid; gap:8px; font-size:14px; font-weight:500}
.location-card__details a{transition:opacity .2s, color .2s}
.location-card__details a:hover{color:var(--cyan-deep)}
.location-card--magenta .location-card__details a:hover{color:var(--yellow); opacity:1}

/* ═════════════════ FORM ═════════════════ */
.form-card{background:var(--fg); color:var(--bg); border-radius:24px; padding:36px}
.form-card__title{font-family:'Bricolage Grotesque'; font-weight:700; font-size:28px; margin-bottom:8px; letter-spacing:-.02em}
.form-card__sub{font-size:14px; opacity:.7; margin-bottom:28px}
.field{margin-bottom:16px}
.field label{display:block; font-size:12px; opacity:.65; margin-bottom:6px; font-weight:600; letter-spacing:.05em; text-transform:uppercase}
.field input,.field select,.field textarea{width:100%; padding:14px 18px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.15); color:var(--bg); font-family:inherit; font-size:15px; border-radius:12px; transition:border-color .2s, background .2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none; border-color:var(--magenta); background:rgba(255,255,255,.1)}
.field textarea{resize:vertical; min-height:90px}
.form-card__btn{width:100%; padding:18px; margin-top:8px; background:var(--magenta); color:var(--bg); border:none; border-radius:100px; font-family:'Bricolage Grotesque'; font-weight:700; font-size:16px; letter-spacing:.02em; cursor:pointer; transition:background .2s, transform .25s var(--easing-bounce)}
.form-card__btn:hover{background:var(--cyan); transform:translateY(-2px) rotate(-2deg)}

/* ═════════════════ FOOTER ═════════════════ */
footer{padding:80px 32px 36px; background:var(--bg-dark); color:var(--bg); position:relative; overflow:hidden}
.footer-grid{display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px; margin-bottom:48px}
@media(max-width:980px){.footer-grid{grid-template-columns:1fr 1fr; gap:32px}}
@media(max-width:560px){.footer-grid{grid-template-columns:1fr}}
.footer__brand img{height:48px; margin-bottom:18px; filter:brightness(0) invert(1)}
.footer__brand p{font-size:14px; opacity:.7; max-width:340px; line-height:1.6}
.footer__col h4{font-family:'Bricolage Grotesque'; font-weight:700; font-size:13px; color:var(--cyan); letter-spacing:.06em; text-transform:uppercase; margin-bottom:18px}
.footer__col a{display:block; font-size:14px; opacity:.75; margin-bottom:10px; transition:color .2s, opacity .2s}
.footer__col a:hover{color:var(--magenta); opacity:1}
.footer-bottom{display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:20px; padding-top:28px; border-top:1px solid rgba(255,255,255,.1); font-size:13px; opacity:.6}
.footer-bottom a{color:var(--cyan); opacity:1}
.footer-bottom a:hover{color:var(--magenta)}
.socials{display:flex; gap:12px}
.socials a{width:38px; height:38px; display:flex; align-items:center; justify-content:center; background:rgba(255,255,255,.06); border-radius:50%; transition:background .2s, transform .25s var(--easing-bounce); opacity:1}
.socials a:hover{background:var(--magenta); transform:translateY(-2px) rotate(-8deg)}
.socials svg{width:16px; height:16px}

/* ═════════════════ STICKY MOBILE BOTTOM CTA ═════════════════ */
.mobile-cta-bar{display:none; position:fixed; left:14px; right:14px; bottom:14px; z-index:75; background:var(--fg); border:2px solid var(--fg); border-radius:18px; padding:8px; box-shadow:0 12px 32px rgba(0,0,0,.25); gap:6px}
.mobile-cta-bar a{flex:1; padding:14px; border-radius:12px; display:flex; align-items:center; justify-content:center; gap:8px; font-family:'Bricolage Grotesque'; font-weight:700; font-size:14px; text-align:center; transition:background .2s}
.mobile-cta-bar .call{background:var(--cyan); color:var(--fg)}
.mobile-cta-bar .free{background:var(--magenta); color:#fff}
@media(max-width:1080px){.mobile-cta-bar{display:flex}}

/* ═════════════════ REVEAL ON SCROLL ═════════════════ */
@supports (animation-timeline: view()){
  .reveal{opacity:0; transform:translateY(40px) scale(.96); animation:revealup linear both; animation-timeline:view(); animation-range:entry 5% cover 25%}
  @keyframes revealup{to{opacity:1; transform:translateY(0) scale(1)}}
}

/* ═════════════════ REAL PHOTO (replaces .photo-placeholder) ═════════════════ */
.photo-real{position:relative; aspect-ratio:1/1.05; border-radius:var(--radius-lg); border:3px solid var(--fg); box-shadow:14px 14px 0 var(--fg); overflow:hidden; transition:transform .35s var(--easing-bounce), box-shadow .35s; background:var(--fg)}
.photo-real:hover{transform:translate(-5px,-5px) rotate(-1.5deg); box-shadow:18px 18px 0 var(--fg)}
.photo-real img{width:100%; height:100%; object-fit:cover; display:block; transition:transform .5s ease}
.photo-real:hover img{transform:scale(1.04)}
.photo-real--wide{aspect-ratio:16/10}
.photo-real--portrait{aspect-ratio:3/4}
.photo-real--square{aspect-ratio:1/1}
.photo-real__badge{position:absolute; top:14px; left:14px; padding:6px 12px; background:var(--yellow); color:var(--fg); border-radius:8px; font-family:'Caveat',cursive; font-weight:700; font-size:18px; transform:rotate(-3deg); border:2px solid var(--fg); z-index:2; line-height:1}
.photo-real__badge--cyan{background:var(--cyan); color:var(--fg)}
.photo-real__badge--magenta{background:var(--magenta); color:#fff}

/* ═════════════════ HERO VIDEO PANEL (welcome video, 9:16) ═════════════════ */
.hero__video-panel{position:relative; width:100%; max-width:340px; aspect-ratio:9/16; border-radius:30px; overflow:hidden; border:4px solid var(--fg); box-shadow:14px 14px 0 var(--fg); background:var(--fg); z-index:2; transform:rotate(2deg); transition:transform .4s var(--easing-bounce), box-shadow .4s}
.hero__video-panel:hover{transform:rotate(0deg) translate(-4px,-4px); box-shadow:18px 18px 0 var(--fg)}
.hero__video-panel video{width:100%; height:100%; object-fit:cover; display:block}
.hero__video-panel::after{content:""; position:absolute; inset:0; pointer-events:none; background:radial-gradient(circle at 50% 100%, transparent 55%, rgba(0,0,0,.35) 100%)}
.hero__video-panel__badge{position:absolute; bottom:18px; left:50%; transform:translateX(-50%) rotate(-3deg); padding:8px 16px; background:var(--magenta); color:#fff; border-radius:100px; font-family:'Caveat',cursive; font-weight:700; font-size:18px; border:2px solid var(--fg); z-index:3; box-shadow:0 4px 12px rgba(0,0,0,.4); white-space:nowrap}
@media(max-width:980px){.hero__video-panel{max-width:280px; margin:0 auto; transform:rotate(0deg)}}

/* ═════════════════ VERTICAL VIDEO CARD (construction loop, 9:16, inline use) ═════════════════ */
.video-vert{position:relative; max-width:260px; width:100%; aspect-ratio:9/16; margin:0 auto; border-radius:22px; overflow:hidden; border:3px solid var(--fg); box-shadow:10px 10px 0 var(--fg); background:var(--fg); transition:transform .35s var(--easing-bounce), box-shadow .35s}
.video-vert:hover{transform:translate(-4px,-4px) rotate(-1deg); box-shadow:14px 14px 0 var(--fg)}
.video-vert video{width:100%; height:100%; object-fit:cover; display:block}
.video-vert__tag{position:absolute; top:12px; left:12px; padding:5px 11px; background:var(--cyan); color:var(--fg); font-family:'Caveat',cursive; font-weight:700; font-size:16px; border-radius:6px; transform:rotate(-3deg); z-index:2; border:2px solid var(--fg); line-height:1}
.video-vert__tag::before{content:"▶ "; color:var(--magenta)}

/* Stack media (photo + video) on the same column */
.media-stack{display:flex; flex-direction:column; gap:24px; align-items:center}
.media-stack .photo-real{width:100%}

/* ═════════════════ COMP CARD WITH REAL IMAGE (diagonismoi) ═════════════════ */
.comp__media{background:var(--fg)}
.comp__media-img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0; transition:transform .5s ease}
.comp:hover .comp__media-img{transform:scale(1.05)}
.comp__media:has(.comp__media-img)::before{background:linear-gradient(180deg, rgba(0,0,0,.1) 0%, rgba(0,0,0,.55) 100%)}
.comp__media:has(.comp__media-img) .comp__placeholder{background:var(--magenta); color:#fff}

/* ═════════════════ LOGO INTRO REVEAL (first-page-load splash) ═════════════════ */
#logo-intro{position:fixed; inset:0; z-index:9999; background:radial-gradient(circle at 50% 50%, #150518 0%, #000 100%); display:grid; place-items:center; overflow:hidden; height:100vh; height:100dvh; animation:logoIntroOut .9s cubic-bezier(.6,0,.4,1) 2.7s forwards; will-change:opacity, transform}
#logo-intro::before, #logo-intro::after{content:""; position:absolute; left:50%; top:50%; width:200vmax; height:200vmax; transform:translate(-50%,-50%); background:conic-gradient(from 0deg, transparent 0%, rgba(31,192,220,.6) 22%, transparent 38%, transparent 62%, rgba(236,4,140,.6) 78%, transparent 96%); filter:blur(140px); opacity:0; animation:logoIntroSweep 2.6s cubic-bezier(.16,.6,.24,1) forwards; will-change:transform, opacity}
#logo-intro::after{animation-delay:.55s; mix-blend-mode:screen}
.logo-intro__mark{position:relative; width:clamp(180px, 30vw, 340px); transform:scale(.65); opacity:0; animation:logoIntroPop 1.6s cubic-bezier(.18,.74,.36,1.04) .35s forwards; filter:drop-shadow(0 30px 70px rgba(236,4,140,.5)); will-change:transform, opacity}
.logo-intro__tagline{position:absolute; left:50%; bottom:18%; transform:translate(-50%, 8px); font-family:'Bricolage Grotesque'; font-weight:800; font-size:clamp(11px, 1.1vw, 15px); letter-spacing:.42em; color:#fff; opacity:0; animation:logoIntroFade 1s cubic-bezier(.2,.6,.2,1) 1.5s forwards; text-align:center; white-space:nowrap; will-change:transform, opacity}
.logo-intro__tagline b{color:var(--cyan); font-weight:800}
.logo-intro__tagline i{color:var(--magenta); font-style:normal; font-weight:800}
@keyframes logoIntroSweep{0%{opacity:0; transform:translate(-50%,-50%) rotate(0deg) scale(.85)}30%{opacity:.7}70%{opacity:.55}100%{opacity:0; transform:translate(-50%,-50%) rotate(180deg) scale(1.05)}}
@keyframes logoIntroPop{0%{transform:scale(.65) rotate(-4deg); opacity:0}30%{opacity:1}60%{transform:scale(1.04) rotate(1.5deg); opacity:1}100%{transform:scale(1) rotate(0deg); opacity:1}}
@keyframes logoIntroFade{to{transform:translate(-50%, 0); opacity:.92}}
@keyframes logoIntroOut{0%{opacity:1; transform:scale(1)}100%{opacity:0; transform:scale(1.04); visibility:hidden; pointer-events:none}}
@media (prefers-reduced-motion: reduce){#logo-intro{animation:logoIntroOut .3s ease-out 0s forwards} #logo-intro::before, #logo-intro::after{display:none} .logo-intro__mark{animation:none; transform:scale(1); opacity:1} .logo-intro__tagline{animation:none; opacity:.9; transform:translate(-50%,0)}}

/* ═════════════════ COMP MOMENT GALLERY (diagonismoi page, "Στιγμές") ═════════════════ */
.moments{padding:120px 32px; background:var(--bg); position:relative}
@media(max-width:768px){.moments{padding:80px 20px}}
.moments__head{text-align:center; max-width:780px; margin:0 auto 50px}
.moments-grid{display:grid; grid-template-columns:repeat(auto-fit, minmax(240px,1fr)); gap:20px; max-width:1340px; margin:0 auto}
.moment{position:relative; aspect-ratio:4/5; border-radius:20px; overflow:hidden; border:3px solid var(--fg); box-shadow:10px 10px 0 var(--fg); transition:transform .35s var(--easing-bounce), box-shadow .35s; background:var(--fg)}
.moment:nth-child(3n+1){transform:rotate(-1.5deg)}
.moment:nth-child(3n+2){transform:rotate(.8deg)}
.moment:nth-child(3n+3){transform:rotate(-.5deg)}
.moment:hover{transform:translate(-4px,-4px) rotate(0deg); box-shadow:14px 14px 0 var(--fg); z-index:5}
.moment img{width:100%; height:100%; object-fit:cover; display:block; transition:transform .5s ease}
.moment:hover img{transform:scale(1.06)}
.moment__caption{position:absolute; left:0; right:0; bottom:0; padding:18px 16px 14px; background:linear-gradient(to top, rgba(0,0,0,.88), transparent); color:#fff; font-family:'Bricolage Grotesque'; font-weight:700; font-size:14px; line-height:1.25}
.moment__caption b{display:block; font-family:'Caveat',cursive; font-weight:700; font-size:18px; color:var(--cyan); margin-bottom:2px}

/* ═════════════════ VIZ BLOCKS (replace photo placeholders with stylized graphic blocks) ═════════════════ */
.viz{position:relative; aspect-ratio:1/1.05; border-radius:var(--radius-lg); border:3px solid var(--fg); box-shadow:14px 14px 0 var(--fg); overflow:hidden; display:flex; align-items:center; justify-content:center; padding:32px; transition:transform .35s var(--easing-bounce), box-shadow .35s}
.viz:hover{transform:translate(-5px,-5px) rotate(-1deg); box-shadow:18px 18px 0 var(--fg)}
.viz--cyan{background:linear-gradient(135deg, var(--cyan) 0%, var(--cyan-deep) 100%); color:#fff}
.viz--magenta{background:linear-gradient(135deg, var(--magenta) 0%, var(--magenta-deep) 100%); color:#fff}
.viz--yellow{background:linear-gradient(135deg, var(--yellow) 0%, #FFB800 100%); color:var(--fg)}
.viz--cream{background:linear-gradient(135deg, var(--bg) 0%, #F0EAE0 100%); color:var(--fg); border:3px solid var(--fg)}
.viz--dark{background:linear-gradient(135deg, var(--bg-dark) 0%, #1a0a1f 100%); color:#fff}
.viz__core{position:relative; z-index:2; width:100%; max-width:340px; text-align:center; display:flex; flex-direction:column; align-items:center; gap:14px}
.viz__icon{width:140px; height:140px; opacity:.95; filter:drop-shadow(0 12px 28px rgba(0,0,0,.25)); animation:bobSlow 5s ease-in-out infinite}
.viz__icon svg{width:100%; height:100%}
@keyframes bobSlow{0%,100%{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-10px) rotate(2deg)}}
.viz__big{font-family:'Bricolage Grotesque'; font-weight:800; font-size:clamp(36px,4vw,52px); line-height:.95; letter-spacing:-.04em; margin:0}
.viz__sub{font-family:'Caveat',cursive; font-weight:700; font-size:22px; line-height:1.1; opacity:.95}
.viz__pills{display:flex; gap:8px; flex-wrap:wrap; justify-content:center; margin-top:6px}
.viz__pill{padding:6px 12px; border-radius:100px; background:rgba(255,255,255,.18); backdrop-filter:blur(8px); font-family:'Bricolage Grotesque'; font-weight:700; font-size:11px; letter-spacing:.05em; border:1.5px solid rgba(255,255,255,.4)}
.viz--cream .viz__pill, .viz--yellow .viz__pill{background:rgba(10,6,18,.08); border-color:rgba(10,6,18,.25)}
.viz__deco{position:absolute; pointer-events:none; opacity:.18}
.viz__deco--tl{top:18px; left:18px; width:46px; transform:rotate(-15deg)}
.viz__deco--br{bottom:18px; right:18px; width:38px; transform:rotate(20deg)}
.viz__deco--tr{top:24px; right:24px; width:42px; transform:rotate(12deg); animation:wobble 4s ease-in-out infinite}
.viz__deco--bl{bottom:24px; left:24px; width:38px; transform:rotate(-10deg); animation:wobble 5s ease-in-out infinite reverse}

/* Excel mock visual (enilikes business-office) */
.excel-mock{position:relative; width:100%; max-width:340px; background:#fff; border:2.5px solid var(--fg); border-radius:14px; overflow:hidden; box-shadow:0 14px 40px rgba(0,0,0,.18); transform:rotate(-2deg); transition:transform .4s var(--easing-bounce)}
.viz:hover .excel-mock{transform:rotate(0deg)}
.excel-mock__bar{display:flex; gap:6px; padding:10px 14px; background:#107c41; align-items:center}
.excel-mock__bar i{width:10px; height:10px; border-radius:50%; background:rgba(255,255,255,.6); display:block}
.excel-mock__bar i:nth-child(1){background:#ff5f57}
.excel-mock__bar i:nth-child(2){background:#febc2e}
.excel-mock__bar i:nth-child(3){background:#28c840}
.excel-mock__cells{display:grid; grid-template-columns:36px repeat(4,1fr); font-family:monospace; font-size:11px; color:var(--fg); border-collapse:collapse}
.excel-mock__cells span{padding:6px 8px; border-right:1px solid #e5e5e5; border-bottom:1px solid #e5e5e5; text-align:right; line-height:1.2}
.excel-mock__cells span:nth-child(5n+1){background:#f5f5f5; text-align:center; font-weight:700}
.excel-mock__cells span.h{background:#107c41; color:#fff; text-align:center; font-weight:700}
.excel-mock__cells span.hl{background:#FFE94A}
.excel-mock__cells span.up{color:#0a8043; font-weight:700}
.excel-mock__cells span.dn{color:#c5221f; font-weight:700}

/* Certificate mock visual (enilikes ASEP/ECDL) */
.cert-mock{position:relative; width:100%; max-width:300px; aspect-ratio:1/1.35; background:#fff; border:6px double var(--fg); border-radius:8px; padding:24px 18px; text-align:center; transform:rotate(2deg); transition:transform .4s var(--easing-bounce); box-shadow:0 18px 40px rgba(0,0,0,.22)}
.viz:hover .cert-mock{transform:rotate(0deg)}
.cert-mock__seal{position:absolute; bottom:14px; right:14px; width:64px; height:64px; border-radius:50%; background:radial-gradient(circle, var(--magenta), var(--magenta-deep)); display:flex; align-items:center; justify-content:center; color:#fff; font-family:'Bricolage Grotesque'; font-weight:800; font-size:11px; line-height:1; transform:rotate(-12deg); border:3px solid #fff; box-shadow:0 4px 12px rgba(0,0,0,.3)}
.cert-mock__small{font-family:'Caveat',cursive; font-size:14px; color:var(--fg-dim); margin-bottom:6px}
.cert-mock__title{font-family:'Bricolage Grotesque'; font-weight:800; font-size:24px; line-height:1; letter-spacing:-.02em; color:var(--fg); margin-bottom:14px}
.cert-mock__line{height:1px; background:var(--fg); opacity:.2; margin:10px 0}
.cert-mock__name{font-family:'Caveat',cursive; font-weight:700; font-size:32px; color:var(--magenta); transform:rotate(-2deg); margin:18px 0 8px; line-height:1}
.cert-mock__role{font-family:'Bricolage Grotesque'; font-size:11px; letter-spacing:.08em; color:var(--fg); margin-bottom:6px}
.cert-mock__org{font-family:'Bricolage Grotesque'; font-weight:700; font-size:13px; color:var(--cyan-deep); letter-spacing:.04em; margin-top:14px}

/* Equipment grid visual (scholeia) */
.equip-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:10px; width:100%; max-width:340px}
.equip-tile{aspect-ratio:1/1; background:rgba(255,255,255,.92); border:2px solid var(--fg); border-radius:14px; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:4px; padding:10px; text-align:center; color:var(--fg); transition:transform .3s var(--easing-bounce); position:relative; overflow:hidden}
.equip-tile:hover{transform:translate(-2px,-2px) rotate(-2deg); box-shadow:4px 4px 0 var(--fg)}
.equip-tile__dot{width:14px; height:14px; border-radius:50%}
.equip-tile__dot--cyan{background:var(--cyan)}
.equip-tile__dot--magenta{background:var(--magenta)}
.equip-tile__dot--yellow{background:var(--yellow); border:1.5px solid var(--fg)}
.equip-tile__name{font-family:'Bricolage Grotesque'; font-weight:800; font-size:10px; line-height:1.05; letter-spacing:-.01em}
.equip-tile__sub{font-family:'Caveat',cursive; font-size:11px; color:var(--fg-dim); line-height:1}

/* Quote card (founder portrait replacement) */
.quote-card{position:relative; aspect-ratio:1/1.05; border-radius:var(--radius-lg); border:3px solid var(--fg); box-shadow:14px 14px 0 var(--fg); overflow:hidden; padding:48px 36px; display:flex; flex-direction:column; justify-content:space-between; background:linear-gradient(160deg, var(--magenta) 0%, var(--magenta-deep) 100%); color:#fff; transition:transform .35s var(--easing-bounce), box-shadow .35s}
.quote-card:hover{transform:translate(-5px,-5px) rotate(-1deg); box-shadow:18px 18px 0 var(--fg)}
.quote-card__mark{font-family:'Bricolage Grotesque'; font-weight:800; font-size:140px; line-height:1; opacity:.18; position:absolute; top:-10px; left:24px; pointer-events:none}
.quote-card__body{position:relative; z-index:2; font-family:'Bricolage Grotesque'; font-weight:700; font-size:clamp(20px,2vw,28px); line-height:1.2; letter-spacing:-.015em; margin-top:30px}
.quote-card__body em{font-style:italic; color:var(--yellow)}
.quote-card__sig{position:relative; z-index:2; display:flex; flex-direction:column; gap:4px; padding-top:16px; border-top:2px solid rgba(255,255,255,.25)}
.quote-card__sig-name{font-family:'Caveat',cursive; font-weight:700; font-size:32px; line-height:1; color:#fff; transform:rotate(-3deg); transform-origin:left}
.quote-card__sig-role{font-family:'Bricolage Grotesque'; font-weight:700; font-size:12px; letter-spacing:.08em; color:rgba(255,255,255,.85)}

/* Robot mascot avatar (team grid) — branded robot face with gradient backgrounds */
.team-card__avatar{aspect-ratio:1/1; display:flex; align-items:center; justify-content:center; position:relative; overflow:hidden; background:#150518}
.team-card__avatar::before, .team-card__avatar::after{content:""; position:absolute; border-radius:50%; filter:blur(28px); opacity:.75; transition:opacity .4s ease}
.team-card__avatar::before{width:65%; height:65%; background:var(--magenta); top:-12%; left:-12%; animation:float1 9s ease-in-out infinite}
.team-card__avatar::after{width:65%; height:65%; background:var(--cyan); bottom:-12%; right:-12%; animation:float2 11s ease-in-out infinite}
/* Per-card gradient variants — cycle every 4 cards for visual rhythm */
.team-card:nth-child(4n+2) .team-card__avatar::before{background:var(--cyan)}
.team-card:nth-child(4n+2) .team-card__avatar::after{background:var(--yellow)}
.team-card:nth-child(4n+3) .team-card__avatar::before{background:var(--yellow)}
.team-card:nth-child(4n+3) .team-card__avatar::after{background:var(--magenta)}
.team-card:nth-child(4n+4) .team-card__avatar::before{background:var(--cyan)}
.team-card:nth-child(4n+4) .team-card__avatar::after{background:var(--magenta)}
.team-card:hover .team-card__avatar::before, .team-card:hover .team-card__avatar::after{opacity:.95}
.team-card__bot{position:relative; z-index:2; width:62%; max-width:160px; filter:drop-shadow(0 10px 24px rgba(0,0,0,.55)); transition:transform .45s var(--easing-bounce)}
.team-card:hover .team-card__bot{transform:rotate(-6deg) scale(1.07)}
.team-card__role-pill{position:absolute; bottom:14px; left:50%; transform:translateX(-50%); z-index:3; padding:6px 13px; background:var(--yellow); color:var(--fg); border:2px solid var(--fg); border-radius:100px; font-family:'Bricolage Grotesque'; font-weight:800; font-size:10px; letter-spacing:.06em; white-space:nowrap; box-shadow:0 4px 12px rgba(0,0,0,.35); line-height:1}
@media(max-width:480px){.team-card__bot{width:55%}}

/* ═════════════════ TOUR VIDEO TILES (homepage "Δες το InTeLab" section) ═════════════════ */
.tour-section{padding:110px 32px; background:var(--bg-alt); position:relative; overflow:hidden}
.tour-section::before{content:""; position:absolute; top:-80px; right:-80px; width:240px; height:240px; border-radius:50%; background:radial-gradient(circle, rgba(31,192,220,.18), transparent 70%); pointer-events:none}
.tour-section::after{content:""; position:absolute; bottom:-100px; left:-80px; width:280px; height:280px; border-radius:50%; background:radial-gradient(circle, rgba(236,4,140,.16), transparent 70%); pointer-events:none}
.tour-section__head{text-align:center; max-width:780px; margin:0 auto 56px; position:relative; z-index:2}
.tour-section__head .h2{margin:0 auto}
.tour-section__head .lead{margin:18px auto 0; max-width:580px}
.tour-grid{display:grid; grid-template-columns:repeat(3, minmax(0,1fr)); gap:28px; max-width:1080px; margin:0 auto; align-items:start; position:relative; z-index:2}
@media(max-width:880px){.tour-grid{grid-template-columns:1fr 1fr}}
.video-tile{position:relative; aspect-ratio:9/16; border-radius:26px; overflow:hidden; border:3px solid var(--fg); box-shadow:12px 12px 0 var(--fg); background:var(--fg); cursor:default; transition:transform .35s var(--easing-bounce), box-shadow .35s; max-width:340px; width:100%; margin:0 auto}
.video-tile:nth-child(3n+1){transform:rotate(-1.5deg)}
.video-tile:nth-child(3n+2){transform:rotate(.8deg)}
.video-tile:nth-child(3n+3){transform:rotate(-.6deg)}
.video-tile:hover{transform:translate(-5px,-5px) rotate(0deg); box-shadow:16px 16px 0 var(--fg); z-index:5}
.video-tile video{width:100%; height:100%; object-fit:cover; display:block}
.video-tile__sound, .video-tile__expand{position:absolute; z-index:4; width:46px; height:46px; min-width:46px; min-height:46px; border-radius:50%; background:rgba(10,6,18,.7); backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px); border:2px solid #fff; color:#fff; font-size:18px; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:transform .25s var(--easing-bounce), background .25s ease; line-height:1; padding:0; font-family:inherit; -webkit-tap-highlight-color:transparent}
.video-tile__sound{top:14px; right:14px}
.video-tile__expand{bottom:74px; right:14px; font-size:16px}
.video-tile__sound:hover, .video-tile__expand:hover{transform:scale(1.12) rotate(-6deg); background:var(--magenta)}
.video-tile__sound:active, .video-tile__expand:active{transform:scale(.94)}
.video-tile__sound.is-on{background:var(--magenta)}
.video-tile video{cursor:pointer}
.video-tile video:fullscreen{object-fit:contain; background:#000}
.video-tile video:-webkit-full-screen{object-fit:contain; background:#000}
.video-tile__pulse{position:absolute; top:14px; left:14px; z-index:3; padding:6px 12px; border-radius:100px; background:rgba(236,4,140,.95); color:#fff; font-family:'Bricolage Grotesque'; font-weight:800; font-size:10px; letter-spacing:.1em; display:flex; align-items:center; gap:7px; border:1.5px solid rgba(255,255,255,.6); box-shadow:0 2px 8px rgba(0,0,0,.3)}
.video-tile__pulse::before{content:""; width:7px; height:7px; border-radius:50%; background:#fff; animation:livePulse 1.4s ease-in-out infinite; box-shadow:0 0 8px rgba(255,255,255,.8)}
@keyframes livePulse{0%,100%{opacity:1; transform:scale(1)}50%{opacity:.4; transform:scale(.6)}}
.video-tile__cap{position:absolute; left:0; right:0; bottom:0; padding:22px 16px 16px; background:linear-gradient(to top, rgba(0,0,0,.92) 0%, rgba(0,0,0,.6) 60%, transparent 100%); color:#fff; font-family:'Bricolage Grotesque'; font-weight:600; font-size:13px; line-height:1.3; pointer-events:none; z-index:2}
.video-tile__cap b{display:block; font-family:'Caveat',cursive; font-weight:700; font-size:20px; color:var(--cyan); margin-bottom:1px; line-height:1}
@media(max-width:768px){
  .tour-section{padding:70px 18px}
  .tour-section__head{margin-bottom:36px}
  .tour-grid{grid-template-columns:1fr; gap:32px; max-width:320px}
  .video-tile{transform:none !important; box-shadow:8px 8px 0 var(--fg)}
  .video-tile:hover{box-shadow:10px 10px 0 var(--fg)}
  .video-tile__sound{width:42px; height:42px; font-size:16px}
}

/* Map section (epikoinonia) — centered single column on desktop */
.map-section .map-section__wrap{max-width:920px; margin:0 auto}
.map-section__head{text-align:center; margin-bottom:36px}
.map-section__head .h2{margin:0 auto 14px}
.map-section__lead{max-width:640px; margin:0 auto; font-size:17px}
.map-stack{display:grid; gap:22px; margin-top:24px; grid-template-columns:1fr 1fr}
.map-stack > div{display:flex; flex-direction:column; gap:10px}
.map-stack iframe{width:100%; height:320px; border:3px solid var(--fg); border-radius:20px; box-shadow:10px 10px 0 var(--fg); display:block; background:var(--cyan)}
.map-stack__label{font-family:'Caveat',cursive; font-weight:700; font-size:20px; color:var(--magenta); display:flex; align-items:center; gap:8px; line-height:1.2}
.map-stack__label::before{content:"📍"}
@media(max-width:880px){
  .map-stack{grid-template-columns:1fr; gap:28px}
  .map-stack iframe{height:260px; box-shadow:8px 8px 0 var(--fg)}
  .map-section__lead{font-size:15px}
}

/* Comp card "Join a team" CTA variant (diagonismoi 3rd card) */
.comp--cta{display:flex; flex-direction:column; justify-content:center; align-items:center; padding:36px 24px; text-align:center; min-height:340px; background:linear-gradient(150deg, var(--magenta) 0%, var(--magenta-deep) 100%); border:none}
.comp--cta:hover{transform:translateY(-5px) rotate(-1deg); border-color:transparent}
.comp--cta__icon{width:64px; height:64px; border-radius:50%; background:var(--yellow); border:3px solid var(--bg); display:flex; align-items:center; justify-content:center; font-size:32px; margin-bottom:18px; transition:transform .3s var(--easing-bounce)}
.comp--cta:hover .comp--cta__icon{transform:rotate(-15deg) scale(1.12)}
.comp--cta h3{font-family:'Bricolage Grotesque'; font-weight:800; font-size:28px; letter-spacing:-.02em; color:#fff; line-height:1; margin-bottom:10px}
.comp--cta p{font-size:14px; color:rgba(255,255,255,.85); line-height:1.5; margin-bottom:22px; max-width:260px}
.comp--cta .btn{padding:14px 26px; font-size:14px; background:#fff; color:var(--magenta); transition:all .25s var(--easing-bounce)}
.comp--cta .btn:hover{background:var(--yellow); color:var(--fg); transform:translateY(-2px) rotate(-2deg)}

/* ═════════════════ MOBILE OPTIMIZATION (additive — overrides default rules below 768px / 560px) ═════════════════ */
@media(max-width:768px){
  /* Type scale tightening */
  .hero{min-height:auto; padding:100px 18px 50px; gap:30px}
  .hero__title{font-size:clamp(40px,11vw,60px)}
  .hero__sub{font-size:16px}
  .hero__ctas{gap:10px}
  .hero__ctas .btn{padding:14px 22px; font-size:14px; width:100%; justify-content:center}
  @media(min-width:480px){.hero__ctas .btn{width:auto}}
  .hero__pill{font-size:11px; padding:7px 14px; margin-bottom:18px}
  .hero__canvas-wrap{min-height:480px}
  .hero__video-panel{max-width:240px; transform:rotate(0deg)}
  .hero__mascot{width:80px; top:-12px; right:-8px}
  .hero__sticker{width:74px; height:74px; font-size:9px; bottom:-10px; left:-8px; padding:8px}
  .hero__scroll{display:none}
  /* Decorations smaller on mobile */
  .deco--star1{width:32px} .deco--star2{width:24px}
  .deco--bolt{width:42px; right:4%} .deco--sparkle1, .deco--sparkle2{width:16px}
  /* Page hero */
  .page-hero{padding:100px 18px 50px}
  .page-hero__title{font-size:clamp(40px,11vw,64px)}
  .page-hero__sub{font-size:15px}
  /* Section + wrap padding */
  section.s, .detail-block{padding:60px 18px}
  .moments{padding:60px 18px}
  .cta-band{padding:80px 18px}
  .cta-band__inner{padding:42px 24px; transform:rotate(0deg)}
  .cta-band__title{font-size:clamp(32px,8vw,48px)}
  /* Headings */
  .h2{font-size:clamp(34px,8.5vw,48px); margin-bottom:18px}
  .h3{font-size:clamp(20px,5vw,26px)}
  /* Section heads */
  .section-head{margin-bottom:36px; gap:18px}
  /* Photo cards smaller shadows on mobile to prevent overflow */
  .photo-real{box-shadow:8px 8px 0 var(--fg)}
  .photo-real:hover{box-shadow:10px 10px 0 var(--fg)}
  .viz{box-shadow:8px 8px 0 var(--fg); padding:24px}
  .viz:hover{box-shadow:10px 10px 0 var(--fg)}
  .quote-card{box-shadow:8px 8px 0 var(--fg); padding:32px 24px}
  .quote-card:hover{box-shadow:10px 10px 0 var(--fg)}
  .quote-card__mark{font-size:100px}
  .quote-card__body{font-size:18px}
  .quote-card__sig-name{font-size:26px}
  .moment{box-shadow:6px 6px 0 var(--fg); transform:none !important}
  .moment:hover{box-shadow:8px 8px 0 var(--fg)}
  /* Comp grid + comp cta */
  .comp{box-shadow:none}
  .comp__body{padding:20px}
  .comp--cta{min-height:280px; padding:30px 20px}
  /* Stats + locations */
  .about-stats{grid-template-columns:repeat(2,1fr); gap:10px}
  .stat__num{font-size:30px}
  /* Detail grid */
  .detail-grid{gap:32px}
  /* Form */
  .form-card{padding:26px 20px}
  /* Footer */
  footer{padding:60px 20px 28px}
  .footer-grid{gap:28px; margin-bottom:32px}
  /* Logo intro splash sized down */
  .logo-intro__mark{width:60vw; max-width:240px}
  /* Equipment tiles smaller font */
  .equip-tile__name{font-size:9px}
  /* Hero detail block tag */
  .detail-tag{font-size:11px; padding:5px 11px}
  /* Tickerband — slower + smaller for readability */
  .tickerband{padding:14px 0}
  .tickerband__row{font-size:24px; gap:30px; animation-duration:24s}
  .tickerband__star{width:22px; height:22px}
  /* Marquee partners */
  .partners{padding:50px 0}
  .marquee{gap:36px; animation-duration:28s}
  .marquee__item{font-size:20px}
  .marquee__star{width:14px; height:14px}
  /* Comp section padding */
  .comp-section{padding:70px 18px}
  /* Mobile CTA bar */
  .mobile-cta-bar{left:10px; right:10px; bottom:10px}
  .mobile-cta-bar a{padding:12px; font-size:13px}
  /* Team grid */
  .team-card__initial{font-size:72px}
}
@media(max-width:420px){
  .hero__title{font-size:42px}
  .hero__sub{font-size:14.5px}
  .h2{font-size:34px}
  .page-hero__title{font-size:42px}
  .nav{padding:10px 14px}
  .nav__brand img{height:32px}
  .nav__brand span{font-size:18px}
  .hamburger{width:38px; height:38px}
  .hero__canvas-wrap{min-height:420px}
  .hero__video-panel{max-width:210px}
  .moments-grid{grid-template-columns:1fr}
  .equip-grid{grid-template-columns:repeat(2,1fr)}
}

/* ═════════════════ MOBILE-FIRST FINAL PASS ═════════════════ */

/* Body padding-bottom: clear sticky mobile-cta-bar so content isn't hidden */
@media(max-width:1080px){
  body{padding-bottom:84px}
  /* Logo intro respects sticky safe-area */
  #logo-intro{padding-bottom:0}
}
@media(max-width:1080px) and (display-mode:standalone){
  body{padding-bottom:calc(84px + env(safe-area-inset-bottom))}
}
.mobile-cta-bar{padding-bottom:calc(8px + env(safe-area-inset-bottom,0px))}

/* iOS-safe viewport */
@supports (height:100dvh){
  .hero{min-height:100dvh}
}

/* ─── Touch-device tweaks: kill heavy hover transforms (they stick on tap) ─── */
@media(hover:none){
  .photo-real:hover,
  .moment:hover,
  .viz:hover,
  .video-tile:hover,
  .hero__video-panel:hover,
  .video-vert:hover,
  .quote-card:hover,
  .comp-gallery__item:hover,
  .equip-tile:hover,
  .svc:hover{
    transform:none;
    box-shadow:8px 8px 0 var(--fg)
  }
  .moment:hover{transform:none}
  /* Restore intentional rotations on cards */
  .moment:nth-child(3n+1){transform:rotate(-1.5deg)}
  .moment:nth-child(3n+2){transform:rotate(.8deg)}
  .moment:nth-child(3n+3){transform:rotate(-.5deg)}
  .video-tile:nth-child(3n+1){transform:rotate(-1.5deg)}
  .video-tile:nth-child(3n+2){transform:rotate(.8deg)}
  .video-tile:nth-child(3n+3){transform:rotate(-.6deg)}
  .hero__video-panel{transform:rotate(2deg)}
  /* Image zoom on hover off */
  .photo-real:hover img,
  .moment:hover img,
  .comp-gallery__item:hover img{transform:none}
  /* Tap feedback via :active for buttons */
  .btn:active{transform:scale(.96)}
  .nav__cta:active, .sidebar__cta:active{transform:scale(.96)}
  .video-tile__sound:active, .video-tile__expand:active{transform:scale(.92)}
  .svc:active{transform:scale(.99)}
}

/* ─── Min tap-target sizes (WCAG 2.2 AA: 24px, AAA: 44px) ─── */
.nav a, .sidebar a, .footer__col a, .lang-toggle button,
.svc__more, .field a, .map-stack__label{min-height:32px; display:inline-flex; align-items:center}
.hamburger, .sidebar__close{min-width:44px; min-height:44px}
.video-tile__sound, .video-tile__expand{min-width:46px; min-height:46px}

/* ─── Prevent horizontal scroll from any rotated card overflow ─── */
html, body{overflow-x:hidden; max-width:100%}

/* ─── Maps + iframes responsive ─── */
iframe{max-width:100%}

/* ─── Mobile keyboard zoom prevention (16px+ on inputs/selects) ─── */
input, select, textarea, button{font-size:16px}

/* ─── Mobile safe area for nav (iPhone notch) ─── */
@supports (padding:env(safe-area-inset-top)){
  .nav{padding-top:max(14px, env(safe-area-inset-top))}
  .sidebar__head{padding-top:env(safe-area-inset-top)}
}

/* ─── Tour grid: better stacking on small phones ─── */
@media(max-width:560px){
  .tour-grid{max-width:300px}
  .video-tile{max-width:300px}
  .video-tile__expand{bottom:68px}
  .video-tile__sound, .video-tile__expand{width:42px; height:42px; min-width:42px; min-height:42px; font-size:16px}
}

/* ─── Fluid typography clamp safety ─── */
.hero__title, .page-hero__title, .h2, .h3{word-wrap:break-word; overflow-wrap:break-word; hyphens:auto}
