:root{
  --blue:#1a61ad;
  --blue-dark:#0f4f95;
  --ink:#071226;
  --muted:#425b7e;
  --line:rgba(26,97,173,.16);
  --soft:#f4f9ff;
  --white:#fff;
  --serif:"Google Sans Flex", "Google Sans", Arial, sans-serif;
  --sans:"Google Sans Flex", "Google Sans", Arial, sans-serif;
}

*{box-sizing:border-box}
html{min-height:100%;scroll-behavior:smooth}
body{margin:0;min-height:100%;font-family:var(--sans);color:var(--ink);background:#fff;line-height:1.55}
a{color:inherit}
button,input,select{font:inherit}
button{cursor:pointer}
.pattern{position:fixed;left:0;right:0;height:14px;background:url('/assets/img/border.svg') repeat-x;background-size:auto 14px;z-index:6000;pointer-events:none}.pattern-top{top:0}.pattern-bottom{bottom:0}

/* Header */
.site-header{position:fixed;top:14px;left:0;right:0;z-index:5000;height:74px;display:flex;align-items:center;justify-content:space-between;padding:0 clamp(20px,4vw,56px);background:rgba(255,255,255,.94);border-bottom:1px solid var(--line);backdrop-filter:blur(16px)}
.brand-link{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);display:block}.brand-link img{display:block;width:172px;height:auto}.lang-rocker{width:42px;height:42px;border:1px solid var(--line);border-radius:50%;display:grid;place-items:center;text-decoration:none;color:var(--blue);background:#fff;font-weight:900;font-size:.78rem;box-shadow:0 12px 30px rgba(9,17,31,.08)}
.menu-button{width:48px;height:48px;border:1px solid rgba(26,97,173,.38);background:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;position:relative;overflow:hidden;box-shadow:0 12px 30px rgba(26,97,173,.12)}
.menu-button:after{content:"";position:absolute;left:0;right:0;bottom:0;height:6px;background:url('/assets/img/border.svg') repeat-x center;background-size:auto 6px}.menu-button span{display:block;width:24px;height:2px;background:var(--blue)}

/* Takeover Menu */
body.menu-is-open{overflow:hidden}.takeover-menu{display:none}.site-header.menu-open{position:fixed;inset:0;height:100vh;padding:0;background:var(--blue);border:0;display:block;overflow:hidden}.site-header.menu-open .lang-rocker{display:none}.site-header.menu-open .brand-link{display:none}.site-header.menu-open .menu-button{position:fixed;top:34px;right:34px;z-index:6010;width:44px;height:44px;border:1px solid rgba(255,255,255,.78);background:rgba(255,255,255,.06);box-shadow:none}.site-header.menu-open .menu-button:after{display:none}.site-header.menu-open .menu-button span{position:absolute;left:12px;top:20px;width:18px;height:2px;margin:0;background:#fff}.site-header.menu-open .menu-button span:nth-child(1){transform:rotate(45deg)}.site-header.menu-open .menu-button span:nth-child(2){opacity:0}.site-header.menu-open .menu-button span:nth-child(3){transform:rotate(-45deg)}
.site-header.menu-open .takeover-menu{position:fixed;inset:0;z-index:6001;display:grid;grid-template-columns:minmax(0,1fr) 340px;width:100vw;height:100vh;background:var(--blue);color:#fff}.takeover-logo{position:fixed;left:38px;top:34px;z-index:6005}.takeover-logo img{display:block;width:160px;height:auto}.takeover-left{position:relative;display:flex;align-items:center;padding:118px clamp(38px,6vw,88px) 82px}.takeover-links{display:flex;flex-direction:column;gap:3px;align-items:flex-start}.takeover-links a,.takeover-links button{appearance:none;border:0;background:transparent;padding:0;margin:0;color:#fff;text-decoration:none;font-family:var(--sans);font-style:normal;font-size:clamp(2.05rem,4vw,4.25rem);font-weight:900;line-height:1.02;letter-spacing:-.055em;text-align:left;text-transform:none}.takeover-links a:hover,.takeover-links button:hover{color:#e6f2ff}.takeover-bottom-line{position:absolute;left:clamp(38px,6vw,88px);bottom:30px;margin:0;text-transform:uppercase;letter-spacing:.18em;font-size:.7rem;font-weight:900;color:#fff}.takeover-right{display:flex;flex-direction:column;justify-content:space-between;gap:36px;padding:118px 34px 30px;border-left:1px solid rgba(255,255,255,.24);background:rgba(0,0,0,.09)}.takeover-label{margin:0 0 12px;color:rgba(255,255,255,.72);text-transform:uppercase;letter-spacing:.16em;font-size:.66rem;font-weight:900}.takeover-buy-block button{width:100%;border:1px solid #fff;background:#fff;color:var(--blue);padding:14px 18px;font-weight:950;text-transform:uppercase}.takeover-policies{display:flex;flex-direction:column;gap:10px}.takeover-policies a{color:#fff;text-decoration:none;font-size:.95rem;font-weight:800}.takeover-bottom-line.right{position:static;text-align:right;line-height:1.3}

/* Homepage */
.home-page{min-height:100svh;padding:122px 220px 70px;display:grid;place-items:center;text-align:center;position:relative}.hero-card{max-width:790px;margin:auto}.sale-label,.eyebrow{margin:0 0 12px;color:var(--blue);text-transform:uppercase;letter-spacing:.18em;font-size:.76rem;font-weight:900}.hero-logo{display:block;width:min(340px,68vw);margin:0 auto 8px}.home-page h1{margin:0 0 10px;font-size:clamp(3.3rem,7vw,6.6rem);line-height:.92;letter-spacing:-.06em}.hero-kicker{margin:0 0 18px;color:var(--blue);font-size:clamp(1.35rem,2.2vw,1.75rem);font-weight:900}.hero-copy{max-width:680px;margin:0 auto 24px;color:var(--muted);font-size:clamp(1rem,1.25vw,1.15rem)}.price-line{margin:0 0 24px;font-size:1.25rem;font-weight:900}.price-line strong{color:var(--blue);font-size:1.25em}.button,.hero-cta,.submit-offer{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:0;background:var(--blue);color:#fff;text-decoration:none;padding:14px 24px;font-weight:900;box-shadow:0 18px 42px rgba(26,97,173,.18)}.button:hover,.hero-cta:hover,.submit-offer:hover{background:var(--blue-dark)}
.banner{position:fixed;top:50%;transform:translateY(-50%);width:160px;height:600px;border:1px dashed rgba(26,97,173,.35);background:linear-gradient(180deg,#f6fbff,#fff);display:flex;align-items:center;justify-content:center;text-align:center;color:#52719b;font-weight:800;z-index:100}.banner-left{left:20px}.banner-right{right:20px}

/* Internal pages */
.content-page{padding:132px clamp(20px,5vw,72px) 70px;max-width:1180px;margin:0 auto}.content-layout{display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:42px;align-items:start}.content-main{min-width:0}.content-hero{text-align:left;margin:0 0 34px}.content-hero h1{font-family:var(--sans);font-weight:900;line-height:.96;letter-spacing:-.045em;font-size:clamp(3rem,6vw,5.8rem);margin:0 0 18px}.content-hero p{font-size:1.13rem;color:var(--muted);max-width:820px}.section{border:1px solid var(--line);background:linear-gradient(180deg,#fff,#f8fbff);padding:clamp(24px,4vw,42px);margin:22px 0}.section h2{font-size:clamp(1.55rem,3vw,2.4rem);line-height:1.05;margin:0 0 14px}.section h3{margin:22px 0 8px;color:var(--blue)}.section p,.section li{color:var(--muted);font-size:1.02rem}.section ul,.section ol{padding-left:1.25rem}.mini-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.mini-card{border:1px solid var(--line);background:#fff;padding:20px}.mini-card h3{margin:0 0 8px}.side-card{position:sticky;top:112px;border:1px solid var(--line);padding:22px;background:#fff}.side-card img{display:block;width:180px;margin:0 auto 18px}.side-price{font-size:1.1rem;font-weight:900;text-align:center}.side-price strong{display:block;color:var(--blue);font-size:1.6rem}.side-card nav{display:flex;flex-direction:column;margin:18px 0;border-top:1px solid var(--line)}.side-card nav a{padding:12px 0;border-bottom:1px solid var(--line);text-decoration:none;font-weight:800;color:var(--ink)}.ad-box{border:1px dashed rgba(26,97,173,.35);background:#f7fbff;min-height:220px;display:grid;place-items:center;color:#52719b;text-align:center;font-weight:800}.ad-banner{min-height:90px;margin-top:24px}.faq-list{display:grid;gap:14px}.faq-list details{border:1px solid var(--line);background:#fff;padding:18px}.faq-list summary{cursor:pointer;font-weight:900;color:var(--ink)}.faq-list p{margin-bottom:0}.timeline-list{counter-reset:item;display:grid;gap:14px}.timeline-item{position:relative;border:1px solid var(--line);background:#fff;padding:20px 20px 20px 70px}.timeline-item:before{counter-increment:item;content:counter(item);position:absolute;left:20px;top:20px;width:34px;height:34px;display:grid;place-items:center;background:var(--blue);color:#fff;font-weight:900}

/* Footer */
.site-footer{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:28px clamp(20px,4vw,56px) 42px;border-top:1px solid var(--line);color:#52719b}.site-footer p{margin:0}.footer-small{font-size:.88rem}.site-footer nav{display:flex;gap:18px;flex-wrap:wrap}.site-footer a{text-decoration:none;font-weight:800}.footer-logo{width:132px;height:auto}

/* Offer modal */
body.modal-is-open{overflow:hidden}.offer-modal-shell{position:fixed;inset:0;z-index:7000;display:none;align-items:center;justify-content:center;padding:28px 18px}.offer-modal-shell.is-open{display:flex}.offer-backdrop{position:absolute;inset:0;background:rgba(255,255,255,.94);backdrop-filter:blur(5px)}.offer-modal{position:relative;width:min(620px,100%);max-height:92vh;overflow:auto;background:#fff;border:1px solid rgba(26,97,173,.24);box-shadow:0 36px 100px rgba(9,17,31,.22)}.modal-pattern{height:14px;background:url('/assets/img/border.svg') repeat-x;background-size:auto 14px}.modal-close{position:absolute;top:22px;right:20px;width:38px;height:38px;border:0;background:#eef6ff;color:var(--blue);font-size:1.5rem}.modal-inner{padding:32px}.modal-inner h2{font-family:var(--sans);font-size:clamp(2rem,4vw,3rem);line-height:1;margin:0 42px 12px 0}.modal-note{color:var(--muted)}.offer-form{display:grid;gap:15px}.field-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.offer-form label span{display:block;font-size:.76rem;text-transform:uppercase;letter-spacing:.1em;font-weight:900;color:var(--blue);margin-bottom:7px}.offer-form input,.offer-form select{width:100%;border:1px solid rgba(26,97,173,.22);padding:13px 14px;outline:none}.offer-form input:focus,.offer-form select:focus{border-color:var(--blue);box-shadow:0 0 0 4px rgba(26,97,173,.12)}.phone-row{display:grid;grid-template-columns:140px 1fr;gap:10px}.hp-wrap{position:absolute;left:-10000px;width:1px;height:1px;overflow:hidden}.email-field{position:relative}.email-suggestions{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid var(--line);box-shadow:0 18px 48px rgba(9,17,31,.12);display:none;z-index:5}.email-suggestions button{display:block;width:100%;border:0;background:#fff;text-align:left;padding:10px 14px}.submit-offer:disabled{opacity:.42;cursor:not-allowed;box-shadow:none}.offer-form small{display:block;margin-top:7px;color:var(--muted);font-weight:800}.offer-form small.bad{color:#9f1d1d}

/* Cookie widget */
.cookie-widget{position:fixed;right:22px;bottom:24px;z-index:6500;width:min(430px,calc(100vw - 44px));background:#fff;border:1px solid rgba(26,97,173,.24);box-shadow:0 22px 70px rgba(9,17,31,.2);padding:16px;color:var(--ink)}.cookie-widget.is-expanded{width:min(470px,calc(100vw - 44px))}.cookie-head{display:flex;gap:10px;align-items:flex-start;margin-bottom:8px}.cookie-head>span{width:30px;height:30px;display:grid;place-items:center;background:#eef6ff;border:1px solid var(--line)}.cookie-head p{margin:0 0 2px;color:var(--blue);text-transform:uppercase;letter-spacing:.13em;font-size:.64rem;font-weight:900}.cookie-head h2{font-size:1.08rem;line-height:1.1;margin:0}.cookie-copy{margin:0 0 9px;color:var(--muted);font-size:.78rem;line-height:1.45}.cookie-copy a{color:var(--blue);font-weight:900}.cookie-mini-row{display:flex;flex-wrap:wrap;gap:6px 12px;margin:10px 0 12px;padding-top:10px;border-top:1px solid var(--line)}.cookie-mini-row span{font-size:.68rem;color:#52719b;white-space:nowrap}.cookie-actions{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:7px;padding-top:10px;border-top:1px solid var(--line)}.cookie-actions button,.cookie-custom button{border:1px solid rgba(26,97,173,.22);background:#fff;color:var(--blue);padding:9px 10px;font-size:.72rem;line-height:1.15;font-weight:900}.cookie-actions .primary,.cookie-custom .primary{background:var(--blue);color:#fff}.cookie-custom{margin-top:12px;border-top:1px solid var(--line);padding-top:12px}.cookie-control-title{margin:0 0 8px;color:var(--blue);text-transform:uppercase;letter-spacing:.12em;font-size:.62rem;font-weight:900}.cookie-custom label{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;padding:8px 0;border-top:1px solid rgba(26,97,173,.1)}.cookie-custom strong{display:block;font-size:.78rem}.cookie-custom small{display:block;color:#52719b;font-size:.69rem;line-height:1.35}.cookie-custom input{width:36px;height:20px;accent-color:var(--blue)}.cookie-custom .save{width:100%;margin-top:10px}

@media (max-width:1180px){.home-page{padding-left:24px;padding-right:24px}.banner{display:none}.content-layout{grid-template-columns:1fr}.side-card{position:static}.mini-grid{grid-template-columns:1fr}}
@media (max-width:820px){.pattern{height:10px;background-size:auto 10px}.site-header{top:10px;height:68px;padding:0 16px}.brand-link img{width:142px}.lang-rocker{width:38px;height:38px}.menu-button{width:42px;height:42px}.site-header.menu-open{overflow:auto}.site-header.menu-open .menu-button{top:22px;right:20px}.site-header.menu-open .takeover-menu{position:relative;grid-template-columns:1fr;height:auto;min-height:100vh;overflow:auto}.takeover-logo{top:24px;left:22px}.takeover-logo img{width:132px}.takeover-left{min-height:72vh;padding:105px 24px 72px}.takeover-links{gap:8px}.takeover-links a,.takeover-links button{font-size:clamp(2rem,10.5vw,3.75rem);line-height:1}.takeover-bottom-line{left:24px;bottom:28px}.takeover-right{border-left:0;border-top:1px solid rgba(255,255,255,.24);padding:28px 24px 34px;gap:34px}.takeover-bottom-line.right{text-align:left}.home-page{padding:98px 18px 48px}.home-page h1{font-size:clamp(2.4rem,13vw,4.2rem)}.hero-logo{width:min(260px,72vw)}.content-page{padding-top:104px}.content-hero h1{font-size:clamp(2.5rem,12vw,4rem)}.field-grid,.phone-row{grid-template-columns:1fr}.site-footer{flex-direction:column;text-align:center}.cookie-widget{left:12px;right:12px;bottom:12px;width:auto;max-height:calc(100vh - 24px);overflow:auto}.cookie-actions{grid-template-columns:1fr}}

/* =========================================================
   Final TOM polish, desktop only
   ========================================================= */

@media (min-width:821px){

  /* Main takeover menu links */
  .site-header.menu-open .takeover-links a,
  .site-header.menu-open .takeover-links button{
    font-weight:700;
    line-height:1.20;
  }

  /* Align logo with the main menu column */
  .site-header.menu-open .takeover-logo{
    left:clamp(38px,6vw,88px);
  }

  /* Right policies block */
  .site-header.menu-open .takeover-policies,
  .site-header.menu-open .takeover-policies a,
  .site-header.menu-open .takeover-label{
    line-height:1.20;
  }

  .site-header.menu-open .takeover-policies a{
    font-weight:600;
  }

}


/* =========================================================
   Final TOM bottom line cleanup, desktop only
   ========================================================= */

@media (min-width:821px){

  /* Bottom-left TOM line */
  .site-header.menu-open .takeover-bottom-line:not(.right){
    font-weight:600;
  }

  /* Remove repetitive bottom-right TOM line */
  .site-header.menu-open .takeover-bottom-line.right{
    display:none;
  }

}


/* =========================================================
   SVG hamburger icon
   ========================================================= */

.site-header:not(.menu-open) .menu-toggle{
  width:46px;
  height:46px;
  display:grid;
  place-items:center;
  padding:0;
}

.site-header:not(.menu-open) .menu-toggle span{
  display:none;
}

.site-header:not(.menu-open) .menu-icon-img{
  display:block;
  width:30px;
  height:30px;
}

.site-header.menu-open .menu-icon-img{
  display:none;
}


/* =========================================================
   SVG hamburger icon
   ========================================================= */

.site-header:not(.menu-open) .menu-button{
  width:46px;
  height:46px;
  display:grid;
  place-items:center;
  padding:0;
}

.site-header:not(.menu-open) .menu-button span{
  display:none;
}

.site-header:not(.menu-open) .menu-icon-img{
  display:block;
  width:30px;
  height:30px;
}

.site-header.menu-open .menu-icon-img{
  display:none;
}


/* =========================================================
   Clean SVG hamburger, icon only
   ========================================================= */

.site-header:not(.menu-open) .menu-button{
  width:46px;
  height:46px;
  display:grid;
  place-items:center;
  padding:0;
  border:0;
  background:transparent;
  box-shadow:none;
  overflow:visible;
}

.site-header:not(.menu-open) .menu-button::before,
.site-header:not(.menu-open) .menu-button::after{
  content:none;
  display:none;
}

.site-header:not(.menu-open) .menu-button span{
  display:none;
}

.site-header:not(.menu-open) .menu-icon-img{
  display:block;
  width:30px;
  height:30px;
  border:0;
  background:transparent;
  box-shadow:none;
}

.site-header.menu-open .menu-icon-img{
  display:none;
}


/* Greek flag language rocker beside hamburger */
.site-header:not(.menu-open){
  gap:14px;
}

.site-header:not(.menu-open) .lang-rocker{
  margin-left:auto;
  margin-right:10px;
  width:34px;
  height:34px;
  display:grid;
  place-items:center;
  border:0;
  background:transparent;
  box-shadow:none;
  text-decoration:none;
}

.site-header:not(.menu-open) .lang-rocker img{
  display:block;
  width:34px;
  height:34px;
  border-radius:50%;
}

.site-header.menu-open .lang-rocker{
  display:none;
}

/* =========================================================
   EN / GR language selector
   ========================================================= */

.site-header:not(.menu-open) .lang-rocker{
  appearance:none;
  margin-left:auto;
  margin-right:10px;
  width:34px;
  height:34px;
  display:grid;
  place-items:center;
  border:0;
  background:transparent;
  box-shadow:none;
  text-decoration:none;
  cursor:pointer;
  padding:0;
}

.site-header:not(.menu-open) .lang-rocker img{
  display:block;
  width:34px;
  height:34px;
  border-radius:50%;
}

.language-popover{
  position:absolute;
  top:calc(100% + 12px);
  right:78px;
  z-index:5200;
  width:190px;
  background:#fff;
  border:1px solid rgba(26,97,173,.18);
  box-shadow:0 18px 50px rgba(9,17,31,.16);
  padding:8px;
}

.language-option{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px;
  text-decoration:none;
  color:#081326;
  font-weight:700;
  line-height:1.2;
}

.language-option:hover{
  background:#eef6ff;
}

.language-option img{
  width:28px;
  height:28px;
  border-radius:50%;
  flex:0 0 auto;
}

.site-header.menu-open .lang-rocker,
.site-header.menu-open .language-popover{
  display:none;
}

@media (max-width:720px){
  .language-popover{
    right:70px;
    top:calc(100% + 10px);
  }
}


/* Hide bottom-right logo on homepage only */
body.home .footer-logo,
body.home-page .footer-logo,
.home-page .footer-logo{
  display:none !important;
}


/* =========================================================
   Buy page
   ========================================================= */

.buy-page .buy-card{
  max-width:760px;
}

.buy-page .offer-form{
  margin-top:32px;
}

.buy-page .internal-helper{
  max-width:680px;
}

.buy-page .offer-form{
  display:flex;
  flex-direction:column;
  gap:22px;
}

.buy-page .submit-offer{
  width:100%;
}



/* =========================================================
   BUY PAGE FIX
   ========================================================= */

.buy-page .internal-page-shell{
  position:relative;
  width:min(1480px,calc(100% - 48px));
  margin:0 auto;
  padding:64px 180px;
  min-height:calc(100vh - 220px);
}

.buy-page .banner{
  position:absolute;
  top:120px;
  width:160px;
  height:600px;
}

.buy-page .banner-left{
  left:0;
}

.buy-page .banner-right{
  right:0;
}

.buy-page .internal-card{
  width:100%;
  max-width:760px;
  margin:0 auto;
  background:#fff;
  border:1px solid rgba(31,94,171,.12);
  padding:56px;
}

.buy-page .eyebrow{
  margin:0 0 14px;
}

.buy-page h1{
  margin:0 0 18px;
  font-size:clamp(44px,5vw,72px);
  line-height:1;
  font-weight:700;
}

.buy-page .internal-helper{
  margin:0 0 40px;
  font-size:18px;
  line-height:1.6;
  color:#315287;
}

.buy-page .offer-form{
  display:flex;
  flex-direction:column;
  gap:22px;
}

.buy-page .field-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
}

.buy-page .submit-offer{
  width:100%;
  min-height:64px;
}

@media (max-width:1200px){

  .buy-page .internal-page-shell{
    padding:48px 32px;
  }

  .buy-page .banner{
    display:none;
  }
}

@media (max-width:768px){

  .buy-page .internal-card{
    padding:32px 24px;
  }

  .buy-page .field-grid{
    grid-template-columns:1fr;
  }

  .buy-page h1{
    font-size:48px;
  }
}


/* =========================================================
   Buy page polish
   ========================================================= */

.buy-page .internal-page-shell{
  width:min(1500px,calc(100% - 40px));
  padding:46px 210px 72px;
}

.buy-page .banner{
  top:86px;
}

.buy-page .banner-left{
  left:20px;
}

.buy-page .banner-right{
  right:20px;
}

.buy-page .internal-card{
  max-width:720px;
  padding:46px 48px 52px;
  border:1px solid rgba(31,94,171,.14);
  box-shadow:0 24px 70px rgba(9,17,31,.06);
}

.buy-page h1{
  font-size:clamp(48px,4.8vw,68px);
  margin-bottom:16px;
}

.buy-page .internal-helper{
  margin-bottom:34px;
}

/* Hide duplicated intro from modal-form include on the buy page */
.buy-page .modal-inner > .eyebrow,
.buy-page .modal-inner > h2,
.buy-page .modal-inner > .modal-note{
  display:none;
}

.buy-page .offer-form{
  margin-top:0;
  gap:18px;
}

.buy-page .offer-form label span{
  margin-bottom:8px;
}

.buy-page .offer-form input,
.buy-page .offer-form select{
  min-height:54px;
}

.buy-page .submit-offer{
  margin-top:4px;
  min-height:58px;
}

@media (max-width:1200px){
  .buy-page .internal-page-shell{
    width:min(860px,calc(100% - 32px));
    padding:42px 0 64px;
  }

  .buy-page .internal-card{
    margin:0 auto;
  }
}

@media (max-width:768px){
  .buy-page .internal-page-shell{
    width:calc(100% - 28px);
    padding:32px 0 48px;
  }

  .buy-page .internal-card{
    padding:30px 22px 34px;
  }
}


/* =========================================================
   Clean dedicated buy page
   ========================================================= */

.buy-page .buy-shell{
  position:relative;
  min-height:calc(100vh - 210px);
  padding:120px 220px 90px;
  display:grid;
  place-items:start center;
}

.buy-page .banner{
  position:fixed;
  top:50%;
  transform:translateY(-50%);
}

.buy-page .banner-left{
  left:24px;
}

.buy-page .banner-right{
  right:24px;
}

.buy-page .buy-card{
  width:min(720px,100%);
  background:#fff;
  border:1px solid rgba(31,94,171,.16);
  box-shadow:0 28px 80px rgba(9,17,31,.08);
  padding:48px;
}

.buy-page .buy-card h1{
  margin:0 0 16px;
  font-size:clamp(48px,5vw,72px);
  line-height:1;
  font-weight:700;
  letter-spacing:-.055em;
}

.buy-page .buy-helper{
  margin:0 0 34px;
  color:#315287;
  font-size:18px;
  line-height:1.55;
}

.buy-page .offer-form{
  display:flex;
  flex-direction:column;
  gap:18px;
  margin:0;
}

.buy-page .field-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
}

.buy-page .phone-row{
  display:grid;
  grid-template-columns:130px 1fr;
  gap:12px;
}

.buy-page .offer-form input,
.buy-page .offer-form select{
  width:100%;
  min-height:54px;
}

.buy-page .submit-offer{
  width:100%;
  min-height:58px;
  margin-top:4px;
}

@media (max-width:1200px){
  .buy-page .buy-shell{
    padding:110px 24px 70px;
  }

  .buy-page .banner{
    display:none;
  }
}

@media (max-width:720px){
  .buy-page .buy-shell{
    padding:96px 16px 48px;
  }

  .buy-page .buy-card{
    padding:30px 22px 34px;
  }

  .buy-page .field-grid,
  .buy-page .phone-row{
    grid-template-columns:1fr;
  }
}


/* =========================================================
   Buy page overlap fix
   ========================================================= */

body.buy-page{
  min-height:100vh;
  overflow-x:hidden;
}

.buy-page .buy-shell{
  min-height:auto;
  padding-bottom:120px;
}

.buy-page .buy-card{
  position:relative;
  z-index:2;
  overflow:visible;
}

.buy-page .offer-form{
  position:relative;
  z-index:3;
}

.buy-page .site-footer{
  position:relative;
  z-index:1;
  margin-top:0;
  background:#fff;
}

/* Kill any old full-width form artefacts on buy page */
.buy-page > .offer-form,
.buy-page main > .offer-form,
.buy-page .modal-inner,
.buy-page .offer-modal,
.buy-page .offer-modal-shell{
  position:static !important;
  inset:auto !important;
  width:auto !important;
  height:auto !important;
  max-height:none !important;
  overflow:visible !important;
  box-shadow:none !important;
  border:0 !important;
  background:transparent !important;
  padding:0 !important;
}

.buy-page .offer-modal-shell,
.buy-page .offer-backdrop,
.buy-page .modal-pattern,
.buy-page .modal-close{
  display:none !important;
}


/* /buy footer polish */
.buy-page .site-footer img,
.buy-page .footer-logo,
.buy-page .site-footer .brand-link{
  display:none !important;
}

.buy-page .site-footer nav a{
  font-weight:200 !important;
  font-size:14px !important;
}


/* /buy 728x90 AdSense placeholder */
.buy-page .buy-bottom-ad{
  width:100%;
  max-width:728px;
  min-height:90px;
  margin:32px auto 0;
  border:1px dashed rgba(26,97,173,.35);
  background:#f7fbff;
  display:grid;
  place-items:center;
  text-align:center;
  color:#52719b;
  font-weight:800;
}


/* Custom dial code picker with real flag images */
.dial-picker{position:relative}
.dial-picker-button{
  width:100%;
  min-height:54px;
  display:flex;
  align-items:center;
  gap:10px;
  padding:0 14px;
  border:1px solid rgba(26,97,173,.22);
  background:#fff;
  color:#081326;
  font-weight:700;
  cursor:pointer;
}
.dial-picker-button img,
.dial-picker-menu img{
  width:24px;
  height:24px;
  border-radius:50%;
  flex:0 0 auto;
}
.dial-picker-menu{
  position:absolute;
  top:calc(100% + 6px);
  left:0;
  right:0;
  z-index:30;
  background:#fff;
  border:1px solid rgba(26,97,173,.22);
  box-shadow:0 18px 48px rgba(9,17,31,.14);
  padding:6px;
  max-height:260px;
  overflow:auto;
}
.dial-picker-menu button{
  width:100%;
  display:flex;
  align-items:center;
  gap:10px;
  border:0;
  background:#fff;
  padding:10px;
  color:#081326;
  font-weight:700;
  cursor:pointer;
  text-align:left;
}
.dial-picker-menu button:hover{background:#eef6ff}

/* Polish custom dial picker */
.dial-picker-button{
  justify-content:flex-start;
  gap:12px;
  font-weight:800;
  line-height:1;
}

.dial-picker-button img{
  width:28px;
  height:28px;
  object-fit:cover;
}

.dial-picker-button span{
  display:inline-flex;
  align-items:center;
  line-height:1;
  padding-top:1px;
}

.dial-picker-menu button{
  line-height:1;
}


/* JPayten-style rectangular flag dial picker */
.phone-row{
  display:grid;
  grid-template-columns:148px 1fr;
  gap:10px;
}

.dial-wrap{
  position:relative;
}

.dial-btn{
  width:100%;
  min-height:54px;
  display:flex;
  align-items:center;
  gap:10px;
  padding:0 14px;
  border:1px solid rgba(26,97,173,.22);
  background:#fff;
  color:#081326;
  font-weight:700;
  line-height:1;
  text-align:left;
  cursor:pointer;
}

.dial-btn img{
  width:20px;
  height:14px;
  object-fit:cover;
  border-radius:0 !important;
  flex-shrink:0;
}

.dial-btn #dialCodeDisplay{
  display:inline-flex;
  align-items:center;
  line-height:1;
  color:#1a61ad;
  font-weight:800;
}

.dial-arrow{
  margin-left:auto;
  color:#52719b;
  font-size:.7rem;
}

.dial-dropdown{
  position:absolute;
  top:100%;
  left:0;
  z-index:300;
  width:260px;
  max-height:260px;
  overflow:auto;
  background:#fff;
  border:1px solid rgba(26,97,173,.22);
  box-shadow:0 18px 48px rgba(9,17,31,.14);
  display:none;
}

.dial-dropdown.open{
  display:block;
}

.dial-opt{
  width:100%;
  display:flex;
  align-items:center;
  gap:10px;
  border:0;
  background:#fff;
  padding:10px 12px;
  color:#081326;
  font-weight:700;
  cursor:pointer;
  text-align:left;
}

.dial-opt:hover{
  background:#eef6ff;
}

.dial-opt img{
  width:20px;
  height:14px;
  object-fit:cover;
  border-radius:0 !important;
  flex-shrink:0;
}

.dial-opt .dc{
  margin-left:auto;
  color:#52719b;
  font-size:.78rem;
}

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

  .dial-dropdown{
    width:100%;
  }
}


/* Final dial picker alignment */
.dial-btn{
  display:grid !important;
  grid-template-columns:34px auto 1fr;
  align-items:center !important;
  column-gap:14px;
  min-height:54px;
  padding:0 16px !important;
}

.dial-btn img{
  width:28px !important;
  height:20px !important;
  object-fit:cover;
  border-radius:3px !important;
  display:block;
}

.dial-btn #dialCodeDisplay{
  display:block;
  color:#1a61ad;
  font-weight:800;
  line-height:1 !important;
  font-size:15px;
  transform:translateY(0);
}

.dial-btn .dial-arrow{
  justify-self:end;
  align-self:center;
  line-height:1;
  margin-left:0;
  color:#1a61ad;
}


/* Form label polish */
.offer-form label span{
  text-transform:none !important;
  letter-spacing:0 !important;
  font-weight:700 !important;
}

/* Dial picker final inline alignment */
.dial-btn{
  display:flex !important;
  align-items:center !important;
  justify-content:flex-start !important;
  gap:12px !important;
}

.dial-btn img{
  display:block !important;
  width:24px !important;
  height:16px !important;
  object-fit:cover !important;
  flex:0 0 auto !important;
}

.dial-btn #dialCodeDisplay{
  display:flex !important;
  align-items:center !important;
  height:16px !important;
  line-height:16px !important;
  font-weight:700 !important;
  transform:none !important;
}

.dial-btn .dial-arrow{
  display:flex !important;
  align-items:center !important;
  height:16px !important;
  line-height:16px !important;
  margin-left:auto !important;
  transform:none !important;
}

/* Dial picker tiny vertical nudge */
.dial-btn #dialCodeDisplay,
.dial-btn .dial-arrow{
  position:relative;
  top:5px;
}


.review-link{
  color:#1a61ad;
  font-weight:700;
  text-decoration:none;
}

.review-link:hover{
  text-decoration:underline;
}

.fireworks{
  position:fixed;
  inset:0;
  pointer-events:none;
  overflow:hidden;
  z-index:9999;
}

.fireworks span{
  position:absolute;
  width:10px;
  height:10px;
  border-radius:50%;
  animation:explode 4s ease-out forwards;
}

.fireworks span:nth-child(1){
  left:20%;
  top:30%;
  background:#1a61ad;
}

.fireworks span:nth-child(2){
  left:40%;
  top:20%;
  background:#ffb400;
}

.fireworks span:nth-child(3){
  left:60%;
  top:35%;
  background:#ff4d6d;
}

.fireworks span:nth-child(4){
  left:75%;
  top:25%;
  background:#6dd400;
}

.fireworks span:nth-child(5){
  left:50%;
  top:15%;
  background:#ffffff;
}

@keyframes explode{
  0%{
    transform:scale(0);
    opacity:1;
  }

  60%{
    transform:scale(12);
    opacity:1;
  }

  100%{
    transform:scale(18);
    opacity:0;
  }
}


/* Real fireworks */
.fireworks{
  position:fixed;
  inset:0;
  pointer-events:none;
  overflow:hidden;
  z-index:9999;
}

.fw{
  position:absolute;
  width:8px;
  height:8px;
}

.fw::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:50%;
  animation:firework 4s ease-out forwards;
}

.fw-1{left:18%;top:28%;}
.fw-2{left:38%;top:18%;}
.fw-3{left:58%;top:26%;}
.fw-4{left:74%;top:20%;}
.fw-5{left:50%;top:12%;}

.fw-1::before{
  box-shadow:
  0 -80px #1a61ad,
  56px -56px #ffb400,
  80px 0 #ffffff,
  56px 56px #6dd400,
  0 80px #ff4d6d,
  -56px 56px #1a61ad,
  -80px 0 #ffffff,
  -56px -56px #ffb400;
}

.fw-2::before{
  box-shadow:
  0 -70px #ffffff,
  50px -50px #1a61ad,
  70px 0 #ff4d6d,
  50px 50px #ffb400,
  0 70px #6dd400,
  -50px 50px #ffffff,
  -70px 0 #1a61ad,
  -50px -50px #ff4d6d;
}

.fw-3::before{
  box-shadow:
  0 -90px #ffb400,
  64px -64px #ffffff,
  90px 0 #1a61ad,
  64px 64px #6dd400,
  0 90px #ff4d6d,
  -64px 64px #ffffff,
  -90px 0 #1a61ad,
  -64px -64px #ffb400;
}

.fw-4::before{
  box-shadow:
  0 -75px #6dd400,
  54px -54px #ff4d6d,
  75px 0 #ffffff,
  54px 54px #1a61ad,
  0 75px #ffb400,
  -54px 54px #ffffff,
  -75px 0 #1a61ad,
  -54px -54px #6dd400;
}

.fw-5::before{
  box-shadow:
  0 -100px #ffffff,
  72px -72px #1a61ad,
  100px 0 #ffb400,
  72px 72px #ff4d6d,
  0 100px #6dd400,
  -72px 72px #ffffff,
  -100px 0 #1a61ad,
  -72px -72px #ffb400;
}

@keyframes firework{
  0%{
    transform:scale(.05);
    opacity:1;
  }

  70%{
    transform:scale(1);
    opacity:1;
  }

  100%{
    transform:scale(1.25);
    opacity:0;
  }
}


/* Clean readable policy pages */
body.policy-page .section{
  border:0 !important;
  background:transparent !important;
  padding:0 !important;
  margin:48px 0 !important;
}

body.policy-page .section h2{
  max-width:820px;
}

body.policy-page .section p,
body.policy-page .section li{
  max-width:820px;
  line-height:1.75;
}

body.policy-page .section ul,
body.policy-page .section ol{
  max-width:820px;
}

body.policy-page .content-page{
  max-width:980px;
}

body.policy-page .content-hero{
  max-width:900px;
}


/* Animated Kebub timeline */
.timeline-page .kebub-history{
  position:relative;
  max-width:880px;
  margin:54px 0 0;
  padding-left:38px;
}

.timeline-page .kebub-history::before{
  content:"";
  position:absolute;
  left:8px;
  top:0;
  bottom:0;
  width:3px;
  background:linear-gradient(180deg,var(--blue),rgba(26,97,173,.12));
  transform-origin:top;
  animation:timelineGrow 1.2s ease-out both;
}

.timeline-page .history-item{
  position:relative;
  display:grid;
  grid-template-columns:160px minmax(0,1fr);
  gap:28px;
  padding:0 0 44px;
  opacity:0;
  transform:translateY(24px);
  animation:timelineItemIn .7s ease-out forwards;
}

.timeline-page .history-item:nth-child(1){animation-delay:.1s}
.timeline-page .history-item:nth-child(2){animation-delay:.25s}
.timeline-page .history-item:nth-child(3){animation-delay:.4s}
.timeline-page .history-item:nth-child(4){animation-delay:.55s}
.timeline-page .history-item:nth-child(5){animation-delay:.7s}
.timeline-page .history-item:nth-child(6){animation-delay:.85s}

.timeline-page .history-item::before{
  content:"";
  position:absolute;
  left:-38px;
  top:4px;
  width:18px;
  height:18px;
  background:#fff;
  border:4px solid var(--blue);
  box-shadow:0 0 0 7px rgba(26,97,173,.1);
}

.timeline-page .history-date{
  color:var(--blue);
  font-weight:900;
  line-height:1.1;
}

.timeline-page .history-item h3{
  margin:0 0 8px;
  color:var(--ink);
  font-size:clamp(1.35rem,2.4vw,2rem);
  line-height:1.05;
}

.timeline-page .history-item p{
  margin-top:0;
}

.timeline-page .history-item.is-now::before{
  background:var(--blue);
  box-shadow:0 0 0 8px rgba(26,97,173,.16),0 0 42px rgba(26,97,173,.32);
}

@keyframes timelineGrow{
  from{transform:scaleY(0)}
  to{transform:scaleY(1)}
}

@keyframes timelineItemIn{
  to{
    opacity:1;
    transform:translateY(0);
  }
}

@media (max-width:760px){
  .timeline-page .kebub-history{
    padding-left:30px;
  }

  .timeline-page .history-item{
    grid-template-columns:1fr;
    gap:8px;
    padding-bottom:38px;
  }

  .timeline-page .history-item::before{
    left:-30px;
  }
}


/* Categorised FAQ page */
.faq-page .faq-intro-links p a{
  font-weight:800;
}

.faq-page .faq-category{
  margin-top:54px !important;
}

.faq-page .faq-category h2{
  margin-bottom:18px;
}

.faq-page .faq-accordion{
  max-width:820px;
  display:grid;
  gap:0;
  border-top:1px solid var(--line);
}

.faq-page .faq-accordion details{
  border-bottom:1px solid var(--line);
  background:#fff;
}

.faq-page .faq-accordion summary{
  list-style:none;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  padding:22px 0;
  font-weight:900;
  color:var(--ink);
}

.faq-page .faq-accordion summary::-webkit-details-marker{
  display:none;
}

.faq-page .faq-accordion summary b{
  width:26px;
  height:26px;
  display:grid;
  place-items:center;
  background:var(--blue);
  color:#fff;
  font-size:1rem;
  line-height:1;
  flex:0 0 auto;
}

.faq-page .faq-accordion details[open] summary b{
  transform:rotate(45deg);
}

.faq-page .faq-accordion details div{
  padding:0 46px 22px 0;
}

.faq-page .faq-accordion details p{
  margin:0;
  color:var(--muted);
}


/* Kebub responsive safety layer */
html,
body{
  max-width:100%;
  overflow-x:hidden;
}

*,
*::before,
*::after{
  box-sizing:border-box;
}

img,
svg,
video,
canvas,
iframe{
  max-width:100%;
}

.content-page,
.home-page{
  width:100%;
}

@media (max-width:900px){
  .content-layout{
    grid-template-columns:1fr !important;
  }

  .side-card{
    position:relative;
    top:auto;
    width:100%;
  }

  .mini-grid{
    grid-template-columns:1fr !important;
  }
}

@media (max-width:760px){
  .content-page{
    padding-left:20px !important;
    padding-right:20px !important;
  }

  .content-hero h1,
  .home-page h1{
    overflow-wrap:anywhere;
  }

  .section{
    max-width:100%;
  }

  .button,
  button,
  input,
  select,
  textarea{
    max-width:100%;
  }

  .button,
  button[type="submit"]{
    min-height:48px;
  }

  .field-grid,
  .phone-row,
  .offer-form-grid{
    grid-template-columns:1fr !important;
  }

  .ad-box{
    min-width:0;
  }

  .site-footer{
    padding-left:20px;
    padding-right:20px;
  }

  .site-footer a{
    overflow-wrap:anywhere;
  }
}

@media (max-width:420px){
  .content-page{
    padding-left:16px !important;
    padding-right:16px !important;
  }

  .content-hero h1{
    font-size:clamp(2.25rem,11vw,3.25rem) !important;
  }

  .content-hero p,
  .section p,
  .section li{
    font-size:1rem;
  }
}

