/* ============================================================
   EVENTIFY — v3 inner pages
   Ivory / rose / editorial style shared by create, how, shop,
   blog, blog detail, contact, values, and modals.
   ============================================================ */

:root{
  --evp-page-pad: clamp(88px, 9vw, 132px);
}

main{
  background: var(--ivory);
}

.evp-page{
  min-height: calc(100vh - 90px);
  background:
    radial-gradient(ellipse 45% 40% at 12% 4%, rgba(226, 52, 138, .10), transparent 68%),
    radial-gradient(ellipse 42% 38% at 88% 10%, rgba(139, 92, 246, .10), transparent 68%),
    var(--ivory);
  color: var(--ink);
}

.evp-wrap{
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 32px;
}

.evp-wrap-wide{
  max-width: 1480px;
  margin: 0 auto;
  padding: 0 32px;
}

.evp-wrap-narrow{
  max-width: 920px;
  margin: 0 auto;
  padding: 0 32px;
}

.evp-hero{
  padding: var(--evp-page-pad) 0 64px;
  text-align: center;
  border-bottom: 1px solid var(--hairline);
  position: relative;
  overflow: hidden;
}

.evp-hero::before{
  content:"";
  position:absolute;
  inset:-20% auto auto 50%;
  transform:translateX(-50%);
  width:min(1180px, 92vw);
  height:520px;
  background:
    radial-gradient(ellipse 42% 60% at 35% 45%, rgba(226,52,138,.12), transparent 68%),
    radial-gradient(ellipse 42% 60% at 70% 30%, rgba(139,92,246,.12), transparent 68%);
  pointer-events:none;
}

.evp-hero > *{
  position:relative;
  z-index:1;
}

.evp-kicker{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:9px 16px;
  border-radius:999px;
  border:1px solid var(--hairline);
  background:rgba(255,254,251,.72);
  color:var(--rose-deep);
  font-size:12px;
  font-weight:700;
  letter-spacing:.04em;
  box-shadow:var(--shadow-sm);
}

.evp-eyebrow{
  display:inline-block;
  font-family:var(--sans);
  font-size:12px;
  font-weight:700;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--rose);
}

.evp-title{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(52px, 7.4vw, 116px);
  line-height:.94;
  letter-spacing:-.045em;
  margin:22px auto 24px;
  max-width:1120px;
  color:var(--ink);
  text-wrap:balance;
}

.evp-title .it,
.evp-section-title .it,
.evp-card-title .it{
  font-style:italic;
  font-weight:300;
  color:var(--rose);
}

.evp-subtitle{
  max-width:760px;
  margin:0 auto;
  color:var(--ink-2);
  font-size:clamp(17px, 1.5vw, 21px);
  line-height:1.55;
  text-wrap:balance;
}

.evp-section{
  padding:96px 0;
}

.evp-section-tight{
  padding:64px 0;
}

.evp-section-title{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(42px, 5.4vw, 82px);
  line-height:.98;
  letter-spacing:-.035em;
  color:var(--ink);
  text-wrap:balance;
}

.evp-section-sub{
  color:var(--ink-2);
  font-size:17px;
  line-height:1.6;
  max-width:700px;
}

.evp-card{
  background:rgba(255,254,251,.86);
  border:1px solid var(--hairline);
  border-radius:24px;
  box-shadow:var(--shadow-sm);
}

.evp-soft-panel{
  background:rgba(255,254,251,.70);
  border:1px solid var(--hairline);
  border-radius:32px;
  box-shadow:0 32px 90px -64px rgba(30,24,18,.36);
}

.evp-gradient-text{
  background:linear-gradient(135deg, var(--rose), var(--marigold));
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
}

.evp-btn,
.evp-btn-dark,
.evp-btn-light,
.evp-btn-ghost{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  border-radius:999px;
  text-decoration:none;
  font-family:var(--sans);
  font-weight:700;
  line-height:1;
  white-space:nowrap;
  cursor:pointer;
  transition:all var(--dur-base) var(--ease-soft);
}

.evp-btn{
  padding:16px 28px;
  border:1px solid transparent;
}

