/* FabriScribe components — index base aligned to v6 */
*{box-sizing:border-box}
    .srOnly{position:absolute!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border:0!important}
    body{
      margin:0;
      font-family: Inter, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, "Noto Sans", "Liberation Sans", sans-serif;
      background:
        radial-gradient(1300px 760px at -8% -12%, var(--bg-spot1) 0%, transparent 58%),
        radial-gradient(1180px 700px at 108% 0%, var(--bg-spot2) 0%, transparent 56%),
        linear-gradient(180deg, var(--page-grad-top) 0%, var(--bg) 42%, var(--page-grad-bottom) 100%);
      color:var(--text);
    }
    a{color:inherit;text-decoration:none}
    .wrap{max-width:var(--max);margin:0 auto;padding:0 20px}
    .nav{
      position:sticky; top:0; z-index:60;
      padding:10px 0 8px;
      background:linear-gradient(180deg, rgba(234,236,235,.94) 0%, rgba(234,236,235,.82) 68%, rgba(234,236,235,0) 100%);
      backdrop-filter:blur(16px);
      border-bottom:0;
    }
    .navin{
      display:flex;align-items:center;justify-content:space-between;gap:14px;
      padding:10px 14px;
      background:var(--panel-bg-soft);
      border:1px solid color-mix(in srgb,var(--accent) 10%, var(--border));
      border-radius:24px;
      box-shadow:0 16px 36px rgba(47,42,39,.08), inset 0 1px 0 rgba(255,255,255,.55);
    }
    .brand{display:flex;align-items:center;gap:12px;font-weight:900;color:var(--text);min-width:0}
    .brand-wordmark{display:flex;flex-direction:column;line-height:1.02;min-width:0}
    .brand-wordmark span{font-size:16px;letter-spacing:-.02em}
    .brand-wordmark small{font-size:10px;font-weight:800;color:var(--muted);letter-spacing:.08em;text-transform:uppercase;margin-top:4px}
    .brand-logo{width:42px;height:42px;border-radius:14px;display:block;object-fit:cover;box-shadow:0 10px 22px rgba(168,100,67,.14);border:1px solid rgba(168,100,67,.16);background:var(--surface-2);flex:0 0 42px}
    .navlinks{display:flex;align-items:center;gap:6px;color:var(--muted);font-weight:750;font-size:14px;padding:5px 6px;background:rgba(255,255,255,.32);border:1px solid color-mix(in srgb,var(--accent) 8%, var(--border));border-radius:18px;box-shadow:inset 0 1px 0 rgba(255,255,255,.45)}
    .navlinks a{padding:10px 13px;border-radius:12px;transition:.18s ease;position:relative}
    .navlinks a:hover{background:rgba(255,255,255,.92);color:var(--text);box-shadow:0 8px 18px rgba(47,42,39,.06)}
    .navcta{display:flex;align-items:center;gap:8px;flex:0 0 auto;flex-wrap:wrap;justify-content:flex-end;padding:6px;background:linear-gradient(180deg, rgba(255,255,255,.58) 0%, rgba(248,250,249,.86) 100%);border:1px solid color-mix(in srgb,var(--accent) 12%, var(--border));border-radius:22px;box-shadow:inset 0 1px 0 rgba(255,255,255,.68), 0 10px 24px rgba(47,42,39,.05)}
    .navcta > *{flex:0 0 auto}
    .navcta > .btn,
    .navcta > .localePicker .localeBtn,
    .navcta > .currencyPicker .currencyBtn{min-height:46px}
    .navcta > .localePicker,
    .navcta > .currencyPicker{position:relative}
    .navcta > a[data-auth="login"]{min-width:110px}
    .localePicker,.currencyPicker{position:relative;display:inline-flex;align-items:center}
    .localeBtn,.currencyBtn{
      width:100%;border:1px solid color-mix(in srgb,var(--accent) 16%, var(--line));
      background:radial-gradient(120% 140% at 0% 0%, rgba(255,255,255,.98) 0%, rgba(255,255,255,.76) 44%, transparent 100%), linear-gradient(180deg, rgba(255,255,255,.96) 0%, rgba(248,250,249,.90) 100%);
      color:var(--text);
      border-radius:16px;padding:11px 13px;font:800 13px/1.2 Inter, ui-sans-serif, system-ui;
      cursor:pointer;display:inline-flex;align-items:center;justify-content:flex-start;min-height:46px;height:46px;gap:10px;white-space:nowrap;
      transition:border-color .18s ease, box-shadow .18s ease, background .18s ease, transform .18s ease;
      box-shadow:0 10px 22px rgba(47,42,39,.05), inset 0 1px 0 rgba(255,255,255,.86);
    }
    .localeBtn{min-width:112px}
    .currencyBtn{min-width:102px;padding:11px 12px;gap:8px}
    .currencyMenu{min-width:210px}
    .localeBtn:hover,.currencyBtn:hover{background:radial-gradient(120% 140% at 0% 0%, rgba(255,255,255,1) 0%, rgba(255,255,255,.84) 44%, transparent 100%), linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(248,250,249,.96) 100%);border-color:color-mix(in srgb,var(--accent) 28%, var(--line));transform:translateY(-1px)}
    .localeBtn:focus-visible,.currencyBtn:focus-visible{
      outline:none;
      border-color:var(--accent);
      box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 15%, transparent);
    }
    .localeFlag{
      width:18px;height:14px;display:inline-block;flex:0 0 18px;border-radius:2px;
      background-size:cover;background-position:center center;background-repeat:no-repeat;
      vertical-align:middle;
    }
    .localeFlagFallback{
      width:18px;height:14px;display:inline-flex;align-items:center;justify-content:center;flex:0 0 18px;
      border-radius:2px;border:1px solid color-mix(in srgb,var(--accent) 18%, var(--border));background:var(--card);color:var(--muted);font-size:10px;
      line-height:1;
    }
    .currencyGlyph{
      width:22px;height:18px;border-radius:6px;border:1px solid color-mix(in srgb,var(--accent) 16%, var(--line));
      box-shadow:0 2px 6px rgba(47,42,39,.05), inset 0 1px 0 rgba(255,255,255,.64);
      background:linear-gradient(135deg, color-mix(in srgb,var(--accent) 10%, white) 0%, color-mix(in srgb,var(--accent-soft) 44%, white) 100%);
      display:inline-flex;align-items:center;justify-content:center;
      font-size:9px;font-weight:900;letter-spacing:.02em;color:var(--accent-strong);text-transform:uppercase;
      overflow:hidden;
    }
    .localeCode,.currencyCode{
      flex:1 1 auto;

      font-weight:800;
      letter-spacing:.02em;
      color:var(--text);
      font-size:13px;
    }
    .localeCaret,.currencyCaret{
      width:7px;height:7px;display:inline-block;flex:0 0 auto;
      border-right:1.75px solid var(--muted);border-bottom:1.75px solid var(--muted);
      transform:translateY(-1px) rotate(45deg);opacity:.72;
      transition:transform .18s ease, opacity .18s ease;
    }
    .localeBtn[aria-expanded="true"] .localeCaret,
    .currencyBtn[aria-expanded="true"] .currencyCaret{transform:translateY(1px) rotate(-135deg);opacity:.9}
    .localeMenu,.currencyMenu{
      position:absolute;top:calc(100% + 10px);right:0;z-index:60;
      min-width:232px;
      background: var(--menu-bg);
      backdrop-filter: blur(8px) saturate(1.02);
      -webkit-backdrop-filter: blur(8px) saturate(1.02);
      border:1px solid var(--line);
      border-radius:18px;
      box-shadow:0 22px 54px rgba(31,78,87,.14), 0 8px 20px rgba(31,78,87,.06);
      padding:7px;
      display:none;
      transform-origin:top right;
      animation:localeMenuIn .18s ease;
    }
    .localeMenu::before,.currencyMenu::before{
      content:'';
      position:absolute;inset:0;
      border-radius:inherit;
      box-shadow:inset 0 1px 0 rgba(255,255,255,.55);
      pointer-events:none;
    }
    .localeMenu.open,.currencyMenu.open{display:block}
    .localeItem,.currencyItem{
      width:100%;border:0;background:transparent;color:var(--text);
      display:flex;align-items:center;gap:12px;text-align:left;
      padding:11px 12px;border-radius:14px;font-size:13px;font-weight:700;cursor:pointer;
      transition:background .16s ease, color .16s ease, transform .16s ease;
    }
    .localeItem:hover,.currencyItem:hover{background: var(--accent-pale);transform:translateY(-1px)}
    .localeItem.is-active,.currencyItem.is-active{
      background: color-mix(in srgb,var(--accent) 12%, white);
      color:var(--accent-strong);
      box-shadow: inset 0 0 0 1px color-mix(in srgb,var(--accent) 16%, white);
    }
    .localeName,.currencyName{flex:1 1 auto}
    .localeCheck,.currencyCheck{
      width:18px;height:18px;border-radius:999px;
      display:inline-flex;align-items:center;justify-content:center;
      margin-left:4px;
      background:color-mix(in srgb,var(--accent) 14%, white);
      color:var(--accent-strong);
      font-size:11px;
      font-weight:900;
      opacity:0;
      transform:scale(.92);
      transition:opacity .16s ease, transform .16s ease;
    }
    .localeItem.is-active .localeCode,.currencyItem.is-active .currencyCode{color:var(--accent-strong)}
    .localeItem.is-active .localeCheck,
    .currencyItem.is-active .currencyCheck{opacity:1;transform:scale(1)}
    @keyframes localeMenuIn{
      from{opacity:0;transform:translateY(-4px) scale(.985)}
      to{opacity:1;transform:translateY(0) scale(1)}
    }
    @media (max-width: 980px){
      .navin{padding:10px 12px}
      .navcta{gap:8px;padding:4px 5px}
      .navlinks{padding:4px 5px}
    }
    @media (max-width: 820px){
      .navin{flex-wrap:wrap;justify-content:center}
      .brand{width:100%;justify-content:center}
      .navlinks{order:3;width:100%;justify-content:center;flex-wrap:wrap}
      .navcta{width:100%;justify-content:center}
      .localeBtn,.currencyBtn{width:94px;padding:10px 12px}
      .localeMenu,.currencyMenu{right:auto;left:0}
      .navcta > a[data-auth="login"]{min-width:auto}
    }
    .btn{
      display:inline-flex;align-items:center;justify-content:center;gap:8px;
      border-radius:18px;padding:12px 16px;font-weight:800;font-size:14px;line-height:1;
      border:1px solid color-mix(in srgb,var(--accent) 10%, var(--line));cursor:pointer;transition:.18s ease;text-decoration:none;
      background:linear-gradient(180deg, rgba(255,255,255,.96) 0%, rgba(248,250,249,.92) 100%);color:var(--text);box-shadow:0 10px 22px rgba(47,42,39,.05), inset 0 1px 0 rgba(255,255,255,.72);
    }
    .btn:hover{transform:translateY(-1px);background:#fff}
    .btn.primary{
      background:linear-gradient(180deg, color-mix(in srgb,var(--accent) 92%, white) 0%, var(--accent-strong) 100%);
      border-color:color-mix(in srgb,var(--accent) 48%, transparent);
      color:#fff;
      box-shadow:0 12px 24px color-mix(in srgb,var(--accent) 26%, transparent), inset 0 1px 0 rgba(255,255,255,.16);
    }
    .navcta .btn.primary{min-width:118px;padding-inline:18px}
    .btn.primary:hover{background:var(--accent-strong);filter:none}

    .heroTop .btn{min-height:48px}
    .navcta .btn, .localeBtn, .currencyBtn{min-height:46px}
    .hero{padding:54px 0 30px}
    .pill{
      display:inline-flex;align-items:center;gap:8px;
      padding:8px 12px;border-radius:999px;
      background: color-mix(in srgb,var(--accent) 10%, white);
      border:1px solid color-mix(in srgb,var(--accent) 18%, var(--line));
      font-weight:800;font-size:12px;color:var(--accent-strong);
      letter-spacing:.2px;
    }
    .pill i{
      width:8px;height:8px;border-radius:999px;background:var(--accent);
      box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 18%, transparent);
      display:inline-block;
    }
    h1{
      margin:14px 0 10px;
      font-size: clamp(34px, 5vw, 56px);
      line-height: 1.04;
      letter-spacing:-.8px;
    }
    h1 .accent{color:var(--accent)}
    .sub{
      max-width: 860px;
      margin: 0 auto;
      color: var(--muted);
      font-size: 16px;
      line-height: 1.6;
    }
    .heroTop{text-align:center;max-width: 920px;margin: 0 auto}
    .ctaRow{margin-top:18px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

    .panel{
      margin-top:26px;
      background: var(--panel-bg);
      border:1px solid var(--border);
      border-radius: var(--radius);
      box-shadow: var(--shadow);
      overflow:hidden;
    }
    .panel.pad{padding:18px}
    .panelTitle{
      font-size:13px;
      font-weight:900;
      color:var(--text);
      margin: 0 0 10px 2px;
      opacity:.88;
    }

    .heroImage{width:100%;display:block;aspect-ratio: 16 / 7;object-fit: cover}

    .previewImg{
      width:100%;
      display:block;
      border-radius: 18px;
      border:1px solid var(--border);
      box-shadow: var(--shadow2);
    }
    .note{font-size:12px;color:var(--muted);margin-top:10px}

    section{padding:0px 0}
    .secHead{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;margin-bottom:16px;  white-space: nowrap;}
    .secHead h2{margin:0;font-size:28px;letter-spacing:-.4px;color:var(--text)}
    .secHead p{margin:0;color:var(--muted);max-width:560px}
	 

    .grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
	.grid3 small{color:var(--muted);font-weight:700}
	
    .card{
      background:var(--panel-bg-soft);
      border:1px solid var(--border);
      border-radius: var(--radius2);
      box-shadow: var(--shadow2);
      padding:16px;
    }
    .card h3{margin:0 0 8px;font-size:16px;color:var(--text)}
    .card p{margin:0;color:var(--muted);line-height:1.55;font-size:14px}

    .plans{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;align-items:stretch;justify-content:center}
    .plan{
      background:var(--panel-bg-soft);
      border:1px solid var(--border);
      border-radius: var(--radius);
      box-shadow: var(--shadow2);
      padding:18px;
      display:flex;
      flex-direction:column;
      min-height: 290px;
    }
    .plan.featured{
      border-color: color-mix(in srgb,var(--accent) 40%, var(--border));
      box-shadow: 0 22px 60px color-mix(in srgb,var(--accent) 12%, transparent), 0 14px 34px rgba(47,42,39,.08);
      position:relative;
    }
    .badge{
      position:absolute;top:14px;left:14px;
      background: color-mix(in srgb,var(--accent) 12%, white);
      border:1px solid color-mix(in srgb,var(--accent) 24%, var(--border));
      color:var(--accent-strong);
      font-weight:900;font-size:11px;
      padding:7px 10px;border-radius:999px;
	  right:14px;left:auto;
    }
    .planName{font-weight:900;font-size:14px;color:var(--text);margin-top:4px}
    .planSub{margin-top:6px;color:var(--muted);font-weight:700;font-size:12px;line-height:1.3}
    .price{font-size:34px;font-weight:950;letter-spacing:-.6px;margin:6px 0 0;color:var(--text)}
    .per{color:var(--muted);font-weight:800;font-size:12px}
    .ul{margin:12px 0 0;padding-left:16px;color:color-mix(in srgb,var(--ink) 84%, white)}
    .ul li{margin:7px 0;font-size:14px}
    .grow{flex:1}
    .plan .btn{margin-top:14px}

    .statsLine{
      display:flex;gap:10px;justify-content:center;align-items:center;margin-top:18px;
      color:var(--text);font-weight:900;flex-wrap:wrap
    }
    .statsLine small{color:var(--muted);font-weight:700}

   
    .trialCard{
      background: linear-gradient(180deg, color-mix(in srgb,var(--accent) 10%, white), rgba(255,255,255,1));
      border:1px solid color-mix(in srgb,var(--accent) 28%, var(--border));
      border-radius: var(--radius);
      box-shadow: 0 22px 60px color-mix(in srgb,var(--accent) 10%, transparent), 0 14px 34px rgba(47,42,39,.08);
      padding:16px;
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:12px;
      flex-wrap:wrap;
      margin: 10px 0 14px;
    }

    .trialCard .t{
      font-weight:950;
      letter-spacing:-.2px;
      font-size:16px;
	   margin-top: 5px;
    }
    .trialCard .s{
      color:var(--text);
      opacity:.82;
      font-weight:800;
      font-size:13px;
      margin-top:4px;
    }
    .trialCard .k{
      display:inline-flex;align-items:center;gap:8px;
      padding:6px 10px;border-radius:999px;
      background: color-mix(in srgb,var(--accent) 12%, white);
      border:1px solid color-mix(in srgb,var(--accent) 25%, transparent);
      color:var(--accent-strong);
      font-weight:950;font-size:12px;
      white-space:nowrap;
    }
    .trialCard .k b{font-weight:950}
   

    footer{
      padding:26px 0 40px;
      border-top: 1px solid rgba(226,232,240,.9);
      color:var(--muted);
    }
    .foot{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap}
    .foot b{color:var(--text)}

   
    .authModal{position:fixed;inset:0;display:none;z-index:9999}
    .authModal.open{display:block}
    .authBackdrop{position:absolute;inset:0;background:rgba(31,78,87,.32);backdrop-filter:blur(6px)}
    .authCard{
      position:relative;
      width:min(520px, calc(100% - 28px));
      margin:clamp(18px, 6vh, 56px) auto 0;
      background:var(--card);
      border:1px solid var(--border);
      border-radius:22px;
      box-shadow:0 30px 80px rgba(31,78,87,.20);
      overflow:hidden;
    }
    .authHeader{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 16px 12px}
    .authBrand{display:flex;align-items:center;gap:12px}
    .authLogo{
      width:38px;height:38px;border-radius:14px;
      display:flex;align-items:center;justify-content:center;
      background:linear-gradient(135deg, color-mix(in srgb,var(--accent) 18%, white), color-mix(in srgb,var(--accent-soft) 55%, white));
      border:1px solid var(--border);
    }
    .authName{font-weight:900;color:var(--text);line-height:1}
    .authSub{font-size:12px;color:var(--muted);margin-top:2px}
    .authClose{border:1px solid var(--border);background:var(--surface);border-radius:12px;padding:8px 10px;cursor:pointer;color:var(--text)}
    .authClose:hover{background:var(--card-alt)}

    .authTabs{display:flex;gap:8px;padding:0 16px 12px}
    .authTab{
      flex:1;
      border:1px solid var(--border);
      background:var(--card-alt);
      color:color-mix(in srgb,var(--ink) 84%, white);
      padding:10px 12px;
      border-radius:14px;
      font-weight:900;
      cursor:pointer;
    }
    .authTab.active{
      background:var(--card);
      color:var(--text);
      box-shadow:0 10px 24px rgba(31,78,87,.06);
    }

    .authBody{padding:0 16px 16px}

    /* Modal-only compact spacing for legal pages injected into the registration flow */
    .authModal .legal-section{padding:18px 18px 16px !important}
    .authModal .legal-section > .wrap{max-width:100% !important;padding:0 !important}
    .authModal .legal-section .legal-card{margin-top:10px !important}
    .authAlert{
      background:rgba(239,68,68,.08);
      border:1px solid rgba(239,68,68,.22);
      color:#991b1b;
      padding:10px 12px;
      border-radius:14px;
      font-weight:800;
      margin:0 0 12px;
      font-size:13px;
    }
    .authForm{display:flex;flex-direction:column;gap:10px}
    
    .authForm[hidden]{display:none !important;}

    .authLabel{display:flex;flex-direction:column;gap:6px;font-weight:900;color:var(--text);font-size:13px}
    .authInput{
      border:1px solid var(--border);
      background:var(--surface);
      border-radius:14px;
      padding:12px 12px;
      font-size:14px;
      outline:none;
      color:var(--text);
    }
    .authInput:focus{border-color:var(--accent);box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 12%, white)}
   
   
   .authFieldWrap{
  position:relative;
  width:100%;
  display:block;
}

