/* ════════════════════════════════════════════════════════════
   АКАДЕМІК · ORDER MODAL — преміальна форма замовлення
   ════════════════════════════════════════════════════════════ */

.om-backdrop{
  position:fixed;inset:0;z-index:1000;
  background:rgba(8,15,40,.65);
  backdrop-filter:blur(8px) saturate(1.3);
  display:flex;align-items:center;justify-content:center;
  padding:24px;
  opacity:0;pointer-events:none;
  transition:opacity .35s cubic-bezier(.16,1,.3,1);
  overflow-y:auto;
}
.om-backdrop.open{opacity:1;pointer-events:auto}

.om-card{
  position:relative;
  width:100%;max-width:560px;
  margin:auto;
  background:linear-gradient(155deg,#0c1c3a 0%,#1e3a8a 50%,#0e3e5f 100%);
  border-radius:28px;
  box-shadow:
    0 40px 100px rgba(0,0,0,.5),
    0 0 0 1px rgba(251,191,36,.14),
    inset 0 1px 0 rgba(255,255,255,.08);
  overflow:hidden;
  transform:translateY(40px) scale(.96);
  transition:all .45s cubic-bezier(.16,1,.3,1);
}
.om-backdrop.open .om-card{transform:translateY(0) scale(1)}

.om-card::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(circle at 18% 18%,rgba(251,191,36,.12),transparent 45%),
    radial-gradient(circle at 82% 82%,rgba(37,99,235,.22),transparent 45%);
}
.om-card::after{
  content:'';position:absolute;top:-30%;right:-25%;
  width:380px;height:380px;
  border:1px solid rgba(255,255,255,.04);
  border-radius:50%;pointer-events:none;
  animation:om-spin 30s linear infinite;
}
@keyframes om-spin{to{transform:rotate(360deg)}}

