/*
Theme Name: RIDE WORKS
Theme URI: https://rideworks.net
Author: RIDE WORKS
Description: Custom theme for RIDE WORKS car detailing studio in Fukui, Japan.
Version: 1.0.0
Text Domain: rideworks
*/

/* ═══════════════════════════════════════
   VARIABLES
═══════════════════════════════════════ */
:root {
  --bg:       #0a0a0a;
  --surf:     #141414;
  --card:     #1c1c1c;
  --border:   #2a2a2a;
  --accent:   #3fa0b5;
  --accent-d: #2b7d90;
  --accent-g: rgba(63,160,181,.08);
  --white:    #f5f5f5;
  --g1:       #cccccc;
  --g2:       #888888;
  --g3:       #444444;
  --line:     #06C755;
  --disp:     'Cormorant Garamond', 'Noto Serif JP', serif;
  --body:     'DM Sans', 'Noto Serif JP', sans-serif;
  --jp:       'Noto Serif JP', serif;
  --hh:       76px;
  --mw:       1240px;
  --ease:     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{background:var(--bg);color:var(--white);font-family:var(--body);
     line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
ul{list-style:none}
::selection{background:var(--accent);color:#000}

/* ═══════════════════════════════════════
   LAYOUT
═══════════════════════════════════════ */
.wrap{max-width:var(--mw);margin:0 auto;padding:0 48px}
section{padding:112px 0}

.lbl {
  font-family:var(--body);
  font-size:10px;font-weight:500;
  letter-spacing:.32em;text-transform:uppercase;
  color:var(--accent);
  display:flex;align-items:center;gap:14px;
  margin-bottom:18px;
}
.lbl::before{content:'';width:32px;height:1px;background:var(--accent)}

h2.sec-title {
  font-family:var(--disp);
  font-size:clamp(32px,5vw,58px);
  font-weight:300;
  line-height:1.1;
  letter-spacing:.01em;
  margin-bottom:20px;
}
h2.sec-title em{font-style:italic;color:var(--accent)}

.sec-body {
  font-size:14px;
  color:var(--g2);
  line-height:1.9;
  max-width:520px;
}
.jp-sub{
  font-family:var(--jp);
  font-size:12px;
  font-weight:300;
  letter-spacing:.2em;
  color:var(--g3);
  display:block;
  margin-top:10px;
}

/* ═══════════════════════════════════════
   HEADER
═══════════════════════════════════════ */
#hdr {
  position:fixed;top:0;left:0;right:0;z-index:100;
  height:var(--hh);
  display:flex;align-items:center;
  background:transparent;
  transition:background .4s var(--ease), border-color .4s;
  border-bottom:1px solid transparent;
}
#hdr.scrolled{
  background:rgba(10,10,10,.92);
  backdrop-filter:blur(16px);
  border-color:var(--border);
}
.hdr-inner{
  max-width:var(--mw);margin:0 auto;padding:0 48px;
  width:100%;
  display:flex;align-items:center;justify-content:space-between;gap:32px;
}

/* Logo */
.site-logo{display:flex;align-items:center}
.logo-img{width:80px;height:80px;object-fit:contain;border-radius:8px;transition:opacity .3s,transform .3s;filter:drop-shadow(0 2px 8px rgba(0,0,0,.4))}
.site-logo:hover .logo-img{transform:scale(1.05);opacity:.8}

/* Nav */
.site-nav ul{display:flex;gap:40px;align-items:center}
.site-nav a{
  font-family:var(--body);font-size:11px;font-weight:500;
  letter-spacing:.22em;text-transform:uppercase;
  color:rgba(245,245,245,.7);
  position:relative;padding-bottom:4px;
  transition:color .3s;
}
.site-nav a::after{
  content:'';position:absolute;bottom:0;left:0;
  width:0;height:1px;background:var(--accent);
  transition:width .3s var(--ease);
}
.site-nav a:hover{color:var(--white)}
.site-nav a:hover::after{width:100%}

/* Header CTAs */
.hdr-cta{display:flex;align-items:center;gap:10px}
.btn-ig{
  width:40px;height:40px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);
  color:#fff;transition:opacity .3s,transform .3s;
  box-shadow:0 2px 8px rgba(188,24,136,.35);
}
.btn-ig:hover{opacity:.85;transform:translateY(-2px)}
.btn-ig svg{width:20px;height:20px;stroke:#fff;fill:none}
.btn-line-hdr{
  display:inline-flex;align-items:center;gap:7px;
  background:var(--line);color:#fff;
  font-family:var(--body);font-size:11px;font-weight:500;
  letter-spacing:.12em;padding:9px 16px;border-radius:3px;
  transition:opacity .3s,transform .3s;
}
.btn-line-hdr:hover{opacity:.85;transform:translateY(-1px)}
.btn-line-hdr svg{width:15px;height:15px;fill:#fff}

/* ═══════════════════════════════════════
   HERO
═══════════════════════════════════════ */
#hero{
  position:relative;height:100vh;min-height:640px;
  display:flex;align-items:flex-end;
  overflow:hidden;
}
.hero-bg{position:absolute;inset:0}
.hero-slide{
  position:absolute;inset:0;
  opacity:0;
  animation:heroFade 18s infinite;
}
.hero-slide img{width:100%;height:100%;object-fit:cover;object-position:center}
.hero-slide:nth-child(1){animation-delay:0s}
.hero-slide:nth-child(2){animation-delay:6s}
.hero-slide:nth-child(3){animation-delay:12s}
@keyframes heroFade{
  0%,100%{opacity:0}
  6%{opacity:1}
  28%{opacity:1}
  34%{opacity:0}
}
.hero-bg::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(
    105deg,
    rgba(10,10,10,.88) 0%,
    rgba(10,10,10,.5)  45%,
    rgba(10,10,10,.15) 100%
  );
}
.hero-body{
  position:relative;z-index:2;
  width:100%;padding:0 48px 80px;
  max-width:calc(var(--mw) + 96px);margin:0 auto;
}
.hero-location{
  font-family:var(--body);font-size:10px;font-weight:500;
  letter-spacing:.4em;text-transform:uppercase;
  color:rgba(245,245,245,.5);
  margin-bottom:28px;
  display:flex;align-items:center;gap:12px;
}
.hero-location::before{content:'';width:28px;height:1px;background:var(--accent)}
.hero-h1{
  font-family:'Playfair Display', serif;
  font-size:clamp(52px,9vw,108px);
  font-weight:400;line-height:.95;
  letter-spacing:-.01em;
  color:var(--white);
  margin-bottom:24px;
}
.hero-h1 em{
  font-family:'Playfair Display', serif;
  font-style:normal;
  font-weight:400;
  color:var(--accent);
}
.hero-jp{
  font-family:var(--jp);
  font-size:13px;font-weight:300;
  letter-spacing:.25em;
  color:rgba(245,245,245,.4);
  margin-bottom:44px;
}
.hero-btns{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.btn-prim{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--accent);color:#000;
  font-family:var(--body);font-size:12px;font-weight:500;
  letter-spacing:.18em;text-transform:uppercase;
  padding:14px 32px;border-radius:2px;
  transition:background .3s,transform .3s;
}
.btn-prim:hover{background:var(--accent-d);transform:translateY(-2px)}
.btn-ghost{
  display:inline-flex;align-items:center;gap:10px;
  border:1px solid rgba(255,255,255,.25);color:var(--g1);
  font-family:var(--body);font-size:12px;font-weight:500;
  letter-spacing:.18em;text-transform:uppercase;
  padding:14px 32px;border-radius:2px;
  transition:border-color .3s,color .3s,transform .3s;
}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}