.authFieldWrap .authInput{
  width:100%;
  display:block;
  box-sizing:border-box;
}

.authInput.hasToggle{
  padding-right:52px;
}

.authPwToggle{
  position:absolute;
  top:50%;
  right:12px;
  transform:translateY(-50%);
  width:32px;
  height:32px;
  padding:0;
  margin:0;
  border:0;
  background:transparent;
  border-radius:10px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--muted);
  cursor:pointer;
  appearance:none;
  -webkit-appearance:none;
}

.authPwToggle:hover{
  color:var(--text);
  background:var(--accent-pale);
}

.authPwToggle:focus-visible{
  outline:none;
  box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 12%, white);
}

.authPwToggle svg{
  width:18px;
  height:18px;
  display:block;
  pointer-events:none;
}
	
	
	
	
	
	
	
	
	
	
	
	
	
	
	
	
	
	
	
	
	
	
	
	
	
	
	
	
    .authStrength{display:grid;gap:6px;margin-top:4px}
    .authStrengthBar{height:8px;border-radius:999px;background:var(--accent-pale);overflow:hidden}
    .authStrengthFill{display:block;height:100%;width:0%;transition:width .2s ease}
    .authStrengthText{font-size:12px;font-weight:800;color:var(--muted)}
    .authBtn{
      border:1px solid var(--border);
      background:var(--surface);
      border-radius:16px;
      padding:12px 14px;
      font-weight:900;
      cursor:pointer;
      margin-top:4px;
      color:var(--text);
      box-shadow:0 10px 24px rgba(31,78,87,.06);
    }
    .authBtn.primary,
    .authBtn.loginBtn,
    .authBtn.registerBtn{
      background:var(--accent);
      border-color:color-mix(in srgb,var(--accent) 45%, transparent);
      color:#fff;
      box-shadow:0 10px 20px color-mix(in srgb,var(--accent) 25%, transparent);
    }
    .authBtn.primary:hover,.authBtn.loginBtn:hover,.authBtn.registerBtn:hover{background:var(--accent-strong);filter:none}
    .authSmallLink{
      display:inline-block;
      margin-top:10px;
      font-size:13px;
      font-weight:900;
      color:var(--text);
      text-decoration:underline;
      opacity:.8;
    }
    .authSmallLink:hover{opacity:1}
    .authFineprint{margin-top:12px;color:var(--muted);font-size:12px;line-height:1.4}

    @media (max-width: 1120px){
      .plans{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
    }

    @media (max-width: 940px){
      .grid3,.plans{grid-template-columns:1fr}
      .heroImage{aspect-ratio: 16/10}
    }
  

   
    .miniNote{display:flex;gap:8px;flex-wrap:wrap; padding-left: 10px}
    .pill{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;border:1px solid var(--border);background:var(--card);color:color-mix(in srgb,var(--ink) 84%, white);font-size:12px}

    
    .offerModal{
      position:fixed; inset:0; z-index:10000;
      opacity:0; visibility:hidden; pointer-events:none;
      transition: opacity 200ms cubic-bezier(.2,.8,.2,1), visibility 0ms linear 200ms;
    }
    .offerModal.open{
      opacity:1; visibility:visible; pointer-events:auto;
      transition: opacity 200ms cubic-bezier(.2,.8,.2,1);
    }
    .offerBackdrop{
      position:absolute; inset:0;
      background:rgba(15,23,42,.45);
      backdrop-filter: blur(8px);
      opacity:0;
      transition: opacity 200ms cubic-bezier(.2,.8,.2,1);
    }
    .offerModal.open .offerBackdrop{ opacity:1; }

    .offerCard{
      position:relative;
      width:min(560px, calc(100% - 28px));
      margin:clamp(18px, 7vh, 64px) auto 0;
      background:var(--card);
      border:1px solid rgba(226,232,240,.95);
      border-radius:24px;
      box-shadow:0 30px 90px rgba(15,23,42,.18);
      overflow:hidden;
      opacity:0;
      transform: translateY(14px) scale(.99);
      transition: opacity 220ms cubic-bezier(.2,.8,.2,1), transform 220ms cubic-bezier(.2,.8,.2,1);
    }
    .offerModal.open .offerCard{
      opacity:1;
      transform: translateY(0) scale(1);
    }

    .offerHead{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:18px 18px 10px;}
    .offerBadge{
      display:inline-flex;align-items:center;gap:8px;
      font-size:11px;font-weight:950;letter-spacing:.14em;text-transform:uppercase;
      color:var(--text);background:var(--card-alt);border:1px solid var(--border);
      border-radius:999px;padding:7px 10px;
    }
    .offerTitle{margin:10px 0 0;font-size:18px;font-weight:900;color:var(--text);line-height:1.2}
    .offerSub{margin:6px 0 0;color:#475569;font-size:13px;line-height:1.4}
    .offerBody{padding:12px 18px 18px}
    .offerCodeBox{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:12px;border:1px dashed rgba(148,163,184,.6);background:var(--card-alt);border-radius:16px;padding:12px 14px}
    .offerCode{font-weight:950;font-size:18px;letter-spacing:.08em;color:var(--text)}
    .offerActions{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
    .offerActions .btn{flex:1;min-width:160px}
    .offerMini{margin-top:12px;display:flex;gap:8px;flex-wrap:wrap}
    .offerMini .pill{border:1px solid var(--border);background:var(--card);border-radius:999px;padding:6px 10px;font-size:12px;color:color-mix(in srgb,var(--ink) 84%, white)}
    .offerFine{margin-top:10px;color:var(--muted);font-size:12px}

    .offerHint{margin-top:8px;color:var(--muted);font-size:12px}
    .offerActions{display:flex;gap:10px;justify-content:flex-end;padding:0 16px 16px}

    /* Preview nos cards */
    .price .was{display:inline-block;margin-right:8px;color:#ef4444;font-weight:900;text-decoration:line-through;font-size:14px;vertical-align:middle}
    .planPromo{margin-top:10px;padding:10px 12px;border-radius:14px;background:rgba(2,132,199,.08);border:1px solid rgba(2,132,199,.18);color:var(--text);font-weight:800;font-size:12px}

  

    

    

    

    
    .miniNote{display:flex;gap:8px;flex-wrap:wrap}
    .pill{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;border:1px solid var(--border);background:var(--card);color:color-mix(in srgb,var(--ink) 84%, white);font-size:12px}

    
    .offerModal{position:fixed;inset:0;display:none;z-index:10000}
    .offerModal.open{display:block}
    .offerBackdrop{position:absolute;inset:0;background:rgba(15,23,42,.45);backdrop-filter:blur(6px)}
    .offerCard{position:relative;width:min(560px,calc(100% - 28px));margin:clamp(18px,6vh,64px) auto 0;background:var(--card);border:1px solid var(--border);border-radius:22px;box-shadow:0 30px 80px rgba(15,23,42,.20);overflow:hidden}
    .offerHead{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:16px 16px 12px}
    .offerBadge{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;background:color-mix(in srgb,var(--accent) 10%, white);border:1px solid color-mix(in srgb,var(--accent) 22%, transparent);font-weight:900;font-size:11px;color:var(--accent-strong);letter-spacing:.2px}
    .offerTitle{font-weight:950;color:var(--text);letter-spacing:-.3px;font-size:18px;margin-top:8px}
    .offerSub{color:var(--muted);font-weight:700;font-size:13px;margin-top:4px;line-height:1.35}
    .offerClose{border:1px solid var(--border);background:var(--card);border-radius:12px;padding:6px 10px;cursor:pointer;font-size:18px;line-height:1}
    .offerClose:hover{background:var(--card-alt)}
    .offerBody{padding:0 16px 14px}
    .offerCodeRow{display:flex;align-items:center;gap:10px;margin-top:10px}
    .offerCode{flex:1;font-weight:950;letter-spacing:.8px;border:1px dashed rgba(148,163,184,.9);border-radius:16px;padding:12px 14px;background:var(--card-alt);text-align:center;text-transform:uppercase}
    .offerHint{font-size:12px;color:var(--muted);margin-top:10px}
    .offerActions{display:flex;gap:10px;justify-content:flex-end;padding:14px 16px 16px;border-top:1px solid rgba(226,232,240,.85)}

    .price .was{display:inline-block;margin-right:8px;color:#ef4444;font-weight:900;text-decoration:line-through;font-size:14px;vertical-align:middle}
    .planPromo{margin-top:10px;padding:10px 12px;border-radius:14px;background:rgba(2,132,199,.08);border:1px solid rgba(2,132,199,.18);color:var(--text);font-weight:800;font-size:12px}

    .pill-bonus{
      font-weight:900;
      padding:6px 10px;
      border-radius:999px;
      border:1px solid rgba(16,185,129,.35);
      box-shadow: 0 8px 24px rgba(168,100,67,.18);
      transform: translateY(-1px);
      white-space: nowrap;
    }
    .previewSection{padding-top:10px;padding-bottom:34px}
    .previewSection .panel{margin-top:0}
    .demoShowcase{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(300px,.92fr);gap:22px;align-items:start}
    .demoCopy{padding:10px 4px 4px 0}
    .demoCopy h3{margin:0 0 10px;font-size:24px;letter-spacing:-.3px}
    .demoCopy p{margin:0;color:var(--muted);line-height:1.65;font-size:15px}
    .demoBullets{display:grid;gap:10px;margin-top:14px}
    .demoBullet{display:flex;gap:10px;align-items:flex-start;padding:10px 12px;border-radius:16px;background:var(--card-alt);border:1px solid var(--border);color:color-mix(in srgb,var(--ink) 84%, white);font-size:14px;line-height:1.45}
    .demoBullet b{color:var(--text)}
    .demoFrameWrap{border-radius:22px;overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow2);background:linear-gradient(180deg, rgba(255,255,255,.9) 0%, rgba(248,250,249,.98) 100%)}
    .demoFrame{display:block;width:100%;height:680px;border:0;background:#fff}
    .demoFallbackNote{margin-top:10px;font-size:12px;color:var(--muted)}

    .extCard{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
    .extCardMain{min-width:260px;flex:1}
    .extCardTitle{font-weight:900;margin-bottom:6px}
    .extCardDesc{color:var(--muted);line-height:1.5}
    .extCardActions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}

    @media (max-width: 980px){
      .previewSection{padding-top:4px}
      .demoShowcase{grid-template-columns:1fr}
      .demoCopy{padding:0}
      .demoFrame{height:620px}
    }
    @media (max-width: 700px){
      .demoFrame{height:540px}
    }
.legal-callout li,
.legal-section li{
  margin:0 0 2px;
  color:var(--muted);
  font-size:14px;
  line-height:1.6;
}