/* Web fonts are enqueued separately (see WTO_Frontend::register_assets) so they
   load in parallel instead of via a render-blocking @import chain. */

/* =========================================================================
   Winti Offerte – Frontend (fully scoped under .wto-app, theme independent)
   ========================================================================= */
.wto-app{
  /* colour vars (--wto-accent etc.) are injected inline per install */
  --wto-accent:#F26419;
  --wto-accent-dark:#D9530E;
  --wto-ink:#16202B;
  --wto-ok:#1F9D6B;
  --wto-accent-rgb:242,100,25;

  --wto-panel:#1E2A38;
  --wto-steel:#5B7085;
  --wto-surface:#EEF1F3;
  --wto-card:#FFFFFF;
  --wto-line:#D7DEE4;
  --wto-line-strong:#B9C4CD;

  --wto-display:'Space Grotesk',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --wto-body:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  --wto-mono:'Space Mono',ui-monospace,SFMono-Regular,Menlo,monospace;

  --wto-radius:14px;
  --wto-shadow:0 1px 2px rgba(22,32,43,.06), 0 12px 32px -12px rgba(22,32,43,.18);

  /* strong custom easing curves (Emil) */
  --wto-ease-out:cubic-bezier(0.23,1,0.32,1);
  --wto-ease-in-out:cubic-bezier(0.77,0,0.175,1);

  /* hard reset so the theme cannot bleed in */
  all: initial;
  display:block;
  /* establish a query container so the layout responds to the space the
     shortcode actually occupies (e.g. a narrow page-builder column), not just
     the viewport width. Fixes [winti_offerte layout="form"] being clipped. */
  container-type:inline-size;
  container-name:wto;
  max-width:100%;
  font-family:var(--wto-body);
  color:var(--wto-ink);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-align:left;
  box-sizing:border-box;
}
.wto-app *,
.wto-app *::before,
.wto-app *::after{box-sizing:border-box;margin:0;padding:0;}
.wto-app button{font-family:inherit;}
.wto-app img{max-width:100%;display:block;}
/* Links default to the plugin's own ink colour so a theme's global link colour
   cannot bleed in; individual components override where a colour is intended. */
.wto-app a{text-decoration:none;color:inherit;}

.wto-inner{max-width:1080px;margin:0 auto;padding:0 20px;}

