/* Global helpers */
.app{ position: relative; overflow-x:hidden; }
.skip-link{
  position:absolute; left:-999px; top:12px; z-index:9999;
  background:#fff; color:#000; padding:10px 12px; border-radius:12px;
}
.skip-link:focus{ left:12px; }

.text-muted{ color: var(--muted) !important; }
.link-soft{ color: var(--champagne); text-decoration: none; border-bottom: 1px dashed rgba(215,185,138,.35); }
.link-soft:hover{ border-bottom-color: rgba(215,185,138,.7); }

.req{ color: var(--sakura); font-weight: 700; }

/* Decorative layers */
.silk{
  position:absolute; inset:-240px -240px auto -240px;
  height: 520px;
  background:
    radial-gradient(380px 240px at 25% 20%, rgba(215,185,138,.22), transparent 65%),
    radial-gradient(380px 260px at 70% 40%, rgba(121,183,255,.12), transparent 70%),
    radial-gradient(420px 300px at 55% 75%, rgba(46,209,167,.10), transparent 70%);
  filter: blur(12px);
  opacity: .9;
  pointer-events:none;
  z-index:0;
}
.halo{
  position:absolute; width: 520px; height: 520px; border-radius: 999px;
  filter: blur(46px);
  opacity: .55;
  pointer-events:none;
  z-index:0;
}
.halo--gold{ left:-140px; top: 220px; background: rgba(215,185,138,.22); }
.halo--jade{ right:-180px; top: 560px; background: rgba(46,209,167,.16); }
.halo--sakura{ left: 18%; top: 1040px; background: rgba(243,183,198,.14); }

.grain{
  position:absolute; inset:0; pointer-events:none; z-index:0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='180' height='180' filter='url(%23n)' opacity='.12'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
  opacity: .35;
}

/* Navbar */
.nav-glass{
  background: linear-gradient(180deg, rgba(7,10,15,.78), rgba(7,10,15,.48));
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(233,238,247,.10);
  z-index:10;
}
.navbar .nav-link{
  color: rgba(233,238,247,.82);
  position: relative;
}
.navbar .nav-link:hover{ color: rgba(233,238,247,.98); }
.navbar .nav-link::after{
  content:""; position:absolute; left:10px; right:10px; bottom:6px;
  height:1px; background: linear-gradient(90deg, transparent, rgba(215,185,138,.65), transparent);
  transform: scaleX(0);
  transform-origin:center;
  transition: transform .25s ease;
}
.navbar .nav-link:hover::after{ transform: scaleX(1); }

.btn-primary{
  background: linear-gradient(135deg, rgba(215,185,138,1), rgba(191,161,114,1));
  border: none;
  color: #0a0d14;
  box-shadow: 0 12px 28px rgba(215,185,138,.18);
}
.btn-primary:hover{ filter: brightness(1.03); }
.btn-outline-light{
  border-color: rgba(233,238,247,.22);
  color: rgba(233,238,247,.92);
}
.btn-outline-light:hover{
  background: rgba(233,238,247,.08);
  border-color: rgba(233,238,247,.30);
  color: rgba(233,238,247,1);
}

.badge-soft{
  background: rgba(215,185,138,.14);
  border: 1px solid rgba(215,185,138,.22);
  color: rgba(233,238,247,.92);
  font-weight: 600;
}

/* Brand mark */
.brand-mark{
  width: 28px; height: 28px; position:relative; display:inline-block;
}
.brand-mark__ring{
  position:absolute; inset:0;
  border-radius: 999px;
  border: 1px solid rgba(215,185,138,.9);
  box-shadow: 0 0 0 4px rgba(215,185,138,.08);
}
.brand-mark__tile{
  position:absolute; inset:7px;
  border-radius: 8px;
  background: linear-gradient(135deg, rgba(121,183,255,.28), rgba(46,209,167,.18));
  border: 1px solid rgba(233,238,247,.14);
}
.brand-mark__slash{
  position:absolute; left: 6px; right: 6px; top: 13px; height: 2px;
  background: rgba(243,183,198,.75);
  transform: rotate(-26deg);
  border-radius: 999px;
}
.brand-mark--sm{ width:22px; height:22px; }
.brand-mark--sm .brand-mark__tile{ inset:6px; border-radius:7px; }
.brand-mark--sm .brand-mark__slash{ left:5px; right:5px; top:10px; }

