/* ===== RESET ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Segoe UI',Tahoma,Geneva,Verdana,sans-serif;font-size:16px;line-height:1.7;color:#222;background:#fff;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:#f50;text-decoration:none;transition:color .2s}
a:hover{color:#c44000}
ul,ol{list-style:none}
h1,h2,h3,h4,h5{line-height:1.3;color:#1a1a1a}
h1{font-size:2.4rem}h2{font-size:2rem}h3{font-size:1.5rem}h4{font-size:1.15rem}
address{font-style:normal}
.container{max-width:1100px;margin:0 auto;padding:0 20px}
.text-center{text-align:center}

/* ===== BUTTONS ===== */
.btn{display:inline-block;padding:14px 32px;border-radius:50px;font-size:1rem;font-weight:700;text-align:center;cursor:pointer;transition:all .25s;border:2px solid transparent;text-decoration:none}
.btn-primary{background:#f50;color:#fff;border-color:#f50}
.btn-primary:hover{background:#d44500;border-color:#d44500;color:#fff}
.btn-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.6)}
.btn-outline:hover{background:#fff;color:#f50;border-color:#fff}
.btn-outline-dark{background:transparent;color:#f50;border-color:#f50}
.btn-outline-dark:hover{background:#f50;color:#fff}
.btn-small{padding:10px 24px;font-size:.9rem}
.btn-large{padding:16px 36px;font-size:1.05rem}

/* ===== HEADER ===== */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;background:transparent;transition:all .4s}
.site-header.scrolled{background:rgba(26,26,26,.95);backdrop-filter:blur(10px);box-shadow:0 2px 20px rgba(0,0,0,.15)}
.header-inner{max-width:1100px;margin:0 auto;padding:0 20px;display:flex;align-items:center;justify-content:space-between;height:72px}

.logo{display:flex;align-items:center;gap:8px;text-decoration:none;color:#fff}
.logo:hover{color:#fff}
.logo-icon{font-size:1.6rem;line-height:1}
.logo-text{font-size:1.15rem;font-weight:700;letter-spacing:-.5px}
.logo-accent{color:#fcb900}

.desktop-nav ul{display:flex;gap:28px}
.desktop-nav a{color:rgba(255,255,255,.85);font-size:.88rem;font-weight:500;text-decoration:none;transition:all .2s;position:relative}
.desktop-nav a:hover{color:#fff}
.desktop-nav a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:#fcb900;transition:width .2s}
.desktop-nav a:hover::after{width:100%}

.header-right{display:flex;align-items:center;gap:16px}

.header-cta{background:#f50;color:#fff;padding:9px 22px;border-radius:50px;font-weight:700;font-size:.85rem;text-decoration:none;transition:all .2s;border:2px solid #f50}
.header-cta:hover{background:transparent;color:#fff;border-color:#fff}

/* BURGER */
.burger{display:none;background:none;border:none;cursor:pointer;padding:8px;z-index:1001}
.burger span{display:block;width:26px;height:2.5px;background:#fff;border-radius:2px;margin:5px 0;transition:all .3s}
.burger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.burger.active span:nth-child(2){opacity:0}
.burger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* OFF-CANVAS */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:999;opacity:0;visibility:hidden;transition:all .3s}
.overlay.active{opacity:1;visibility:visible}

.offcanvas{position:fixed;top:0;right:-340px;width:320px;max-width:88vw;height:100vh;height:100dvh;background:#fff;z-index:1002;transition:right .35s ease;overflow-y:auto;box-shadow:-4px 0 30px rgba(0,0,0,.15)}
.offcanvas.active{right:0}

.offcanvas-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #eee}
.offcanvas-logo{font-size:1.1rem;font-weight:700;color:#222}

.offcanvas-close{background:none;border:none;font-size:2rem;cursor:pointer;color:#333;line-height:1;padding:4px}
.offcanvas ul{padding:10px 0}
.offcanvas li{margin:0}
.offcanvas a{display:block;padding:14px 24px;font-size:1rem;color:#222;border-bottom:1px solid #f5f5f5;text-decoration:none;transition:background .15s}
.offcanvas a:hover{background:#fff5f0;color:#f50}

.offcanvas-contact{padding:20px 24px;border-top:1px solid #eee;display:flex;flex-direction:column;gap:10px}
.offcanvas-cta{display:block;text-align:center;background:#f50;color:#fff;font-weight:700;padding:12px;border-radius:50px;text-decoration:none}

/* ===== HERO ===== */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg-img{width:100%;height:100%;object-fit:cover;object-position:center}
.hero-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(180,60,0,.75) 0%,rgba(200,70,0,.85) 50%,rgba(140,40,0,.9) 100%)}
.hero-content{position:relative;z-index:2;max-width:750px;padding:0 20px}

.hero-tag{display:inline-block;background:rgba(255,255,255,.15);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.2);padding:8px 24px;border-radius:50px;font-size:.85rem;font-weight:600;margin-bottom:20px;letter-spacing:.5px}

.hero h1{font-size:3rem;color:#fff;margin-bottom:20px;font-weight:800;text-shadow:0 2px 12px rgba(0,0,0,.2)}
.hero p{font-size:1.15rem;margin-bottom:32px;opacity:.92;max-width:600px;margin-left:auto;margin-right:auto}

.hero-buttons{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-bottom:40px}
.hero-badges{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.badge{background:rgba(255,255,255,.12);backdrop-filter:blur(4px);padding:10px 20px;border-radius:50px;font-size:.85rem;font-weight:600;border:1px solid rgba(255,255,255,.2)}

/* ===== PHONE STRIP ===== */
.phone-strip{background:#1a1a1a;color:#fff;text-align:center;padding:14px 20px}
.phone-strip p{font-size:.95rem;margin:0}
.phone-strip a{color:#fcb900;font-weight:700;text-decoration:none}
.phone-strip a:hover{text-decoration:underline;color:#fcb900}

/* ===== SECTIONS ===== */
.section{padding:80px 0}
.section-alt{background:#f7f7f7}
.section-title{text-align:center;margin-bottom:16px;font-size:2rem}
.section-title::after{content:'';display:block;width:60px;height:3px;background:#f50;margin:12px auto 0;border-radius:2px}
.section-subtitle{text-align:center;max-width:700px;margin:0 auto 50px;color:#555;font-size:1rem}

/* ===== SERVICE CARDS ===== */
.services-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:30px}

.service-card{background:#fff;border:1px solid #eee;border-radius:16px;overflow:hidden;transition:box-shadow .3s,transform .3s}
.service-card:hover{box-shadow:0 12px 40px rgba(0,0,0,.08);transform:translateY(-3px)}

.service-img{height:220px;overflow:hidden;background:#f0f0f0}
.service-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.service-card:hover .service-img img{transform:scale(1.04)}

.service-body{padding:28px}
.service-card h3{margin-bottom:12px;font-size:1.35rem}
.service-card h3 a{color:#f50;text-decoration:none}
.service-card h3 a:hover{text-decoration:underline}
.service-card h4{margin-top:18px;margin-bottom:8px;color:#333;font-size:1.05rem}
.service-card p{color:#555;margin-bottom:10px;font-size:.93rem}
.service-card ul{margin:10px 0 16px 20px;list-style:disc}
.service-card ul li{color:#555;font-size:.93rem;margin-bottom:6px}

.service-phone{margin-top:18px;padding:12px 16px;background:#fff5f0;border-radius:8px;font-weight:600;font-size:.95rem;color:#c44000;border-left:3px solid #f50}
.service-phone a{color:#f50;font-weight:700;text-decoration:none}
.service-phone a:hover{text-decoration:underline}

/* ===== ABOUT ===== */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:start}
.about-text p{margin-bottom:16px;color:#444}
.about-cta{margin-top:24px}
.about-features{display:flex;flex-direction:column;gap:18px}

.feature{display:flex;gap:16px;align-items:flex-start;background:#fff;padding:20px;border-radius:12px;border:1px solid #eee;transition:box-shadow .2s}
.feature:hover{box-shadow:0 4px 16px rgba(0,0,0,.04)}
.feature-icon{font-size:1.6rem;flex-shrink:0}
.feature h4{margin-bottom:4px;color:#222;font-size:1rem}
.feature p{color:#555;font-size:.88rem}

/* ===== URGENCY BANNER ===== */
.urgency-banner{background:linear-gradient(135deg,#1a1a1a,#2a2a2a);color:#fff;padding:60px 20px;text-align:center}
.urgency-banner h2{color:#fcb900;font-size:2rem;margin-bottom:16px}
.urgency-banner p{max-width:700px;margin:0 auto 12px;opacity:.88;font-size:.95rem}
.urgency-banner .btn{margin-top:20px}

/* ===== DETAIL BLOCKS ===== */
.detail-block{margin-bottom:36px;padding-bottom:28px;border-bottom:1px solid #eee}
.detail-block:last-child{border-bottom:none;margin-bottom:0}
.detail-block h3{color:#f50;margin-bottom:10px}
.detail-block h4{margin-top:14px;margin-bottom:6px;color:#333}
.detail-block p{color:#444;margin-bottom:10px;font-size:.95rem}
.detail-block a{color:#f50;font-weight:600}

/* ===== PRICES ===== */
.price-table-title{color:#f50;margin:40px 0 16px;text-align:center}
.price-table-title:first-of-type{margin-top:0}
.table-wrapper{overflow-x:auto;margin-bottom:10px}
table{width:100%;border-collapse:collapse;background:#fff;border-radius:10px;overflow:hidden;box-shadow:0 1px 6px rgba(0,0,0,.05)}
thead{background:#f50;color:#fff}
th,td{padding:14px 20px;text-align:left;font-size:.93rem}
th{font-weight:600}
tbody tr{border-bottom:1px solid #f0f0f0}
tbody tr:nth-child(odd){background:#fafafa}
tbody tr:hover{background:#fff5f0}

/* ===== WORKS ===== */
.works-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
a.work-card{text-decoration:none;color:inherit;display:block}
a.work-card:hover{color:inherit}
.work-card{background:#fff;border-radius:14px;overflow:hidden;border:1px solid #eee;transition:box-shadow .3s,transform .3s}
.work-card:hover{box-shadow:0 8px 24px rgba(0,0,0,.07);transform:translateY(-3px)}
.work-img{height:180px;display:flex;align-items:center;justify-content:center;font-size:.95rem;font-weight:600;color:#666}
.work-card h4{padding:16px 16px 4px;font-size:1.05rem;color:#222}
.work-card p{padding:0 16px 16px;color:#555;font-size:.88rem}

/* ===== TEAM ===== */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.team-card{text-align:center;background:#fff;border-radius:14px;padding:0;border:1px solid #eee;overflow:hidden;transition:box-shadow .3s}
.team-card:hover{box-shadow:0 8px 24px rgba(0,0,0,.07)}

.team-photo{width:100%;height:240px;overflow:hidden;background:#e8e8e8}
.team-photo img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.team-card:hover .team-photo img{transform:scale(1.04)}

.team-card h4{margin:16px 16px 4px;font-size:1.05rem}
.team-role{display:block;color:#f50;font-size:.82rem;font-weight:700;margin:0 16px 8px;text-transform:uppercase;letter-spacing:.5px}
.team-card p{color:#555;font-size:.88rem;padding:0 16px 20px}

/* ===== CONTACT ===== */
.contact-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:50px;align-items:start}

.contact-form-wrap{background:#fff;border:1px solid #eee;border-radius:16px;padding:36px;position:relative;overflow:hidden;min-height:400px}
.contact-form-wrap h3{color:#f50;margin-bottom:24px;font-size:1.3rem}

.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{margin-bottom:18px}
.form-group label{display:block;margin-bottom:6px;font-size:.88rem;font-weight:600;color:#333}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 16px;border:1.5px solid #ddd;border-radius:10px;font-size:.95rem;font-family:inherit;transition:border-color .2s,box-shadow .2s;background:#fafafa}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#f50;background:#fff;box-shadow:0 0 0 3px rgba(255,85,0,.1)}
.form-group textarea{resize:vertical}
.form-group select{cursor:pointer;appearance:auto}

.form-check{display:flex;align-items:flex-start;gap:4px}
.form-check label{display:flex;align-items:flex-start;gap:8px;font-size:.85rem;color:#555;cursor:pointer}
.form-check input[type="checkbox"]{margin-top:3px;flex-shrink:0;width:16px;height:16px;accent-color:#f50}

.form-submit{width:100%;margin-top:8px;position:relative;overflow:hidden}

/* Button loading state */
.form-submit .btn-spinner{display:none;width:20px;height:20px;border:2.5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite;margin-left:10px;vertical-align:middle}
.form-submit.loading .btn-text{opacity:.7}
.form-submit.loading .btn-spinner{display:inline-block}
.form-submit.loading{pointer-events:none;opacity:.85}

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

/* ===== FORM SUCCESS STATE ===== */
.form-success{display:none;text-align:center;padding:40px 20px}

.contact-form-wrap.submitted .contact-form{display:none}
.contact-form-wrap.submitted .form-success{display:block;animation:successFadeIn .6s ease-out}

@keyframes successFadeIn{
  from{opacity:0;transform:translateY(30px)}
  to{opacity:1;transform:translateY(0)}
}

/* Animated Checkmark */
.success-checkmark{width:80px;height:80px;margin:0 auto 24px}

.checkmark-svg{width:80px;height:80px;border-radius:50%;display:block;stroke-width:2;stroke:#4caf50;stroke-miterlimit:10;box-shadow:inset 0 0 0 #4caf50;animation:fillCheck .4s ease-in-out .4s forwards,scaleCheck .3s ease-in-out .9s both}

.checkmark-circle{stroke-dasharray:166;stroke-dashoffset:166;stroke-width:2;stroke-miterlimit:10;stroke:#4caf50;fill:none;animation:strokeCircle .6s cubic-bezier(.65,0,.45,1) forwards}

.checkmark-check{transform-origin:50% 50%;stroke-dasharray:48;stroke-dashoffset:48;stroke-width:3;animation:strokeCheck .3s cubic-bezier(.65,0,.45,1) .8s forwards}

@keyframes strokeCircle{
  100%{stroke-dashoffset:0}
}
@keyframes strokeCheck{
  100%{stroke-dashoffset:0}
}
@keyframes fillCheck{
  100%{box-shadow:inset 0 0 0 40px rgba(76,175,80,.08)}
}
@keyframes scaleCheck{
  0%,100%{transform:none}
  50%{transform:scale3d(1.1,1.1,1)}
}

.success-title{font-size:1.6rem;color:#222;margin-bottom:12px;animation:successSlideUp .5s ease-out .5s both}
.success-text{color:#555;font-size:1rem;margin-bottom:28px;max-width:400px;margin-left:auto;margin-right:auto;animation:successSlideUp .5s ease-out .65s both}

.success-details{display:flex;flex-direction:column;gap:12px;margin-bottom:32px;animation:successSlideUp .5s ease-out .8s both}
.success-detail-item{display:flex;align-items:center;justify-content:center;gap:10px;font-size:.95rem;color:#333;font-weight:500}
.success-icon{font-size:1.2rem}

@keyframes successSlideUp{
  from{opacity:0;transform:translateY(15px)}
  to{opacity:1;transform:translateY(0)}
}

#sendAnotherBtn{animation:successSlideUp .5s ease-out 1s both}

/* ===== FORM ERROR MESSAGE ===== */
.form-message{margin-top:16px;padding:12px;border-radius:8px;font-size:.9rem;display:none}
.form-message.error{display:block;background:#fce4ec;color:#c62828;border:1px solid #ef9a9a;animation:shakeError .4s ease}

@keyframes shakeError{
  0%,100%{transform:translateX(0)}
  20%{transform:translateX(-8px)}
  40%{transform:translateX(8px)}
  60%{transform:translateX(-4px)}
  80%{transform:translateX(4px)}
}

.contact-info{padding-top:10px}
.contact-info h3{color:#f50;margin-bottom:12px;font-size:1.2rem}
.contact-info p{color:#444;margin-bottom:12px;font-size:.93rem}
.contact-item{margin-bottom:14px}
.contact-item strong{display:block;margin-bottom:2px;font-size:.9rem}
.contact-item a{color:#f50;font-weight:600}
.contact-map{margin-top:20px}
.contact-map iframe{width:100%;border-radius:12px}

/* ===== FAQ v2 — DARK SPLIT LAYOUT ===== */
.faq-section{
  background:#0d0d0d;
  padding:100px 0;
}

.faq-layout{
  display:grid;
  grid-template-columns:1fr 1.4fr;
  gap:60px;
  align-items:start;
}

/* --- Sidebar --- */
.faq-sidebar{
  position:sticky;
  top:100px;
}

.faq-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:.72rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:2px;
  color:#f50;
  margin-bottom:24px;
}
.faq-badge-dot{
  width:8px;
  height:8px;
  background:#f50;
  border-radius:50%;
  display:inline-block;
  animation:pulseDot 2s ease infinite;
}
@keyframes pulseDot{
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.5;transform:scale(.7)}
}

.faq-main-title{
  font-size:3rem;
  font-weight:900;
  color:#fff;
  line-height:1.1;
  margin-bottom:20px;
}

.faq-main-desc{
  color:#888;
  font-size:.95rem;
  line-height:1.7;
  margin-bottom:36px;
}

.faq-contact-hint p{
  color:#555;
  font-size:.85rem;
  margin-bottom:8px;
}
.faq-contact-link{
  color:#f50;
  font-weight:700;
  font-size:.95rem;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  gap:4px;
  transition:gap .2s,color .2s;
}
.faq-contact-link:hover{
  gap:10px;
  color:#fcb900;
}

/* --- Questions column --- */
.faq-questions{
  display:flex;
  flex-direction:column;
  gap:8px;
}

/* --- Individual item --- */
.faq-item-v2{
  border-radius:12px;
  background:#161616;
  border:1px solid #222;
  overflow:hidden;
  transition:border-color .3s,background .3s,box-shadow .3s;
}
.faq-item-v2:hover{
  border-color:#333;
  background:#1a1a1a;
}
.faq-item-v2.open{
  border-color:rgba(255,85,0,.3);
  background:#1a1a1a;
  box-shadow:0 0 30px rgba(255,85,0,.05),0 8px 24px rgba(0,0,0,.3);
}

/* --- Button trigger --- */
.faq-btn{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:22px 24px;
  background:none;
  border:none;
  cursor:pointer;
  font-family:inherit;
  text-align:left;
  transition:padding .3s;
}
.faq-item-v2.open .faq-btn{
  padding-bottom:8px;
}

.faq-btn-text{
  font-size:1rem;
  font-weight:600;
  color:#ccc;
  transition:color .3s;
  line-height:1.4;
  flex:1;
}
.faq-item-v2:hover .faq-btn-text{
  color:#eee;
}
.faq-item-v2.open .faq-btn-text{
  color:#fff;
}

/* --- Arrow icon (chevron style) --- */
.faq-arrow{
  width:36px;
  height:36px;
  flex-shrink:0;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:8px;
  background:#222;
  transition:background .3s,transform .4s cubic-bezier(.4,0,.2,1);
}
.faq-item-v2:hover .faq-arrow{
  background:#2a2a2a;
}
.faq-item-v2.open .faq-arrow{
  background:rgba(255,85,0,.15);
  transform:rotate(180deg);
}

.faq-arrow svg{
  width:16px;
  height:16px;
  stroke:#666;
  stroke-width:2;
  fill:none;
  transition:stroke .3s;
}
.faq-item-v2:hover .faq-arrow svg{
  stroke:#999;
}
.faq-item-v2.open .faq-arrow svg{
  stroke:#f50;
}

/* --- Answer panel --- */
.faq-panel{
  max-height:0;
  overflow:hidden;
  transition:max-height .45s cubic-bezier(.4,0,.2,1);
}

.faq-panel-inner{
  padding:4px 24px 24px 24px;
  opacity:0;
  transform:translateY(-6px);
  transition:opacity .3s ease .08s,transform .3s ease .08s;
}
.faq-item-v2.open .faq-panel-inner{
  opacity:1;
  transform:translateY(0);
}

.faq-panel-inner p{
  color:#888;
  font-size:.9rem;
  line-height:1.8;
  margin:0;
  border-left:2px solid rgba(255,85,0,.2);
  padding-left:16px;
}

.faq-panel-inner a{
  color:#f50;
  font-weight:600;
  text-decoration:none;
  transition:color .2s;
}
.faq-panel-inner a:hover{
  color:#fcb900;
}

/* ===== FAQ RESPONSIVE ===== */
@media(max-width:900px){
  .faq-layout{
    grid-template-columns:1fr;
    gap:40px;
  }
  .faq-sidebar{
    position:static;
    text-align:center;
  }
  .faq-main-title{
    font-size:2.2rem;
  }
  .faq-main-title br{
    display:none;
  }
  .faq-contact-hint{
    display:none;
  }
}

@media(max-width:640px){
  .faq-section{
    padding:60px 0;
  }
  .faq-main-title{
    font-size:1.8rem;
  }
  .faq-btn{
    padding:18px 16px;
  }
  .faq-btn-text{
    font-size:.92rem;
  }
  .faq-panel-inner{
    padding:4px 16px 20px 16px;
  }
  .faq-arrow{
    width:32px;
    height:32px;
  }
  .faq-arrow svg{
    width:14px;
    height:14px;
  }
}


/* ===== FOOTER ===== */
.site-footer{background:#111;color:#aaa;padding:0}
.footer-top{padding:40px 0 0;border-bottom:1px solid #222;margin-bottom:30px;padding-bottom:30px}
.footer-brand h4{color:#fff;font-size:1.3rem;margin-bottom:8px}
.footer-brand p{font-size:.9rem;max-width:500px;margin-bottom:12px}

.footer-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;padding-bottom:30px}
.footer-col h5{color:#fff;margin-bottom:14px;font-size:1rem}
.footer-col p{font-size:.85rem;margin-bottom:6px}
.footer-col a{color:#ccc;text-decoration:none;transition:color .2s}
.footer-col a:hover{color:#f50}
.footer-col ul li{margin-bottom:5px;font-size:.85rem}

.footer-bottom{padding:20px 0;border-top:1px solid #222;text-align:center;font-size:.8rem}
.footer-bottom p{margin-bottom:4px}
.footer-bottom a{color:#f50}

/* ===== BACK TO TOP ===== */
.back-to-top{position:fixed;bottom:80px;right:20px;width:48px;height:48px;background:#f50;color:#fff;border:none;border-radius:50%;font-size:1.3rem;cursor:pointer;opacity:0;visibility:hidden;transition:all .3s;z-index:900;box-shadow:0 4px 16px rgba(255,85,0,.3)}
.back-to-top.visible{opacity:1;visibility:visible}
.back-to-top:hover{background:#d44500;transform:translateY(-3px)}

/* ===== CONFETTI CANVAS ===== */
#confettiCanvas{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:9999}

/* ===== STICKY CTA MOBILE ===== */
.sticky-cta-mobile{display:none;position:fixed;bottom:0;left:0;right:0;z-index:998;background:#f50;text-align:center;padding:14px;box-shadow:0 -2px 12px rgba(0,0,0,.15)}
.sticky-cta-mobile a{color:#fff;font-weight:700;font-size:1.05rem;text-decoration:none}

/* ===== RESPONSIVE: TABLET ===== */
@media(max-width:1024px){
  .desktop-nav{display:none}
  .burger{display:block}
  .header-cta{display:none}
  .header-inner{height:64px}
  .hero h1{font-size:2.4rem}
  .services-grid{grid-template-columns:1fr}
  .about-grid{grid-template-columns:1fr}
  .works-grid{grid-template-columns:repeat(2,1fr)}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .contact-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .form-row{grid-template-columns:1fr}
}

/* ===== RESPONSIVE: MOBILE ===== */
@media(max-width:640px){
  body{font-size:15px}
  .hero{min-height:85vh;padding:80px 16px 50px}
  .hero h1{font-size:1.9rem}
  .hero p{font-size:1rem}
  .hero-buttons{flex-direction:column;align-items:center}
  .hero-badges{flex-direction:column;align-items:center}
  .section{padding:50px 0}
  .section-title{font-size:1.5rem}
  h3{font-size:1.25rem}
  .works-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr}
  .team-photo{height:280px}
  .footer-grid{grid-template-columns:1fr}
  .sticky-cta-mobile{display:block}
  .back-to-top{bottom:76px}
  table{font-size:.84rem}
  th,td{padding:10px 12px}
  .service-img{height:180px}
  .contact-form-wrap{padding:24px 18px}
  .phone-strip{font-size:.85rem;padding:10px 16px}
  .success-details{gap:8px}
  .success-title{font-size:1.3rem}
}

/* ===== RESPONSIVE: SMALL ===== */
@media(max-width:380px){
  .hero h1{font-size:1.55rem}
  .btn{padding:12px 24px;font-size:.9rem}
  .btn-large{padding:14px 28px;font-size:.95rem}
  .logo-text{font-size:1rem}
  .service-body{padding:20px}
}


/* ===== OUTBOUND LINKS ===== */
.outbound-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:32px;
}

.outbound-card{
  background:#fff;
  border-radius:18px;
  padding:40px 36px;
  position:relative;
  overflow:hidden;
  border:1px solid #e8e8e8;
  transition:box-shadow .4s ease,transform .4s ease;
}
.outbound-card:hover{
  box-shadow:0 16px 48px rgba(0,0,0,.07);
  transform:translateY(-4px);
}

/* Decorative side stripe */
.outbound-card::before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  width:5px;
  height:100%;
  background:linear-gradient(180deg,#f50 0%,#fcb900 100%);
  border-radius:18px 0 0 18px;
  transition:width .3s ease;
}
.outbound-card:hover::before{
  width:6px;
}

/* Large number watermark */
.outbound-number{
  position:absolute;
  top:-10px;
  right:20px;
  font-size:7rem;
  font-weight:900;
  color:rgba(255,85,0,.04);
  line-height:1;
  pointer-events:none;
  user-select:none;
  transition:color .4s ease;
}
.outbound-card:hover .outbound-number{
  color:rgba(255,85,0,.07);
}

.outbound-content{
  position:relative;
  z-index:1;
}

.outbound-tag{
  display:inline-block;
  font-size:.7rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:1.5px;
  color:#999;
  margin-bottom:14px;
}

.outbound-title{
  font-size:1.35rem;
  color:#1a1a1a;
  font-weight:800;
  line-height:1.3;
  margin-bottom:16px;
}

.outbound-divider{
  width:40px;
  height:3px;
  background:linear-gradient(90deg,#f50,#fcb900);
  border-radius:2px;
  margin-bottom:18px;
  transition:width .3s ease;
}
.outbound-card:hover .outbound-divider{
  width:60px;
}

.outbound-text{
  color:#555;
  font-size:.95rem;
  line-height:1.75;
  margin-bottom:20px;
}
.outbound-text a{
  color:#f50;
  font-weight:600;
  text-decoration:none;
  border-bottom:1.5px solid rgba(255,85,0,.25);
  transition:border-color .2s,color .2s;
}
.outbound-text a:hover{
  color:#c44000;
  border-bottom-color:#c44000;
}

.outbound-source{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:.78rem;
  color:#bbb;
  font-weight:500;
  letter-spacing:.3px;
}
.outbound-source::before{
  content:'';
  display:inline-block;
  width:8px;
  height:8px;
  background:#f50;
  border-radius:50%;
  opacity:.4;
}

/* ===== RESPONSIVE ===== */
@media(max-width:768px){
  .outbound-grid{
    grid-template-columns:1fr;
    gap:20px;
  }
  .outbound-card{
    padding:28px 24px;
  }
  .outbound-number{
    font-size:5rem;
    right:12px;
  }
  .outbound-title{
    font-size:1.15rem;
  }
}
