/* Saypower Main CSS */
:root {
  --primary:      #e8500a;
  --primary-dark: #c43d00;
  --dark:         #0f1923;
  --dark2:        #1a2535;
  --text:         #1a1a2e;
  --text-muted:   #6b7280;
  --bg:           #ffffff;
  --bg-alt:       #f7f8fa;
  --border:       #e5e7eb;
  --shadow:       0 4px 24px rgba(0,0,0,.07);
  --shadow-lg:    0 12px 48px rgba(0,0,0,.12);
  --radius:       10px;
  --radius-lg:    16px;
  --transition:   .3s cubic-bezier(.4,0,.2,1);
}

/* Reset */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Inter',sans-serif;color:var(--text);background:var(--bg);line-height:1.6;overflow-x:hidden}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}

/* Utilities */
.container{max-width:1200px;margin:0 auto;padding:0 24px}
.section{padding:96px 0}
.text-accent{color:var(--primary)}
.brand-say{color:var(--dark);font-weight:900}
.brand-power{color:var(--primary);font-weight:900}
.section-label{display:inline-block;font-size:.75rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--primary);margin-bottom:12px}
.section-header{text-align:center;max-width:640px;margin:0 auto 64px}
.section-header h2{font-size:clamp(1.8rem,3vw,2.5rem);font-weight:800;line-height:1.2;margin-bottom:14px}
.section-header p{color:var(--text-muted);font-size:1rem}
.section-cta{text-align:center;margin-top:48px}
.empty-state{text-align:center;color:var(--text-muted);padding:48px 0}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;border-radius:6px;font-weight:600;font-size:.9rem;transition:var(--transition);cursor:pointer;border:2px solid transparent}
.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}
.btn-primary:hover{background:var(--primary-dark);border-color:var(--primary-dark);transform:translateY(-2px);box-shadow:0 6px 20px rgba(232,80,10,.3)}
.btn-outline-dark{border-color:var(--dark);color:var(--dark)}
.btn-outline-dark:hover{background:var(--dark);color:#fff}
.btn-outline-white{border-color:rgba(255,255,255,.6);color:#fff}
.btn-outline-white:hover{background:rgba(255,255,255,.15)}
.btn-white{background:#fff;color:var(--primary);font-weight:700}
.btn-white:hover{background:#f0f0f0;transform:translateY(-2px)}
.btn-lg{padding:15px 36px;font-size:1rem;border-radius:8px}
.btn-full{width:100%;justify-content:center}

/* Alerts */
.alert{padding:14px 18px;border-radius:var(--radius);margin-bottom:20px;font-size:.9rem}
.alert-success{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}
.alert-error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}
.alert-error p{margin-bottom:4px}

/* ===== HEADER ===== */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;transition:var(--transition)}
.site-header.scrolled{background:rgba(255,255,255,.97);backdrop-filter:blur(12px);box-shadow:0 2px 20px rgba(0,0,0,.08)}
.header-inner{display:flex;align-items:center;gap:24px;height:76px}
.logo{display:flex;align-items:center;gap:12px}
.logo-mark{width:40px;height:40px;background:var(--primary);color:#fff;font-size:1.2rem;font-weight:900;display:flex;align-items:center;justify-content:center;border-radius:6px;flex-shrink:0}
.logo-text{display:flex;flex-direction:column;line-height:1.1}
.logo-say{font-size:1rem;font-weight:900;color:#fff;letter-spacing:.05em}
.logo-power{font-size:1rem;font-weight:900;color:var(--primary);letter-spacing:.05em}
.logo-text small{font-size:.6rem;color:rgba(255,255,255,.6);font-weight:400;letter-spacing:.05em}
.site-header.scrolled .logo-say{color:var(--dark)}
.site-header.scrolled .logo-text small{color:var(--text-muted)}
.main-nav{margin-left:auto}
.main-nav ul{display:flex;align-items:center;gap:4px}
.main-nav a{padding:8px 14px;border-radius:6px;font-size:.875rem;font-weight:500;transition:var(--transition)}
.site-header:not(.scrolled) .main-nav a{color:rgba(255,255,255,.85)}
.site-header.scrolled .main-nav a{color:var(--text)}
.main-nav a:hover,.main-nav a.active{background:rgba(232,80,10,.1);color:var(--primary)}
.site-header:not(.scrolled) .main-nav a:hover{background:rgba(255,255,255,.12);color:#fff}
.header-cta{margin-left:8px}
.site-header:not(.scrolled) .header-cta{background:var(--primary);color:#fff;border-color:var(--primary)}
.hamburger{display:none;flex-direction:column;gap:5px;padding:8px;margin-left:auto}
.hamburger span{display:block;width:24px;height:2px;background:currentColor;border-radius:2px;transition:var(--transition)}
.site-header:not(.scrolled) .hamburger{color:#fff}
.site-header.scrolled .hamburger{color:var(--dark)}

/* ===== HERO / SLIDER ===== */
.hero{position:relative;height:100vh;min-height:600px;overflow:hidden}
.hero-slider{position:relative;width:100%;height:100%}
.hero-slide{position:absolute;inset:0;background-image:var(--bg-img);background-size:cover;background-position:center;opacity:0;transition:opacity .8s ease}
.hero-slide.active{opacity:1}
.slide-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(15,25,35,.85) 0%,rgba(15,25,35,.5) 100%)}
.slide-content{position:relative;z-index:1;height:100%;display:flex;flex-direction:column;justify-content:center;padding-top:76px;max-width:700px}
.hero-tag{display:inline-block;background:var(--primary);color:#fff;font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:6px 16px;border-radius:4px;margin-bottom:20px;width:fit-content}
.slide-content h1{font-size:clamp(2.4rem,5vw,4rem);font-weight:900;color:#fff;line-height:1.1;margin-bottom:20px}
.slide-content h1 .accent{color:var(--primary)}
.slide-content p{font-size:1.05rem;color:rgba(255,255,255,.8);max-width:520px;margin-bottom:32px;line-height:1.7}
.hero-btns{display:flex;gap:16px;flex-wrap:wrap}
.slider-controls{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:20px;z-index:10}
.slider-btn{width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.3);color:#fff;font-size:1.1rem;display:flex;align-items:center;justify-content:center;transition:var(--transition);cursor:pointer}
.slider-btn:hover{background:var(--primary);border-color:var(--primary)}
.slider-dots{display:flex;gap:8px}
.dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.4);border:none;cursor:pointer;transition:var(--transition)}
.dot.active{background:var(--primary);width:28px;border-radius:5px}

/* ===== ABOUT STRIP ===== */
.about-strip{background:var(--bg-alt);padding:80px 0}
.about-strip-inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.about-strip-text h2{font-size:clamp(1.8rem,3vw,2.4rem);font-weight:900;margin-bottom:20px}
.about-strip-text p{color:var(--text-muted);line-height:1.8;margin-bottom:28px}
.about-strip-values{display:flex;flex-direction:column;gap:20px}
.value-card{background:#fff;border-radius:var(--radius);padding:24px;border:1px solid var(--border);border-left:4px solid var(--primary);transition:var(--transition)}
.value-card:hover{box-shadow:var(--shadow);transform:translateX(4px)}
.value-num{font-size:.75rem;font-weight:800;color:var(--primary);letter-spacing:.1em;margin-bottom:6px}
.value-card h3{font-size:1rem;font-weight:700;margin-bottom:6px}
.value-card p{font-size:.875rem;color:var(--text-muted);line-height:1.6}

/* ===== STATS ===== */
.stats-section{background:var(--dark);padding:60px 0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.stat-item{text-align:center;padding:32px 16px;border-right:1px solid rgba(255,255,255,.08)}
.stat-item:last-child{border-right:none}
.stat-num{font-size:2.8rem;font-weight:900;color:#fff;line-height:1}
.stat-plus{font-size:1.8rem;font-weight:900;color:var(--primary)}
.stat-item p{color:rgba(255,255,255,.6);font-size:.875rem;margin-top:8px}

/* ===== SERVICES HOME ===== */
.services-home{background:var(--bg)}
.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}
.service-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px 24px;transition:var(--transition);position:relative;overflow:hidden}
.service-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--primary);transform:scaleX(0);transform-origin:left;transition:var(--transition)}
.service-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:transparent}
.service-card:hover::after{transform:scaleX(1)}
.service-card-icon{font-size:2rem;margin-bottom:16px;width:52px;height:52px;background:rgba(232,80,10,.08);border-radius:10px;display:flex;align-items:center;justify-content:center}
.service-card h3{font-size:1rem;font-weight:700;margin-bottom:10px;color:var(--text)}
.service-card p{font-size:.875rem;color:var(--text-muted);line-height:1.6;flex:1;margin-bottom:16px}
.service-card-link{font-size:.8rem;font-weight:700;color:var(--primary);margin-top:auto}

/* ===== LAST PROJECT ===== */
.last-project{background:var(--dark2);padding:96px 0}
.last-project-inner{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.last-project-img img{border-radius:var(--radius-lg);width:100%;aspect-ratio:4/3;object-fit:cover}
.project-placeholder{aspect-ratio:4/3;background:rgba(255,255,255,.05);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:4rem}
.last-project-text .section-label{color:var(--primary)}
.last-project-text h2{font-size:clamp(1.6rem,2.5vw,2.2rem);font-weight:800;color:#fff;margin-bottom:12px}
.project-loc{color:rgba(255,255,255,.5);font-size:.875rem;margin-bottom:16px}
.last-project-text p{color:rgba(255,255,255,.7);line-height:1.8;margin-bottom:28px}

/* ===== CTA BANNER ===== */
.cta-banner{position:relative;padding:96px 0;overflow:hidden}
.cta-banner-bg{position:absolute;inset:0;background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 100%)}
.cta-banner-bg::after{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}
.cta-content{position:relative;z-index:1;text-align:center;color:#fff}
.cta-content h2{font-size:clamp(1.8rem,3vw,2.6rem);font-weight:800;margin-bottom:14px}
.cta-content p{font-size:1.05rem;color:rgba(255,255,255,.85);margin-bottom:36px}
.cta-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* ===== CONTACT ===== */
.contact-home{background:var(--bg-alt)}
.contact-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:64px;align-items:start}
.contact-info-col{display:flex;flex-direction:column;gap:24px}
.contact-info-item{display:flex;gap:16px;align-items:flex-start}
.ci-icon{font-size:1.4rem;width:48px;height:48px;background:#fff;border:1px solid var(--border);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.contact-info-item strong{display:block;font-weight:700;font-size:.875rem;margin-bottom:3px}
.contact-info-item span,.contact-info-item a{color:var(--text-muted);font-size:.875rem;line-height:1.5}
.contact-info-item a:hover{color:var(--primary)}
.contact-form-col{background:#fff;border-radius:var(--radius-lg);padding:40px;box-shadow:var(--shadow);border:1px solid var(--border)}
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.form-group label{font-size:.8rem;font-weight:700;color:var(--text);text-transform:uppercase;letter-spacing:.04em}
.form-group input,.form-group textarea,.form-group select{padding:12px 14px;border:1.5px solid var(--border);border-radius:6px;font-family:inherit;font-size:.9rem;color:var(--text);transition:var(--transition);background:var(--bg)}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(232,80,10,.1)}
.form-group textarea{resize:vertical;min-height:120px}

/* ===== PAGE HERO ===== */
.page-hero{background:linear-gradient(135deg,var(--dark) 0%,var(--dark2) 100%);padding:140px 0 72px;color:#fff;text-align:center}
.page-hero h1{font-size:clamp(2rem,4vw,3rem);font-weight:900;margin-bottom:10px}
.page-hero p{color:rgba(255,255,255,.65);font-size:1rem;margin-bottom:20px}
.breadcrumb{display:flex;align-items:center;justify-content:center;gap:8px;font-size:.8rem;color:rgba(255,255,255,.4)}
.breadcrumb a{color:var(--primary)}
.breadcrumb span{color:rgba(255,255,255,.25)}

/* ===== ABOUT PAGE ===== */
.about-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.about-detail-text h2{font-size:clamp(1.6rem,2.5vw,2.2rem);font-weight:800;margin-bottom:20px}
.about-detail-text p{color:var(--text-muted);line-height:1.8;margin-bottom:16px}
.about-stats-row{display:flex;gap:32px;margin:32px 0}
.about-stat strong{display:block;font-size:2rem;font-weight:900;color:var(--primary)}
.about-stat span{font-size:.8rem;color:var(--text-muted)}
.about-timeline h3{font-size:1.1rem;font-weight:700;margin-bottom:24px}
.timeline{display:flex;flex-direction:column;gap:0}
.timeline-item{display:flex;gap:16px;padding-bottom:24px;position:relative}
.timeline-item::before{content:'';position:absolute;left:7px;top:20px;bottom:0;width:2px;background:var(--border)}
.timeline-item:last-child::before{display:none}
.timeline-dot{width:16px;height:16px;border-radius:50%;background:var(--border);border:3px solid #fff;box-shadow:0 0 0 2px var(--border);flex-shrink:0;margin-top:3px}
.timeline-dot.active{background:var(--primary);box-shadow:0 0 0 2px var(--primary)}
.timeline-content strong{display:block;font-size:.9rem;font-weight:700;margin-bottom:3px}
.timeline-content p{font-size:.85rem;color:var(--text-muted)}
.mv-section{background:var(--bg-alt)}
.mv-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}
.mv-card{background:#fff;border-radius:var(--radius-lg);padding:36px 28px;border:1px solid var(--border);transition:var(--transition)}
.mv-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.mv-icon{font-size:2.5rem;margin-bottom:16px}
.mv-card h3{font-size:1.05rem;font-weight:700;margin-bottom:10px}
.mv-card p{color:var(--text-muted);font-size:.875rem;line-height:1.7}

/* ===== SERVICES PAGE ===== */
.services-grid-full{display:flex;flex-direction:column;gap:16px}
.service-card-full{display:flex;align-items:center;gap:24px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:24px 28px;transition:var(--transition)}
.service-card-full:hover{border-color:var(--primary);box-shadow:var(--shadow);transform:translateX(4px)}
.scf-icon{font-size:2rem;width:56px;height:56px;background:rgba(232,80,10,.07);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.scf-body{flex:1}
.scf-body h3{font-size:1rem;font-weight:700;margin-bottom:6px;color:var(--text)}
.scf-body p{font-size:.875rem;color:var(--text-muted);line-height:1.6}
.scf-arrow{font-size:1.2rem;color:var(--primary);font-weight:700;flex-shrink:0;transition:var(--transition)}
.service-card-full:hover .scf-arrow{transform:translateX(4px)}

/* ===== SERVICE DETAIL ===== */
.service-detail-wrap{display:grid;grid-template-columns:1fr 320px;gap:48px;align-items:start}
.service-detail-icon{font-size:3rem;width:72px;height:72px;background:rgba(232,80,10,.08);border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:20px}
.service-detail-content h2{font-size:clamp(1.6rem,2.5vw,2rem);font-weight:800;margin-bottom:20px}
.service-detail-desc{color:var(--text-muted);line-height:1.9;font-size:.95rem;margin-bottom:32px}
.service-detail-sidebar{display:flex;flex-direction:column;gap:20px}
.sidebar-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px}
.sidebar-card h4{font-size:.9rem;font-weight:700;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border)}
.sidebar-service-list{display:flex;flex-direction:column;gap:8px}
.sidebar-service-list a{font-size:.875rem;color:var(--text-muted);padding:8px 10px;border-radius:6px;transition:var(--transition);display:flex;align-items:center;gap:8px}
.sidebar-service-list a:hover{background:rgba(232,80,10,.06);color:var(--primary)}
.sidebar-contact p{font-size:.875rem;color:var(--text-muted);margin-bottom:16px}

/* ===== PROJECTS PAGE ===== */
.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:24px}
.project-card{background:#fff;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);transition:var(--transition)}
.project-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.project-img{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--dark)}
.project-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.project-card:hover .project-img img{transform:scale(1.05)}
.project-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:3rem}
.project-location-badge{position:absolute;bottom:12px;left:12px;background:rgba(0,0,0,.65);color:#fff;font-size:.75rem;padding:5px 12px;border-radius:100px;backdrop-filter:blur(4px)}
.project-body{padding:20px 24px}
.project-body h3{font-size:1rem;font-weight:700;margin-bottom:8px}
.project-body p{color:var(--text-muted);font-size:.875rem;line-height:1.6}

/* ===== FOOTER ===== */
.site-footer{background:var(--dark);color:rgba(255,255,255,.65)}
.footer-main{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:48px;padding:72px 0 48px}
.footer-logo .logo-say{color:#fff}
.footer-logo .logo-text small{color:rgba(255,255,255,.4)}
.footer-brand p{font-size:.875rem;line-height:1.7;margin-top:16px;max-width:280px}
.footer-badges{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}
.badge-item{font-size:.75rem;background:rgba(255,255,255,.07);padding:5px 12px;border-radius:100px}
.footer-col h4{color:#fff;font-size:.875rem;font-weight:700;margin-bottom:18px}
.footer-col ul{display:flex;flex-direction:column;gap:10px}
.footer-col a{font-size:.875rem;transition:var(--transition)}
.footer-col a:hover{color:var(--primary)}
.footer-contact-list{display:flex;flex-direction:column;gap:14px}
.footer-contact-list li{display:flex;gap:10px;align-items:flex-start;font-size:.875rem}
.fc-icon{flex-shrink:0;margin-top:1px}
.footer-contact-list a:hover{color:var(--primary)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.07);padding:20px 0}
.footer-bottom-inner{display:flex;justify-content:space-between;align-items:center;font-size:.8rem}

/* ===== 404 ===== */
.error-page{min-height:80vh;display:flex;align-items:center;justify-content:center;text-align:center}
.error-num{font-size:8rem;font-weight:900;color:var(--primary);line-height:1}
.error-content h2{font-size:1.5rem;margin:8px 0}
.error-content p{color:var(--text-muted);margin-bottom:28px}

/* ===== ANIMATIONS ===== */
[data-animate]{opacity:0;transform:translateY(28px);transition:opacity .6s ease,transform .6s ease}
[data-animate="fade-left"]{transform:translateX(36px)}
[data-animate="fade-right"]{transform:translateX(-36px)}
[data-animate="fade-down"]{transform:translateY(-20px)}
[data-animate].animated{opacity:1;transform:none}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .about-strip-inner,.about-detail-grid,.last-project-inner,.service-detail-wrap{grid-template-columns:1fr;gap:48px}
  .footer-main{grid-template-columns:1fr 1fr;gap:32px}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .stat-item{border-right:none;border-bottom:1px solid rgba(255,255,255,.08)}
}
@media(max-width:768px){
  .section{padding:64px 0}
  .main-nav,.header-cta{display:none}
  .main-nav.open{display:flex;flex-direction:column;position:fixed;top:76px;left:0;right:0;background:rgba(255,255,255,.98);backdrop-filter:blur(12px);padding:20px;box-shadow:0 8px 32px rgba(0,0,0,.1)}
  .main-nav.open ul{flex-direction:column;gap:4px}
  .main-nav.open a{color:var(--text);padding:12px 16px;border-radius:8px}
  .hamburger{display:flex}
  .contact-grid{grid-template-columns:1fr;gap:40px}
  .form-row-2{grid-template-columns:1fr}
  .footer-main{grid-template-columns:1fr;gap:28px}
  .footer-bottom-inner{flex-direction:column;gap:6px;text-align:center}
  .hero-btns{flex-direction:column;align-items:flex-start}
  .cta-actions{flex-direction:column;align-items:center}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:480px){
  .stats-grid{grid-template-columns:1fr 1fr}
  .projects-grid{grid-template-columns:1fr}
}

/* Hero slide - görsel yoksa koyu gradient göster */
.hero-slide { background-color: var(--dark); }
.hero-slide[style*="slide1"] { background-image: var(--bg-img), linear-gradient(135deg,#0f1923,#1a2535); }
.hero-slide[style*="slide2"] { background-image: var(--bg-img), linear-gradient(135deg,#1a2535,#0f1923); }
.hero-slide[style*="slide3"] { background-image: var(--bg-img), linear-gradient(135deg,#0f1923,#2a1a0f); }

/* ===== TIMELINE HORIZONTAL (About) ===== */
.timeline-horizontal {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 0;
  position: relative;
  margin-top: 16px;
}
.timeline-horizontal::before {
  content: '';
  position: absolute;
  top: 28px;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--border);
  z-index: 0;
}
.th-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 0 12px;
  position: relative;
  z-index: 1;
}
.th-year {
  font-size: .8rem;
  font-weight: 800;
  color: var(--primary);
  margin-bottom: 10px;
  background: var(--bg-alt);
  padding: 2px 8px;
  border-radius: 4px;
}
.th-dot {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--primary);
  border: 3px solid var(--bg-alt);
  box-shadow: 0 0 0 2px var(--primary);
  margin-bottom: 12px;
  flex-shrink: 0;
}
.th-text {
  font-size: .8rem;
  color: var(--text-muted);
  line-height: 1.5;
}

@media (max-width: 768px) {
  .timeline-horizontal {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  .timeline-horizontal::before { display: none; }
  .th-item { flex-direction: row; text-align: left; gap: 12px; align-items: flex-start; }
  .th-year { min-width: 60px; }
}

/* ===== DROPDOWN NAV ===== */
.has-dropdown { position: relative; }
.dropdown-toggle { display: flex; align-items: center; gap: 4px; }
.dropdown-arrow { font-size: .65rem; transition: transform var(--transition); }
.has-dropdown:hover .dropdown-arrow { transform: rotate(180deg); }

.dropdown-menu {
  position: absolute;
  top: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%);
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: 0 16px 48px rgba(0,0,0,.14);
  border: 1px solid var(--border);
  min-width: 280px;
  padding: 8px;
  opacity: 0;
  visibility: hidden;
  transform: translateX(-50%) translateY(8px);
  transition: opacity .2s ease, transform .2s ease, visibility .2s;
  z-index: 500;
}
.has-dropdown:hover .dropdown-menu,
.has-dropdown:focus-within .dropdown-menu {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
}
.dropdown-menu li a {
  display: flex !important;
  align-items: center;
  gap: 12px;
  padding: 10px 12px !important;
  border-radius: 8px;
  color: var(--text) !important;
  background: transparent !important;
  transition: var(--transition);
}
.dropdown-menu li a:hover {
  background: rgba(232,80,10,.06) !important;
  color: var(--primary) !important;
}
.dm-icon { font-size: 1.2rem; width: 32px; height: 32px; background: var(--bg-alt); border-radius: 8px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.dropdown-menu li a strong { display: block; font-size: .875rem; font-weight: 600; line-height: 1.2; }
.dropdown-menu li a small { display: block; font-size: .75rem; color: var(--text-muted); margin-top: 1px; }
.dropdown-divider { height: 1px; background: var(--border); margin: 6px 8px; }

/* Mobile dropdown */
@media (max-width: 768px) {
  .dropdown-menu {
    position: static;
    transform: none;
    box-shadow: none;
    border: none;
    border-left: 3px solid var(--primary);
    border-radius: 0;
    padding: 4px 0 4px 12px;
    margin: 4px 0 4px 16px;
    background: transparent;
    opacity: 1;
    visibility: visible;
    display: none;
  }
  .has-dropdown.open .dropdown-menu { display: block; }
  .dropdown-menu li a { padding: 8px 10px !important; }
  .dropdown-menu li a strong { color: var(--text); }
  .dropdown-divider { display: none; }
  .dm-icon { display: none; }
}

/* ===== LEGAL PAGES ===== */
.legal-page { padding: 60px 0 96px; }
.legal-content { max-width: 860px; margin: 0 auto; }
.legal-content h2 { font-size: 1.4rem; font-weight: 800; margin: 40px 0 14px; color: var(--text); }
.legal-content h3 { font-size: 1.1rem; font-weight: 700; margin: 28px 0 10px; color: var(--text); }
.legal-content p { color: var(--text-muted); line-height: 1.9; margin-bottom: 16px; font-size: .95rem; }
.legal-content ul { margin: 12px 0 20px 20px; display: flex; flex-direction: column; gap: 8px; }
.legal-content ul li { color: var(--text-muted); font-size: .95rem; line-height: 1.7; list-style: disc; }
.legal-content strong { color: var(--text); font-weight: 600; }
.legal-meta { background: var(--bg-alt); border-radius: var(--radius); padding: 16px 20px; margin-bottom: 32px; font-size: .85rem; color: var(--text-muted); border-left: 4px solid var(--primary); }
.legal-toc { background: var(--bg-alt); border-radius: var(--radius-lg); padding: 24px 28px; margin-bottom: 40px; }
.legal-toc h4 { font-size: .9rem; font-weight: 700; margin-bottom: 12px; }
.legal-toc ol { padding-left: 20px; display: flex; flex-direction: column; gap: 6px; }
.legal-toc ol li a { font-size: .875rem; color: var(--primary); }
.legal-toc ol li a:hover { text-decoration: underline; }

/* ===== ABOUT PAGE - AREAS ===== */
.about-areas-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 20px; }
.about-area-card { background: #fff; border-radius: var(--radius-lg); padding: 28px 24px; border: 1px solid var(--border); transition: var(--transition); }
.about-area-card:hover { transform: translateY(-4px); box-shadow: var(--shadow); border-color: var(--primary); }
.aac-icon { font-size: 2rem; margin-bottom: 14px; width: 52px; height: 52px; background: rgba(232,80,10,.07); border-radius: 10px; display: flex; align-items: center; justify-content: center; }
.about-area-card h3 { font-size: 1rem; font-weight: 700; margin-bottom: 10px; }
.about-area-card p { font-size: .875rem; color: var(--text-muted); line-height: 1.7; }

/* WHY GRID */
.why-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 20px; }
.why-card { background: #fff; border-radius: var(--radius-lg); padding: 28px 24px; border: 1px solid var(--border); transition: var(--transition); text-align: center; }
.why-card:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.why-icon { font-size: 2.2rem; margin-bottom: 14px; }
.why-card h3 { font-size: 1rem; font-weight: 700; margin-bottom: 8px; }
.why-card p { font-size: .875rem; color: var(--text-muted); line-height: 1.7; }

/* ===== VISION MISSION PAGE ===== */
.vm-hero-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; margin-bottom: 0; }
.vm-card { border-radius: var(--radius-lg); padding: 40px 36px; }
.vm-card--vision { background: linear-gradient(135deg, var(--dark) 0%, var(--dark2) 100%); color: #fff; }
.vm-card--mission { background: linear-gradient(135deg, var(--primary-dark) 0%, var(--primary) 100%); color: #fff; }
.vm-card-icon { font-size: 2.5rem; margin-bottom: 16px; }
.vm-card h2 { font-size: 1.5rem; font-weight: 800; margin-bottom: 16px; }
.vm-lead { font-size: 1.05rem; font-weight: 600; margin-bottom: 16px; opacity: .95; line-height: 1.5; }
.vm-card p { font-size: .9rem; opacity: .85; line-height: 1.8; margin-bottom: 12px; }

.values-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 20px; }
.value-detail-card { background: #fff; border-radius: var(--radius-lg); padding: 28px 24px; border: 1px solid var(--border); transition: var(--transition); }
.value-detail-card:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.vdc-header { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.vdc-icon { font-size: 1.8rem; width: 48px; height: 48px; background: rgba(232,80,10,.07); border-radius: 10px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.vdc-header h3 { font-size: 1rem; font-weight: 700; }
.value-detail-card p { font-size: .875rem; color: var(--text-muted); line-height: 1.7; }

.goals-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 20px; }
.goal-card { background: #fff; border-radius: var(--radius-lg); padding: 28px 24px; border: 1px solid var(--border); transition: var(--transition); }
.goal-card:hover { border-color: var(--primary); box-shadow: var(--shadow); }
.goal-num { font-size: 2.5rem; font-weight: 900; color: var(--primary); opacity: .3; line-height: 1; margin-bottom: 10px; }
.goal-card h3 { font-size: 1rem; font-weight: 700; margin-bottom: 8px; }
.goal-card p { font-size: .875rem; color: var(--text-muted); line-height: 1.7; }

@media (max-width: 768px) {
  .vm-hero-grid { grid-template-columns: 1fr; }
  .vm-card { padding: 28px 24px; }
}

/* Footer legal links */
.footer-legal-links { display: flex; gap: 20px; }
.footer-legal-links a { font-size: .8rem; color: rgba(255,255,255,.4); transition: var(--transition); }
.footer-legal-links a:hover { color: var(--primary); }
@media (max-width: 768px) {
  .footer-legal-links { flex-wrap: wrap; gap: 12px; justify-content: center; }
}

/* ===== SERVICES LIST - CARD GRID ===== */
.srv-card-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 28px; }
.srv-card { background: #fff; border-radius: var(--radius-lg); overflow: hidden; border: 1px solid var(--border); transition: var(--transition); display: flex; flex-direction: column; }
.srv-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); border-color: transparent; }
.srv-card-img-wrap { position: relative; aspect-ratio: 16/9; overflow: hidden; display: block; background: var(--dark); }
.srv-card-img-wrap img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.srv-card:hover .srv-card-img-wrap img { transform: scale(1.06); }
.srv-card-icon-badge { position: absolute; top: 12px; left: 12px; width: 44px; height: 44px; background: rgba(255,255,255,.95); border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 1.4rem; box-shadow: 0 2px 8px rgba(0,0,0,.15); }
.srv-card-body { padding: 22px 24px; flex: 1; display: flex; flex-direction: column; }
.srv-card-body h3 { font-size: 1rem; font-weight: 700; margin-bottom: 10px; }
.srv-card-body h3 a { color: var(--text); transition: var(--transition); }
.srv-card-body h3 a:hover { color: var(--primary); }
.srv-card-body p { font-size: .875rem; color: var(--text-muted); line-height: 1.6; flex: 1; margin-bottom: 16px; }
.srv-card-cta { display: inline-flex; align-items: center; gap: 6px; font-size: .8rem; font-weight: 700; color: var(--primary); transition: var(--transition); }
.srv-card-cta span { transition: transform var(--transition); }
.srv-card-cta:hover span { transform: translateX(4px); }

/* Process Steps */
.process-steps { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 20px; }
.process-step { display: flex; gap: 16px; align-items: flex-start; background: #fff; border-radius: var(--radius); padding: 24px; border: 1px solid var(--border); transition: var(--transition); }
.process-step:hover { border-color: var(--primary); box-shadow: var(--shadow); }
.ps-num { font-size: 1.8rem; font-weight: 900; color: var(--primary); opacity: .25; line-height: 1; flex-shrink: 0; min-width: 48px; }
.ps-body h3 { font-size: .95rem; font-weight: 700; margin-bottom: 6px; }
.ps-body p { font-size: .85rem; color: var(--text-muted); line-height: 1.6; }

/* ===== SERVICE / PROJECT DETAIL ===== */
.service-detail-hero { position: relative; height: 420px; background-size: cover; background-position: center; display: flex; align-items: flex-end; }
.sdh-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,.8) 0%, rgba(0,0,0,.3) 60%, transparent 100%); }
.sdh-content { position: relative; z-index: 1; padding-bottom: 48px; color: #fff; }
.sdh-content h1 { font-size: clamp(1.8rem, 3.5vw, 2.8rem); font-weight: 900; margin-top: 12px; }
.breadcrumb--light a { color: rgba(255,255,255,.7); }
.breadcrumb--light span { color: rgba(255,255,255,.4); }

.service-detail-layout { display: grid; grid-template-columns: 1fr 320px; gap: 48px; align-items: start; }
.sd-main { min-width: 0; }
.sd-intro { font-size: 1.05rem; color: var(--text-muted); line-height: 1.9; margin-bottom: 32px; padding-bottom: 32px; border-bottom: 1px solid var(--border); }
.sd-img-wrap { margin-bottom: 32px; border-radius: var(--radius-lg); overflow: hidden; }
.sd-img-wrap img { width: 100%; aspect-ratio: 16/8; object-fit: cover; }
.sd-section { margin-bottom: 32px; padding-bottom: 32px; border-bottom: 1px solid var(--border); }
.sd-section:last-of-type { border-bottom: none; }
.sd-section h2 { font-size: 1.25rem; font-weight: 800; margin-bottom: 14px; color: var(--text); }
.sd-section p { color: var(--text-muted); line-height: 1.9; font-size: .95rem; }

/* FAQ */
.sd-faq { margin-bottom: 32px; }
.sd-faq h2 { font-size: 1.25rem; font-weight: 800; margin-bottom: 16px; }
.faq-item { border: 1px solid var(--border); border-radius: var(--radius); margin-bottom: 8px; overflow: hidden; }
.faq-q { width: 100%; display: flex; justify-content: space-between; align-items: center; padding: 16px 20px; font-size: .9rem; font-weight: 600; text-align: left; cursor: pointer; background: #fff; transition: var(--transition); gap: 12px; }
.faq-q:hover { background: var(--bg-alt); }
.faq-q[aria-expanded="true"] { background: var(--bg-alt); color: var(--primary); }
.faq-icon { font-size: 1.2rem; font-weight: 400; flex-shrink: 0; transition: transform var(--transition); }
.faq-q[aria-expanded="true"] .faq-icon { transform: rotate(45deg); }
.faq-a { padding: 0 20px 16px; }
.faq-a p { font-size: .875rem; color: var(--text-muted); line-height: 1.7; }

/* CTA Box */
.sd-cta-box { background: linear-gradient(135deg, var(--dark) 0%, var(--dark2) 100%); border-radius: var(--radius-lg); padding: 36px; color: #fff; margin-top: 32px; }
.sd-cta-box h3 { font-size: 1.2rem; font-weight: 800; margin-bottom: 10px; }
.sd-cta-box p { color: rgba(255,255,255,.75); font-size: .9rem; margin-bottom: 24px; }

/* Sidebar */
.sd-sidebar { display: flex; flex-direction: column; gap: 20px; position: sticky; top: 90px; }
.sd-sidebar-card { background: #fff; border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 24px; }
.sd-sidebar-card h4 { font-size: .875rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; margin-bottom: 16px; padding-bottom: 12px; border-bottom: 1px solid var(--border); color: var(--text-muted); }
.sd-features-list { display: flex; flex-direction: column; gap: 10px; }
.sd-features-list li { display: flex; align-items: center; gap: 10px; font-size: .875rem; }
.sdf-check { width: 20px; height: 20px; background: rgba(232,80,10,.1); color: var(--primary); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: .7rem; font-weight: 700; flex-shrink: 0; }
.sd-other-list { display: flex; flex-direction: column; gap: 6px; }
.sd-other-list a { display: flex; align-items: center; gap: 10px; font-size: .875rem; padding: 8px 10px; border-radius: 6px; transition: var(--transition); color: var(--text); }
.sd-other-list a:hover { background: rgba(232,80,10,.06); color: var(--primary); }
.sd-contact-card { background: var(--bg-alt); }

/* Project Meta Bar */
.project-meta-bar { display: flex; flex-wrap: wrap; gap: 0; background: var(--bg-alt); border-radius: var(--radius-lg); overflow: hidden; margin-bottom: 32px; border: 1px solid var(--border); }
.pmb-item { flex: 1; min-width: 120px; padding: 16px 20px; border-right: 1px solid var(--border); }
.pmb-item:last-child { border-right: none; }
.pmb-item span { display: block; font-size: .72rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: .06em; margin-bottom: 4px; }
.pmb-item strong { font-size: .9rem; font-weight: 700; }

/* Project Gallery */
.project-gallery { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 12px; }
.pg-item { border-radius: var(--radius); overflow: hidden; aspect-ratio: 4/3; }
.pg-item img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.pg-item:hover img { transform: scale(1.05); }

/* Project info list */
.project-info-list { display: flex; flex-direction: column; gap: 10px; }
.project-info-list li { display: flex; justify-content: space-between; align-items: center; font-size: .85rem; padding-bottom: 10px; border-bottom: 1px solid var(--border); }
.project-info-list li:last-child { border-bottom: none; padding-bottom: 0; }
.project-info-list li span { color: var(--text-muted); }
.project-info-list li strong { font-weight: 600; text-align: right; max-width: 60%; }

/* Other project link */
.other-project-link { display: flex !important; align-items: center; gap: 10px; }
.other-project-link img { width: 52px; height: 40px; object-fit: cover; border-radius: 6px; flex-shrink: 0; }

/* Project card link */
.project-body h3 a { color: var(--text); transition: var(--transition); }
.project-body h3 a:hover { color: var(--primary); }

@media (max-width: 1024px) {
  .service-detail-layout { grid-template-columns: 1fr; }
  .sd-sidebar { position: static; }
}
@media (max-width: 768px) {
  .service-detail-hero { height: 320px; }
  .srv-card-grid { grid-template-columns: 1fr; }
  .project-meta-bar { flex-direction: column; }
  .pmb-item { border-right: none; border-bottom: 1px solid var(--border); }
  .pmb-item:last-child { border-bottom: none; }
}
