/* ================================================================
   DENTAL — America Web Studios  |  NEW DESIGN v2
   Design Language: Diagonal slash / precision / bold editorial
   Colors: Navy #162348 | Red #CC1C2A | Blue #2B5FA5 | LtBlue #4A90D9
   Fonts: Clash Display (display) + Inter (body)
================================================================ */
@import url('https://api.fontshare.com/v2/css?f[]=clash-display@400,500,600,700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap');
 
:root {
  --navy:   #162348;
  --navy2:  #0e1830;
  --red:    #CC1C2A;
  --red2:   #a81520;
  --blue:   #2B5FA5;
  --lblue:  #4A90D9;
  --white:  #ffffff;
  --off:    #F4F6FB;
  --gray:   #5E6E8A;
  --line:   rgba(22,35,72,0.1);
  --fh:     'Clash Display', sans-serif;
  --fb:     'Inter', sans-serif;
  --rad:    0px;
}
 
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body { font-family:var(--fb); background:var(--white); color:var(--navy); overflow-x:hidden; }
img { display:block; width:100%; }
a { text-decoration:none; color:inherit; }
::-webkit-scrollbar { width:3px; }
::-webkit-scrollbar-track { background:var(--off); }
::-webkit-scrollbar-thumb { background:var(--red); }
 
/* ── SCROLL BAR TOP ── */
#scrollBar {
  position:fixed; top:0; left:0; height:3px; width:0;
  background:linear-gradient(90deg, var(--navy), var(--red));
  z-index:9999; transition:width .1s linear;
}
 
/* ── SLASH DECORATOR ── */
.slash {
  display:inline-flex; align-items:center; gap:3px;
  color:var(--red); font-family:var(--fh); font-size:1.1rem; font-weight:700;
  letter-spacing:-1px; margin-bottom:14px; line-height:1;
}
.slash::before { content:'//'; }
 
/* ─────────────────────────────
   HEADER
───────────────────────────── */
#hdr {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  height:68px;
  background:var(--white);
  border-bottom:2px solid var(--navy);
  transition:box-shadow .3s;
}
#hdr.stuck { box-shadow:0 4px 28px rgba(22,35,72,.14); }
.hdr-in {
  display:flex; align-items:center; justify-content:space-between; height:100%;
}
.logo-wrap img { width:100px; height:auto; }
.hdr-right { display:flex; align-items:center; gap:10px; }
 