/* Hero */
.hero{
  position:relative;
  padding: 68px 0 0;
  z-index:1;
}
.eyebrow{
  letter-spacing: .12em;
  text-transform: uppercase;
  font-size: .82rem;
  color: rgba(233,238,247,.72);
}
.hero-title{
  line-height: 1.05;
}
.chips{ display:flex; flex-wrap:wrap; gap:10px; }
.chip{
  font-size: .85rem;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(233,238,247,.06);
  border: 1px solid rgba(233,238,247,.10);
}
.note{
  display:flex; gap:10px; align-items:flex-start;
  padding: 12px 14px;
  border-radius: var(--radius-lg);
  background: rgba(18,26,46,.32);
  border: 1px solid rgba(233,238,247,.10);
}
.note__dot{
  width:10px; height:10px; border-radius: 999px;
  margin-top: 5px;
  background: rgba(215,185,138,.85);
  box-shadow: 0 0 0 5px rgba(215,185,138,.12);
}
.note__text{ font-size: .95rem; }

.hero-frame{
  background: linear-gradient(180deg, rgba(16,22,36,.72), rgba(16,22,36,.50));
  border: 1px solid rgba(233,238,247,.14);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow);
  overflow:hidden;
  position:relative;
}
.hero-frame::before{
  content:"";
  position:absolute; inset:-2px;
  background: conic-gradient(from 220deg, rgba(215,185,138,.18), transparent 30%, rgba(46,209,167,.12), transparent 60%, rgba(243,183,198,.10));
  filter: blur(14px);
  opacity: .9;
  z-index:0;
}
.hero-frame > *{ position:relative; z-index:1; }

.hero-frame__top{
  display:flex; gap:10px; justify-content:space-between;
  padding: 16px 16px 0;
}
.hero-kpi{
  flex:1;
  padding: 12px 12px;
  border-radius: 16px;
  background: rgba(7,10,15,.35);
  border: 1px solid rgba(233,238,247,.12);
}
.hero-kpi__k{ font-size:.8rem; color: rgba(233,238,247,.70); }
.hero-kpi__v{ font-weight: 700; margin-top: 2px; }

.hero-frame__img{
  padding: 10px 16px 6px;
}
.hero-frame__img img{
  width:100%;
  border-radius: 16px;
  border: 1px solid rgba(233,238,247,.12);
  background: rgba(7,10,15,.25);
}
.hero-frame__bottom{
  display:flex; flex-wrap:wrap; gap:8px;
  padding: 0 16px 16px;
}
.mini-tag{
  font-size: .8rem;
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(233,238,247,.06);
  border: 1px solid rgba(233,238,247,.10);
}

/* Section cuts */
.cut{ display:block; width:100%; height: 90px; }
.cut path{ fill: rgba(18,26,46,.75); }
.cut--hero{ margin-top: 44px; }
.cut--hero path{ fill: rgba(18,26,46,.55); }
.cut--mid path{ fill: rgba(18,26,46,.60); }

/* Sections */
.section-pad{
  position:relative;
  padding: 74px 0;
  z-index:1;
}
.section-alt{
  background: linear-gradient(180deg, rgba(18,26,46,.55), rgba(18,26,46,.28));
  border-top: 1px solid rgba(233,238,247,.08);
  border-bottom: 1px solid rgba(233,238,247,.08);
}
.section-head{
  max-width: 860px;
}
.divider-soft{
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(233,238,247,.16), transparent);
}

/* Cards */
.card-geo{
  height:100%;
  padding: 18px 18px;
  border-radius: var(--radius-lg);
  background: var(--card);
  border: 1px solid rgba(233,238,247,.12);
  box-shadow: 0 16px 40px rgba(0,0,0,.22);
  position:relative;
  overflow:hidden;
}
.card-geo::after{
  content:"";
  position:absolute; inset:auto -20px -22px auto;
  width: 120px; height: 120px;
  background: radial-gradient(circle at 30% 30%, rgba(215,185,138,.28), transparent 60%);
  filter: blur(6px);
}
.card-geo__icon{
  width: 38px; height: 38px;
  border-radius: 14px;
  display:grid; place-items:center;
  background: rgba(215,185,138,.14);
  border: 1px solid rgba(215,185,138,.22);
  color: rgba(233,238,247,.92);
  margin-bottom: 10px;
}

