/*
Theme Name: JECC Corporate
Description: JECC Corporate Website — Premium Edition
Version: 2.0
*/
:root {
  --bg: #FFFFFF; --bg2: #F5F5F7;
  --text: #1D1D1F; --text2: #6E6E73; --text3: #AEAEB2;
  --blue: #0071E3; --teal: #00B8B0; --accent: #0066CC;
  --surface: #FFFFFF;
  --border: rgba(0,0,0,0.06);
  --glass: rgba(255,255,255,0.72);
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.04);
  --shadow-md: 0 4px 20px rgba(0,0,0,0.06);
  --shadow-lg: 0 8px 40px rgba(0,0,0,0.08);
  --shadow-xl: 0 20px 60px rgba(0,0,0,0.12);
  --radius: 18px; --radius-sm: 12px; --radius-lg: 24px; --radius-xl: 32px;
  --max-w: 1200px;
  --font: -apple-system, BlinkMacSystemFont, 'SF Pro Display', 'PingFang SC', 'Noto Sans SC', 'Helvetica Neue', sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;overflow-x:hidden}
body{font-family:var(--font);color:var(--text2);background:var(--bg);line-height:1.6;font-size:17px;letter-spacing:-0.01em;overflow-x:hidden}
.container{max-width:var(--max-w);margin:0 auto;padding:0 32px}
a{color:var(--blue);text-decoration:none}

/* ====== SCROLL REVEAL ====== */
.reveal{opacity:0;transform:translateY(40px);transition:opacity 0.8s cubic-bezier(0.16,1,0.3,1),transform 0.8s cubic-bezier(0.16,1,0.3,1)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:0.1s}
.reveal-delay-2{transition-delay:0.2s}
.reveal-delay-3{transition-delay:0.3s}
.reveal-delay-4{transition-delay:0.4s}
.reveal-left{transform:translateX(-40px)}
.reveal-left.visible{transform:translateX(0)}
.reveal-right{transform:translateX(40px)}
.reveal-right.visible{transform:translateX(0)}