/* phone toggle button */
.h-phone {
  display:inline-flex; align-items:center; gap:7px;
  padding:8px 18px; border:2px solid var(--navy);
  background:transparent; color:var(--navy);
  font-family:var(--fb); font-size:13px; font-weight:600;
  cursor:pointer; transition:all .25s; white-space:nowrap;
}
.h-phone:hover { background:var(--navy); color:#fff; }
 
 
/* CTA button */
.h-cta {
  display:inline-flex; align-items:center; gap:7px;
  padding:9px 22px; background:var(--red); color:#fff;
  font-family:var(--fb); font-size:13px; font-weight:700;
  border:none; cursor:pointer; transition:all .3s; white-space:nowrap;
  clip-path: polygon(0 0, calc(100% - 10px) 0, 100% 100%, 10px 100%);
}
.h-cta:hover { background:var(--red2); transform:translateY(-1px); }
 
/* ─────────────────────────────
   COMMON SECTION BUTTONS (2 per section)
───────────────────────────── */
.s-btns { display:flex; gap:12px; flex-wrap:wrap; margin-top:28px; align-items:center; }
.btn-solid {
  display:inline-flex; align-items:center; gap:8px;
  padding:13px 30px; background:var(--navy); color:#fff;
  font-family:var(--fb); font-size:13px; font-weight:700;
  border:2px solid var(--navy); cursor:pointer; transition:all .3s;
  clip-path: polygon(0 0, calc(100% - 10px) 0, 100% 100%, 10px 100%);
}
.btn-solid:hover { background:var(--red); border-color:var(--red); color:#fff; }
.btn-solid.red { background:var(--red); border-color:var(--red); }
.btn-solid.red:hover { background:var(--navy); border-color:var(--navy); }
 
.btn-ghost {
  display:inline-flex; align-items:center; gap:8px;
  padding:11px 26px; background:transparent; color:var(--navy);
  font-family:var(--fb); font-size:13px; font-weight:600;
  border:2px solid var(--navy); cursor:pointer; transition:all .3s;
  white-space:nowrap;
}
.btn-ghost:hover { background:var(--navy); color:#fff; }
 
 
/* white variants for dark sections */
.btn-solid-white {
  display:inline-flex; align-items:center; gap:8px;
  padding:13px 30px; background:#fff; color:var(--navy);
  font-family:var(--fb); font-size:13px; font-weight:700;
  border:2px solid #fff; cursor:pointer; transition:all .3s;
  clip-path: polygon(0 0, calc(100% - 10px) 0, 100% 100%, 10px 100%);
}
.btn-solid-white:hover { background:var(--red); color:#fff; border-color:var(--red); }
.btn-ghost-white {
  display:inline-flex; align-items:center; gap:8px;
  padding:11px 26px; background:transparent; color:#fff;
  font-family:var(--fb); font-size:13px; font-weight:600;
  border:2px solid rgba(255,255,255,.4); cursor:pointer; transition:all .3s;
  white-space:nowrap;
}
.btn-ghost-white:hover { border-color:#fff; background:rgba(255,255,255,.08); }
 
 
/* ─────────────────────────────
   BANNER
───────────────────────────── */
#banner {
  min-height:100vh; padding-top:68px;
  background:var(--navy2);
  position:relative; overflow:hidden;
  display:flex; align-items:center;
}
/* diagonal background split */
#banner::after {
  content:''; position:absolute;
  top:0; right:0; bottom:0; width:45%;
  background:var(--navy);
  clip-path: polygon(12% 0, 100% 0, 100% 100%, 0 100%);
  z-index:0;
}
.banner-img-panel {
  position:absolute; top:0; right:0; bottom:0; width:45%;
  clip-path: polygon(12% 0, 100% 0, 100% 100%, 0 100%);
  z-index:1; overflow:hidden;
}
.banner-img-panel img {
  width:100%; height:100%; object-fit:cover; object-position:center;
  filter:brightness(.5) saturate(.8);
}
.banner-img-panel::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg, var(--navy2) 0%, transparent 60%);
}
/* big decorative number */
.banner-deco-num {
  position:absolute; right:2%; top:50%; transform:translateY(-50%);
  font-family:var(--fh); font-size:28vw; font-weight:700;
  color:rgba(255,255,255,.03); line-height:1; pointer-events:none;
  z-index:2; user-select:none;
}
.banner-content { position:relative; z-index:3; padding:80px 0; }
.banner-tag {
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--fb); font-size:11px; font-weight:700;
  letter-spacing:3px; text-transform:uppercase; color:var(--lblue);
  margin-bottom:28px;
}
.banner-tag::before {
  content:''; width:32px; height:2px; background:var(--red); flex-shrink:0;
}
.banner-h1 {
  font-family:var(--fh); font-size:clamp(2.8rem,6vw,5.2rem);
  font-weight:700; line-height:1.05; letter-spacing:-0.03em;
  color:#fff; margin-bottom:24px;
}
.banner-h1 .red { color:var(--red); }
.banner-h1 .stroke {
  -webkit-text-stroke:2px rgba(255,255,255,.25);
  color:transparent;
}
.banner-sub {
  color:rgba(255,255,255,.5); font-size:.97rem; line-height:1.8;
  max-width:480px; margin-bottom:0;
}
/* stats row */
.banner-stats {
  display:flex; gap:0; margin-top:48px;
  border-top:1px solid rgba(255,255,255,.1);
}
.bstat {
  padding:28px 36px 28px 0; margin-right:36px;
  border-right:1px solid rgba(255,255,255,.1);
}
.bstat:last-child { border-right:none; }
.bstat-num {
  font-family:var(--fh); font-size:2.6rem; font-weight:700;
  color:#fff; line-height:1;
}
.bstat-num span { color:var(--red); }
.bstat-lbl { font-size:11px; color:rgba(255,255,255,.4); margin-top:5px; letter-spacing:1px; text-transform:uppercase; font-weight:500; }
 
/* marquee */
.marquee-strip {
  background:var(--red); overflow:hidden; padding:12px 0; position:relative; z-index:4;
}
.marquee-inner {
  display:flex; gap:0; white-space:nowrap;
  animation:mq 24s linear infinite;
}
.marquee-inner span {
  font-family:var(--fh); font-size:1rem; letter-spacing:3px; color:#fff;
  padding:0 28px; display:inline-flex; align-items:center; gap:12px; flex-shrink:0;
}
.marquee-inner span::after { content:'✦'; font-size:.5rem; opacity:.7; }
@keyframes mq { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }
 