/* Meander gold borders */
.om-meander{
  position:absolute;left:24px;right:24px;height:8px;pointer-events:none;
  background:
    linear-gradient(90deg,#fbbf24 25%,transparent 25%) 0 0/14px 3px repeat-x,
    linear-gradient(90deg,transparent 75%,#fbbf24 75%) 0 3px/14px 3px repeat-x,
    linear-gradient(90deg,#fbbf24 25%,transparent 25%) 7px 3px/14px 3px repeat-x,
    linear-gradient(90deg,transparent 75%,#fbbf24 75%) 7px 6px/14px 3px repeat-x;
  opacity:.4;
}
.om-meander-t{top:16px}
.om-meander-b{bottom:16px;transform:scaleY(-1)}

/* Close button */
.om-close{
  position:absolute;top:18px;right:18px;z-index:5;
  width:36px;height:36px;border-radius:50%;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  display:grid;place-items:center;cursor:pointer;
  color:#fff;font-size:18px;
  transition:all .3s;
  backdrop-filter:blur(6px);
}
.om-close:hover{background:rgba(251,191,36,.18);border-color:rgba(251,191,36,.4);transform:rotate(90deg)}

/* Header */
.om-head{position:relative;z-index:2;padding:40px 40px 24px;text-align:center}
.om-badge{
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 14px;
  background:rgba(251,191,36,.1);
  border:1px solid rgba(251,191,36,.3);
  border-radius:30px;
  font-size:10.5px;font-weight:700;letter-spacing:2px;text-transform:uppercase;
  color:#fbbf24;
  margin-bottom:12px;
}
.om-head h2{
  font-family:'Cormorant Garamond',serif;
  font-size:32px;font-weight:700;line-height:1.15;color:#fff;
  margin-bottom:6px;
}
.om-head p{font-size:13.5px;color:rgba(255,255,255,.65);font-weight:300}

/* Form body */
.om-body{
  position:relative;z-index:2;
  padding:8px 40px 32px;
  max-height:70vh;overflow-y:auto;
  scrollbar-width:thin;scrollbar-color:rgba(251,191,36,.4) transparent;
}
.om-body::-webkit-scrollbar{width:6px}
.om-body::-webkit-scrollbar-track{background:transparent}
.om-body::-webkit-scrollbar-thumb{background:rgba(251,191,36,.4);border-radius:3px}

.om-field{margin-bottom:18px}
.om-label{
  display:flex;justify-content:space-between;align-items:center;
  font-size:12px;font-weight:600;
  color:rgba(255,255,255,.85);
  letter-spacing:.5px;
  margin-bottom:8px;
}
.om-label .req{color:#fbbf24}
.om-label .opt{font-size:10.5px;color:rgba(255,255,255,.4);font-weight:500;text-transform:uppercase;letter-spacing:1.2px}

.om-input,.om-select,.om-textarea{
  width:100%;
  padding:12px 16px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.14);
  border-radius:12px;
  font-family:'Source Sans 3',sans-serif;font-size:14px;
  color:#fff;
  transition:all .3s;
  backdrop-filter:blur(6px);
  appearance:none;
}
.om-input::placeholder,.om-textarea::placeholder{color:rgba(255,255,255,.36)}
.om-input:focus,.om-select:focus,.om-textarea:focus{
  outline:none;
  background:rgba(255,255,255,.1);
  border-color:#fbbf24;
  box-shadow:0 0 0 4px rgba(251,191,36,.1);
}
.om-select{
  cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23fbbf24' stroke-width='2.5' stroke-linecap='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 16px center;
  padding-right:42px;
}
.om-select option{background:#0c1c3a;color:#fff;padding:8px}
.om-textarea{resize:vertical;min-height:72px;font-family:'Source Sans 3',sans-serif;line-height:1.5}

/* Chips (quick select) */
.om-chips{display:flex;flex-wrap:wrap;gap:6px}
.om-chip{
  padding:8px 13px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.12);
  border-radius:10px;
  font-family:'Source Sans 3',sans-serif;font-size:12.5px;font-weight:500;
  color:rgba(255,255,255,.75);
  cursor:pointer;
  transition:all .25s;
}
.om-chip:hover{background:rgba(251,191,36,.08);border-color:rgba(251,191,36,.3);color:#fff}
.om-chip.active{
  background:linear-gradient(135deg,#fbbf24,#f59e0b);
  border-color:transparent;color:#0c1c3a;font-weight:700;
  box-shadow:0 4px 12px rgba(251,191,36,.32);
}

/* Messenger picker */
.om-soc{display:flex;gap:8px}
.om-soc-btn{
  flex:1;
  display:flex;align-items:center;justify-content:center;gap:6px;
  padding:10px 12px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.12);
  border-radius:11px;
  font-family:'Source Sans 3',sans-serif;font-size:12.5px;font-weight:600;
  color:rgba(255,255,255,.75);
  cursor:pointer;
  transition:all .25s;
}
.om-soc-btn svg{flex-shrink:0;opacity:.7;transition:opacity .25s}
.om-soc-btn:hover{background:rgba(255,255,255,.1);color:#fff}
.om-soc-btn:hover svg{opacity:1}
.om-soc-btn.active{border-color:transparent;color:#fff;font-weight:700}
.om-soc-btn.active svg{opacity:1}
.om-soc-btn[data-soc="tg"].active{background:linear-gradient(135deg,#2AABEE,#229ED9);box-shadow:0 4px 12px rgba(42,171,238,.4)}
.om-soc-btn[data-soc="wa"].active{background:linear-gradient(135deg,#25D366,#128C7E);box-shadow:0 4px 12px rgba(37,211,102,.4)}
.om-soc-btn[data-soc="vb"].active{background:linear-gradient(135deg,#7360F2,#5b50d6);box-shadow:0 4px 12px rgba(115,96,242,.4)}

/* Range sliders */
.om-range-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:10px}
.om-range-head .om-label{margin-bottom:0}
.om-range-val{
  font-family:'Cormorant Garamond',serif;
  font-size:20px;font-weight:700;
  background:linear-gradient(135deg,#fbbf24,#fde68a);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
  line-height:1;
}
.om-range-val span{font-size:13px;color:rgba(255,255,255,.5);-webkit-text-fill-color:rgba(255,255,255,.5);margin-left:2px}
.om-range{
  width:100%;height:8px;border-radius:6px;
  background:linear-gradient(90deg,#fbbf24 0%,#fbbf24 var(--p,30%),rgba(255,255,255,.1) var(--p,30%));
  appearance:none;-webkit-appearance:none;
  outline:none;cursor:pointer;
}
.om-range::-webkit-slider-thumb{
  appearance:none;-webkit-appearance:none;
  width:22px;height:22px;border-radius:50%;
  background:linear-gradient(135deg,#fbbf24,#f59e0b);
  border:3px solid #0c1c3a;
  box-shadow:0 4px 12px rgba(251,191,36,.5);
  cursor:pointer;
  transition:transform .2s;
}
.om-range::-webkit-slider-thumb:hover{transform:scale(1.15)}
.om-range::-moz-range-thumb{
  width:22px;height:22px;border-radius:50%;
  background:linear-gradient(135deg,#fbbf24,#f59e0b);
  border:3px solid #0c1c3a;
  box-shadow:0 4px 12px rgba(251,191,36,.5);
  cursor:pointer;
}

/* Submit button */
.om-submit{
  width:100%;
  padding:15px 24px;
  margin-top:6px;
  background:linear-gradient(135deg,#fbbf24,#f59e0b);
  color:#0c1c3a;
  border:none;border-radius:14px;
  font-family:'Source Sans 3',sans-serif;
  font-size:15px;font-weight:700;letter-spacing:.5px;
  cursor:pointer;
  transition:all .4s;
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  box-shadow:0 8px 24px rgba(251,191,36,.32);
  position:relative;overflow:hidden;
}
.om-submit::after{
  content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);
  transition:left .6s;
}
.om-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 36px rgba(251,191,36,.5)}
.om-submit:hover:not(:disabled)::after{left:100%}
.om-submit:disabled{opacity:.55;cursor:not-allowed}

.om-trust{
  display:flex;align-items:center;justify-content:center;gap:6px;
  margin-top:12px;
  font-size:11px;color:rgba(255,255,255,.5);
}

/* Error message */
.om-err{
  background:rgba(239,68,68,.1);
  border:1px solid rgba(239,68,68,.3);
  color:#fca5a5;
  padding:10px 14px;border-radius:10px;
  font-size:12.5px;font-weight:500;
  margin-bottom:14px;
  display:none;
}
.om-err.show{display:block;animation:om-shake .4s}
@keyframes om-shake{
  0%,100%{transform:translateX(0)}
  25%{transform:translateX(-6px)}
  75%{transform:translateX(6px)}
}

/* Success state */
.om-success{
  position:relative;z-index:2;
  padding:50px 40px 50px;
  text-align:center;
  animation:om-fade .5s ease both;
}
@keyframes om-fade{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}
.om-check{
  width:96px;height:96px;
  margin:0 auto 24px;
  border-radius:50%;
  background:linear-gradient(135deg,#fbbf24,#f59e0b);
  display:grid;place-items:center;
  box-shadow:0 14px 40px rgba(251,191,36,.5);
  position:relative;
}
.om-check::before{
  content:'';position:absolute;inset:-10px;
  border-radius:50%;
  border:2px solid rgba(251,191,36,.32);
  animation:om-pulse 2s ease-in-out infinite;
}
@keyframes om-pulse{0%,100%{transform:scale(1);opacity:.5}50%{transform:scale(1.15);opacity:0}}
.om-success h3{
  font-family:'Cormorant Garamond',serif;
  font-size:32px;font-weight:700;color:#fff;line-height:1.15;
  margin-bottom:10px;
}
.om-success p{
  font-size:14.5px;color:rgba(255,255,255,.7);
  line-height:1.55;font-weight:300;
  margin-bottom:24px;
  max-width:380px;margin-left:auto;margin-right:auto;
}
.om-success-close{
  display:inline-flex;align-items:center;gap:8px;
  padding:13px 26px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.14);
  border-radius:12px;
  color:#fff;cursor:pointer;
  font-family:'Source Sans 3',sans-serif;
  font-size:14px;font-weight:600;
  transition:all .3s;
}
.om-success-close:hover{background:rgba(255,255,255,.1)}

/* ═══ MOBILE ═══ */
@media(max-width:600px){
  .om-backdrop{padding:0;align-items:flex-end}
  .om-card{
    max-width:100%;
    border-radius:24px 24px 0 0;
    margin-top:auto;
    max-height:92vh;
  }
  .om-meander{left:18px;right:18px}
  .om-close{top:14px;right:14px;width:32px;height:32px;font-size:15px}
  .om-head{padding:36px 22px 18px}
  .om-head h2{font-size:24px}
  .om-head p{font-size:12.5px}
  .om-body{padding:8px 22px 28px;max-height:none}
  .om-field{margin-bottom:14px}
  .om-input,.om-select,.om-textarea{padding:11px 14px;font-size:13.5px}
  .om-chip{padding:7px 11px;font-size:11.5px}
  .om-soc-btn{padding:9px 8px;font-size:11.5px;gap:4px}
  .om-soc-btn svg{width:14px;height:14px}
  .om-range-val{font-size:18px}
  .om-submit{padding:14px 22px;font-size:14px}
  .om-success{padding:40px 22px 40px}
  .om-success h3{font-size:24px}
  .om-success p{font-size:13px}
  .om-check{width:80px;height:80px;margin-bottom:18px}
  .om-check svg{width:40px;height:40px}
}


/* ════════════════════════════════════════════════════════════
   THEME: MAIN (синьо-блакитна як головна сторінка)
   ════════════════════════════════════════════════════════════ */
.om-theme-main .om-card{
  background:linear-gradient(155deg,#1e3a8a 0%,#1e40af 45%,#0e7490 100%);
  box-shadow:
    0 40px 100px rgba(30,64,175,.45),
    0 0 0 1px rgba(125,211,252,.16),
    inset 0 1px 0 rgba(255,255,255,.08);
}
.om-theme-main .om-card::before{
  background:
    radial-gradient(circle at 18% 18%,rgba(125,211,252,.16),transparent 45%),
    radial-gradient(circle at 82% 82%,rgba(8,145,178,.24),transparent 45%);
}
.om-theme-main .om-badge{
  background:rgba(125,211,252,.10);
  border-color:rgba(125,211,252,.36);
  color:#bae6fd;
}
.om-theme-main .om-badge svg{fill:#bae6fd}
.om-theme-main .om-meander{
  background:
    linear-gradient(90deg,#7dd3fc 25%,transparent 25%) 0 0/14px 3px repeat-x,
    linear-gradient(90deg,transparent 75%,#7dd3fc 75%) 0 3px/14px 3px repeat-x,
    linear-gradient(90deg,#7dd3fc 25%,transparent 25%) 7px 3px/14px 3px repeat-x,
    linear-gradient(90deg,transparent 75%,#7dd3fc 75%) 7px 6px/14px 3px repeat-x;
  opacity:.45;
}
.om-theme-main .om-close:hover{
  background:rgba(125,211,252,.18);
  border-color:rgba(125,211,252,.4);
}
.om-theme-main .om-label .req{color:#7dd3fc}
.om-theme-main .om-input:focus,
.om-theme-main .om-select:focus,
.om-theme-main .om-textarea:focus{
  border-color:#7dd3fc;
  box-shadow:0 0 0 4px rgba(125,211,252,.14);
}
.om-theme-main .om-select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%237dd3fc' stroke-width='2.5' stroke-linecap='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
}
.om-theme-main .om-chip:hover{
  background:rgba(125,211,252,.10);
  border-color:rgba(125,211,252,.32);
}
.om-theme-main .om-chip.active{
  background:linear-gradient(135deg,#38bdf8,#0891b2);
  color:#fff;
  box-shadow:0 4px 14px rgba(14,165,233,.45);
}
.om-theme-main .om-range{
  background:linear-gradient(90deg,#38bdf8 0%,#38bdf8 var(--p,30%),rgba(255,255,255,.12) var(--p,30%));
}
.om-theme-main .om-range::-webkit-slider-thumb{
  background:linear-gradient(135deg,#7dd3fc,#0ea5e9);
  box-shadow:0 4px 14px rgba(14,165,233,.5);
}
.om-theme-main .om-range::-moz-range-thumb{
  background:linear-gradient(135deg,#7dd3fc,#0ea5e9);
  box-shadow:0 4px 14px rgba(14,165,233,.5);
}
.om-theme-main .om-range-val{
  background:linear-gradient(135deg,#bae6fd,#0ea5e9);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}
.om-theme-main .om-submit{
  background:linear-gradient(135deg,#0ea5e9,#0891b2);
  color:#fff;
  box-shadow:0 8px 24px rgba(14,165,233,.42);
}
.om-theme-main .om-submit:hover:not(:disabled){
  box-shadow:0 12px 36px rgba(14,165,233,.6);
}
.om-theme-main .om-check{
  background:linear-gradient(135deg,#38bdf8,#0891b2);
  box-shadow:0 14px 40px rgba(14,165,233,.5);
}
.om-theme-main .om-check svg{stroke:#fff!important}
.om-theme-main .om-check::before{border-color:rgba(125,211,252,.3)}

/* Telegram-only contact field — slide-in animation */
.om-field-msg-contact:not([hidden]){
  animation:om-slide-in .35s cubic-bezier(.16,1,.3,1);
}
@keyframes om-slide-in{
  from{opacity:0;transform:translateY(-8px);max-height:0;margin-bottom:0;overflow:hidden}
  to{opacity:1;transform:translateY(0);max-height:120px;margin-bottom:18px}
}
