/* ===== ICON THEME — DARK MODE DEFAULT ===== */
:root {
  --t-primary:#fff;--t-primary-hover:#e0e0e0;--t-secondary:#1a1a1a;--t-accent:#fff;
  --t-bg:#111;--t-surface:#1a1a1a;--t-text:#fff;--t-text-secondary:rgba(255,255,255,.7);
  --t-border:rgba(255,255,255,.08);--t-error:#f87171;--t-success:#34d399;
  --t-font-heading:'Titillium Web',sans-serif;--t-font-body:'Raleway',sans-serif;
  --t-radius:0;--t-radius-sm:0;--t-radius-lg:0;--t-max-width:1280px;
  --t-shadow:0 2px 15px rgba(0,0,0,.25);--t-shadow-lg:0 15px 40px rgba(0,0,0,.3);
  --bg:#111;--bg-alt:#1a1a1a;
  --text:#fff;--text-body:rgba(255,255,255,.7);--text-muted:rgba(255,255,255,.45);--text-num:#8f8f8f;
  --border:rgba(255,255,255,.08);--accent:#fff;
  --btn-bg:#fff;--btn-color:#1a1a1a;
}

/* ===== LIGHT MODE ===== */
[data-theme="light"] {
  --t-primary:#1a1a1a;--t-primary-hover:#333;--t-secondary:#1a1a1a;--t-accent:#1a1a1a;
  --t-bg:#fff;--t-surface:#f5f5f5;--t-text:#1a1a1a;--t-text-secondary:#555;
  --t-border:rgba(0,0,0,.08);--t-error:#ef4444;--t-success:#10b981;
  --t-shadow:0 2px 15px rgba(0,0,0,.1);--t-shadow-lg:0 15px 40px rgba(0,0,0,.12);
  --bg:#fff;--bg-alt:#f5f5f5;
  --text:#1a1a1a;--text-body:#555;--text-muted:#8f8f8f;--text-num:#8f8f8f;
  --border:rgba(0,0,0,.08);--accent:#1a1a1a;
  --btn-bg:#1a1a1a;--btn-color:#fff;
}

/* ===== DARK MODE (explicit) ===== */
[data-theme="dark"] {
  --t-primary:#fff;--t-primary-hover:#e0e0e0;--t-accent:#fff;
  --t-bg:#111;--t-surface:#1a1a1a;--t-text:#fff;--t-text-secondary:rgba(255,255,255,.7);
  --t-border:rgba(255,255,255,.08);--t-error:#f87171;--t-success:#34d399;
  --bg:#111;--bg-alt:#1a1a1a;
  --text:#fff;--text-body:rgba(255,255,255,.7);--text-muted:rgba(255,255,255,.45);
  --border:rgba(255,255,255,.08);--accent:#fff;
  --btn-bg:#fff;--btn-color:#1a1a1a;
}

