/* ============================================
   BATU — Production Styles
   Apple-inspired, Toss-level clean
   ============================================ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
::selection{background:rgba(0,113,227,.12);color:#0a0a0a}
section[id]{scroll-margin-top:80px}
body{overflow-x:hidden}

/* ===================== BUTTONS ===================== */
.btn-primary{display:inline-flex;align-items:center;justify-content:center;padding:16px 36px;background:#0071e3;color:#fff;font-weight:600;font-size:.938rem;border-radius:980px;transition:all .3s cubic-bezier(.25,.46,.45,.94);text-decoration:none;min-width:180px}
.btn-primary:hover{background:#0077ED;transform:scale(1.02)}.btn-primary:active{transform:scale(.98)}
.btn-secondary{display:inline-flex;align-items:center;justify-content:center;padding:16px 36px;background:transparent;color:#0071e3;font-weight:600;font-size:.938rem;border-radius:980px;border:1.5px solid #0071e3;transition:all .3s cubic-bezier(.25,.46,.45,.94);text-decoration:none;min-width:180px}
.btn-secondary:hover{background:#0071e3;color:#fff;transform:scale(1.02)}.btn-secondary:active{transform:scale(.98)}
.btn-nav{padding:10px 24px;background:#0071e3;color:#fff;font-size:.813rem;font-weight:600;border-radius:980px;text-decoration:none;transition:all .3s ease}
.btn-nav:hover{background:#0077ED}
@media(max-width:640px){.btn-primary,.btn-secondary{width:100%;min-width:unset}}

/* ===================== TYPOGRAPHY ===================== */
.text-gradient{background:linear-gradient(135deg,#0071e3 0%,#00c6ff 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* ===================== NAVBAR ===================== */
#navbar{background:rgba(255,255,255,.72);backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px)}
#navbar.scrolled{background:rgba(255,255,255,.92);box-shadow:0 1px 0 rgba(0,0,0,.06)}
.nav-logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:inherit}
.nav-logo-icon{width:32px;height:32px;border-radius:8px;background:#0071e3;display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:800}

/* Dropdown */
.nav-dropdown{position:relative}
.nav-dropdown-trigger{cursor:pointer;display:flex;align-items:center;gap:4px}
.nav-dropdown-trigger svg{transition:transform .2s}
.nav-dropdown:hover .nav-dropdown-trigger svg{transform:rotate(180deg)}
.nav-dropdown-menu{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(4px);min-width:160px;padding:8px;background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:14px;box-shadow:0 8px 32px rgba(0,0,0,.08);opacity:0;visibility:hidden;transition:all .25s cubic-bezier(.25,.46,.45,.94)}
.nav-dropdown:hover .nav-dropdown-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.nav-dropdown-menu a{display:block;padding:10px 16px;font-size:.813rem;font-weight:500;color:#444;text-decoration:none;border-radius:8px;transition:all .15s}
.nav-dropdown-menu a:hover{background:#f5f5f7;color:#0071e3}

/* Mobile */
.mobile-menu-closed{max-height:0;opacity:0;transition:max-height .4s cubic-bezier(.25,.46,.45,.94),opacity .3s ease}
.mobile-menu-open{max-height:600px;opacity:1}
.mobile-nav-link{display:block;padding:14px 0;font-size:1.125rem;font-weight:600;text-decoration:none;color:#0a0a0a;border-bottom:1px solid rgba(0,0,0,.04);transition:color .2s}
.mobile-nav-link:hover{color:#0071e3}
.mobile-nav-sub{padding-left:16px}
.mobile-nav-sub a{display:block;padding:10px 0;font-size:.938rem;font-weight:500;color:#6b7280;text-decoration:none}
.mobile-nav-sub a:hover{color:#0071e3}
.menu-active .menu-line:first-child{transform:translateY(4px) rotate(45deg)}
.menu-active .menu-line:last-child{transform:translateY(-4px) rotate(-45deg)}

/* ===================== HERO ===================== */
.hero-grid{background-image:linear-gradient(rgba(0,0,0,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.025) 1px,transparent 1px);background-size:64px 64px;animation:gridShift 25s linear infinite}
@keyframes gridShift{0%{background-position:0 0}100%{background-position:64px 64px}}
.fade-up{opacity:0;transform:translateY(28px);animation:fadeUp .8s cubic-bezier(.25,.46,.45,.94) forwards}
.delay-1{animation-delay:.12s}.delay-2{animation-delay:.24s}.delay-3{animation-delay:.36s}
@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}
.animate-float{animation:float 8s ease-in-out infinite}
.animate-float-delay{animation:float 8s ease-in-out 2s infinite}
@keyframes float{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-20px) scale(1.05)}}
.scroll-indicator{width:24px;height:40px;border:2px solid rgba(0,0,0,.12);border-radius:12px;position:relative}
.scroll-dot{width:4px;height:8px;background:rgba(0,0,0,.25);border-radius:2px;position:absolute;top:8px;left:50%;transform:translateX(-50%);animation:scrollBounce 1.6s ease-in-out infinite}
@keyframes scrollBounce{0%,100%{transform:translateX(-50%) translateY(0);opacity:1}50%{transform:translateX(-50%) translateY(12px);opacity:.3}}

/* ===================== TRUST ===================== */
.trust-logo{font-size:.75rem;font-weight:600;color:#c4c4c4;letter-spacing:.05em;transition:color .3s}
.trust-logo:hover{color:#0071e3}

/* ===================== ABOUT VISUAL (Clean 3-col) ===================== */
.about-feature-card{background:#fff;border:none;border-radius:20px;padding:28px 24px;text-align:center;transition:all .4s cubic-bezier(.25,.46,.45,.94)}
.about-feature-card:hover{box-shadow:0 12px 40px rgba(0,0,0,.08);transform:translateY(-4px)}
.about-feature-icon{width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.about-feature-bar{display:flex;gap:6px;margin-top:16px}
.about-feature-bar span{flex:1;height:6px;border-radius:3px}

/* ===================== STAT ===================== */
.stat-card{padding:16px;background:#f5f5f7;border-radius:16px;text-align:center}

/* ===================== SERVICE FEATURE MINI CARDS ===================== */
.svc-feature{transition:all .4s cubic-bezier(.25,.46,.45,.94)}
.svc-feature:hover{background:#0071e3;box-shadow:0 12px 32px rgba(0,113,227,.15);transform:translateY(-4px)}
.svc-feature:hover .about-feature-icon{background:rgba(255,255,255,.2)!important}
.svc-feature:hover .about-feature-icon svg{color:#fff!important}
.svc-feature:hover p{color:#fff!important}

/* ===================== SERVICE PREV/NEXT NAV ===================== */
.svc-nav-section{padding:0 0 20px}
.svc-nav{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.svc-nav-link{display:flex;align-items:center;gap:12px;padding:20px 24px;border-radius:16px;text-decoration:none;color:inherit;transition:color .3s ease}
.svc-nav-link:hover .svc-nav-name{color:#0071e3}
.svc-nav-link svg{flex-shrink:0;color:#ccc;transition:color .3s}
.svc-nav-link:hover svg{color:#0071e3}
.svc-nav-prev{justify-content:flex-start}
.svc-nav-next{justify-content:flex-end;text-align:right}
.svc-nav-label{display:block;font-size:11px;color:#999;margin-bottom:2px}
.svc-nav-name{display:block;font-size:14px;font-weight:600;color:#1a1a1a;transition:color .3s}
@media(max-width:640px){.svc-nav{grid-template-columns:1fr}.svc-nav-next{text-align:left;justify-content:flex-start;flex-direction:row-reverse}}

/* ===================== SERVICE CARDS (Toss Place style) ===================== */
.service-card-inner{position:relative;padding:32px;border-radius:24px;background:#fff;border:1px solid #e8e8ed;transition:all .5s cubic-bezier(.25,.46,.45,.94);height:100%;overflow:hidden}
/* Per-service hover colors */
.service-card[data-color="blue"]:hover .service-card-inner{border-color:transparent;background:#0071e3;box-shadow:0 20px 60px rgba(0,113,227,.18)}
.service-card[data-color="rose"]:hover .service-card-inner{border-color:transparent;background:#e11d48;box-shadow:0 20px 60px rgba(225,29,72,.18)}
.service-card[data-color="purple"]:hover .service-card-inner{border-color:transparent;background:#7c3aed;box-shadow:0 20px 60px rgba(124,58,237,.18)}
.service-card[data-color="violet"]:hover .service-card-inner{border-color:transparent;background:#7c3aed;box-shadow:0 20px 60px rgba(124,58,237,.18)}
.service-card[data-color="amber"]:hover .service-card-inner{border-color:transparent;background:#d97706;box-shadow:0 20px 60px rgba(217,119,6,.18)}
.service-card[data-color="green"]:hover .service-card-inner{border-color:transparent;background:#059669;box-shadow:0 20px 60px rgba(5,150,105,.18)}
.service-card[data-color="cyan"]:hover .service-card-inner{border-color:transparent;background:#0891b2;box-shadow:0 20px 60px rgba(8,145,178,.18)}
.service-card:hover .service-card-inner h3,.service-card:hover .service-card-inner p{color:#fff}
.service-card:hover .service-card-inner .service-features li{color:rgba(255,255,255,.8)}
.service-card:hover .service-card-inner .service-features svg{color:#fff!important}
.service-icon{width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;margin-bottom:20px;transition:all .4s ease}
.service-icon.blue{background:rgba(0,113,227,.07);color:#0071e3}.service-card:hover .service-icon{background:rgba(255,255,255,.2);color:#fff}
.service-icon.purple{background:rgba(139,92,246,.07);color:#8b5cf6}
.service-icon.rose{background:rgba(225,29,72,.07);color:#e11d48}
.service-icon.violet{background:rgba(124,58,237,.07);color:#7c3aed}
.service-icon.amber{background:rgba(245,158,11,.07);color:#f59e0b}
.service-icon.green{background:rgba(16,185,129,.07);color:#10b981}
.service-icon.cyan{background:rgba(6,182,212,.07);color:#06b6d4}
.service-badge{font-size:.688rem;font-weight:600;padding:4px 12px;border-radius:100px;transition:all .4s ease}
.service-card:hover .service-badge{background:rgba(255,255,255,.2)!important;color:#fff!important}
.service-badge.blue{color:#0071e3;background:rgba(0,113,227,.07)}.service-badge.purple{color:#8b5cf6;background:rgba(139,92,246,.07)}
.service-badge.rose{color:#e11d48;background:rgba(225,29,72,.07)}.service-badge.violet{color:#7c3aed;background:rgba(124,58,237,.07)}
.service-badge.amber{color:#f59e0b;background:rgba(245,158,11,.07)}.service-badge.green{color:#10b981;background:rgba(16,185,129,.07)}
.service-badge.cyan{color:#06b6d4;background:rgba(6,182,212,.07)}
.service-features{display:flex;flex-direction:column;gap:8px;font-size:.875rem;color:#6b7280}
.service-features li{display:flex;align-items:center;gap:8px;transition:color .4s ease}
.service-arrow{position:absolute;bottom:28px;right:28px;width:36px;height:36px;border-radius:12px;background:#f5f5f7;display:flex;align-items:center;justify-content:center;color:#c4c4c4;transition:all .4s ease}
.service-card:hover .service-arrow{background:rgba(255,255,255,.2);color:#fff;transform:translateX(4px)}

/* ===================== PROCESS ===================== */
.process-number{width:64px;height:64px;margin:0 auto 20px;border-radius:50%;background:#f5f5f7;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:700;color:#0071e3;transition:all .4s ease;position:relative;z-index:2}
.process-step:hover .process-number{background:#0071e3;color:#fff;transform:scale(1.08)}

/* ===================== MARQUEE ===================== */
.marquee-mask{mask-image:linear-gradient(to right,transparent,black 10%,black 90%,transparent);-webkit-mask-image:linear-gradient(to right,transparent,black 10%,black 90%,transparent);overflow:hidden}
.marquee-track{display:flex;width:max-content;animation:marquee 30s linear infinite}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.partner-logo{flex-shrink:0;width:130px;height:64px;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:16px;font-weight:600;font-size:.813rem;color:#6b7280;border:1px solid #e8e8ed;transition:all .3s ease}
.partner-logo:hover{border-color:#0071e3;color:#0071e3}
.counter-card{text-align:center;background:#fff;padding:24px;border-radius:20px;border:1px solid #e8e8ed}

/* ===================== CONTACT ===================== */
.contact-info-card{display:flex;align-items:center;gap:16px;padding:16px 20px;border-radius:16px;background:#f5f5f7;border:1px solid transparent;text-decoration:none;color:inherit;transition:all .3s ease}
.contact-info-card:hover{border-color:rgba(0,113,227,.12);background:#fff;box-shadow:0 4px 16px rgba(0,0,0,.04)}
.contact-info-icon{width:44px;height:44px;border-radius:14px;background:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:1px solid #e8e8ed}

/* ===================== FORM ===================== */
.form-label{display:block;font-size:.813rem;font-weight:600;margin-bottom:8px}
.form-input{width:100%;padding:14px 18px;border-radius:14px;background:#fff;border:1px solid #e0e0e0;font-size:.875rem;outline:none;transition:all .3s ease;font-family:inherit}
.form-input:focus{border-color:#0071e3;box-shadow:0 0 0 3px rgba(0,113,227,.08)}
.form-input.error{border-color:#ef4444!important;box-shadow:0 0 0 3px rgba(239,68,68,.08)!important}
.form-select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%236b7280' viewBox='0 0 16 16'%3E%3Cpath d='M4.646 5.646a.5.5 0 0 1 .708 0L8 8.293l2.646-2.647a.5.5 0 0 1 .708.708l-3 3a.5.5 0 0 1-.708 0l-3-3a.5.5 0 0 1 0-.708z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:44px}
.error-msg{color:#ef4444;font-size:.75rem;margin-top:6px}
.error-msg.show{display:block!important}
.submit-btn{width:100%;padding:16px;background:#0071e3;color:#fff;font-weight:600;font-size:.938rem;border:none;border-radius:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .3s ease;font-family:inherit}
.submit-btn:hover{background:#0077ED}.submit-btn:active{transform:scale(.98)}

/* ===================== HERO GRADIENT ANIMATED ===================== */
.page-hero{position:relative;overflow:hidden;background:linear-gradient(135deg,#f5f5f7,#ebebed,#e8e8ea,#f5f5f7);background-size:300% 300%;animation:heroGradMove 10s ease infinite}
@keyframes heroGradMove{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}

/* ===================== PRODUCT SLOGAN SHOWCASE ===================== */
.product-slogan{position:relative;border-radius:32px;overflow:hidden;min-height:320px}
.product-slogan .ps-bg{position:absolute;inset:0;z-index:0}
.product-slogan .ps-content{position:relative;z-index:2;padding:40px 36px}
.product-slogan .ps-img{position:relative;z-index:1;width:100%;max-height:360px;overflow:hidden;display:flex;align-items:flex-end;justify-content:center}
.product-slogan .ps-img img{width:100%;height:100%;object-fit:cover;border-radius:0 0 32px 32px}
@media(min-width:1024px){.product-slogan{display:flex;align-items:stretch;min-height:400px}.product-slogan .ps-content{flex:1;padding:56px 48px;display:flex;flex-direction:column;justify-content:center}.product-slogan .ps-img{flex:1;max-height:none;border-radius:0}.product-slogan .ps-img img{border-radius:0;height:100%;object-fit:cover;transform:scale(1.07);transition:transform .6s cubic-bezier(.25,.46,.45,.94)}.product-slogan:hover .ps-img img{transform:scale(1.13)}}

/* ===================== SLOGAN BANNER ===================== */
.slogan-section{position:relative;overflow:hidden}
.slogan-section .slogan-bg{position:absolute;inset:0;border-radius:32px}
.slogan-icon-wrap{width:120px;height:120px;border-radius:28px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
@media(min-width:1024px){.slogan-icon-wrap{width:160px;height:160px;border-radius:36px}}

/* ===================== REVIEW CARDS ===================== */
.review-card{background:#fff;border:1px solid #e8e8ed;border-radius:20px;padding:24px;min-width:280px;max-width:320px;flex-shrink:0}
.review-stars{display:flex;gap:2px}
.review-stars svg{width:16px;height:16px}
.review-source{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:100px;font-size:.688rem;font-weight:600}
.review-marquee-wrap{overflow:hidden;mask-image:linear-gradient(to right,transparent,black 8%,black 92%,transparent);-webkit-mask-image:linear-gradient(to right,transparent,black 8%,black 92%,transparent)}
.review-marquee-track{display:flex;gap:20px;width:max-content;animation:reviewScroll 40s linear infinite}
.review-marquee-track:hover{animation-play-state:paused}
@keyframes reviewScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ===================== FOOTER ===================== */
.footer-link{font-size:.875rem;color:#9ca3af;text-decoration:none;transition:color .2s}.footer-link:hover{color:#fff}

/* ===================== MODAL ===================== */
#successModal.active{opacity:1;pointer-events:auto}
#successModal.active #modalContent{transform:scale(1)}
.checkmark-svg path{stroke-dasharray:48;stroke-dashoffset:48}
#successModal.active .checkmark-svg path{animation:drawCheck .6s .3s ease forwards}
@keyframes drawCheck{to{stroke-dashoffset:0}}

/* ===================== REVEAL ===================== */
.reveal{opacity:0;transform:translateY(36px);transition:opacity .7s cubic-bezier(.25,.46,.45,.94),transform .7s cubic-bezier(.25,.46,.45,.94)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal:nth-child(2){transition-delay:.08s}.reveal:nth-child(3){transition-delay:.16s}.reveal:nth-child(4){transition-delay:.24s}

/* ===================== BACK TO TOP ===================== */
#backToTop.show{opacity:1;transform:translateY(0);pointer-events:auto}

/* ===================== SUBPAGE ===================== */
.page-hero{padding:160px 0 80px;text-align:center;background:#f5f5f7}
.page-hero .page-label{font-size:.813rem;font-weight:600;color:#0071e3;letter-spacing:.1em;text-transform:uppercase;margin-bottom:12px}
.page-hero h1{font-size:2.5rem;font-weight:700;letter-spacing:-.02em;line-height:1.2}
@media(min-width:1024px){.page-hero h1{font-size:3.25rem}}

.breadcrumb{display:flex;align-items:center;gap:6px;font-size:.75rem;color:#9ca3af;justify-content:center;margin-top:16px}
.breadcrumb a{color:#9ca3af;text-decoration:none;transition:color .2s}
.breadcrumb a:hover{color:#0071e3}
.breadcrumb svg{width:12px;height:12px}

/* Partner grid for subpage */
.partner-grid-item{background:#fff;border:1px solid #e8e8ed;border-radius:20px;padding:32px;display:flex;align-items:center;justify-content:center;min-height:100px;transition:all .4s ease}
.partner-grid-item:hover{border-color:rgba(0,113,227,.15);box-shadow:0 8px 32px rgba(0,0,0,.06);transform:translateY(-2px)}

/* Map container */
.map-container{border-radius:24px;overflow:hidden;border:1px solid #e8e8ed}
.map-container iframe{display:block}

/* Info list for direction page */
.info-row{display:flex;align-items:flex-start;gap:16px;padding:20px 0;border-bottom:1px solid #f0f0f0}
.info-row:last-child{border-bottom:none}
.info-icon{width:40px;height:40px;border-radius:12px;background:#f5f5f7;display:flex;align-items:center;justify-content:center;flex-shrink:0}

.feedback_red{color:red}