/* ===== PRICING TABLE PRO v1.1 — FRONT-END ===== */
.ptp-outer{font-family:'Segoe UI',system-ui,sans-serif;max-width:1200px;margin:0 auto;padding:0 16px 48px;position:relative;overflow:visible}

/* ---- Duration Selector ---- */
.ptp-duration-wrap{text-align:center;padding:24px 0 18px}
.ptp-dur-label{display:block;font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:#888;margin-bottom:8px;font-weight:600}
.ptp-dur-select-wrap{display:inline-block;position:relative}
.ptp-dur-select-wrap::after{content:'';position:absolute;right:12px;top:50%;transform:translateY(-50%);border:5px solid transparent;border-top-color:#555;pointer-events:none}
.ptp-dur-select{appearance:none;border:1.5px solid #ddd;border-radius:8px;padding:10px 38px 10px 16px;font-size:15px;background:#fff;color:#1a1a1a;cursor:pointer;min-width:170px}

/* ---- Grid ---- */
.ptp-grid{display:grid;gap:10px}
.ptp-cols-1{grid-template-columns:1fr}
.ptp-cols-2{grid-template-columns:repeat(2,1fr)}
.ptp-cols-3{grid-template-columns:repeat(3,1fr)}
.ptp-cols-4{grid-template-columns:repeat(4,1fr)}

/* ---- Card ---- */
.ptp-card{border:1.5px solid #e2e2e2;border-radius:12px;background:#fff;overflow:visible;position:relative}
.ptp-card.ptp-featured{border:2.5px solid #1d6ee6}

/* ---- Badges ---- */
.ptp-badge-pop{position:absolute;top:-1px;left:50%;transform:translateX(-50%);background:#1d6ee6;color:#fff;font-size:11px;font-weight:700;padding:4px 14px;border-radius:0 0 8px 8px;letter-spacing:.05em;text-transform:uppercase;white-space:nowrap;z-index:20}
.ptp-badge-domain{position:absolute;top:12px;right:12px;border:1.5px solid #1d6ee6;color:#1d6ee6;font-size:11px;font-weight:600;padding:3px 10px;border-radius:20px;background:#fff;z-index:2}

/* ---- Card Head ---- */
.ptp-card-head{
  padding:20px 18px 14px;
  position:relative;
  top:0;
  background:#fff;
  z-index:5;
  border-bottom:1.5px solid #e8e8e8;
  border-radius:12px 12px 0 0;
  box-shadow:0 2px 8px rgba(0,0,0,.06);
}
.ptp-outer.ptp-sticky-enabled .ptp-card-head{
  position:sticky;
  top:var(--ptp-sticky-top,0px);
  z-index:40;
}
.ptp-card.ptp-featured .ptp-card-head{
  padding-top:32px;
  background:#fff;
  border-bottom:1.5px solid #d0e0fa;
}
/* Card and grid must not clip sticky or badge */
.ptp-card{overflow:visible !important}
.ptp-grid{overflow:visible !important}
.ptp-name{font-size:18px;font-weight:700;color:#111;margin-bottom:3px}
.ptp-desc{font-size:12px;color:#888;margin-bottom:12px;min-height:16px}
.ptp-off-row{display:flex;align-items:center;gap:8px;margin-bottom:5px}
.ptp-off-badge{background:#fff3e0;color:#e65100;font-size:11px;font-weight:700;padding:3px 8px;border-radius:4px}
.ptp-orig-price{font-size:13px;color:#bbb;text-decoration:line-through}
.ptp-price-row{display:flex;align-items:center;justify-content:space-between;gap:4px;margin-bottom:3px}
.ptp-price-left{display:flex;align-items:baseline;gap:1px}
.ptp-price-right{display:flex;align-items:center;flex-shrink:0}
.ptp-cur{font-size:17px;font-weight:700;color:#111}
.ptp-amount{font-size:38px;font-weight:800;color:#111;line-height:1}
.ptp-mo{font-size:14px;color:#888}
.ptp-total-line{font-size:12px;color:#888;margin-bottom:4px;min-height:16px}
.ptp-period-val{font-size:13px;font-weight:700;color:#1d6ee6;letter-spacing:.01em}
.ptp-extras{font-size:12px;font-weight:600;margin-bottom:12px;min-height:18px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.ptp-extras-blue{color:#1d6ee6}
.ptp-extras-badge{background:#fff3e0;color:#e65100;font-size:11px;font-weight:700;padding:3px 8px;border-radius:4px}

/* ---- Buttons ---- */
.ptp-btn{display:block;text-align:center;padding:11px 16px;border-radius:8px;font-size:14px;font-weight:600;border:2px solid #1d6ee6;color:#1d6ee6;text-decoration:none;transition:background .15s,color .15s}
.ptp-btn:hover{background:#e8f0fe;color:#1d6ee6}
.ptp-btn-primary{background:#1d6ee6;color:#fff}
.ptp-btn-primary:hover{background:#1558c0;color:#fff}
.ptp-btn-sm{padding:7px 12px;font-size:13px;border-radius:6px}

/* ---- GREEN Renewal Bar ---- */
.ptp-renewal-green{text-align:center;padding:8px 14px}
.ptp-renewal-green span{display:inline-flex;align-items:center;gap:5px;background:#d4edda;border:1px solid #b8dfc4;border-radius:8px;font-size:11px;font-weight:600;color:#276239;padding:6px 16px;white-space:nowrap}
.ptp-renewal-green span::before{content:'✓';color:#28a745;font-weight:700}
.ptp-orig-mo{font-size:11px;color:#bbb;font-weight:400;margin-left:1px}

/* ---- Features ---- */
.ptp-features-wrap{border-top:1px solid #f0f0f0;overflow:visible;position:relative}
.ptp-feat-list{list-style:none;padding:12px 18px 4px;margin:0}
.ptp-feat-list li{display:flex;align-items:flex-start;gap:7px;padding:5px 0;font-size:13px;color:#222;border-bottom:.5px solid #f5f5f5;position:relative;overflow:visible}
.ptp-feat-list li:last-child{border-bottom:none}

/* Enabled — green check */
.ptp-check{flex-shrink:0;margin-top:1px;color:#28a745;stroke:#28a745}

/* Disabled — red cross + strikethrough text */
.ptp-feat-disabled{color:#bbb!important}
.ptp-feat-disabled .ptp-feat-text{text-decoration:line-through;color:#bbb}
.ptp-cross{flex-shrink:0;margin-top:1px;color:#e53935;stroke:#e53935}

/* FREE badge */
.ptp-free-badge{display:inline-block;background:#1d6ee6;color:#fff;font-size:10px;font-weight:700;padding:2px 6px;border-radius:3px;vertical-align:middle;margin-left:3px}

/* ---- Feature Tooltips ---- */
.ptp-has-tooltip{border-bottom:1.5px dotted #444;cursor:text}
.ptp-tooltip-box{display:none;position:absolute;left:0;top:calc(100% + 4px);z-index:999;background:#1a1a2e;color:#fff;font-size:12px;line-height:1.5;padding:10px 14px;border-radius:8px;width:260px;box-shadow:0 4px 16px rgba(0,0,0,.25);pointer-events:none}
.ptp-feat-list li:hover .ptp-tooltip-box{display:block}
.ptp-tooltip-box::before{content:'';position:absolute;bottom:100%;left:16px;border:6px solid transparent;border-bottom-color:#1a1a2e}

/* ---- Expand/Collapse ---- */
.ptp-expand-btn{display:flex;align-items:center;justify-content:center;gap:5px;width:100%;padding:10px 18px;background:none;border:none;border-top:1.5px solid #e0e0e0;cursor:pointer;font-size:12px;font-weight:700;color:#111;text-decoration:underline;text-decoration-color:#1d6ee6;text-underline-offset:3px}
.ptp-expand-btn .ptp-expand-arrow{transition:transform .22s;color:#28a745;stroke:#28a745}
.ptp-expand-btn[aria-expanded="true"] .ptp-expand-arrow{transform:rotate(180deg)}
.ptp-expand-section{display:none;padding:0 16px 12px}
.ptp-expand-section.ptp-open{display:block}

/* Groups */
.ptp-group{border-bottom:.5px solid #f0f0f0}
.ptp-group:last-child{border-bottom:none}
.ptp-group-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;background:none;border:none;padding:9px 0;font-size:13px;font-weight:500;color:#222;cursor:pointer;text-align:left;gap:6px}
.ptp-group-arrow{transition:transform .2s;flex-shrink:0;color:#28a745;stroke:#28a745}
.ptp-group-toggle[aria-expanded="true"] .ptp-group-arrow{transform:rotate(180deg)}
.ptp-group-list{display:none;list-style:none;padding:4px 0 8px 2px;margin:0}
.ptp-group-list.ptp-open{display:block}
.ptp-group-list li{display:flex;align-items:center;gap:6px;font-size:12px;color:#555;padding:3px 0;border-bottom:.5px solid #f8f8f8}
.ptp-group-list li:last-child{border-bottom:none}
.ptp-group-list.ptp-feat-list{padding:6px 0 8px;margin:0}
.ptp-group-list.ptp-feat-list li{align-items:flex-start;gap:7px;padding:5px 0;font-size:13px;color:#222;border-bottom:.5px solid #f5f5f5;position:relative;overflow:visible}
.ptp-group-list.ptp-feat-list .ptp-check{color:#28a745;stroke:#28a745}
.ptp-group-list.ptp-feat-list .ptp-cross{color:#e53935;stroke:#e53935}
.ptp-group-list.ptp-feat-list .ptp-feat-disabled{color:#bbb!important}

/* ---- Global Expand ---- */
.ptp-global-expand-wrap{text-align:center;margin-top:14px}
.ptp-global-expand{display:inline-flex;align-items:center;gap:6px;background:none;border:1.5px solid #1d6ee6;color:#1d6ee6;font-size:13px;font-weight:600;padding:9px 22px;border-radius:8px;cursor:pointer;transition:background .15s}
.ptp-global-expand:hover{background:#e8f0fe}
.ptp-global-expand svg{transition:transform .22s;color:#28a745;stroke:#28a745}
.ptp-global-expand[data-open="1"] svg{transform:rotate(180deg)}

/* Sticky is enabled only after expanded features are open. */

/* ---- COMPACT STICKY (shown only when card-head is stuck at top) ---- */
.ptp-compact-sticky{display:none}  /* hidden by default */
.ptp-compact-top{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:6px;min-height:22px}
.ptp-compact-name{font-size:16px;font-weight:700;color:#111;line-height:1.25}
.ptp-compact-domain{border:1px solid #cfe0ff;background:#eef5ff;color:#1d6ee6;font-size:11px;font-weight:600;padding:4px 9px;border-radius:5px;white-space:nowrap}
.ptp-compact-price-row{display:flex;align-items:flex-end;justify-content:space-between;gap:8px;margin-bottom:10px}
.ptp-compact-price{display:flex;align-items:baseline;gap:1px}
.ptp-compact-cur{font-size:15px;font-weight:700;color:#111}
.ptp-compact-amount{font-size:30px;font-weight:800;color:#111;line-height:1}
.ptp-compact-mo{font-size:13px;color:#888}
.ptp-compact-year{flex-shrink:0}
.ptp-compact-year-val{font-size:12px;font-weight:700;color:#1d6ee6;white-space:nowrap}
.ptp-btn-compact{padding:9px 14px;font-size:13px}

/* When card-head is stuck: show compact, hide full */
.ptp-card-head.is-sticky .ptp-compact-sticky{display:block}
.ptp-card-head.is-sticky .ptp-full-details{display:none}
.ptp-card-head.is-sticky{padding:16px 18px 14px;border-radius:12px 12px 0 0;box-shadow:0 4px 14px rgba(0,0,0,.08);overflow:visible;isolation:isolate}
.ptp-card-head.is-sticky::before{
  content:'';
  position:absolute;
  left:-12px;
  right:-12px;
  top:-72px;
  height:74px;
  background:#fff;
  z-index:0;
  pointer-events:none;
}
.ptp-card-head.is-sticky .ptp-compact-sticky{position:relative;z-index:1}
.ptp-card.ptp-featured .ptp-card-head.is-sticky{padding-top:16px}

/* ---- FULL DETAILS: shown in normal (non-stuck) state ---- */
.ptp-full-details{display:block}

/* ---- Responsive ---- */
@media(max-width:900px){
  .ptp-cols-4,.ptp-cols-3{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:560px){
  .ptp-cols-4,.ptp-cols-3,.ptp-cols-2{grid-template-columns:1fr}
}

/* ===========================================================
   PRICING HUB — tabs + dropdown switcher
   =========================================================== */

/* ---- TABS style ---- */
.ptp-hub-tabs{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  padding:20px 0 16px;
  border-bottom:1px solid #e8e8e8;
  margin-bottom:24px;
}
.ptp-hub-tab{
  padding:9px 20px;
  border:1.5px solid #d0d0d0;
  border-radius:24px;
  background:#f8f8f8;
  color:#444;
  font-size:14px;
  font-weight:500;
  cursor:pointer;
  transition:all .15s;
  white-space:nowrap;
}
.ptp-hub-tab:hover{border-color:#1d6ee6;color:#1d6ee6;background:#f0f5ff}
.ptp-hub-tab.active{
  background:#1d6ee6;
  color:#fff;
  border-color:#1d6ee6;
  font-weight:600;
}

/* ---- DROPDOWN style ---- */
.ptp-hub-dropdown-wrap{
  background:#f9f9f9;
  border:1.5px solid #e0e0e0;
  border-radius:12px;
  padding:20px 24px;
  margin-bottom:24px;
}
.ptp-hub-row{
  display:flex;
  gap:20px;
  flex-wrap:wrap;
}
.ptp-hub-field{flex:1;min-width:200px}
.ptp-hub-field-label{
  display:block;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.05em;
  color:#888;
  margin-bottom:8px;
  font-weight:600;
}
.ptp-hub-sel-wrap{position:relative}
.ptp-hub-sel-wrap::after{
  content:'';position:absolute;right:14px;top:50%;
  transform:translateY(-50%);
  border:5px solid transparent;border-top-color:#555;
  pointer-events:none;
}
.ptp-hub-sel-wrap select,
.ptp-hub-dur-clone{
  appearance:none;
  width:100%;
  border:1.5px solid #d0d0d0;
  border-radius:8px;
  padding:11px 40px 11px 16px;
  font-size:15px;
  background:#fff;
  color:#1a1a1a;
  cursor:pointer;
}

/* ---- PANEL visibility ---- */
.ptp-hub-panel{display:none}
.ptp-hub-panel.active{display:block}

/* --- style="both" / "dropdown": hide the inline duration wrap
   but keep the <select> accessible in the DOM so JS can read its options.
   We use visibility+height:0 instead of display:none. --- */
.ptp-hub-style-both .ptp-duration-wrap,
.ptp-hub-style-dropdown .ptp-duration-wrap {
  visibility: hidden;
  height: 0;
  overflow: hidden;
  margin: 0;
  padding: 0;
}

/* Tab-only mode: keep inline duration fully visible */
.ptp-hub-style-tabs .ptp-duration-wrap {
  visibility: visible;
  height: auto;
  overflow: visible;
}

/* Separator between tabs row and dropdown row in "both" mode */
.ptp-hub-style-both .ptp-hub-tabs {
  margin-bottom:0;
  border-bottom:none;
  padding-bottom:12px;
}
.ptp-hub-style-both .ptp-hub-dropdown-wrap {
  margin-top:0;
  border-top:1px solid #e8e8e8;
  border-radius:0 0 12px 12px;
  border-top-left-radius:0;
  border-top-right-radius:0;
  padding-top:16px;
  margin-bottom:24px;
}

@media(max-width:560px){
  .ptp-hub-row{flex-direction:column}
  .ptp-hub-tab{padding:8px 14px;font-size:13px}
}