/* ====== NAV ====== */
.navbar{position:fixed;top:0;left:0;right:0;z-index:100;transition:transform 0.4s cubic-bezier(0.16,1,0.3,1)}
.navbar-inner{margin:16px auto 0;max-width:var(--max-w);background:var(--glass);backdrop-filter:blur(40px) saturate(180%);-webkit-backdrop-filter:blur(40px) saturate(180%);border-radius:var(--radius-lg);border:1px solid var(--border);padding:0 28px;transition:all 0.3s ease;box-shadow:0 4px 24px rgba(0,0,0,0.04)}
.navbar-inner:hover{box-shadow:0 8px 32px rgba(0,0,0,0.08)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:52px}
.nav-logo{font-size:18px;font-weight:700;color:var(--text);letter-spacing:-0.3px;text-decoration:none;display:flex;align-items:center;gap:6px;transition:opacity 0.2s}
.nav-logo:hover{opacity:0.8}
.nav-logo span{color:var(--teal)}
.nav-links{display:flex;gap:4px;list-style:none;align-items:center}
.nav-links a{text-decoration:none;color:var(--text2);font-size:13px;font-weight:500;padding:6px 14px;border-radius:8px;transition:all .2s;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:2px;left:50%;transform:translateX(-50%) scaleX(0);width:60%;height:1.5px;background:var(--blue);border-radius:1px;transition:transform 0.3s cubic-bezier(0.16,1,0.3,1)}
.nav-links a:hover::after,.nav-links a.active::after{transform:translateX(-50%) scaleX(1)}
.nav-links a:hover,.nav-links a.active{color:var(--text);background:rgba(0,0,0,0.03)}
.nav-lang{display:flex;gap:2px;background:rgba(0,0,0,0.03);border-radius:10px;padding:2px;margin-left:8px}
.nav-lang a{padding:4px 10px;border-radius:8px;font-size:11px;color:var(--text2);font-weight:600;text-decoration:none;transition:all .2s cubic-bezier(0.16,1,0.3,1);cursor:pointer}
.nav-lang a.active,.nav-lang a:hover{background:#fff;color:var(--text);box-shadow:var(--shadow-sm);transform:scale(1.05)}
.nav-cta{font-size:12px;font-weight:600;padding:8px 18px;border-radius:20px;background:linear-gradient(135deg,var(--blue),var(--accent));color:#fff!important;text-decoration:none;transition:all .3s cubic-bezier(0.16,1,0.3,1);margin-left:8px;box-shadow:0 2px 8px rgba(0,113,227,0.2);position:relative;overflow:hidden}
.nav-cta::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.2),transparent);transition:left 0.5s}
.nav-cta:hover::before{left:100%}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(0,113,227,0.35)}
/* SECTION */
.section{padding:120px 0;position:relative}
.section-dark{background:var(--bg2)}
.section-label{font-size:12px;font-weight:600;color:var(--teal);letter-spacing:2px;margin-bottom:16px;text-transform:uppercase}
.section-title{font-size:clamp(36px,5vw,52px);font-weight:800;color:var(--text);margin-bottom:20px;letter-spacing:-1.5px;line-height:1.12;position:relative}
.section-title::after{content:'';display:block;width:48px;height:3px;background:linear-gradient(90deg,var(--teal),var(--blue));border-radius:2px;margin-top:16px}
.section-desc{font-size:18px;color:var(--text2);max-width:560px;margin-bottom:56px;line-height:1.75}
/* PAGE HERO */
.page-hero{padding:160px 0 100px;background:linear-gradient(180deg,#F5F7FA,#FFFFFF);position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;top:-50%;right:-20%;width:600px;height:600px;background:radial-gradient(circle,rgba(0,184,176,0.06),transparent 70%);border-radius:50%;animation:floatSlow 20s ease-in-out infinite}
@keyframes floatSlow{0%,100%{transform:translate(0,0)}50%{transform:translate(-30px,-20px)}}
.page-hero h1{font-size:clamp(36px,5vw,56px);font-weight:800;color:var(--text);letter-spacing:-1.5px;margin-bottom:12px;position:relative;z-index:1}
.page-hero p{font-size:18px;color:var(--text2);max-width:520px;line-height:1.7;position:relative;z-index:1}
/* BUTTONS */
.btn{font-size:15px;font-weight:600;padding:14px 32px;border-radius:28px;border:none;cursor:pointer;transition:all .35s cubic-bezier(0.16,1,0.3,1);text-decoration:none;display:inline-flex;align-items:center;gap:8px;letter-spacing:-0.2px}
.btn-primary{background:linear-gradient(135deg,var(--blue),var(--accent));color:#fff;box-shadow:0 4px 16px rgba(0,113,227,0.2)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(0,113,227,0.35)}
.btn-outline{background:transparent;color:var(--blue);border:1.5px solid var(--blue);backdrop-filter:blur(10px)}
.btn-outline:hover{background:rgba(0,113,227,0.06);transform:translateY(-2px)}

/* ====== HERO (HOME) ====== */
.hero{position:relative;padding:180px 0 140px;overflow:hidden;min-height:100vh;display:flex;align-items:center}
.hero-bg{position:absolute;inset:0}
.hero-bg::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,#F5F7FA 0%,#FFFFFF 60%)}
.hero-bg::after{content:'';position:absolute;inset:0;background-image:radial-gradient(circle at 85% 15%,rgba(0,184,176,0.08) 0%,transparent 50%),radial-gradient(circle at 15% 80%,rgba(0,113,227,0.06) 0%,transparent 50%),radial-gradient(circle at 50% 50%,rgba(0,113,227,0.02) 0%,transparent 70%)}
.hero .container{position:relative;z-index:1}
.hero-eyebrow{font-size:13px;font-weight:600;color:var(--teal);letter-spacing:1.5px;margin-bottom:20px;animation:fadeInUp 0.8s cubic-bezier(0.16,1,0.3,1) both}
.hero h1{font-size:clamp(48px,8vw,88px);font-weight:800;color:var(--text);line-height:1.04;margin-bottom:28px;letter-spacing:-3px;animation:fadeInUp 0.8s 0.15s cubic-bezier(0.16,1,0.3,1) both}
.hero h1 .accent{color:transparent;background:linear-gradient(135deg,var(--teal),var(--blue) 60%);-webkit-background-clip:text;background-clip:text;background-size:200% auto;animation:shimmer 3s ease-in-out infinite}
.hero h1 .light{font-weight:400;color:var(--text2)}
@keyframes shimmer{0%,100%{background-position:0% center}50%{background-position:200% center}}
.hero-sub{font-size:19px;color:var(--text2);max-width:500px;margin-bottom:44px;line-height:1.8;animation:fadeInUp 0.8s 0.3s cubic-bezier(0.16,1,0.3,1) both}
.hero-actions{display:flex;gap:16px;align-items:center;animation:fadeInUp 0.8s 0.45s cubic-bezier(0.16,1,0.3,1) both}
.hero-stats{margin-top:80px;display:flex;gap:16px;animation:fadeInUp 0.8s 0.6s cubic-bezier(0.16,1,0.3,1) both}
.hero-stat{text-align:center;padding:24px 36px;background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);transition:all 0.4s cubic-bezier(0.16,1,0.3,1);cursor:default}
.hero-stat:hover{box-shadow:var(--shadow-xl);transform:translateY(-4px);border-color:rgba(0,184,176,0.2)}
.hero-stat strong{display:block;font-size:38px;font-weight:800;color:var(--text);letter-spacing:-1.5px;line-height:1}
.hero-stat small{display:block;font-size:12px;color:var(--text2);margin-top:8px;letter-spacing:0.5px}
@keyframes fadeInUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
/* Hero Visual */
.hero-visual{position:absolute;right:-5%;top:50%;transform:translateY(-50%);width:600px;height:600px;pointer-events:none;z-index:0;opacity:0.6}
.hero-visual .ring{position:absolute;inset:0;border-radius:50%;border:2px solid rgba(0,184,176,0.08);animation:rotate 60s linear infinite}
.hero-visual .ring:nth-child(2){inset:30px;border-color:rgba(0,113,227,0.06);animation-direction:reverse;animation-duration:45s}
.hero-visual .ring:nth-child(3){inset:70px;border-color:rgba(0,184,176,0.04);animation-duration:35s}
.hero-visual .dot{position:absolute;width:4px;height:4px;background:var(--teal);border-radius:50%;opacity:0.3;animation:dotFloat 8s ease-in-out infinite}
.hero-visual .dot:nth-child(4){top:15%;left:20%;animation-delay:0s}
.hero-visual .dot:nth-child(5){top:30%;right:15%;animation-delay:2s;background:var(--blue)}
.hero-visual .dot:nth-child(6){bottom:25%;left:25%;animation-delay:4s}
.hero-visual .dot:nth-child(7){bottom:15%;right:20%;animation-delay:6s;background:var(--blue)}
@keyframes rotate{to{transform:rotate(360deg)}}
@keyframes dotFloat{0%,100%{transform:translate(0,0);opacity:0.2}50%{transform:translate(10px,-15px);opacity:0.6}}

/* ====== SOLUTIONS GRID ====== */
.solutions-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.sol-card{background:var(--surface);border-radius:var(--radius-xl);padding:44px 36px;border:1px solid var(--border);transition:all 0.5s cubic-bezier(0.16,1,0.3,1);position:relative;overflow:hidden;cursor:pointer}
.sol-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,transparent,rgba(0,113,227,0.02));opacity:0;transition:opacity 0.5s}
.sol-card:hover::before{opacity:1}
.sol-card:hover{box-shadow:var(--shadow-xl);transform:translateY(-6px);border-color:transparent}
.sol-card:hover .sol-icon{transform:scale(1.1) rotate(-5deg)}
.sol-card.featured{grid-column:span 2;background:linear-gradient(135deg,#F8FBFE,#F0F6FC);border-color:rgba(0,113,227,0.1)}
.sol-icon{width:56px;height:56px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:24px;transition:all 0.4s cubic-bezier(0.16,1,0.3,1);position:relative;z-index:1}
.sol-card h3{font-size:22px;font-weight:700;color:var(--text);margin-bottom:10px;position:relative;z-index:1}
.sol-card p{font-size:14px;color:var(--text2);line-height:1.7;margin-bottom:24px;position:relative;z-index:1}
.sol-tags{display:flex;gap:8px;flex-wrap:wrap;position:relative;z-index:1}
.sol-tag{padding:4px 12px;border-radius:8px;font-size:11px;font-weight:600;background:var(--bg2);color:var(--text2);transition:all 0.3s}
.sol-card:hover .sol-tag{background:rgba(0,184,176,0.08);color:var(--teal)}
.sol-link{display:inline-flex;align-items:center;gap:6px;font-size:14px;font-weight:600;color:var(--blue);text-decoration:none;margin-top:24px;transition:all .3s;position:relative;z-index:1}
.sol-link::after{content:'→';transition:transform 0.3s;display:inline-block}
.sol-link:hover{gap:10px;color:var(--accent)}

/* ====== PRODUCT STRIP ====== */
.product-strip{border-radius:var(--radius-xl);overflow:hidden;display:flex;flex-direction:column;gap:1px;background:var(--border)}
.product-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1px;background:var(--border)}
.product-item{background:var(--surface);padding:56px 44px;transition:all 0.5s cubic-bezier(0.16,1,0.3,1);position:relative;overflow:hidden;cursor:default}
.product-item::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--teal),var(--blue));transform:scaleX(0);transition:transform 0.5s cubic-bezier(0.16,1,0.3,1)}
.product-item:hover::after{transform:scaleX(1)}
.product-item:hover{background:#FAFBFC;transform:translateY(-2px)}
.product-item .prod-num{font-size:11px;font-weight:700;color:var(--text3);letter-spacing:2px;margin-bottom:20px;text-transform:uppercase}
.product-item h4{font-size:24px;font-weight:700;color:var(--text);margin-bottom:10px;letter-spacing:-0.5px}
.product-item p{font-size:14px;color:var(--text2);line-height:1.7;margin-bottom:20px}
.product-item .prod-spec{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:700;color:var(--teal);padding:6px 14px;background:rgba(0,184,176,0.06);border-radius:20px;transition:all 0.3s}
.product-item:hover .prod-spec{background:rgba(0,184,176,0.12)}

/* ====== CASES ====== */
.case-layout{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.case-featured{grid-row:span 2;background:linear-gradient(160deg,#0F1923,#1A2A3A);color:#fff;border-radius:var(--radius-xl);padding:56px;position:relative;overflow:hidden;transition:transform 0.5s cubic-bezier(0.16,1,0.3,1)}
.case-featured:hover{transform:translateY(-4px)}
.case-featured::before{content:'';position:absolute;top:-30%;right:-30%;width:500px;height:500px;background:radial-gradient(circle,rgba(0,184,176,0.12),transparent 70%);border-radius:50%;animation:floatSlow 15s ease-in-out infinite}
.case-featured::after{content:'';position:absolute;bottom:-20%;left:-20%;width:400px;height:400px;background:radial-gradient(circle,rgba(0,113,227,0.08),transparent 70%);border-radius:50%}
.case-featured>*{position:relative;z-index:1}
.case-featured .case-logo{font-size:12px;color:rgba(255,255,255,0.4);margin-bottom:28px;letter-spacing:1.5px;font-weight:600}
.case-featured h3{font-size:34px;font-weight:800;margin-bottom:14px;letter-spacing:-1px}
.case-featured p{font-size:16px;color:rgba(255,255,255,0.55);line-height:1.9;max-width:380px;margin-bottom:32px}
.case-card{background:var(--surface);border-radius:var(--radius-xl);padding:40px;border:1px solid var(--border);transition:all 0.4s cubic-bezier(0.16,1,0.3,1);cursor:pointer}
.case-card:hover{box-shadow:var(--shadow-xl);transform:translateY(-4px);border-color:transparent}
.case-card .case-tag{font-size:11px;color:var(--teal);font-weight:700;margin-bottom:14px;letter-spacing:1px}
.case-card h4{font-size:20px;font-weight:700;color:var(--text);margin-bottom:10px;letter-spacing:-0.3px}
.case-card p{font-size:14px;color:var(--text2);line-height:1.7}

/* ====== ABOUT ====== */
.about-layout{display:grid;grid-template-columns:1fr 1fr;gap:100px;align-items:center}
.about-text h3{font-size:44px;font-weight:800;color:var(--text);margin-bottom:24px;letter-spacing:-1.5px;line-height:1.12}
.about-text .lead{font-size:19px;color:var(--text2);line-height:1.9;margin-bottom:36px}
.about-badges{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.ab-badge{padding:28px;background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);text-align:center;transition:all 0.4s cubic-bezier(0.16,1,0.3,1);cursor:default}
.ab-badge:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);border-color:rgba(0,113,227,0.15)}
.ab-badge strong{display:block;font-size:32px;font-weight:800;color:var(--blue);letter-spacing:-1px;transition:transform 0.3s}
.ab-badge:hover strong{transform:scale(1.1)}
.ab-badge small{font-size:12px;color:var(--text2);margin-top:6px;display:block;letter-spacing:0.5px}
.about-visual{position:relative;height:460px;border-radius:var(--radius-xl);overflow:hidden;background:linear-gradient(160deg,#E8F0F8,#DCE6F0);display:flex;align-items:center;justify-content:center}
.about-visual::before{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.4'%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");opacity:0.5}
.about-visual .logo-badge{width:180px;height:180px;border-radius:40px;background:rgba(255,255,255,0.9);box-shadow:var(--shadow-xl);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:800;color:var(--text);text-align:center;line-height:1.4;backdrop-filter:blur(20px);position:relative;z-index:1;transition:transform 0.5s cubic-bezier(0.16,1,0.3,1)}
.about-visual .logo-badge:hover{transform:scale(1.05) rotate(-2deg)}

/* ====== NEWS ====== */
.news-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.news-card{background:var(--surface);border-radius:var(--radius);padding:32px;border:1px solid var(--border);transition:all 0.4s cubic-bezier(0.16,1,0.3,1);cursor:pointer;position:relative;overflow:hidden}
.news-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--teal),var(--blue));transform:scaleX(0);transform-origin:left;transition:transform 0.5s cubic-bezier(0.16,1,0.3,1)}
.news-card:hover::before{transform:scaleX(1)}
.news-card:hover{box-shadow:var(--shadow-xl);transform:translateY(-4px);border-color:transparent}
.news-card .news-date{font-size:11px;color:var(--text3);margin-bottom:14px;font-weight:600;letter-spacing:0.5px}
.news-card h4{font-size:17px;font-weight:700;color:var(--text);line-height:1.45;margin-bottom:10px;letter-spacing:-0.2px}
.news-card p{font-size:13px;color:var(--text2);line-height:1.7}

/* ====== CTA ====== */
.cta-card{background:linear-gradient(160deg,#061525,#0F2845);border-radius:var(--radius-xl);padding:100px 64px;text-align:center;color:#fff;position:relative;overflow:hidden}
.cta-card::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 30% 50%,rgba(0,184,176,0.1),transparent 50%),radial-gradient(circle at 70% 50%,rgba(0,113,227,0.08),transparent 50%),radial-gradient(circle at 50% 0%,rgba(255,255,255,0.03),transparent 60%)}
.cta-card>*{position:relative;z-index:1}
.cta-card h2{font-size:clamp(36px,5vw,52px);font-weight:800;margin-bottom:20px;letter-spacing:-1.5px}
.cta-card p{font-size:18px;color:rgba(255,255,255,0.55);margin-bottom:44px}
.cta-card .btn{background:#fff;color:#0F1923;font-size:17px;font-weight:700;padding:18px 44px;border-radius:30px;transition:all 0.4s cubic-bezier(0.16,1,0.3,1);position:relative;overflow:hidden}
.cta-card .btn::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(0,0,0,0.05),transparent);transition:left 0.6s}
.cta-card .btn:hover::before{left:100%}
.cta-card .btn:hover{background:#F5F5F7;box-shadow:0 16px 48px rgba(0,0,0,0.2);transform:translateY(-3px)}

/* ====== FOOTER ====== */
.footer{background:var(--bg2);padding:80px 0 36px;position:relative}
.footer::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--border),transparent)}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:48px;margin-bottom:52px}
.footer h5{font-size:13px;font-weight:700;color:var(--text);margin-bottom:16px;letter-spacing:0.5px}
.footer p,.footer a{font-size:13px;color:var(--text2);text-decoration:none;line-height:2.4;display:block;transition:all .2s}
.footer a:hover{color:var(--blue);transform:translateX(3px)}
.footer-bottom{border-top:1px solid var(--border);padding-top:28px;font-size:12px;color:var(--text3);text-align:center;letter-spacing:0.3px}