.evp-btn-dark{
  padding:16px 28px;
  background:var(--ink);
  color:var(--ivory)!important;
  border:1px solid var(--ink);
}

.evp-btn-dark:hover{
  background:var(--plum);
  border-color:var(--plum);
  transform:translateY(-2px);
}

.evp-btn-light{
  padding:16px 28px;
  background:var(--paper);
  color:var(--ink)!important;
  border:1px solid var(--hairline-2);
}

.evp-btn-light:hover{
  border-color:var(--ink);
  transform:translateY(-2px);
}

.evp-btn-ghost{
  padding:12px 0;
  color:var(--ink)!important;
  border:0;
  background:transparent;
}

.evp-btn-ghost:hover{
  color:var(--rose-deep)!important;
}

.evp-btn-primary{
  background:linear-gradient(135deg, var(--rose), var(--marigold));
  color:var(--ivory)!important;
  border:1px solid transparent;
  box-shadow:0 20px 40px -20px rgba(226,52,138,.55);
}

.evp-btn-primary:hover{
  color:var(--ivory)!important;
  transform:translateY(-2px);
  box-shadow:0 26px 50px -20px rgba(226,52,138,.70);
}

/* ============================================================
   Modal refresh
   ============================================================ */
#partyWizardModal .modal-content{
  background:var(--paper)!important;
  color:var(--ink)!important;
  border:1px solid var(--hairline)!important;
  border-radius:32px!important;
  box-shadow:0 80px 180px -90px rgba(30,24,18,.55)!important;
}

#partyWizardModal .modal-header{
  background:
    radial-gradient(ellipse 50% 70% at 20% 0%, rgba(226,52,138,.14), transparent 70%),
    radial-gradient(ellipse 50% 70% at 80% 0%, rgba(139,92,246,.14), transparent 70%),
    var(--ivory)!important;
  border-bottom:1px solid var(--hairline)!important;
  padding:28px 32px 18px!important;
}

#partyWizardModal .modal-body{
  padding:28px 32px!important;
}

#partyWizardModal .modal-footer{
  background:var(--ivory)!important;
  border-top:1px solid var(--hairline)!important;
  padding:20px 32px 28px!important;
}

#partyWizardModal h4,
#partyWizardModal h5{
  font-family:var(--serif)!important;
  font-weight:500!important;
  letter-spacing:-.02em!important;
  color:var(--ink)!important;
}

#partyWizardModal h4{
  font-size:38px!important;
  line-height:1!important;
}

#partyWizardModal h5{
  font-size:28px!important;
}

#partyWizardModal .wizard-muted{
  color:var(--ink-2)!important;
}

#partyWizardModal .wizard-progress-shell{
  background:var(--cream)!important;
  height:5px!important;
  border-radius:999px!important;
  margin-top:18px!important;
}

#partyWizardModal .wizard-progress-bar{
  background:linear-gradient(135deg,var(--rose),var(--marigold))!important;
}

#partyWizardModal .wizard-card,
#partyWizardModal .wizard-friend-row,
#partyWizardModal .wizard-theme-box,
#partyWizardModal .wizard-bag-item{
  background:var(--paper)!important;
  border:1px solid var(--hairline)!important;
  border-radius:22px!important;
  box-shadow:var(--shadow-sm)!important;
}

#partyWizardModal .btn-dark,
#partyWizardModal .btn-primary{
  border-radius:999px!important;
  background:var(--ink)!important;
  border-color:var(--ink)!important;
  color:var(--ivory)!important;
}

#partyWizardModal .btn-dark:hover,
#partyWizardModal .btn-primary:hover{
  background:var(--plum)!important;
  border-color:var(--plum)!important;
}

#partyWizardModal .btn-outline-dark,
#partyWizardModal .btn-outline-secondary{
  border-radius:999px!important;
  border-color:var(--hairline-2)!important;
  color:var(--ink)!important;
  background:transparent!important;
}

#partyWizardModal .btn-outline-dark:hover,
#partyWizardModal .btn-outline-secondary:hover{
  background:var(--ink)!important;
  color:var(--ivory)!important;
  border-color:var(--ink)!important;
}

