/*
Theme Name: 3D Scan Vision
Theme URI: https://3dscanvision.com
Author: 3D Scan Vision
Author URI: https://3dscanvision.com
Description: Profesyonel 3D tarama, metroloji ve tersine mühendislik ürünleri için hassasiyet odaklı WooCommerce uyumlu kurumsal & e-ticaret teması. Yapısal ışık / lazer tarama estetiğinden esinlenen özgün tasarım.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: scanvision
Tags: e-commerce, woocommerce, technology, industrial, custom-menu, featured-images, full-width-template, translation-ready
*/

/* =========================================================
   3D SCAN VISION — Design tokens
   Palette:  Ink #0B0E16 / Off-white #F4F6FB / Scan Blue #2563EB
             Laser Cyan #22D3EE / Slate #5B6472
   Type:     Display "Space Grotesk" · Body "Inter" · Data "IBM Plex Mono"
   Signature: yatay tarama çizgisi (scan line) + nokta bulutu (point-cloud) ızgarası
   ========================================================= */

:root{
  --ink:#0B0E16;
  --ink-2:#11151F;
  --ink-3:#171C28;
  --off:#F4F6FB;
  --off-2:#E7ECF4;
  --paper:#FFFFFF;
  --blue:#2563EB;
  --blue-600:#1D4ED8;
  --cyan:#22D3EE;
  --slate:#5B6472;
  --slate-2:#8A93A3;
  --line:rgba(11,14,22,.10);
  --line-on-dark:rgba(255,255,255,.12);
  --radius:14px;
  --radius-sm:10px;
  --maxw:1240px;
  --gut:clamp(20px,4vw,48px);
  --ff-display:"Space Grotesk",system-ui,sans-serif;
  --ff-body:"Inter",system-ui,-apple-system,sans-serif;
  --ff-mono:"IBM Plex Mono",ui-monospace,monospace;
  --shadow:0 24px 60px -28px rgba(11,14,22,.45);
  --shadow-sm:0 8px 24px -16px rgba(11,14,22,.4);
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--ff-body);
  font-size:17px;
  line-height:1.6;
  color:var(--ink);
  background:var(--off);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
h1,h2,h3,h4{font-family:var(--ff-display);font-weight:600;line-height:1.08;letter-spacing:-.02em;margin:0}
p{margin:0}

.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gut)}
.eyebrow{
  font-family:var(--ff-mono);
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--blue);
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:26px;height:2px;background:linear-gradient(90deg,var(--cyan),var(--blue));display:inline-block}
.mono{font-family:var(--ff-mono)}

/* Buttons -------------------------------------------------- */
.btn{
  display:inline-flex;align-items:center;gap:.55em;
  font-family:var(--ff-display);font-weight:500;font-size:15px;
  padding:13px 22px;border-radius:var(--radius-sm);
  border:1px solid transparent;transition:.18s ease;white-space:nowrap;
}
.btn-primary{background:var(--blue);color:#fff;box-shadow:0 10px 24px -12px var(--blue)}
.btn-primary:hover{background:var(--blue-600);transform:translateY(-2px)}
.btn-ghost{border-color:var(--line);color:var(--ink);background:transparent}
.btn-ghost:hover{border-color:var(--blue);color:var(--blue)}
.btn-ghost--ondark{border-color:var(--line-on-dark);color:#fff}
.btn-ghost--ondark:hover{border-color:var(--cyan);color:var(--cyan)}
.btn-arrow svg{width:16px;height:16px;transition:transform .18s ease}
.btn:hover .btn-arrow svg,.btn-arrow:hover svg{transform:translateX(3px)}

/* =========================================================
   Header
   ========================================================= */
.site-header{
  position:sticky;top:0;z-index:120;
  background:rgba(244,246,251,.82);
  backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid var(--line);
  transition:background .25s ease,border-color .25s ease;
}
.header-inner{display:flex;align-items:center;gap:28px;height:74px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--ff-display);font-weight:700;font-size:20px;letter-spacing:-.02em}
.brand .glyph{width:34px;height:34px;flex:0 0 auto}
.brand b{color:var(--blue)}

.main-nav{margin-left:auto}
.main-nav ul{list-style:none;display:flex;gap:4px;margin:0;padding:0}
.main-nav a{
  display:block;padding:10px 14px;border-radius:9px;
  font-size:15px;font-weight:500;color:var(--ink);transition:.16s ease;
}
.main-nav a:hover,.main-nav .current-menu-item>a{color:var(--blue);background:rgba(37,99,235,.07)}
.main-nav .menu-item-has-children>a::after{content:"";display:inline-block;width:6px;height:6px;margin-left:8px;border-right:1.6px solid currentColor;border-bottom:1.6px solid currentColor;transform:translateY(-2px) rotate(45deg);opacity:.6}

/* Sub-menu */
.main-nav .sub-menu{
  position:absolute;min-width:230px;background:var(--paper);
  border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);
  padding:8px;margin-top:10px;display:none;flex-direction:column;
}
.main-nav li{position:relative}
.main-nav li:hover>.sub-menu{display:flex}
.main-nav .sub-menu a{padding:9px 12px}