/* ====== RESPONSIVE ====== */
@media(max-width:1024px){
  .solutions-grid{grid-template-columns:1fr 1fr}.sol-card.featured{grid-column:span 2}
  .case-layout{grid-template-columns:1fr}.news-grid{grid-template-columns:1fr 1fr}
  .product-row{grid-template-columns:1fr 1fr}.about-layout{grid-template-columns:1fr;gap:56px}
  .hero-visual{display:none}.hero{padding:160px 0 100px;min-height:auto}
  .hero h1{font-size:clamp(40px,7vw,64px)}
}
@media(max-width:768px){
  .hero h1{font-size:38px;letter-spacing:-1.5px}
  .solutions-grid{grid-template-columns:1fr}.sol-card.featured{grid-column:span 1}
  .product-row{grid-template-columns:1fr}
  .news-grid{grid-template-columns:1fr}
  .hero-stats{flex-wrap:wrap}
  .hero-stat{flex:1;min-width:130px}
  .cta-card{padding:64px 28px}
  .nav-links{display:none}
  .page-hero h1{font-size:32px}
  .footer-grid{grid-template-columns:1fr 1fr}
  .section{padding:80px 0}
  .about-layout{gap:40px}
  .about-text h3{font-size:32px}
}
@media(max-width:480px){
  .footer-grid{grid-template-columns:1fr}
  .hero h1{font-size:32px}
  .case-featured{padding:36px}
}