.hero-scroll{
  position:absolute;bottom:40px;right:48px;z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:8px;
  font-family:var(--body);font-size:9px;letter-spacing:.3em;
  color:rgba(245,245,245,.3);text-transform:uppercase;
  writing-mode:vertical-rl;
}
.hero-scroll::after{
  content:'';width:1px;height:48px;
  background:linear-gradient(to bottom,var(--accent),transparent);
  animation:sc 2s ease-in-out infinite;
}
@keyframes sc{
  0%,100%{opacity:0;transform:scaleY(0);transform-origin:top}
  50%{opacity:1;transform:scaleY(1);transform-origin:top}
}

/* ═══════════════════════════════════════
   TICKER
═══════════════════════════════════════ */
#ticker{
  background:var(--surf);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:16px 0;overflow:hidden;white-space:nowrap;
}
.ticker-track{
  display:inline-block;
  animation:tick 35s linear infinite;
  font-family:var(--disp);
  font-style:italic;font-weight:300;
  font-size:15px;letter-spacing:.08em;
  color:var(--g2);
}
.ticker-track .t-item{margin:0 32px}
.ticker-track .t-dot{color:var(--accent);margin:0 8px}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ═══════════════════════════════════════
   SERVICES
═══════════════════════════════════════ */
#services{background:var(--bg);padding:0}

