/* ============================================================
   AURORA PRO — sistem de design pentru pagini servicii
   Scoped cu prefix `srv-`. Folosește variabilele globale din style.css
   (--brand-*, --text-*, --color-accent, --radius-*, --bg-*, --border-color).
   ============================================================ */
.srv-hero, .srv-section, .srv-cta-band { position: relative; overflow: hidden; }
#srv-calc { overflow: visible; }
.srv-hero { padding: 80px 0 96px; }
.srv-section { padding: 56px 0; }

/* Aurora bg behind hero */
.srv-aurora { position: absolute; inset: 0; pointer-events: none; z-index: 0; overflow: hidden; }
.srv-blob { position: absolute; border-radius: 50%; filter: blur(80px); opacity: .5; }
.srv-b1 { top: -10%; left: -5%; width: 55%; height: 55%; background: radial-gradient(circle, #60a5fa, transparent 70%); }
.srv-b2 { top: 5%; right: -10%; width: 50%; height: 60%; background: radial-gradient(circle, rgba(139,92,246,.55), transparent 70%); }
.srv-b3 { top: 40%; left: 30%; width: 50%; height: 40%; background: radial-gradient(circle, rgba(34,211,238,.4), transparent 70%); }
.srv-mesh { position: absolute; inset: 0; background-image: linear-gradient(rgba(226,232,240,.5) 1px, transparent 1px), linear-gradient(90deg, rgba(226,232,240,.5) 1px, transparent 1px); background-size: 64px 64px; mask: radial-gradient(ellipse 60% 70% at 50% 30%, #000 0%, transparent 80%); -webkit-mask: radial-gradient(ellipse 60% 70% at 50% 30%, #000 0%, transparent 80%); opacity: .6; }
.srv-hero .container, .srv-section .container, .srv-cta-band .container { position: relative; z-index: 1; }

/* Type */
.srv-h1 { font-family: var(--font-display); font-weight: 700; font-size: clamp(32px, 4.4vw, 56px); line-height: 1.08; letter-spacing: -.022em; margin: 24px 0 24px; color: var(--text-primary); }
.srv-h2 { font-family: var(--font-display); font-weight: 700; font-size: clamp(32px, 4.4vw, 56px); line-height: 1.06; letter-spacing: -.022em; margin: 8px 0 0; color: var(--text-primary); }
.srv-grad { background: linear-gradient(135deg, var(--brand-600), #8b5cf6 60%, var(--color-accent)); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; color: transparent; }
.srv-grad-light { background: linear-gradient(135deg, #fff, var(--brand-300)); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; color: transparent; }
.srv-lead { font-size: 18px; line-height: 1.6; color: var(--text-secondary); max-width: 620px; margin: 0 0 48px; }

.srv-pill { display: inline-flex; align-items: center; gap: 8px; padding: 8px 14px; background: rgba(255,255,255,.85); backdrop-filter: blur(12px); border: 1px solid var(--border-color); border-radius: 99px; font-size: 13px; font-weight: 600; color: var(--brand-600); box-shadow: 0 4px 16px -4px rgba(37,99,235,.15); width: fit-content; }
.srv-pill-sm { padding: 5px 10px; font-size: 11px; letter-spacing: .04em; text-transform: uppercase; }
.srv-pill-light { background: rgba(255,255,255,.15); border-color: rgba(255,255,255,.25); color: #fff; backdrop-filter: blur(20px); }
.srv-pill-dot { width: 6px; height: 6px; background: var(--brand-600); border-radius: 50%; box-shadow: 0 0 0 3px rgba(37,99,235,.13); animation: srvPulse 2s ease-in-out infinite; }
.srv-pill-light .srv-pill-dot { background: var(--color-accent); box-shadow: 0 0 0 3px rgba(34,211,238,.2), 0 0 12px var(--color-accent); }
@keyframes srvPulse { 0%, 100% { box-shadow: 0 0 0 3px rgba(37,99,235,.13); } 50% { box-shadow: 0 0 0 6px rgba(37,99,235,.06); } }

.srv-eyebrow { font-size: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: .1em; color: var(--brand-600); padding: 6px 0; display: inline-block; border-bottom: 2px solid rgba(37,99,235,.2); }

/* Buttons */
.srv-btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 14px 22px; font-size: 14px; font-weight: 600; border-radius: 99px; cursor: pointer; text-decoration: none; border: none; font-family: inherit; transition: all .25s var(--ease-out); }
.srv-btn-primary { background: linear-gradient(135deg, var(--brand-600), var(--brand-500)); color: #fff; box-shadow: 0 4px 14px -2px rgba(37,99,235,.35), 0 12px 24px -8px rgba(37,99,235,.2); }
.srv-btn-primary:hover { color: #fff; transform: translateY(-2px); box-shadow: 0 8px 24px -4px rgba(37,99,235,.4), 0 20px 40px -10px rgba(37,99,235,.28); }
.srv-btn-white { background: #fff; color: var(--brand-600); box-shadow: 0 4px 16px rgba(0,0,0,.15); }
.srv-btn-white:hover { color: var(--brand-700); transform: translateY(-2px); box-shadow: 0 8px 28px rgba(0,0,0,.2); }
.srv-btn-accent { background: linear-gradient(135deg, var(--color-accent, #22d3ee), #06b6d4); color: #fff; box-shadow: 0 4px 16px rgba(34,211,238,.32); }
.srv-btn-accent:hover { color: #fff; transform: translateY(-2px); box-shadow: 0 8px 28px rgba(34,211,238,.45); }
.srv-out-actions { display: flex; flex-direction: column; gap: 10px; position: relative; }
.srv-btn-outline-light { background: rgba(255,255,255,.1); color: #fff; border: 1px solid rgba(255,255,255,.3); backdrop-filter: blur(8px); }
.srv-btn-outline-light:hover { color: #fff; background: rgba(255,255,255,.18); border-color: rgba(255,255,255,.5); }
.srv-btn-block { width: 100%; }

/* HERO BENTO */
.srv-bento { display: grid; grid-template-columns: repeat(4, 1fr); grid-template-rows: auto auto; gap: 12px; margin-top: 32px; }
.srv-tile { background: rgba(255,255,255,.7); backdrop-filter: blur(18px) saturate(1.2); border: 1px solid rgba(255,255,255,.9); border-radius: var(--radius-xl); padding: 20px; position: relative; overflow: hidden; box-shadow: 0 1px 0 rgba(255,255,255,.9) inset, 0 8px 32px -8px rgba(37,99,235,.18), 0 24px 48px -24px rgba(15,23,42,.1); transition: all .35s cubic-bezier(.22,1,.36,1); }
.srv-tile:hover { transform: translateY(-4px); box-shadow: 0 1px 0 rgba(255,255,255,1) inset, 0 12px 40px -8px rgba(37,99,235,.28), 0 32px 64px -24px rgba(15,23,42,.14); }
.srv-tile-feat { grid-column: span 2; grid-row: span 2; padding: 28px; background: linear-gradient(135deg, #2563ebf0, #8b5cf6d0); color: #fff; border-color: rgba(255,255,255,.2); display: flex; flex-direction: column; justify-content: space-between; min-height: 240px; }
.srv-tile-feat .srv-pill { background: rgba(255,255,255,.18); border-color: rgba(255,255,255,.25); color: #fff; }
.srv-tile-feat h3 { font-size: 24px; font-weight: 700; line-height: 1.15; letter-spacing: -.018em; margin: 14px 0 8px; color: #fff; }
.srv-tile-feat p { font-size: 14px; color: rgba(255,255,255,.85); line-height: 1.5; max-width: 86%; }
.srv-tile-spot { position: absolute; top: -50%; right: -30%; width: 80%; height: 200%; background: radial-gradient(circle, rgba(255,255,255,.3), transparent 60%); pointer-events: none; }
.srv-tile-foot { display: flex; justify-content: space-between; align-items: center; margin-top: 16px; padding-top: 14px; border-top: 1px solid rgba(255,255,255,.2); }
.srv-tile-price { font-size: 28px; font-weight: 700; color: #fff; letter-spacing: -.02em; display: flex; flex-direction: column; line-height: 1; }
.srv-tile-price i { font-style: normal; font-size: 12px; color: rgba(255,255,255,.7); font-weight: 500; margin-bottom: 4px; }
.srv-arrow-btn { color: #fff; background: rgba(255,255,255,.18); padding: 10px 16px; border-radius: 99px; font-size: 13px; font-weight: 600; text-decoration: none; transition: all .25s; border: 1px solid rgba(255,255,255,.25); }
.srv-arrow-btn:hover { background: #fff; color: var(--brand-600); }

.srv-tile-stat { display: flex; flex-direction: column; gap: 6px; justify-content: space-between; min-height: 110px; }
.srv-tile-dark { background: linear-gradient(135deg, var(--text-primary), #1e293b); border-color: rgba(255,255,255,.08); color: #fff; }
.srv-stat-n { font-size: 40px; font-weight: 700; letter-spacing: -.02em; line-height: 1; background: linear-gradient(135deg, var(--brand-600), #8b5cf6); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.srv-tile-dark .srv-stat-n { background: linear-gradient(135deg, var(--color-accent), var(--brand-300)); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.srv-stat-n i { font-style: normal; font-size: 18px; }
.srv-stat-l { font-size: 13px; font-weight: 500; color: var(--text-muted); line-height: 1.3; }
.srv-tile-dark .srv-stat-l { color: rgba(255,255,255,.65); }

.srv-tile-cta { grid-column: span 2; display: flex; align-items: center; justify-content: space-between; gap: 20px; min-height: 110px; }
.srv-tile-cta h4 { font-size: 18px; font-weight: 700; line-height: 1.2; letter-spacing: -.015em; color: var(--text-primary); }

/* Section heads */
.srv-shead { margin-bottom: 56px; max-width: 780px; }
.srv-shead-p { font-size: 15px; color: var(--text-muted); margin-top: 14px; }

/* Benefits */
.srv-benefits { display: grid; grid-template-columns: repeat(5, 1fr); gap: 16px; }
.srv-bcard { background: rgba(255,255,255,.7); backdrop-filter: blur(16px); border: 1px solid rgba(255,255,255,.9); border-radius: var(--radius-lg); padding: 28px 22px; position: relative; overflow: hidden; display: flex; flex-direction: column; gap: 12px; box-shadow: 0 1px 0 rgba(255,255,255,.9) inset, 0 8px 24px -8px rgba(37,99,235,.12); transition: all .35s cubic-bezier(.22,1,.36,1); }
.srv-bcard:hover { transform: translateY(-6px); border-color: rgba(37,99,235,.4); box-shadow: 0 1px 0 rgba(255,255,255,1) inset, 0 12px 32px -8px rgba(37,99,235,.25), 0 24px 48px -16px rgba(37,99,235,.15); }
.srv-bcard-glow { position: absolute; top: -50%; left: -30%; width: 160%; height: 200%; background: radial-gradient(ellipse, rgba(37,99,235,.06), transparent 60%); opacity: 0; transition: opacity .4s; pointer-events: none; }
.srv-bcard:hover .srv-bcard-glow { opacity: 1; }
.srv-bcard-icon { width: 44px; height: 44px; border-radius: 12px; background: linear-gradient(135deg, var(--brand-600), #8b5cf6); color: #fff; display: flex; align-items: center; justify-content: center; box-shadow: 0 6px 16px -4px rgba(37,99,235,.35); }
.srv-bcard-icon svg { width: 22px; height: 22px; }
.srv-bcard h3 { font-size: 16px; font-weight: 600; color: var(--text-primary); margin: 4px 0 0; letter-spacing: -.005em; }
.srv-bcard p { font-size: 13px; line-height: 1.55; color: var(--text-muted); margin: 0; flex: 1; }
.srv-bcard-num { position: absolute; top: 18px; right: 20px; font-size: 48px; font-weight: 800; color: rgba(37,99,235,.06); line-height: 1; letter-spacing: -.02em; pointer-events: none; }

/* Types */
.srv-types { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.srv-type { text-align: left; background: rgba(255,255,255,.7); backdrop-filter: blur(16px); border: 1px solid rgba(255,255,255,.9); border-radius: var(--radius-xl); padding: 28px; cursor: pointer; color: var(--text-primary); font-family: inherit; display: flex; flex-direction: column; gap: 14px; position: relative; overflow: hidden; box-shadow: 0 1px 0 rgba(255,255,255,.9) inset, 0 8px 24px -8px rgba(37,99,235,.12); transition: all .35s cubic-bezier(.22,1,.36,1); }
.srv-type:hover { transform: translateY(-6px); border-color: rgba(37,99,235,.4); box-shadow: 0 1px 0 rgba(255,255,255,1) inset, 0 16px 40px -10px rgba(37,99,235,.3), 0 32px 64px -20px rgba(37,99,235,.2); }
.srv-type-glow { position: absolute; top: -30%; right: -30%; width: 80%; height: 120%; background: radial-gradient(circle, rgba(37,99,235,.1), transparent 60%); opacity: 0; transition: opacity .4s; }
.srv-type:hover .srv-type-glow { opacity: 1; }
.srv-type-head { display: flex; justify-content: space-between; align-items: center; }
.srv-type-num { font-size: 13px; font-weight: 600; color: var(--brand-600); font-variant-numeric: tabular-nums; }
.srv-type-tag { font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: .08em; padding: 4px 10px; border-radius: 99px; background: rgba(37,99,235,.07); color: var(--brand-600); border: 1px solid rgba(37,99,235,.15); }
.srv-type h3 { font-size: 22px; font-weight: 700; letter-spacing: -.018em; margin: 0; color: var(--text-primary); }
.srv-type > p { font-size: 13.5px; line-height: 1.55; color: var(--text-muted); margin: 0; min-height: 58px; }
.srv-type-feat { display: flex; flex-direction: column; gap: 6px; padding: 14px 0; border-top: 1px solid var(--border-color); border-bottom: 1px solid var(--border-color); }
.srv-type-feat span { font-size: 13px; color: var(--text-primary); display: flex; gap: 8px; align-items: center; }
.srv-type-feat i { color: var(--brand-600); font-style: normal; font-weight: 700; }
.srv-type-foot { display: flex; align-items: center; gap: 14px; margin-top: auto; }
.srv-type-foot > div { display: flex; flex-direction: column; line-height: 1; }
.srv-type-from { font-size: 11px; color: var(--text-muted); font-weight: 500; }
.srv-type-price { font-size: 26px; font-weight: 700; letter-spacing: -.02em; background: linear-gradient(135deg, var(--brand-600), #8b5cf6); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; margin-top: 2px; }
.srv-type-dur { font-size: 12px; color: var(--text-muted); font-weight: 500; margin-left: auto; }
.srv-type-arrow { width: 32px; height: 32px; border-radius: 50%; background: rgba(37,99,235,.07); color: var(--brand-600); display: flex; align-items: center; justify-content: center; font-size: 14px; transition: all .3s; }
.srv-type:hover .srv-type-arrow { background: var(--brand-600); color: #fff; transform: translateX(4px); }
.srv-type[href] { text-decoration: none; }
.srv-type-cat-icon { width: 52px; height: 52px; border-radius: 14px; background: linear-gradient(135deg, rgba(37,99,235,.1), rgba(139,92,246,.1)); color: var(--brand-600); display: flex; align-items: center; justify-content: center; transition: all .3s; }
.srv-type-cat-icon svg { width: 24px; height: 24px; }
.srv-type:hover .srv-type-cat-icon { background: linear-gradient(135deg, var(--brand-600), #8b5cf6); color: #fff; transform: scale(1.05); }
a.srv-tile-feat { text-decoration: none; color: #fff; }
a.srv-tile-feat:hover { color: #fff; }
a.srv-tile-feat .srv-arrow-btn { display: inline-block; }

/* ========== Hero quick chips (showroom) ========== */
.srv-hero-quick { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 28px; }
.srv-quick-chip {
    display: inline-flex; align-items: center; gap: 10px;
    padding: 12px 18px;
    background: rgba(255,255,255,.92);
    backdrop-filter: blur(14px);
    border: 1.5px solid rgba(226,232,240,.9);
    border-radius: 99px;
    font-size: 13.5px; font-weight: 600;
    color: var(--text-primary);
    text-decoration: none;
    box-shadow: 0 4px 14px -2px rgba(37,99,235,.08);
    transition: all .25s cubic-bezier(.22,1,.36,1);
}
.srv-quick-chip svg { flex-shrink: 0; color: var(--brand-600); }
.srv-quick-chip b { color: var(--brand-600); font-weight: 700; }
.srv-quick-chip:hover { transform: translateY(-2px); border-color: var(--brand-600); box-shadow: 0 8px 24px -4px rgba(37,99,235,.2); color: var(--text-primary); }
.srv-quick-chip--b svg { color: #8b5cf6; }
.srv-quick-chip--b:hover { border-color: #8b5cf6; box-shadow: 0 8px 24px -4px rgba(139,92,246,.25); }

/* ========== Path selector (A vs B) ========== */
.srv-paths { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; }
.srv-path {
    position: relative; overflow: hidden;
    display: flex; flex-direction: column; gap: 16px;
    padding: 36px 32px;
    border-radius: var(--radius-xl);
    text-decoration: none;
    color: var(--text-primary);
    transition: all .4s cubic-bezier(.22,1,.36,1);
    min-height: 460px;
}
.srv-path--ready {
    background: linear-gradient(140deg, #fff 0%, #f0f4ff 100%);
    border: 1.5px solid rgba(37,99,235,.18);
    box-shadow: 0 1px 0 rgba(255,255,255,.9) inset, 0 12px 32px -10px rgba(37,99,235,.18), 0 32px 64px -32px rgba(15,23,42,.12);
}
.srv-path--ready:hover {
    transform: translateY(-6px);
    border-color: rgba(37,99,235,.45);
    box-shadow: 0 1px 0 rgba(255,255,255,1) inset, 0 20px 48px -10px rgba(37,99,235,.3), 0 40px 80px -24px rgba(15,23,42,.18);
}
.srv-path--custom {
    background: linear-gradient(140deg, #1e293b 0%, #0f172a 60%, #1e1b4b 100%);
    border: 1.5px solid rgba(139,92,246,.3);
    color: #fff;
    box-shadow: 0 12px 40px -10px rgba(99,102,241,.35), 0 32px 64px -24px rgba(15,23,42,.4);
}
.srv-path--custom:hover {
    transform: translateY(-6px);
    border-color: rgba(139,92,246,.6);
    box-shadow: 0 20px 56px -10px rgba(99,102,241,.5), 0 40px 80px -20px rgba(15,23,42,.5);
    color: #fff;
}
.srv-path-spot {
    position: absolute; top: -40%; right: -30%;
    width: 70%; height: 160%;
    pointer-events: none;
    transition: opacity .4s;
    opacity: .5;
}
.srv-path--ready .srv-path-spot { background: radial-gradient(circle, rgba(37,99,235,.15), transparent 60%); }
.srv-path--custom .srv-path-spot { background: radial-gradient(circle, rgba(139,92,246,.25), transparent 60%); }
.srv-path:hover .srv-path-spot { opacity: 1; }

.srv-path-head { display: flex; justify-content: space-between; align-items: center; position: relative; z-index: 1; }
.srv-path-letter {
    width: 44px; height: 44px;
    border-radius: 12px;
    display: flex; align-items: center; justify-content: center;
    font-family: var(--font-display);
    font-size: 22px; font-weight: 800;
    letter-spacing: -.02em;
}
.srv-path--ready .srv-path-letter { background: linear-gradient(135deg, var(--brand-600), #6366f1); color: #fff; box-shadow: 0 8px 20px -6px rgba(37,99,235,.45); }
.srv-path--custom .srv-path-letter { background: linear-gradient(135deg, #8b5cf6, var(--color-accent, #22d3ee)); color: #fff; box-shadow: 0 8px 20px -6px rgba(139,92,246,.5); }
.srv-path-tag {
    font-size: 10.5px; font-weight: 700;
    text-transform: uppercase; letter-spacing: .08em;
    padding: 5px 12px; border-radius: 99px;
}
.srv-path--ready .srv-path-tag { background: rgba(37,99,235,.08); color: var(--brand-600); border: 1px solid rgba(37,99,235,.18); }
.srv-path--custom .srv-path-tag { background: rgba(255,255,255,.1); color: #fff; border: 1px solid rgba(255,255,255,.2); }

.srv-path-title {
    font-family: var(--font-display);
    font-size: clamp(26px, 3vw, 36px);
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: -.022em;
    margin: 0;
    position: relative; z-index: 1;
}
.srv-path--ready .srv-path-title { color: var(--text-primary); }
.srv-path--custom .srv-path-title {
    background: linear-gradient(135deg, #fff 0%, #ddd6fe 60%, #22d3ee 100%);
    -webkit-background-clip: text; background-clip: text;
    -webkit-text-fill-color: transparent;
}
.srv-path-lead { font-size: 14.5px; line-height: 1.55; margin: 0; position: relative; z-index: 1; }
.srv-path--ready .srv-path-lead { color: var(--text-muted); }
.srv-path--custom .srv-path-lead { color: rgba(255,255,255,.7); }

.srv-path-pros { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 9px; position: relative; z-index: 1; }
.srv-path-pros li { display: flex; align-items: center; gap: 10px; font-size: 13.5px; font-weight: 500; }
.srv-path-pros svg { flex-shrink: 0; }
.srv-path--ready .srv-path-pros li { color: var(--text-primary); }
.srv-path--ready .srv-path-pros svg { color: var(--brand-600); }
.srv-path--custom .srv-path-pros li { color: rgba(255,255,255,.92); }
.srv-path--custom .srv-path-pros svg { color: var(--color-accent, #22d3ee); }

.srv-path-foot {
    margin-top: auto;
    padding-top: 20px;
    display: flex; justify-content: space-between; align-items: flex-end;
    position: relative; z-index: 1;
}
.srv-path--ready .srv-path-foot { border-top: 1px solid rgba(37,99,235,.15); }
.srv-path--custom .srv-path-foot { border-top: 1px solid rgba(255,255,255,.12); }
.srv-path-foot > div { display: flex; flex-direction: column; line-height: 1; gap: 4px; }
.srv-path-from { font-size: 11px; font-weight: 500; text-transform: uppercase; letter-spacing: .08em; }
.srv-path--ready .srv-path-from { color: var(--text-muted); }
.srv-path--custom .srv-path-from { color: rgba(255,255,255,.55); }
.srv-path-price {
    font-size: 32px; font-weight: 800; letter-spacing: -.02em;
}
.srv-path--ready .srv-path-price { background: linear-gradient(135deg, var(--brand-600), #8b5cf6); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.srv-path--custom .srv-path-price { background: linear-gradient(135deg, #fff, #22d3ee); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.srv-path-cta {
    display: inline-flex; align-items: center;
    padding: 12px 20px;
    border-radius: 99px;
    font-size: 13.5px; font-weight: 700;
    transition: all .3s;
}
.srv-path--ready .srv-path-cta { background: var(--brand-600); color: #fff; box-shadow: 0 6px 16px -4px rgba(37,99,235,.4); }
.srv-path--ready:hover .srv-path-cta { transform: translateX(4px); box-shadow: 0 10px 24px -4px rgba(37,99,235,.5); }
.srv-path--custom .srv-path-cta { background: linear-gradient(135deg, var(--color-accent, #22d3ee), #06b6d4); color: #fff; box-shadow: 0 6px 16px -4px rgba(34,211,238,.4); }
.srv-path--custom:hover .srv-path-cta { transform: translateX(4px); box-shadow: 0 10px 24px -4px rgba(34,211,238,.55); }

/* ========== Divider "OR" ========== */
.srv-divider-or {
    padding: 8px 0 32px;
    position: relative;
}
.srv-divider-or .container { display: flex; align-items: center; gap: 18px; }
.srv-divider-line {
    flex: 1; height: 1px;
    background: linear-gradient(90deg, transparent, rgba(37,99,235,.25), transparent);
}
.srv-divider-word {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--text-muted);
    padding: 8px 18px;
    background: #fff;
    border: 1px solid rgba(226,232,240,.9);
    border-radius: 99px;
    white-space: nowrap;
}

/* Calculator */
.srv-calc { display: grid; grid-template-columns: 1fr 380px; gap: 24px; align-items: start; }
.srv-calc-pane { background: rgba(255,255,255,.75); backdrop-filter: blur(16px); border: 1px solid rgba(255,255,255,.9); border-radius: var(--radius-xl); padding: 32px; box-shadow: 0 1px 0 rgba(255,255,255,.9) inset, 0 12px 32px -8px rgba(37,99,235,.12); }
.srv-calc-section + .srv-calc-section { margin-top: 36px; padding-top: 32px; border-top: 1px solid var(--border-color); }
.srv-calc-h { display: flex; align-items: center; gap: 12px; font-size: 18px; font-weight: 700; letter-spacing: -.01em; color: var(--text-primary); margin: 0 0 20px; }
.srv-calc-step { width: 28px; height: 28px; border-radius: 50%; background: linear-gradient(135deg, var(--brand-600), #8b5cf6); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 700; }

.srv-base-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.srv-base-btn { text-align: left; background: #fff; border: 1.5px solid var(--border-color); border-radius: 14px; padding: 14px 16px; cursor: pointer; display: flex; flex-direction: column; gap: 4px; font-family: inherit; color: var(--text-primary); transition: all .2s; }
.srv-base-btn:hover { border-color: rgba(37,99,235,.4); transform: translateY(-1px); }
.srv-base-btn.is-on { border-color: var(--brand-600); background: linear-gradient(135deg, rgba(37,99,235,.04), rgba(139,92,246,.04)); box-shadow: 0 0 0 3px rgba(37,99,235,.09); }
.srv-base-label { font-size: 13.5px; font-weight: 600; }
.srv-base-meta { font-size: 12px; color: var(--text-muted); }
.srv-base-meta b { color: var(--brand-600); font-weight: 700; }

.srv-addon-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.srv-addon-btn { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 10px; background: #fff; border: 1.5px solid var(--border-color); border-radius: 14px; padding: 12px 14px; cursor: pointer; font-family: inherit; color: var(--text-primary); transition: all .2s; text-align: left; }
.srv-addon-btn:hover { border-color: rgba(37,99,235,.4); }
.srv-addon-btn.is-on { border-color: var(--brand-600); background: linear-gradient(135deg, rgba(37,99,235,.06), rgba(139,92,246,.06)); }
.srv-addon-tick { width: 22px; height: 22px; border-radius: 50%; background: var(--border-color); color: var(--text-muted); display: flex; align-items: center; justify-content: center; font-size: 15px; font-weight: 300; transition: all .2s; line-height: 1; }
.srv-addon-btn.is-on .srv-addon-tick { background: linear-gradient(135deg, var(--brand-600), #8b5cf6); color: #fff; }
.srv-addon-btn.is-on .srv-addon-tick::before { content: '−'; }
.srv-addon-btn.is-on .srv-addon-tick { font-size: 0; }
.srv-addon-btn.is-on .srv-addon-tick::before { font-size: 15px; }
.srv-addon-label { font-size: 12.5px; font-weight: 500; line-height: 1.3; }
.srv-addon-price { font-size: 12px; font-weight: 700; color: var(--brand-600); font-variant-numeric: tabular-nums; }

.srv-calc-out { position: sticky; top: 88px; align-self: start; background: linear-gradient(135deg, var(--text-primary), #1e293b); color: #fff; border-radius: var(--radius-xl); padding: 32px; overflow: hidden; box-shadow: 0 24px 60px -20px rgba(37,99,235,.4); }
.srv-out-bg { position: absolute; top: -30%; right: -30%; width: 120%; height: 120%; background: radial-gradient(circle, rgba(37,99,235,.4), transparent 60%); pointer-events: none; }
.srv-out-eye { color: var(--color-accent); border-color: rgba(34,211,238,.2); position: relative; }
.srv-out-num { display: flex; align-items: flex-start; gap: 6px; margin: 14px 0 24px; position: relative; }
.srv-out-curr { font-size: 32px; color: var(--color-accent); font-weight: 600; margin-top: 14px; }
.srv-out-val { font-size: 72px; font-weight: 800; letter-spacing: -.03em; line-height: 1; background: linear-gradient(135deg, #fff, var(--brand-300)); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; font-variant-numeric: tabular-nums; }
.srv-out-meta { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; padding: 16px 0; border-top: 1px solid rgba(255,255,255,.1); border-bottom: 1px solid rgba(255,255,255,.1); position: relative; }
.srv-out-meta div { display: flex; flex-direction: column; gap: 4px; }
.srv-out-meta span { font-size: 11px; color: rgba(255,255,255,.55); text-transform: uppercase; letter-spacing: .06em; font-weight: 600; }
.srv-out-meta b { font-size: 17px; font-weight: 700; }
.srv-out-incl { display: flex; flex-direction: column; gap: 8px; padding: 16px 0 20px; position: relative; }
.srv-out-incl div { display: flex; align-items: center; gap: 8px; font-size: 13px; color: rgba(255,255,255,.85); }
.srv-out-incl svg { color: var(--color-accent); flex-shrink: 0; }
.srv-calc-out .srv-btn { position: relative; }
.srv-out-fp { font-size: 11px; color: rgba(255,255,255,.45); text-align: center; margin: 14px 0 0; position: relative; }

/* Timeline */
/* ===== Timeline · Sine Wave (animat la viewport) ===== */
.srv-tl { position: relative; display: grid; grid-template-columns: repeat(5, 1fr); gap: 18px; padding-top: 72px; }
.srv-tl-rail { display: none; }
.srv-tl-svg { position: absolute; left: 0; right: 0; top: 0; width: 100%; pointer-events: none; z-index: 0; overflow: visible; }
.srv-tl-svg .seg { fill: none; stroke-width: 2; stroke-linecap: round; }
.srv-tl-svg .seg-bg { stroke: rgba(226,232,240,.65); stroke-dasharray: 4 6; }
.srv-tl-svg .seg.draw { stroke: url(#srv-tl-linegrad); }
.srv-tl-svg .traveler { fill: #fff; stroke: url(#srv-tl-linegrad); stroke-width: 2; filter: drop-shadow(0 0 8px rgba(34,211,238,.7)) drop-shadow(0 0 16px rgba(37,99,235,.5)); opacity: 0; }
.srv-tl-svg .traveler.lit { opacity: 1; }
.srv-tl-item { position: relative; display: flex; flex-direction: column; align-items: center; gap: 22px; z-index: 1; }
.srv-tl-pin { width: 60px; height: 60px; border-radius: 50%; background: #fff; border: 3px solid transparent; background-image: linear-gradient(#fff, #fff), linear-gradient(135deg, var(--brand-600), #8b5cf6); background-origin: border-box; background-clip: padding-box, border-box; display: flex; align-items: center; justify-content: center; position: relative; box-shadow: 0 8px 24px -6px rgba(37,99,235,.35); }
.srv-tl-pin::after { content: ''; position: absolute; inset: -6px; border-radius: 50%; border: 1.5px dashed rgba(37,99,235,.35); opacity: 0; transform: scale(.9); transition: opacity .4s, transform .4s; }
.srv-tl-item.lit .srv-tl-pin::after { opacity: 1; transform: scale(1); animation: srv-tl-rim 14s linear infinite; }
@keyframes srv-tl-rim { to { transform: rotate(360deg); } }
.srv-tl-item .srv-tl-pin, .srv-tl-item .srv-tl-card { opacity: 0; }
.srv-tl-item .srv-tl-pin { transform: scale(.55); }
.srv-tl-item .srv-tl-card { transform: translateY(14px); }
.srv-tl-item.lit .srv-tl-pin { animation: srv-tl-pinIn .55s cubic-bezier(.34,1.56,.64,1) forwards; }
.srv-tl-item.lit .srv-tl-card { animation: srv-tl-cardIn .55s .12s cubic-bezier(.22,1,.36,1) forwards; }
@keyframes srv-tl-pinIn { 0% { opacity: 0; transform: scale(.55); } 60% { transform: scale(1.12); } 100% { opacity: 1; transform: scale(1); } }
@keyframes srv-tl-cardIn { to { opacity: 1; transform: translateY(0); } }
.srv-tl-pin span { font-size: 14px; font-weight: 700; background: linear-gradient(135deg, var(--brand-600), #8b5cf6); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; letter-spacing: -.01em; font-family: ui-monospace, "JetBrains Mono", Consolas, monospace; }
.srv-tl-card { background: rgba(255,255,255,.92); backdrop-filter: blur(10px); border: 1px solid rgba(226,232,240,.9); border-radius: 14px; padding: 16px; flex: 1; width: 100%; display: flex; flex-direction: column; gap: 6px; box-shadow: 0 1px 0 rgba(255,255,255,.9) inset, 0 10px 22px -12px rgba(37,99,235,.18); transition: all .3s; }
.srv-tl-card:hover { transform: translateY(-4px); border-color: rgba(37,99,235,.35); box-shadow: 0 1px 0 rgba(255,255,255,1) inset, 0 16px 40px -12px rgba(37,99,235,.25); }
.srv-tl-dur { font-size: 10px; font-weight: 700; color: var(--brand-600); text-transform: uppercase; letter-spacing: .08em; padding: 3px 8px; background: rgba(37,99,235,.07); border-radius: 99px; width: fit-content; font-family: ui-monospace, "JetBrains Mono", Consolas, monospace; }
.srv-tl-card h3 { font-size: 14.5px; font-weight: 700; letter-spacing: -.015em; color: var(--text-primary); margin: 4px 0 0; }
.srv-tl-card p { font-size: 12.5px; line-height: 1.5; color: var(--text-muted); margin: 0; flex: 1; }
.srv-tl-kpi { display: flex; align-items: center; gap: 6px; font-size: 11px; font-weight: 600; color: var(--brand-600); padding-top: 8px; border-top: 1px dashed var(--border-color); }
@media (prefers-reduced-motion: reduce){ .srv-tl *, .srv-tl *::before, .srv-tl *::after { animation-duration: .01s !important; transition-duration: .01s !important; } }

/* FAQ */
.srv-faq { background: rgba(255,255,255,.7); backdrop-filter: blur(14px); border: 1px solid rgba(255,255,255,.9); border-radius: var(--radius-xl); overflow: hidden; box-shadow: 0 1px 0 rgba(255,255,255,.9) inset, 0 12px 32px -8px rgba(37,99,235,.12); }
.srv-faq-row { border-bottom: 1px solid var(--border-color); }
.srv-faq-row:last-child { border-bottom: 0; }
.srv-faq-row.is-open { background: linear-gradient(135deg, rgba(37,99,235,.03), rgba(139,92,246,.03)); }
.srv-faq-q { display: grid; grid-template-columns: 48px 1fr 36px; align-items: center; gap: 16px; width: 100%; padding: 22px 28px; background: none; border: 0; cursor: pointer; text-align: left; font-family: inherit; color: var(--text-primary); transition: padding .25s; }
.srv-faq-q:hover { padding-left: 36px; }
.srv-faq-n { font-size: 13px; font-weight: 700; color: var(--brand-600); font-variant-numeric: tabular-nums; }
.srv-faq-qt { font-size: 17px; font-weight: 600; letter-spacing: -.01em; }
.srv-faq-tog { width: 32px; height: 32px; border-radius: 50%; background: rgba(226,232,240,.5); color: var(--brand-600); display: flex; align-items: center; justify-content: center; transition: transform .3s, background .3s; }
.srv-faq-tog svg { width: 16px; height: 16px; }
.srv-faq-row.is-open .srv-faq-tog { background: var(--brand-600); color: #fff; transform: rotate(180deg); }
.srv-faq-a { max-height: 0; overflow: hidden; transition: max-height .35s ease; }
.srv-faq-row.is-open .srv-faq-a { max-height: 320px; }
.srv-faq-a p { font-size: 14.5px; line-height: 1.65; color: var(--text-secondary); padding: 0 28px 24px 92px; margin: 0; }

/* CTA band */
.srv-cta-band { padding: 64px 0; position: relative; overflow: hidden; background: linear-gradient(135deg, var(--text-primary) 0%, #1e293b 50%, rgba(37,99,235,.2) 100%); color: #fff; text-align: center; }
.srv-cta-blob { position: absolute; border-radius: 50%; filter: blur(80px); pointer-events: none; }
.srv-cta-b1 { top: -30%; left: 10%; width: 50%; height: 80%; background: rgba(37,99,235,.47); }
.srv-cta-b2 { bottom: -30%; right: 10%; width: 40%; height: 60%; background: rgba(139,92,246,.33); }
.srv-cta-inner { position: relative; z-index: 1; max-width: 780px; text-align: center; }
.srv-cta-inner .srv-pill { margin: 0 auto; }
.srv-cta-h { font-family: var(--font-display); font-weight: 800; font-size: clamp(28px, 3.6vw, 48px); line-height: 1.08; letter-spacing: -.022em; margin: 18px 0 14px; color: #fff; }
.srv-cta-band p { font-size: 16px; color: rgba(255,255,255,.7); margin: 0 auto 24px; max-width: 540px; }
.srv-cta-row { display: flex; gap: 12px; justify-content: center; margin-bottom: 64px; flex-wrap: wrap; }
.srv-cta-meta { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; margin-top: 36px; padding-top: 28px; border-top: 1px solid rgba(255,255,255,.15); text-align: left; }
.srv-cta-meta div { display: flex; flex-direction: column; gap: 4px; }
.srv-cta-meta b { font-size: 17px; font-weight: 700; color: #fff; }
.srv-cta-meta span { font-size: 12px; color: rgba(255,255,255,.55); text-transform: uppercase; letter-spacing: .08em; }

/* Drawer */
.srv-scrim { position: fixed; inset: 0; background: rgba(15,23,42,.5); backdrop-filter: blur(6px); opacity: 0; pointer-events: none; transition: opacity .3s; z-index: 200; }
.srv-scrim.is-on { opacity: 1; pointer-events: auto; }
.srv-drawer { position: fixed; top: 0; right: 0; bottom: 0; width: 540px; max-width: 90vw; background: linear-gradient(180deg, #fff, var(--bg-surface)); border-left: 1px solid var(--border-color); transform: translateX(100%); transition: transform .4s cubic-bezier(.22,1,.36,1); z-index: 201; overflow-y: auto; box-shadow: -24px 0 60px rgba(15,23,42,.15); }
.srv-drawer.is-on { transform: translateX(0); }
.srv-drawer-content { padding: 56px 40px; position: relative; }
.srv-d-x { position: fixed; top: 20px; right: 20px; width: 36px; height: 36px; border-radius: 50%; background: var(--bg-surface); border: 1px solid var(--border-color); color: var(--text-primary); cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all .2s; z-index: 202; opacity: 0; pointer-events: none; }
.srv-drawer.is-on ~ .srv-d-x, .srv-drawer.is-on .srv-d-x { opacity: 1; pointer-events: auto; }
.srv-d-x:hover { background: var(--brand-600); color: #fff; border-color: var(--brand-600); }
.srv-d-x svg { width: 16px; height: 16px; }
.srv-d-h { font-family: var(--font-display); font-size: 36px; font-weight: 800; line-height: 1.08; letter-spacing: -.02em; margin: 12px 0 12px; color: var(--text-primary); }
.srv-d-desc { font-size: 15px; line-height: 1.65; color: var(--text-secondary); margin: 0 0 24px; }
.srv-d-meta { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; padding: 18px; background: rgba(255,255,255,.7); backdrop-filter: blur(8px); border: 1px solid var(--border-color); border-radius: 14px; margin-bottom: 28px; }
.srv-d-meta div { display: flex; flex-direction: column; gap: 4px; }
.srv-d-meta span { font-size: 11px; color: var(--text-muted); text-transform: uppercase; letter-spacing: .06em; font-weight: 600; }
.srv-d-meta b { font-size: 18px; font-weight: 700; color: var(--text-primary); }
.srv-d-sec { margin-bottom: 24px; }
.srv-d-sec h4 { font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--brand-600); margin: 0 0 12px; }
.srv-d-sec ul { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: 1fr 1fr; gap: 8px 14px; }
.srv-d-sec li { font-size: 14px; color: var(--text-primary); display: flex; gap: 8px; align-items: center; }
.srv-d-sec p { font-size: 14.5px; line-height: 1.6; color: var(--text-secondary); margin: 0; }

/* Scroll reveal */
[data-animate] { opacity: 0; transform: translateY(24px); transition: opacity .7s ease, transform .7s cubic-bezier(.22,1,.36,1); }
[data-animate].srv-in { opacity: 1; transform: translateY(0); }

/* Responsive */
@media (max-width: 1024px) {
    .srv-bento { grid-template-columns: repeat(2, 1fr); }
    .srv-tile-feat { grid-column: span 2; grid-row: auto; }
    .srv-tile-cta { grid-column: span 2; }
    .srv-benefits { grid-template-columns: repeat(2, 1fr); }
    .srv-types { grid-template-columns: repeat(2, 1fr); }
    .srv-paths { grid-template-columns: 1fr; }
    .srv-path { min-height: auto; padding: 28px 24px; }
    .srv-calc { grid-template-columns: 1fr; }
    .srv-calc-out { position: static; }
    .srv-base-grid, .srv-addon-grid { grid-template-columns: repeat(2, 1fr); }
    .srv-tl { grid-template-columns: 1fr; }
    .srv-tl-rail { display: none; }
    .srv-tl-item { flex-direction: row; align-items: flex-start; gap: 18px; }
    .srv-cta-meta { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
    .srv-hero, .srv-section { padding: 40px 0; }
    .srv-bento, .srv-benefits, .srv-types, .srv-paths { grid-template-columns: 1fr; }
    .srv-hero-quick { flex-direction: column; }
    .srv-quick-chip { width: 100%; justify-content: center; }
    .srv-tile-feat { grid-column: auto; padding: 28px; }
    .srv-tile-cta { flex-direction: column; align-items: flex-start; }
    .srv-base-grid, .srv-addon-grid { grid-template-columns: 1fr; }
    .srv-faq-q { padding: 18px 20px; grid-template-columns: 36px 1fr 32px; gap: 12px; }
    .srv-faq-a p { padding-left: 68px; padding-right: 20px; }
    .srv-cta-meta { grid-template-columns: 1fr; }
    .srv-drawer { width: 100vw; }
    .srv-drawer-content { padding: 56px 24px; }
    .srv-d-h { font-size: 28px; }
    .srv-d-meta { grid-template-columns: 1fr; }
    .srv-d-sec ul { grid-template-columns: 1fr; }
}

/* ============================================================
   PRODUCTS PAGE — Aurora Pro extension
   ============================================================ */

/* Hero search pill (top-right floating) */
.srv-search-pill { position: absolute; top: 24px; right: 24px; z-index: 10; display: flex; align-items: center; height: 44px; width: 44px; background: rgba(255,255,255,.92); backdrop-filter: blur(14px); border: 1.5px solid rgba(226,232,240,.9); border-radius: 99px; box-shadow: 0 4px 16px -4px rgba(37,99,235,.15); transition: width .35s cubic-bezier(.4,0,.2,1), border-color .2s, box-shadow .2s; overflow: hidden; }
.srv-search-pill.is-open { width: 340px; border-color: var(--brand-600); box-shadow: 0 0 0 4px rgba(37,99,235,.1), 0 8px 24px -4px rgba(37,99,235,.25); }
.srv-search-toggle { flex-shrink: 0; width: 42px; height: 42px; border: 0; background: transparent; color: var(--text-muted); cursor: pointer; display: flex; align-items: center; justify-content: center; transition: color .15s; padding: 0; }
.srv-search-toggle:hover, .srv-search-pill.is-open .srv-search-toggle { color: var(--brand-600); }
.srv-search-pill input { flex: 1; border: 0; background: transparent; outline: none; padding: 0 6px; font-size: 14px; color: var(--text-primary); font-family: inherit; min-width: 0; width: 0; }
.srv-search-pill.is-open input { width: 100%; }
.srv-search-submit { flex-shrink: 0; width: 36px; height: 36px; border: 0; border-radius: 50%; background: linear-gradient(135deg, var(--brand-600), #8b5cf6); color: #fff; cursor: pointer; margin-right: 4px; display: none; align-items: center; justify-content: center; }
.srv-search-pill.is-open .srv-search-submit { display: flex; }

/* Categories — segmented bar (modern, compact) */
.srv-cat-wrap { margin: 36px 0 40px; position: relative; }
.srv-cat-bar { display: flex; gap: 6px; padding: 6px; background: rgba(255,255,255,.7); backdrop-filter: blur(16px) saturate(1.2); border: 1px solid rgba(255,255,255,.9); border-radius: 99px; box-shadow: 0 1px 0 rgba(255,255,255,.9) inset, 0 8px 24px -8px rgba(37,99,235,.18); overflow-x: auto; scrollbar-width: none; -ms-overflow-style: none; scroll-snap-type: x mandatory; }
.srv-cat-bar::-webkit-scrollbar { display: none; }

.srv-cat-pill { display: inline-flex; align-items: center; gap: 8px; padding: 8px 14px; border: 0; border-radius: 99px; font-size: 13px; font-weight: 600; color: var(--text-secondary); text-decoration: none; background: transparent; cursor: pointer; transition: all .25s cubic-bezier(.22,1,.36,1); white-space: nowrap; flex-shrink: 0; scroll-snap-align: start; position: relative; }
.srv-cat-pill:hover { color: var(--brand-600); background: rgba(37,99,235,.06); }
.srv-cat-pill.is-active { background: linear-gradient(135deg, var(--brand-600), #8b5cf6); color: #fff; box-shadow: 0 6px 18px -4px rgba(37,99,235,.45), 0 1px 2px rgba(15,23,42,.06); }

.srv-cat-pill-icon { display: inline-flex; align-items: center; justify-content: center; width: 22px; height: 22px; border-radius: 7px; background: rgba(37,99,235,.08); color: var(--brand-600); flex-shrink: 0; transition: all .25s; }
.srv-cat-pill-icon svg { width: 13px; height: 13px; }
.srv-cat-pill:hover .srv-cat-pill-icon { background: rgba(37,99,235,.14); }
.srv-cat-pill.is-active .srv-cat-pill-icon { background: rgba(255,255,255,.22); color: #fff; }

.srv-cat-pill-count { display: inline-flex; align-items: center; justify-content: center; min-width: 18px; height: 18px; padding: 0 5px; background: rgba(148,163,184,.18); color: var(--text-muted); border-radius: 99px; font-size: 10.5px; font-weight: 700; line-height: 1; transition: all .25s; }
.srv-cat-pill:hover .srv-cat-pill-count { background: rgba(37,99,235,.14); color: var(--brand-600); }
.srv-cat-pill.is-active .srv-cat-pill-count { background: rgba(255,255,255,.25); color: #fff; }

/* Toolbar (count + sort) */
.srv-px-toolbar { display: flex; justify-content: space-between; align-items: center; margin-bottom: 28px; gap: 16px; flex-wrap: wrap; }
.srv-px-count { display: inline-flex; align-items: center; gap: 10px; font-size: 13px; color: var(--text-muted); font-weight: 500; }
.srv-px-count strong { color: var(--text-primary); font-weight: 700; }
.srv-px-count-dot { width: 8px; height: 8px; background: #22c55e; border-radius: 50%; box-shadow: 0 0 0 3px rgba(34,197,94,.18); animation: srvPulse 2.4s ease-in-out infinite; }

.srv-sort { position: relative; }
.srv-sort-btn { display: inline-flex; align-items: center; gap: 8px; padding: 10px 16px; background: rgba(255,255,255,.85); backdrop-filter: blur(10px); border: 1.5px solid var(--border-color); border-radius: 99px; font-size: 13px; font-weight: 600; color: var(--text-primary); cursor: pointer; font-family: inherit; transition: all .2s; }
.srv-sort-btn:hover { border-color: rgba(37,99,235,.4); }
.srv-sort-btn svg { width: 14px; height: 14px; }
.srv-sort-menu { position: absolute; top: calc(100% + 8px); right: 0; min-width: 220px; background: #fff; border: 1px solid var(--border-color); border-radius: 14px; box-shadow: 0 16px 40px -8px rgba(15,23,42,.18); padding: 6px; opacity: 0; visibility: hidden; transform: translateY(-6px); transition: all .2s; z-index: 50; }
.srv-sort.is-open .srv-sort-menu { opacity: 1; visibility: visible; transform: translateY(0); }
.srv-sort-item { display: flex; align-items: center; gap: 10px; padding: 10px 14px; border-radius: 10px; font-size: 13px; font-weight: 500; color: var(--text-primary); text-decoration: none; transition: background .15s; }
.srv-sort-item:hover { background: rgba(37,99,235,.06); color: var(--brand-600); }
.srv-sort-item.is-active { background: linear-gradient(135deg, rgba(37,99,235,.08), rgba(139,92,246,.08)); color: var(--brand-600); }
.srv-sort-btn > svg:not(.srv-sort-chev) { width: 14px; height: 14px; flex-shrink: 0; }
.srv-sort-item > svg { width: 14px; height: 14px; flex-shrink: 0; }

/* Product grid + cards */
.srv-px-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
@media (max-width: 1100px) { .srv-px-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 800px)  { .srv-px-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px)  { .srv-px-grid { grid-template-columns: 1fr; } }

.srv-pcard { position: relative; background: rgba(255,255,255,.7); backdrop-filter: blur(14px); border: 1px solid rgba(255,255,255,.9); border-radius: var(--radius-xl); overflow: hidden; box-shadow: 0 1px 0 rgba(255,255,255,.9) inset, 0 8px 24px -10px rgba(37,99,235,.15); transition: all .35s cubic-bezier(.22,1,.36,1); }
.srv-pcard:hover { transform: translateY(-6px); border-color: rgba(37,99,235,.4); box-shadow: 0 1px 0 rgba(255,255,255,1) inset, 0 16px 40px -10px rgba(37,99,235,.3), 0 32px 64px -20px rgba(37,99,235,.2); }
.srv-pcard a { color: inherit; text-decoration: none; display: block; }
.srv-pcard-img { position: relative; aspect-ratio: 16 / 11; overflow: hidden; background: linear-gradient(135deg, var(--brand-600), #8b5cf6); display: flex; align-items: center; justify-content: center; color: #fff; }
.srv-pcard-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .55s cubic-bezier(.22,1,.36,1); }
.srv-pcard:hover .srv-pcard-img img { transform: scale(1.05); }
.srv-pcard-ph { display: flex; flex-direction: column; align-items: center; gap: 12px; opacity: .92; padding: 24px; text-align: center; }
.srv-pcard-ph svg { width: 42px; height: 42px; opacity: .85; }
.srv-pcard-ph-text { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .12em; color: rgba(255,255,255,.92); }
.srv-pcard-badge { position: absolute; top: 14px; left: 14px; padding: 5px 11px; font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; border-radius: 6px; background: var(--brand-600); color: #fff; box-shadow: 0 4px 12px rgba(37,99,235,.4); z-index: 2; }
.srv-pcard-badge--sale { background: linear-gradient(135deg, #ef4444, #f59e0b); box-shadow: 0 4px 12px rgba(239,68,68,.4); }
.srv-pcard-badge--popular { background: linear-gradient(135deg, #f59e0b, #ef4444); box-shadow: 0 4px 12px rgba(245,158,11,.4); }
.srv-pcard-overlay { position: absolute; inset: 0; background: linear-gradient(180deg, transparent 50%, rgba(15,23,42,.85) 100%); display: flex; align-items: flex-end; justify-content: space-between; padding: 16px; gap: 8px; opacity: 0; transition: opacity .3s; }
.srv-pcard:hover .srv-pcard-overlay { opacity: 1; }
.srv-pcard-cta { color: #fff; font-size: 13px; font-weight: 700; }
.srv-pcard-demo { padding: 8px 14px; background: #fff; color: var(--brand-600); border: 0; border-radius: 99px; font-size: 12px; font-weight: 700; cursor: pointer; font-family: inherit; transition: all .2s; }
.srv-pcard-demo:hover { transform: translateY(-1px); box-shadow: 0 4px 12px rgba(0,0,0,.2); }

.srv-pcard-body { padding: 18px 18px 16px; }
.srv-pcard-cat { display: inline-block; font-size: 10.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--brand-600); margin-bottom: 8px; }
.srv-pcard-title { font-size: 16px; font-weight: 700; letter-spacing: -.01em; color: var(--text-primary); margin: 0 0 6px; line-height: 1.25; display: -webkit-box; -webkit-line-clamp: 1; -webkit-box-orient: vertical; overflow: hidden; }
.srv-pcard-desc { font-size: 12.5px; line-height: 1.5; color: var(--text-muted); margin: 0 0 12px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; min-height: 36px; }
.srv-pcard-tech { display: flex; flex-wrap: wrap; gap: 5px; margin-bottom: 14px; min-height: 22px; }
.srv-pcard-tag { font-size: 10.5px; font-weight: 600; padding: 3px 8px; border-radius: 5px; background: rgba(37,99,235,.07); color: var(--brand-600); border: 1px solid rgba(37,99,235,.14); }
.srv-pcard-tag--more { background: rgba(148,163,184,.1); color: var(--text-muted); border-color: rgba(148,163,184,.2); }
.srv-pcard-foot { display: flex; justify-content: space-between; align-items: center; padding-top: 14px; border-top: 1px solid var(--border-color); gap: 10px; }
.srv-pcard-price { display: flex; flex-direction: column; line-height: 1.1; gap: 2px; }
.srv-pcard-price-old { font-size: 11px; color: var(--text-muted); text-decoration: line-through; }
.srv-pcard-price-cur { font-size: 17px; font-weight: 700; background: linear-gradient(135deg, var(--brand-600), #8b5cf6); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; letter-spacing: -.01em; font-variant-numeric: tabular-nums; }
.srv-pcard-arrow { width: 32px; height: 32px; border-radius: 50%; background: rgba(37,99,235,.07); color: var(--brand-600); display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: all .25s; }
.srv-pcard-arrow svg { width: 14px; height: 14px; }
.srv-pcard:hover .srv-pcard-arrow { background: var(--brand-600); color: #fff; transform: translateX(3px); }

/* Empty state */
.srv-px-empty { padding: 60px 24px; text-align: center; max-width: 480px; margin: 0 auto; background: rgba(255,255,255,.7); backdrop-filter: blur(12px); border: 1px dashed rgba(37,99,235,.3); border-radius: var(--radius-xl); }
.srv-px-empty-icon { width: 72px; height: 72px; border-radius: 50%; background: linear-gradient(135deg, rgba(37,99,235,.08), rgba(139,92,246,.08)); color: var(--brand-600); display: flex; align-items: center; justify-content: center; margin: 0 auto 18px; }
.srv-px-empty h2 { font-size: 19px; font-weight: 700; color: var(--text-primary); margin: 0 0 8px; }
.srv-px-empty p { font-size: 13.5px; color: var(--text-muted); line-height: 1.55; margin: 0 0 18px; }

/* Responsive search position */
@media (max-width: 640px) {
    .srv-search-pill { top: 16px; right: 16px; }
    .srv-search-pill.is-open { width: calc(100vw - 32px); max-width: 320px; }
    .srv-cat-bar { gap: 8px; }
    .srv-cat-pill { padding: 8px 14px; font-size: 12.5px; }
}