/* ============================================================
   Forms shared
   ============================================================ */
.evp-form-label{
  display:block;
  font-size:11px;
  font-weight:800;
  letter-spacing:.20em;
  text-transform:uppercase;
  color:var(--ink-3);
  margin:0 0 10px;
}

.evp-page .form-control,
.evp-page .form-select{
  border:1px solid var(--hairline);
  border-radius:18px;
  background:rgba(255,254,251,.78);
  color:var(--ink);
  padding:16px 18px;
  font-size:16px;
  min-height:56px;
  box-shadow:none;
}

.evp-page textarea.form-control{
  min-height:128px;
  resize:vertical;
}

.evp-page .form-control::placeholder,
.evp-page .form-select{
  color:var(--ink-3);
}

.evp-page .form-control:focus,
.evp-page .form-select:focus{
  border-color:var(--rose);
  box-shadow:0 0 0 4px rgba(226,52,138,.10);
  background:var(--paper);
}

/* ============================================================
   Create Event
   ============================================================ */
.evc-page{
  padding:128px 0 96px;
}

.evc-shell{
  max-width:980px;
  margin:0 auto;
  padding:0 32px;
}

.evc-card{
  overflow:hidden;
}

.evc-progress{
  height:5px;
  background:var(--cream);
}

.evc-progress-bar{
  height:100%;
  width:33.333%;
  background:linear-gradient(135deg,var(--rose),var(--marigold));
  transition:width .28s var(--ease-soft);
}

.evc-body{
  padding:56px;
}

.evc-head{
  text-align:center;
  margin-bottom:44px;
}

.evc-head h1{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(46px, 5.5vw, 78px);
  line-height:.95;
  letter-spacing:-.04em;
  margin:0 0 10px;
}

.evc-step-title{
  color:var(--ink-3);
  font-size:14px;
  letter-spacing:.08em;
}

.evc-step-section{
  display:none;
}

.evc-step-section.active{
  display:block;
  animation:evcFade .28s var(--ease-soft);
}

@keyframes evcFade{
  from{opacity:0;transform:translateY(10px)}
  to{opacity:1;transform:none}
}

.evc-type-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
}

.evc-type-card{
  display:block;
  min-height:116px;
  padding:20px;
  background:var(--paper);
  border:1px solid var(--hairline);
  border-radius:22px;
  cursor:pointer;
  transition:all .22s var(--ease-soft);
}

.evc-type-card:hover{
  transform:translateY(-2px);
  border-color:var(--hairline-2);
  box-shadow:var(--shadow-sm);
}

.btn-check:checked + .evc-type-card{
  border-color:var(--rose)!important;
  box-shadow:0 0 0 4px rgba(226,52,138,.10), var(--shadow-sm);
  background:linear-gradient(180deg, rgba(252,227,238,.46), var(--paper));
}

.evc-type-title{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:800;
  color:var(--ink);
  margin-bottom:6px;
}

.evc-type-title i{
  color:var(--rose);
}

.evc-type-card small{
  display:block;
  color:var(--ink-2);
  line-height:1.45;
}

.evc-map-shell{
  height:360px;
  display:none;
  border:1px solid var(--hairline);
  border-radius:24px;
  overflow:hidden;
  background:var(--ivory-2);
}

.evc-info-box{
  border:1px solid var(--hairline);
  border-radius:24px;
  padding:22px;
  background:linear-gradient(180deg, rgba(252,227,238,.36), var(--paper));
}

.evc-actions{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  margin-top:44px;
}

.evc-actions .btn{
  min-width:154px;
}

/* ============================================================
   How it works / values cards
   ============================================================ */
.evp-step-grid,
.evp-values-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:24px;
}

.evp-step-card,
.evp-value-card{
  padding:36px;
  min-height:260px;
  transition:all var(--dur-base) var(--ease-soft);
}

.evp-step-card:hover,
.evp-value-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-md);
}

.evp-step-num{
  font-family:var(--serif);
  font-style:italic;
  font-weight:300;
  font-size:34px;
  color:var(--rose);
  margin-bottom:28px;
  display:block;
}