.svc-hero{
  display:grid;grid-template-columns:1fr 1fr;
  min-height:520px;
}
.svc-hero-img{overflow:hidden;position:relative}
.svc-hero-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .8s var(--ease);
}
.svc-hero:hover .svc-hero-img img{transform:scale(1.04)}
.svc-hero-body{
  background:var(--surf);
  padding:72px 64px;
  display:flex;flex-direction:column;justify-content:center;
  border-bottom:1px solid var(--border);
}
.svc-num{
  font-family:var(--disp);font-size:80px;font-weight:300;
  color:var(--border);line-height:1;margin-bottom:24px;
}
.svc-name{
  font-family:var(--disp);font-size:38px;font-weight:300;
  line-height:1.1;letter-spacing:.02em;margin-bottom:6px;
}
.svc-jp-name{
  font-family:var(--jp);font-size:12px;font-weight:300;
  letter-spacing:.22em;color:var(--accent);margin-bottom:24px;
}
.svc-desc{font-size:14px;color:var(--g2);line-height:1.9;margin-bottom:32px}
.btn-svc{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--body);font-size:11px;font-weight:500;
  letter-spacing:.2em;text-transform:uppercase;
  color:var(--accent);
  border-bottom:1px solid transparent;
  transition:border-color .3s;
  align-self:flex-start;
}
.btn-svc:hover{border-color:var(--accent)}

.svc-grid3{
  display:grid;grid-template-columns:repeat(3,1fr);
}
.svc-card{
  position:relative;overflow:hidden;
  border-right:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.svc-card:last-child{border-right:none}
.svc-card-img{height:280px;overflow:hidden}
.svc-card-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .6s var(--ease),filter .6s;
  filter:brightness(.8);
}
.svc-card:hover .svc-card-img img{transform:scale(1.07);filter:brightness(.55)}
.svc-card-body{padding:32px 36px;background:var(--surf)}
.svc-card-num{
  font-family:var(--disp);font-size:11px;font-weight:300;
  letter-spacing:.3em;color:var(--accent);margin-bottom:10px;
}
.svc-card-title{
  font-family:var(--disp);font-size:24px;font-weight:300;
  letter-spacing:.02em;margin-bottom:4px;
}
.svc-card-jp{
  font-family:var(--jp);font-size:11px;font-weight:300;
  letter-spacing:.18em;color:var(--g3);margin-bottom:14px;
}
.svc-card-desc{font-size:13px;color:var(--g2);line-height:1.8}

.svc-wide{
  display:grid;grid-template-columns:1fr 1fr;
  border-top:1px solid var(--border);
}
.svc-wide-img{overflow:hidden;min-height:320px}
.svc-wide-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.svc-wide:hover .svc-wide-img img{transform:scale(1.04)}
.svc-wide-body{
  background:var(--surf);
  padding:56px 64px;
  display:flex;flex-direction:column;justify-content:center;
  border-left:1px solid var(--border);
}

/* ═══════════════════════════════════════
   ABOUT
═══════════════════════════════════════ */
#about{
  background:var(--surf);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:0;
}
.about-grid{display:grid;grid-template-columns:1fr 1fr;min-height:640px}
.about-img{overflow:hidden;position:relative}
.about-img img{width:100%;height:100%;object-fit:cover}
.about-img::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to right,transparent 70%,var(--surf));
}
.about-body{
  padding:80px 72px;
  display:flex;flex-direction:column;justify-content:center;
}
.about-feats{margin-top:40px;display:flex;flex-direction:column;gap:0}
.about-feat{
  display:flex;align-items:flex-start;gap:20px;
  padding:24px 0;border-bottom:1px solid var(--border);
}
.about-feat:last-child{border:none}
.feat-dot{
  width:2px;height:2px;border-radius:50%;
  background:var(--accent);margin-top:10px;flex-shrink:0;
}
.feat-title{
  font-family:var(--disp);font-size:16px;font-weight:400;
  letter-spacing:.04em;margin-bottom:4px;
}
.feat-desc{font-size:13px;color:var(--g2);line-height:1.8}