/* ===== RESET ===== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Raleway',sans-serif;font-weight:400;font-size:16px;color:var(--text-body);background:var(--bg);overflow-x:hidden;transition:background .4s,color .4s}
a{text-decoration:none;color:inherit;transition:all .3s}
ul{list-style:none}img{max-width:100%;height:auto;display:block}
section{transition:background .4s}

/* ===== HEADER 92px ===== */
#site-header{position:fixed;top:0;left:0;width:100%;z-index:1000;height:92px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:0 50px;transition:background .4s,box-shadow .4s}
#site-header.scrolled{background:var(--bg-alt);backdrop-filter:blur(12px);box-shadow:0 2px 15px rgba(0,0,0,.25)}
[data-theme="light"] #site-header.scrolled{background:rgba(255,255,255,.97)}
.logo-link{display:flex;align-items:center}
.logo-link img{height:35px;width:auto;transition:filter .4s}
[data-theme="dark"] .logo-link img{filter:brightness(0) invert(1)}
[data-theme="light"] .logo-link img{filter:none}
[data-theme="light"] #site-header:not(.scrolled) .logo-link img{filter:brightness(0) invert(1)}
.main-nav{display:flex;align-items:center;gap:35px}
.main-nav>a,.has-dropdown>a{font-family:'Titillium Web',sans-serif;font-size:14px;font-weight:400;text-transform:uppercase;color:#fff;padding:8px 0;position:relative}
[data-theme="light"] #site-header.scrolled .main-nav>a,[data-theme="light"] #site-header.scrolled .has-dropdown>a{color:#1a1a1a}
.main-nav>a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1px;background:currentColor;transition:width .3s}
.main-nav>a:hover::after,.main-nav>a.active::after{width:100%}
.has-dropdown{position:relative}
.has-dropdown>a{display:flex;align-items:center;gap:7px}
.dd-arrow{width:5px;height:5px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:rotate(45deg);display:inline-block;margin-top:-2px}
.mega-menu{position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(8px);background:rgba(20,20,20,.97);backdrop-filter:blur(14px);width:520px;padding:35px 40px;display:grid;grid-template-columns:1fr 1fr;gap:10px 50px;opacity:0;visibility:hidden;transition:all .35s cubic-bezier(.22,1,.36,1);z-index:100;border:1px solid rgba(255,255,255,.06)}
[data-theme="light"] .mega-menu{background:rgba(255,255,255,.98);box-shadow:0 15px 40px rgba(0,0,0,.12);border-color:rgba(0,0,0,.06)}
.has-dropdown:hover .mega-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.mega-col .mega-title{font-family:'Titillium Web',sans-serif;font-size:11px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:#fff;opacity:.35;margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.08)}
[data-theme="light"] .mega-col .mega-title{color:#1a1a1a;opacity:.4;border-bottom-color:rgba(0,0,0,.08)}
.mega-col a{display:flex;align-items:center;gap:8px;padding:9px 0;font-family:'Titillium Web',sans-serif;font-size:14px;font-weight:300;color:rgba(255,255,255,.65);transition:all .25s}
[data-theme="light"] .mega-col a{color:#555}
.mega-col a::before{content:'';width:0;height:1px;background:var(--accent);transition:width .25s;flex-shrink:0}
.mega-col a:hover{color:#fff;padding-left:4px}
.mega-col a:hover::before{width:14px}
[data-theme="light"] .mega-col a:hover{color:#1a1a1a}
.header-right{display:flex;align-items:center;gap:18px;justify-self:end}
.search-toggle{cursor:pointer;color:#fff;opacity:.8;transition:opacity .3s;background:none;border:none;padding:5px}
.search-toggle:hover{opacity:1}
[data-theme="light"] #site-header.scrolled .search-toggle{color:#1a1a1a}
.cart-toggle{position:relative;cursor:pointer;color:#fff;opacity:.8;transition:opacity .3s;text-decoration:none;padding:5px;display:flex;align-items:center}
.cart-toggle:hover{opacity:1}
[data-theme="light"] #site-header.scrolled .cart-toggle{color:#1a1a1a}
.cart-badge{position:absolute;top:-4px;right:-6px;min-width:16px;height:16px;border-radius:50%;background:#ef4444;color:#fff;font-family:'Titillium Web',sans-serif;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1;padding:0 4px}
.theme-toggle{cursor:pointer;background:none;border:1px solid rgba(255,255,255,.3);color:#fff;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .3s;font-size:15px}
.theme-toggle:hover{background:rgba(255,255,255,.1)}
[data-theme="light"] #site-header.scrolled .theme-toggle{border-color:rgba(0,0,0,.15);color:#1a1a1a}
.hamburger{display:flex;cursor:pointer;background:none;border:none;flex-direction:column;gap:6px;padding:8px;margin-left:5px}
.hamburger span{width:25px;height:1.5px;background:#fff;display:block;transition:all .3s}
.hamburger span:nth-child(2){width:18px}
[data-theme="light"] #site-header.scrolled .hamburger span{background:#1a1a1a}

/* ===== SIDE PANEL ===== */
.side-panel-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:2000;opacity:0;visibility:hidden;transition:all .4s}
.side-panel-overlay.open{opacity:1;visibility:visible}
.side-panel{position:fixed;top:0;right:-420px;width:420px;height:100vh;background:#1a1a1a;z-index:2001;padding:50px 45px;transition:right .5s cubic-bezier(.22,1,.36,1);overflow-y:auto}
.side-panel.open{right:0}
.side-panel .sp-close{position:absolute;top:25px;right:30px;background:none;border:none;color:#fff;font-size:28px;cursor:pointer;opacity:.6;transition:opacity .3s;width:40px;height:40px;display:flex;align-items:center;justify-content:center}
.side-panel .sp-close:hover{opacity:1}
.side-panel .sp-logo{margin-bottom:30px}
.side-panel .sp-logo img{height:35px;filter:brightness(0) invert(1)}
.side-panel .sp-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:35px}
.side-panel .sp-gallery img{width:100%;aspect-ratio:1;object-fit:cover}
.side-panel .sp-title{font-family:'Titillium Web',sans-serif;font-weight:400;font-size:22px;color:#fff;margin-bottom:22px}
.side-panel .sp-contact{margin-bottom:12px;display:flex;align-items:flex-start;gap:14px}
.side-panel .sp-contact .sp-ico{opacity:.4;margin-top:3px;min-width:20px;text-align:center;font-size:15px;color:#fff}
.side-panel .sp-contact span,.side-panel .sp-contact a{font-size:14px;line-height:1.7;color:rgba(255,255,255,.7)}
.side-panel .sp-contact a:hover{color:var(--accent)}
.side-panel .sp-social{display:flex;gap:12px;margin-top:28px}
.side-panel .sp-social a{width:42px;height:42px;border:1px solid rgba(255,255,255,.15);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;transition:all .3s}
.side-panel .sp-social a:hover{background:#fff;color:#1a1a1a;border-color:#fff}

/* ===== SIDEBAR SOCIAL ===== */
.sidebar-social{position:fixed;left:0;top:50%;transform:translateY(-50%);z-index:100;display:flex;flex-direction:column}
.sidebar-social a{writing-mode:vertical-rl;text-orientation:mixed;font-size:10px;font-weight:600;letter-spacing:3px;text-transform:uppercase;padding:22px 14px;color:var(--text);opacity:.4;transition:opacity .3s,background .3s}
.sidebar-social a:hover{opacity:.8;background:rgba(128,128,128,.08)}

/* ===== HERO SLIDER ===== */
.hero-slider{position:relative;height:100vh;overflow:hidden;background:#000}
.slide{position:absolute;inset:0;opacity:0;visibility:hidden;transition:opacity 1.2s,visibility 1.2s}
.slide.active{opacity:1;visibility:visible}
.slide-bg{position:absolute;inset:-5%;width:110%;height:110%;background-size:cover;background-position:center;filter:brightness(.5);transform:scale(1);transition:transform 8s ease}
.slide.active .slide-bg{transform:scale(1.05)}
.slide-content{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;padding:0 40px}
.slide-content h1{font-family:'Titillium Web',sans-serif;font-weight:200;font-size:90px;line-height:1.05;color:#fff;margin-bottom:25px;opacity:0;transform:translateY(40px);transition:opacity 1s .3s,transform 1s .3s}
.slide.active h1{opacity:1;transform:translateY(0)}
.slide-content p{font-size:16px;line-height:1.9;color:rgba(255,255,255,.85);max-width:620px;margin-bottom:35px;opacity:0;transform:translateY(25px);transition:opacity 1s .6s,transform 1s .6s}
.slide.active p{opacity:1;transform:translateY(0)}
.slide.active .btn-wrap{opacity:1;transform:translateY(0)}
.slide-content .btn-wrap{opacity:0;transform:translateY(15px);transition:opacity 1s .9s,transform 1s .9s}
.slide.active .btn-wrap{opacity:1;transform:translateY(0)}
.btn-slider{display:inline-block;padding:15px 38px;background:rgba(26,26,26,.55);border:1px solid rgba(255,255,255,.4);color:#fff;font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;transition:all .4s}
.btn-slider:hover{background:#fff;color:#1a1a1a;border-color:#fff}
.slider-arrows{position:absolute;bottom:40px;right:50px;display:flex;gap:8px;z-index:10}
.slider-arrows button{width:55px;height:55px;border:1px solid rgba(255,255,255,.25);background:transparent;color:#fff;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s}
.slider-arrows button:hover{background:rgba(255,255,255,.12)}
.slider-dots{position:absolute;bottom:50px;left:50%;transform:translateX(-50%);display:flex;gap:10px;z-index:10}
.slider-dots button{width:12px;height:12px;border-radius:50%;border:1.5px solid rgba(255,255,255,.5);background:transparent;cursor:pointer;transition:all .3s}
.slider-dots button.active{background:#fff;border-color:#fff}

/* ===== QUOTE ===== */
.quote-section{padding:90px 50px;background:var(--bg-alt);border-bottom:1px solid var(--border)}
.quote-section blockquote{font-family:'Titillium Web',sans-serif;font-weight:300;font-size:30px;line-height:1.6;color:var(--text-body);max-width:900px;margin:0 auto}

/* ===== ABOUT ===== */
.about-section{padding:110px 0;background:var(--bg);overflow:hidden}
.about-wrap{max-width:1280px;margin:0 auto;padding:0 40px;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-images{position:relative}
.about-images .main-img{width:100%;max-width:540px;height:auto;object-fit:cover;z-index:2;position:relative}
.about-images .bg-sketch{position:absolute;bottom:-30px;right:0;width:220px;opacity:.07;z-index:1}
.about-images .gallery-strip{position:absolute;top:0;right:0;display:grid;grid-template-columns:1fr 1fr;gap:4px;z-index:3}
.about-images .gallery-strip img{width:90px;height:90px;object-fit:cover;border:3px solid var(--bg)}
.about-content .label{font-size:16px;letter-spacing:normal;color:var(--text-body);margin-bottom:15px}
.about-content h2{font-family:'Titillium Web',sans-serif;font-weight:400;font-size:42px;color:var(--text);margin-bottom:18px}
.divider{width:80px;height:0;margin-bottom:25px;border-top:1px solid var(--border);position:relative}
.divider::before,.divider::after{content:'';position:absolute;top:-3px;width:6px;height:6px;background:var(--text-muted);border-radius:50%;opacity:.5}
.divider::before{left:0}.divider::after{left:15px}
.about-content p{font-size:16px;line-height:30px;color:var(--text-body);margin-bottom:32px;max-width:500px}
.btn-filled{display:inline-block;padding:18px 41px;background:var(--btn-bg);border:1px solid var(--btn-bg);color:var(--btn-color);font-size:13px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;transition:all .4s}
.btn-filled:hover{background:transparent;color:var(--text);border-color:var(--text)}

/* ===== SERVICE CARDS (styles moved to block template) ===== */

/* ===== WHY SECTION ===== */
.why-section{padding:110px 0;background:var(--bg);position:relative;overflow:hidden}
.why-section::before{content:'';position:absolute;inset:0;background:url('/themes/icon/assets/img/image1-process.png') center/80% no-repeat;opacity:.04;pointer-events:none}
.why-header{text-align:center;margin-bottom:50px;position:relative;z-index:1}
.why-header .label{font-size:14px;letter-spacing:2px;color:var(--text-muted);margin-bottom:12px}
.why-header h2{font-family:'Titillium Web',sans-serif;font-weight:300;font-size:48px;color:var(--text)}
.why-header .divider{margin:18px auto 0}
.why-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:40px;align-items:center;max-width:1280px;margin:0 auto;padding:0 40px;position:relative;z-index:1}
.why-col-left{text-align:right}
.why-col-right{text-align:left}
.why-col-center{display:flex;justify-content:center}
.why-col-center img{width:450px;height:450px;border-radius:50%;object-fit:cover}
.why-item{margin-bottom:50px}
.why-item:last-child{margin-bottom:0}
.why-item .num{font-family:'Titillium Web',sans-serif;font-weight:400;font-size:20px;color:var(--text-num);margin-bottom:6px}
.why-item h4{font-family:'Titillium Web',sans-serif;font-weight:600;font-size:20px;color:var(--text);margin-bottom:10px}
.why-item p{font-size:16px;line-height:30px;color:var(--text-body)}

/* ===== PORTFOLIO ===== */
.portfolio-section{padding:0;background:var(--bg)}
.portfolio-header{text-align:center;padding:80px 40px 40px}
.portfolio-header .label{font-size:14px;letter-spacing:2px;color:var(--text-muted);margin-bottom:12px}
.portfolio-header h2{font-family:'Titillium Web',sans-serif;font-weight:400;font-size:30px;color:var(--text);line-height:1.4}
.portfolio-header .divider{margin:18px auto 0}
.portfolio-filters{display:flex;justify-content:center;gap:30px;padding:0 40px 40px;flex-wrap:wrap}
.portfolio-filters button{background:none;border:none;color:var(--text);font-family:'Titillium Web',sans-serif;font-size:13px;font-weight:400;text-transform:uppercase;cursor:pointer;padding:6px 2px;opacity:.4;position:relative;transition:all .3s}
.portfolio-filters button:hover{opacity:.7}
.portfolio-filters button.active{opacity:1}
.portfolio-filters button.active::after{content:'';position:absolute;bottom:0;left:0;width:100%;height:1px;background:var(--text)}
.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);height:640px}
.portfolio-item{position:relative;overflow:hidden;cursor:pointer}
.portfolio-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.portfolio-item:hover img{transform:scale(1.06)}
.portfolio-hover{position:absolute;inset:0;background:rgba(0,0,0,.6);display:flex;flex-direction:column;justify-content:flex-end;padding:25px;opacity:0;transition:opacity .4s}
.portfolio-item:hover .portfolio-hover{opacity:1}
.portfolio-hover .cat{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.6);margin-bottom:5px}
.portfolio-hover h4{font-family:'Titillium Web',sans-serif;font-weight:600;font-size:17px;color:#fff}

/* ===== FOOTER ===== */
footer{background:#1a1a1a;padding:70px 0 0;color:rgba(255,255,255,.7)}
.footer-wrap{max-width:1280px;margin:0 auto;padding:0 40px}
.footer-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:60px;padding-bottom:40px}
.footer-logo{margin-bottom:25px}
.footer-logo img{height:40px;filter:brightness(0) invert(1)}
.footer-brand p{font-size:14px;line-height:2;color:rgba(255,255,255,.65);max-width:480px}
.footer-brand p strong{font-weight:600;color:#fff}
.footer-contact h3{font-family:'Titillium Web',sans-serif;font-weight:400;font-size:20px;color:#fff;margin-bottom:25px}
.contact-row{display:flex;align-items:flex-start;gap:12px;margin-bottom:14px}
.contact-row .ico{font-size:15px;opacity:.5;margin-top:2px;min-width:20px;text-align:center}
.contact-row span,.contact-row a{font-size:14px;line-height:1.7;color:rgba(255,255,255,.7)}
.contact-row a:hover{color:var(--accent)}
.social-links{display:flex;gap:12px;margin-top:25px}
.social-links a{width:44px;height:44px;border:1px solid rgba(255,255,255,.15);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;transition:all .3s}
.social-links a:hover{background:#fff;color:#1a1a1a;border-color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.06);padding:25px 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}
.footer-bottom p{font-size:12px;color:rgba(255,255,255,.35)}
.footer-bottom a{color:rgba(255,255,255,.5)}.footer-bottom a:hover{color:#fff}

/* ===== ANIMATIONS ===== */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .8s cubic-bezier(.22,1,.36,1),transform .8s cubic-bezier(.22,1,.36,1)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal.d1{transition-delay:.12s}.reveal.d2{transition-delay:.24s}

/* ===== MOBILE MENU ===== */
.mobile-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:1001;opacity:0;visibility:hidden;transition:all .35s}
.mobile-overlay.open{opacity:1;visibility:visible}
.mobile-nav{position:fixed;top:0;right:-340px;width:340px;height:100vh;background:var(--bg);z-index:1002;padding:80px 30px 40px;transition:right .4s cubic-bezier(.22,1,.36,1);overflow-y:auto}
.mobile-nav.open{right:0}
.mobile-nav .close-btn{position:absolute;top:20px;right:20px;background:none;border:none;color:var(--text);font-size:28px;cursor:pointer}
.mobile-nav a{display:block;padding:13px 0;font-family:'Titillium Web',sans-serif;font-size:14px;font-weight:400;text-transform:uppercase;color:var(--text);border-bottom:1px solid var(--border)}
.mobile-nav .sub-label-m{padding:10px 0 2px;font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--text-muted);border:none}
.mobile-nav .sub a{padding-left:20px;font-size:12px;color:var(--text-body)}

/* ===== RESPONSIVE ===== */
/* ===== RESPONSIVE ===== */

/* Tablet: hide desktop nav, switch header to 2-col */
@media(max-width:1100px){
    .main-nav{display:none}
    #site-header{padding:0 20px;grid-template-columns:1fr auto}
}

/* Tablet */
@media(max-width:1024px){
    .about-wrap{grid-template-columns:1fr;text-align:center}
    .about-images .main-img{width:100%;max-width:400px;margin:0 auto}
    .about-images .gallery-strip{display:none}
    .about-content p{max-width:100%;margin-inline:auto}
    /* services-grid styles in block template */
    .why-grid{grid-template-columns:1fr;text-align:center}
    .why-col-left,.why-col-right{text-align:center}
    .why-col-center{order:-1}
    .why-col-center img{width:280px;height:280px}
    .portfolio-grid{grid-template-columns:1fr 1fr;height:auto}
    .portfolio-item{aspect-ratio:1}
    .footer-grid{grid-template-columns:1fr;gap:40px}
    .sidebar-social{display:none}
}

/* Mobile landscape */
@media(max-width:768px){
    /* Header mobile */
    #site-header{height:64px;padding:0 16px}
    .logo-link img{height:28px}
    .header-right{gap:10px}
    .search-toggle{padding:4px}
    .search-toggle svg{width:16px;height:16px}
    .theme-toggle{width:32px;height:32px;font-size:13px}
    .hamburger{padding:6px;margin-left:2px}
    .hamburger span{width:22px}

    /* Mobile nav */
    .mobile-nav{width:min(320px, 85vw);padding:70px 24px 30px}
    .mobile-nav a{padding:12px 0;font-size:13px}
    .mobile-nav .sub a{font-size:11px;padding-left:16px}
    .mobile-nav .close-btn{top:16px;right:16px;font-size:24px}

    /* Hero */
    .slide-content h1{font-size:36px}
    .slide-content p{font-size:14px;margin-bottom:20px}
    .btn-slider{padding:12px 28px;font-size:10px;letter-spacing:2px}

    /* Sections */
    .quote-section{padding:50px 20px}
    .quote-section blockquote{font-size:20px;line-height:1.5}
    .about-section,.why-section{padding:60px 0}
    .about-wrap{padding:0 20px;gap:30px}
    .about-content .label{font-size:14px}
    .about-content h2{font-size:30px}
    .about-content p{font-size:14px;line-height:1.7}
    .btn-filled{padding:14px 30px;font-size:12px}
    /* service-overlay styles in block template */
    .why-header h2{font-size:30px}
    .why-item p{font-size:14px;line-height:1.6}
    .portfolio-header{padding:50px 20px 25px}
    .portfolio-header h2{font-size:22px}
    .portfolio-filters{gap:8px;padding:0 20px 25px}
    .portfolio-filters button{font-size:11px;padding:5px 2px}

    /* Footer */
    .footer-wrap{padding:0 20px}
    .footer-brand p{font-size:13px}
    .footer-contact h3{font-size:18px}
    .footer-bottom{flex-direction:column;text-align:center;gap:4px}
    .footer-bottom p{font-size:11px}
}

/* Mobile portrait */
@media(max-width:480px){
    #site-header{height:56px;padding:0 14px}
    .logo-link img{height:24px}
    .header-right{gap:8px}
    .theme-toggle{width:28px;height:28px;font-size:12px;border-width:.5px}
    .hamburger span{width:20px;height:1px}
    .hamburger{gap:5px;padding:5px}
    .search-toggle svg{width:15px;height:15px}

    .slide-content{padding:0 20px}
    .slide-content h1{font-size:26px;margin-bottom:14px}
    .slide-content p{font-size:13px;line-height:1.6;margin-bottom:18px}
    .slider-arrows{bottom:16px;right:14px;gap:6px}
    .slider-arrows button{width:38px;height:38px;font-size:16px}
    .slider-dots{bottom:20px}
    .slider-dots button{width:10px;height:10px}

    .quote-section{padding:40px 16px}
    .quote-section blockquote{font-size:18px}
    /* services responsive in block template */

    .portfolio-grid{grid-template-columns:1fr;height:auto}
    .portfolio-item{aspect-ratio:4/3}
    .portfolio-filters{gap:6px}
    .portfolio-filters button{font-size:10px}

    .why-grid{padding:0 20px;gap:25px}
    .why-col-center img{width:200px;height:200px}
    .why-item .num{font-size:16px}
    .why-item h4{font-size:17px}
    .why-item p{font-size:13px}
    .why-header h2{font-size:26px}

    .about-content h2{font-size:26px}
    .about-content .label{font-size:13px}

    footer{padding:50px 0 0}
    .footer-logo img{height:30px}
    .social-links a{width:38px;height:38px}

    /* Mobile menu refinement */
    .mobile-nav{width:min(300px, 90vw);padding:60px 20px 24px}
    .mobile-nav a{padding:11px 0;font-size:12px;letter-spacing:1px}
    .mobile-nav .sub-label-m{font-size:9px;padding:8px 0 2px}
    .mobile-nav .sub a{font-size:11px;padding-left:14px}
}

/* ===== FLOATING WHATSAPP BUTTON ===== */
.wa-float{position:fixed;bottom:24px;z-index:999;width:56px;height:56px;background:#25d366;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 12px rgba(37,211,102,.4);transition:transform .3s,box-shadow .3s;text-decoration:none}
.wa-float:hover{transform:scale(1.1);box-shadow:0 6px 20px rgba(37,211,102,.5)}
.wa-float.wa-right{right:24px}
.wa-float.wa-left{left:24px}
.wa-tooltip{position:absolute;bottom:100%;margin-bottom:8px;white-space:nowrap;background:#1a1a1a;color:#fff;font-family:'Titillium Web',sans-serif;font-size:12px;padding:6px 12px;border-radius:6px;opacity:0;visibility:hidden;transition:opacity .25s,visibility .25s;pointer-events:none}
.wa-tooltip::after{content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:#1a1a1a}
.wa-float:hover .wa-tooltip{opacity:1;visibility:visible}
@media(max-width:768px){
    .wa-float{bottom:80px;width:50px;height:50px}
    .wa-float.wa-right{right:16px}
    .wa-float.wa-left{left:16px}
    .wa-tooltip{display:none}
}
