
/* =========================================================
   Aden Technical Systems (vNext)
   Futuristic AI + gold accents, uses Canva assets
   ========================================================= */

:root{
  --bg0:#060B16;
  --bg1:#0B132B;
  --bg2:#0F1E34;
  --panel: rgba(12, 24, 40, 0.62);
  --panel2: rgba(18, 34, 54, 0.60);

  --text:#EAF2FF;
  --muted: rgba(234,242,255,.72);

  --cyan:#00D4FF;
  --cyan2:#00A5E3;
  --gold:#D4AF37;

  --radius: 16px;
  --radius2: 22px;

  --shadow: 0 30px 90px rgba(0,0,0,.55);

  --container: 1180px;

  /* Assets */
  --hero-bg: url("assets/hero-bg-kinetic.png");
  --card-bg: url("assets/service-card-bg.png");
  --badge-time: url("assets/badge-time-saved.png");
  --badge-reliability: url("assets/badge-reliability.png");
}

*{ box-sizing: border-box; }
html, body{ height:100%; }
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color: var(--text);
  background: radial-gradient(1200px 800px at 20% 10%, rgba(0,212,255,.10), transparent 55%),
              radial-gradient(900px 700px at 90% 30%, rgba(212,175,55,.07), transparent 60%),
              linear-gradient(180deg, var(--bg0), var(--bg1) 45%, #050A13 100%);
  overflow-x: hidden;
}

a{ color: inherit; text-decoration: none; }
img{ max-width: 100%; display:block; }

.container{
  width: min(var(--container), calc(100% - 44px));
  margin: 0 auto;
}

/* subtle film grain */
.noise{
  position: fixed;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='240' height='240'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='240' height='240' filter='url(%23n)' opacity='.12'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
  pointer-events:none;
  opacity:.18;
  z-index: 1;
}

.cursor-glow{
  position: fixed;
  width: 520px;
  height: 520px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(0,212,255,.16), rgba(0,212,255,0) 60%);
  transform: translate(-50%, -50%);
  pointer-events:none;
  z-index: 2;
  opacity: .9;
  filter: blur(0px);
}

/* Header */
.site-header{
  position: sticky;
  top:0;
  z-index: 50;
  backdrop-filter: blur(10px);
  background: rgba(6,11,22,.55);
  border-bottom: 1px solid rgba(0,165,227,.18);
}

.site-header.is-scrolled{
  background: rgba(6,11,22,.75);
  border-bottom-color: rgba(0,212,255,.22);
}

.nav{
  display:flex;
  align-items:center;
  justify-content: space-between;
  padding: 14px 0;
  position: relative;
  z-index: 3;
}

.brand{
  display:flex;
  gap: 12px;
  align-items:center;
}

.brand-icon{
  filter: drop-shadow(0 0 14px rgba(0,212,255,.22))
          drop-shadow(0 0 7px rgba(212,175,55,.12));
}

.brand-text{ display:flex; flex-direction: column; line-height: 1.05; }
.brand-name{ font-weight: 700; letter-spacing:.02em; }
.brand-tag{ font-size:.78rem; color: var(--muted); margin-top: 3px; }

.nav-links{
  display:flex;
  gap: 18px;
  align-items:center;
  font-weight: 600;
  color: rgba(234,242,255,.85);
}

.nav-links a{
  padding: 10px 10px;
  border-radius: 999px;
  transition: background .2s ease, color .2s ease;
}

.nav-links a:hover{
  background: rgba(0,212,255,.10);
  color: var(--text);
}

.nav-cta{
  border: 1px solid rgba(212,175,55,.35);
  background: linear-gradient(180deg, rgba(212,175,55,.18), rgba(212,175,55,.06));
}

.nav-toggle{
  display:none;
  border: 1px solid rgba(0,165,227,.22);
  background: rgba(12,24,40,.55);
  border-radius: 12px;
  width: 46px;
  height: 42px;
  cursor: pointer;
}

.nav-toggle span{
  display:block;
  height: 2px;
  background: rgba(234,242,255,.85);
  margin: 7px 10px;
  border-radius: 99px;
}

/* Hero */
.hero{
  position: relative;
  padding: 84px 0 56px;
  overflow: hidden;
  z-index: 3;
}

