/**
 * OB Lens Configurator v20.1 — Frontend CSS
 * All visual values use CSS custom properties (--ob-*) set by JS from admin settings.
 * v20.0: ENTERPRISE POLISH — directional step transitions, loading states,
 *   refined trust strip, subtle WhatsApp pulse, stepper 320px fix,
 *   pricing row hierarchy, intercept polish, modern upload zone,
 *   safe-area toast, restore bar hierarchy, global footer refined,
 *   unified transition easing, consistent border weights, touch targets 44px min.
 * Fallback values match the default settings.
 */

/* ═══ CSS VARIABLES (injected by JS, fallbacks here) ═══ */
:root {
  --ob-primary: #014E3F;
  --ob-primary-hover: #013D31;
  --ob-accent: #22c55e;
  --ob-error: #ef4444;
  --ob-text: #1a1a1a;
  --ob-text-sec: #6b7280;
  --ob-text-muted: #9ca3af;
  --ob-bg: #ffffff;
  --ob-bg-sec: #f9fafb;
  --ob-border: #e5e7eb;
  --ob-border-lt: #f3f4f6;
  --ob-card-r: 12px;
  --ob-btn-r: 10px;
  --ob-font: 'Roboto', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
  --ob-font-heading: 'Poppins', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
  --ob-heading-size: 22px;
  --ob-body-size: 14px;
  --ob-card-pad: 16px;
  --ob-card-gap: 10px;
  --ob-tag-bg: rgba(1,78,63,0.08);
  --ob-tag-color: #014E3F;
  --ob-add-bg: #5b6abf;
  --ob-add-color: #ffffff;
  --ob-info-bg: #eef6ff;
  --ob-left-w: 45%;
  --ob-anim: 220ms;
  --ob-ease: cubic-bezier(.4,0,.2,1);
}

/* ═══ RESET ═══ */
.ob-modal *,.ob-modal *::before,.ob-modal *::after,
.ob-intercept *,.ob-intercept *::before,.ob-intercept *::after{box-sizing:border-box;margin:0;padding:0;}
body.ob-open{overflow:hidden!important;}

/* ═══ FULL-SCREEN MODAL ═══ */
.ob-modal{position:fixed;inset:0;z-index:100000;font-family:var(--ob-font);font-size:var(--ob-body-size);line-height:1.5;color:var(--ob-text);-webkit-font-smoothing:antialiased;display:flex;flex-direction:column;}
.ob-page{display:flex;flex:1;min-height:0;background:var(--ob-bg);}

.ob-modal--centered{background:rgba(0,0,0,.5);align-items:center;justify-content:center;}
.ob-modal--centered .ob-page{max-width:1100px;max-height:90vh;border-radius:16px;overflow:hidden;box-shadow:0 25px 50px rgba(0,0,0,.25);}
.ob-modal--centered .ob-gf{border-radius:0 0 16px 16px;}

.ob-modal--slide-right{background:rgba(0,0,0,.4);}
.ob-modal--slide-right .ob-page{margin-left:auto;max-width:560px;width:100%;animation:ob-slide-in var(--ob-anim) var(--ob-ease);}
@keyframes ob-slide-in{from{transform:translateX(100%)}to{transform:translateX(0)}}