/* Panels */
.panel{
  padding: 22px 22px;
  border-radius: var(--radius-xl);
  background: linear-gradient(180deg, rgba(16,22,36,.72), rgba(16,22,36,.52));
  border: 1px solid rgba(233,238,247,.12);
  box-shadow: var(--shadow);
  position:relative;
  overflow:hidden;
}
.panel--wide{
  border-top-left-radius: 34px;
  border-bottom-right-radius: 34px;
}
.panel--accent{
  background: linear-gradient(180deg, rgba(215,185,138,.16), rgba(16,22,36,.60));
  border: 1px solid rgba(215,185,138,.20);
}
.panel__cap{
  display:inline-flex;
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(233,238,247,.06);
  border: 1px solid rgba(233,238,247,.10);
  font-size: .82rem;
  color: rgba(233,238,247,.78);
  margin-bottom: 10px;
}

.pill{
  display:flex; gap:10px;
  padding: 12px 12px;
  border-radius: 18px;
  background: rgba(7,10,15,.30);
  border: 1px solid rgba(233,238,247,.10);
}
.pill__dot{
  width:10px; height:10px; border-radius: 999px;
  margin-top: 6px;
  background: rgba(46,209,167,.75);
  box-shadow: 0 0 0 5px rgba(46,209,167,.10);
}
.pill__t{ font-weight: 700; }
.pill__s{ font-size: .92rem; }

/* Stack */
.panel--stack{ padding: 20px; }
.stack{ display:flex; flex-direction:column; gap:10px; }
.stack__item{
  display:flex; align-items:center; gap:12px;
  padding: 12px 12px;
  border-radius: 18px;
  background: rgba(7,10,15,.30);
  border: 1px solid rgba(233,238,247,.10);
}
.stack__item img{
  width: 54px; height: 54px;
  border-radius: 14px;
  border: 1px solid rgba(233,238,247,.12);
  background: rgba(7,10,15,.25);
}
.stack__txt .small{ line-height: 1.25; }

/* Timeline */
.timeline{
  border-radius: var(--radius-xl);
  border: 1px solid rgba(233,238,247,.12);
  background: rgba(16,22,36,.55);
  box-shadow: 0 18px 50px rgba(0,0,0,.22);
  overflow:hidden;
}
.timeline__row{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
}
.timeline__step{
  padding: 18px 18px;
  border-right: 1px solid rgba(233,238,247,.10);
  position:relative;
}
.timeline__step:last-child{ border-right: none; }
.timeline__n{
  width: 44px; height: 30px;
  border-radius: 999px;
  display:grid; place-items:center;
  background: rgba(215,185,138,.14);
  border: 1px solid rgba(215,185,138,.22);
  font-weight: 800;
  color: rgba(233,238,247,.92);
  margin-bottom: 10px;
}
.timeline__c p{ font-size: .95rem; }

@media (max-width: 991px){
  .timeline__row{ grid-template-columns: 1fr; }
  .timeline__step{ border-right: none; border-bottom: 1px solid rgba(233,238,247,.10); }
  .timeline__step:last-child{ border-bottom: none; }
}

/* Lists */
.list-check{
  list-style:none;
  padding-left: 0;
  margin: 0;
}
.list-check li{
  position:relative;
  padding-left: 26px;
  margin: 10px 0;
  color: rgba(233,238,247,.92);
}
.list-check li::before{
  content:"";
  position:absolute; left: 0; top: .45em;
  width: 14px; height: 14px;
  border-radius: 6px;
  background: rgba(46,209,167,.22);
  border: 1px solid rgba(46,209,167,.26);
  box-shadow: 0 0 0 4px rgba(46,209,167,.08);
}
.list-check li::after{
  content:"";
  position:absolute; left: 4px; top: .52em;
  width: 7px; height: 4px;
  border-left: 2px solid rgba(233,238,247,.86);
  border-bottom: 2px solid rgba(233,238,247,.86);
  transform: rotate(-45deg);
}