/* ─────────────────────────────
   SECTION BASE
───────────────────────────── */
section { padding:96px 0; position:relative; overflow:hidden; }
.s-label {
  font-family:var(--fb); font-size:11px; font-weight:700;
  letter-spacing:3px; text-transform:uppercase; color:var(--red);
  display:flex; align-items:center; gap:10px; margin-bottom:14px;
}
.s-label::before { content:'//'; font-size:.9rem; }
.s-h2 {
  font-family:var(--fh); font-size:clamp(2rem,4vw,3.2rem);
  font-weight:700; line-height:1.1; letter-spacing:-0.02em;
  color:var(--navy); margin-bottom:16px;
}
.s-h2 em { font-style:normal; color:var(--red); }
.s-sub { color:var(--gray); font-size:.95rem; line-height:1.8; max-width:520px; }
.bg-off { background:var(--off) !important; }
.bg-navy { background:var(--navy) !important; }
 
/* ─────────────────────────────
   ABOUT
───────────────────────────── */
#about { background:var(--white); }
.about-img-outer { position:relative; }
.about-img-frame {
  position:relative;
  border-left:5px solid var(--red);
  padding-left:0;
}
.about-img-frame img {
  width:100%; height:500px; object-fit:cover;
  filter:grayscale(15%);
}
.about-counter-box {
  position:absolute; bottom:-28px; right:-28px;
  background:var(--navy); color:#fff;
  padding:24px 28px; text-align:center;
  border-left:4px solid var(--red);
}
.about-counter-box .num { font-family:var(--fh); font-size:2.8rem; font-weight:700; line-height:1; color:var(--red); }
.about-counter-box .lbl { font-size:11px; opacity:.6; margin-top:4px; letter-spacing:1px; text-transform:uppercase; }
.feat-row {
  display:flex; gap:14px; align-items:flex-start;
  padding:16px 0; border-bottom:1px solid var(--line);
}
.feat-row:last-child { border-bottom:none; }
.feat-icon {
  width:42px; height:42px; flex-shrink:0;
  background:var(--off); border-left:3px solid var(--red);
  display:flex; align-items:center; justify-content:center;
  color:var(--navy); font-size:18px; transition:all .3s;
}
.feat-row:hover .feat-icon { background:var(--navy); color:#fff; border-color:var(--navy); }
.feat-row h6 { font-family:var(--fh); font-size:.95rem; font-weight:700; margin-bottom:3px; }
.feat-row p { font-size:.82rem; color:var(--gray); line-height:1.65; margin:0; }
 
/* ─────────────────────────────
   SERVICES
───────────────────────────── */
#services { background:var(--navy); }
.svc-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:1px; background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.06); margin-top:56px;
}
@media(max-width:900px){ .svc-grid{ grid-template-columns:1fr 1fr; } }
@media(max-width:576px){ .svc-grid{ grid-template-columns:1fr; } }
.svc-item {
  background:var(--navy); padding:40px 32px;
  position:relative; overflow:hidden; transition:background .3s;
  border-right:1px solid rgba(255,255,255,.05);
}
.svc-item:nth-child(3n){ border-right:none; }
.svc-item::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:3px;
  background:var(--red); transform:scaleX(0); transform-origin:left;
  transition:transform .4s cubic-bezier(.34,1.56,.64,1);
}
.svc-item:hover { background:var(--navy2); }
.svc-item:hover::after { transform:scaleX(1); }
.svc-n {
  font-family:var(--fh); font-size:4.5rem; color:rgba(255,255,255,.03);
  line-height:1; margin-bottom:-8px; user-select:none; font-weight:700;
  transition:color .3s;
}
.svc-item:hover .svc-n { color:rgba(204,28,42,.08); }
.svc-ico {
  width:50px; height:50px; background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);
  display:flex; align-items:center; justify-content:center;
  font-size:22px; color:var(--lblue); margin-bottom:18px; transition:all .35s;
}
.svc-item:hover .svc-ico { background:var(--red); color:#fff; border-color:transparent; }
.svc-item h4 { font-family:var(--fh); font-size:1.25rem; font-weight:700; color:#fff; margin-bottom:10px; }
.svc-item p { font-size:.83rem; color:rgba(255,255,255,.4); line-height:1.75; margin-bottom:20px; }
.btn-svc {
  display:inline-flex; align-items:center; gap:7px;
  font-family:var(--fb); font-size:.72rem; font-weight:700;
  letter-spacing:1px; text-transform:uppercase;
  background:var(--red); color:#fff; padding:8px 18px; border:none; cursor:pointer; transition:all .3s;
}
.btn-svc:hover { background:#fff; color:var(--navy); }
.btn-svc-ghost {
  display:inline-flex; align-items:center; gap:7px;
  font-family:var(--fb); font-size:.72rem; font-weight:700;
  letter-spacing:1px; text-transform:uppercase;
  background:transparent; color:rgba(255,255,255,.5);
  border:1px solid rgba(255,255,255,.15); padding:7px 16px; cursor:pointer; transition:all .3s;
  white-space:nowrap;
}
.btn-svc-ghost:hover { color:#fff; border-color:rgba(255,255,255,.4); }
 
 
/* ─────────────────────────────
   PROCESS
───────────────────────────── */
#process { background:var(--off); }
.proc-row {
  display:grid; grid-template-columns:200px 1fr;
  gap:0 56px; margin-bottom:0; position:relative;
}
@media(max-width:768px){ .proc-row{ grid-template-columns:60px 1fr; gap:0 20px; } }
.proc-left { display:flex; flex-direction:column; align-items:center; padding-top:8px; }
.proc-num {
  width:64px; height:64px; background:var(--white);
  border:2px solid var(--line); display:flex; align-items:center; justify-content:center;
  font-family:var(--fh); font-size:1.4rem; font-weight:700; color:var(--navy);
  transition:all .4s; position:relative; z-index:1; flex-shrink:0;
}
.proc-row:hover .proc-num,
.proc-row.active .proc-num { background:var(--red); color:#fff; border-color:var(--red); box-shadow:0 0 0 6px rgba(204,28,42,.12); }
.proc-line2 { width:2px; flex:1; min-height:20px; background:var(--line); margin:8px 0; }
.proc-row:last-child .proc-line2 { display:none; }
.proc-body2 {
  background:var(--white); border:1px solid var(--line);
  border-left:4px solid transparent; padding:26px 30px; margin-bottom:14px;
  transition:all .35s;
}
.proc-row:hover .proc-body2,
.proc-row.active .proc-body2 { border-left-color:var(--red); box-shadow:6px 6px 0 rgba(204,28,42,.1); }
.proc-phase { font-size:11px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--red); margin-bottom:6px; }
.proc-body2 h5 { font-family:var(--fh); font-size:1.1rem; font-weight:700; color:var(--navy); margin-bottom:6px; }
.proc-body2 p { color:var(--gray); font-size:.84rem; line-height:1.72; margin:0; }
 
/* ─────────────────────────────
   PORTFOLIO
───────────────────────────── */
#portfolio { background:var(--white); }
.port-grid {
  display:grid; grid-template-columns:repeat(4,1fr);
  grid-template-rows:auto; gap:3px; margin-top:52px;
}
@media(max-width:900px){ .port-grid{ grid-template-columns:1fr 1fr; } }
@media(max-width:576px){ .port-grid{ grid-template-columns:1fr; } }
.port-item { position:relative; overflow:hidden; background:var(--navy); cursor:pointer; }

@media(max-width:900px){  }
.port-item img {
  width:100%; height:100%; min-height:240px; object-fit:cover;
  transition:transform .7s cubic-bezier(.33,1,.68,1), filter .4s;
  filter:grayscale(30%) brightness(.9);
}
.port-item:nth-child(1) img { min-height:483px; }

.port-item:hover img { transform:scale(1.07); filter:grayscale(0%) brightness(1); }
.port-ov {
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(22,35,72,.95) 0%, rgba(22,35,72,.2) 55%, transparent 100%);
  opacity:0; transition:opacity .35s;
  display:flex; flex-direction:column; justify-content:flex-end; padding:24px;
}
.port-item:hover .port-ov { opacity:1; }
.port-cat { font-size:10px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--lblue); margin-bottom:5px; }
.port-title { font-family:var(--fh); font-size:1.1rem; color:#fff; font-weight:700; }
.port-arrow {
  position:absolute; top:16px; right:16px;
  width:38px; height:38px; background:var(--red);
  display:flex; align-items:center; justify-content:center;
  color:#fff; font-size:16px;
  transform:scale(0) rotate(-45deg); transition:transform .35s cubic-bezier(.34,1.56,.64,1);
}
.port-item:hover .port-arrow { transform:scale(1) rotate(0deg); }
 
/* ─────────────────────────────
   CTA
───────────────────────────── */
#cta { background:var(--navy); position:relative; overflow:hidden; }
.cta-bg-text {
  position:absolute; right:-2%; top:50%; transform:translateY(-50%);
  font-family:var(--fh); font-size:18vw; font-weight:700;
  color:rgba(255,255,255,.025); line-height:1; pointer-events:none; user-select:none;
  white-space:nowrap;
}
.cta-in { position:relative; z-index:1; }
.cta-in h2 { font-family:var(--fh); font-size:clamp(2.2rem,5vw,4rem); font-weight:700; color:#fff; line-height:1.05; margin-bottom:18px; }
.cta-in h2 .red { color:var(--red); }
.cta-in p { color:rgba(255,255,255,.5); font-size:.97rem; line-height:1.78; max-width:500px; margin-bottom:0; }
 
/* ─────────────────────────────
   PACKAGES
───────────────────────────── */
#packages { background:var(--off); }
.pkg-tabs-list {
  display:flex; flex-wrap:wrap; gap:0; list-style:none !important;
  padding:0 !important; margin:0 0 40px !important;
  border-bottom:2px solid var(--line);
}
.pkg-tabs-list li { list-style:none !important; padding:0 !important; }
.pkg-tab-btn2 {
  display:inline-block; padding:12px 22px;
  background:transparent; border:none; border-bottom:3px solid transparent;
  margin-bottom:-2px; font-family:var(--fb); font-size:.8rem; font-weight:700;
  letter-spacing:.5px; text-transform:uppercase; color:var(--gray);
  cursor:pointer; transition:all .25s; white-space:nowrap;
}
.pkg-tab-btn2:hover { color:var(--navy); }
.pkg-tab-btn2.active { color:var(--red); border-bottom-color:var(--red); }
.tab-content { position:relative; }
.tab-pane { display:none; }
.tab-pane.show.active { display:block; }
 
.p-card {
  background:var(--white); border:1px solid var(--line);
  border-top:3px solid transparent; padding:30px 24px;
  height:100%; display:flex; flex-direction:column; transition:all .35s;
  position:relative; overflow:hidden;
}
.p-card:hover { border-top-color:var(--red); box-shadow:0 8px 32px rgba(22,35,72,.1); transform:translateY(-4px); }
.p-card.pop { border-top-color:var(--red); background:var(--navy); color:#fff; }
.p-card.pop:hover { box-shadow:0 8px 40px rgba(22,35,72,.35); }
.p-badge {
  position:absolute; top:0; right:0;
  background:var(--red); color:#fff; font-size:.6rem; font-weight:800;
  letter-spacing:1.5px; text-transform:uppercase; padding:4px 14px;
}
.p-card h3 { font-family:var(--fh); font-size:1.1rem; font-weight:700; margin-bottom:10px; line-height:1.2; }
.p-card.pop h3 { color:#fff; }
.p-price { font-family:var(--fh); font-size:2.1rem; font-weight:700; color:var(--red); line-height:1; margin-bottom:6px; }
.p-card.pop .p-price { color:var(--lblue); }
.p-strike { font-size:.9rem; color:var(--gray); text-decoration:line-through; font-weight:400; margin-left:4px; }
.p-card.pop .p-strike { color:rgba(255,255,255,.35); }
.p-note { font-size:.71rem; color:var(--gray); margin-bottom:10px; padding:4px 10px; border-left:3px solid var(--red); background:var(--off); line-height:1.4; }
.p-card.pop .p-note { background:rgba(255,255,255,.06); color:rgba(255,255,255,.5); }
.p-list { list-style:none !important; padding:0 !important; margin:10px 0 14px !important; flex:1; }
.p-list li { font-size:.8rem; color:var(--gray); padding:5px 0; border-bottom:1px solid var(--line); display:flex; align-items:flex-start; gap:8px; line-height:1.5; list-style:none !important; }
.p-list li::before { content:'→'; color:var(--red); font-size:.7rem; margin-top:2px; flex-shrink:0; font-weight:700; }
.p-list li::marker { display:none !important; }
.p-card.pop .p-list li { color:rgba(255,255,255,.55); border-bottom-color:rgba(255,255,255,.07); }
.p-scroll { max-height:190px; overflow-y:auto; scrollbar-width:thin; scrollbar-color:rgba(204,28,42,.4) transparent; }
.p-scroll::-webkit-scrollbar { width:3px; }
.p-scroll::-webkit-scrollbar-thumb { background:rgba(204,28,42,.4); }
.p-contact { display:flex; gap:7px; margin-bottom:10px; flex-wrap:wrap; }
.p-speak, .p-chat {
  flex:1; min-width:90px; display:flex; flex-direction:column;
  padding:7px 9px; transition:all .3s; cursor:pointer; text-decoration:none;
  border:1px solid var(--line); background:var(--off);
}
.p-speak:hover { border-color:var(--blue); background:rgba(43,95,165,.06); }
.p-chat:hover { border-color:var(--red); background:rgba(204,28,42,.05); }
.p-card.pop .p-speak, .p-card.pop .p-chat { background:rgba(255,255,255,.06); border-color:rgba(255,255,255,.1); }
.p-speak small, .p-chat small { font-size:.58rem; color:var(--gray); display:block; margin-bottom:2px; }
.p-card.pop .p-speak small, .p-card.pop .p-chat small { color:rgba(255,255,255,.35); }
.p-speak span, .p-chat span { font-size:.74rem; font-weight:700; color:var(--navy); }
.p-card.pop .p-speak span, .p-card.pop .p-chat span { color:#fff; }
.btn-p {
  display:block; width:100%; text-align:center; padding:11px;
  font-family:var(--fb); font-size:.78rem; font-weight:800;
  letter-spacing:.5px; text-transform:uppercase;
  background:var(--navy); color:#fff; border:none; cursor:pointer; transition:all .3s; margin-top:auto;
}
.btn-p:hover { background:var(--red); color:#fff; }
.btn-p.inv { background:transparent; border:1.5px solid rgba(255,255,255,.3); color:#fff; }
.btn-p.inv:hover { background:var(--red); border-color:var(--red); }
 
/* ─────────────────────────────
   FAQ
───────────────────────────── */
#faq { background:var(--white); }
.faq-acc .accordion-item {
  background:var(--white); border:1px solid var(--line) !important;
  margin-bottom:10px; border-radius:0 !important; overflow:hidden;
}
.faq-acc .accordion-button {
  background:var(--white); color:var(--navy);
  font-family:var(--fh); font-weight:600; font-size:.97rem;
  padding:18px 24px; box-shadow:none !important; border:none;
  border-left:4px solid transparent; transition:border-left-color .3s;
}
.faq-acc .accordion-button:not(.collapsed) { background:var(--off); color:var(--red); border-left-color:var(--red); }
.faq-acc .accordion-button::after { filter:invert(0) sepia(1) saturate(5) hue-rotate(0deg) brightness(.4); }
.faq-acc .accordion-body { color:var(--gray); padding:0 24px 18px; line-height:1.78; font-size:.87rem; background:var(--off); }
 
/* ─────────────────────────────
   TESTIMONIALS
───────────────────────────── */
#testimonials { background:var(--navy); }
.testi-row { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:rgba(255,255,255,.06); margin-top:52px; }
@media(max-width:900px){ .testi-row{ grid-template-columns:1fr 1fr; } }
@media(max-width:576px){ .testi-row{ grid-template-columns:1fr; } }
.testi-cell {
  background:var(--navy); padding:36px 28px; position:relative; transition:background .3s;
  border-right:1px solid rgba(255,255,255,.05);
}
.testi-cell:nth-child(3n){ border-right:none; }
.testi-cell:hover { background:var(--navy2); }
.t-mark { font-size:52px; line-height:1; color:var(--red); opacity:.3; font-family:Georgia,serif; margin-bottom:4px; }
.t-stars { color:var(--red); font-size:13px; letter-spacing:2px; margin-bottom:12px; }
.t-text { color:rgba(255,255,255,.5); font-size:.85rem; line-height:1.78; margin-bottom:22px; font-style:italic; }
.t-author { display:flex; align-items:center; gap:12px; padding-top:18px; border-top:1px solid rgba(255,255,255,.08); }
.t-av {
  width:42px; height:42px; background:var(--red); flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--fh); font-size:16px; font-weight:700; color:#fff;
}
.t-name { font-weight:700; font-size:.85rem; color:#fff; }
.t-role { font-size:.72rem; color:rgba(255,255,255,.35); }
 
/* ─────────────────────────────
   CONTACT
───────────────────────────── */
#contact { background:var(--off); }
.ct-info-item {
  display:flex; gap:16px; align-items:center;
  padding:18px 20px; background:var(--white);
  border:1px solid var(--line); border-left:4px solid var(--red);
  margin-bottom:12px; transition:all .3s;
}
.ct-info-item:hover { box-shadow:4px 4px 0 var(--red); transform:translate(-2px,-2px); }
.ct-ico { width:42px; height:42px; background:var(--navy); display:flex; align-items:center; justify-content:center; color:var(--lblue); font-size:18px; flex-shrink:0; }
.ct-lbl { font-size:10px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--gray); margin-bottom:3px; }
.ct-val { font-size:.9rem; font-weight:600; color:var(--navy); }
.ct-form-box {
  background:var(--white); border:1px solid var(--line);
  border-top:4px solid var(--red); padding:42px 38px;
}
.form-label { color:var(--gray); font-size:11px; font-weight:700; letter-spacing:1px; text-transform:uppercase; margin-bottom:6px; display:block; }
.form-control, .form-select {
  background:var(--off) !important; border:1px solid var(--line) !important;
  border-radius:0 !important; color:var(--navy) !important;
  padding:10px 14px; font-family:var(--fb); font-size:.9rem; transition:all .3s;
}
.form-control:focus, .form-select:focus {
  border-color:var(--red) !important; background:var(--white) !important;
  box-shadow:0 0 0 3px rgba(204,28,42,.1) !important;
}
.form-control::placeholder { color:rgba(94,110,138,.45) !important; }
.form-check-input { border-color:var(--line) !important; border-radius:0 !important; }
.form-check-input:checked { background-color:var(--red) !important; border-color:var(--red) !important; }
.form-check-label { color:var(--gray); font-size:12px; line-height:1.5; }
.form-check-label a { color:var(--red); }
.btn-send {
  width:100%; padding:14px; background:var(--navy); color:#fff;
  border:none; font-family:var(--fh); font-size:1rem; font-weight:700;
  cursor:pointer; transition:all .3s; letter-spacing:.5px;
  clip-path: polygon(0 0, calc(100% - 12px) 0, 100% 100%, 12px 100%);
}
.btn-send:hover { background:var(--red); }
 
/* ─────────────────────────────
   FOOTER
───────────────────────────── */
#footer { background:var(--navy2); color:#fff; padding:56px 0 28px; border-top:4px solid var(--red); }
.foot-logo img { width:100px; height: auto; filter:brightness(0) invert(1); margin-bottom:16px; }
.foot-desc { color:rgba(255,255,255,.4); font-size:13px; line-height:1.75; max-width:260px; }
.foot-title { font-family:var(--fh); font-size:.85rem; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; color:rgba(255,255,255,.3); margin-bottom:18px; }
.foot-links { display:flex; flex-direction:column; gap:11px; }
.foot-links a { color:rgba(255,255,255,.5); font-size:13px; text-decoration:none; display:flex; align-items:center; gap:8px; transition:color .2s; }
.foot-links a:hover { color:var(--lblue); }
.foot-contacts { list-style:none; padding:0; }
.foot-contacts li { display:flex; gap:10px; align-items:center; color:rgba(255,255,255,.45); font-size:13px; margin-bottom:11px; }
.foot-contacts li i { color:var(--red); font-size:14px; flex-shrink:0; }
.foot-contacts li a { color:rgba(255,255,255,.45); text-decoration:none; transition:color .2s; }
.foot-contacts li a:hover { color:var(--lblue); }
.foot-bottom {
  margin-top:40px; padding-top:22px; border-top:1px solid rgba(255,255,255,.07);
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:10px;
}
.foot-copy { color:rgba(255,255,255,.25); font-size:12px; }
.foot-legal { display:flex; gap:18px; }
.foot-legal a { color:rgba(255,255,255,.25); font-size:12px; text-decoration:none; transition:color .2s; }
.foot-legal a:hover { color:var(--lblue); }
 
/* ─────────────────────────────
   POPUP
───────────────────────────── */
.pop-overlay {
  position:fixed; inset:0; background:rgba(0,0,0,.75);
  backdrop-filter:blur(6px); z-index:9999;
  display:flex; align-items:center; justify-content:center;
  opacity:0; visibility:hidden; transition:all .3s; padding:20px;
}
.pop-overlay.show { opacity:1; visibility:visible; }
.pop-box {
  background:var(--white); width:100%; max-width:470px;
  position:relative; transform:translateY(24px) scale(.95);
  transition:all .35s cubic-bezier(.34,1.56,.64,1);
  box-shadow:0 32px 80px rgba(0,0,0,.35); max-height:92vh; overflow-y:auto;
  border-top:4px solid var(--red);
}
.pop-overlay.show .pop-box { transform:translateY(0) scale(1); }
.pop-hd { background:var(--navy); padding:12px 32px; position:relative; }
.pop-close {
  position:absolute; top:14px; right:14px; width:32px; height:32px;
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.12);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; color:rgba(255,255,255,.5); font-size:16px; transition:all .2s;
}
.pop-close:hover { background:var(--red); color:#fff; border-color:var(--red); }
.pop-lbl { font-size:10px; font-weight:700; letter-spacing:2.5px; text-transform:uppercase; color:rgba(255,255,255,.35); margin-bottom:6px; }
.pop-hd h3 { font-family:var(--fh); font-size:1.7rem; font-weight:700; color:#fff; }
.pop-bd { padding:28px 32px; }
.pop-fg { margin-bottom:13px; }
 
/* ─────────────────────────────
   COOKIE
───────────────────────────── */
#ckBar {
  position:fixed; bottom:0; left:0; right:0;
  background:var(--navy2); border-top:3px solid var(--red);
  z-index:8000; padding:16px 0;
  transform:translateY(110%); transition:transform .45s cubic-bezier(.34,1.56,.64,1);
}
#ckBar.show { transform:translateY(0); }
.ck-row { display:flex; align-items:center; gap:20px; flex-wrap:wrap; }
.ck-txt { flex:1; color:rgba(255,255,255,.5); font-size:12px; line-height:1.6; min-width:200px; }
.ck-txt a { color:var(--lblue); }
.ck-bts { display:flex; gap:8px; flex-shrink:0; }
.btn-cka { padding:8px 20px; background:var(--red); color:#fff; border:none; font-size:12px; font-weight:700; cursor:pointer; transition:all .2s; }
.btn-cka:hover { background:var(--red2); }
.btn-ckd { padding:8px 16px; background:transparent; color:rgba(255,255,255,.4); border:1px solid rgba(255,255,255,.15); font-size:12px; cursor:pointer; transition:all .2s; }
.btn-ckd:hover { color:#fff; border-color:rgba(255,255,255,.3); }
 
/* ─────────────────────────────
   RESPONSIVE
───────────────────────────── */
@media(max-width:991px){
  .about-counter-box { display:none; }
  .ct-form-box { padding:28px 20px; }
  #banner::after { display:none; }
  .banner-img-panel { display:none; }
  .banner-deco-num { display:none; }
  .banner-content { padding:40px 0; }
}
@media(max-width:768px){
  section { padding:68px 0; }
  .banner-h1 { font-size:2.3rem; }
  .hdr-right .h-phone { display:none; }
  .testi-row { grid-template-columns:1fr; }
  .foot-bottom { flex-direction:column; text-align:center; }
}
@media(max-width:576px){
  .pkg-tab-btn2 { padding:10px 14px; font-size:.72rem; }
  .banner-stats { flex-direction:column; gap:0; }
  .bstat { border-right:none; border-bottom:1px solid rgba(255,255,255,.1); padding:20px 0; margin-right:0; }
  .bstat:last-child { border-bottom:none; }
}


/* 3 per row */
.port-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

.port-item {
  position: relative;
  height: 280px;
  border-radius: 14px;
  overflow: hidden;
  cursor: pointer;
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.10);
  transition: transform .35s ease, box-shadow .35s ease;
}

.port-item:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.18);
}

.port-item a {
  position: absolute;
  inset: 0;
  display: block;
}

.port-item img {
  width: 100%;
  height: auto;
  display: block;
  transition: transform 4s ease;
  transform: translateY(0);
}

.port-item:hover img {
  transform: translateY(calc(-100% + 280px));
}

@media (max-width: 992px) {
  .port-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 600px) {
  .port-grid { grid-template-columns: 1fr; }
  .port-item { height: 220px; }
  .port-item:hover img {
    transform: translateY(calc(-100% + 220px));
  }
}