/* ═══ LEFT PANEL ═══ */
.ob-left{width:var(--ob-left-w);flex-shrink:0;display:flex;flex-direction:column;background:linear-gradient(180deg,var(--ob-bg) 0%,var(--ob-bg-sec) 100%);border-right:1px solid var(--ob-border);position:relative;contain:content;}
.ob-left-top{padding:20px 28px 0;}
.ob-modal .ob-back-frame,.ob-back-frame{display:inline-flex!important;align-items:center!important;gap:6px!important;background:#1a1a1a!important;border:none!important;cursor:pointer!important;font-family:var(--ob-font-heading)!important;font-size:13px!important;font-weight:600!important;color:#fff!important;padding:10px 22px!important;border-radius:50px!important;line-height:1!important;transition:all .18s var(--ob-ease)!important;box-shadow:0 1px 3px rgba(0,0,0,.08)!important;text-decoration:none!important;text-transform:none!important;letter-spacing:0!important;white-space:nowrap!important;}
.ob-modal .ob-back-frame:hover,.ob-back-frame:hover{background:#333!important;color:#fff!important;transform:translateY(-1px)!important;box-shadow:0 4px 14px rgba(0,0,0,.15)!important;}
.ob-modal .ob-back-frame:active,.ob-back-frame:active{transform:translateY(0)!important;box-shadow:0 1px 3px rgba(0,0,0,.08)!important;}
.ob-back-frame svg{flex-shrink:0;transition:transform .18s var(--ob-ease);}
.ob-back-frame:hover svg{transform:translateX(-2px);}
.ob-left-brand{text-align:center;padding:14px 28px 0;font-size:10px;font-weight:600;letter-spacing:2.5px;color:var(--ob-text-muted);opacity:.5;}
.ob-left-body{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:16px 32px 32px;overflow-y:auto;scroll-behavior:smooth;}
.ob-left-body::-webkit-scrollbar{width:3px;}
.ob-left-body::-webkit-scrollbar-track{background:transparent;}
.ob-left-body::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px;}

.ob-l-img{width:100%;max-width:420px;margin:0 auto 20px;display:flex;align-items:center;justify-content:center;}
.ob-l-img img{max-width:100%;max-height:200px;object-fit:contain;display:block;transition:transform .35s var(--ob-ease);}
.ob-l-img:hover img.ob-img-loaded{transform:scale(1.02);}
.ob-l-name{font-family:var(--ob-font-heading);font-size:16px;font-weight:600;color:var(--ob-text);text-align:center;margin-bottom:3px;letter-spacing:-.01em;}
.ob-l-variant{font-size:13px;color:var(--ob-text-sec);text-align:center;margin-bottom:12px;letter-spacing:.01em;}
.ob-l-badge{display:inline-flex;align-items:center;gap:8px;font-size:12px;color:var(--ob-text-sec);margin-bottom:20px;max-width:100%;word-break:break-word;text-align:center;}
.ob-l-badge-dot{width:7px;height:7px;border-radius:50%;background:var(--ob-accent);display:inline-block;flex-shrink:0;}
.ob-l-divider{width:80%;max-width:380px;height:1px;background:var(--ob-border);margin:0 auto 16px;opacity:.7;}
.ob-l-sub{display:flex;justify-content:space-between;align-items:center;width:80%;max-width:380px;margin:0 auto 6px;}
.ob-l-sub-label{font-family:var(--ob-font-heading);font-size:14px;font-weight:600;color:var(--ob-text);}
.ob-l-sub-val{font-family:var(--ob-font-heading);font-size:18px;font-weight:700;color:var(--ob-text);letter-spacing:-.02em;}
.ob-l-lines{width:80%;max-width:380px;margin:8px auto 0;display:flex;flex-direction:column;gap:2px;}
.ob-l-line{display:flex;justify-content:space-between;align-items:flex-start;padding:7px 12px;font-size:12px;color:var(--ob-text-sec);border-radius:8px;transition:background .15s;}
.ob-l-line:nth-child(odd){background:rgba(0,0,0,.015);}
.ob-l-line-info{display:flex;flex-direction:column;gap:1px;min-width:0;flex:1;}
.ob-l-line-cat{font-family:var(--ob-font-heading);font-weight:600;font-size:10px;color:var(--ob-text);text-transform:uppercase;letter-spacing:.5px;}
.ob-l-line-name{font-size:12px;color:var(--ob-text-sec);font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.ob-l-line-price{font-weight:600;color:var(--ob-text-sec);flex-shrink:0;margin-left:12px;font-size:12px;}

/* ═══ RIGHT PANEL ═══ */
.ob-right{flex:1;display:flex;flex-direction:column;min-width:0;background:var(--ob-bg);contain:layout style;}
.ob-stepper-bar{flex-shrink:0;padding:16px 32px 0;}
.ob-stepper{display:flex;align-items:center;justify-content:center;}
.ob-sn{display:flex;flex-direction:column;align-items:center;gap:6px;position:relative;z-index:1;}
.ob-sc{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .25s var(--ob-ease);}
.ob-sc.done{background:var(--ob-primary);box-shadow:0 2px 6px rgba(1,78,63,.18);}
.ob-sc.done svg{width:12px;height:12px;}
.ob-sc.active{background:var(--ob-primary);box-shadow:0 0 0 4px rgba(1,78,63,.1),0 2px 6px rgba(1,78,63,.18);}
.ob-sc.active::after{content:'';width:8px;height:8px;background:#fff;border-radius:50%;}
.ob-sc.future{background:var(--ob-bg);border:1.5px solid #d1d5db;}
.ob-sl{font-family:var(--ob-font-heading);font-size:11px;font-weight:500;white-space:nowrap;}
.ob-sl.done{color:var(--ob-text-sec);}
.ob-sl.active{color:var(--ob-primary);font-weight:600;}
.ob-sl:not(.done):not(.active){color:var(--ob-text-muted);}
.ob-sline{width:72px;height:2px;flex-shrink:0;margin:0 4px;margin-bottom:22px;transition:background .25s var(--ob-ease);border-radius:1px;}
.ob-sline.done{background:var(--ob-primary);}
.ob-sline:not(.done){background:#d1d5db;}

.ob-right-head{display:flex;align-items:center;justify-content:flex-end;padding:12px 24px 0;flex-shrink:0;}
.ob-modal .ob-close,.ob-close{background:#fff!important;border:1.5px solid #1a1a1a!important;cursor:pointer!important;color:#1a1a1a!important;width:36px!important;height:36px!important;border-radius:50%!important;display:flex!important;align-items:center!important;justify-content:center!important;transition:all .18s var(--ob-ease)!important;padding:0!important;margin:0!important;min-width:36px!important;min-height:36px!important;max-width:36px!important;max-height:36px!important;line-height:1!important;text-decoration:none!important;text-transform:none!important;letter-spacing:0!important;box-shadow:none!important;outline:none!important;font-size:0!important;text-indent:0!important;overflow:visible!important;}
.ob-modal .ob-close:hover,.ob-close:hover{background:#1a1a1a!important;color:#fff!important;border-color:#1a1a1a!important;transform:translateY(-1px)!important;box-shadow:0 4px 12px rgba(0,0,0,.12)!important;}
.ob-modal .ob-close:active,.ob-close:active{transform:translateY(0)!important;box-shadow:none!important;}
.ob-close svg{width:18px!important;height:18px!important;}

.ob-content{flex:1;overflow-y:auto;padding:20px 32px 28px;-webkit-overflow-scrolling:touch;scroll-behavior:smooth;}
.ob-content::-webkit-scrollbar{width:3px;}
.ob-content::-webkit-scrollbar-track{background:transparent;}
.ob-content::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px;}
.ob-content::-webkit-scrollbar-thumb:hover{background:#9ca3af;}

.ob-footer{flex-shrink:0;border-top:1px solid var(--ob-border);padding:14px 32px;display:flex;align-items:center;justify-content:flex-end;gap:12px;background:var(--ob-bg);}
.ob-footer .ob-btn{max-width:280px!important;flex:1!important;}

.ob-gf{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:10px 32px;border-top:1px solid var(--ob-border);background:var(--ob-bg);font-size:12px;color:var(--ob-text-muted);}
.ob-gf a{color:var(--ob-primary);text-decoration:underline;font-weight:500;}
.ob-gf-trust{display:flex;gap:20px;}
.ob-gf-trust span{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:var(--ob-text-sec);}
.ob-gf-trust span svg{opacity:.65;}

/* ═══ HEADINGS ═══ */
.ob-h{font-family:var(--ob-font-heading);font-size:var(--ob-heading-size);font-weight:700;color:var(--ob-text);margin-bottom:2px;line-height:1.25;letter-spacing:-.02em;}
.ob-sub{font-size:14px;color:var(--ob-text-sec);margin-bottom:12px;display:flex;align-items:center;gap:6px;line-height:1.5;}
.ob-help{font-size:13px;color:var(--ob-text-sec);margin-top:24px;}
.ob-help a{color:var(--ob-primary);text-decoration:underline;}

/* ═══ CARDS ═══ */
.ob-cards{display:flex;flex-direction:column;gap:var(--ob-card-gap);}
@media(min-width:1200px){.ob-cards--grid{display:grid;grid-template-columns:1fr 1fr;}}
.ob-c{display:flex;align-items:center;gap:14px;padding:var(--ob-card-pad) calc(var(--ob-card-pad) + 2px);border-radius:var(--ob-card-r);border:1.5px solid var(--ob-border);cursor:pointer;background:var(--ob-bg);transition:border-color .18s var(--ob-ease),background .18s var(--ob-ease),box-shadow .18s var(--ob-ease),transform .18s var(--ob-ease);backface-visibility:hidden;}
.ob-c:hover{border-color:#c9cdd3;transform:translateY(-1px);box-shadow:0 4px 16px rgba(0,0,0,.04);}
.ob-c.sel{border-color:var(--ob-primary);border-width:2px;padding:calc(var(--ob-card-pad) - 1px) calc(var(--ob-card-pad) + 3px);}
.ob-c.sel-fill{border-color:var(--ob-primary);background:rgba(1,78,63,.04);}
.ob-c.sel-shadow{border-color:var(--ob-border);box-shadow:0 4px 12px rgba(1,78,63,.15),0 0 0 2px var(--ob-primary);}
.ob-c.sel,.ob-c.sel-fill{background:rgba(1,78,63,.02);}
.ob-c.sel .ob-c-t,.ob-c.sel-fill .ob-c-t,.ob-c.sel-shadow .ob-c-t{color:var(--ob-primary);}

.ob-c-ico{width:44px;height:44px;flex-shrink:0;display:flex;align-items:center;justify-content:center;color:var(--ob-text-sec);transition:color .18s;}
.ob-c-ico svg{width:36px;height:36px;}
.ob-c.sel .ob-c-ico,.ob-c.sel-fill .ob-c-ico,.ob-c.sel-shadow .ob-c-ico{color:var(--ob-primary);}
.ob-c-body{flex:1;min-width:0;}
.ob-c-t{font-family:var(--ob-font-heading);font-size:15px;font-weight:600;color:var(--ob-text);display:flex;align-items:center;gap:8px;flex-wrap:wrap;transition:color .18s;}
.ob-c-d{font-size:13px;color:var(--ob-text-sec);margin-top:2px;line-height:1.45;}
.ob-c-p{font-size:13px;color:var(--ob-primary);font-weight:500;margin-top:4px;}
.ob-c-tag{font-size:10px;font-weight:600;color:var(--ob-tag-color);background:var(--ob-tag-bg);padding:2px 9px;border-radius:20px;letter-spacing:.02em;}

.ob-c-check{width:22px;height:22px;flex-shrink:0;border-radius:6px;border:1.5px solid #d1d5db;display:flex;align-items:center;justify-content:center;transition:all .18s var(--ob-ease);}
.ob-c.sel .ob-c-check,.ob-c.sel-fill .ob-c-check,.ob-c.sel-shadow .ob-c-check{background:var(--ob-primary);border-color:var(--ob-primary);}
.ob-c.sel .ob-c-check svg,.ob-c.sel-fill .ob-c-check svg,.ob-c.sel-shadow .ob-c-check svg{width:13px;height:13px;}

.ob-c-radio{width:22px;height:22px;flex-shrink:0;border-radius:50%;border:2px solid #d1d5db;display:flex;align-items:center;justify-content:center;transition:all .2s var(--ob-ease);margin-left:auto;}
.ob-c-radio span{width:0;height:0;border-radius:50%;background:var(--ob-primary);transition:all .2s var(--ob-ease);}
.ob-c-radio.checked{border-color:var(--ob-primary);}
.ob-c-radio.checked span{width:10px;height:10px;}
.ob-c.sel .ob-c-radio,.ob-c.sel-fill .ob-c-radio,.ob-c.sel-shadow .ob-c-radio{border-color:var(--ob-primary);}
.ob-c.sel .ob-c-radio span,.ob-c.sel-fill .ob-c-radio span,.ob-c.sel-shadow .ob-c-radio span{width:10px;height:10px;}

.ob-treat-hint{font-size:13px;color:var(--ob-text-muted);margin-top:16px;padding:10px 16px;background:var(--ob-bg-sec);border-radius:8px;border:1px solid var(--ob-border-lt);text-align:center;font-style:italic;}

/* ═══ PRESCRIPTION FORM ═══ */
.ob-rx-intro{margin:4px 0 20px;}
.ob-rx-intro-text{font-size:14px;color:var(--ob-text-sec);line-height:1.6;}
.ob-rx-help-link{color:var(--ob-primary);text-decoration:underline;font-weight:500;cursor:pointer;}
.ob-rx-help-link:hover{color:var(--ob-primary-hover);}
.ob-rx-form{display:flex;flex-direction:column;gap:0;background:var(--ob-bg-sec);border:1px solid var(--ob-border-lt);border-radius:var(--ob-card-r);overflow:hidden;}
.ob-rx-eye-label{display:flex;align-items:center;gap:8px;padding:12px 16px;font-family:var(--ob-font-heading);font-size:13px;font-weight:600;color:var(--ob-text);background:rgba(1,78,63,.025);border-bottom:1px solid var(--ob-border-lt);}
.ob-rx-eye-dot{width:8px;height:8px;border-radius:50%;display:inline-block;}
.ob-rx-eye-dot--od{background:#3b82f6;}
.ob-rx-eye-dot--og{background:#8b5cf6;}
.ob-rx-eye-sep{color:var(--ob-text-muted);font-weight:400;margin:0 4px;}
.ob-rx-row{display:grid;grid-template-columns:100px 1fr 1fr;gap:12px;align-items:center;padding:10px 16px;border-bottom:1px solid var(--ob-border-lt);}
.ob-rx-row:last-child{border-bottom:none;}
.ob-rx-row.ob-rx-header{padding:8px 16px 6px;border-bottom:1px solid var(--ob-border);}
.ob-rx-label{font-family:var(--ob-font-heading);font-size:13px;font-weight:600;color:var(--ob-text);}
.ob-rx-col-head{font-size:11px;font-weight:600;color:var(--ob-primary);text-transform:uppercase;letter-spacing:.5px;}
.ob-rx-field .ob-sel{width:100%;}

.ob-rx-pd-info-box{display:flex;gap:12px;padding:16px 20px;background:var(--ob-info-bg);border:1px solid #d4e5f7;border-radius:12px;margin:20px 0 16px;align-items:flex-start;}
.ob-rx-pd-info-icon{flex-shrink:0;color:var(--ob-primary);margin-top:2px;}
.ob-rx-pd-info-content{flex:1;font-size:13px;color:#4b5563;line-height:1.6;}
.ob-rx-pd-info-content strong{font-family:var(--ob-font-heading);display:block;font-size:14px;color:var(--ob-text);margin-bottom:6px;}
.ob-rx-pd-info-content p{margin:0;}
.ob-rx-pd-section{margin-top:0;}

.ob-rx-help-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:100005;transition:opacity var(--ob-anim) var(--ob-ease);opacity:0;}
.ob-rx-help-overlay.open{display:block;opacity:1;}
.ob-rx-help-drawer{position:fixed;top:0;right:-420px;width:400px;max-width:90vw;height:100%;background:#fff;z-index:100010;box-shadow:-8px 0 40px rgba(0,0,0,.12);transition:right .3s var(--ob-ease);display:flex;flex-direction:column;overflow:hidden;}
.ob-rx-help-drawer.open{right:0;}
.ob-rx-help-drawer-head{display:flex;align-items:center;justify-content:space-between;padding:24px 28px 20px;border-bottom:1px solid var(--ob-border);}
.ob-rx-help-drawer-head h3{font-family:var(--ob-font-heading);font-size:20px;font-weight:700;color:var(--ob-primary);margin:0;}
.ob-rx-help-close{background:none;border:none;font-size:28px;cursor:pointer;color:var(--ob-text-muted);padding:0 4px;line-height:1;transition:color .15s;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;}
.ob-rx-help-close:hover{color:var(--ob-text);}
.ob-rx-help-drawer-body{flex:1;overflow-y:auto;padding:28px;font-size:14px;color:var(--ob-text-sec);line-height:1.7;}
.ob-rx-help-drawer-body h4{font-family:var(--ob-font-heading);font-size:16px;font-weight:700;color:var(--ob-text);margin:24px 0 8px;}
.ob-rx-help-drawer-body h4:first-child{margin-top:0;}
.ob-rx-help-drawer-body p{margin:0 0 16px;}

.ob-sel{width:100%;padding:10px 28px 10px 12px;border:1px solid var(--ob-border);border-radius:8px;font-family:var(--ob-font);font-size:14px;color:var(--ob-text);background:var(--ob-bg);cursor:pointer;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%239ca3af' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:10px;min-width:auto;transition:border-color .15s,box-shadow .15s;}
.ob-sel:focus{outline:none;border-color:var(--ob-primary);box-shadow:0 0 0 2px rgba(1,78,63,.12);}
.ob-sel-add{background-color:var(--ob-add-bg);color:var(--ob-add-color);border-color:var(--ob-add-bg);background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23ffffff' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");}
.ob-sel-add option{background:#fff;color:#1a1a1a;}

/* ═══ FILE UPLOAD ═══ */
.ob-upload{border:1.5px dashed #d1d5db;border-radius:var(--ob-card-r);padding:36px 24px;text-align:center;cursor:pointer;transition:border-color .18s var(--ob-ease),background .18s var(--ob-ease);margin-top:16px;color:var(--ob-text-sec);background:var(--ob-bg-sec);}
.ob-upload:hover,.ob-upload.over{border-color:var(--ob-primary);background:rgba(1,78,63,.02);}
.ob-upload svg{margin-bottom:12px;color:var(--ob-text-muted);}
.ob-upload-t{font-size:14px;margin-bottom:4px;}
.ob-upload-t strong{color:var(--ob-primary);}
.ob-upload-h{font-size:12px;color:var(--ob-text-muted);}
.ob-upload-file{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:var(--ob-bg-sec);border:1px solid var(--ob-border);border-radius:10px;margin-top:20px;}
.ob-upload-file-name{font-size:13px;color:var(--ob-text);font-weight:500;}
.ob-upload-file-rm{background:none;border:none;cursor:pointer;font-size:16px;color:var(--ob-text-muted);padding:4px 8px;border-radius:6px;min-width:36px;min-height:36px;display:flex;align-items:center;justify-content:center;transition:all .15s;}
.ob-upload-file-rm:hover{color:var(--ob-error);background:#fef2f2;}

/* ═══ BUTTONS ═══ */
.ob-modal .ob-btn,.ob-btn{display:inline-flex!important;align-items:center!important;justify-content:center!important;gap:8px!important;padding:14px 32px!important;border-radius:50px!important;font-family:var(--ob-font-heading)!important;font-size:15px!important;font-weight:600!important;cursor:pointer!important;border:none!important;transition:all .18s var(--ob-ease)!important;white-space:nowrap!important;line-height:1!important;text-decoration:none!important;text-transform:none!important;letter-spacing:0!important;box-shadow:none!important;}
.ob-modal .ob-btn-fill,.ob-btn-fill{background:var(--ob-primary)!important;color:#fff!important;border:none!important;}
.ob-modal .ob-btn-fill:hover,.ob-btn-fill:hover{background:var(--ob-primary-hover)!important;color:#fff!important;transform:translateY(-1px);box-shadow:0 4px 14px rgba(1,78,63,.22)!important;}
.ob-btn-fill:disabled{opacity:.5!important;cursor:not-allowed!important;transform:none!important;box-shadow:none!important;}
.ob-btn-fill:active:not(:disabled){transform:translateY(0)!important;box-shadow:none!important;}
.ob-modal .ob-btn-out,.ob-btn-out{background:#1a1a1a!important;color:#fff!important;border:none!important;}
.ob-modal .ob-btn-out:hover,.ob-btn-out:hover{background:#333!important;color:#fff!important;transform:translateY(-1px);box-shadow:0 4px 14px rgba(0,0,0,.15)!important;}
.ob-btn-out:active{transform:translateY(0)!important;box-shadow:none!important;}
.ob-modal .ob-btn-cart,.ob-btn-cart{background:var(--ob-primary)!important;color:#fff!important;padding:14px 40px!important;border:none!important;}
.ob-modal .ob-btn-cart:hover,.ob-btn-cart:hover{background:var(--ob-primary-hover)!important;color:#fff!important;transform:translateY(-1px);box-shadow:0 4px 18px rgba(1,78,63,.28)!important;}
.ob-btn-cart svg{width:16px;height:16px;}
.ob-btn-cart:disabled{opacity:.5!important;cursor:not-allowed!important;transform:none!important;box-shadow:none!important;}
.ob-btn-cart:active:not(:disabled){transform:translateY(0)!important;box-shadow:none!important;}

.ob-lens-trigger{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;cursor:pointer;font-family:var(--ob-font-heading);font-weight:600;border-radius:50px;transition:all .18s var(--ob-ease);line-height:1;}
.ob-btn--primary{background:var(--ob-primary);color:#fff;}
.ob-btn--primary:hover{background:var(--ob-primary-hover);}
.ob-btn--outline{background:var(--ob-bg);color:var(--ob-text);border:1.5px solid var(--ob-border);}
.ob-btn--outline:hover{border-color:var(--ob-primary);color:var(--ob-primary);}
.ob-btn--ghost{background:transparent;color:var(--ob-primary);border:none;}
.ob-btn--ghost:hover{background:rgba(1,78,63,.06);}
.ob-btn--sm{padding:9px 20px;font-size:13px;}
.ob-btn--md{padding:12px 28px;font-size:14px;}
.ob-btn--lg{padding:16px 40px;font-size:16px;}
.ob-btn--xl{padding:20px 52px;font-size:18px;}
.ob-btn--full{width:100%;}

/* ═══ TOAST ═══ */
.ob-toast{position:fixed;bottom:100px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--ob-text);color:#fff;padding:12px 28px;border-radius:50px;font-family:var(--ob-font);font-size:14px;font-weight:500;z-index:100020;opacity:0;transition:opacity var(--ob-anim) var(--ob-ease),transform var(--ob-anim) var(--ob-ease);pointer-events:none;box-shadow:0 8px 30px rgba(0,0,0,.22);}
.ob-toast.vis{opacity:1;transform:translateX(-50%) translateY(0);}

/* ═══ SPINNER ═══ */
.ob-spin{display:inline-block;width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:ob-spin .6s linear infinite;}
@keyframes ob-spin{to{transform:rotate(360deg)}}

/* ═══ INTERCEPT BOTTOM SHEET ═══ */
.ob-intercept{position:fixed;inset:0;z-index:99999;font-family:var(--ob-font);}
.ob-intercept-bg{position:absolute;inset:0;background:rgba(0,0,0,.45);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);}
.ob-intercept-sheet{position:absolute;bottom:0;left:0;right:0;background:var(--ob-bg);border-radius:20px 20px 0 0;padding:20px 24px 32px;display:flex;flex-direction:column;gap:14px;max-width:460px;margin:0 auto;animation:ob-sheet-up .3s var(--ob-ease);box-shadow:0 -12px 50px rgba(0,0,0,.16);}
@keyframes ob-sheet-up{from{transform:translateY(100%)}to{transform:translateY(0)}}
.ob-intercept--centered .ob-intercept-sheet{position:absolute;bottom:auto;top:50%;left:50%;right:auto;transform:translate(-50%,-50%);border-radius:20px;max-width:420px;width:calc(100% - 32px);animation:ob-pop-in .3s var(--ob-ease);box-shadow:0 20px 50px rgba(0,0,0,.2);}
@keyframes ob-pop-in{from{opacity:0;transform:translate(-50%,-50%) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}
.ob-intercept-handle{width:40px;height:4px;background:#d1d5db;border-radius:2px;margin:0 auto 8px;}
.ob-intercept--centered .ob-intercept-handle{display:none;}
.ob-int-product{display:flex;align-items:center;gap:14px;padding:4px 0;}
.ob-int-img{width:68px;height:68px;object-fit:contain;border-radius:12px;background:var(--ob-bg-sec);flex-shrink:0;padding:6px;border:1px solid var(--ob-border-lt);box-shadow:0 2px 8px rgba(0,0,0,.04);}
.ob-int-info{flex:1;min-width:0;}
.ob-int-name{font-family:var(--ob-font-heading);font-size:14px;font-weight:600;color:var(--ob-text);line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.ob-int-price{font-family:var(--ob-font-heading);font-size:15px;font-weight:700;color:var(--ob-text);margin-top:3px;}
.ob-int-divider{height:1px;background:var(--ob-border);margin:2px 0;}
.ob-ibtn{display:flex!important;align-items:center!important;justify-content:center!important;gap:8px!important;width:100%!important;padding:15px!important;border-radius:50px!important;font-family:var(--ob-font-heading)!important;font-size:15px!important;font-weight:600!important;cursor:pointer!important;border:none!important;transition:all .18s var(--ob-ease)!important;text-decoration:none!important;text-transform:none!important;letter-spacing:0!important;box-shadow:none!important;line-height:1!important;position:relative!important;}
.ob-ibtn-primary{background:var(--ob-primary)!important;color:#fff!important;}
.ob-ibtn-primary:hover{background:var(--ob-primary-hover)!important;color:#fff!important;transform:translateY(-1px);box-shadow:0 4px 18px rgba(1,78,63,.25)!important;}
.ob-ibtn-primary:active{transform:translateY(0)!important;box-shadow:none!important;}
.ob-ibtn-primary svg{width:18px;height:18px;}
.ob-ibtn-outline{background:#1a1a1a!important;color:#fff!important;border:none!important;}
.ob-ibtn-outline:hover{background:#333!important;color:#fff!important;transform:translateY(-1px);box-shadow:0 4px 14px rgba(0,0,0,.15)!important;}
.ob-ibtn-outline.ob-loading{color:transparent!important;pointer-events:none;}
.ob-ibtn-outline.ob-loading::after{content:'';position:absolute;width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:ob-spin .6s linear infinite;}
.ob-ibtn-cancel{background:none;border:none;cursor:pointer;font-family:var(--ob-font);font-size:13px;color:var(--ob-text-muted);padding:8px;text-align:center;width:100%;min-height:44px;transition:color .15s;}
.ob-ibtn-cancel:hover{color:var(--ob-text-sec);}

/* ═══ MOBILE PRICE BAR ═══ */
.ob-mobile-price{display:none;}

/* ═══ MOBILE ═══ */
@media(max-width:899px){
.ob-left{display:none;}
.ob-right{width:100%;}
.ob-stepper-bar{padding:16px 16px 0;}
.ob-sline{width:40px;}
.ob-right-head{padding:10px 16px 0;}
.ob-content{padding:18px 18px 22px;}
.ob-footer{padding:12px 16px;}
.ob-footer .ob-btn{max-width:none!important;}
.ob-gf{padding:8px 16px;flex-direction:column;gap:4px;text-align:center;}
.ob-gf-trust{gap:16px;}
.ob-sel{font-size:16px!important;}
.ob-mobile-price{display:block;flex-shrink:0;background:var(--ob-bg-sec);border-bottom:1px solid var(--ob-border);padding:10px 20px;}
.ob-mp-inner{display:flex;align-items:center;justify-content:space-between;gap:12px;}
.ob-mp-name{font-family:var(--ob-font-heading);font-size:13px;font-weight:500;color:var(--ob-text-sec);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;flex:1;}
.ob-mp-total{font-family:var(--ob-font-heading);font-size:16px;font-weight:700;color:var(--ob-text);flex-shrink:0;}
.ob-toast{bottom:120px;}
}

@media(max-width:599px){
.ob-sl{display:none;}
.ob-sl.active{display:block;font-size:10px;}
.ob-sline{width:24px;margin-bottom:0;margin:0 2px;}
.ob-sc{width:22px;height:22px;}
.ob-sc.done svg{width:10px;height:10px;}
.ob-sc.active::after{width:6px;height:6px;}
.ob-c{padding:16px 18px;}
.ob-c.sel{padding:15px 17px;}
.ob-btn{padding:12px 20px!important;font-size:14px!important;}
.ob-rx-row{grid-template-columns:80px 1fr 1fr;gap:8px;padding:8px 12px;}
.ob-rx-label{font-size:12px;}
.ob-sel{padding:10px 28px 10px 10px;}
.ob-rx-help-drawer{width:100%;max-width:100%;right:-100%;}
}

@media(max-width:374px){
.ob-sline{width:16px;margin:0 1px;}
.ob-sc{width:20px;height:20px;}
.ob-stepper-bar{padding:12px 12px 0;}
.ob-content{padding:16px 14px 20px;}
.ob-footer{padding:10px 12px;}
}

/* ═══ ANIMATION ═══ */
.ob-anim-none{--ob-anim:0ms;}
.ob-anim-fast{--ob-anim:150ms;}
.ob-anim-slow{--ob-anim:400ms;}

/* ═══ FOCUS ═══ */
.ob-c:focus-visible,.ob-btn:focus-visible,.ob-btn-fill:focus-visible,.ob-btn-cart:focus-visible,.ob-lens-trigger:focus-visible,.ob-ibtn:focus-visible,.ob-close:focus-visible,.ob-back-frame:focus-visible,.ob-sum-edit:focus-visible{outline:2px solid var(--ob-primary);outline-offset:2px;}
.ob-sel:focus-visible{outline:2px solid var(--ob-primary);outline-offset:1px;}
.ob-upload:focus-visible{outline:2px solid var(--ob-primary);outline-offset:2px;}

/* ═══ VALIDATION ═══ */
.ob-sel.ob-sel-error{border-color:var(--ob-error);box-shadow:0 0 0 2px rgba(239,68,68,.15);animation:ob-shake .35s ease;}
@keyframes ob-shake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-4px)}40%,80%{transform:translateX(4px)}}

.ob-lens-cart-badge{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;vertical-align:middle;margin-left:4px;color:var(--ob-primary,#014E3F);}

/* ═══ STEP TRANSITIONS — v20: DIRECTIONAL ═══ */
.ob-content{transition:none;}
.ob-content--exit-fwd{opacity:0;transform:translateX(-8px);pointer-events:none;}
.ob-content--exit-bwd{opacity:0;transform:translateX(8px);pointer-events:none;}
.ob-content--enter-fwd{animation:ob-step-fwd var(--ob-anim) var(--ob-ease) forwards;}
.ob-content--enter-bwd{animation:ob-step-bwd var(--ob-anim) var(--ob-ease) forwards;}
.ob-content--exit{opacity:0;transform:translateY(6px);pointer-events:none;}
.ob-content--enter{animation:ob-step-fwd var(--ob-anim) var(--ob-ease) forwards;}
@keyframes ob-step-fwd{from{opacity:0;transform:translateX(16px)}to{opacity:1;transform:translateX(0)}}
@keyframes ob-step-bwd{from{opacity:0;transform:translateX(-16px)}to{opacity:1;transform:translateX(0)}}

.ob-c.sel,.ob-c.sel-fill,.ob-c.sel-shadow{animation:ob-card-pop 200ms var(--ob-ease);}
@keyframes ob-card-pop{0%{transform:scale(1)}50%{transform:scale(1.008)}100%{transform:scale(1)}}

.ob-l-img img{background:var(--ob-bg-sec);min-height:180px;border-radius:8px;transition:min-height .25s var(--ob-ease),transform .35s var(--ob-ease);}
.ob-l-img img.ob-img-loaded{min-height:auto;background:transparent;}

.ob-sum-rx-detail{margin-top:6px;font-family:'SF Mono','Menlo','Monaco','Courier New',monospace;font-size:12px;color:var(--ob-text-sec);line-height:1.8;background:var(--ob-bg-sec);padding:10px 16px;border-radius:8px;border:1px solid var(--ob-border-lt);letter-spacing:.02em;}
.ob-sum-rx-line{white-space:nowrap;}

/* ═══ REDUCED MOTION ═══ */
@media(prefers-reduced-motion:reduce){
.ob-intercept-sheet,.ob-modal--slide-right .ob-page,.ob-intercept--centered .ob-intercept-sheet,.ob-content--enter,.ob-content--enter-fwd,.ob-content--enter-bwd,.ob-c.sel,.ob-c.sel-fill,.ob-c.sel-shadow,.ob-wa-btn{animation:none!important;}
.ob-c,.ob-sc,.ob-sline,.ob-sel,.ob-toast,.ob-rx-help-drawer,.ob-rx-help-overlay,.ob-btn,.ob-btn-fill,.ob-btn-cart,.ob-ibtn,.ob-ibtn-primary,.ob-sum-card,.ob-back-frame,.ob-close,.ob-sum-edit{transition:none!important;}
.ob-c:hover,.ob-sum-card:hover,.ob-btn-fill:hover,.ob-btn-cart:hover,.ob-ibtn-primary:hover,.ob-back-frame:hover,.ob-close:hover{transform:none!important;}
}

/* ═══ TRUST STRIP ═══ */
.ob-trust-strip{display:flex;align-items:center;justify-content:center;gap:20px;padding:10px 20px;background:rgba(1,78,63,.018);border-bottom:1px solid rgba(1,78,63,.04);flex-shrink:0;flex-wrap:wrap;}
.ob-trust-item{display:inline-flex;align-items:center;gap:5px;font-family:var(--ob-font);font-size:11px;font-weight:500;color:var(--ob-text-sec);white-space:nowrap;letter-spacing:.01em;}
.ob-trust-item svg{flex-shrink:0;opacity:.65;}

/* ═══ WHATSAPP ═══ */
.ob-wa-wrap{flex-shrink:0;display:flex;justify-content:flex-end;padding:0 20px 12px;pointer-events:none;}
.ob-wa-btn{width:48px;height:48px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px rgba(37,211,102,.35);z-index:10;transition:transform .18s var(--ob-ease),box-shadow .18s var(--ob-ease);text-decoration:none!important;cursor:pointer;pointer-events:auto;animation:ob-wa-pulse 4s ease-in-out 3s infinite;}
.ob-wa-btn:hover{transform:scale(1.1);box-shadow:0 6px 22px rgba(37,211,102,.45);animation:none;}
.ob-wa-btn svg{width:22px;height:22px;}
@keyframes ob-wa-pulse{0%,100%{box-shadow:0 4px 14px rgba(37,211,102,.35)}50%{box-shadow:0 4px 14px rgba(37,211,102,.35),0 0 0 8px rgba(37,211,102,.08)}}

/* ═══ RESTORE BAR ═══ */
.ob-restore-bar{display:flex;align-items:center;gap:16px;padding:14px 24px;background:var(--ob-bg);border-bottom:1px solid var(--ob-border);flex-shrink:0;font-family:var(--ob-font);font-size:14px;color:var(--ob-text);flex-wrap:wrap;transition:opacity .25s var(--ob-ease),max-height .25s var(--ob-ease),padding .25s var(--ob-ease);max-height:120px;}
.ob-restore-msg{flex:1;min-width:0;display:flex;align-items:center;gap:8px;font-weight:600;font-family:var(--ob-font-heading);color:var(--ob-primary);font-size:14px;}
.ob-restore-msg svg{flex-shrink:0;}
.ob-restore-actions{display:flex;gap:8px;flex-shrink:0;}
.ob-restore-yes{background:var(--ob-primary);color:#fff;border:none;padding:10px 24px;border-radius:50px;font-family:var(--ob-font-heading);font-size:14px;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .18s var(--ob-ease);min-height:44px;}
.ob-restore-no{background:#1a1a1a;border:none;padding:10px 22px;border-radius:50px;font-family:var(--ob-font-heading);font-size:14px;font-weight:600;color:#fff;cursor:pointer;white-space:nowrap;transition:all .18s var(--ob-ease);min-height:44px;}
.ob-restore-yes:hover{background:var(--ob-primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px rgba(1,78,63,.2);}
.ob-restore-no:hover{background:#333;transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.12);}

.ob-rec-banner{font-family:var(--ob-font);font-size:13px;color:var(--ob-primary);background:rgba(1,78,63,.06);padding:10px 16px;border-radius:10px;border:1px solid rgba(1,78,63,.12);margin-bottom:16px;line-height:1.5;}
.ob-c-inc{font-size:12px;color:var(--ob-text-sec);margin-top:4px;line-height:1.4;}
.ob-c-inc strong{color:var(--ob-text);font-weight:600;}

@media(max-width:899px){
.ob-trust-strip{padding:8px 16px;gap:12px;}
.ob-trust-item{font-size:10px;}
.ob-wa-wrap{padding:0 12px 8px;}
.ob-wa-btn{width:44px;height:44px;}
.ob-wa-btn svg{width:20px;height:20px;}
.ob-restore-bar{padding:12px 16px;font-size:13px;gap:10px;flex-direction:column;align-items:stretch;}
.ob-restore-actions{justify-content:stretch;}
.ob-restore-yes,.ob-restore-no{flex:1;text-align:center;padding:10px 16px;font-size:13px;}
}
@media(max-width:599px){
.ob-trust-strip{gap:8px;padding:6px 12px;}
.ob-trust-item{font-size:9px;gap:3px;}
}

/* ═══ PROGRESS BAR ═══ */
.ob-progress-bar{height:3px;background:var(--ob-border-lt);border-radius:2px;margin:10px 40px 0;overflow:hidden;flex-shrink:0;}
.ob-progress-fill{height:100%;background:linear-gradient(90deg,var(--ob-primary),#059669);border-radius:2px;transition:width .35s var(--ob-ease);}
.ob-step-counter{display:none;}
@media(max-width:899px){
.ob-progress-bar{margin:8px 20px 0;}
.ob-step-counter{display:block;text-align:center;font-family:var(--ob-font);font-size:11px;color:var(--ob-text-muted);padding:4px 0 0;flex-shrink:0;}
}

/* ═══ SKELETON LOADING ═══ */
@keyframes ob-shimmer{0%{background-position:-200px 0}100%{background-position:calc(200px + 100%) 0}}
.ob-btn-cart.ob-loading{position:relative;color:transparent!important;pointer-events:none;}
.ob-btn-cart.ob-loading::after{content:'';position:absolute;inset:0;border-radius:inherit;background:linear-gradient(90deg,var(--ob-primary) 25%,rgba(255,255,255,.25) 50%,var(--ob-primary) 75%);background-size:200px 100%;animation:ob-shimmer 1.2s ease infinite;}
.ob-btn-cart.ob-loading .ob-spin{display:none;}
.ob-int-product-skeleton{display:flex;align-items:center;gap:14px;padding:4px 0;}
.ob-skel-img{width:60px;height:60px;border-radius:8px;background:linear-gradient(90deg,var(--ob-bg-sec) 25%,#eee 50%,var(--ob-bg-sec) 75%);background-size:200px 100%;animation:ob-shimmer 1.2s ease infinite;}
.ob-skel-text{flex:1;display:flex;flex-direction:column;gap:6px;}
.ob-skel-line{height:12px;border-radius:4px;background:linear-gradient(90deg,var(--ob-bg-sec) 25%,#eee 50%,var(--ob-bg-sec) 75%);background-size:200px 100%;animation:ob-shimmer 1.2s ease infinite;}
.ob-skel-line:first-child{width:70%;}
.ob-skel-line:last-child{width:40%;}

.ob-step-hint{font-size:13px;color:var(--ob-primary);margin-bottom:14px;padding:8px 14px;background:rgba(1,78,63,.03);border-radius:8px;border-left:3px solid rgba(1,78,63,.25);line-height:1.5;font-weight:500;}

.ob-pd-guide-link{display:inline-flex;align-items:center;gap:4px;font-size:13px;color:var(--ob-primary);font-weight:500;cursor:pointer;text-decoration:underline;margin-top:8px;min-height:44px;}
.ob-pd-guide-link:hover{color:var(--ob-primary-hover);}
.ob-pd-guide{margin-top:16px;padding:20px;background:var(--ob-bg-sec);border:1px solid var(--ob-border);border-radius:var(--ob-card-r);display:none;}
.ob-pd-guide.open{display:block;}
.ob-pd-guide-title{font-family:var(--ob-font-heading);font-size:15px;font-weight:600;color:var(--ob-text);margin-bottom:12px;}
.ob-pd-guide-steps{counter-reset:pd-step;display:flex;flex-direction:column;gap:12px;}
.ob-pd-guide-step{display:flex;gap:12px;align-items:flex-start;font-size:13px;color:var(--ob-text-sec);line-height:1.5;}
.ob-pd-guide-step::before{counter-increment:pd-step;content:counter(pd-step);flex-shrink:0;width:24px;height:24px;border-radius:50%;background:var(--ob-primary);color:#fff;font-size:12px;font-weight:600;display:flex;align-items:center;justify-content:center;margin-top:1px;}
.ob-pd-guide-illus{display:flex;justify-content:center;margin:12px 0;gap:16px;}
.ob-pd-guide-illus svg{max-width:160px;height:auto;}

.ob-rx-feedback-wrap{margin-top:8px;}
.ob-rx-feedback{font-size:13px;padding:10px 16px;border-radius:10px;margin-top:8px;line-height:1.5;display:flex;align-items:flex-start;gap:8px;}
.ob-rx-feedback svg{flex-shrink:0;margin-top:2px;}
.ob-rx-feedback--info{color:var(--ob-primary);background:rgba(1,78,63,.06);border:1px solid rgba(1,78,63,.12);}
.ob-rx-feedback--warn{color:#b45309;background:rgba(180,83,9,.06);border:1px solid rgba(180,83,9,.15);}

.ob-rx-saved-card{border-color:var(--ob-accent);background:rgba(34,197,94,.04);}
.ob-rx-saved-card .ob-c-d{font-family:'Menlo','Monaco','Courier New',monospace;font-size:11px;line-height:1.5;color:var(--ob-text-sec);}

.ob-c[data-tip]{position:relative;}
.ob-c[data-tip]::after{content:attr(data-tip);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);background:var(--ob-text);color:#fff;font-family:var(--ob-font);font-size:11px;font-weight:500;padding:6px 12px;border-radius:6px;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .15s;z-index:5;}
.ob-c[data-tip]::before{content:'';position:absolute;bottom:calc(100% + 4px);left:50%;transform:translateX(-50%);border:4px solid transparent;border-top-color:var(--ob-text);pointer-events:none;opacity:0;transition:opacity .15s;z-index:5;}
.ob-c[data-tip]:hover::after,.ob-c[data-tip]:hover::before{opacity:1;}
@media(max-width:899px){.ob-c[data-tip]::after,.ob-c[data-tip]::before{display:none;}}

.ob-lens-viz{display:flex;align-items:center;justify-content:center;gap:6px;margin:8px 0 18px;padding:0;}
.ob-lens-viz-item{display:flex;flex-direction:column;align-items:center;gap:5px;opacity:.3;transition:opacity .2s var(--ob-ease),transform .2s var(--ob-ease);cursor:pointer;padding:8px 14px;border-radius:10px;position:relative;}
.ob-lens-viz-item:hover{opacity:.55;}
.ob-lens-viz-item.active{opacity:1;transform:scale(1.06);}
.ob-lens-viz-item.active::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:20px;height:2px;background:var(--ob-primary);border-radius:1px;}
.ob-lens-viz-label{font-family:var(--ob-font-heading);font-size:11px;font-weight:700;color:var(--ob-text-muted);}
.ob-lens-viz-item.active .ob-lens-viz-label{color:var(--ob-primary);}

/* ═══ SUMMARY ═══ */
.ob-sum-cards{display:flex;flex-direction:column;gap:8px;}
.ob-sum-card{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--ob-bg-sec);border:1px solid var(--ob-border-lt);border-radius:12px;transition:background .18s var(--ob-ease),transform .18s var(--ob-ease),box-shadow .18s var(--ob-ease);backface-visibility:hidden;}
.ob-sum-card:hover{background:#f1f3f5;transform:translateY(-1px);box-shadow:0 3px 10px rgba(0,0,0,.04);}
.ob-sum-card-ico{width:36px;height:36px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:rgba(1,78,63,.06);border-radius:10px;color:var(--ob-primary);}
.ob-sum-card-body{flex:1;min-width:0;}
.ob-sum-card-label{font-family:var(--ob-font-heading);font-size:10px;font-weight:600;color:var(--ob-text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px;}
.ob-sum-card-val{font-size:14px;color:var(--ob-text);font-weight:500;display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.ob-sum-card-price{font-size:11px;color:var(--ob-primary);font-weight:600;background:rgba(1,78,63,.06);padding:2px 8px;border-radius:6px;}
.ob-modal .ob-sum-edit,.ob-sum-edit{background:#fff!important;border:1.5px solid var(--ob-border)!important;cursor:pointer!important;font-family:var(--ob-font-heading)!important;font-size:12px!important;color:var(--ob-text)!important;font-weight:600!important;padding:6px 18px!important;flex-shrink:0!important;border-radius:50px!important;transition:all .18s var(--ob-ease)!important;min-height:36px!important;line-height:1!important;text-decoration:none!important;text-transform:none!important;letter-spacing:0!important;box-shadow:none!important;display:inline-flex!important;align-items:center!important;justify-content:center!important;white-space:nowrap!important;}
.ob-modal .ob-sum-edit:hover,.ob-sum-edit:hover{background:var(--ob-bg-sec)!important;border-color:#b0b5bc!important;color:var(--ob-text)!important;text-decoration:none!important;transform:translateY(-1px)!important;box-shadow:0 2px 8px rgba(0,0,0,.06)!important;}
.ob-sum-total-wrap{margin-top:18px;border:1.5px solid var(--ob-border);border-radius:14px;overflow:hidden;}
.ob-sum-total-line{display:flex;justify-content:space-between;padding:11px 18px;font-size:13px;color:var(--ob-text-sec);border-bottom:1px solid var(--ob-border-lt);}
.ob-sum-total-line span{color:var(--ob-text-sec);font-weight:500;}
.ob-sum-total-line:last-of-type{border-bottom:none;}
.ob-sum-total{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;background:rgba(1,78,63,.035);border-top:1.5px solid rgba(1,78,63,.1);}
.ob-sum-total-l{font-family:var(--ob-font-heading);font-size:16px;font-weight:700;color:var(--ob-primary);}
.ob-sum-total-v{font-family:var(--ob-font-heading);font-size:22px;font-weight:700;color:var(--ob-primary);letter-spacing:-.02em;}
.ob-sum-rx-detail{margin-top:-4px;margin-bottom:8px;}

.ob-int-price-compare{display:flex;gap:8px;padding:8px 0 4px;}
.ob-int-price-badge{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:12px 12px;border-radius:10px;background:var(--ob-bg-sec);border:1px solid var(--ob-border-lt);text-align:center;}
.ob-int-price-badge--primary{background:rgba(1,78,63,.04);border-color:rgba(1,78,63,.12);}
.ob-int-price-badge-label{font-size:10px;font-weight:600;color:var(--ob-text-muted);text-transform:uppercase;letter-spacing:.4px;}
.ob-int-price-badge-val{font-family:var(--ob-font-heading);font-size:15px;font-weight:700;color:var(--ob-text);}
.ob-int-price-badge--primary .ob-int-price-badge-val{color:var(--ob-primary);}

@media(max-width:599px){
.ob-sum-card{padding:12px 14px;gap:10px;}
.ob-sum-card-ico{width:32px;height:32px;border-radius:8px;}
.ob-sum-card-ico svg{width:16px;height:16px;}
.ob-sum-total-wrap{border-radius:12px;}
.ob-int-price-compare{flex-direction:column;}
.ob-lens-viz{gap:2px;}
.ob-lens-viz-item{padding:6px 10px;}
.ob-lens-viz-item svg{width:30px;height:30px;}
.ob-lens-viz-label{font-size:10px;}
}