.header-actions{display:flex;align-items:center;gap:6px;margin-left:8px}
.icon-btn{
  width:42px;height:42px;display:grid;place-items:center;border-radius:10px;
  border:1px solid transparent;background:transparent;color:var(--ink);transition:.16s ease;position:relative;
}
.icon-btn:hover{background:rgba(11,14,22,.06);color:var(--blue)}
.icon-btn svg{width:21px;height:21px}
.cart-count{
  position:absolute;top:4px;right:4px;min-width:18px;height:18px;padding:0 4px;
  background:var(--blue);color:#fff;font-family:var(--ff-mono);font-size:11px;font-weight:600;
  border-radius:9px;display:grid;place-items:center;line-height:1;
}
.nav-toggle{display:none}

/* Search drawer */
.search-drawer{display:none;border-bottom:1px solid var(--line);background:var(--paper)}
.search-drawer.open{display:block}
.search-drawer .wrap{padding-block:18px}
.search-drawer form{display:flex;gap:10px}
.search-drawer input[type=search]{
  flex:1;border:1px solid var(--line);border-radius:10px;padding:13px 16px;font-size:16px;font-family:inherit;
}
.search-drawer input[type=search]:focus{outline:2px solid var(--blue);outline-offset:1px;border-color:transparent}

/* =========================================================
   Hero — signature: point-cloud grid + sweeping scan line
   ========================================================= */
