*{margin:0;padding:0;box-sizing:border-box}
body{min-height:100vh;font-family:Georgia,"Times New Roman",serif;background:radial-gradient(circle at top left,rgba(116,221,231,.30),transparent 36%),radial-gradient(circle at bottom right,rgba(68,188,205,.20),transparent 38%),linear-gradient(180deg,#effdff 0%,#fff 45%,#def8fb 100%);color:#173f46;overflow-x:hidden}
.page-pattern{position:fixed;inset:0;background-image:url("logo.jpg");background-size:92px;background-repeat:repeat;opacity:.045;pointer-events:none;z-index:0}
.hero{position:relative;z-index:1;width:100%;box-shadow:0 24px 60px rgba(39,160,176,.22)}
.hero img{display:block;width:100%;max-height:360px;object-fit:cover}
.main{position:relative;z-index:1;max-width:1040px;margin:0 auto;padding:70px 20px 110px;text-align:center}
.card{max-width:640px;margin:0 auto;padding:56px 28px 62px;border:1px solid rgba(255,255,255,.88);border-radius:36px;background:rgba(255,255,255,.66);box-shadow:0 30px 90px rgba(32,147,163,.20);backdrop-filter:blur(18px)}
.brand-mark{width:86px;height:86px;margin:0 auto 26px;border-radius:50%;overflow:hidden;box-shadow:0 16px 40px rgba(34,156,173,.28)}
.brand-mark img{width:100%;height:100%;object-fit:cover}
.eyebrow{font-size:15px;letter-spacing:4px;text-transform:uppercase;color:#2a9daf;margin-bottom:16px;font-weight:bold}
h1{font-size:clamp(56px,11vw,110px);line-height:.9;color:#207d8c;letter-spacing:10px;text-shadow:0 12px 36px rgba(33,150,166,.18)}
.subtitle{margin-top:18px;margin-bottom:42px;font-size:22px;font-style:italic;color:#5a9da7}
.work-button{display:inline-flex;align-items:center;justify-content:center;min-width:260px;min-height:64px;border-radius:999px;text-decoration:none;color:white;font-size:22px;letter-spacing:4px;background:linear-gradient(135deg,#75dce7 0%,#2ca3b4 100%);border:1px solid rgba(255,255,255,.86);box-shadow:0 18px 42px rgba(38,156,174,.42);transition:.25s}
.work-button:hover{transform:translateY(-4px);box-shadow:0 24px 60px rgba(38,156,174,.55)}
.support-note{margin-top:34px;color:#5a9da7;font-size:17px}
.support-inline{margin-top:12px;padding:13px 24px;border-radius:999px;border:1px solid rgba(42,157,175,.24);background:rgba(255,255,255,.78);color:#207d8c;cursor:pointer;font-size:15px}
.chat-float{position:fixed;right:22px;bottom:22px;z-index:6;border:none;border-radius:999px;padding:16px 24px;color:white;font-size:16px;cursor:pointer;background:linear-gradient(135deg,#75dce7,#2a9daf);box-shadow:0 16px 38px rgba(38,156,174,.45)}
.chat-panel{position:fixed;right:22px;bottom:86px;z-index:7;width:380px;max-width:calc(100vw - 28px);height:540px;max-height:calc(100vh - 110px);display:none;flex-direction:column;border-radius:28px;overflow:hidden;background:rgba(255,255,255,.96);box-shadow:0 30px 90px rgba(0,0,0,.24);border:1px solid rgba(255,255,255,.8)}
.chat-panel.active{display:flex}
.chat-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;background:linear-gradient(135deg,#75dce7,#2a9daf);color:white}
.chat-head b{display:block;font-size:18px}.chat-head span{display:block;font-size:12px;opacity:.9;margin-top:3px}.chat-head button{border:0;background:transparent;color:white;font-size:30px;cursor:pointer}
.chat-body{flex:1;overflow-y:auto;padding:18px;background:linear-gradient(rgba(255,255,255,.92),rgba(255,255,255,.92)),url("logo.jpg");background-size:84px}
.system-message{margin:0 auto 14px;padding:10px 12px;border-radius:14px;max-width:88%;text-align:center;font-size:13px;color:#5a8d95;background:#eefbfc}
.message{max-width:82%;margin-bottom:12px}.message.admin{margin-right:auto}.message.visitor{margin-left:auto;text-align:right}
.message-label{margin-bottom:4px;font-size:12px;color:#6a9ca4}.message-text{display:inline-block;padding:12px 14px;border-radius:18px;font-family:Arial,sans-serif;line-height:1.35;text-align:left;word-break:break-word}
.message.admin .message-text{color:#173f46;background:#eefbfc;border-bottom-left-radius:6px}.message.visitor .message-text{color:white;background:linear-gradient(135deg,#65d2de,#2a9daf);border-bottom-right-radius:6px}
.chat-form{display:flex;gap:8px;padding:12px;border-top:1px solid #d6f0f4;background:white}.chat-form input{flex:1;padding:14px;border-radius:999px;border:1px solid #c8edf2;outline:none;font-size:15px}.chat-form button{width:48px;height:48px;border:0;border-radius:50%;color:white;cursor:pointer;background:linear-gradient(135deg,#75dce7,#2a9daf)}
@media(max-width:640px){.hero img{max-height:240px}.main{padding:44px 14px 100px}.card{padding:38px 18px 46px;border-radius:28px}.work-button{width:100%}.chat-panel{right:14px;bottom:78px;width:calc(100vw - 28px)}}

.down-arrow{display:inline-block;margin-top:8px;font-size:36px;color:#2a9daf;animation:bounce 1.4s infinite}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(8px)}}

.work-button{flex-direction:column;gap:4px}
.work-subtitle{font-size:14px;opacity:.95}
.manual-button{display:inline-block;margin-top:14px;padding:14px 24px;border-radius:999px;border:1px solid rgba(42,157,175,.25);background:#fff;color:#207d8c;cursor:pointer}
.tiffany-footer{max-width:900px;margin:40px auto 0;text-align:center;line-height:1.7;color:#245d66}

.paygrid-button{
  display:inline-block;
  margin-top:14px;
  padding:14px 24px;
  border-radius:999px;
  border:1px solid rgba(42,157,175,.25);
  background:rgba(255,255,255,.88);
  color:#207d8c;
  cursor:pointer;
  font-family:Georgia,"Times New Roman",serif;
  font-size:16px;
  letter-spacing:1px;
  box-shadow:0 14px 34px rgba(32,147,163,.14);
  transition:.25s;
}
.paygrid-button:hover{
  transform:translateY(-3px);
  background:rgba(255,255,255,.98);
}
.paygrid-modal{
  position:fixed;
  inset:0;
  z-index:30;
  display:none;
  align-items:center;
  justify-content:center;
  padding:18px;
  background:rgba(10,44,50,.48);
  backdrop-filter:blur(9px);
}
.paygrid-modal.active{
  display:flex;
}
.paygrid-window{
  position:relative;
  width:100%;
  max-width:900px;
  max-height:88vh;
  overflow:auto;
  padding:34px;
  border-radius:30px;
  background:rgba(255,255,255,.96);
  border:1px solid rgba(255,255,255,.9);
  box-shadow:0 30px 90px rgba(0,0,0,.28);
  text-align:center;
}
.paygrid-window h2{
  margin-bottom:22px;
  color:#207d8c;
  font-size:28px;
  letter-spacing:1px;
}
.paygrid-window img{
  max-width:100%;
  height:auto;
  border-radius:18px;
  box-shadow:0 20px 55px rgba(32,147,163,.20);
}
.paygrid-close{
  position:absolute;
  top:14px;
  right:18px;
  border:0;
  background:transparent;
  color:#2a9daf;
  font-size:34px;
  cursor:pointer;
}
@media(max-width:640px){
  .paygrid-button{
    width:100%;
  }
  .paygrid-window{
    padding:30px 16px;
  }
}

/* HARD FIX: buttons under WORK button */
.action-buttons{
  width:100%;
  margin-top:18px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:12px;
}
.paygrid-button,
.manual-button{
  width:100%;
  max-width:360px;
  min-height:54px;
  padding:14px 22px;
  border-radius:999px;
  border:1px solid rgba(42,157,175,.35);
  background:rgba(255,255,255,.92);
  color:#207d8c;
  cursor:pointer;
  font-family:Georgia,"Times New Roman",serif;
  font-size:16px;
  letter-spacing:1px;
  box-shadow:0 14px 34px rgba(32,147,163,.16);
  transition:.25s;
}
.paygrid-button:hover,
.manual-button:hover{
  transform:translateY(-3px);
  background:rgba(255,255,255,1);
}