/* Callout */
.callout{
  padding: 16px 16px;
  border-radius: var(--radius-xl);
  background: rgba(7,10,15,.30);
  border: 1px solid rgba(233,238,247,.10);
}
.callout__title{ font-weight: 800; }
.callout__text{ margin-top: 6px; }

/* Pricing */
.price{
  height:100%;
  border-radius: 26px;
  border: 1px solid rgba(233,238,247,.12);
  background: linear-gradient(180deg, rgba(16,22,36,.72), rgba(16,22,36,.50));
  box-shadow: 0 18px 55px rgba(0,0,0,.24);
  overflow:hidden;
  position:relative;
}
.price__top{ padding: 18px 18px 0; }
.price__name{ font-weight: 900; font-size: 1.2rem; }
.price__body{ padding: 14px 18px 0; }
.price__cta{ padding: 16px 18px 18px; }
.price__line{
  display:flex; gap:10px; justify-content:space-between; align-items:flex-start;
  padding: 10px 0;
  border-bottom: 1px dashed rgba(233,238,247,.10);
}
.price__line:last-of-type{ border-bottom: none; }
.price__tag{
  display:inline-flex;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: .78rem;
  background: rgba(233,238,247,.06);
  border: 1px solid rgba(233,238,247,.10);
  color: rgba(233,238,247,.86);
  white-space: nowrap;
}
.price--featured{
  border: 1px solid rgba(215,185,138,.28);
  background: linear-gradient(180deg, rgba(215,185,138,.18), rgba(16,22,36,.56));
  transform: translateY(-6px);
}
.price__badge{
  position:absolute; top: 14px; right: 14px;
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(243,183,198,.14);
  border: 1px solid rgba(243,183,198,.20);
  font-size: .78rem;
  font-weight: 800;
}

/* Accordion */
.acc-luxe .accordion-item{
  border: 1px solid rgba(233,238,247,.10);
  background: rgba(16,22,36,.55);
  border-radius: 18px !important;
  overflow:hidden;
  margin-bottom: 12px;
}
.acc-luxe .accordion-button{
  background: transparent;
  color: rgba(233,238,247,.92);
  font-weight: 800;
}
.acc-luxe .accordion-button:focus{ box-shadow: var(--focus); }
.acc-luxe .accordion-button:not(.collapsed){
  background: rgba(233,238,247,.06);
  color: rgba(233,238,247,.98);
}
.acc-luxe .accordion-body{ background: rgba(7,10,15,.22); }

/* Quotes */
.quote{
  height:100%;
  padding: 18px 18px;
  border-radius: var(--radius-xl);
  background: rgba(16,22,36,.55);
  border: 1px solid rgba(233,238,247,.12);
  box-shadow: 0 18px 55px rgba(0,0,0,.20);
}
.quote__top{ display:flex; align-items:center; gap:10px; margin-bottom: 10px; }
.quote__mark{
  width: 40px; height: 40px;
  border-radius: 16px;
  display:grid; place-items:center;
  background: rgba(215,185,138,.14);
  border: 1px solid rgba(215,185,138,.22);
  font-size: 1.4rem;
}

/* Contact */
.contact-card, .form-card{
  border-radius: var(--radius-xl);
  background: rgba(16,22,36,.60);
  border: 1px solid rgba(233,238,247,.12);
  box-shadow: 0 18px 55px rgba(0,0,0,.22);
  padding: 20px;
}
.contact-card__h, .form-card__h{ font-weight: 900; font-size: 1.05rem; }

.form-control, .form-select{
  background: rgba(7,10,15,.28);
  border: 1px solid rgba(233,238,247,.14);
  color: rgba(233,238,247,.92);
  border-radius: 14px;
}
.form-control:focus{
  background: rgba(7,10,15,.34);
  border-color: rgba(121,183,255,.35);
  box-shadow: var(--focus);
  color: rgba(233,238,247,.98);
}
.form-control::placeholder{
  color: #fff;
}
.form-check-input{
  border-color: rgba(233,238,247,.18);
  background-color: rgba(7,10,15,.28);
}
.form-check-input:checked{
  background-color: rgba(215,185,138,.95);
  border-color: rgba(215,185,138,.95);
}
.alert-success{
  background: rgba(46,209,167,.14);
  border: 1px solid rgba(46,209,167,.22);
  color: rgba(233,238,247,.92);
  border-radius: 16px;
}