.hero-bg{
  position:absolute;
  inset:-80px -60px -60px -60px;
  background:
    radial-gradient(circle at 25% 25%, rgba(0,212,255,.18), transparent 55%),
    radial-gradient(circle at 75% 70%, rgba(212,175,55,.10), transparent 60%),
    linear-gradient(180deg, rgba(6,11,22,.80), rgba(6,11,22,.92)),
    var(--hero-bg) center/cover no-repeat;
  filter: saturate(1.0) contrast(1.1) brightness(0.92);
  transform: translateZ(0);
}

.hero-fade{
  position:absolute;
  left:0; right:0; bottom:-1px;
  height: 120px;
  background: linear-gradient(180deg, rgba(6,11,22,0), rgba(6,11,22,1));
  z-index: 2;
}

.hero-inner{
  position: relative;
  z-index: 4;
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 34px;
  align-items: center;
}

.hero-badge{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid rgba(0,165,227,.22);
  background: rgba(12,24,40,.55);
  color: rgba(234,242,255,.85);
}

.hero-badge .dot{
  width: 10px;
  height: 10px;
  border-radius: 99px;
  background: var(--cyan);
  box-shadow: 0 0 14px rgba(0,212,255,.55);
}

.hero-title{
  margin: 18px 0 10px;
  font-size: clamp(2.1rem, 3.6vw, 3.4rem);
  line-height: 1.05;
  letter-spacing: -0.02em;
}

.accent{
  color: var(--cyan);
  text-shadow: 0 0 24px rgba(0,212,255,.22);
}

.hero-subtitle{
  margin: 0 0 18px;
  color: var(--muted);
  font-size: 1.05rem;
  line-height: 1.6;
  max-width: 60ch;
}

.hero-actions{
  display:flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 10px;
}

.hero-stats{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 22px;
}

.stat{
  display:flex;
  gap: 12px;
  align-items:center;
  padding: 12px 12px;
  border-radius: var(--radius);
  border: 1px solid rgba(0,165,227,.18);
  background: rgba(12,24,40,.45);
}

.stat-value{ font-weight: 800; }
.stat-label{ color: var(--muted); font-size:.88rem; margin-top: 2px; }

/* Hero card */
.hero-card{
  position: relative;
  border-radius: var(--radius2);
  border: 1px solid rgba(0,165,227,.22);
  background: rgba(12,24,40,.58);
  box-shadow: var(--shadow);
  overflow:hidden;
  padding: 22px 18px 18px;
}

.hero-card-grid{
  position:absolute;
  inset:0;
  background:
    linear-gradient(transparent 0, transparent 24px, rgba(0,212,255,.10) 25px),
    linear-gradient(90deg, transparent 0, transparent 24px, rgba(0,212,255,.08) 25px);
  background-size: 25px 25px;
  opacity: .12;
  pointer-events:none;
}

.hero-card-glow{
  position:absolute;
  inset:-30%;
  background:
    radial-gradient(circle at 30% 25%, rgba(0,212,255,.26), rgba(0,0,0,0) 55%),
    radial-gradient(circle at 70% 75%, rgba(212,175,55,.14), rgba(0,0,0,0) 62%);
  opacity: .9;
  pointer-events:none;
}

.hero-logo{
  width: min(360px, 100%);
  margin: 0 auto 14px;
  animation: floaty 8s ease-in-out infinite;
  filter: drop-shadow(0 0 18px rgba(0,212,255,.30))
          drop-shadow(0 0 6px rgba(212,175,55,.12));
}

@keyframes floaty{
  0%,100%{ transform: translateY(0); }
  50%{ transform: translateY(-10px); }
}

.hero-card-copy{ position: relative; z-index: 1; }
.mini-title{ font-weight: 800; letter-spacing:.02em; margin-bottom: 10px; }
.mini-list{
  margin:0 0 14px;
  padding-left: 18px;
  color: rgba(234,242,255,.88);
  line-height: 1.75;
}

.hero-card-cta{
  display:flex;
  justify-content: space-between;
  gap: 12px;
  position: relative;
  z-index: 1;
}