.evp-card-title{
  font-family:var(--serif);
  font-weight:400;
  font-size:34px;
  line-height:1.02;
  letter-spacing:-.025em;
  margin:0 0 18px;
}

.evp-card-text{
  color:var(--ink-2);
  font-size:16px;
  line-height:1.6;
  margin:0;
}

.evp-dark-band{
  background:linear-gradient(155deg,#2A0E3D 0%,#1A0A2E 58%,#3A0F2F 100%);
  color:var(--ivory);
  border-radius:36px;
  padding:64px;
  position:relative;
  overflow:hidden;
}

.evp-dark-band::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 80% 20%, rgba(226,52,138,.22), transparent 50%),
    radial-gradient(circle at 20% 80%, rgba(139,92,246,.18), transparent 50%);
  pointer-events:none;
}

.evp-dark-band > *{
  position:relative;
  z-index:1;
}

.evp-dark-band h2{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(42px, 5.4vw, 84px);
  line-height:.96;
  letter-spacing:-.035em;
  margin:0 0 20px;
}

.evp-dark-band p{
  color:rgba(251,247,240,.74);
  font-size:18px;
  line-height:1.6;
  max-width:720px;
}

/* ============================================================
   Shop / Shopping
   ============================================================ */
.evs-layout{
  padding:64px 0 104px;
}

.evs-hero-card{
  max-width:1280px;
  margin:0 auto;
  padding:44px;
  border-radius:32px;
  background:rgba(255,254,251,.80);
  border:1px solid var(--hairline);
  box-shadow:0 34px 90px -64px rgba(30,24,18,.40);
}

.evs-breadcrumb .breadcrumb{
  margin-bottom:18px;
}

.evs-breadcrumb a,
.evs-breadcrumb .breadcrumb-item{
  color:var(--ink-3);
  text-decoration:none;
}

.evs-title{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(48px, 5.8vw, 86px);
  line-height:.96;
  letter-spacing:-.04em;
  margin:18px 0 10px;
}

.evs-subtitle{
  color:var(--ink-2);
  font-size:17px;
  max-width:760px;
  margin:0;
}

.evs-grid{
  display:grid;
  grid-template-columns:300px minmax(0,1fr);
  gap:34px;
  align-items:start;
}

.evs-filter-stack{
  position:sticky;
  top:108px;
  display:grid;
  gap:18px;
}

.evs-filter-card{
  background:var(--paper);
  border:1px solid var(--hairline);
  border-radius:22px;
  padding:22px;
  box-shadow:var(--shadow-sm);
}

.evs-filter-title{
  font-family:var(--serif);
  font-size:24px;
  font-weight:500;
  letter-spacing:-.02em;
  margin-bottom:14px;
  color:var(--ink);
}

.evs-scroll-list{
  max-height:250px;
  overflow:auto;
  padding-right:4px;
}

.evs-filter-link{
  display:block;
  padding:9px 0;
  color:var(--ink-2);
  text-decoration:none;
  font-size:14px;
  border-bottom:1px dashed rgba(229,218,198,.62);
}

.evs-filter-link:hover,
.evs-filter-link.active{
  color:var(--rose-deep);
}

.evs-filter-link.active{
  font-weight:800;
}

.evs-toolbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:18px 22px;
  margin-bottom:24px;
}

.evs-product-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:24px;
}

.evs-product-card{
  background:var(--paper);
  border:1px solid var(--hairline);
  border-radius:22px;
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:all var(--dur-base) var(--ease-soft);
  height:100%;
  display:flex;
  flex-direction:column;
}

.evs-product-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-md);
}

.evs-product-img{
  position:relative;
  aspect-ratio:4/3;
  background:linear-gradient(180deg,var(--ivory-2),var(--paper));
  border-bottom:1px solid var(--hairline);
  padding:20px;
  display:flex;
  align-items:center;
  justify-content:center;
}

.evs-product-img img{
  width:100%;
  height:100%;
  object-fit:contain;
  mix-blend-mode:multiply;
}