/* ═══════════════════════════════════════
   GALLERY
═══════════════════════════════════════ */
#gallery{background:var(--bg)}
.gal-head{
  display:flex;align-items:flex-end;
  justify-content:space-between;
  flex-wrap:wrap;gap:20px;
  margin-bottom:48px;
}
.btn-all{
  font-family:var(--body);font-size:11px;font-weight:500;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--accent);
  display:flex;align-items:center;gap:8px;
  border-bottom:1px solid transparent;
  transition:border-color .3s;
}
.btn-all:hover{border-color:var(--accent)}
.gal-masonry{column-count:3;column-gap:3px}
.gal-item{
  break-inside:avoid;margin-bottom:3px;
  position:relative;overflow:hidden;display:block;
}
.gal-item img{
  width:100%;display:block;
  transition:transform .5s var(--ease),filter .5s;
  filter:brightness(.88);
}
.gal-item:hover img{transform:scale(1.06);filter:brightness(.5)}
.gal-over{
  position:absolute;inset:0;
  display:flex;align-items:flex-end;padding:20px;
  opacity:0;transition:opacity .3s;
}
.gal-item:hover .gal-over{opacity:1}
.gal-tag{
  font-family:var(--body);font-size:10px;font-weight:500;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--accent);
  border-bottom:1px solid var(--accent);padding-bottom:2px;
}

/* ═══════════════════════════════════════
   CTA BAND
═══════════════════════════════════════ */
#cta{
  background:var(--surf);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:96px 0;text-align:center;
  position:relative;overflow:hidden;
}
#cta::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 50% 50%,rgba(63,160,181,.06) 0%,transparent 70%);
}
.cta-inner{max-width:680px;margin:0 auto;padding:0 48px;position:relative}
.cta-h2{
  font-family:var(--disp);
  font-size:clamp(36px,6vw,72px);
  font-weight:300;font-style:italic;
  line-height:1.05;letter-spacing:.01em;margin-bottom:12px;
}
.cta-jp{
  font-family:var(--jp);font-size:13px;font-weight:300;
  letter-spacing:.22em;color:var(--g3);margin-bottom:44px;
}
.cta-btns{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap}
.btn-line-lg{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--line);color:#fff;
  font-family:var(--body);font-size:12px;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;
  padding:15px 36px;border-radius:2px;
  transition:opacity .3s,transform .3s;
}
.btn-line-lg:hover{opacity:.85;transform:translateY(-2px)}
.btn-line-lg svg{width:18px;height:18px;fill:#fff}
.btn-tel{
  display:inline-flex;align-items:center;gap:8px;
  border:1px solid var(--border);color:var(--g1);
  font-family:var(--body);font-size:12px;font-weight:500;
  letter-spacing:.12em;padding:15px 28px;border-radius:2px;
  transition:border-color .3s,color .3s,transform .3s;
}
.btn-tel:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}

/* ═══════════════════════════════════════
   NEWS
═══════════════════════════════════════ */
#news{background:var(--bg)}
.news-list{border-top:1px solid var(--border);margin-top:48px}
.news-item{
  display:grid;
  grid-template-columns:160px 100px 1fr 24px;
  align-items:center;gap:32px;
  padding:24px 0;border-bottom:1px solid var(--border);
  transition:color .3s;cursor:pointer;
}
.news-item:hover{color:var(--accent)}
.n-date{font-family:var(--body);font-size:12px;color:var(--g3);letter-spacing:.06em}
.n-cat{
  font-family:var(--body);font-size:10px;font-weight:500;
  letter-spacing:.2em;text-transform:uppercase;
  color:var(--accent);background:var(--accent-g);
  border:1px solid rgba(63,160,181,.2);
  padding:4px 12px;border-radius:2px;white-space:nowrap;justify-self:start;
}
.n-title{font-size:14px;font-weight:300;line-height:1.5}
.n-arr{color:var(--g3);transition:color .3s,transform .3s;font-size:14px}
.news-item:hover .n-arr{color:var(--accent);transform:translateX(4px)}

