/*
Theme Name: Thimze Media
Theme URI: https://thimzemedia.com
Author: Thimze Media
Author URI: https://thimzemedia.com
Description: Custom theme for Thimze Media — Design. Print. Brand. Repeat.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
Text Domain: thimze-media
*/

:root{
  --bg:#0a0b0d;
  --card:#131518;
  --card-2:#191c20;
  --line:#242830;
  --text:#f4f5f6;
  --text-dim:#9a9fa8;
  --text-dimmer:#5c6169;
  --blue:#19c3f3;
  --blue-soft:rgba(25,195,243,0.12);

  --display:'Space Grotesk', sans-serif;
  --body:'Inter', sans-serif;
}
*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{ background:var(--bg); color:var(--text); font-family:var(--body); overflow-x:hidden; }
a{ color:inherit; text-decoration:none; }
img{ display:block; max-width:100%; }
::selection{ background:var(--blue); color:#04121a; }
:focus-visible{ outline:2px solid var(--blue); outline-offset:3px; }

.wrap{ max-width:1180px; margin:0 auto; padding:0 32px; }
@media (max-width:640px){ .wrap{ padding:0 20px; } }

h1,h2,h3{ font-family:var(--display); font-weight:700; line-height:1.05; letter-spacing:-0.01em; }

.eyebrow{ font-size:13px; font-weight:600; color:var(--blue); display:flex; align-items:center; gap:8px; margin-bottom:16px; }
.eyebrow::before{ content:''; width:6px; height:6px; border-radius:50%; background:var(--blue); box-shadow:0 0 8px var(--blue); }

.btn{ display:inline-flex; align-items:center; gap:8px; padding:15px 26px; border-radius:100px; font-weight:600; font-size:14px; transition:transform .25s ease, box-shadow .25s ease, background .25s ease, color .25s; border:none; cursor:pointer; font-family:var(--body); }
.btn-solid{ background:var(--blue); color:#04121a; }
.btn-solid:hover{ transform:translateY(-2px); box-shadow:0 10px 30px rgba(25,195,243,0.3); }
.btn-outline{ border:1px solid var(--line); color:var(--text); background:transparent; }
.btn-outline:hover{ border-color:var(--blue); color:var(--blue); }

.reveal{ opacity:0; transform:translateY(26px); transition:opacity .7s ease, transform .7s ease; }
.reveal.in{ opacity:1; transform:translateY(0); }

/* ===== HEADER / NAV ===== */
header{ position:fixed; top:0; left:0; right:0; z-index:600; transition:background .3s, border-color .3s; border-bottom:1px solid transparent; }
header.scrolled{ background:rgba(10,11,13,0.8); backdrop-filter:blur(12px); border-color:var(--line); }
.nav{ display:flex; align-items:center; justify-content:space-between; padding:20px 32px; }
.logo{ font-family:var(--display); font-weight:700; font-size:19px; display:flex; align-items:center; gap:8px; }
.site-logo{ display:flex; align-items:center; }
.site-logo img{ height:34px; width:auto; max-width:200px; object-fit:contain; display:block; }
.custom-logo-link{ display:flex; align-items:center; }
.site-logo-footer img{ height:30px; }
.logo .dot{ width:8px; height:8px; border-radius:50%; background:var(--blue); box-shadow:0 0 10px var(--blue); }
.nav-links{ display:flex; gap:30px; font-size:14px; font-weight:500; align-items:center; }
.nav-links > li > a{ color:var(--text-dim); transition:color .2s; padding:8px 0; display:block; }
.nav-links > li > a:hover{ color:var(--text); }
.nav-links li{ list-style:none; }
.has-drop{ position:relative; }
.has-drop > a{ color:var(--text-dim); cursor:pointer; display:flex !important; align-items:center; gap:5px; transition:color .2s; }
.has-drop:hover > a{ color:var(--text); }
.has-drop .caret{ font-size:10px; transition:transform .2s; }
.has-drop:hover .caret{ transform:rotate(180deg); }
.dropdown{ position:absolute; top:28px; left:50%; transform:translateX(-50%) translateY(6px); background:var(--card); border:1px solid var(--line); border-radius:14px; padding:8px; min-width:170px; opacity:0; pointer-events:none; transition:opacity .2s, transform .2s; list-style:none; }
.has-drop:hover .dropdown{ opacity:1; pointer-events:auto; transform:translateX(-50%) translateY(0); }
.dropdown a{ display:block; padding:10px 14px; font-size:14px; color:var(--text-dim); border-radius:8px; }
.dropdown a:hover{ background:var(--card-2); color:var(--text); }
.nav-cta{ display:flex; align-items:center; gap:16px; }
.nav-toggle{ display:none; width:40px; height:40px; border:1px solid var(--line); border-radius:10px; background:transparent; cursor:pointer; align-items:center; justify-content:center; flex-direction:column; gap:4px; }
.nav-toggle span{ width:18px; height:1.5px; background:var(--text); display:block; transition:transform .25s, opacity .25s; }
@media (max-width:900px){
  .nav-links{ display:none; position:absolute; top:100%; left:0; right:0; background:var(--bg); border-bottom:1px solid var(--line); flex-direction:column; align-items:flex-start; gap:0; padding:10px 32px 20px; }
  .nav-links.open{ display:flex; }
  .nav-links > li{ width:100%; }
  .nav-links > li > a{ padding:14px 0; border-bottom:1px solid var(--line); }
  .has-drop .dropdown{ position:static; transform:none; opacity:1; pointer-events:auto; display:none; background:transparent; border:none; padding:0 0 0 14px; }
  .has-drop.open .dropdown{ display:block; }
  .nav-toggle{ display:flex; }
}
  /* ===== HERO ===== */
  .hero{ padding:180px 0 0; position:relative; overflow:hidden; min-height:92vh; display:flex; flex-direction:column; justify-content:center; }
  .hero-bg{ position:absolute; inset:0; z-index:0; overflow:hidden; }
  .hero-bg span{
    position:absolute; border-radius:50%; filter:blur(70px); opacity:0.35;
    animation:drift 16s ease-in-out infinite alternate;
  }
  .hero-bg span:nth-child(1){ width:420px; height:420px; background:var(--blue); top:-120px; left:5%; }
  .hero-bg span:nth-child(2){ width:340px; height:340px; background:#7b5cff; top:120px; right:0%; animation-delay:3s; }
  .hero-bg span:nth-child(3){ width:300px; height:300px; background:var(--blue); bottom:-140px; left:35%; animation-delay:6s; }
  @keyframes drift{ from{ transform:translate(0,0) scale(1);} to{ transform:translate(30px,-40px) scale(1.12);} }
  @media (prefers-reduced-motion:reduce){ .hero-bg span{ animation:none; } }

  .hero-inner{ position:relative; z-index:2; text-align:center; padding:0 20px; }
  .hero-badge{ display:inline-flex; align-items:center; gap:8px; font-size:13px; color:var(--text-dim); background:var(--card); border:1px solid var(--line); padding:8px 16px; border-radius:100px; margin-bottom:30px; }
  .hero-badge .dot{ width:6px; height:6px; border-radius:50%; background:var(--blue); box-shadow:0 0 8px var(--blue); }
  .hero h1{ font-size:clamp(34px,5.6vw,68px); max-width:840px; margin:0 auto; }
  .hero-tagline{ margin-top:26px; font-family:var(--display); font-size:clamp(20px,3vw,30px); color:var(--blue); height:40px; display:flex; align-items:center; justify-content:center; }
  .hero-tagline span{ display:inline-block; }
  .hero-actions{ margin-top:38px; display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

  .hero-video-wrap{ position:relative; z-index:2; margin:70px auto 0; max-width:1560px; width:94vw; padding:0; }
  .hero-video{ position:relative; border-radius:28px; overflow:hidden; border:1px solid var(--line); box-shadow:0 50px 120px rgba(0,0,0,0.6); aspect-ratio:16/8; background:linear-gradient(150deg,#0f2530,#0a0b0d); }
  .hero-video video{ width:100%; height:100%; object-fit:cover; display:block; }
  .hero-video iframe{ position:absolute; top:50%; left:50%; width:100%; height:100%; border:none; transform:translate(-50%,-50%) scale(1.02); pointer-events:none; }
  .hero-video::after{ content:''; position:absolute; inset:0; box-shadow:inset 0 0 0 1px rgba(255,255,255,0.04); pointer-events:none; }
  .hero-video-glow{ position:absolute; inset:-60px; z-index:-1; background:radial-gradient(circle at 50% 30%, rgba(25,195,243,0.28), transparent 65%); filter:blur(50px); }
  .hero-video-scrim{ position:absolute; inset:0; background:linear-gradient(180deg, rgba(4,8,12,0.35) 0%, transparent 22%, transparent 70%, rgba(4,8,12,0.55) 100%); pointer-events:none; z-index:2; }
  .hero-video-caption{ position:absolute; left:28px; bottom:26px; z-index:3; font-size:13px; color:rgba(255,255,255,0.85); font-weight:500; }
  .hero-video-badge{ position:absolute; right:28px; top:26px; z-index:3; font-size:11px; font-weight:700; letter-spacing:0.08em; color:#fff; background:rgba(10,11,13,0.5); backdrop-filter:blur(6px); border:1px solid rgba(255,255,255,0.18); padding:7px 14px; border-radius:100px; }
  @media (max-width:900px){ .hero-video{ aspect-ratio:4/5; border-radius:20px; } .hero-video iframe{ transform:translate(-50%,-50%) scale(1.7); } .hero-video-wrap{ width:92vw; margin-top:48px; } }

  /* ===== SECTION ===== */
  .section{ padding:120px 0; }
  .section-head{ max-width:640px; margin:0 auto 56px; text-align:center; }
  .section-head.left{ text-align:left; margin:0 0 48px; }
  .section-head h2{ font-size:clamp(30px,4.4vw,48px); margin-top:6px; }
  .section-head p{ color:var(--text-dim); margin-top:16px; font-size:15px; line-height:1.6; }

  /* ===== ABOUT ===== */
  .about-grid{ display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
  .about-visual{ aspect-ratio:4/3; border-radius:20px; border:1px solid var(--line); background:linear-gradient(150deg,#0f2530,#0a0b0d); position:relative; overflow:hidden; }
  .about-visual::after{ content:''; position:absolute; inset:0; background:radial-gradient(circle at 30% 20%, rgba(25,195,243,0.25), transparent 60%); }
  .about-text p{ color:var(--text-dim); font-size:16px; line-height:1.75; margin-bottom:28px; }
  .about-actions{ display:flex; gap:14px; flex-wrap:wrap; }
  @media (max-width:860px){ .about-grid{ grid-template-columns:1fr; gap:32px; } }

  /* ===== SERVICES ===== */
  .service-list{ border-top:1px solid var(--line); }
  .service-item{ border-bottom:1px solid var(--line); padding:34px 4px; cursor:pointer; transition:padding-left .3s; }
  .service-item:hover{ padding-left:14px; }
  .service-top{ display:flex; justify-content:space-between; align-items:center; gap:20px; }
  .service-num{ font-family:var(--display); font-size:13px; color:var(--text-dimmer); }
  .service-top h3{ font-size:clamp(22px,3vw,32px); text-transform:none; flex:1; transition:color .3s; }
  .service-item:hover .service-top h3{ color:var(--blue); }
  .service-plus{ font-size:22px; color:var(--text-dim); transition:transform .3s, color .3s; }
  .service-item.open .service-plus{ transform:rotate(45deg); color:var(--blue); }
  .service-body{ max-height:0; overflow:hidden; transition:max-height .4s ease; }
  .service-body p{ padding:18px 0 0; color:var(--text-dim); font-size:15px; line-height:1.7; max-width:640px; }

  /* ===== PORTFOLIO ===== */
  .work-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
  .work-card{ border-radius:18px; overflow:hidden; border:1px solid var(--line); transition:transform .3s, border-color .3s; }
  .work-card:hover{ transform:translateY(-6px); border-color:var(--blue); }
  .work-thumb{ aspect-ratio:4/5; position:relative; }
  .work-thumb::after{ content:''; position:absolute; inset:0; background:linear-gradient(160deg, rgba(25,195,243,0.2), transparent 60%); }
  .work-info{ padding:18px 20px 22px; background:var(--card); }
  .work-tag{ font-size:12px; color:var(--blue); font-weight:600; }
  .work-info h3{ font-size:21px; text-transform:none; margin-top:6px; }
  .work-info span{ font-size:12px; color:var(--text-dim); }
  @media (max-width:860px){ .work-grid{ grid-template-columns:repeat(2,1fr); } }
  @media (max-width:560px){ .work-grid{ grid-template-columns:1fr; } }

  /* ===== TESTIMONIALS ===== */
  .testi-lede{ text-align:center; max-width:520px; margin:0 auto 56px; color:var(--text-dim); font-size:15px; }
  .testi-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
  .testi-card{ background:var(--card); border:1px solid var(--line); border-radius:20px; padding:30px; }
  .testi-card p{ font-size:15px; line-height:1.65; margin-bottom:24px; }
  .testi-person{ display:flex; align-items:center; gap:12px; }
  .testi-avatar{ width:38px; height:38px; border-radius:50%; border:1px solid var(--line); }
  .testi-person b{ display:block; font-size:14px; }
  .testi-person span{ font-size:12px; color:var(--text-dim); }
  @media (max-width:860px){ .testi-grid{ grid-template-columns:1fr; } }

  /* ===== LOGO MARQUEE ===== */
  .logo-strip{ overflow:hidden; white-space:nowrap; border-top:1px solid var(--line); border-bottom:1px solid var(--line); padding:40px 0; margin:80px 0; }
  .logo-track{ display:inline-flex; animation:marquee 24s linear infinite; }
  .logo-track span{ font-family:var(--display); font-weight:700; font-size:22px; color:var(--text-dimmer); padding:0 40px; }
  .logo-track .logo-item{ width:150px; height:50px; flex-shrink:0; display:flex; align-items:center; justify-content:center; margin:0 25px; }
  .logo-track .logo-item img{ max-width:100%; max-height:100%; width:auto; height:auto; object-fit:contain; opacity:0.55; filter:grayscale(1) brightness(1.6); transition:opacity .25s, filter .25s; }
  .logo-track .logo-item img:hover{ opacity:1; filter:none; }
  @keyframes marquee{ from{transform:translateX(0);} to{transform:translateX(-50%);} }

  /* ===== COUNTERS ===== */
  .counter-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; text-align:center; }
  .counter b{ font-family:var(--display); font-size:clamp(32px,4.4vw,48px); color:var(--blue); display:block; }
  .counter span{ font-size:13px; color:var(--text-dim); }
  @media (max-width:760px){ .counter-grid{ grid-template-columns:repeat(2,1fr); row-gap:36px; } }

  /* ===== CONNECT ===== */
  .connect{ text-align:center; }
  .connect p{ color:var(--text-dim); max-width:440px; margin:16px auto 32px; font-size:15px; }
  .connect-btns{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
  .social-btn{ display:inline-flex; align-items:center; gap:8px; border:1px solid var(--line); padding:12px 20px; border-radius:100px; font-size:14px; font-weight:500; transition:border-color .2s, color .2s; }
  .social-btn:hover{ border-color:var(--blue); color:var(--blue); }
  .social-btn svg{ width:16px; height:16px; }
  .social-btn path,.social-btn rect,.social-btn circle{ stroke:currentColor; fill:none; stroke-width:1.6; }

  /* ===== FINAL CTA ===== */
  .cta{ text-align:center; padding:140px 0; position:relative; border-top:1px solid var(--line); overflow:hidden; }
  .cta-glow{ position:absolute; bottom:-260px; left:50%; transform:translateX(-50%); width:800px; height:500px; background:radial-gradient(ellipse at center, var(--blue), transparent 70%); opacity:0.18; filter:blur(50px); pointer-events:none; }
  .cta h2{ font-size:clamp(34px,5.6vw,58px); position:relative; z-index:2; }
  .cta p{ color:var(--text-dim); max-width:420px; margin:18px auto 0; font-size:15px; position:relative; z-index:2; }
  .cta .btn{ margin-top:32px; position:relative; z-index:2; }

  /* ===== FOOTER ===== */
  footer{ border-top:1px solid var(--line); padding-top:70px; }
  .foot-top{ display:grid; grid-template-columns:1.5fr 1fr 1fr; gap:40px; padding-bottom:60px; }
  .foot-brand p{ color:var(--text-dim); font-size:14px; max-width:300px; margin-top:14px; line-height:1.6; }
  .foot-social{ display:flex; gap:12px; margin-top:22px; }
  .foot-social a{ width:36px; height:36px; border:1px solid var(--line); border-radius:50%; display:flex; align-items:center; justify-content:center; }
  .foot-social svg{ width:13px; height:13px; }
  .foot-social path{ stroke:var(--text-dim); fill:none; stroke-width:1.6; }
  .foot-col h4{ font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:0.06em; color:var(--text-dim); margin-bottom:18px; }
  .foot-col a, .foot-col p{ display:block; font-size:14px; color:var(--text-dim); padding:6px 0; }
  .foot-col a:hover{ color:var(--blue); }
  .foot-bottom{ display:flex; justify-content:space-between; padding:24px 0; border-top:1px solid var(--line); font-size:12px; color:var(--text-dimmer); flex-wrap:wrap; gap:8px; }
  @media (max-width:760px){ .foot-top{ grid-template-columns:1fr 1fr; } }
  @media (max-width:520px){ .foot-top{ grid-template-columns:1fr; } }
  /* ===== PAGE HERO (subpages) ===== */
  .page-hero{ padding:170px 0 90px; position:relative; overflow:hidden; border-bottom:1px solid var(--line); }
  .page-hero-bg{ position:absolute; inset:0; z-index:0; overflow:hidden; }
  .page-hero-bg span{ position:absolute; border-radius:50%; filter:blur(80px); opacity:0.28; background:var(--blue); width:360px; height:360px; top:-160px; right:-60px; }
  .page-hero .wrap{ position:relative; z-index:2; }
  .breadcrumb{ font-size:13px; color:var(--text-dimmer); margin-bottom:22px; }
  .breadcrumb a{ color:var(--text-dim); }
  .breadcrumb a:hover{ color:var(--blue); }
  .page-hero h1{ font-size:clamp(32px,5vw,54px); max-width:720px; }
  .page-hero p.lede{ color:var(--text-dim); font-size:16px; line-height:1.7; max-width:560px; margin-top:20px; }

  /* ===== TEAM ===== */
  .team-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
  .team-card{ text-align:center; }
  .team-photo{ aspect-ratio:1; border-radius:16px; border:1px solid var(--line); background:linear-gradient(150deg,#0f2530,#0a0b0d); margin-bottom:14px; position:relative; overflow:hidden; }
  .team-photo::after{ content:''; position:absolute; inset:0; background:radial-gradient(circle at 30% 20%, rgba(25,195,243,0.2), transparent 60%); }
  .team-card b{ display:block; font-family:var(--display); font-size:15px; }
  .team-card span{ font-size:13px; color:var(--text-dim); }
  @media (max-width:860px){ .team-grid{ grid-template-columns:repeat(2,1fr); } }

  /* ===== VALUES ===== */
  .value-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
  .value-card{ background:var(--card); border:1px solid var(--line); border-radius:18px; padding:30px; }
  .value-icon{ width:42px; height:42px; border-radius:12px; background:var(--blue-soft); display:flex; align-items:center; justify-content:center; margin-bottom:20px; }
  .value-icon svg{ width:20px; height:20px; stroke:var(--blue); fill:none; stroke-width:1.6; }
  .value-card h3{ font-size:18px; margin-bottom:10px; }
  .value-card p{ color:var(--text-dim); font-size:14px; line-height:1.65; }
  @media (max-width:860px){ .value-grid{ grid-template-columns:1fr; } }

  /* ===== TIMELINE ===== */
  .timeline{ position:relative; padding-left:32px; border-left:1px solid var(--line); }
  .timeline-item{ position:relative; padding-bottom:44px; }
  .timeline-item:last-child{ padding-bottom:0; }
  .timeline-item::before{ content:''; position:absolute; left:-37px; top:2px; width:11px; height:11px; border-radius:50%; background:var(--blue); box-shadow:0 0 10px var(--blue); }
  .timeline-item b{ font-family:var(--display); color:var(--blue); font-size:14px; display:block; margin-bottom:6px; }
  .timeline-item h3{ font-size:19px; margin-bottom:8px; }
  .timeline-item p{ color:var(--text-dim); font-size:14px; line-height:1.65; max-width:520px; }

  /* ===== SERVICE DETAIL BLOCKS ===== */
  .sd-block{ display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; padding:70px 0; border-bottom:1px solid var(--line); }
  .sd-block:last-child{ border-bottom:none; }
  .sd-block.rev .sd-visual{ order:2; }
  .sd-visual{ aspect-ratio:4/3; border-radius:20px; border:1px solid var(--line); background:linear-gradient(150deg,#0f2530,#0a0b0d); position:relative; overflow:hidden; }
  .sd-visual::after{ content:''; position:absolute; inset:0; background:radial-gradient(circle at 70% 30%, rgba(25,195,243,0.22), transparent 60%); }
  .sd-num{ font-family:var(--display); font-size:13px; color:var(--text-dimmer); }
  .sd-text h3{ font-size:clamp(24px,3vw,32px); margin:10px 0 18px; }
  .sd-text p{ color:var(--text-dim); font-size:15px; line-height:1.75; margin-bottom:22px; }
  .sd-list{ list-style:none; display:flex; flex-direction:column; gap:12px; }
  .sd-list li{ font-size:14px; color:var(--text-dim); display:flex; align-items:flex-start; gap:10px; }
  .sd-list li::before{ content:'—'; color:var(--blue); flex-shrink:0; }
  @media (max-width:860px){ .sd-block, .sd-block.rev{ grid-template-columns:1fr; gap:28px; } .sd-block.rev .sd-visual{ order:0; } }

  /* ===== PROCESS ===== */
  .process-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
  .process-card{ border:1px solid var(--line); border-radius:18px; padding:28px 24px; position:relative; }
  .process-card .sd-num{ margin-bottom:16px; display:block; }
  .process-card h3{ font-size:17px; margin-bottom:10px; }
  .process-card p{ color:var(--text-dim); font-size:13.5px; line-height:1.6; }
  @media (max-width:860px){ .process-grid{ grid-template-columns:1fr 1fr; } }
  @media (max-width:560px){ .process-grid{ grid-template-columns:1fr; } }

  /* ===== FILTER TABS ===== */
  .filter-tabs{ display:flex; gap:10px; flex-wrap:wrap; margin-bottom:40px; }
  .filter-btn{ border:1px solid var(--line); padding:10px 20px; border-radius:100px; font-size:13px; font-weight:500; color:var(--text-dim); cursor:pointer; transition:all .2s; background:transparent; font-family:var(--body); }
  .filter-btn:hover{ color:var(--text); border-color:var(--text-dim); }
  .filter-btn.active{ background:var(--blue); color:#04121a; border-color:var(--blue); }
  .work-card{ display:block; }
  .work-card.hidden{ display:none; }

  /* ===== CONTACT ===== */
  .contact-grid{ display:grid; grid-template-columns:0.9fr 1.1fr; gap:60px; align-items:start; }
  .contact-cards{ display:flex; flex-direction:column; gap:16px; }
  .contact-card{ background:var(--card); border:1px solid var(--line); border-radius:16px; padding:24px; display:flex; gap:16px; align-items:flex-start; }
  .contact-card-icon{ width:38px; height:38px; border-radius:10px; background:var(--blue-soft); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
  .contact-card-icon svg{ width:18px; height:18px; stroke:var(--blue); fill:none; stroke-width:1.6; }
  .contact-card b{ display:block; font-size:14px; margin-bottom:4px; }
  .contact-card span, .contact-card a{ font-size:13.5px; color:var(--text-dim); display:block; line-height:1.6; }
  .contact-card a:hover{ color:var(--blue); }
  .form-card{ background:var(--card); border:1px solid var(--line); border-radius:20px; padding:36px; }
  .form-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-bottom:16px; }
  .form-group{ margin-bottom:16px; }
  .form-group label{ display:block; font-size:13px; font-weight:500; color:var(--text-dim); margin-bottom:8px; }
  .form-group input, .form-group select, .form-group textarea{
    width:100%; background:var(--card-2); border:1px solid var(--line); border-radius:10px; padding:13px 16px;
    color:var(--text); font-family:var(--body); font-size:14px; transition:border-color .2s;
  }
  .form-group input:focus, .form-group select:focus, .form-group textarea:focus{ outline:none; border-color:var(--blue); }
  .form-group textarea{ resize:vertical; min-height:110px; }
  .form-card .btn-solid{ width:100%; justify-content:center; border:none; cursor:pointer; margin-top:6px; }
  @media (max-width:860px){ .contact-grid{ grid-template-columns:1fr; gap:40px; } .form-row{ grid-template-columns:1fr; gap:0; } }

  /* ===== FAQ ===== */
  .faq-list{ max-width:760px; margin:0 auto; }
  .faq-item{ border-bottom:1px solid var(--line); }
  .faq-top{ display:flex; justify-content:space-between; align-items:center; gap:20px; padding:24px 4px; cursor:pointer; }
  .faq-top h3{ font-size:16px; font-weight:600; font-family:var(--body); }
  .faq-plus{ font-size:20px; color:var(--text-dim); transition:transform .3s, color .3s; flex-shrink:0; }
  .faq-item.open .faq-plus{ transform:rotate(45deg); color:var(--blue); }
  .faq-body{ max-height:0; overflow:hidden; transition:max-height .35s ease; }
  .faq-body p{ padding:0 4px 22px; color:var(--text-dim); font-size:14px; line-height:1.7; }

  /* ===== BLOG ===== */
  .blog-featured{ display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:center; border:1px solid var(--line); border-radius:22px; overflow:hidden; margin-bottom:60px; }
  .blog-featured-visual{ aspect-ratio:16/11; background:linear-gradient(150deg,#0f2530,#0a0b0d); position:relative; }
  .blog-featured-visual::after{ content:''; position:absolute; inset:0; background:radial-gradient(circle at 30% 20%, rgba(25,195,243,0.22), transparent 60%); }
  .blog-featured-text{ padding:20px 40px 20px 0; }
  .blog-tag{ font-size:12px; color:var(--blue); font-weight:600; }
  .blog-featured-text h3{ font-size:clamp(22px,3vw,30px); margin:12px 0 14px; }
  .blog-featured-text p{ color:var(--text-dim); font-size:14.5px; line-height:1.7; margin-bottom:20px; }
  .blog-meta{ font-size:12.5px; color:var(--text-dimmer); }
  @media (max-width:860px){ .blog-featured{ grid-template-columns:1fr; } .blog-featured-text{ padding:0 24px 28px; } }

  .blog-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
  .blog-card{ border-radius:18px; overflow:hidden; border:1px solid var(--line); transition:transform .3s, border-color .3s; display:block; }
  .blog-card:hover{ transform:translateY(-6px); border-color:var(--blue); }
  .blog-thumb{ aspect-ratio:4/3; position:relative; }
  .blog-thumb::after{ content:''; position:absolute; inset:0; background:linear-gradient(160deg, rgba(25,195,243,0.2), transparent 60%); }
  .blog-info{ padding:18px 20px 22px; background:var(--card); }
  .blog-info h3{ font-size:18px; line-height:1.35; margin:8px 0 10px; }
  @media (max-width:860px){ .blog-grid{ grid-template-columns:repeat(2,1fr); } }
  @media (max-width:560px){ .blog-grid{ grid-template-columns:1fr; } }

  .pagination{ display:flex; justify-content:center; gap:8px; margin-top:56px; }
  .page-btn{ width:40px; height:40px; border-radius:50%; border:1px solid var(--line); display:flex; align-items:center; justify-content:center; font-size:13px; color:var(--text-dim); transition:all .2s; }
  .page-btn:hover, .page-btn.active{ border-color:var(--blue); color:var(--blue); }

  /* ===== ARTICLE / SINGLE POST ===== */
  .article-hero-visual{ aspect-ratio:21/9; border-radius:20px; border:1px solid var(--line); background:linear-gradient(150deg,#0f2530,#0a0b0d); position:relative; overflow:hidden; margin-bottom:48px; }
  .article-hero-visual::after{ content:''; position:absolute; inset:0; background:radial-gradient(circle at 30% 20%, rgba(25,195,243,0.22), transparent 60%); }
  .article-hero-visual img{ width:100%; height:100%; object-fit:cover; }
  .article-body{ max-width:720px; margin:0 auto; color:var(--text-dim); font-size:16px; line-height:1.8; }
  .article-body p{ margin-bottom:24px; }
  .article-body h2{ color:var(--text); font-size:26px; margin:44px 0 18px; }
  .article-body h3{ color:var(--text); font-size:20px; margin:34px 0 14px; }
  .article-body ul, .article-body ol{ margin:0 0 24px 22px; }
  .article-body li{ margin-bottom:10px; }
  .article-body a{ color:var(--blue); text-decoration:underline; text-underline-offset:3px; }
  .article-body img{ border-radius:14px; margin:28px 0; }
  .article-body blockquote{ border-left:2px solid var(--blue); padding-left:22px; color:var(--text); font-style:italic; margin:28px 0; }
  .article-wrap{ max-width:720px; margin:0 auto; }
  .article-meta-row{ display:flex; align-items:center; gap:14px; color:var(--text-dimmer); font-size:13px; margin-bottom:40px; }
  .article-meta-row .blog-tag{ background:var(--blue-soft); padding:5px 12px; border-radius:100px; }
  .article-nav{ display:flex; justify-content:space-between; gap:20px; max-width:720px; margin:70px auto 0; padding-top:36px; border-top:1px solid var(--line); }
  .article-nav a{ font-size:14px; color:var(--text-dim); max-width:45%; }
  .article-nav a:hover{ color:var(--blue); }
  .article-nav .next{ text-align:right; margin-left:auto; }

  /* ===== FORM NOTICES ===== */
  .form-notice{ padding:16px 20px; border-radius:12px; font-size:14px; margin-bottom:20px; }
  .form-notice.success{ background:rgba(25,195,243,0.12); border:1px solid var(--blue); color:var(--blue); }
  .form-notice.error{ background:rgba(255,90,90,0.1); border:1px solid #ff5a5a; color:#ff8888; }

  /* ===== PROJECT SINGLE ===== */
  .project-visual{ aspect-ratio:16/9; border-radius:20px; border:1px solid var(--line); background:linear-gradient(150deg,#0f2530,#0a0b0d); position:relative; overflow:hidden; margin-bottom:44px; }
  .project-visual::after{ content:''; position:absolute; inset:0; background:radial-gradient(circle at 30% 20%, rgba(25,195,243,0.22), transparent 60%); }
  .project-visual img{ width:100%; height:100%; object-fit:cover; }
  .project-meta{ display:flex; gap:32px; flex-wrap:wrap; margin:28px 0 40px; padding:24px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
  .project-meta div b{ display:block; font-size:12px; text-transform:uppercase; letter-spacing:.06em; color:var(--text-dimmer); margin-bottom:6px; }
  .project-meta div span{ font-size:15px; color:var(--text); }

  /* ===== NO RESULTS ===== */
  .no-results{ text-align:center; color:var(--text-dim); padding:60px 0; }

  /* ===== NATIVE PAGINATION STYLING ===== */
  .pagination .page-numbers{ width:40px; height:40px; border-radius:50%; border:1px solid var(--line); display:flex; align-items:center; justify-content:center; font-size:13px; color:var(--text-dim); transition:all .2s; }
  .pagination .page-numbers:hover, .pagination .page-numbers.current{ border-color:var(--blue); color:var(--blue); }
  .pagination .page-numbers.dots{ border:none; }

  /* ===== COMMENTS ===== */
  .comments-area{ color:var(--text-dim); }
  .comments-title{ font-family:var(--display); font-size:22px; color:var(--text); margin-bottom:24px; }
  .comment-list{ list-style:none; }
  .comment-list .comment{ border-top:1px solid var(--line); padding:22px 0; }
  .comment-author-name{ color:var(--text); font-weight:600; font-size:14px; }
  .comment-meta{ font-size:12px; color:var(--text-dimmer); margin-bottom:8px; }
  .comment-content p{ font-size:14px; line-height:1.7; }
  .comment-respond input[type="text"], .comment-respond input[type="email"], .comment-respond input[type="url"], .comment-respond textarea{
    width:100%; background:var(--card-2); border:1px solid var(--line); border-radius:10px; padding:13px 16px; color:var(--text); font-family:var(--body); font-size:14px; margin-bottom:14px;
  }
  .comment-respond label{ display:block; font-size:13px; color:var(--text-dim); margin-bottom:6px; }
  .comment-reply-title{ font-family:var(--display); font-size:19px; color:var(--text); margin-bottom:18px; }
