
/* =============================================================================
   PLAN CARD — CSS (mantido / alinhado ao visual atual)
   ============================================================================ */

/* Reset local e variáveis */
.plan-card *,.plan-card *::before,.plan-card *::after{ box-sizing:border-box;min-width:0 }
.plan-card{
  --primary: var(--color-primary-600);
  --primary-light: var(--color-primary-50);
  --primary-dark: var(--color-primary-700);
  --primary-rgb: var(--bs-primary-rgb);
  --secondary: var(--color-primary-500);
  --secondary-rgb: 69,137,255;
  --accent:#f43f5e; --success:#16a34a;
  --light:#f8fafc;--dark:#0f172a;--gray:#475569;--border:#e2e8f0;
  --card-bg:#fff;--shadow:0 4px 20px rgba(0,0,0,.08);
  --shadow-strong:0 16px 36px -12px rgba(var(--primary-rgb),.35);
  --glow-primary:0 0 16px rgba(var(--primary-rgb),.18);
  --radius:20px;--ease:cubic-bezier(.2,.6,.2,1);
  --trans:transform .35s var(--ease),box-shadow .35s var(--ease),opacity .3s var(--ease);
  background:var(--card-bg); border:1px solid var(--border); border-radius:var(--radius); box-shadow:var(--shadow);
  position:relative; display:flex; flex-direction:column; gap:.2rem;
  padding:clamp(.9rem,1.5vw,1.2rem); transition:var(--trans); overflow:hidden; cursor:pointer; outline:none; max-width:100%;
}
.plan-card:hover{box-shadow:var(--shadow-strong),var(--glow-primary)}
.plan-card.is-selected{box-shadow:0 0 0 3px rgba(var(--primary-rgb),.25),var(--shadow-strong);border-color:#c7d2fe}
.plan-card.selected{box-shadow:0 0 0 3px rgba(16,185,129,.25),var(--shadow-strong);border-color:#bbf7d0}

/* Header do card */
.plan-card .plan-header{display:flex;flex-direction:column;gap:.6rem;margin:.2rem 0 .8rem}
.group-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.8rem;flex-wrap:wrap;min-width:0}
.group-header-left{display:flex;flex-direction:column;gap:.4rem;min-width:0}
.group-title{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;min-width:0}
.group-name{font-weight:700;color:var(--gray);font-size:clamp(.85rem,1.8vw,.95rem);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* Badges */
.badge{padding:.18rem .5rem;border-radius:999px;font-weight:700;font-size:.72rem}
.badge-type,.badge-featured{ background:var(--primary-light); color:var(--primary); border:1px solid #dbe4ff }
.badge-featured{display:inline-flex;align-items:center;gap:.35rem}

/* Carta e chip */
.carta-credito{
  color:var(--dark);font-size:clamp(1rem,2.2vw,1.15rem);font-weight:800;line-height:1.3;
  padding:6px 10px;border:1px dashed var(--border);border-radius:10px;background:#fff;
  width:max-content;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis
}
.group-modalities-chip{background:var(--light);border:1px solid var(--border);color:var(--gray);padding:.35rem .6rem;border-radius:999px;font-weight:700;font-size:.78rem}

/* Escassez */
.badge-scarce{position:absolute;top:12px;right:12px;z-index:3;pointer-events:none;background:#fef3c7;color:#b45309;font-weight:800;font-size:.8rem;padding:6px 10px;border-radius:999px;border:1px solid #fde68a}

/* Troca de visualização */
.view-switch{display:flex;gap:.4rem;align-items:center;flex-wrap:wrap}
.view-btn{appearance:none;border:1px solid var(--border);background:var(--light);padding:.35rem .65rem;border-radius:999px;cursor:pointer;font-weight:700;font-size:.82rem;color:var(--gray);transition:background .2s var(--ease),border-color .2s var(--ease),transform .15s var(--ease)}
.view-btn:hover{transform:scale(1.02)}
.view-btn.active{background:var(--primary-light);border-color:#dbe4ff;color:var(--primary)}
.view-area{isolation:isolate}

/* Acordeão por prazo */
.mobile-accordion{display:flex;flex-direction:column;gap:.6rem;max-width:100%}
.mob-section{border:1px solid var(--border);border-radius:14px;overflow:hidden;background:#fff;transition:box-shadow .25s var(--ease),border-color .25s var(--ease)}
.mob-section[open]{border-color:#d9ddff;box-shadow:0 6px 20px rgba(var(--primary-rgb),.08)}
.mob-summary{
  display:flex;align-items:center;gap:.6rem;padding:.7rem .9rem;cursor:pointer;list-style:none;user-select:none;
  background:linear-gradient(0deg,rgba(var(--primary-rgb),.02),rgba(var(--primary-rgb),.02));border-bottom:1px dashed var(--border);
  transition:background .25s var(--ease),color .25s var(--ease)
}
.mob-summary::-webkit-details-marker{display:none}
.mob-summary .mob-summary-hint{margin-left:.25rem;font-size:.78rem;color:var(--gray);opacity:.85}
.mob-summary .chevron{margin-left:auto;display:inline-flex;align-items:center;justify-content:center;transition:transform .25s var(--ease),color .25s var(--ease);color:var(--gray)}
.mob-summary:hover{background:linear-gradient(0deg,rgba(var(--primary-rgb),.05),rgba(var(--primary-rgb),.05))}
.mob-summary:focus-visible{outline:3px solid rgba(var(--primary-rgb),.3);outline-offset:2px;border-bottom-color:transparent}
.mob-section[open] .mob-summary{background:linear-gradient(0deg,rgba(var(--primary-rgb),.08),rgba(var(--primary-rgb),.08))}
.mob-section[open] .mob-summary .chevron{transform:rotate(180deg);color:var(--primary)}
.mob-list{display:flex;flex-direction:column;gap:.5rem;padding:.6rem .8rem .8rem}
.mob-item{border:1px solid var(--border);border-radius:12px;background:var(--light);padding:.7rem;display:flex;flex-direction:column;gap:.45rem}
.mob-item.disabled{opacity:.6}

/* Item melhor */
.best-item{
  display:grid; grid-template-columns:minmax(0,1fr) auto; grid-template-areas:"info price" "btn btn";
  align-items:start;gap:.6rem;background:var(--light); border:1px solid var(--border);border-radius:14px;padding:.7rem;
  transition:transform .2s var(--ease),box-shadow .2s var(--ease); cursor:pointer;max-width:100%
}
.best-item:hover{transform:scale(1.01);box-shadow:0 10px 16px -8px rgba(0,0,0,.08)}
.best-item.best{border-color:var(--primary)}
.best-info{grid-area:info;display:flex;flex-direction:column;gap:.15rem;min-width:0;line-height:1.25}
.best-mod{font-weight:800;color:var(--dark);font-size:.95rem}
.best-fee{font-size:.82rem;color:var(--gray);display:flex;flex-direction:column;gap:2px;line-height:1.25}
.best-fee span{display:block;white-space:normal;overflow-wrap:anywhere}
.best-price{grid-area:price;justify-self:end;align-self:start;font-weight:900;font-size:clamp(1rem,2.4vw,1.1rem);color:var(--primary);white-space:nowrap;line-height:1.05;font-variant-numeric:tabular-nums lining-nums;-moz-font-feature-settings:"tnum" 1,"lnum" 1;-webkit-font-feature-settings:"tnum" 1,"lnum" 1;font-feature-settings:"tnum" 1,"lnum" 1}

/* Botão Selecionar */
.select-plan-btn{
  grid-area:btn; display:flex;align-items:center;justify-content:center;gap:8px;width:100%;
  padding:.7rem;border:none;border-radius:12px;
  background:linear-gradient(to right,var(--primary),var(--secondary));color:#fff;
  font-weight:700;transition:transform .2s var(--ease),box-shadow .2s var(--ease);
  box-shadow:var(--glow-primary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden;max-width:100%;
  min-height:44px;line-height:1.1;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none
}
.select-plan-btn:hover{transform:scale(1.01)}
.select-plan-btn.selected{background:var(--success);box-shadow:0 0 15px rgba(16,185,129,.3);pointer-events:none}
.select-plan-btn:focus-visible{outline:3px solid rgba(var(--bs-primary-rgb,28,38,127),1);outline-offset:2px}

/* Carousel */
.plan-carousel-wrap{ position:relative;border:1px solid var(--border);border-radius:14px; padding:.6rem .8rem;background:#fff;overflow:hidden; overscroll-behavior:contain;max-width:100% }
.slide-swiper{overflow:visible;max-width:100%}
.slide-slide-inner{position:relative;display:flex;flex-direction:column;gap:.6rem;max-width:100%}
.slide-slide-head{display:flex;align-items:center;gap:.6rem;min-width:0}
.mob-summary .prazo-chip,.slide-slide-head .prazo-chip{
  display:inline-flex;align-items:center;gap:.35rem;background:var(--primary-light);color:var(--primary);
  border:1px solid #e4e7ff;font-weight:800;border-radius:999px;padding:.2rem .55rem
}
.slide-slide-head .slide-hint{margin-left:auto;font-size:.78rem;color:var(--gray);opacity:.85}
.slide-list{display:flex;flex-direction:column;gap:.5rem;max-width:100%;padding:.25rem .2rem}

/* Itens do slide */
.slide-item{
  border:1px solid var(--border);border-radius:12px;background:var(--light);padding:.6rem;
  display:grid;grid-template-columns:minmax(0,1fr) auto;grid-template-areas:"info price" "btn btn";
  gap:.6rem;cursor:pointer;transition:box-shadow .2s var(--ease),border-color .2s var(--ease);
  -webkit-user-select:none;user-select:none;-webkit-touch-callout:none;max-width:100%;
  margin:.15rem .2rem; /* folga para não encostar na borda do wrap */
}
.slide-item:hover{box-shadow:0 10px 16px -8px rgba(0,0,0,.08); border-color:#c7d2fe}
.slide-item.best{border-color:var(--primary)}
.slide-item.disabled{opacity:.6}
.slide-info{grid-area:info;display:flex;flex-direction:column;gap:.15rem;min-width:0;line-height:1.25}
.slide-mod{font-weight:800;color:var(--dark);font-size:.95rem}
.slide-fee{font-size:.82rem;color:var(--gray);display:flex;flex-direction:column;gap:2px;line-height:1.25}
.slide-fee span{display:block;white-space:normal;overflow-wrap:anywhere}
.slide-price{grid-area:price;justify-self:end;align-self:start;font-weight:900;font-size:clamp(1rem,2.4vw,1.1rem);color:var(--primary);white-space:nowrap;line-height:1.05;font-variant-numeric:tabular-nums lining-nums;-moz-font-feature-settings:"tnum" 1,"lnum" 1;-webkit-font-feature-settings:"tnum" 1,"lnum" 1;font-feature-settings:"tnum" 1,"lnum" 1}

/* Barra de controles + dots */
.pc-controls{ display:flex;align-items:center;gap:.5rem;justify-content:space-between; margin-top:.6rem;padding:.35rem .4rem;border-top:1px dashed var(--border) }
.plan-card .pc-controls .pc-nav{
  position:static;transform:none;width:38px;height:38px;border-radius:999px;
  border:1px solid var(--border);background:linear-gradient(#fff,#f7f7ff);
  color:var(--dark);display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow);cursor:pointer;
  transition:transform .15s var(--ease),box-shadow .15s var(--ease),opacity .2s
}
.plan-card .pc-controls .pc-nav:hover{transform:scale(1.04);box-shadow:0 10px 18px -10px rgba(0,0,0,.15)}
.plan-card .pc-controls .pc-nav:disabled{opacity:.45;cursor:not-allowed}
.pc-nav.hidden{display:none}
.plan-card .pc-controls .pc-nav::before{content:"";display:inline-block;width:12px;height:12px;border:2px solid currentColor;border-top:none;border-right:none}
.plan-card .pc-controls .pc-nav.prev::before{transform:rotate(45deg);margin-left:2px}
.plan-card .pc-controls .pc-nav.next::before{transform:rotate(-135deg);margin-right:2px}

.pc-pagination{display:flex;align-items:center;justify-content:center;gap:8px;flex:1;min-width:0}
.pc-pagination.hidden{display:none}
.pc-pagination .swiper-pagination-bullet{ width:8px;height:8px;border-radius:999px;background:#d1d5db;opacity:1;border:none;outline:none; transition:transform .15s var(--ease),background .2s var(--ease) }
.pc-pagination .swiper-pagination-bullet:focus-visible{outline:3px solid rgba(var(--primary-rgb),.3);outline-offset:2px}
.pc-pagination .swiper-pagination-bullet-active{background:var(--primary);transform:scale(1.15)}

/* Compare button + actions wrap */
.item-actions{display:flex;gap:.5rem;align-items:center;justify-content:flex-end;flex-wrap:wrap}

/* Resumo compacto */
.resumo-plan-container{margin-top:1rem}
.resumo-plan-container .resumo-card{background:var(--card-bg);border:1px solid var(--border);border-radius:14px;padding:1rem;box-shadow:var(--shadow)}
.resumo-plan-container .resumo-mini{padding:0.9rem}
.resumo-plan-container .resumo-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.6rem 1rem}
@media (max-width:520px){.resumo-plan-container .resumo-grid{grid-template-columns:1fr}}
.resumo-plan-container .resumo-row{display:flex;align-items:baseline;justify-content:space-between;gap:.75rem;min-width:0}
.resumo-plan-container .resumo-label{font-size:.85rem;color:var(--gray);white-space:nowrap}
.resumo-plan-container .resumo-value{
  font-weight:800;color:var(--dark);font-size:1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  font-variant-numeric:tabular-nums lining-nums;-moz-font-feature-settings:"tnum" 1,"lnum" 1;-webkit-font-feature-settings:"tnum" 1,"lnum" 1;font-feature-settings:"tnum" 1,"lnum" 1
}

/* Responsivo */
@media (max-width:480px){
  .best-item,.slide-item{grid-template-columns:1fr;grid-template-areas:"info" "price" "btn"}
  .best-price,.slide-price{justify-self:end}
  .plan-card .pc-controls .pc-nav{width:34px;height:34px}
  .pc-pagination .swiper-pagination-bullet{width:7px;height:7px}
}
@media (max-width:420px){
  .badge-type.asset-type{display:none}
  .carta-credito{font-size:.95rem;padding:5px 8px}
  .select-plan-btn{padding:.6rem;font-size:.88rem}
}
@media (max-width:340px){
  .slide-mod,.best-mod{font-size:.92rem}
}

/* Touch / overscroll */
.plan-carousel-wrap,.slide-swiper,.slide-list,.mobile-accordion{overscroll-behavior-x:contain}
@supports (touch-action:pan-y){
  .plan-carousel-wrap,.swiper,.swiper-wrapper,.swiper-slide,.slide-slide-inner,.slide-list,.slide-item,.select-plan-btn{touch-action:pan-y!important}
}
.plan-carousel-wrap,.slide-list,.slide-item,.select-plan-btn{-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}
.plan-carousel-wrap::before,.plan-carousel-wrap::after{
  content:"";position:absolute;top:0;bottom:0;width:max(env(safe-area-inset-left,0px),28px);pointer-events:auto;background:transparent
}
.plan-carousel-wrap::before{left:calc(-1*max(env(safe-area-inset-left,0px),28px))}
.plan-carousel-wrap::after{right:calc(-1*max(env(safe-area-inset-right,0px),28px))}

/* Destaque */
.badge-featured{
  background: linear-gradient(90deg,#f59e0b,#f97316); color:#fff; border-radius:999px;
  padding: .25rem .5rem; font-weight:600; font-size:.75rem; margin-left:.5rem; white-space:nowrap;
}