.reveal {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94),
              transform 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.reveal.visible { opacity: 1; transform: translateY(0); }
.reveal:nth-child(1) { transition-delay: 0.05s; }
.reveal:nth-child(2) { transition-delay: 0.10s; }
.reveal:nth-child(3) { transition-delay: 0.15s; }
.reveal:nth-child(4) { transition-delay: 0.20s; }
.reveal:nth-child(5) { transition-delay: 0.25s; }
.reveal:nth-child(6) { transition-delay: 0.30s; }

/* ==================== WOOCOMMERCE PRODUCT STRIP STYLES ==================== */
.product-item .add_to_cart_button {
  display: inline-block;
  padding: 8px 20px;
  background: var(--blue); color: #fff !important;
  border-radius: 20px; font-size: 12px; font-weight: 600;
  text-decoration: none;
  transition: all 0.2s;
}
.product-item .add_to_cart_button:hover {
  background: var(--accent);
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(0,113,227,0.25);
}
.product-item .add_to_cart_button.added { background: #14B482; }
.product-item .added_to_cart {
  display: inline-block; margin-left: 8px;
  font-size: 12px; color: var(--teal); font-weight: 600;
}

/* Single product page */
.single-product-hero { padding: 140px 0 60px; }
.single-product-layout {
  display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: start;
}
.sp-title {
  font-size: clamp(32px, 4vw, 48px);
  font-weight: 800; color: var(--text);
  letter-spacing: -1px; margin-bottom: 16px;
}
.sp-price { font-size: 32px; font-weight: 800; color: var(--blue); margin-bottom: 24px; display: block; }
.sp-desc { font-size: 16px; color: var(--text2); line-height: 1.8; margin-bottom: 28px; }
.sp-actions form.cart { display: flex; gap: 12px; align-items: center; }
.sp-actions .quantity input {
  padding: 14px; width: 70px;
  border: 1.5px solid var(--border); border-radius: var(--radius-sm);
  font-size: 16px; font-weight: 600; text-align: center;
}
.sp-actions .single_add_to_cart_button {
  padding: 14px 36px; background: var(--blue); color: #fff;
  border: none; border-radius: 28px; font-size: 15px; font-weight: 600; cursor: pointer;
  transition: all 0.25s;
}
.sp-actions .single_add_to_cart_button:hover {
  background: var(--accent); transform: translateY(-2px);
  box-shadow: 0 8px 28px rgba(0,113,227,0.3);
}

/* Notices */
.woocommerce-message { max-width: var(--max-w); margin: 20px auto 0; padding: 16px 24px; border-radius: var(--radius); font-size: 14px; background: #E8F8F0; color: #14B482; border: 1px solid rgba(20,180,130,0.2); }
.woocommerce-error { max-width: var(--max-w); margin: 20px auto 0; padding: 16px 24px; border-radius: var(--radius); font-size: 14px; background: #FFF0F0; color: #DC3232; }

/* Cart/Checkout */
.wc-wrapper table { width: 100%; border-collapse: collapse; border-radius: var(--radius-lg); overflow: hidden; }
.wc-wrapper table th { text-align: left; padding: 14px 16px; font-size: 11px; font-weight: 700; color: var(--text3); letter-spacing: 1px; border-bottom: 2px solid var(--border); }
.wc-wrapper table td { padding: 16px; font-size: 15px; color: var(--text); border-bottom: 1px solid var(--border); }
.wc-wrapper table img { width: 70px; border-radius: var(--radius-sm); }
.cart_totals { background: var(--bg2); border-radius: var(--radius-xl); padding: 32px; margin-top: 32px; }
.checkout-button, .wc-forward {
  display: inline-block; padding: 16px 40px; background: var(--blue); color: #fff !important;
  border-radius: 28px; font-size: 15px; font-weight: 600; text-decoration: none; transition: all 0.25s;
}
.checkout-button:hover { background: var(--accent); transform: translateY(-2px); box-shadow: 0 8px 28px rgba(0,113,227,0.3); }
.coupon { display: flex; gap: 8px; margin-bottom: 16px; }
.coupon input { padding: 12px 16px; border: 1.5px solid var(--border); border-radius: var(--radius-sm); font-size: 14px; flex: 1; }
.coupon button { padding: 12px 24px; background: var(--text); color: #fff; border: none; border-radius: var(--radius-sm); font-size: 13px; font-weight: 600; cursor: pointer; }

@media(max-width:1024px){ .single-product-layout{grid-template-columns:1fr;gap:32px} }
@media(max-width:768px){ .sp-title{font-size:28px} .sp-price{font-size:24px} }
/* === Cart & Account Icons in Nav - grouped === */
.nav-icons{display:flex;align-items:center;gap:2px;margin-left:4px}
.nav-cart, .nav-account {
  display: flex; align-items: center; justify-content: center;
  width: 38px; height: 38px;
  color: var(--text);
  opacity: 0.65;
  transition: opacity 0.2s, color 0.2s, background 0.2s;
  position: relative;
  border-radius: 10px;
}
.nav-cart:hover,.nav-account:hover{opacity:1;color:var(--accent,#00a8ff);background:rgba(0,113,227,0.08)}
.nav-cart .cart-count {
  position: absolute; top:2px;right:2px;
  background:#ff3b30;
  color: #fff;
  font-size: 10px; font-weight: 700;
  min-width: 16px; height: 16px;
  border-radius:8px;box-shadow:0 1px 4px rgba(255,59,48,0.4);display:flex; align-items: center; justify-content: center;
  line-height: 1;
  padding: 0 4px;
}
@media(max-width:768px){
  .nav-cart, .nav-account { width: 34px; height: 34px; }
  .nav-cart svg, .nav-account svg { width: 18px; height: 18px; }
}

/* =============================================
   My Account / Login / Register - Dark Theme
   ============================================= */
.woocommerce-account{padding-top:120px!important;padding-bottom:80px!important}
.woocommerce-account .entry-title,.woocommerce-account h2{font-size:28px;font-weight:700;margin-bottom:8px;color:#fff}
.woocommerce-account .entry-content{max-width:960px;margin:0 auto;padding:0 24px}
.woocommerce-account .u-columns{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin-top:40px}
@media(max-width:768px){.woocommerce-account .u-columns{grid-template-columns:1fr}}
.woocommerce-form-login,.woocommerce-form-register{padding:40px 36px!important;background:rgba(255,255,255,.03);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.08)!important;border-radius:20px!important;box-shadow:0 8px 32px rgba(0,0,0,.3)}
.woocommerce-form-login h2,.woocommerce-form-register h2{font-size:22px;margin-bottom:6px;color:#fff}
.woocommerce-form-login .form-row,.woocommerce-form-register .form-row{margin-bottom:18px}
.woocommerce-form-login label,.woocommerce-form-register label{display:block;margin-bottom:6px;font-size:13px;font-weight:500;color:rgba(255,255,255,.6);letter-spacing:.02em}
.woocommerce-form-login input[type="text"],.woocommerce-form-login input[type="email"],.woocommerce-form-login input[type="password"],.woocommerce-form-register input[type="text"],.woocommerce-form-register input[type="email"],.woocommerce-form-register input[type="password"]{width:100%;padding:14px 16px;background:rgba(255,255,255,.05);border:1.5px solid rgba(255,255,255,.1);border-radius:10px;color:#fff!important;font-size:15px;transition:border-color .2s,box-shadow .2s}
.woocommerce-form-login input:focus,.woocommerce-form-register input:focus{outline:none;border-color:var(--accent,#00a8ff);box-shadow:0 0 0 3px rgba(0,168,255,.15)}
.woocommerce-form-login .woocommerce-form-login__submit,.woocommerce-form-register .woocommerce-form-register__submit{width:100%;padding:14px 28px;background:linear-gradient(135deg,var(--blue,#0071e3),var(--accent,#00a8ff));color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 16px rgba(0,113,227,.3)}
.woocommerce-form-login .woocommerce-form-login__submit:hover,.woocommerce-form-register .woocommerce-form-register__submit:hover{transform:translateY(-1px);box-shadow:0 6px 24px rgba(0,113,227,.45)}
.woocommerce-form-login .woocommerce-form-login__rememberme{display:flex;align-items:center;gap:8px;font-size:13px;color:rgba(255,255,255,.5)}
.woocommerce-form-login .woocommerce-form-login__rememberme input{accent-color:var(--accent,#00a8ff)}
.woocommerce-form-login .lost_password{margin-left:auto;font-size:13px}
.woocommerce-form-login .lost_password a{color:var(--accent,#00a8ff);text-decoration:none}
.woocommerce-MyAccount-navigation{background:rgba(255,255,255,.03);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.06);border-radius:16px;padding:24px}
.woocommerce-MyAccount-navigation ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:2px}
.woocommerce-MyAccount-navigation li a{display:block;padding:12px 16px;color:rgba(255,255,255,.65);text-decoration:none;font-size:14px;border-radius:10px;transition:background .2s,color .2s}
.woocommerce-MyAccount-navigation li a:hover,.woocommerce-MyAccount-navigation li.is-active a{background:rgba(0,168,255,.1);color:var(--accent,#00a8ff)}
.woocommerce-MyAccount-content{background:rgba(255,255,255,.03);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.06);border-radius:16px;padding:32px;color:rgba(255,255,255,.8)}
.woocommerce-MyAccount-content a{color:var(--accent,#00a8ff);text-decoration:none}
.woocommerce-MyAccount-content .woocommerce-Message,.woocommerce-MyAccount-content .woocommerce-info{background:rgba(0,168,255,.08);border:1px solid rgba(0,168,255,.2);border-radius:10px;padding:16px 20px;color:rgba(255,255,255,.85);margin-bottom:24px}