.evs-wish-count{
  position:absolute;
  top:14px;
  left:14px;
  border:1px solid var(--hairline);
  background:rgba(255,254,251,.88);
  color:var(--ink);
  border-radius:999px;
  padding:7px 11px;
  font-size:12px;
  font-weight:800;
}

.evs-wish-count i{
  color:var(--rose);
}

.evs-product-body{
  padding:20px;
  display:flex;
  flex-direction:column;
  gap:10px;
  flex:1;
}

.evs-brand{
  font-size:10px;
  font-weight:800;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-3);
}

.evs-product-name{
  font-family:var(--serif);
  font-size:24px;
  font-weight:500;
  line-height:1.12;
  letter-spacing:-.02em;
  color:var(--ink);
  min-height:2.24em;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

.evs-meta-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-top:auto;
}

.evs-price{
  display:flex;
  gap:8px;
  align-items:baseline;
}

.evs-price old,
.evs-price .old{
  color:var(--ink-4);
  text-decoration:line-through;
  font-size:13px;
}

.evs-price .current{
  color:var(--ink);
  font-weight:900;
  font-size:17px;
}

.evs-rating{
  color:#B07A2A;
  font-size:13px;
  font-weight:800;
}

.evs-chip-row{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:8px;
}

.evs-chip,
.evs-active-chip{
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  border:1px solid var(--hairline);
  background:var(--ivory-2);
  color:var(--ink-2);
  text-decoration:none;
  padding:6px 10px;
  font-size:12px;
  font-weight:700;
}

.evs-active-chip{
  background:var(--rose-pale);
  color:var(--rose-deep);
  border-color:var(--rose-soft);
}

.evs-product-actions{
  display:flex;
  gap:10px;
  margin-top:12px;
}

.evs-product-actions .ev-mini-btn{
  flex:1;
}

.evs-empty{
  padding:80px 32px;
  text-align:center;
  border:1px dashed var(--hairline-2);
  border-radius:28px;
  color:var(--ink-2);
}

.price-slider{
  width:100%;
  -webkit-appearance:none;
  height:4px;
  border-radius:999px;
  background:var(--cream);
}

.price-slider::-webkit-slider-thumb{
  -webkit-appearance:none;
  width:18px;
  height:18px;
  border-radius:50%;
  background:var(--rose);
  border:3px solid var(--paper);
  box-shadow:var(--shadow-sm);
}

/* ============================================================
   Blog
   ============================================================ */
.evb-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:28px;
}

.evb-card{
  overflow:hidden;
  height:100%;
  display:flex;
  flex-direction:column;
  transition:all var(--dur-base) var(--ease-soft);
}

.evb-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-md);
}

.evb-img{
  aspect-ratio:16/10;
  background:var(--ivory-2);
  border-bottom:1px solid var(--hairline);
  overflow:hidden;
}

.evb-img img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.evb-img-empty{
  width:100%;
  height:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:var(--serif);
  font-style:italic;
  color:var(--ink-3);
  font-size:22px;
}

.evb-body{
  padding:24px;
  display:flex;
  flex-direction:column;
  gap:12px;
  flex:1;
}

.evb-cat{
  align-self:flex-start;
  background:var(--rose-pale);
  color:var(--rose-deep);
  border:1px solid var(--rose-soft);
  border-radius:999px;
  padding:7px 11px;
  font-size:11px;
  font-weight:800;
}

.evb-card h2,
.evb-card h3{
  font-family:var(--serif);
  font-weight:500;
  font-size:30px;
  line-height:1.05;
  letter-spacing:-.02em;
  margin:0;
}

.evb-date{
  color:var(--ink-3);
  font-size:13px;
  margin:0;
}

.evb-detail{
  padding:132px 0 96px;
}

.evb-detail-head{
  text-align:center;
  max-width:960px;
  margin:0 auto 48px;
}

.evb-detail-title{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(54px, 7vw, 104px);
  line-height:.95;
  letter-spacing:-.045em;
  margin:18px 0;
}

.evb-detail-img{
  width:100%;
  max-height:520px;
  object-fit:cover;
  border-radius:28px;
  border:1px solid var(--hairline);
  box-shadow:var(--shadow-md);
  margin-bottom:56px;
}

