/* Simple banner: hero visual + upload */
@media (min-width:992px){.section:has(.simple-banner__visual){min-height:clamp(520px,72vh,900px)}}
@media (prefers-reduced-motion:reduce){.simple-banner__contour-ring,.simple-banner__contours-svg{animation:none}}

.simple-banner__visual{position:absolute;top:0;left:46vw;z-index:2;height:70vh;padding-top:clamp(50px,8vw,115px);padding-bottom:2px;pointer-events:none;width:min(56vw,760px);transform:translateX(clamp(0px,3vw,48px));isolation:isolate}
@media(max-width:991.98px){.simple-banner__visual{position:relative;left:auto;right:auto;width:100%;height:auto;min-height:280px;margin-top:clamp(20px,5vw,40px);padding-top:0;transform:none}}
/* Vector hero replaces the ACF attachment (same artwork as home_banner.svg); hide duplicate stack. */
.simple-banner__visual:has(.simple-banner__contours) .simple-banner__visual-img{display:none}
.simple-banner__visual-img{position:relative;z-index:1;display:block;height:100%;width:auto;max-width:100%;margin-left:auto;object-fit:contain;pointer-events:none}
@media(max-width:991.98px){.simple-banner__visual-img{height:auto;max-height:45vh;margin:0 auto}}
.simple-banner__contours{position:absolute;inset:6% 5% 10% 18%;z-index:2;pointer-events:none}
.simple-banner__contours-svg{width:100%;height:100%;display:block;opacity:.96;transform-origin:56% 48%;animation:podContourSway 14s ease-in-out infinite alternate}
.simple-banner__contours-svg>g{opacity:.9}
.simple-banner__contour-ring{fill:none;stroke-dasharray:100 64;animation:podContourDrift 11s ease-in-out infinite alternate}
@keyframes podContourDrift{0%{stroke-dashoffset:0;opacity:.68}100%{stroke-dashoffset:280;opacity:1}}
@keyframes podContourSway{0%{transform:rotate(-1.1deg) scale(1)}100%{transform:rotate(1.1deg) scale(1.03)}}
.simple-banner__upload-zone{position:absolute;left:56%;top:48%;transform:translate(-50%,-50%);z-index:10;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;min-width:min(100%,240px);padding:1rem 1.35rem;max-width:260px;text-align:center;color:#fff;background:rgba(12,18,38,.72);border:1px solid rgba(255,255,255,.35);border-radius:12px;cursor:pointer;pointer-events:auto;transition:background .2s ease,border-color .2s ease,transform .15s ease,box-shadow .2s ease;font:inherit;box-shadow:0 8px 32px rgba(0,0,0,.25)}
.simple-banner__upload-zone:hover,.simple-banner__upload-zone:focus-visible{background:rgba(25,35,70,.65);border-color:rgba(255,255,255,.45);outline:none}
.simple-banner__upload-zone:focus-visible{box-shadow:0 0 0 2px rgba(15,20,40,.9),0 0 0 5px rgba(255,255,255,.75)}
.simple-banner__upload-zone--drag{background:rgba(40,55,110,.78);border-color:rgba(255,255,255,.5);transform:translate(-50%,-50%) scale(1.02)}
.simple-banner__upload-zone:active{transform:translate(-50%,-50%) scale(.98)}
.simple-banner__upload-zone--drag:active{transform:translate(-50%,-50%) scale(.99)}
@media(max-width:991.98px){.simple-banner__upload-zone{left:50%;top:46%}.simple-banner__contours{inset:8% 10% 12% 10%}.simple-banner__contours-svg{transform-origin:50% 50%}}
.simple-banner__upload-icon{display:flex;color:rgba(255,255,255,.95)}
.simple-banner__upload-text{font-size:.875rem;font-weight:600;line-height:1.25}
.simple-banner__upload-input{position:absolute;width:0;height:0;opacity:0;pointer-events:none}
.pod-phasio-dialog{padding:0;border:none;border-radius:16px;max-width:420px;width:calc(100% - 2rem);background:#0f1428;color:#fff;box-shadow:0 24px 60px rgba(0,0,0,.45)}
.pod-phasio-dialog--wide{max-width:min(560px,96vw)}
.pod-phasio-dialog::backdrop{background:rgba(0,0,0,.55)}
.pod-phasio-dialog__inner{padding:1.5rem}
.pod-phasio-dialog__file-meta{font-size:.8rem;opacity:.8;margin:0 0 1rem}
.pod-phasio-progress{display:flex;align-items:center;gap:1rem;margin:1rem 0 1.25rem}
.pod-phasio-progress__spinner{flex-shrink:0;width:2rem;height:2rem;border:3px solid rgba(255,255,255,.2);border-top-color:rgba(233,30,140,.95);border-radius:50%;animation:podPhasioSpin .75s linear infinite}
@keyframes podPhasioSpin{to{transform:rotate(360deg)}}
@media (prefers-reduced-motion:reduce){.pod-phasio-progress__spinner{animation:none;opacity:.75}}
.pod-phasio-progress__label{flex:1;margin:0;font-size:.95rem;font-weight:600}
.pod-phasio-preview__canvas-wrap{width:100%;min-height:min(280px,40vh);border-radius:12px;overflow:hidden;position:relative;border:1px solid rgba(15,20,40,.18);background:linear-gradient(165deg,rgba(25,35,60,.9) 0%,rgba(12,18,38,.95) 100%)}
.pod-phasio-preview__canvas-wrap:not(.pod-phasio-preview__canvas-wrap--progress){background:#fff;border-color:rgba(15,20,40,.12)}
.pod-phasio-preview__canvas-wrap--progress{display:flex;align-items:center;justify-content:center;min-height:min(280px,40vh)}
.pod-phasio-preview__progress-inner{display:flex;flex-direction:column;align-items:center;gap:1rem;text-align:center;padding:1.5rem;max-width:22rem}
.pod-phasio-preview__canvas-wrap--progress .pod-phasio-progress__label{flex:unset;margin:0}
.pod-phasio-preview__canvas-wrap canvas{display:block;width:100%;height:100%;min-height:260px;touch-action:none}
.pod-phasio-preview__placeholder{min-height:260px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem;text-align:center;gap:.5rem}
.pod-phasio-preview__canvas-wrap:not(.pod-phasio-preview__canvas-wrap--progress) .pod-phasio-preview__placeholder-title{color:#141824;opacity:1}
.pod-phasio-preview__canvas-wrap:not(.pod-phasio-preview__canvas-wrap--progress) .pod-phasio-preview__placeholder-text{color:#3d4556;opacity:1}
.pod-phasio-preview__placeholder-title{font-size:1rem;font-weight:700;margin:0;opacity:.9}
.pod-phasio-preview__placeholder-text{font-size:.85rem;margin:0;opacity:.75;line-height:1.35;max-width:28ch}
.pod-phasio-dialog .pod-phasio-preview__price-hint{display:block;width:100%;box-sizing:border-box;margin:1.25rem 0 0;font-size:1.05rem;font-weight:600;line-height:1.4;opacity:.95;text-align:right}
.pod-phasio-login-hint{font-size:1rem;font-weight:600;margin:0 0 .5rem;opacity:.95}
.pod-phasio-preview__auth{margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.12)}
.pod-phasio-preview__auth .pod-phasio-dialog__hint{margin-bottom:0}
.pod-phasio-preview__auth .pod-phasio-dialog__actions{margin-top:1rem}
.pod-phasio-dialog h2{font-size:1.25rem;margin:0 0 .75rem}
.pod-phasio-dialog p{margin:0 0 1rem;font-size:.9rem;opacity:.9}
.pod-phasio-dialog label{display:block;font-size:.8rem;margin-bottom:.35rem;opacity:.85}
.pod-phasio-dialog input[type=email],.pod-phasio-dialog input[type=text]{width:100%;padding:.6rem .75rem;border-radius:8px;border:1px solid rgba(255,255,255,.25);background:rgba(255,255,255,.08);color:#fff;margin-bottom:1rem;box-sizing:border-box}
.pod-phasio-otp-intro{margin:0 0 .75rem;font-size:.9rem;line-height:1.45;opacity:.95;color:rgba(255,255,255,.95)}
.pod-phasio-otp-intro__email{font-weight:700;word-break:break-all;color:#fff}
.pod-phasio-otp-field{display:grid;grid-template-columns:repeat(6,1fr);gap:0;width:100%;box-sizing:border-box;border:1px solid rgba(15,20,40,.18);border-radius:10px;overflow:hidden;margin:0 0 1.25rem;background:#fff;box-shadow:0 1px 0 rgba(0,0,0,.04)}
.pod-phasio-otp-cell{width:100%;min-width:0;border:none;border-right:1px solid rgba(15,20,40,.12);border-radius:0;margin:0!important;padding:.72rem .2rem!important;min-height:3rem;box-sizing:border-box;text-align:center;font-size:1.35rem!important;font-weight:600!important;font-variant-numeric:tabular-nums;line-height:1.2;color:#141824!important;background:#fff!important;-webkit-appearance:none;appearance:none}
.pod-phasio-otp-cell:last-child{border-right:none}
.pod-phasio-otp-cell:focus{outline:none;background:#f0f2f8!important;box-shadow:inset 0 0 0 2px rgba(233,30,140,.35)}
.pod-phasio-otp-cell::placeholder{color:rgba(20,24,36,.25)}
.pod-phasio-dialog__actions{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}
.pod-phasio-dialog button{display:inline-flex;align-items:center;justify-content:center;text-align:center;flex:1;min-width:100px;min-height:2.75rem;padding:.65rem 1rem;border-radius:8px;border:none;font-weight:600;line-height:1.25;cursor:pointer;font:inherit}
.pod-phasio-dialog__primary{background:#e91e8c;color:#fff}
.pod-phasio-dialog__secondary{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.35)}
.pod-phasio-dialog__hint{font-size:.8rem;opacity:.75;margin-top:.75rem}
.pod-phasio-dialog__error-msg{font-size:.9rem;line-height:1.45;opacity:.95;margin:0 0 1rem;white-space:pre-wrap}
.pod-phasio-dialog__actions--direct{margin-top:1.25rem}
.pod-phasio-dialog__primary--wide{flex:2}
.pod-phasio-dialog__primary:disabled{opacity:.6;cursor:not-allowed}
.pod-phasio-dialog__portal-link{color:rgba(233,30,140,.95);text-decoration:underline;text-underline-offset:2px;font-weight:600}
.pod-phasio-dialog__portal-link:hover{color:#fff}
.pod-phasio-dialog--embed{max-width:min(960px,96vw);width:96vw;height:92vh;max-height:92vh;display:flex;flex-direction:column}
.pod-phasio-dialog--embed .pod-phasio-dialog__inner{padding:0;display:flex;flex-direction:column;flex:1;min-height:0}
.pod-phasio-embed__header{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0}
.pod-phasio-embed__title{font-size:1.05rem;font-weight:700}
.pod-phasio-embed__close{background:none;border:none;color:#fff;font-size:1.6rem;line-height:1;cursor:pointer;padding:.25rem .5rem;opacity:.8;transition:opacity .15s}
.pod-phasio-embed__close:hover{opacity:1}
.pod-phasio-embed__hint{margin:0;padding:.5rem 1.25rem;font-size:.85rem;opacity:.8;flex-shrink:0}
.pod-phasio-embed__iframe-wrap{flex:1;min-height:0;position:relative;background:#fff;border-radius:0 0 12px 12px;overflow:hidden}
.pod-phasio-embed__loading{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;background:#0f1428;color:#fff;z-index:2}
.pod-phasio-embed__iframe{width:100%;height:100%;border:none;display:block;opacity:0;transition:opacity .3s ease}
.pod-phasio-embed__iframe--loaded{opacity:1}
.pod-phasio-embed__footer{flex-shrink:0;padding:.6rem 1.25rem;text-align:right;font-size:.8rem}
@media(max-width:640px){.pod-phasio-dialog--embed{width:100vw;max-width:100vw;height:100vh;max-height:100vh;border-radius:0}.pod-phasio-embed__iframe-wrap{border-radius:0}}
/* ── Preloaded hero iframe (drag-through to Phasio) ── */
.pod-phasio-hero-iframe{position:fixed;width:1px;height:1px;border:none;opacity:0;pointer-events:none;z-index:-1;overflow:hidden;clip:rect(0,0,0,0)}
.pod-phasio-hero-iframe--modal{position:fixed;top:2vh;left:2vw;width:96vw;height:calc(96vh - 5.5rem);margin-top:2.75rem;opacity:1;pointer-events:auto;z-index:100002;border-radius:0 0 12px 12px;background:#fff;transition:opacity .25s ease;overflow:visible;clip:auto}
.pod-phasio-hero-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:100000;opacity:0;transition:opacity .25s ease}
.pod-phasio-hero-backdrop--visible{display:block;opacity:1}
.pod-phasio-hero-modal__header{display:none;position:fixed;top:2vh;left:2vw;width:96vw;box-sizing:border-box;z-index:100003;background:#0f1428;color:#fff;padding:.75rem 1.25rem;border-radius:12px 12px 0 0;align-items:center;justify-content:space-between}
.pod-phasio-hero-modal__header--visible{display:flex}
.pod-phasio-hero-modal__title{font-size:1.05rem;font-weight:700}
.pod-phasio-hero-modal__login-hint{position:absolute;right:max(72px,calc(48vw - 628px));top:50%;transform:translateY(-50%);font-size:.8rem;font-weight:400;opacity:0;white-space:nowrap;animation:pod-hint-fade-in .6s ease 1s forwards,pod-hint-nudge 1.5s ease-in-out 1.8s 4}
.pod-phasio-hero-modal__login-arrow{display:inline-block;margin-left:.35rem;font-size:1.1rem;animation:pod-arrow-bounce 1.5s ease-in-out 1.8s 4}
@keyframes pod-hint-fade-in{to{opacity:.75}}
@keyframes pod-hint-nudge{0%,100%{opacity:.75}50%{opacity:1}}
@keyframes pod-arrow-bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}
.pod-phasio-hero-modal__close{background:none;border:none;color:#fff;font-size:1.6rem;line-height:1;cursor:pointer;padding:.25rem .5rem;opacity:.8;transition:opacity .15s}
.pod-phasio-hero-modal__close:hover{opacity:1}
.pod-phasio-hero-modal__footer{display:none;position:fixed;bottom:calc(2vh);left:2vw;width:96vw;box-sizing:border-box;z-index:100003;background:#0f1428;color:#fff;padding:.5rem 1.25rem;border-radius:0 0 12px 12px;text-align:right;font-size:.8rem}
.pod-phasio-hero-modal__footer--visible{display:block;margin-top:-1px}
@media(max-width:640px){.pod-phasio-hero-modal__login-hint{display:none}.pod-phasio-hero-iframe--modal{top:0;left:0;width:100vw;height:calc(100vh - 5rem);margin-top:2.75rem;border-radius:0}.pod-phasio-hero-modal__header,.pod-phasio-hero-modal__header--visible{top:0;left:0;width:100vw;border-radius:0}.pod-phasio-hero-modal__footer,.pod-phasio-hero-modal__footer--visible{bottom:0;left:0;width:100vw;border-radius:0}}
