/* --- Combined stylesheet generated --- */

/* From index.html */
:root{
      --container:1280px;
      --brand:#406CA3; /* accent used on quotes */
      --cta:#017a0a;   /* green CTA */
      --cta-border:#0b5c12;
      --rule:#e5e5e5;
    }
    *{box-sizing:border-box}
    html,body{margin:0;padding:0}
    body{font-family:'Cabin', Helvetica, Arial, sans-serif; color:#111; background:#fff; line-height:1.5}
    .container{max-width:var(--container); margin:0 auto; padding:0 10px}
    .row{display:flex; flex-wrap:wrap; margin:0 -10px}
    .col{padding:0 10px}
    .col-12{flex:0 0 100%}
    .col-6{flex:0 0 50%}
    .col-4{flex:0 0 33.3333%}
    @media (max-width: 960px){ .col-6,.col-4{flex-basis:100%} }

    /* Headline sizes pulled from source (H1=32px, quotes=23px) */
    h1.section{font-size:32px; text-align:center; margin:18px 0; font-weight:700}
    h2.quote{font-size:23px; text-align:center; font-weight:400; font-style:italic; margin:0 0 10px}
    .top-alert{font-size:30px; color:rgb(255 0 0); text-align:center; margin:0px 0;    line-height: 1.2}
    .sub-note{font-size:16px; text-align:center}
    .divider{height:1px;background:var(--rule);margin:18px 0}

    /* Video wrappers mimic CF markup */
    .video-wrap{position:relative; width:100%; border:0;}
    .ratio{position:relative; width:100%;}
    .ratio::before{content:""; display:block; padding-top:56.25%}
    .ratio > *{position:absolute; inset:0; width:100%; height:100%}
    .videoplaceholder{display:grid; place-items:center; background:#000; cursor:pointer}
    .videoplaceholder_inner{width:72px; height:72px; border-radius:999px; background:rgba(255,255,255,.1); border:2px solid rgba(255,255,255,.7); display:grid; place-items:center}
    .videoplaceholder_inner:after{content:""; border-left:20px solid #fff; border-top:12px solid transparent; border-bottom:12px solid transparent; margin-left:6px}

    img.responsive{max-width:100%; height:auto; display:block; margin:0 auto}

    .cta{display:inline-block; background:var(--cta); color:#fff; text-decoration:none; padding:14px 18px; border-radius:3px; font-weight:700; border-bottom:3px solid var(--cta-border)}
    .cta:hover{filter:brightness(1.05)}

    .block{margin:22px 0}
    .between{margin:26px 0}
    .center{text-align:center}
    .brand{color:var(--brand); font-weight:700}

    /* Lazy loading fade-in */
    .fade{opacity:0; transition:opacity .35s ease}
    .fade.loaded{opacity:1}
      .sticky-cta{position:sticky;top:0;z-index:100;background:var(--cta);color:#fff;text-align:center;border-top:6px solid var(--cta-border);border-bottom:6px solid var(--cta-border);transform:translateY(-110%);opacity:0;pointer-events:none;transition:transform .25s ease, opacity .25s ease}
    .sticky-cta.show{transform:translateY(0);opacity:1;pointer-events:auto}
    .sticky-cta a{display:inline-block;padding:10px 22px;font-weight:700;color:#fff;text-decoration:none}
      /* simple responsive gallery */
    .gallery{margin:26px 0}
    .grid{display:grid;grid-template-columns:repeat(6,1fr);gap:10px}
    @media(max-width:1200px){.grid{grid-template-columns:repeat(4,1fr)}}
    @media(max-width:780px){.grid{grid-template-columns:repeat(2,1fr)}}
    .grid img{width:100%;height:auto;display:block;border-radius:4px}
	
	
	.cta,
.sticky-cta a{
  font-size: clamp(28px, 6vw, 50px); /* ελάχιστο 28px, μέγιστο 50px */
  line-height: 1.15;
  padding: 12px 20px;
}
/* 1) Κράτα σταθερό χώρο για την κάθετη scrollbar */
:root { scrollbar-gutter: stable both-edges; }
@supports not (scrollbar-gutter: stable) {
  html { overflow-y: scroll; }            /* fallback για παλιότερα browsers */
}

/* 2) Αποφυγή τυχαίου οριζόντιου scroll */
html, body { overflow-x: hidden; }

/* 3) Κάνε τη μπάρα πραγματικά fixed ώστε να μην αλλάζει το ύψος */
.sticky-cta{
  position: fixed; top:0; left:0; right:0; z-index:1000;
  background: var(--cta); color:#fff;
  /* αντί για border (που αλλάζει ύψος), βάλε inset box-shadow */
  box-shadow: 0 6px 0 var(--cta-border) inset, 0 -6px 0 var(--cta-border) inset;
  /* animation χωρίς αλλαγή ύψους */
  transform: translateY(-110%); opacity:0; pointer-events:none;
  transition: transform .25s ease, opacity .25s ease;
}
.sticky-cta.show{ transform: translateY(0); opacity:1; pointer-events:auto; }

/* 4) Σταθερό κενό στην κορυφή για να μην σκεπάζει περιεχόμενο */
body { padding-top: 70px; }  /* ρύθμισέ το στο πραγματικό ύψος της μπάρας σου */

:root { --sticky-h: 74px; }   /* ύψος της μπάρας σου (ρύθμισέ το) */

body { padding-top: 0; }      /* καθόλου padding by default */
body.has-sticky { padding-top: var(--sticky-h); }  /* μόνο όταν φαίνεται το CTA */

/* From index.html */
/* Κεντραρισμένο container – δεν πιάνει 100% */
  .twall .wrap{
    max-width: 1200px;        /* άλλαξέ το αν θες πιο στενό/φαρδύ */
    margin: 0 auto;
    padding: 8px 12px;
  }

  /* Masonry με columns για να μην υπάρχουν dead spaces */
  .masonry{
    columns: 4 260px;         /* # στηλών & ελάχιστο πλάτος στοιχείου */
    column-gap: 12px;
  }
  .masonry img{
    width: 100%;
    display: block;
    margin: 0 0 12px;
    break-inside: avoid;      /* αποφυγή σπασίματος στηλών γύρω από εικόνες */
    border-radius: 6px;       /* προαιρετικό */
  }

  /* Responsive στήλες */
  @media (max-width: 1200px){ .masonry{ columns: 3 240px; } }
  @media (max-width: 900px) { .masonry{ columns: 2 220px; } }
  @media (max-width: 560px) { .masonry{ columns: 1 280px; } }
  
  
  
  /* ========== Broadsheet theme (Greek-friendly) ========== */
/* (A) Webfonts με ελληνική υποστήριξη — μπορείς να αφήσεις το 0,700;1,400&family=Noto+Serif:wght@400;700&display=swap");

/* (B) Χρωματικές μεταβλητές ΜΟΝΟ μέσα στο broadsheet section */
.broadsheet{
  --ink: #111;
  --paper: #ebebeb;      /* ζητήθηκε */
  --rule: #000;          /* dashed γραμμές */
  --red: #c1121f;        /* accent κόκκινο */
  --yellow: #fff279;     /* highlighter */
  color: var(--ink);
  font: 16px/1.65 "Noto Serif", Georgia, serif;
  background: var(--paper);
}

/* Αν θες όλη η σελίδα να έχει #ebebeb, βάλε στο <body> class="broadsheet-page" */
.broadsheet-page{ background:#ebebeb; }

/* -------- Τυπογραφία -------- */
.broadsheet .headline{
  font: 700 34px/1.1 "Source Serif 4", serif;
  text-align: center;
  letter-spacing: .02em;
  margin: 0 0 12px;
  text-transform: uppercase;
}
.broadsheet .deck{
  font: italic 16px/1.5 "Noto Serif", serif;
  text-align: center;
  margin: 0 0 24px;
}
.broadsheet h2.h{
  font: 700 22px/1.2 "Source Serif 4", serif;
  margin: 0 0 10px;
  text-align: center;
}
.broadsheet img,
.broadsheet iframe{
  display: block;
  width: 100%;
  height: auto;
  border: 0;
}

/* -------- Layout / Κουτιά -------- */
.broadsheet .wrap{ max-width:1200px; margin:0 auto; padding:28px 18px; }
.broadsheet .row{ display:grid; grid-template-columns:1fr 1fr 1fr; gap:18px; margin:26px 0; }

/* dashed dividers & panels (όπως ζήτησες) */
.broadsheet .rule{ height:0; border-top:2px dashed var(--rule); margin:20px 0; }
.broadsheet .panel{ border:2px dashed var(--rule); padding:14px; background:#fff; }

/* -------- Accents (ΚΟΚΚΙΝΟ) -------- */
/* 1) Inline λέξη/φράση με κόκκινο φόντο και λευκά γράμματα */
.broadsheet .accent{ background:var(--red); color:#fff; padding:0 .18em; font-weight:700; }

/* 2) “Σφραγίδα”/ετικέτα direct marketing */
.broadsheet .stamp{
  display:inline-block;
  background:var(--red);
  color:#fff;
  padding:2px 6px;
  margin:0 0 10px;
  text-transform:uppercase;
  letter-spacing:.03em;
  font-weight:700;
  border:2px dashed var(--rule);
}

/* -------- Highlighters (ΚΙΤΡΙΝΟ & ΚΟΚΚΙΝΟ) -------- */
/* (a) Κεντρική λωρίδα (marker) – ΧΡΗΣΗ: <mark class="hl-yellow">...</mark>
   ή <span class="hl-yellow">...</span> */
.broadsheet .hl-yellow{
  background: linear-gradient(transparent 30%, var(--yellow) 30% 80%, transparent 80%);
  padding: 0 .12em;
}
/* (b) Πλήρες γέμισμα κίτρινου (αν θες πιο “γεμάτο”) */
.broadsheet .hl-yellow-fill{
  background: var(--yellow);
  padding: 0 .12em;
}

/* (c) Κεντρική λωρίδα κόκκινου (πιο “σοβαρό” τονισμα χωρίς να ουρλιάζει)
   ΧΡΗΣΗ: <mark class="hl-red">...</mark> */
.broadsheet .hl-red{
  background: linear-gradient(transparent 30%, rgba(193,18,31,.25) 30% 80%, transparent 80%);
  padding: 0 .12em;
}
/* (d) Πλήρες κόκκινο + λευκό text (για πολύ έντονο CTA μέσα σε κείμενο)
   ΧΡΗΣΗ: <span class="hl-red-fill">...</span> */
.broadsheet .hl-red-fill{
  background: var(--red);
  color: #fff;
  padding: 0 .18em;
  font-weight: 700;
}

/* Προαιρετικό: αυτό-μαρκαρισμένο bold (αν το ενεργοποιήσεις) */
.broadsheet.auto-highlight strong,
.broadsheet.auto-highlight b{
  font-weight:700;
  background: linear-gradient(transparent 30%, var(--yellow) 30% 80%, transparent 80%);
  padding: 0 .12em;
}

/* -------- Responsive -------- */
@media (max-width: 880px){
  .broadsheet .row{ grid-template-columns:1fr; }
}

/* From index-styles.html */
:root {
  --ink:#111;
  --paper:#ebebeb;
  --rule:#000;
  --red:#c1121f;
  --yellow:#fff279;
}

*{box-sizing:border-box}
html,body{margin:0}
body{
  background:var(--paper);
  color:var(--ink);
  font:16px/1.65 'Noto Serif', Georgia, serif;
}

.wrap{max-width:1200px;margin:0 auto;padding:28px 18px}

/* Typography */
.headline{
  font:700 34px/1.1 'Source Serif 4', serif;
  text-align:center;
  letter-spacing:.02em;
  margin:0 0 12px;
  text-transform:uppercase;
}
.deck{
  font:italic 16px/1.5 'Noto Serif', serif;
  text-align:center;
  margin:0 0 24px;
}
h2.h{
  font:700 22px/1.2 'Source Serif 4', serif;
  margin:0 0 10px;
  text-align:center;
}

/* Layout */
.rule{height:0;border-top:2px dashed var(--rule);margin:20px 0}
.row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px;margin:26px 0}
.panel{border:2px dashed var(--rule);padding:14px;background:#fff}

img,iframe{display:block;width:100%;height:auto;border:0}

/* Accents */
.accent{background:var(--red);color:#fff;padding:0 .18em}
.stamp{
  display:inline-block;
  background:var(--red);
  color:#fff;
  padding:2px 6px;
  margin:0 0 10px;
  text-transform:uppercase;
  letter-spacing:.03em;
  font-weight:700;
}

/* Highlighter */
strong,b{
  font-weight:700;
  background:linear-gradient(transparent 35%, var(--yellow) 35% 75%, transparent 75%);
  padding:0 .12em;
}

@media(max-width:880px){
  .row{grid-template-columns:1fr}
}

/* Extras / normalization */

:root{
  --container:1280px;
  --brand:#406CA3;
  --cta:#017a0a;
  --cta-border:#0b5c12;
  --rule:#e5e5e5;
  --ink:#111;
  --paper:#ebebeb;
  --red:#c1121f;
  --yellow:#fff279;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:'Noto Serif', Georgia, serif;color:var(--ink);background:#fff;line-height:1.6}
.container{max-width:var(--container); margin:0 auto; padding:0 10px}
.row{display:flex; flex-wrap:wrap; margin:0 -10px}
.col{padding:0 10px}
.col-12{flex:0 0 100%}
.col-6{flex:0 0 50%}
.col-4{flex:0 0 33.3333%}
@media (max-width: 960px){ .col-6,.col-4{flex-basis:100%} }
h1.section{font-size:32px; text-align:center; margin:18px 0; font-weight:700}
h2.quote{font-size:23px; text-align:center; font-weight:400; font-style:italic; margin:0 0 10px}
.sub-note{font-size:16px; text-align:center}
.divider{height:1px;background:var(--rule);margin:18px 0}
.video-wrap{position:relative; width:100%; border:0;}
.ratio{position:relative; width:100%;}
.ratio::before{content:""; display:block; padding-top:56.25%}
.ratio > *{position:absolute; inset:0; width:100%; height:100%}
.videoplaceholder{display:grid; place-items:center; background:#000; cursor:pointer}
.videoplaceholder_inner{width:72px; height:72px; border-radius:999px; background:rgba(255,255,255,.1); border:2px solid rgba(255,255,255,.7); display:grid; place-items:center}
.videoplaceholder_inner:after{content:""; border-left:20px solid #fff; border-top:12px solid transparent; border-bottom:12px solid transparent; margin-left:6px}
img.responsive{max-width:100%; height:auto; display:block; margin:0 auto}
.cta{display:inline-block; background:var(--cta); color:#fff; text-decoration:none; padding:14px 18px; border-radius:3px; font-weight:700; border-bottom:3px solid var(--cta-border)}
.cta:hover{filter:brightness(1.05)}
.block{margin:22px 0}
.between{margin:26px 0}
.center{text-align:center}
.brand{color:#406CA3; font-weight:700}
:root { scrollbar-gutter: stable both-edges; }
html, body { overflow-x: hidden; }
.sticky-cta{position: fixed; top:0; left:0; right:0; z-index:1000;background: var(--cta); color:#fff; text-align:center;box-shadow: 0 6px 0 var(--cta-border) inset, 0 -6px 0 var(--cta-border) inset;transform: translateY(-110%); opacity:0; pointer-events:none;transition: transform .25s ease, opacity .25s ease;}
.sticky-cta.show{ transform: translateY(0); opacity:1; pointer-events:auto; }
.sticky-cta a{display:inline-block;padding:10px 22px;font-weight:700;color:#fff;text-decoration:none}
.cta, .sticky-cta a{ font-size: clamp(28px, 6vw, 50px); line-height:1.15; padding: 12px 20px; }
:root { --sticky-h: 74px; }
body.has-sticky { padding-top: var(--sticky-h); }
.hero-dark{ background:#000; color:#fff; }
.hero-dark .sub-note{ color:#fff; }
.gallery{margin:26px 0}
.grid{display:grid;grid-template-columns:repeat(6,1fr);gap:10px}
@media(max-width:1200px){.grid{grid-template-columns:repeat(4,1fr)}}
@media(max-width:780px){.grid{grid-template-columns:repeat(2,1fr)}}
.grid img{width:100%;height:auto;display:block;border-radius:4px}
.twall .wrap{ max-width: 1200px; margin: 0 auto; padding: 8px 12px; }
.masonry{ columns: 4 260px; column-gap: 12px; }
.masonry img{ width: 100%; display: block; margin: 0 0 12px; break-inside: avoid; border-radius: 6px; }
@media (max-width: 1200px){ .masonry{ columns: 3 240px; } }
@media (max-width: 900px) { .masonry{ columns: 2 220px; } }
@media (max-width: 560px) { .masonry{ columns: 1 280px; } }
.broadsheet{ --ink:#111; --paper:#ebebeb; --rule:#000; --red:#c1121f; --yellow:#fff279; color:var(--ink); background:var(--paper); }
.broadsheet .wrap{ max-width:1200px; margin:0 auto; padding:28px 18px; }
.broadsheet .headline{ font: 700 34px/1.1 "Source Serif 4", serif; text-align:center; letter-spacing:.02em; margin:0 0 12px; text-transform:uppercase; }
.broadsheet .deck{ font: italic 16px/1.5 "Noto Serif", serif; text-align:center; margin:0 0 24px; }
.broadsheet h2.h{ font: 700 22px/1.2 "Source Serif 4", serif; margin:0 0 10px; text-align:center; }
.broadsheet img, .broadsheet iframe{ display:block; width:100%; height:auto; border:0; }
.broadsheet .rule{ height:0; border-top:2px dashed var(--rule); margin:20px 0; }
.broadsheet .panel{ border:2px dashed var(--rule); padding:14px; background:#fff; }
.broadsheet .accent{ background:var(--red); color:#fff; padding:0 .18em; font-weight:700; }
.broadsheet .stamp{ display:inline-block; background:var(--red); color:#fff; padding:2px 6px; margin:0 0 10px; text-transform:uppercase; letter-spacing:.03em; font-weight:700; border:2px dashed var(--rule); }
.broadsheet .hl-yellow{ background: linear-gradient(transparent 30%, var(--yellow) 30% 80%, transparent 80%); padding: 0 .12em; }
.broadsheet .hl-yellow-fill{ background: var(--yellow); padding: 0 .12em; }
.broadsheet .hl-red{ background: linear-gradient(transparent 30%, rgba(193,18,31,.25) 30% 80%, transparent 80%); padding: 0 .12em; }
.broadsheet .hl-red-fill{ background: var(--red); color: #fff; padding: 0 .18em; font-weight: 700; }
@media (max-width: 880px){ .broadsheet .row{ display:block; } }


/* === User tweaks === */

/* Red banner strips */
.broadsheet .banner-red{
  display:block;
  width:100%;
  background: var(--red);
  color:#fff;
  padding: 8px 12px;
  font-weight: 800;
  text-align:center;
  border:2px dashed var(--rule);
  margin: 10px 0;
  letter-spacing:.02em;
}

/* Auto-highlight bold text inside broadsheet */
.broadsheet b,
.broadsheet strong{
  background: var(--yellow);
  padding: 0 .15em;
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 2px;
  font-weight: 800;
}

/* Make yellow fill option stronger when we explicitly use it */
.broadsheet .hl-yellow-fill{
  background: var(--yellow);
  padding: 0 .18em;
  font-weight: 800;
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 2px;
}

/* Red fill fine-tune */
.broadsheet .hl-red-fill{
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
  border-radius: 3px;
}

/* Tighten vertical rhythm to reduce dead space */
.broadsheet .panel{ margin: 6px 0; }
.broadsheet .rule{ margin: 14px 0; }
.broadsheet .row{ align-items: flex-start; }
.broadsheet .panel .video-wrap{ margin-top: 6px; }

/* Avoid dashed panels wrapping entire rows */
.broadsheet .row.panel{ border: 0; padding: 0; background: transparent; }


/* Poster image fills the video wrapper so it's not black */
.video-wrap, .video-hero { position: relative; }
.video-wrap.ratio, .video-hero.ratio { aspect-ratio: 16/9; }
.video-wrap .video-poster, .video-hero .video-poster {
  position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block;
}
.video-wrap .play-btn, .video-hero .play-btn {
  position: absolute; inset: 0; width: 100%; height: 100%; background: transparent; border: 0; cursor: pointer;
}


/* --- Video poster fixes to avoid black frame --- */
.video-wrap, .video-hero { position: relative; background: transparent ; }
.video-wrap .videoplaceholder, .video-hero .videoplaceholder { background: transparent ; }
.video-wrap .video-poster, .video-hero .video-poster {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; display: block; z-index: 1;
}
.video-wrap .play-btn, .video-hero .play-btn { position: absolute; inset: 0; z-index: 2; background: transparent; border: 0; }
.video-wrap iframe, .video-hero iframe { position: absolute; inset: 0; width: 100%; height: 100%; display: block; z-index: 3; }


/* ===== Application page styles (build on existing theme) ===== */
.topbar{
  position: sticky; top: 0; z-index: 1000;
  background: #000; color:#fff;
  border-bottom: 1px solid rgba(255,255,255,.12);
}
.topbar__in{ display:flex; align-items:center; justify-content:space-between; min-height:48px; }
.brand-title{ color:#fff; text-decoration:none; font-weight:800; }
.topbar__link{ color:#fff; text-decoration:none; opacity:.9; }
.topbar__link:hover{ opacity:1; }

.lead-hero{ padding:42px 0 22px; background:#fff; color:#111; text-align:center; }
.lead-headline{
  font: 800 clamp(28px, 4.5vw, 44px)/1.12 "Source Serif 4", serif;
  margin: 0 0 10px;
}
.lead-step{
  font: 700 16px/1.45 "Noto Serif", serif;
  color:#c1121f;            /* red like the screenshot */
  margin: 0;
}

/* Gradient shell around the form */
.lead-form-area{ padding: 12px 0 48px; }
.form-shell{
  background: linear-gradient(180deg, #49a6ff 0%, #2b78c6 100%);
  border-radius: 14px;
  padding: 20px;
  box-shadow: 0 12px 30px rgba(0,0,0,.12);
}
.form-shell-title{
  text-align:center;
  color:#fff;
  font: 800 clamp(18px, 2.8vw, 28px)/1.2 "Source Serif 4", serif;
  margin: 6px 0 12px;
  text-shadow: 0 1px 0 rgba(0,0,0,.15);
  letter-spacing:.02em;
}
.form-card{
  background:#fff;
  border-radius: 10px;
  overflow:hidden;
  box-shadow: 0 6px 18px rgba(0,0,0,.12);
  padding: 0;
}

/* Make the embedded Jotform behave responsively */
.form-card iframe,
.form-card [id^="JotFormIFrame"]{
  width: 100% ;
  min-height: 760px;
  display:block;
}

/* Footer */
.footnote{ padding: 28px 0; background:#fff; color:#666; font: 400 14px/1.4 "Noto Serif", serif; text-align:center; }

/* Mobile polish */
@media (max-width: 680px){
  .lead-hero{ padding-top: 28px; }
  .form-shell{ padding: 16px; }
  .form-card iframe,
  .form-card [id^="JotFormIFrame"]{ min-height: 880px; } /* extra space for stacked fields */
}


/* ===== Calendly (Step 2/2) ===== */
.book-hero{ text-align:center; padding:40px 0 12px; }
.book-note{
  margin: 6px auto 4px;
  font: 700 15px/1.5 "Noto Serif", serif;
  color:#b30000;
}
.book-note .accent{ text-decoration: underline; }
.book-note-2{
  margin:0 auto 14px;
  font: 400 14px/1.6 "Noto Serif", serif;
  color:#333;
}
.book-note-2 a{ color:#b30000; text-underline-offset:2px; }

.calendly-shell{ padding: 8px 0 54px; }
.calendly-card{
  background:#fff;
  border-radius: 14px;
  overflow:hidden;
  box-shadow: 0 14px 34px rgba(0,0,0,.12);
  padding: 0;
}

/* Ensure the widget stretches full width nicely */
.calendly-card .calendly-inline-widget{ width:100% ; display:block; }
.container{ width:min(1100px,92%); margin-inline:auto; }

@media (max-width: 680px){
  .book-hero{ padding-top:28px; }
  .calendly-card .calendly-inline-widget{ height: 1100px ; }
}

/* Fix: avoid inner scrollbars by making the Calendly container taller */
.calendly-card .calendly-inline-widget{ height: 1200px ; }
.calendly-card .calendly-inline-widget iframe{ height: 1200px ; }

@media (max-width: 1024px){
  .calendly-card .calendly-inline-widget{ height: 1400px ; }
  .calendly-card .calendly-inline-widget iframe{ height: 1400px ; }
}
@media (max-width: 680px){
  .calendly-card .calendly-inline-widget{ height: 1600px ; }
  .calendly-card .calendly-inline-widget iframe{ height: 1600px ; }
}

/* With landing page details hidden, we can reduce heights */
.calendly-card .calendly-inline-widget{ height: 1050px ; }
.calendly-card .calendly-inline-widget iframe{ height: 1050px ; }

@media (max-width: 1024px){
  .calendly-card .calendly-inline-widget{ height: 1250px ; }
  .calendly-card .calendly-inline-widget iframe{ height: 1250px ; }
}
@media (max-width: 680px){
  .calendly-card .calendly-inline-widget{ height: 1400px ; }
  .calendly-card .calendly-inline-widget iframe{ height: 1400px ; }
}

/* Smaller heading on mobile so the calendar appears sooner */
@media (max-width: 480px){
  .lead-headline{ font-size: 28px; }
  .book-note{ font-size: 14px; }
  .book-note-2{ font-size: 13px; }
}


/* === Two-column booking layout === */
.container--wide{ width:min(1280px, 96%); margin-inline:auto; }
.cal-two{ padding: 12px 0 36px; }
.cal-grid{
  display:grid;
  grid-template-columns: 2fr 1.1fr; /* give Calendly more room */
  gap: 24px;
}

/* Cards */
.cal-box, .text-box{
  background:#fff;
  border-radius:14px;
  box-shadow: 0 10px 26px rgba(0,0,0,.10);
}
.cal-box{ overflow:hidden; }
.text-box{ padding:22px 22px; }
.text-title{
  font: 800 20px/1.2 "Source Serif 4", serif; margin: 6px 0 12px;
}
.checklist{ margin:0 0 12px 0; padding-left: 20px; }
.checklist li{ margin: 8px 0; }
.tiny-note{ font: 400 14px/1.6 "Noto Serif", serif; color:#333; }
.goodluck{ font:700 16px/1.2 "Noto Serif", serif; margin-top:8px; }

/* Calendly height tuning to reduce bottom deadspace while avoiding inner scrollbars */
.cal-col .calendly-inline-widget{ width:100% ; height:980px ; display:block; }
.cal-col .calendly-inline-widget iframe{ height:980px ; }

/* Desktop: make the right column sticky so it uses vertical space smartly */
@media (min-width: 1025px){
  .text-col{ position: sticky; top: 84px; height: fit-content; }
}

/* Tablet / Mobile stack */
@media (max-width: 1024px){
  .cal-grid{ grid-template-columns: 1fr; }
  .text-col{ position: static; }
  .cal-col .calendly-inline-widget{ height:1150px ; }
  .cal-col .calendly-inline-widget iframe{ height:1150px ; }
}

@media (max-width: 680px){
  .container--wide{ width:min(100%, 96%); }
  .cal-col .calendly-inline-widget{ height:1250px ; }
  .cal-col .calendly-inline-widget iframe{ height:1250px ; }
}

/* === Deadspace reduction pass === */
.container--wide{ width:min(1400px, 98%); }

.cal-two{ padding: 8px 0 18px; }

/* Base/desktop */
.cal-col .calendly-inline-widget{ height:920px ; }
.cal-col .calendly-inline-widget iframe{ height:920px ; }

/* Tablet */
@media (max-width: 1024px){
  .cal-col .calendly-inline-widget{ height:1000px ; }
  .cal-col .calendly-inline-widget iframe{ height:1000px ; }
}

/* Mobile */
@media (max-width: 680px){
  .cal-col .calendly-inline-widget{ height:1050px ; }
  .cal-col .calendly-inline-widget iframe{ height:1050px ; }
}

/* === Deadspace fix v2 === */
/* Base desktop height a bit tighter */
.cal-col .calendly-inline-widget{ height:880px; display:block; }
.cal-col .calendly-inline-widget iframe{ height:880px; }

/* Tablet */
@media (max-width: 1024px){
  .cal-col .calendly-inline-widget{ height:940px; }
  .cal-col .calendly-inline-widget iframe{ height:940px; }
}

/* Mobile */
@media (max-width: 680px){
  .cal-col .calendly-inline-widget{ height:860px; }
  .cal-col .calendly-inline-widget iframe{ height:860px; }
}


/* -------- Base -------- */
:root {
  --text: #222;
  --muted: #606060;
  --blue: #0075B2;
  --bg: #fff;
  --maxw: 1040px;
}
* { box-sizing: border-box; }
body { margin:0; font-family: "Open Sans", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; color:var(--text); background:var(--bg); }
.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 16px; }

/* -------- Top bar + countdown -------- */
.topbar { background:#000; color:#fff; padding:10px 0; }
.topbar .wrap { display:flex; align-items:center; justify-content:center; gap:18px; flex-wrap:wrap; }
.topbar__label { font-weight:700; font-size:14px; }
.countdown { display:flex; align-items:center; gap:10px; }
.cd-box { background:#111; border-radius:6px; padding:8px 10px; text-align:center; min-width:70px; }
.cd-num { font-weight:800; font-size:26px; color:#fff; line-height:1; }
.cd-lbl { font-size:10px; letter-spacing:.12em; color:#cfd3d7; margin-top:4px; }

.countdown--inline .cd-box { min-width:64px; padding:6px 8px; }
.countdown--inline .cd-num { font-size:22px; }

/* -------- Hero -------- */
.hero { text-align:center; padding: 18px 0 0; }
.hero__title { font-family: "Raleway", Arial, sans-serif; font-weight:800; font-size:40px; line-height:1.15; margin: 10px 0; }
.hero__sub { font-size:18px; margin: 8px 0 6px; color:var(--muted); }

/* -------- Two columns -------- */
.two-col { display:grid; grid-template-columns: 1fr 1fr; gap:28px; padding: 24px 0 8px; }
.col--media .media { width:100%; height:auto; display:block; border-radius:6px; box-shadow: 0 6px 18px rgba(0,0,0,.15); }
.caption { text-align:center; font-size:12px; color:var(--muted); margin:8px 0 0; }
.section-title { text-align:center; font-weight:700; font-size:18px; margin:0 0 10px; }

.checks { margin:8px 0 14px; padding-left:0; list-style:none; }
.checks li { margin: 8px 0; padding-left:28px; position:relative; font-size:16px; line-height:1.55; }
.checks li::before { content:"✓"; position:absolute; left:0; top:0; font-weight:700; }

.btn { display:inline-block; text-align:center; border-radius:6px; padding:14px 18px; font-weight:700; text-decoration:none; cursor:pointer; }
.btn--primary { background: var(--blue); color:#fff; width:100%; font-size:22px; }
.btn--primary:hover { filter: brightness(.92); }
.fine { text-align:center; font-size:12px; margin: 8px 0; }

@media (max-width: 860px) {
  .two-col { grid-template-columns: 1fr; }
  .btn--primary { font-size:20px; }
  .hero__title { font-size:32px; }
}

/* -------- Modal -------- */
.modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:2000;opacity:0;pointer-events:none;transition:opacity .25s ease;}
.modal[aria-hidden="false"]{opacity:1;pointer-events:auto;}
.modal__overlay{position:absolute;inset:0;background:rgba(0,0,0,.63);}
.modal__card{position:relative;z-index:1;width:min(720px,92vw);max-height:90vh;overflow:auto;background:#fff;border-radius:10px;box-shadow:0 20px 60px rgba(0,0,0,.35);padding:20px 16px 24px;}
.modal__close{position:absolute;top:8px;right:10px;border:0;background:transparent;font-size:30px;line-height:1;cursor:pointer;color:#333;opacity:.7}
.modal__close:hover{opacity:1}
body.modal-open{overflow:hidden}

/* Hide any UTM rows if present */
#_form_17_ ._form_element._field1,
#_form_17_ ._form_element._field5,
#_form_17_ ._form_element._field6{display:none !important;}

/* -------- Footer -------- */
.site-footer {
  background:#000; color:#fff; text-align:center;
  font: 400 13px/1.6 "Open Sans", Arial, sans-serif;
  padding: 24px 12px; margin-top: 40px;
}
.site-footer p { margin:6px 0; }
.site-footer a { color:#fff; text-decoration: underline; text-underline-offset:2px; }
.site-footer a:hover { opacity:.8; }
.site-footer .small-c { font-size:.8em; vertical-align: baseline; }