/* Sections */
.section{ padding: 74px 0; position: relative; z-index: 3; }
.section-alt{
  background: radial-gradient(1000px 700px at 20% 20%, rgba(0,212,255,.08), transparent 60%),
              radial-gradient(1000px 700px at 80% 60%, rgba(212,175,55,.06), transparent 62%),
              linear-gradient(180deg, rgba(6,11,22,.0), rgba(6,11,22,.55));
  border-top: 1px solid rgba(0,165,227,.14);
  border-bottom: 1px solid rgba(0,165,227,.14);
}

.section-head{
  margin-bottom: 26px;
}
.section-head h2{
  margin: 0 0 10px;
  font-size: clamp(1.6rem, 2.4vw, 2.2rem);
  letter-spacing: -0.02em;
}
.section-head p{
  margin: 0;
  color: var(--muted);
  max-width: 80ch;
  line-height: 1.65;
}

/* Cards */
.cards{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.card{
  position: relative;
  padding: 22px 18px;
  border-radius: var(--radius);
  border: 1px solid rgba(0,165,227,.18);
  background:
    linear-gradient(180deg, rgba(12,24,40,.78), rgba(12,24,40,.58)),
    var(--card-bg) center/cover no-repeat;
  overflow: hidden;
  box-shadow: 0 18px 45px rgba(0,0,0,.35);
}
.card::before{
  content:"";
  position:absolute;
  inset:0;
  background: radial-gradient(circle at 30% 20%, rgba(0,212,255,.16), transparent 55%);
  opacity: .9;
  pointer-events:none;
}
.card.featured{
  border-color: rgba(212,175,55,.35);
  box-shadow: 0 24px 70px rgba(0,0,0,.52);
}
.card h3{ margin:0 0 8px; }
.card p{ margin:0 0 14px; color: var(--muted); line-height: 1.65; }
.bullets{ margin:0; padding-left: 18px; color: rgba(234,242,255,.9); line-height: 1.8; }

/* Portfolio */
.portfolio-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.pf{
  border-radius: var(--radius2);
  border: 1px solid rgba(0,165,227,.18);
  background: rgba(12,24,40,.45);
  box-shadow: 0 24px 60px rgba(0,0,0,.45);
  overflow:hidden;
}
.pf-media{
  position: relative;
  aspect-ratio: 16/9;
  overflow:hidden;
}
.pf-media img{
  width:100%;
  height:100%;
  object-fit: cover;
  transform: scale(1.02);
  transition: transform 650ms ease, filter 650ms ease;
  filter: saturate(1.10) contrast(1.08);
}
.pf:hover .pf-media img{
  transform: scale(1.08);
  filter: saturate(1.18) contrast(1.12);
}
.pf-glow{
  position:absolute;
  inset:-25%;
  background:
    radial-gradient(circle at 30% 30%, rgba(0,212,255,.22), transparent 55%),
    radial-gradient(circle at 70% 70%, rgba(212,175,55,.10), transparent 62%);
  pointer-events:none;
}
.pf-body{ padding: 18px 18px 20px; }
.pf-body h3{ margin:0 0 8px; }
.pf-body p{ margin:0 0 14px; color: var(--muted); line-height: 1.6; }
.pf-tags{ display:flex; flex-wrap: wrap; gap: 8px; margin-bottom: 14px; }
.pf-tags span{
  font-size: .82rem;
  padding: 7px 10px;
  border-radius: 999px;
  border: 1px solid rgba(0,165,227,.16);
  background: rgba(12,24,40,.55);
  color: rgba(234,242,255,.86);
}

/* Process steps */
.steps{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.step{
  border-radius: var(--radius2);
  border: 1px solid rgba(0,165,227,.16);
  background: rgba(12,24,40,.50);
  padding: 18px 18px 20px;
}
.step-num{
  font-weight: 900;
  letter-spacing: .08em;
  color: rgba(212,175,55,.9);
  margin-bottom: 8px;
}
.step h3{ margin:0 0 8px; }
.step p{ margin:0; color: var(--muted); line-height: 1.65; }

/* Contact */
.contact-grid{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 16px;
  align-items: start;
}
.form{
  border-radius: var(--radius2);
  border: 1px solid rgba(0,165,227,.18);
  background: rgba(12,24,40,.55);
  padding: 18px 18px 20px;
  box-shadow: 0 24px 70px rgba(0,0,0,.45);
}
.form-row{ display:flex; flex-direction: column; gap: 8px; margin-bottom: 14px; }
label{ font-weight: 700; color: rgba(234,242,255,.92); }
input, select, textarea{
  border-radius: 12px;
  border: 1px solid rgba(0,165,227,.22);
  background: rgba(6,11,22,.55);
  color: var(--text);
  padding: 12px 12px;
  outline: none;
}
input:focus, select:focus, textarea:focus{
  border-color: rgba(0,212,255,.55);
  box-shadow: 0 0 0 3px rgba(0,212,255,.12);
}
textarea{ resize: vertical; }

.hp{ display:none; }

.form-note{
  color: var(--muted);
  margin: 12px 0 0;
  line-height: 1.6;
}
.link{
  background: none;
  border: none;
  color: var(--cyan);
  cursor: pointer;
  padding: 0;
  font-weight: 700;
}

.form-status{
  margin-top: 12px;
  color: rgba(234,242,255,.9);
}

/* Right panel */
.contact-panel{
  border-radius: var(--radius2);
  border: 1px solid rgba(0,165,227,.16);
  background: rgba(12,24,40,.40);
  padding: 18px 18px 20px;
}
.contact-divider{
  height: 1px;
  background: rgba(0,165,227,.16);
  margin: 14px 0;
}
.tag-grid{ display:flex; flex-wrap: wrap; gap: 8px; }
.tag{
  font-size: .84rem;
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid rgba(212,175,55,.25);
  background: rgba(212,175,55,.06);
  color: rgba(234,242,255,.88);
}

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  border-radius: 999px;
  padding: 12px 14px;
  font-weight: 800;
  letter-spacing: .01em;
  cursor: pointer;
  border: 1px solid rgba(0,165,227,.22);
  background: rgba(12,24,40,.50);
  transition: transform .12s ease, background .2s ease, border-color .2s ease;
}
.btn:hover{ transform: translateY(-1px); border-color: rgba(0,212,255,.45); background: rgba(12,24,40,.68); }
.btn:active{ transform: translateY(0); }

.btn-primary{
  border-color: rgba(0,212,255,.45);
  background: linear-gradient(180deg, rgba(0,212,255,.22), rgba(0,165,227,.08));
  box-shadow: 0 18px 40px rgba(0,212,255,.10);
}
.btn-secondary{
  border-color: rgba(212,175,55,.28);
  background: linear-gradient(180deg, rgba(212,175,55,.14), rgba(212,175,55,.05));
}
.btn-small{ padding: 10px 12px; font-weight: 800; }
.btn-ghost{
  background: rgba(6,11,22,.35);
}
.btn-gold{
  border-color: rgba(212,175,55,.45);
  background: linear-gradient(180deg, rgba(212,175,55,.22), rgba(212,175,55,.06));
}

/* Badges */
.badge-icon{
  width: 44px;
  height: 44px;
  flex: 0 0 44px;
  display:inline-block;
  background-size: contain;
  background-repeat:no-repeat;
  background-position:center;
  filter: drop-shadow(0 0 10px rgba(0,212,255,.18));
}
.badge-time{ background-image: var(--badge-time); }
.badge-reliability{ background-image: var(--badge-reliability); }

/* Modals */
.modal{
  position: fixed;
  inset: 0;
  display: none;
  z-index: 9999;
}
.modal[aria-hidden="false"]{ display:block; }
.modal-backdrop{
  position:absolute; inset:0;
  background: rgba(0,0,0,.72);
  backdrop-filter: blur(6px);
}
.modal-panel{
  position: relative;
  width: min(920px, calc(100% - 32px));
  margin: 56px auto;
  border-radius: var(--radius2);
  border: 1px solid rgba(0,165,227,.22);
  background: rgba(6,11,22,.86);
  box-shadow: 0 35px 120px rgba(0,0,0,.65);
  overflow: hidden;
  padding: 18px;
}
.modal-panel-wide{ width: min(1120px, calc(100% - 32px)); padding: 0; }
.modal-close{
  position:absolute;
  top: 14px; right: 14px;
  width: 42px; height: 42px;
  border-radius: 999px;
  border: 1px solid rgba(0,165,227,.22);
  background: rgba(12,24,40,.55);
  color: var(--text);
  cursor: pointer;
}
.modal-title{ margin: 8px 8px 0; }
.modal-subtitle{ margin: 8px 8px 14px; color: var(--muted); }
.modal-iframe{ height: min(70vh, 640px); border-radius: 16px; overflow:hidden; border: 1px solid rgba(0,165,227,.18); }
.modal-iframe iframe{ width:100%; height:100%; border: 0; background: #000; }

/* Portfolio modal */
.pf-modal{
  display:grid;
  grid-template-columns: 1.25fr 1fr;
  gap: 0;
}
.pf-modal-media{
  background: rgba(0,0,0,.25);
}
.pf-modal-media img{
  width:100%;
  height:100%;
  max-height: 640px;
  object-fit: cover;
  display:block;
}
.pf-modal-body{
  padding: 24px;
}
.pf-modal-title{ margin:0 0 8px; }
.pf-modal-summary{ margin:0 0 14px; color: var(--muted); line-height: 1.65; }

.pf-modal-grid{
  display:grid;
  gap: 12px;
}
.pf-block{
  border-radius: 16px;
  border: 1px solid rgba(0,165,227,.16);
  background: rgba(12,24,40,.45);
  padding: 14px;
}
.pf-block h4{
  margin:0 0 10px;
  color: var(--cyan);
  letter-spacing:.02em;
}
.pf-block ul{
  margin:0;
  padding-left: 18px;
  line-height: 1.75;
  color: rgba(234,242,255,.9);
}
.pf-modal-cta{
  display:flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 14px;
}

/* Footer */
.footer{
  padding: 22px 0;
  border-top: 1px solid rgba(0,165,227,.14);
  background: rgba(6,11,22,.55);
  position: relative;
  z-index: 3;
}
.footer-inner{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 16px;
  color: var(--muted);
}
.footer-left{ display:flex; align-items:center; gap: 10px; }
.footer a{ color: rgba(234,242,255,.82); }
.footer a:hover{ color: var(--cyan); }

/* Reveal animations */
.reveal{
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 650ms ease, transform 650ms ease;
}
.reveal.is-visible{
  opacity: 1;
  transform: translateY(0);
}

/* Responsive */
@media (max-width: 980px){
  .hero-inner{ grid-template-columns: 1fr; }
  .cards{ grid-template-columns: 1fr; }
  .portfolio-grid{ grid-template-columns: 1fr; }
  .steps{ grid-template-columns: 1fr; }
  .contact-grid{ grid-template-columns: 1fr; }
  .nav-links{
    position: absolute;
    top: 62px;
    right: 0;
    left: 0;
    display:none;
    flex-direction: column;
    gap: 8px;
    padding: 14px;
    background: rgba(6,11,22,.92);
    border-bottom: 1px solid rgba(0,165,227,.18);
  }
  .nav-links.is-open{ display:flex; }
  .nav-toggle{ display:block; }
  .nav-cta{ width: 100%; text-align:center; }
  .pf-modal{ grid-template-columns: 1fr; }
  .modal-panel-wide{ padding: 0; }
}


/* =========================================================
   CHATBOT WIDGET (n8n)
   Floating button + panel (Aden vNext)
   ========================================================= */

.chatbot-fab{
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 9998;
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 12px 14px 12px 12px;
  border-radius: 999px;
  border: 1px solid rgba(0,212,255,.28);
  background: rgba(8,14,26,.72);
  backdrop-filter: blur(10px);
  color: rgba(234,242,255,.92);
  cursor: pointer;
  box-shadow: 0 22px 70px rgba(0,0,0,.55);
  transition: transform .12s ease, border-color .2s ease, background .2s ease;
}
.chatbot-fab:hover{
  transform: translateY(-2px);
  border-color: rgba(212,175,55,.38);
  background: rgba(8,14,26,.86);
}
.chatbot-fab-ring{
  position:absolute;
  inset:-6px;
  border-radius: 999px;
  background:
    radial-gradient(circle at 30% 30%, rgba(0,212,255,.28), rgba(0,0,0,0) 55%),
    radial-gradient(circle at 70% 70%, rgba(212,175,55,.18), rgba(0,0,0,0) 62%);
  filter: blur(6px);
  opacity: .65;
  pointer-events:none;
}
.chatbot-fab-icon{
  width: 38px;
  height: 38px;
  border-radius: 14px;
  border: 1px solid rgba(0,165,227,.22);
  background: rgba(12,24,40,.55);
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}
.chatbot-fab-icon img{
  width: 26px;
  height: 26px;
  filter: drop-shadow(0 0 10px rgba(0,212,255,.22));
}
.chatbot-fab-text{
  font-weight: 900;
  letter-spacing: .02em;
}

.chatbot{
  position: fixed;
  inset: 0;
  display:none;
  z-index: 9999;
}
.chatbot[aria-hidden="false"]{ display:block; }

.chatbot-backdrop{
  position:absolute;
  inset:0;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(4px);
}

.chatbot-panel{
  position:absolute;
  right: 18px;
  bottom: 78px;
  width: min(420px, calc(100% - 36px));
  max-height: min(620px, calc(100vh - 120px));
  display:flex;
  flex-direction: column;
  border-radius: 22px;
  border: 1px solid rgba(0,212,255,.22);
  background:
    radial-gradient(800px 400px at 20% 0%, rgba(0,212,255,.12), transparent 55%),
    radial-gradient(800px 400px at 80% 100%, rgba(212,175,55,.08), transparent 62%),
    rgba(6,11,22,.92);
  box-shadow: 0 35px 120px rgba(0,0,0,.70);
  overflow:hidden;
}

.chatbot-header{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px;
  border-bottom: 1px solid rgba(0,165,227,.16);
}

.chatbot-title{
  display:flex;
  align-items:center;
  gap: 10px;
}
.chatbot-dot{
  width: 10px;
  height: 10px;
  border-radius: 99px;
  background: var(--cyan);
  box-shadow: 0 0 18px rgba(0,212,255,.55);
}
.chatbot-name{ font-weight: 900; }
.chatbot-sub{ font-size: .82rem; color: var(--muted); margin-top: 2px; }

.chatbot-close{
  width: 42px;
  height: 42px;
  border-radius: 999px;
  border: 1px solid rgba(0,165,227,.22);
  background: rgba(12,24,40,.55);
  color: rgba(234,242,255,.92);
  cursor: pointer;
}

.chatbot-body{
  padding: 14px;
  overflow:auto;
  display:flex;
  flex-direction: column;
  gap: 10px;
}

.chatbot-msg{ display:flex; }
.chatbot-msg.user{ justify-content: flex-end; }
.chatbot-msg.bot{ justify-content: flex-start; }

.chatbot-msg .bubble{
  max-width: 86%;
  padding: 10px 12px;
  border-radius: 16px;
  border: 1px solid rgba(0,165,227,.14);
  background: rgba(12,24,40,.50);
  color: rgba(234,242,255,.92);
  line-height: 1.55;
}

.chatbot-msg.user .bubble{
  border-color: rgba(212,175,55,.22);
  background: linear-gradient(180deg, rgba(212,175,55,.14), rgba(212,175,55,.05));
}

.chatbot-input{
  display:flex;
  gap: 10px;
  padding: 12px;
  border-top: 1px solid rgba(0,165,227,.16);
  background: rgba(6,11,22,.70);
}
.chatbot-input input{
  flex: 1 1 auto;
  border-radius: 14px;
  border: 1px solid rgba(0,165,227,.22);
  background: rgba(6,11,22,.55);
  padding: 12px;
  color: var(--text);
}
.chatbot-send{
  flex: 0 0 auto;
  border-radius: 14px;
  border: 1px solid rgba(0,212,255,.45);
  background: linear-gradient(180deg, rgba(0,212,255,.22), rgba(0,165,227,.08));
  color: rgba(234,242,255,.95);
  font-weight: 900;
  padding: 12px 14px;
  cursor: pointer;
}

.chatbot-footer{
  display:flex;
  justify-content: space-between;
  align-items:center;
  padding: 10px 12px;
  border-top: 1px solid rgba(0,165,227,.12);
  color: var(--muted);
  font-size: .82rem;
}
.chatbot-link{
  background: none;
  border: none;
  color: rgba(212,175,55,.95);
  font-weight: 900;
  cursor: pointer;
  padding: 6px 8px;
  border-radius: 10px;
}
.chatbot-link:hover{
  background: rgba(212,175,55,.08);
}

@media (max-width: 520px){
  .chatbot-panel{ right: 10px; left: 10px; width: auto; }
  .chatbot-fab{ right: 10px; bottom: 10px; }
}


/* =========================================================
   PORTFOLIO MODAL: Fit + sizing fixes
   ========================================================= */
.modal-panel.modal-panel-wide{
  max-height: calc(100vh - 72px);
  overflow: hidden;
}
.pf-modal{
  height: calc(100vh - 108px);
}
.pf-modal-media{
  display:flex;
  align-items:center;
  justify-content:center;
  max-height: calc(100vh - 108px);
}
.pf-modal-media img{
  width: 100%;
  height: 100%;
  max-height: calc(100vh - 108px);
  object-fit: contain;
  display:block;
}
.pf-modal-body{
  max-height: calc(100vh - 108px);
  overflow: auto;
}

@media (max-width: 980px){
  .modal-panel.modal-panel-wide{
    max-height: calc(100vh - 32px);
    overflow: auto;
  }
  .pf-modal{ height: auto; }
  .pf-modal-body{ max-height: none; overflow: visible; }
  .pf-modal-media{ max-height: 55vh; }
  .pf-modal-media img{ height: 55vh; max-height: 55vh; }
}


/* =========================================================
   BOOKING CALENDAR STYLES (v4)
   ========================================================= */

/* Make booking modal scrollable */
.modal[aria-hidden="false"] .modal-panel {
  max-height: 85vh;
  overflow-y: auto;
}

.booking-step {
  padding: 0;
}

.booking-form {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

/* Calendar Loading */
.calendar-loading {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 3rem 1rem;
  gap: 1rem;
}

.spinner {
  width: 40px;
  height: 40px;
  border: 3px solid rgba(0, 246, 255, 0.1);
  border-top-color: #00f6ff;
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

.calendar-error {
  padding: 1.5rem;
  background: rgba(255, 82, 82, 0.1);
  border: 1px solid rgba(255, 82, 82, 0.3);
  border-radius: 8px;
  color: #ff5252;
  text-align: center;
  margin: 1rem 0;
}

/* Calendar Grid */
.calendar-grid {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  padding: 0.5rem 0;
  max-height: 400px;
  overflow-y: auto;
}

.calendar-date-group {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.calendar-date-header {
  font-size: 0.875rem;
  font-weight: 600;
  color: #00f6ff;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid rgba(0, 246, 255, 0.2);
}

.calendar-slots-row {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
  gap: 0.75rem;
}

.calendar-slot-btn {
  padding: 0.75rem 1rem;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 6px;
  color: #fff;
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
  text-align: center;
}

.calendar-slot-btn:hover {
  background: rgba(0, 246, 255, 0.1);
  border-color: rgba(0, 246, 255, 0.4);
  transform: translateY(-2px);
}

.calendar-slot-btn.selected {
  background: rgba(0, 246, 255, 0.2);
  border-color: #00f6ff;
  box-shadow: 0 0 20px rgba(0, 246, 255, 0.3);
}

/* Confirmation Step */
.booking-confirm {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 1rem 0;
}

.confirm-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.75rem 1rem;
  background: rgba(255, 255, 255, 0.03);
  border-radius: 6px;
  border: 1px solid rgba(255, 255, 255, 0.1);
}

.confirm-row-highlight {
  background: rgba(0, 246, 255, 0.1);
  border-color: rgba(0, 246, 255, 0.3);
}

.confirm-label {
  font-size: 0.875rem;
  color: rgba(255, 255, 255, 0.6);
  font-weight: 500;
}

.confirm-value {
  font-size: 0.9375rem;
  color: #fff;
  font-weight: 600;
  text-align: right;
}

.booking-actions {
  display: flex;
  gap: 1rem;
  margin-top: 1.5rem;
}

/* Mobile Responsive */
@media (max-width: 640px) {
  .calendar-slots-row {
    grid-template-columns: repeat(auto-fill, minmax(80px, 1fr));
    gap: 0.5rem;
  }
  
  .calendar-slot-btn {
    padding: 0.625rem 0.75rem;
    font-size: 0.8125rem;
  }
  
  .booking-actions {
    flex-direction: column;
  }
  
  .confirm-row {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.25rem;
  }
  
  .confirm-value {
    text-align: left;
  }
}
