:root {
  --purple:#7c3aed;--purple2:#6d28d9;--purple-l:#ede9fe;--purple-bd:#ddd6fe;--navy:#1a1a2e;
  --text:#1a1a2e;--muted:#6b7280;--muted2:#9ca3af;--border:#e5e7eb;--bg:#f3f4f6;--white:#ffffff;
  --card-blue:#eef2ff;--red:#dc2626;--amber:#d97706;--amber-bg:#fffbeb;--green:#16a34a;
}
*{box-sizing:border-box;margin:0;padding:0;font-family:inherit}
html{background:#ffffff}
body{font-family:'Lato',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;background:#ffffff;color:var(--text);min-height:100vh;padding:28px 24px 48px}

.page-header{display:flex;align-items:flex-start;justify-content:space-between;max-width:1120px;margin:0 auto 24px;gap:16px}
.page-header h1{font-size:clamp(24px,3.5vw,36px);font-weight:900;color:var(--navy);letter-spacing:-1.2px;line-height:1.1}
.page-header h1 span{color:var(--purple)}
.page-header p{font-size:13px;color:var(--muted);margin-top:6px;max-width:480px;line-height:1.5}
.header-cta{background:var(--navy);color:#fff;font-size:13px;font-weight:700;padding:11px 22px;border-radius:8px;text-decoration:none;white-space:nowrap;flex-shrink:0;transition:background .15s}
.header-cta:hover{background:#2d2d4e}

.family-toggle{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px;max-width:1120px;margin-left:auto;margin-right:auto}
.family-btn{padding:14px 16px;border:1px solid rgba(0,0,0,0.06);border-radius:12px;background:var(--white);cursor:pointer;transition:all .15s;text-align:left;box-shadow:0 4px 16px rgba(0,0,0,0.08)}
.family-btn:hover{border-color:var(--purple-bd);background:var(--purple-l);box-shadow:0 4px 20px rgba(0,0,0,0.12)}
.family-btn.active{border-color:var(--purple-bd);background:var(--purple-l);box-shadow:0 4px 20px rgba(124,58,237,.14)}
.family-btn-title{font-size:13px;font-weight:700;color:var(--navy);margin-bottom:4px;display:flex;align-items:center;gap:6px}
.ep-logo-icon{width:18px;height:18px;border-radius:4px;object-fit:cover;flex-shrink:0}
.family-btn-desc{font-size:11px;color:var(--muted);line-height:1.45}

.email-modal{position:fixed;inset:0;background:rgba(255,255,255,0.75);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:none;align-items:center;justify-content:center;z-index:999;padding:20px}
.email-modal.show{display:flex}
.email-modal-card{position:relative;background:var(--white);border-radius:16px;box-shadow:0 8px 32px rgba(0,0,0,.15);padding:32px 28px;max-width:480px;width:100%}
.email-modal-close{position:absolute;top:12px;right:14px;background:none;border:none;font-size:20px;line-height:1;color:var(--muted);cursor:pointer;padding:4px 6px;border-radius:6px;transition:color .15s,background .15s}
.email-modal-close:hover{color:var(--navy);background:rgba(0,0,0,.06)}
.email-modal h2{font-size:22px;font-weight:800;color:var(--navy);margin-bottom:8px;text-align:center}
.email-modal-sub{font-size:13px;color:var(--muted);margin-bottom:24px;line-height:1.6;text-align:center}
.email-form{display:flex;flex-direction:column;gap:14px}
.email-form label{display:block;font-size:12px;font-weight:700;color:var(--navy);margin-bottom:5px}
.email-form input{width:100%;padding:10px 13px;border:1.5px solid var(--border);border-radius:9px;font-size:13px;color:var(--navy);background:var(--bg);font-family:inherit;transition:border-color .15s}
.email-form input:focus{outline:none;border-color:var(--purple);background:#fff}
.email-error{font-size:11px;color:var(--red);margin-top:4px;display:none}
.email-error.show{display:block}
.submit-btn{width:100%;padding:13px;background:linear-gradient(135deg,var(--purple),var(--purple2));color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:700;cursor:pointer;transition:all .15s;margin-top:8px}
.submit-btn:disabled{opacity:.5;cursor:not-allowed}
.submit-btn:not(:disabled):hover{box-shadow:0 4px 14px rgba(124,58,237,.35);transform:translateY(-1px)}
.gdpr-note{font-size:11px;color:var(--muted);margin-top:14px;line-height:1.5;text-align:center}
.hidden{display:none!important}

.top-row{display:grid;grid-template-columns:1fr 340px;gap:16px;max-width:1120px;margin:0 auto 16px;align-items:stretch}
.card{background:var(--white);border-radius:16px;border:1px solid rgba(0,0,0,0.06);box-shadow:0 4px 20px rgba(0,0,0,0.09);padding:22px}
.card-label{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.7px;margin-bottom:14px}
.date-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field label{display:block;font-size:13px;font-weight:700;color:var(--navy);margin-bottom:5px}
.field .hint{font-size:11px;color:var(--muted2);margin-top:4px;line-height:1.4}
.gt-wrap{display:flex;align-items:center;gap:8px;margin-top:2px}
.gt-side-label{font-size:13px;font-weight:700;color:var(--muted);transition:color .2s;line-height:1}
.gt-side-label.gt-active{color:var(--navy)}
.gt-toggle{display:inline-flex;align-items:center;cursor:pointer;user-select:none;flex-shrink:0}
.gt-toggle input[type=checkbox]{display:none}
.gt-track{display:inline-block;width:38px;height:22px;background:var(--border);border-radius:999px;position:relative;flex-shrink:0;transition:background .2s}
.gt-track::after{content:'';position:absolute;width:16px;height:16px;background:#fff;border-radius:50%;top:3px;left:3px;transition:left .2s;box-shadow:0 1px 3px rgba(0,0,0,.25)}
.gt-toggle input:checked~.gt-track{background:var(--purple)}
.gt-toggle input:checked~.gt-track::after{left:19px}
.prgd-wrap{margin-top:6px;display:flex;align-items:center;gap:6px}
.prgd-label{font-size:10px;color:var(--muted);font-weight:700;white-space:nowrap}
.prgd-field-wrap{position:relative}
.prgd-display{padding:4px 8px 4px 10px;min-width:120px;font-size:11px}
.prgd-display .date-val{font-size:11px}
input[type=date]{width:100%;padding:9px 11px;border:1.5px solid var(--border);border-radius:9px;font-size:13px;color:var(--navy);background:var(--bg);font-family:inherit;transition:border-color .15s,box-shadow .15s;cursor:pointer}
input[type=date]:focus{outline:none;border-color:var(--purple);box-shadow:0 0 0 3px rgba(124,58,237,.1);background:#fff}
.divider{height:1px;background:var(--border);margin:16px 0}
.milestone-row{display:flex;align-items:center;justify-content:space-between;gap:12px}
.ms-text .ms-label{font-size:13px;font-weight:700;color:var(--navy)}
.ms-text .ms-sub{font-size:11px;color:var(--muted);margin-top:4px;line-height:1.5;max-width:320px}
.ms-pill{display:flex;align-items:center;gap:8px;background:var(--purple-l);border:1.5px solid var(--purple-bd);border-radius:10px;padding:8px 14px;flex-shrink:0}
.ms-num{font-size:26px;font-weight:900;color:var(--purple);letter-spacing:-1px;line-height:1}
.ms-lbl{font-size:10px;font-weight:700;color:var(--purple);text-transform:uppercase;letter-spacing:.5px;line-height:1.3}

.summary-card{background:#E0D4FF;border-radius:16px;border:1px solid rgba(255,255,255,0.6);box-shadow:0 4px 20px rgba(0,0,0,0.09);padding:22px;position:relative}
.sc-label{font-size:13px;font-weight:600;color:var(--muted);margin-bottom:4px}
.sc-amount{font-size:36px;font-weight:900;color:var(--navy);letter-spacing:-1.5px;line-height:1;font-variant-numeric:tabular-nums}
.sc-desc{font-size:12px;color:var(--muted);margin-top:8px;line-height:1.5}
.sc-divider{height:1px;background:var(--purple-bd);margin:14px 0}
.sc-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:7px}
.sc-row:last-of-type{margin-bottom:0}
.sr-label{font-size:12px;font-weight:600;color:var(--navy)}
.sr-val{font-size:12px;color:var(--muted)}
.cur-toggle{display:flex;background:rgba(124,58,237,.1);border-radius:8px;padding:3px;gap:2px;margin-top:14px}
.cur-btn{flex:1;padding:7px;border:none;border-radius:6px;font-size:12px;font-weight:700;cursor:pointer;background:transparent;color:var(--purple);opacity:.55;transition:all .15s;font-family:inherit}
.cur-btn.active{background:var(--purple);color:#fff;opacity:1;box-shadow:0 2px 6px rgba(124,58,237,.3)}

.calc-overlay{position:absolute;inset:0;background:#E0D4FF;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:16px;z-index:10;padding:20px;text-align:center}
.calc-overlay-title{font-size:15px;font-weight:700;color:var(--navy);margin-bottom:6px}
.calc-overlay-sub{font-size:12px;color:var(--muted);margin-bottom:18px;line-height:1.5}
.calc-btn{padding:14px 28px;background:linear-gradient(135deg,var(--purple),var(--purple2));color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:700;cursor:pointer;box-shadow:0 6px 20px rgba(124,58,237,.3);transition:all .15s}
.calc-btn:hover{box-shadow:0 8px 24px rgba(124,58,237,.4);transform:translateY(-2px)}

.add-country-bar{background:var(--white);border:1px solid rgba(0,0,0,0.06);border-radius:12px;padding:12px 16px;max-width:1120px;margin:0 auto 12px;display:flex;align-items:center;gap:12px;box-shadow:0 4px 20px rgba(0,0,0,0.09)}
.add-country-bar.hidden{display:none}
.add-country-bar.blurred{filter:blur(4px);pointer-events:none}
.ac-label{font-size:12px;font-weight:700;color:var(--navy);white-space:nowrap}
.ac-search-wrap{position:relative;flex:1;max-width:320px}
.ac-search{width:100%;padding:8px 12px;border:1.5px solid var(--border);border-radius:8px;font-size:13px;color:var(--navy);background:var(--bg);font-family:inherit;transition:border-color .15s}
.ac-search:focus{outline:none;border-color:var(--purple);background:#fff}
.ac-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--white);border:1.5px solid var(--border);border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,.1);max-height:280px;overflow-y:auto;z-index:100;display:none}
.ac-dropdown.show{display:block}
.ac-option{padding:10px 12px;font-size:13px;color:var(--navy);cursor:pointer;transition:background .1s;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px}
.ac-option:last-child{border-bottom:none}
.ac-option:hover{background:var(--purple-l)}
.ac-flag{font-size:16px;width:20px;text-align:center}
.ac-empty{padding:16px;text-align:center;font-size:12px;color:var(--muted);font-style:italic}
.ac-count{font-size:11px;color:var(--muted);white-space:nowrap}

.table-card{background:var(--white);border-radius:16px;border:1px solid rgba(0,0,0,0.06);box-shadow:0 4px 20px rgba(0,0,0,0.09);max-width:1120px;margin:0 auto;overflow:hidden;position:relative}
.table-card.blurred{filter:blur(4px);pointer-events:none}
.toolbar{padding:12px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.tb-left{flex:1;min-width:0}
.tt-title{font-size:14px;font-weight:700;color:var(--navy)}
.tt-meta{font-size:11px;color:var(--muted);margin-top:2px}
.tt-grant{font-size:11px;color:var(--muted);margin-top:1px}
.tb-right{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.search-box{display:flex;align-items:center;gap:6px;background:var(--bg);border:1.5px solid var(--border);border-radius:8px;padding:6px 10px;transition:border-color .15s}
.search-box:focus-within{border-color:var(--purple)}
.search-box input{border:none;background:none;outline:none;font-size:12px;color:var(--text);width:150px;font-family:inherit}
.search-box input::placeholder{color:var(--muted2)}
.sort-select{padding:7px 28px 7px 10px;border:1.5px solid var(--border);border-radius:8px;background:var(--white);font-size:12px;font-weight:600;color:var(--muted);cursor:pointer;font-family:inherit;transition:border-color .15s;outline:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%236b7280' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}
.sort-select:focus,.sort-select:hover{border-color:var(--purple);color:var(--purple)}
.restore-btn{padding:7px 12px;border:1.5px solid var(--border);border-radius:8px;background:var(--white);font-size:12px;font-weight:600;color:var(--muted);cursor:pointer;font-family:inherit;transition:all .15s;white-space:nowrap}
.restore-btn:hover{border-color:var(--purple);color:var(--purple)}
/* WIPO empty-state: hide table wrap + table-foot until user adds countries */
.table-card.wipo-empty #table-scroll-wrap{display:none}
.table-card.wipo-empty #table-foot{display:none!important}

/* Scrollable table wrapper */
#table-scroll-wrap{overflow-y:auto;max-height:520px;scrollbar-width:thin;scrollbar-color:transparent transparent;transition:scrollbar-color .2s}
#table-scroll-wrap:hover{scrollbar-color:var(--purple-bd) transparent}
#table-scroll-wrap::-webkit-scrollbar{width:5px}
#table-scroll-wrap::-webkit-scrollbar-track{background:transparent}
#table-scroll-wrap::-webkit-scrollbar-thumb{background:transparent;border-radius:3px;transition:background .2s}
#table-scroll-wrap:hover::-webkit-scrollbar-thumb{background:var(--purple-bd)}

table{width:100%;border-collapse:collapse}
thead{background:var(--purple-l);border-bottom:1.5px solid var(--purple-bd);position:sticky;top:0;z-index:5}
thead th{padding:9px 16px;text-align:left;font-size:10px;font-weight:700;color:var(--purple);text-transform:uppercase;letter-spacing:.6px;white-space:nowrap;user-select:none}
thead th.r{text-align:right}
thead th.c{text-align:center}
.yr-badge{display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:11px;width:30px;height:22px;border-radius:5px;border:1px solid;background:var(--amber-bg);color:var(--amber);border-color:#fde68a}
tbody tr{border-bottom:1px solid var(--border);background:var(--white)}
tbody tr:nth-child(even){background:#fafafa}
tbody tr.removed{opacity:.35}
td{padding:9px 16px;vertical-align:middle}
td.r{text-align:right}
td.c{text-align:center}
.jur-cell{display:flex;align-items:center;gap:10px}
.flag{font-size:18px;line-height:1;width:24px;text-align:center;flex-shrink:0}
.jur-name{font-weight:600;font-size:13px;color:var(--navy)}
.jur-sub{font-size:10px;color:var(--muted2);font-weight:500;margin-top:2px}
.fee-val{font-weight:700;font-size:13px;color:var(--navy);font-variant-numeric:tabular-nums}
.fee-cur{font-size:10px;color:var(--muted2);font-weight:500;margin-left:2px}
.usd-val{font-size:11px;color:var(--muted);font-weight:600;font-variant-numeric:tabular-nums}
.rm-btn{width:26px;height:26px;border-radius:6px;border:1.5px solid var(--border);background:var(--white);color:var(--muted2);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}
.rm-btn-restore{background:var(--green)!important;border-color:var(--green)!important;color:#fff!important;font-size:17px!important;font-weight:700!important}
.rm-btn-restore:hover{background:#15803d!important;border-color:#15803d!important}
.empty-state{padding:52px 20px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px;color:var(--muted)}
.table-foot{padding:9px 18px;font-size:11px;color:var(--muted);line-height:1.6;background:#fafafa;border-top:1px solid var(--border);display:none}
/* Custom Date Picker */
.date-field-wrap{position:relative}
.date-input-display{width:100%;padding:9px 11px;border:1.5px solid var(--border);border-radius:9px;font-size:13px;color:var(--navy);background:var(--bg);cursor:pointer;display:flex;align-items:center;justify-content:space-between;transition:border-color .15s,box-shadow .15s;user-select:none;font-family:inherit}
.date-input-display:hover,.date-input-display.open{border-color:var(--purple);box-shadow:0 0 0 3px rgba(124,58,237,.1);background:#fff}
.date-input-display svg{color:var(--muted2);flex-shrink:0}
.date-val{color:var(--muted2)}
.date-input-display.has-value .date-val{color:var(--navy)}
.cdp-wrap{position:absolute;top:calc(100% + 6px);left:0;background:#fff;border-radius:16px;box-shadow:0 8px 32px rgba(0,0,0,.14);padding:16px;z-index:500;display:none;width:272px;border:1px solid rgba(0,0,0,0.06)}
.cdp-wrap.open{display:block}
.cdp-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.cdp-nav{background:none;border:1.5px solid var(--border);border-radius:8px;width:30px;height:30px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--muted);transition:all .15s;font-size:14px;line-height:1;font-family:inherit}
.cdp-nav:hover{border-color:var(--purple);color:var(--purple)}
.cdp-selects{display:flex;gap:4px;align-items:center}
.cdp-sel{border:1.5px solid var(--border);border-radius:8px;padding:4px 6px;font-size:12px;font-weight:700;color:var(--navy);background:#fff;cursor:pointer;font-family:inherit;outline:none;transition:border-color .15s}
.cdp-sel:focus,.cdp-sel:hover{border-color:var(--purple)}
.cdp-days-hd{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;margin-bottom:4px}
.cdp-days-hd span{font-size:10px;font-weight:700;color:var(--muted2);padding:3px 0}
.cdp-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.cdp-day{text-align:center;padding:6px 0;font-size:12px;cursor:pointer;border-radius:7px;color:var(--navy);transition:background .12s,color .12s}
.cdp-day:hover{background:var(--purple-l);color:var(--purple)}
.cdp-day.cdp-selected{background:var(--purple);color:#fff;font-weight:700}
.cdp-day.cdp-today:not(.cdp-selected){color:var(--purple);font-weight:700}
.cdp-day.cdp-other{visibility:hidden;pointer-events:none}
.cdp-day.cdp-disabled{color:var(--muted2);opacity:.35;cursor:not-allowed;pointer-events:none}
.cdp-footer{display:flex;justify-content:space-between;margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}
.cdp-clear-btn{background:none;border:1.5px solid var(--border);border-radius:8px;padding:6px 14px;font-size:12px;font-weight:600;color:var(--muted);cursor:pointer;font-family:inherit;transition:all .15s}
.cdp-clear-btn:hover{border-color:var(--red);color:var(--red)}
.cdp-select-btn{background:var(--purple);border:none;border-radius:8px;padding:6px 18px;font-size:12px;font-weight:700;color:#fff;cursor:pointer;font-family:inherit;transition:background .15s}
.cdp-select-btn:hover{background:var(--purple2)}

/* EP grant note */
.ep-grant-note{padding:10px 16px;font-size:12px;color:var(--muted);line-height:1.5;border-top:1px solid var(--border);background:#fafafa}

/* Total annuity fee info icon + tooltip */
.annuity-info-wrap{position:relative;display:inline-block;vertical-align:middle;margin-left:6px}
.annuity-info-btn{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;background:var(--purple);color:#fff;font-size:9px;font-weight:700;cursor:pointer;user-select:none;font-style:normal;line-height:1;opacity:.8;transition:opacity .15s}
.annuity-info-btn:hover{opacity:1}
.annuity-tooltip{display:none;position:absolute;bottom:calc(100% + 8px);left:0;width:250px;background:#fff;color:var(--navy);border:1px solid var(--purple-bd);font-size:11px;font-weight:400;line-height:1.6;padding:10px 13px;border-radius:10px;z-index:200;font-style:italic;box-shadow:0 4px 20px rgba(124,58,237,.13);white-space:normal}
.annuity-tooltip::after{content:'';position:absolute;top:100%;left:10px;border:5px solid transparent;border-top-color:var(--purple-bd)}
.annuity-info-wrap:hover .annuity-tooltip,.annuity-info-wrap:focus-within .annuity-tooltip{display:block}

/* Unitary Patent toggle */
.up-toggle{display:inline-flex;align-items:center;cursor:pointer;user-select:none;flex-shrink:0}
.up-toggle input[type=checkbox]{display:none}
.up-track{display:inline-block;width:38px;height:22px;background:var(--border);border-radius:999px;position:relative;flex-shrink:0;transition:background .2s}
.up-track::after{content:'';position:absolute;width:16px;height:16px;background:#fff;border-radius:50%;top:3px;left:3px;transition:left .2s;box-shadow:0 1px 3px rgba(0,0,0,.25)}
.up-toggle input:checked~.up-track{background:var(--purple)}
.up-toggle input:checked~.up-track::after{left:19px}
.fee-suppressed{color:var(--muted2)!important}
.li-note{display:block;font-size:11px;color:var(--muted);font-style:italic;margin-top:3px;line-height:1.3}
.jur-note{display:block;font-size:10px;color:var(--muted2);font-style:italic;margin-top:3px;line-height:1.35;max-width:280px}

/* Per-row info icon + tooltip */
.jur-name{display:inline-flex;align-items:center;gap:4px;flex-wrap:wrap}
.row-info-wrap{position:relative;display:inline-flex;align-items:center;flex-shrink:0;vertical-align:middle}
.row-info-btn{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;background:var(--purple);color:#fff;font-size:9px;font-weight:700;cursor:pointer;user-select:none;font-style:normal;line-height:1;opacity:.8;transition:opacity .15s}
.row-info-btn:hover{opacity:1}
.row-info-tip{display:none;position:fixed;top:0;left:0;transform:translateX(-50%) translateY(-100%);width:230px;background:#fff;color:var(--navy);border:1px solid var(--purple-bd);font-size:11px;font-weight:400;line-height:1.6;padding:10px 13px;border-radius:10px;z-index:9999;font-style:italic;box-shadow:0 4px 20px rgba(124,58,237,.13);white-space:normal}
.row-info-tip::after{content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:var(--purple-bd)}

@media(max-width:820px){
  body{padding:16px 12px 40px}
  .top-row{grid-template-columns:1fr}
  .date-row{grid-template-columns:1fr}
  .page-header{flex-direction:column}
  .family-toggle{grid-template-columns:1fr}
  .add-country-bar{flex-direction:column;align-items:stretch}
  .ac-search-wrap{max-width:100%}
}

/* --- Renew CTA button --- */
/* Only show after the overlay is dismissed (user has entered data + email) */
.calc-overlay:not(.hidden) ~ .renew-cta-btn{display:none}
.renew-cta-btn{display:inline-block;width:auto;margin-top:18px;padding:11px 22px;background:var(--purple);color:#fff;border:none;border-radius:10px;font-family:inherit;font-size:14px;font-weight:700;letter-spacing:.01em;cursor:pointer;transition:background .15s,transform .1s;position:relative;z-index:11}
.renew-cta-btn:hover{background:var(--purple2)}
.renew-cta-btn:active{transform:scale(.98)}

/* --- Renew modal overlay --- */
.renew-modal-overlay{display:none;position:fixed;inset:0;z-index:1000;align-items:center;justify-content:center;background:rgba(255,255,255,0.75);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.renew-modal-overlay.open{display:flex}

/* --- Renew modal box --- */
.renew-modal{position:relative;background:#fff;border-radius:16px;padding:36px 32px 32px;max-width:380px;width:90%;box-shadow:0 12px 48px rgba(124,58,237,.18);text-align:center;animation:renew-pop .2s ease}
@keyframes renew-pop{from{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}
.renew-modal-close{position:absolute;top:14px;right:16px;background:none;border:none;font-size:17px;color:var(--muted);cursor:pointer;line-height:1;padding:4px;border-radius:50%;transition:color .15s}
.renew-modal-close:hover{color:var(--navy)}
.renew-modal-icon{font-size:36px;margin-bottom:14px}
.renew-modal-title{font-size:18px;font-weight:900;color:var(--navy);margin-bottom:10px}
.renew-modal-body{font-size:14px;color:var(--muted);line-height:1.65}