.hero{
  position:relative;overflow:hidden;color:#fff;
  background:radial-gradient(120% 120% at 80% -10%,#16203a 0%,var(--ink) 55%);
}
.hero::before{ /* point-cloud dot grid */
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(rgba(120,170,255,.16) 1.3px,transparent 1.4px);
  background-size:26px 26px;
  -webkit-mask-image:radial-gradient(120% 90% at 75% 0%,#000 35%,transparent 78%);
          mask-image:radial-gradient(120% 90% at 75% 0%,#000 35%,transparent 78%);
}
.hero::after{ /* sweeping laser scan line */
  content:"";position:absolute;left:0;right:0;height:2px;top:0;
  background:linear-gradient(90deg,transparent,var(--cyan),transparent);
  box-shadow:0 0 22px 3px rgba(34,211,238,.5);
  animation:scan 7s linear infinite;opacity:.85;
}
@keyframes scan{0%{top:-2%}100%{top:102%}}

.hero-grid{position:relative;display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center;padding-block:clamp(64px,9vw,120px)}
.hero h1{font-size:clamp(38px,5.6vw,68px);font-weight:700}
.hero h1 em{font-style:normal;color:var(--cyan)}
.hero .lead{margin-top:22px;font-size:clamp(17px,2vw,20px);color:#C3CBDC;max-width:34ch}
.hero-cta{display:flex;gap:12px;margin-top:34px;flex-wrap:wrap}
.hero-trust{margin-top:40px;display:flex;gap:28px;flex-wrap:wrap;color:#9aa6bd;font-size:13px}
.hero-trust b{color:#fff;font-family:var(--ff-mono)}

/* Floating spec card */
.spec-card{
  background:rgba(255,255,255,.04);border:1px solid var(--line-on-dark);
  border-radius:18px;padding:26px;backdrop-filter:blur(6px);
}
.spec-card .sc-top{display:flex;align-items:center;justify-content:space-between;color:#9aa6bd;font-family:var(--ff-mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase}
.sc-dot{width:9px;height:9px;border-radius:50%;background:var(--cyan);box-shadow:0 0 10px var(--cyan)}
.spec-row{display:flex;justify-content:space-between;align-items:baseline;padding:16px 0;border-bottom:1px solid var(--line-on-dark)}
.spec-row:last-child{border-bottom:0;padding-bottom:0}
.spec-row .k{color:#9aa6bd;font-size:14px}
.spec-row .v{font-family:var(--ff-mono);font-size:22px;color:#fff}
.spec-row .v span{color:var(--cyan);font-size:14px}

/* =========================================================
   Sections
   ========================================================= */
.section{padding-block:clamp(64px,8vw,108px)}
.section--ink{background:var(--ink);color:#fff}
.section-head{max-width:680px;margin-bottom:48px}
.section-head h2{font-size:clamp(28px,3.6vw,44px);margin-top:14px}
.section-head p{margin-top:16px;color:var(--slate);font-size:18px}
.section--ink .section-head p{color:#9aa6bd}
.scanline{height:1px;background:linear-gradient(90deg,var(--cyan),var(--blue),transparent);border:0;margin:0}

/* Category cards */
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.cat-card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  padding:28px;transition:.2s ease;position:relative;overflow:hidden;
}
.cat-card::after{content:"";position:absolute;left:0;bottom:0;height:3px;width:0;background:linear-gradient(90deg,var(--blue),var(--cyan));transition:width .25s ease}
.cat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-sm);border-color:transparent}
.cat-card:hover::after{width:100%}
.cat-ico{width:48px;height:48px;border-radius:11px;display:grid;place-items:center;background:rgba(37,99,235,.09);color:var(--blue);margin-bottom:18px}
.cat-ico svg{width:25px;height:25px}
.cat-card h3{font-size:20px;margin-bottom:8px}
.cat-card p{color:var(--slate);font-size:15px}
.cat-card .more{margin-top:16px;display:inline-flex;align-items:center;gap:7px;color:var(--blue);font-weight:500;font-size:14px;font-family:var(--ff-display)}
.cat-card .more svg{width:15px;height:15px}

/* Industries */
.ind-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line-on-dark);border:1px solid var(--line-on-dark);border-radius:var(--radius);overflow:hidden}
.ind-item{background:var(--ink);padding:30px 26px;transition:.2s ease}
.ind-item:hover{background:var(--ink-3)}
.ind-item .num{font-family:var(--ff-mono);font-size:12px;color:var(--cyan);letter-spacing:.1em}
.ind-item h3{font-size:20px;margin:12px 0 8px;color:#fff}
.ind-item p{color:#9aa6bd;font-size:14px}

/* Stats */
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.stat .v{font-family:var(--ff-mono);font-size:clamp(34px,5vw,52px);font-weight:600;color:var(--ink);line-height:1}
.section--ink .stat .v{color:#fff}
.stat .v span{color:var(--blue);font-size:.5em}
.stat .k{margin-top:10px;color:var(--slate);font-size:14px}
.section--ink .stat .k{color:#9aa6bd}

/* Featured products row (WooCommerce shortcode container) */
.woo-featured{margin-top:8px}
.woo-featured ul.products{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;list-style:none;margin:0;padding:0}
.woo-featured ul.products li.product{margin:0;text-align:left}

/* CTA band */
.cta-band{
  position:relative;overflow:hidden;border-radius:22px;
  background:linear-gradient(120% 120% at 90% 0%,var(--blue-600),var(--ink) 70%);
  color:#fff;padding:clamp(36px,5vw,60px);
}
.cta-band::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.1) 1.2px,transparent 1.3px);background-size:24px 24px;opacity:.5}
.cta-band .inner{position:relative;display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap}
.cta-band h2{font-size:clamp(26px,3.4vw,40px);max-width:18ch}
.cta-band p{color:#cdd6ea;margin-top:10px}

/* =========================================================
   Footer
   ========================================================= */
.site-footer{background:var(--ink);color:#9aa6bd;padding-block:64px 30px;font-size:15px}
.foot-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px}
.foot-brand .brand{color:#fff;margin-bottom:16px}
.foot-brand p{max-width:34ch}
.foot-col h4{color:#fff;font-size:14px;letter-spacing:.04em;margin-bottom:16px;font-family:var(--ff-display)}
.foot-col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.foot-col a:hover{color:var(--cyan)}
.foot-news input{width:100%;background:rgba(255,255,255,.05);border:1px solid var(--line-on-dark);border-radius:9px;padding:11px 13px;color:#fff;font-family:inherit;margin-bottom:10px}
.foot-bottom{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-top:48px;padding-top:24px;border-top:1px solid var(--line-on-dark);font-size:13px}

/* =========================================================
   Generic content (page.php / single.php / WooCommerce)
   ========================================================= */
.page-hero{background:var(--ink);color:#fff;padding-block:clamp(48px,7vw,84px)}
.page-hero h1{font-size:clamp(30px,4.6vw,52px)}
.page-hero .crumbs{font-family:var(--ff-mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--cyan);margin-bottom:16px}
.content-area{padding-block:clamp(40px,6vw,72px)}
.content-area .entry-content{max-width:74ch}
.content-area .entry-content h2{margin-top:1.6em;font-size:28px}
.content-area .entry-content h3{margin-top:1.4em;font-size:22px}
.content-area .entry-content p{margin-top:1em}
.content-area .entry-content a{color:var(--blue);text-decoration:underline;text-underline-offset:3px}

/* WooCommerce buttons inherit our look */
.woocommerce a.button,.woocommerce button.button,.woocommerce .button,
.woocommerce #respond input#submit,.woocommerce input.button{
  background:var(--blue)!important;color:#fff!important;border-radius:10px!important;
  font-family:var(--ff-display)!important;font-weight:500!important;padding:12px 20px!important;border:0!important;
}
.woocommerce a.button:hover,.woocommerce button.button:hover{background:var(--blue-600)!important}
.woocommerce ul.products li.product .price{color:var(--ink);font-family:var(--ff-mono)}
.woocommerce span.onsale{background:var(--cyan)!important;color:var(--ink)!important;border-radius:8px}

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width:1024px){
  .hero-grid{grid-template-columns:1fr;gap:34px}
  .spec-card{max-width:440px}
  .cat-grid,.ind-grid{grid-template-columns:repeat(2,1fr)}
  .stat-grid{grid-template-columns:repeat(2,1fr)}
  .woo-featured ul.products{grid-template-columns:repeat(3,1fr)}
  .foot-top{grid-template-columns:1fr 1fr}
}
@media (max-width:768px){
  body{font-size:16px}
  .main-nav,.header-actions .search-open{display:none}
  .nav-toggle{display:grid}
  .main-nav.open{
    display:block;position:fixed;inset:74px 0 0;background:var(--off);
    padding:18px var(--gut);overflow:auto;z-index:115;
  }
  .main-nav.open ul{flex-direction:column;gap:2px}
  .main-nav.open a{padding:14px 12px;font-size:18px;border-bottom:1px solid var(--line)}
  .main-nav.open .sub-menu{position:static;display:flex;box-shadow:none;border:0;padding-left:14px}
  .cat-grid,.ind-grid,.stat-grid{grid-template-columns:1fr}
  .woo-featured ul.products{grid-template-columns:repeat(2,1fr)}
  .foot-top{grid-template-columns:1fr;gap:30px}
  .cta-band .inner{flex-direction:column;align-items:flex-start}
}

/* Accessibility -------------------------------------------- */
:focus-visible{outline:2px solid var(--blue);outline-offset:2px;border-radius:4px}
.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:16px;top:12px;z-index:200;background:#fff;padding:10px 16px;border-radius:8px;box-shadow:var(--shadow-sm)}
.screen-reader-text{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(1px,1px,1px,1px)}

@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .hero::after{display:none}
}