.evb-reading{
  max-width:820px;
  margin:0 auto;
  color:var(--ink-2);
  font-size:18px;
  line-height:1.85;
}

.evb-reading h1,
.evb-reading h2,
.evb-reading h3,
.evb-reading h4{
  font-family:var(--serif);
  color:var(--ink);
  font-weight:500;
  letter-spacing:-.02em;
  margin:1.7em 0 .6em;
}

.evb-reading h2{font-size:42px;line-height:1.05;}
.evb-reading h3{font-size:32px;line-height:1.1;}
.evb-reading p{margin:0 0 1.2em;}
.evb-reading img{max-width:100%;height:auto;border-radius:22px;border:1px solid var(--hairline);}
.evb-tags{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:16px;}

/* ============================================================
   Contact
   ============================================================ */
.evcnt-card{
  display:grid;
  grid-template-columns:.88fr 1.12fr;
  gap:0;
  overflow:hidden;
}

.evcnt-info{
  background:linear-gradient(155deg,#2A0E3D 0%,#1A0A2E 55%,#3A0F2F 100%);
  color:var(--ivory);
  padding:56px;
  position:relative;
  overflow:hidden;
}

.evcnt-info::before{
  content:"@";
  position:absolute;
  right:-20px;
  bottom:-70px;
  font-family:var(--serif);
  font-style:italic;
  font-weight:300;
  font-size:260px;
  color:rgba(251,247,240,.08);
  line-height:1;
}

.evcnt-info h2,
.evcnt-form h2{
  font-family:var(--serif);
  font-weight:500;
  font-size:42px;
  letter-spacing:-.025em;
  margin:0 0 18px;
}

.evcnt-info p{
  color:rgba(251,247,240,.72);
  line-height:1.6;
  margin-bottom:36px;
}

.evcnt-line{
  display:flex;
  align-items:center;
  gap:18px;
  margin-top:24px;
  position:relative;
  z-index:1;
}

.evcnt-icon{
  width:50px;
  height:50px;
  border-radius:50%;
  background:rgba(251,247,240,.10);
  color:var(--rose-soft);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex:0 0 50px;
}

.evcnt-label{
  font-size:11px;
  font-weight:800;
  letter-spacing:.20em;
  text-transform:uppercase;
  color:rgba(251,247,240,.52);
}

.evcnt-value,
.evcnt-value a{
  color:var(--ivory);
  font-weight:800;
  text-decoration:none;
  word-break:break-word;
}

.evcnt-form{
  background:var(--paper);
  padding:56px;
}

/* ============================================================
   Responsive
   ============================================================ */
@media(max-width:1199px){
  .evs-product-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
}

@media(max-width:991px){
  .evp-step-grid,
  .evp-values-grid,
  .evb-grid{grid-template-columns:1fr 1fr;}
  .evs-grid{grid-template-columns:1fr;}
  .evs-filter-stack{position:static;}
  .evcnt-card{grid-template-columns:1fr;}
  .evc-body{padding:42px 32px;}
}

@media(max-width:720px){
  .evp-wrap,
  .evp-wrap-wide,
  .evp-wrap-narrow,
  .evc-shell{padding:0 22px;}
  .evp-hero{padding:112px 0 48px;}
  .evp-section{padding:72px 0;}
  .evp-step-grid,
  .evp-values-grid,
  .evb-grid,
  .evc-type-grid{grid-template-columns:1fr;}
  .evp-dark-band{padding:42px 28px;border-radius:28px;}
  .evc-page{padding:112px 0 72px;}
  .evc-body{padding:36px 22px;}
  .evc-actions{flex-direction:column-reverse;align-items:stretch;}
  .evc-actions .btn{width:100%;}
  .evs-hero-card{padding:30px 24px;border-radius:26px;}
  .evs-product-grid{grid-template-columns:1fr;}
  .evs-toolbar{align-items:stretch;flex-direction:column;}
  .evs-product-actions{flex-direction:column;}
  .evcnt-info,.evcnt-form{padding:38px 26px;}
}