/* Mini note */
.mini-note{
  padding: 14px 16px;
  border-radius: 18px;
  background: rgba(7,10,15,.28);
  border: 1px solid rgba(233,238,247,.10);
}
.mini-note__k{ font-weight: 900; }
.mini-note__v{ margin-top: 6px; }

/* Contact strip */
.contact-strip{
  display:flex; justify-content:space-between; align-items:center; gap:12px;
  padding: 16px 16px;
  border-radius: 22px;
  background: linear-gradient(90deg, rgba(215,185,138,.14), rgba(16,22,36,.55));
  border: 1px solid rgba(233,238,247,.12);
}
.contact-strip__r{ display:flex; gap:10px; flex-wrap:wrap; }

/* Mobile responsive */
@media (max-width: 575px){
  /* Base sizing */
  .container{ padding: 0 16px !important; }
  
  /* Section padding */
  .sec-pad{ padding: 56px 0; }
  .sec-hero{ padding: 64px 0 54px; }
  
  /* Typography */
  .h1-like{ font-size: clamp(1.5rem, 2.5vw, 1.9rem); }
  .h2{ font-size: clamp(1.4rem, 2.4vw, 1.8rem); }
  .h3{ font-size: clamp(1.2rem, 2vw, 1.5rem); }
  .h4{ font-size: clamp(1rem, 1.6vw, 1.3rem); }
  .h5{ font-size: clamp(.95rem, 1.5vw, 1.1rem); }
  .h6{ font-size: .9rem; }
  
  /* Layout adjustments */
  .row{ margin-left: -8px; margin-right: -8px; }
  [class*="col-"]{ padding-left: 8px; padding-right: 8px; }
  
  /* Grid columns */
  .col-md-6, .col-lg-4, .col-lg-6{ width: 100% !important; }
  
  /* Feature/card stacking */
  .feature-card{ margin-bottom: 12px; }
  .process-item{ margin-bottom: 12px; }
  .pricing-card{ margin-bottom: 12px; }
  .faq-item{ margin-bottom: 12px; }
  
  /* Button sizing */
  .btn{ padding: .5rem 1rem; font-size: .95rem; }
  
  /* Prevent overflow */
  html, body{ width: 100%; max-width: 100%; }
  .app{ width: 100%; }
  
  .contact-strip{ flex-direction: column; align-items:flex-start; }
}

/* Footer */
.footer-wrap{
  padding: 48px 0 30px;
  border-top: 1px solid rgba(233,238,247,.10);
  background: rgba(7,10,15,.28);
}
.footer-top{
  display:grid;
  grid-template-columns: 1.2fr 1.8fr;
  gap: 24px;
}
.footer-links{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.footer-h{ font-weight: 900; margin-bottom: 8px; }
.footer-col a{
  display:block;
  padding: 6px 0;
  color: rgba(233,238,247,.86);
  text-decoration:none;
}
.footer-col a:hover{ color: rgba(233,238,247,.98); }
.footer-social{ display:flex; flex-wrap:wrap; gap:10px; }
.social-link{
  font-size: .9rem;
  padding: 8px 10px;
  border-radius: 999px;
  background: rgba(233,238,247,.06);
  border: 1px solid rgba(233,238,247,.10);
  text-decoration:none;
  color: rgba(233,238,247,.86);
}
.social-link:hover{ background: rgba(233,238,247,.08); color: rgba(233,238,247,.98); }
.footer-bottom{
  display:flex; justify-content:space-between; gap:12px; flex-wrap:wrap;
  padding-top: 18px;
  margin-top: 18px;
  border-top: 1px solid rgba(233,238,247,.10);
}
@media (max-width: 991px){
  .footer-top{ grid-template-columns: 1fr; }
  .footer-links{ grid-template-columns: 1fr 1fr; }
}
@media (max-width: 575px){
  .footer-links{ grid-template-columns: 1fr; }
}