/* ═══════════════════════════════════════
   ACCESS
═══════════════════════════════════════ */
#access{background:var(--surf);border-top:1px solid var(--border)}
.access-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;margin-top:56px}
.info-table{width:100%;border-collapse:collapse}
.info-table tr{border-bottom:1px solid var(--border)}
.info-table th{
  font-family:var(--body);font-size:10px;font-weight:500;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--g3);text-align:left;padding:18px 0;width:100px;vertical-align:top;
}
.info-table td{font-size:14px;font-weight:300;color:var(--g1);padding:18px 0 18px 24px;line-height:1.7}
.info-table a{color:var(--accent);transition:opacity .3s}
.info-table a:hover{opacity:.75}
.access-map{aspect-ratio:4/3;overflow:hidden;border:1px solid var(--border)}
.access-map iframe{width:100%;height:100%;border:0;filter:invert(92%) hue-rotate(180deg) brightness(.85)}
.access-note{font-size:12px;color:var(--g3);margin-top:12px;letter-spacing:.04em}

/* ═══════════════════════════════════════
   FOOTER
═══════════════════════════════════════ */
#footer{background:#050505;border-top:1px solid var(--border);padding:56px 0 32px}
.footer-inner{display:grid;grid-template-columns:1fr auto;gap:48px;align-items:start;margin-bottom:48px}
.footer-logo{margin-bottom:16px}
.footer-logo img{width:52px;height:52px;object-fit:contain;border-radius:6px;opacity:.85}
.footer-desc{font-size:13px;color:var(--g3);line-height:1.85;max-width:340px}
.footer-contact{font-size:13px;color:var(--g3);margin-top:14px;line-height:1.9}
.footer-contact a{color:var(--g2);transition:color .3s}
.footer-contact a:hover{color:var(--accent)}
.footer-nav{display:flex;flex-direction:column;gap:14px;align-items:flex-end}
.footer-nav a{
  font-family:var(--body);font-size:11px;font-weight:500;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--g3);transition:color .3s;
}
.footer-nav a:hover{color:var(--accent)}
.footer-bottom{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:28px;border-top:1px solid var(--border);flex-wrap:wrap;gap:14px;
}
.footer-copy{font-family:var(--body);font-size:11px;color:var(--g3);letter-spacing:.1em}
.footer-soc{display:flex;gap:10px}
.footer-soc a{
  width:34px;height:34px;border:1px solid var(--border);
  border-radius:2px;display:flex;align-items:center;justify-content:center;
  color:var(--g3);transition:color .3s,border-color .3s;
}
.footer-soc a:hover{color:var(--accent);border-color:var(--accent)}
.footer-soc svg{width:15px;height:15px}

/* ═══════════════════════════════════════
   LINE FLOAT
═══════════════════════════════════════ */
#lf{
  position:fixed;bottom:28px;right:28px;z-index:900;
  display:flex;flex-direction:column;align-items:center;gap:6px;
}
.lf-btn{
  width:56px;height:56px;background:var(--line);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 20px rgba(6,199,85,.4);
  transition:transform .3s,box-shadow .3s;
}
.lf-btn:hover{transform:translateY(-3px) scale(1.06);box-shadow:0 8px 28px rgba(6,199,85,.5)}
.lf-btn svg{width:27px;height:27px;fill:#fff}
.lf-lbl{font-family:var(--body);font-size:9px;font-weight:500;
         letter-spacing:.15em;color:var(--line);text-transform:uppercase;
         text-shadow:0 1px 4px rgba(0,0,0,.8)}

/* ═══════════════════════════════════════
   ANIMATIONS
═══════════════════════════════════════ */
.fu{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.fu.vis{opacity:1;transform:translateY(0)}
.fu.d1{transition-delay:.1s}.fu.d2{transition-delay:.2s}.fu.d3{transition-delay:.3s}

/* ═══════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════ */
@media(max-width:1024px){
  .wrap{padding:0 28px}
  .hdr-inner{padding:0 28px}
  .hero-body{padding:0 28px 64px}
  .svc-hero,.svc-wide,.about-grid,.access-grid{grid-template-columns:1fr}
  .svc-grid3{grid-template-columns:1fr 1fr}
  .svc-hero-body,.about-body,.svc-wide-body{padding:48px 36px}
  .gal-masonry{column-count:2}
}
@media(max-width:768px){
  :root{--hh:60px}
  section{padding:72px 0}
  .site-nav{display:none}
  .svc-grid3{grid-template-columns:1fr}
  .gal-masonry{column-count:2}
  .news-item{grid-template-columns:1fr;gap:8px}
  .n-arr{display:none}
  .footer-inner{grid-template-columns:1fr}
  .footer-nav{align-items:flex-start}
}