/* ---------- Top bar ---------- */
.wto-topbar{background:var(--wto-ink);color:#fff;font-size:13px;}
.wto-topbar .wto-inner{display:flex;justify-content:space-between;align-items:center;gap:12px;min-height:42px;flex-wrap:wrap;padding-top:6px;padding-bottom:6px;}
.wto-topbar a{color:#cdd6df;}
.wto-topbar a:hover{color:#fff;}
.wto-emrg{display:inline-flex;align-items:center;gap:8px;color:#fff;font-weight:500;}
.wto-dot{width:7px;height:7px;border-radius:50%;background:var(--wto-accent);box-shadow:0 0 0 3px rgba(var(--wto-accent-rgb),.25);animation:wto-pulse 2.4s var(--wto-ease-in-out) infinite;}
@keyframes wto-pulse{0%,100%{box-shadow:0 0 0 3px rgba(var(--wto-accent-rgb),.25);}50%{box-shadow:0 0 0 6px rgba(var(--wto-accent-rgb),0);}}

/* ---------- Header ---------- */
.wto-header{background:var(--wto-card);border-bottom:1px solid var(--wto-line);}
.wto-header .wto-inner{display:flex;align-items:center;justify-content:space-between;min-height:74px;padding-top:10px;padding-bottom:10px;gap:14px;}
.wto-logo-row{display:flex;align-items:center;gap:12px;}
.wto-mark{width:42px;height:42px;border-radius:9px;background:var(--wto-ink);display:grid;place-items:center;flex:none;color:var(--wto-accent);transition:transform .5s var(--wto-ease-out);}
.wto-mark svg{transition:transform .5s var(--wto-ease-out);}
.wto-header:hover .wto-mark svg{transform:rotate(-6deg) scale(1.05);}
.wto-brand{font-family:var(--wto-display);font-weight:700;color:var(--wto-ink);font-size:16px;letter-spacing:-.01em;line-height:1.15;}
.wto-brand small{display:block;font-family:var(--wto-body);font-weight:500;color:var(--wto-steel);font-size:11px;letter-spacing:.04em;text-transform:uppercase;}
.wto-phone-pill{display:inline-flex;align-items:center;gap:8px;font-weight:600;color:var(--wto-ink);font-size:14px;padding:9px 14px;border:1px solid var(--wto-line);border-radius:999px;transition:border-color .18s ease,transform .16s var(--wto-ease-out);}
.wto-phone-pill:hover{border-color:var(--wto-line-strong);}
.wto-phone-pill:active{transform:scale(0.97);}
.wto-phone-pill svg{width:16px;height:16px;color:var(--wto-accent);}

/* ---------- Intro ---------- */
.wto-intro{padding:40px 20px 26px;}
.wto-banner{border-radius:var(--wto-radius);overflow:hidden;margin-bottom:24px;box-shadow:var(--wto-shadow);}
.wto-banner img{width:100%;height:auto;max-height:340px;object-fit:cover;}
.wto-eyebrow{font-family:var(--wto-mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--wto-accent);font-weight:700;}
.wto-h1{font-family:var(--wto-display);font-weight:700;font-size:clamp(28px,4.4vw,42px);line-height:1.05;letter-spacing:-.02em;margin:12px 0 10px;max-width:18ch;color:var(--wto-ink);}
.wto-lead{color:var(--wto-steel);max-width:56ch;font-size:16px;}
.wto-trust{display:flex;gap:22px;flex-wrap:wrap;margin-top:20px;}
.wto-trust span{display:inline-flex;align-items:center;gap:8px;font-size:13.5px;color:var(--wto-ink);font-weight:500;}
.wto-trust svg{width:16px;height:16px;color:var(--wto-ok);flex:none;}

/* ---------- Layout ---------- */
/* minmax(0,1fr) lets the main column shrink below its content's min-content so
   it never forces horizontal overflow (right-side clipping) in tight columns. */
.wto-grid{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:26px;align-items:start;padding-bottom:60px;}
/* Collapse on the container width (handles embedding in narrow columns); the
   viewport @media acts as a fallback for browsers without container queries. */
@container wto (max-width:900px){.wto-grid{grid-template-columns:minmax(0,1fr);}}
@media(max-width:900px){.wto-grid{grid-template-columns:minmax(0,1fr);}}
/* layout variants (shortcode-configurable) */
.wto-no-sidebar .wto-grid{grid-template-columns:minmax(0,1fr);max-width:780px;}
.wto-layout-form .wto-grid{padding-top:24px;}
.wto-panel-box{min-width:0;background:var(--wto-card);border:1px solid var(--wto-line);border-radius:var(--wto-radius);box-shadow:var(--wto-shadow);overflow:hidden;}

/* ---------- Progress ruler ---------- */
.wto-progress{padding:22px 26px 4px;border-bottom:1px solid var(--wto-line);background:linear-gradient(180deg,#fff,#fbfcfd);}
.wto-meta{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:14px;}
.wto-step-label{font-family:var(--wto-display);font-weight:600;font-size:15px;color:var(--wto-ink);}
.wto-count{font-family:var(--wto-mono);font-size:12px;color:var(--wto-steel);}
.wto-ruler{position:relative;height:34px;margin:0 2px;}
.wto-track{position:absolute;top:9px;left:0;right:0;height:2px;background:var(--wto-line-strong);}
.wto-fill{position:absolute;top:9px;left:0;height:2px;width:0;background:var(--wto-accent);transition:width .45s var(--wto-ease-in-out);}
.wto-ticks{position:relative;display:flex;justify-content:space-between;}
.wto-tick{display:flex;flex-direction:column;align-items:center;gap:6px;flex:1;}
.wto-tick:first-child{align-items:flex-start;}
.wto-tick:last-child{align-items:flex-end;}
.wto-pin{width:20px;height:20px;border-radius:50%;background:#fff;border:2px solid var(--wto-line-strong);display:grid;place-items:center;font-family:var(--wto-mono);font-size:10px;color:var(--wto-steel);transition:.25s var(--wto-ease-out);z-index:1;}
.wto-tick.done .wto-pin{background:var(--wto-accent);border-color:var(--wto-accent);color:#fff;}
.wto-tick.active .wto-pin{border-color:var(--wto-accent);color:var(--wto-accent);box-shadow:0 0 0 4px rgba(var(--wto-accent-rgb),.14);}
.wto-cap{font-size:10.5px;color:var(--wto-steel);text-align:center;letter-spacing:.02em;font-weight:500;white-space:nowrap;}
.wto-tick.active .wto-cap{color:var(--wto-ink);}
@container wto (max-width:560px){.wto-cap{display:none;}.wto-tick.active .wto-cap{display:block;position:absolute;bottom:-2px;}.wto-ruler{height:24px;}}
@media(max-width:560px){.wto-cap{display:none;}.wto-tick.active .wto-cap{display:block;position:absolute;bottom:-2px;}.wto-ruler{height:24px;}}

/* ---------- Steps ---------- */
.wto-step{display:none;padding:28px 26px 30px;}
.wto-step.active{display:block;animation:wto-fade .4s var(--wto-ease-out);}
@keyframes wto-fade{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:none;}}
.wto-h2{font-family:var(--wto-display);font-weight:600;font-size:21px;letter-spacing:-.01em;margin-bottom:4px;color:var(--wto-ink);}
.wto-sub{color:var(--wto-steel);font-size:14.5px;margin-bottom:22px;}
.wto-req{color:var(--wto-accent);}

/* service cards */
.wto-opt-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
@container wto (max-width:520px){.wto-opt-grid{grid-template-columns:1fr;}}
@media(max-width:520px){.wto-opt-grid{grid-template-columns:1fr;}}
.wto-opt{position:relative;display:flex;gap:14px;align-items:flex-start;padding:16px;border:1.5px solid var(--wto-line);border-radius:12px;cursor:pointer;background:#fff;text-align:left;width:100%;
  transition:border-color .18s var(--wto-ease-out),background .18s ease,box-shadow .18s ease,transform .16s var(--wto-ease-out);
  opacity:0;transform:translateY(8px);animation:wto-rise .45s var(--wto-ease-out) forwards;animation-delay:calc(var(--i,0)*55ms);}
@keyframes wto-rise{to{opacity:1;transform:none;}}
.wto-opt:hover{border-color:var(--wto-line-strong);background:#fcfdfe;}
.wto-opt:active{transform:scale(0.985);}
.wto-opt.sel{border-color:var(--wto-accent);background:rgba(var(--wto-accent-rgb),.05);box-shadow:0 0 0 3px rgba(var(--wto-accent-rgb),.1);}
.wto-ic{width:42px;height:42px;border-radius:10px;background:var(--wto-surface);display:grid;place-items:center;flex:none;color:var(--wto-ink);transition:background .18s var(--wto-ease-out),color .18s ease,transform .35s var(--wto-ease-out);}
.wto-opt:hover .wto-ic{transform:translateY(-2px) rotate(-3deg);}
.wto-opt.sel .wto-ic{background:var(--wto-accent);color:#fff;transform:none;}
.wto-ic svg{width:23px;height:23px;}
/* custom uploaded icons (SVG/PNG/WebP) keep their own colours */
.wto-ic-img{width:24px;height:24px;object-fit:contain;display:block;}
.wto-ic--custom{background:#fff;border:1px solid var(--wto-line);}
.wto-opt.sel .wto-ic--custom{background:#fff;}
.wto-opt:hover .wto-ic--custom{transform:translateY(-2px);}
.wto-opt-txt{min-width:0;}
.wto-opt-h3{display:block;font-family:var(--wto-display);font-size:15px;font-weight:600;margin-bottom:3px;color:var(--wto-ink);overflow-wrap:anywhere;}
.wto-opt-p{display:block;font-size:12.5px;color:var(--wto-steel);line-height:1.4;overflow-wrap:anywhere;}
.wto-check{position:absolute;top:12px;right:12px;width:18px;height:18px;border-radius:50%;border:2px solid var(--wto-line-strong);display:grid;place-items:center;opacity:0;transform:scale(.6);transition:.18s var(--wto-ease-out);}
.wto-opt.sel .wto-check{opacity:1;transform:scale(1);border-color:var(--wto-accent);background:var(--wto-accent);}
.wto-check svg{width:11px;height:11px;color:#fff;}

/* chips */
.wto-chips{display:flex;flex-wrap:wrap;gap:10px;}
.wto-chip{padding:10px 16px;border:1.5px solid var(--wto-line);border-radius:999px;cursor:pointer;font-size:14px;font-weight:500;background:#fff;color:var(--wto-ink);user-select:none;transition:border-color .16s ease,background .16s ease,color .16s ease,transform .14s var(--wto-ease-out);}
.wto-chip:hover{border-color:var(--wto-line-strong);}
.wto-chip:active{transform:scale(0.95);}
.wto-chip.sel{border-color:var(--wto-accent);background:var(--wto-accent);color:#fff;}

/* fields */
.wto-fld{margin-bottom:18px;}
.wto-half{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
@container wto (max-width:520px){.wto-half{grid-template-columns:1fr;}}
@media(max-width:520px){.wto-half{grid-template-columns:1fr;}}
.wto-lab{display:block;font-size:13px;font-weight:600;margin-bottom:7px;color:var(--wto-ink);}
.wto-hint{font-weight:400;color:var(--wto-steel);font-size:12px;}
.wto-app input[type=text],.wto-app input[type=tel],.wto-app input[type=email],.wto-app input[type=date],.wto-app input[type=number],.wto-app select,.wto-app textarea{
  width:100%;padding:12px 14px;border:1.5px solid var(--wto-line);border-radius:10px;font-family:var(--wto-body);font-size:15px;color:var(--wto-ink);background:#fff;line-height:1.4;transition:border-color .16s var(--wto-ease-out),box-shadow .16s ease;-webkit-appearance:none;appearance:none;}
.wto-app select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235B7085' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:18px;padding-right:40px;}
.wto-app textarea{resize:vertical;min-height:104px;}
.wto-app input:focus,.wto-app select:focus,.wto-app textarea:focus{outline:none;border-color:var(--wto-accent);box-shadow:0 0 0 3px rgba(var(--wto-accent-rgb),.12);}
.wto-app input::placeholder,.wto-app textarea::placeholder{color:#9aa7b1;}
.wto-dims{display:grid;grid-template-columns:1fr auto 1fr;gap:10px;align-items:center;}
.wto-x{font-family:var(--wto-mono);color:var(--wto-steel);font-weight:700;}
.wto-inp-unit{position:relative;}
.wto-inp-unit .wto-u{position:absolute;right:13px;top:50%;transform:translateY(-50%);font-family:var(--wto-mono);font-size:12px;color:var(--wto-steel);pointer-events:none;}
.wto-inp-unit input{padding-right:42px;}

/* emergency toggle */
.wto-toggle-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:15px 16px;border:1.5px solid var(--wto-line);border-radius:12px;background:#fff;cursor:pointer;transition:border-color .2s var(--wto-ease-out),background .2s ease;}
.wto-toggle-row.on{border-color:var(--wto-accent);background:rgba(var(--wto-accent-rgb),.05);}
.wto-t-txt strong{display:block;font-family:var(--wto-display);font-size:14.5px;color:var(--wto-ink);}
.wto-t-txt span{font-size:12.5px;color:var(--wto-steel);}
.wto-switch{width:48px;height:28px;border-radius:999px;background:var(--wto-line-strong);position:relative;flex:none;transition:background .2s var(--wto-ease-out);}
.wto-switch.on{background:var(--wto-accent);}
.wto-knob{position:absolute;top:3px;left:3px;width:22px;height:22px;border-radius:50%;background:#fff;transition:left .22s var(--wto-ease-out);box-shadow:0 1px 3px rgba(0,0,0,.2);}
.wto-switch.on .wto-knob{left:23px;}

/* upload */
.wto-drop{border:1.5px dashed var(--wto-line-strong);border-radius:12px;padding:28px 18px;text-align:center;cursor:pointer;transition:border-color .18s var(--wto-ease-out),background .18s ease;background:#fcfdfe;}
.wto-drop:hover,.wto-drop:focus-visible,.wto-drop.wto-drag{border-color:var(--wto-accent);background:rgba(var(--wto-accent-rgb),.05);outline:none;}
.wto-drop svg{width:30px;height:30px;color:var(--wto-steel);margin:0 auto 8px;transition:transform .35s var(--wto-ease-out),color .18s ease;}
.wto-drop:hover svg{transform:translateY(-3px);color:var(--wto-accent);}
.wto-drop strong{display:block;font-size:14px;font-family:var(--wto-display);color:var(--wto-ink);}
.wto-drop span{font-size:12.5px;color:var(--wto-steel);}
.wto-files{display:flex;flex-wrap:wrap;gap:9px;margin-top:14px;}
.wto-file-tag{display:inline-flex;align-items:center;gap:8px;background:var(--wto-surface);border:1px solid var(--wto-line);border-radius:8px;padding:7px 10px;font-size:12.5px;color:var(--wto-ink);animation:wto-fade .25s var(--wto-ease-out);}
.wto-file-tag button{background:none;border:none;cursor:pointer;color:var(--wto-steel);font-size:15px;line-height:1;padding:0 2px;transition:color .15s ease,transform .14s var(--wto-ease-out);}
.wto-file-tag button:hover{color:var(--wto-accent-dark);}
.wto-file-tag button:active{transform:scale(0.85);}

/* conditional blocks */
.wto-cond{display:none;}
.wto-cond.show{display:block;animation:wto-fade .35s var(--wto-ease-out);}

/* nav */
.wto-nav{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:20px 26px;border-top:1px solid var(--wto-line);background:#fbfcfd;}
.wto-btn{font-family:var(--wto-display);font-weight:600;font-size:15px;border-radius:10px;padding:13px 22px;cursor:pointer;border:1.5px solid transparent;display:inline-flex;align-items:center;gap:9px;transition:background .16s ease,border-color .16s ease,transform .14s var(--wto-ease-out),box-shadow .16s ease;}
.wto-btn-primary{background:var(--wto-accent);color:#fff;box-shadow:0 6px 16px -8px rgba(var(--wto-accent-rgb),.7);}
.wto-btn-primary:hover{background:var(--wto-accent-dark);}
.wto-btn-primary:active{transform:scale(0.97);}
.wto-btn-primary svg{width:16px;height:16px;transition:transform .25s var(--wto-ease-out);}
.wto-btn-primary:hover svg{transform:translateX(3px);}
.wto-btn-ghost{background:#fff;color:var(--wto-ink);border-color:var(--wto-line);}
.wto-btn-ghost:hover{border-color:var(--wto-line-strong);}
.wto-btn-ghost:active{transform:scale(0.97);}
.wto-btn-ghost svg{width:16px;height:16px;}
.wto-btn:disabled{opacity:.55;cursor:not-allowed;}
.wto-btn.wto-hide{visibility:hidden;}
.wto-btn.wto-loading{position:relative;pointer-events:none;opacity:.85;}

/* spinner */
.wto-spin{width:16px;height:16px;border:2px solid rgba(255,255,255,.45);border-top-color:#fff;border-radius:50%;animation:wto-rot .7s linear infinite;}
@keyframes wto-rot{to{transform:rotate(360deg);}}

/* sidebar */
.wto-aside{position:sticky;top:18px;display:flex;flex-direction:column;gap:16px;min-width:0;}
@container wto (max-width:900px){.wto-aside{position:static;}}
@media(max-width:900px){.wto-aside{position:static;}}
.wto-sum{background:var(--wto-card);border:1px solid var(--wto-line);border-radius:var(--wto-radius);box-shadow:var(--wto-shadow);overflow:hidden;}
.wto-sum-head{padding:16px 18px;background:var(--wto-ink);color:#fff;}
.wto-sum-head .wto-eyebrow{color:var(--wto-accent);font-size:10.5px;}
.wto-sum-head h3{font-family:var(--wto-display);font-size:16px;margin-top:4px;color:#fff;}
.wto-sum-body{padding:8px 18px 16px;}
.wto-sum-row{display:flex;justify-content:space-between;gap:12px;padding:11px 0;border-bottom:1px dashed var(--wto-line);font-size:13.5px;}
.wto-sum-row:last-child{border-bottom:none;}
.wto-sum-row .wto-k{color:var(--wto-steel);}
.wto-sum-row .wto-v{font-weight:600;text-align:right;color:var(--wto-ink);transition:color .2s ease;min-width:0;overflow-wrap:anywhere;}
.wto-sum-row .wto-v.empty{color:#aab4bd;font-weight:400;}
.wto-help{background:#fff;border:1px solid var(--wto-line);border-radius:var(--wto-radius);padding:18px;font-size:13px;color:var(--wto-steel);}
.wto-help strong{display:block;color:var(--wto-ink);font-family:var(--wto-display);margin-bottom:6px;font-size:14px;}
.wto-help a:not(.wto-wa-btn){color:var(--wto-accent);font-weight:600;}
.wto-wa-btn,.wto-help a.wto-wa-btn{display:flex;align-items:center;justify-content:center;gap:9px;margin-top:12px;background:#25D366;color:#fff;font-family:var(--wto-display);font-weight:600;font-size:14px;padding:11px;border-radius:10px;transition:transform .14s var(--wto-ease-out),filter .16s ease;}
.wto-wa-btn:hover{filter:brightness(1.04);}
.wto-wa-btn:active{transform:scale(0.97);}
.wto-wa-btn svg{width:18px;height:18px;}

/* review */
.wto-review{display:flex;flex-direction:column;}
.wto-review .wto-r{display:flex;justify-content:space-between;gap:14px;padding:13px 0;border-bottom:1px solid var(--wto-line);opacity:0;transform:translateY(6px);animation:wto-rise .4s var(--wto-ease-out) forwards;}
.wto-review .wto-r .wto-k{color:var(--wto-steel);font-size:13.5px;flex:none;width:42%;}
.wto-review .wto-r .wto-v{font-weight:600;text-align:right;font-size:13.5px;color:var(--wto-ink);min-width:0;overflow-wrap:anywhere;}
.wto-consent{display:flex;gap:11px;align-items:flex-start;margin-top:20px;font-size:13px;color:var(--wto-steel);line-height:1.45;cursor:pointer;}
.wto-consent input{margin-top:3px;width:17px;height:17px;accent-color:var(--wto-accent);flex:none;}
.wto-consent a{color:var(--wto-accent);font-weight:600;}
.wto-err{color:var(--wto-accent-dark);font-size:12.5px;margin-top:6px;display:none;}
.wto-err.show{display:block;animation:wto-fade .2s var(--wto-ease-out);}

/* success */
.wto-done{display:none;text-align:center;padding:50px 26px 46px;}
.wto-done.show{display:block;animation:wto-fade .5s var(--wto-ease-out);}
.wto-badge{width:74px;height:74px;border-radius:50%;background:rgba(31,157,107,.12);display:grid;place-items:center;margin:0 auto 20px;animation:wto-pop .5s var(--wto-ease-out);}
@keyframes wto-pop{0%{transform:scale(.6);opacity:0;}60%{transform:scale(1.08);}100%{transform:scale(1);opacity:1;}}
.wto-badge svg{width:38px;height:38px;color:var(--wto-ok);}
.wto-done h2{font-family:var(--wto-display);font-size:25px;margin-bottom:8px;}
.wto-done p{color:var(--wto-steel);max-width:46ch;margin:0 auto 6px;}
.wto-ref{font-family:var(--wto-mono);font-size:13px;background:var(--wto-surface);display:inline-block;padding:8px 14px;border-radius:8px;margin-top:14px;color:var(--wto-ink);}
.wto-next{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;max-width:600px;margin:30px auto 0;text-align:left;}
@container wto (max-width:560px){.wto-next{grid-template-columns:1fr;}}
@media(max-width:560px){.wto-next{grid-template-columns:1fr;}}
.wto-n{background:var(--wto-surface);border-radius:12px;padding:15px;}
.wto-n .wto-num{font-family:var(--wto-mono);font-size:12px;color:var(--wto-accent);font-weight:700;}
.wto-n strong{display:block;font-family:var(--wto-display);font-size:14px;margin:6px 0 3px;color:var(--wto-ink);}
.wto-n span{font-size:12.5px;color:var(--wto-steel);}
.wto-done-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:26px;}

.wto-note{text-align:center;font-size:12px;color:var(--wto-steel);margin:18px auto 0;max-width:1080px;padding:0 20px;}

/* shake (validation feedback) */
@keyframes wto-shake{10%,90%{transform:translateX(-1px);}20%,80%{transform:translateX(2px);}30%,50%,70%{transform:translateX(-4px);}40%,60%{transform:translateX(4px);}}
.wto-shake{animation:wto-shake .4s var(--wto-ease-out);}

/* inline toast */
.wto-toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%) translateY(120%);background:var(--wto-ink,#16202B);color:#fff;font-family:var(--wto-body);padding:13px 20px;border-radius:12px;font-size:14px;font-weight:500;box-shadow:0 12px 32px -8px rgba(0,0,0,.4);z-index:99999;max-width:90vw;transition:transform .4s var(--wto-ease-out,cubic-bezier(0.23,1,0.32,1));}
.wto-toast.show{transform:translateX(-50%) translateY(0);}

/* accessibility: reduced motion */
@media (prefers-reduced-motion: reduce){
  .wto-app *,.wto-app *::before,.wto-app *::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important;}
  .wto-opt{opacity:1;transform:none;}
}

/* touch: gate hover transforms */
@media (hover: none){
  .wto-opt:hover .wto-ic{transform:none;}
  .wto-drop:hover svg{transform:none;}
  .wto-btn-primary:hover svg{transform:none;}
}

/* =========================================================================
   Theme-isolation hardening
   -------------------------------------------------------------------------
   Many themes / page-builders style bare <button>, <a> and form controls in
   the content area with a compound selector (e.g. `.entry-content button`,
   specificity 0,1,1). That BEATS the plugin's single-class component rules
   (`.wto-opt` = 0,1,0), so theme colours bleed into the widget's buttons and
   links (orange/yellow service cards, orange link text) even though `.wto-app`
   uses `all:initial` (which only resets the root, not descendant buttons).

   We fix this once, here, by re-asserting the plugin's own palette at ID
   specificity (`#wto-app …`, from the root <div id="wto-app">) AND with
   `!important`. That combination beats any realistic theme rule – including a
   theme that itself uses `!important` on `button`/`a` (class-level !important
   loses to ID-level !important). Spans/divs (chips, toggles) are left alone –
   themes don't style bare span/div, so they never bleed.
   ========================================================================= */

/* Neutralise inherited theme chrome on native elements. */
#wto-app button{
  -webkit-appearance:none!important;appearance:none!important;
  background:none!important;background-color:transparent!important;background-image:none!important;
  color:inherit!important;box-shadow:none!important;text-shadow:none!important;
  text-transform:none!important;letter-spacing:normal!important;white-space:normal!important;min-height:0!important;
}
#wto-app a{color:inherit!important;background:none!important;text-decoration:none!important;}

/* Service cards. */
#wto-app .wto-opt{background:#fff!important;border:1.5px solid var(--wto-line)!important;border-radius:12px!important;}
#wto-app .wto-opt:hover{background:#fcfdfe!important;border-color:var(--wto-line-strong)!important;}
#wto-app .wto-opt.sel{background:rgba(var(--wto-accent-rgb),.05)!important;border-color:var(--wto-accent)!important;box-shadow:0 0 0 3px rgba(var(--wto-accent-rgb),.1)!important;}
#wto-app .wto-ic{background:var(--wto-surface)!important;color:var(--wto-ink)!important;}
#wto-app .wto-opt.sel .wto-ic{background:var(--wto-accent)!important;color:#fff!important;}
#wto-app .wto-ic--custom,#wto-app .wto-opt.sel .wto-ic--custom{background:#fff!important;}
#wto-app .wto-opt-h3{color:var(--wto-ink)!important;}
#wto-app .wto-opt-p{color:var(--wto-steel)!important;}
#wto-app .wto-check{border:2px solid var(--wto-line-strong)!important;}
#wto-app .wto-opt.sel .wto-check{background:var(--wto-accent)!important;border-color:var(--wto-accent)!important;}

/* Nav / action buttons (also used as <a class="wto-btn …">). */
#wto-app .wto-btn{border:1.5px solid transparent!important;border-radius:10px!important;}
#wto-app .wto-btn-primary,#wto-app a.wto-btn-primary{background:var(--wto-accent)!important;color:#fff!important;box-shadow:0 6px 16px -8px rgba(var(--wto-accent-rgb),.7)!important;}
#wto-app .wto-btn-primary:hover{background:var(--wto-accent-dark)!important;}
#wto-app .wto-btn-ghost{background:#fff!important;color:var(--wto-ink)!important;border-color:var(--wto-line)!important;}
#wto-app .wto-btn-ghost:hover{border-color:var(--wto-line-strong)!important;}

/* File-tag remove button. */
#wto-app .wto-file-tag button{color:var(--wto-steel)!important;}
#wto-app .wto-file-tag button:hover{color:var(--wto-accent-dark)!important;}

/* Links that carry an intentional colour. */
#wto-app .wto-topbar a{color:#cdd6df!important;}
#wto-app .wto-topbar a:hover{color:#fff!important;}
#wto-app .wto-help a:not(.wto-wa-btn){color:var(--wto-accent)!important;}
#wto-app .wto-consent a{color:var(--wto-accent)!important;}
#wto-app .wto-wa-btn,#wto-app a.wto-wa-btn{background:#25D366!important;color:#fff!important;}

/* Form controls. */
#wto-app input[type=text],#wto-app input[type=tel],#wto-app input[type=email],
#wto-app input[type=date],#wto-app input[type=number],#wto-app select,#wto-app textarea{
  background:#fff!important;color:var(--wto-ink)!important;border:1.5px solid var(--wto-line)!important;
}
#wto-app input:focus,#wto-app select:focus,#wto-app textarea:focus{border-color:var(--wto-accent)!important;}

/* Layout: guarantee the service-card grid never overflows / gets clipped,
   even if a theme forces a min-width or nowrap on the buttons. */
#wto-app .wto-opt-grid{width:100%!important;max-width:100%!important;}
#wto-app .wto-opt{width:100%!important;min-width:0!important;max-width:100%!important;white-space:normal!important;overflow-wrap:anywhere;}
