:root {
  --bg:#fafafa;--bg2:#f5f5f7;--text:#0d0b09;--muted:#6e6e73;
  --accent:#c4a35a;--accent2:#8b6914;--light:#e5e5e7;--card:#ffffff;--dark:#0d0b09;
  --cream:#f0ebe3;--gold:#c4a35a;--stone:#e5e5e7;--charcoal:#0d0b09;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:auto}
body{font-family:'Zen Kaku Gothic New',sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden;cursor:none;transition:background-color .5s ease}
::selection{background:var(--accent);color:#0d0b09}

/* CURSOR */
#cursor-dot{position:fixed;top:0;left:0;z-index:999998;width:6px;height:6px;background:#c4a35a;border-radius:50%;pointer-events:none;transform:translate(-50%,-50%);transition:width 0.2s,height 0.2s,background 0.2s,opacity 0.3s}
#cursor-ring{position:fixed;top:0;left:0;z-index:999997;width:36px;height:36px;border:1px solid rgba(196,163,90,0.4);border-radius:50%;pointer-events:none;transform:translate(-50%,-50%);transition:width 0.3s ease-out,height 0.3s ease-out,border-color 0.3s,background 0.3s,opacity 0.3s;display:flex;align-items:center;justify-content:center}
#cursor-ring .cursor-text{font-family:'Sora',sans-serif;font-size:10px;letter-spacing:3px;color:#c4a35a;text-transform:uppercase;opacity:0;transition:opacity 0.2s;pointer-events:none}
#cursor-ring.cursor-hover-link{width:90px;height:90px;border-color:transparent;background:rgba(184,150,62,0.08)}
#cursor-ring.cursor-hover-link #cursor-dot{transform:scale(0)}
#cursor-ring.cursor-hover-work{width:80px;height:80px;border-color:rgba(184,150,62,0.3);background:rgba(26,23,20,0.85)}
#cursor-ring.cursor-hover-work .cursor-text{opacity:1}
a,button,.work-img-wrap,.blog-entry,.cta-btn{cursor:none}

/* LOADER */
#loader{position:fixed;inset:0;z-index:999999;background:#0d0b09;overflow:hidden;display:flex;align-items:center;justify-content:center}
body.loader-active{overflow:hidden;position:fixed;width:100%;top:0;left:0}
.loader-title{font-family:'Sora',sans-serif;font-weight:200;line-height:1.08;letter-spacing:-0.01em;text-align:center;user-select:none;color:transparent;-webkit-text-stroke:1.3px rgba(235,239,245,0.88);font-size:9.5vw;pointer-events:none}
.loader-title-row{display:block;white-space:nowrap}
.loader-title-char{display:inline-block;clip-path:inset(100% 0 0 0);transform:translateY(22px);will-change:clip-path,transform,opacity}
@media (max-width:900px){
  .loader-title{font-size:10vw;-webkit-text-stroke:1px rgba(235,239,245,0.88)}
}
@media (max-width:420px){
  .loader-title{font-size:9vw}
}

/* NAV — Hero 上 (default) は透明背景 + 白文字、スクロール後 (light bg) は dark 文字 */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:28px 5vw;display:flex;justify-content:space-between;align-items:center;transition:all .5s cubic-bezier(.4,0,.2,1);background:transparent}
nav.scrolled{background:rgba(250,250,250,0.92);backdrop-filter:blur(20px) saturate(180%);padding:18px 5vw;border-bottom:1px solid rgba(13,11,9,0.06)}
.nav-logo{display:flex;align-items:center}
.nav-logo a{display:flex;align-items:center;color:inherit;text-decoration:none}
.nav-logo img{height:56px;width:auto;display:block;object-fit:contain;margin-right:12px;transition:height .3s ease}
nav.scrolled .nav-logo img{height:36px}
.nav-brand{font-family:'Sora',sans-serif;font-size:14px;font-weight:600;letter-spacing:2.5px;color:#f0ebe3;text-transform:uppercase;white-space:nowrap;transition:opacity .3s ease,font-size .3s ease,color .4s}
.nav-logo a:hover .nav-brand{opacity:.7}
nav.scrolled .nav-brand{font-size:12px;letter-spacing:2px;color:var(--accent2)}
.nav-links{display:flex;gap:40px}
.nav-links a{font-family:'Sora',sans-serif;font-size:13px;letter-spacing:2px;color:rgba(240,235,227,0.85);text-decoration:none;text-transform:uppercase;position:relative;transition:color .4s;font-weight:500}
.nav-links a::after{content:'';position:absolute;bottom:-6px;left:0;width:0;height:1px;background:var(--accent);transition:width .4s cubic-bezier(.4,0,.2,1)}
.nav-links a:hover{color:#fff}
.nav-links a:hover::after{width:100%}
nav.scrolled .nav-links a{color:var(--text)}
nav.scrolled .nav-links a:hover{color:var(--accent2)}

/* NAV TOGGLE (mobile hamburger) */
#navToggle{display:none;position:fixed !important;top:20px;right:20px;width:48px;height:48px;padding:0;z-index:100001 !important;background:none;border:1px solid transparent;border-radius:50%;cursor:pointer;flex-direction:column;align-items:center;justify-content:center;gap:6px;transition:border-color .3s}
.nav-toggle-bar{display:block;width:22px;height:1.5px;background:var(--text);border-radius:2px;transition:transform .4s cubic-bezier(.4,0,.2,1),opacity .4s cubic-bezier(.4,0,.2,1),background .3s ease}
#navToggle[aria-expanded="true"]{border-color:rgba(184,150,62,0.2)}
#navToggle[aria-expanded="true"] .nav-toggle-bar{background:#b8963e}
#navToggle[aria-expanded="true"] .nav-toggle-bar:nth-child(1){transform:translateY(8px) rotate(45deg)}
#navToggle[aria-expanded="true"] .nav-toggle-bar:nth-child(2){opacity:0}
#navToggle[aria-expanded="true"] .nav-toggle-bar:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* MOBILE MENU OVERLAY */
#mobileMenu{display:none;position:fixed !important;top:0 !important;left:0 !important;width:100vw !important;height:100vh !important;z-index:100000 !important;background:#1a1714 !important;flex-direction:column;align-items:center;justify-content:center;overflow:hidden}
#mobileMenu::before{content:'';position:absolute;top:-20%;left:-20%;width:60%;height:60%;background:radial-gradient(circle,rgba(184,150,62,0.06) 0%,transparent 70%);border-radius:50%;pointer-events:none}
#mobileMenu::after{content:'';position:absolute;bottom:-10%;right:-10%;width:40%;height:40%;background:radial-gradient(circle,rgba(184,150,62,0.04) 0%,transparent 70%);border-radius:50%;pointer-events:none}
#mobileMenu.open{display:flex !important}
.menu-logo{position:absolute;top:24px;left:24px;z-index:100001;opacity:0.3}
.menu-logo img{height:36px;max-height:36px;width:auto;object-fit:contain;display:block}
.menu-line-deco{position:absolute;left:40px;top:20%;height:60%;width:1px;background:linear-gradient(to bottom,transparent,rgba(184,150,62,0.15),transparent);pointer-events:none;z-index:100001}
#mobileMenu .menu-links{display:flex;flex-direction:column;align-items:flex-start;gap:28px;padding-left:60px;position:relative;z-index:100001}
#mobileMenu .menu-links a{font-family:'Cormorant Garamond',serif;font-size:28px;font-weight:300;letter-spacing:6px;color:rgba(240,235,227,0.6);text-decoration:none;text-transform:uppercase;transition:all .4s ease;position:relative;padding-left:32px;display:flex;align-items:center}
#mobileMenu .menu-links a::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);width:0;height:1px;background:#b8963e;transition:width .4s ease}
#mobileMenu .menu-links a:hover,#mobileMenu .menu-links a:active{color:#f0ebe3;letter-spacing:8px;transform:translateX(12px)}
#mobileMenu .menu-links a:hover::before,#mobileMenu .menu-links a:active::before{width:24px}
#mobileMenu .menu-sns{display:flex;gap:12px;align-items:center;position:absolute;bottom:48px;z-index:100001}
#mobileMenu .menu-sns a{font-family:'Sora',sans-serif;font-size:10px;letter-spacing:4px;color:rgba(184,150,62,0.4);text-decoration:none;text-transform:uppercase;transition:color .3s}
#mobileMenu .menu-sns a:hover{color:rgba(184,150,62,0.8)}
.menu-sns-dot{color:rgba(184,150,62,0.2);font-size:14px;line-height:1}
.nav-sns{display:none}

/* HERO (local dark theme — hero 以下は light に反転) */
.hero{min-height:100vh;display:flex;align-items:center;padding:0 5vw;position:relative;overflow:hidden;transform-style:preserve-3d;background:#0d0b09;color:#f0ebe3}
/* Hero 下端で dark → light グラデ、次セクション statement (var(--bg)) に自然に繋ぐ */
.hero::after{content:'';position:absolute;left:0;right:0;bottom:-1px;height:120px;background:linear-gradient(to bottom,transparent,#fafafa 92%);z-index:11;pointer-events:none}
.hero-content{position:relative;z-index:10;width:100%;text-align:center;transform-style:preserve-3d}
.hero-bot-wrap{position:absolute;bottom:60px;right:5vw;opacity:0;z-index:1;pointer-events:none}
.hero-shapes{position:absolute;inset:0;pointer-events:none;z-index:1}
.hero-grid{display:grid;grid-template-columns:1.1fr 0.9fr;gap:4vw;align-items:center;width:100%;max-width:1300px;margin:0 auto}
.hero-bg-letter{position:absolute;top:50%;right:-5vw;transform:translateY(-50%);font-family:'Cormorant Garamond',serif;font-size:45vw;font-weight:300;color:transparent;-webkit-text-stroke:1px rgba(240,235,227,0.03);line-height:1;pointer-events:none;user-select:none}
#hero-particles{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:0}
.hero-left{z-index:1}
.hero-label{font-family:'Sora',sans-serif;font-size:9px;letter-spacing:6px;color:var(--accent);text-transform:uppercase;margin-bottom:32px;display:flex;align-items:center;gap:16px;opacity:0;transform:translateY(20px)}
.hero-label::before{content:'';width:48px;height:1px;background:var(--accent)}
.hero-label.no-before::before{display:none}
.hero-label.no-before{gap:0}
.hero-title{font-family:'Cormorant Garamond',serif;font-size:clamp(56px,8vw,100px);font-weight:300;line-height:0.95;margin-bottom:36px;overflow:hidden;text-wrap:balance}
.hero-title .line{display:block;overflow:hidden}
.hero-title .line span{display:inline-block;transform:translateY(110%)}
.hero-title strong{font-weight:600}
.hero-title em{font-style:italic;color:var(--accent);font-weight:300}
.hero-desc{font-size:15px;color:var(--muted);line-height:2.2;margin-bottom:48px;max-width:400px;font-weight:400;opacity:0;transform:translateY(20px)}
.cta-btn{display:inline-flex;align-items:center;gap:14px;font-family:'Sora',sans-serif;font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--text);text-decoration:none;padding:20px 40px;border:1px solid rgba(196,163,90,0.3);border-radius:50px;position:relative;overflow:hidden;transition:color .5s,border-color .5s;background:transparent;-webkit-appearance:none;appearance:none;-webkit-tap-highlight-color:transparent}
.hero .cta-btn{opacity:0;transform:translateY(20px)}
.cta-btn::before{content:'';position:absolute;inset:0;background:var(--cream);transform:scaleX(0);transform-origin:right;transition:transform .6s cubic-bezier(.16,1,.3,1);border-radius:50px}
.cta-btn:hover::before{transform:scaleX(1);transform-origin:left}
.cta-btn:hover{color:#0d0b09;border-color:var(--cream)}
.cta-btn span,.cta-btn svg{position:relative;z-index:1}
.cta-btn svg{transition:transform .4s cubic-bezier(.16,1,.3,1)}
.cta-btn:hover svg{transform:translateX(6px)}

.hero-right{position:relative;z-index:1;display:flex;justify-content:center;opacity:0;transform:translateY(30px)}

/* HERO GRID PATTERN */
.hero-grid-pattern{position:absolute;inset:0;opacity:0.03;background-image:linear-gradient(to right,var(--accent) 1px,transparent 1px),linear-gradient(to bottom,var(--accent) 1px,transparent 1px);background-size:80px 80px;pointer-events:none}

/* HERO GEOMETRIC SHAPES */
.hero-shape{position:absolute;pointer-events:none;opacity:0}
.hero-shape.diamond{border:1px solid rgba(196,163,90,0.3);transform:rotate(45deg)}
.hero-shape.circle{border:1px solid rgba(196,163,90,0.2);border-radius:50%}
.hero-shape.line-shape{background:linear-gradient(90deg,transparent,rgba(196,163,90,0.3),transparent);height:1px}

/* HERO OUTLINED TEXT */
.hero-title-outlined{font-family:'Sora',sans-serif;font-weight:300;line-height:0.92;text-align:center;user-select:none;margin:0;letter-spacing:0.18em;text-shadow:0 0 32px rgba(11,14,20,0.6),0 0 8px rgba(11,14,20,0.4)}
.hero-title-outlined .bella-text{display:block;font-size:13vw;color:rgba(235,239,245,0.78);-webkit-text-stroke:2px rgba(235,239,245,0.92);opacity:0}
.hero-title-outlined .tech-text{display:block;font-size:13vw;color:rgba(218,225,234,0.72);-webkit-text-stroke:2px rgba(218,225,234,0.86);margin-top:-1.5vw;opacity:0}
@media(min-width:768px){
  .hero-title-outlined .bella-text,.hero-title-outlined .tech-text{font-size:12vw}
}

/* HERO LABEL LINE */
.hero-label-line{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:48px;opacity:0}
.hero-label-line .line-bar{width:48px;height:1px;background:var(--accent)}
.hero-label-line .label-text{font-family:'Sora',sans-serif;font-size:12px;letter-spacing:0.4em;color:var(--accent);text-transform:uppercase}

/* HERO TAGLINE */
.hero-tagline{text-align:center;font-family:'Cormorant Garamond',serif;font-weight:300;font-size:clamp(18px,2.5vw,28px);color:rgba(240,235,227,0.8);margin-top:48px;letter-spacing:0.05em;opacity:0}

/* HERO MORPH — rotating keyword */
.hero-morph{position:relative;display:block;margin-top:40px;height:20px;text-align:center;font-family:'Sora',sans-serif;font-size:13px;font-weight:300;letter-spacing:0.45em;color:rgba(196,163,90,0.82);text-transform:uppercase;opacity:0;transition:opacity 1.2s cubic-bezier(.22,1,.36,1);pointer-events:none;user-select:none}
.hero-morph.is-visible{opacity:1}
.hero-morph .morph-item{position:absolute;left:0;right:0;top:0;opacity:0;transform:translateY(14px);transition:opacity .5s ease,transform .75s cubic-bezier(.22,1,.36,1);will-change:opacity,transform}
.hero-morph .morph-item.is-active{opacity:1;transform:translateY(0)}
.hero-morph .morph-item.is-out{opacity:0;transform:translateY(-14px);transition:opacity .45s ease,transform .7s cubic-bezier(.65,0,.35,1)}
@media (max-width:600px){
  .hero-morph{margin-top:28px;font-size:11px;letter-spacing:0.35em;height:18px}
}
@media (prefers-reduced-motion:reduce){
  .hero-morph{opacity:1;transition:none}
  .hero-morph .morph-item{transition:none}
}

/* SCROLL INDICATOR */
.scroll-indicator{position:absolute;bottom:48px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:12px;opacity:0}
.scroll-indicator .scroll-text{font-family:'Sora',sans-serif;font-size:11px;letter-spacing:0.3em;color:var(--muted);text-transform:uppercase}
.scroll-indicator .scroll-line{width:1px;height:48px;background:linear-gradient(to bottom,var(--accent),transparent);animation:scrollPulse 2s ease-in-out infinite}
@keyframes scrollPulse{0%,100%{transform:scaleY(0.5);opacity:0.3}50%{transform:scaleY(1);opacity:1}}

/* NOISE TEXTURE */
.noise-overlay{position:absolute;inset:0;pointer-events:none;opacity:0.02;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* BELLA BOT ANIMATIONS */
@keyframes blink{0%,92%,100%{transform:scaleY(1)}95%{transform:scaleY(0.1)}}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes wave{0%,100%{transform:rotate(0deg)}25%{transform:rotate(-20deg)}50%{transform:rotate(10deg)}75%{transform:rotate(-10deg)}}
@keyframes readSway{0%,100%{transform:rotate(-2deg)}50%{transform:rotate(2deg)}}
@keyframes antPulse{0%,100%{opacity:0.3}50%{opacity:0.9}}
@keyframes floatSoft{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-12px) rotate(2deg)}}
.bb-blink{animation:blink 4s ease-in-out infinite;transform-origin:center}
.bb-blink2{animation:blink 4s ease-in-out infinite 2s;transform-origin:center}
.bb-bob{animation:bob 3s ease-in-out infinite}
.bb-wave{animation:wave 2s ease-in-out infinite;transform-origin:72px 62px}
.bb-read{animation:readSway 4s ease-in-out infinite}
.bb-pulse{animation:antPulse 2s ease-in-out infinite}
.bb-float{animation:floatSoft 5s ease-in-out infinite}

/* STATEMENT */
.statement-section{padding:140px 5vw;background:var(--bg);position:relative;overflow:hidden}
.statement-wrap{max-width:1100px;margin:0 auto}
.statement-layout{display:grid;grid-template-columns:1.4fr 1fr;gap:72px;align-items:center}
.statement-copy{text-align:left}
.statement-logo{display:flex;justify-content:center;align-items:center;margin-top:66px}
.statement-logo img{max-width:280px;height:auto;display:block}
@media(max-width:768px){
  .statement-layout{grid-template-columns:1fr;gap:40px}
  .statement-copy{text-align:center}
  .statement-logo{margin-top:0}
  .statement-logo img{max-width:200px}
}
.statement-eyebrow{font-family:'Sora',sans-serif;font-size:11px;letter-spacing:4px;color:var(--accent2);text-transform:uppercase;margin-bottom:32px;font-weight:600}
.statement-text{font-family:'Shippori Mincho','Noto Serif JP',serif;font-size:clamp(22px,4vw,46px);font-weight:500;line-height:1.55;letter-spacing:0.03em;color:var(--text);margin:0 auto;word-break:keep-all}
.statement-text em{font-style:normal;color:var(--accent2);font-weight:700}
.statement-sub{font-family:'Zen Kaku Gothic New',sans-serif;font-size:15px;line-height:2;color:var(--text);margin-top:40px;font-weight:400}

/* STATS */
.stats-section{padding:100px 5vw;display:flex;justify-content:center;gap:12vw;background:var(--bg2)}
.stat-item{text-align:center}
.stat-num{font-family:'Cormorant Garamond',serif;font-size:clamp(52px,7vw,80px);font-weight:400;line-height:1;display:inline-block;font-variant-numeric:tabular-nums;color:var(--text)}
.stat-suffix{font-size:0.5em;color:var(--accent2);margin-left:2px;vertical-align:top;font-weight:500}
.stat-label{font-family:'Sora',sans-serif;font-size:12px;letter-spacing:3px;text-transform:uppercase;color:var(--muted);margin-top:14px;font-weight:600}
.stat-line{width:24px;height:1px;background:var(--accent);margin:12px auto 0;opacity:0.8}

/* SECTIONS */
.sec-pad{padding:140px 5vw;position:relative}
.sec-label{font-family:'Sora',sans-serif;font-size:11px;letter-spacing:5px;text-transform:uppercase;color:var(--accent2);margin-bottom:16px;display:flex;align-items:center;gap:16px;font-weight:600}
.sec-label::before{content:'';width:48px;height:1px;background:var(--accent);opacity:0.7}
.sec-heading{font-family:'Cormorant Garamond',serif;font-size:clamp(40px,5.5vw,64px);font-weight:400;line-height:1.1;margin-bottom:80px;text-wrap:balance;color:var(--text)}
.sec-heading em{font-style:italic;color:var(--accent2);font-weight:500}

/* PHILOSOPHY */
.philosophy-section{position:relative;overflow:hidden}
.philosophy-deco{position:absolute;inset:0;pointer-events:none}
.philosophy-bg-svg{width:100%;height:100%;position:absolute;inset:0}
.philosophy-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;max-width:1100px;margin:0 auto;position:relative;z-index:1}
.philosophy-card{padding:48px 32px;background:#f5f2ed;border:1px solid rgba(196,163,90,0.15);border-radius:20px;text-align:center;color:#1a1714;transition:border-color .5s,transform .5s,box-shadow .5s}
.philosophy-card:hover{border-color:rgba(196,163,90,.3);transform:translateY(-8px) !important;box-shadow:0 20px 60px rgba(196,163,90,.08)}
.philosophy-bot{width:80px;height:80px;margin:0 auto 24px}
.philosophy-bot svg{display:block}
.philosophy-title{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:600;margin-bottom:0;line-height:1.4;text-wrap:balance;color:#1a1714}
.philosophy-line{width:32px;height:1px;background:var(--accent);margin:20px auto;opacity:0.4}
.philosophy-text{font-size:15px;color:var(--text);line-height:2.1;font-weight:400}
@media(max-width:900px){.philosophy-grid{grid-template-columns:1fr;gap:24px;max-width:480px}.philosophy-card{padding:36px 24px}}

/* PHILOSOPHY — スライダー (PC: フルスクリーン切替, モバイル: 横スクロール) */
.phi-wrap{max-width:1100px;margin:0 auto;padding:0 5vw;position:relative;z-index:1}
.phi-stage{position:relative;min-height:480px;border-radius:24px;background:linear-gradient(135deg,var(--bg2),#ebe3d0);overflow:hidden}
.phi-stage::before{content:'';position:absolute;top:-20%;right:-10%;width:60%;height:60%;background:radial-gradient(circle,rgba(196,163,90,0.22),transparent 60%);filter:blur(40px);pointer-events:none;z-index:0}
.phi-slide{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:80px 48px;opacity:0;transform:scale(0.96);transition:opacity .7s cubic-bezier(.22,1,.36,1),transform .7s cubic-bezier(.22,1,.36,1);pointer-events:none;z-index:1}
.phi-slide.is-active{opacity:1;transform:scale(1);pointer-events:auto}
.phi-num{font-family:'Cormorant Garamond',serif;font-size:clamp(100px,16vw,200px);font-weight:400;color:rgba(196,163,90,0.14);line-height:1;letter-spacing:-0.03em;position:absolute;top:20px;left:40px;pointer-events:none}
.phi-slide h3{font-family:'Cormorant Garamond',serif;font-size:clamp(32px,5.2vw,60px);color:var(--text);font-weight:500;margin:0 0 32px;line-height:1.15;text-wrap:balance;position:relative;z-index:1;max-width:18ch;letter-spacing:-0.01em}
.phi-slide p{font-size:clamp(14px,1.6vw,17px);line-height:2;color:var(--text);max-width:56ch;margin:0;position:relative;z-index:1}
.phi-controls{display:flex;align-items:center;justify-content:center;gap:32px;margin-top:40px}
.phi-prev,.phi-next{width:52px;height:52px;border-radius:50%;border:1px solid var(--light);background:var(--card);cursor:pointer;font-size:20px;color:var(--text);transition:all .3s;font-family:'Sora',sans-serif;display:flex;align-items:center;justify-content:center;padding:0}
.phi-prev:hover:not(:disabled),.phi-next:hover:not(:disabled){border-color:var(--accent);background:var(--accent);color:#fff;transform:scale(1.08)}
.phi-prev:disabled,.phi-next:disabled{opacity:.35;cursor:not-allowed}
.phi-progress{display:flex;align-items:center;gap:16px;min-width:220px;justify-content:center}
.phi-bar{width:160px;height:2px;background:var(--light);position:relative;overflow:hidden;border-radius:1px}
.phi-bar::after{content:'';position:absolute;left:0;top:0;bottom:0;width:33.33%;background:var(--accent);transition:transform .5s cubic-bezier(.22,1,.36,1);transform-origin:left}
.phi-bar.p2::after{transform:translateX(100%)}
.phi-bar.p3::after{transform:translateX(200%)}
.phi-count{font-family:'Sora',sans-serif;font-size:12px;letter-spacing:3px;color:var(--muted);font-weight:700;min-width:70px;text-align:center}
.phi-dots-mobile{display:none}

/* Mobile: 横スワイプ + scroll-snap + dots */
@media(max-width:768px){
  .phi-wrap{padding:0}
  .phi-stage{min-height:auto;background:transparent;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;display:flex;border-radius:0;padding:4px 0 20px;gap:16px}
  .phi-stage::before{display:none}
  .phi-stage::-webkit-scrollbar{display:none}
  .phi-stage{scrollbar-width:none}
  .phi-slide{position:relative;inset:auto;flex:0 0 85%;margin:0;opacity:1;transform:none;pointer-events:auto;min-height:380px;scroll-snap-align:center;border-radius:20px;background:linear-gradient(135deg,var(--bg2),#ebe3d0);padding:48px 28px;transition:none;overflow:hidden}
  .phi-slide:first-child{margin-left:7.5vw}
  .phi-slide:last-child{margin-right:7.5vw}
  .phi-slide::before{content:'';position:absolute;top:-10%;right:-10%;width:70%;height:60%;background:radial-gradient(circle,rgba(196,163,90,0.22),transparent 60%);filter:blur(30px);pointer-events:none;z-index:0}
  .phi-num{top:16px;left:24px;font-size:80px}
  .phi-slide h3{font-size:26px;margin-bottom:20px;max-width:none}
  .phi-slide p{font-size:14px;line-height:1.9}
  .phi-controls{display:none}
  .phi-dots-mobile{display:flex;justify-content:center;gap:10px;margin-top:16px;padding:0 5vw}
  .phi-dots-mobile button{width:10px;height:10px;border-radius:50%;border:none;background:var(--light);cursor:pointer;padding:0;transition:background .3s,transform .3s;appearance:none}
  .phi-dots-mobile button.is-active{background:var(--accent);transform:scale(1.4)}
}
@media(prefers-reduced-motion:reduce){
  .phi-slide{transition:none !important}
}

/* WORKS */
.works-grid{display:grid;gap:120px;max-width:1200px}
.work-card{display:grid;grid-template-columns:1.2fr 0.8fr;gap:64px;align-items:center}
.work-card:nth-child(even){grid-template-columns:0.8fr 1.2fr}
.work-card:nth-child(even) .work-thumb{order:2}
.work-card:nth-child(even) .work-info{order:1}
.work-thumb{position:relative}
.work-order{position:absolute;top:-32px;left:-20px;font-family:'Cormorant Garamond',serif;font-size:96px;font-weight:300;color:var(--accent);opacity:0.12;line-height:1;z-index:2;user-select:none}
.work-img-wrap{width:100%;aspect-ratio:4/3;border-radius:24px;overflow:hidden;position:relative;cursor:pointer;transition:transform .6s cubic-bezier(.16,1,.3,1)}
.work-img-wrap.is-distort{filter:url(#bellaDistort);will-change:filter}
@media (hover:none){.work-img-wrap.is-distort{filter:none}}
@media (prefers-reduced-motion:reduce){.work-img-wrap.is-distort{filter:none}}
.work-card:hover .work-img-wrap{transform:scale(1.05)}
.work-img-wrap::before{content:'';position:absolute;top:0;left:-120%;width:80%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.12),transparent);z-index:10;pointer-events:none;transition:left .8s cubic-bezier(.16,1,.3,1)}
.work-card:hover .work-img-wrap::before{left:140%}

/* Work screenshot overlay */
.work-screenshot{position:absolute;top:0;left:0;width:100%;height:100%;z-index:3;opacity:0;transition:opacity .5s ease;pointer-events:none}
.work-screenshot.visible{opacity:1}
.work-screenshot img{width:100%;height:100%;display:block}
.work-ss-close{position:absolute;top:8px;right:8px;width:22px;height:22px;background:rgba(0,0,0,.5);border:none;border-radius:50%;color:#fff;font-size:12px;cursor:pointer;z-index:6;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s;pointer-events:none;line-height:1}
.work-screenshot.visible+.work-ss-close{opacity:1;pointer-events:auto}
.work-hint{position:absolute;bottom:8px;right:12px;font-family:'Sora',sans-serif;font-size:9px;color:rgba(255,255,255,.5);z-index:5;pointer-events:none;letter-spacing:1px}

/* Miniature UI shared */
.mini-ui{width:100%;height:100%;position:relative;padding:0;font-family:'Sora',sans-serif;color:rgba(255,255,255,.92);display:flex;flex-direction:column;user-select:none;filter:brightness(.7);transition:filter .5s ease}
.work-card:hover .mini-ui{filter:brightness(1)}
.mini-ui *{box-sizing:border-box}
.thumb-1-bg{background:linear-gradient(135deg,#1a2a3a,#2c4050)}
.thumb-2-bg{background:linear-gradient(135deg,#1e3a2e,#2a5040)}
.thumb-3-bg{background:linear-gradient(135deg,#3a2a1a,#5a4430)}
.thumb-4-bg{background:linear-gradient(135deg,#2a1e3a,#403050)}

/* === 1. Shift Manager === */
.shift-ui{gap:0}
.shift-header{display:flex;align-items:center;gap:8px;padding:8px 12px;background:rgba(0,0,0,.2)}
.shift-line-icon{width:22px;height:22px;background:#06c755;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.shift-line-icon svg{width:14px;height:14px}
.shift-title{font-size:9px;letter-spacing:1.5px;opacity:.7;text-transform:uppercase;flex:1}
.shift-date{font-size:7px;color:rgba(184,150,62,.8);letter-spacing:1px}
.shift-table{flex:1;display:flex;flex-direction:column;gap:1px;overflow:hidden;padding:4px}
.shift-row{display:flex;gap:1px;flex:1}
.shift-cell{flex:1;background:rgba(255,255,255,.04);border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:7px;color:rgba(255,255,255,.35);position:relative;transition:background .4s,color .4s,box-shadow .4s}
.shift-cell.head{background:rgba(184,150,62,.15);color:rgba(184,150,62,.9);font-size:8px;font-weight:600;letter-spacing:1px}
.shift-cell.name{background:rgba(255,255,255,.07);color:rgba(255,255,255,.6);font-size:7px;text-align:left;padding-left:6px;flex:0 0 15%}
.shift-cell .bar{position:absolute;bottom:3px;left:12%;right:12%;height:4px;border-radius:2px;opacity:.4;transition:opacity .4s,background .4s}
.shift-cell.confirmed{background:rgba(184,150,62,.15)}
.shift-cell.confirmed .bar{opacity:.8;background:#b8963e}
.shift-cell.glow{background:rgba(184,150,62,.35);box-shadow:0 0 12px rgba(184,150,62,.6),inset 0 0 8px rgba(184,150,62,.3);color:#fff}
.shift-cell.glow .bar{opacity:1;background:#d4aa4f}
@keyframes shiftGlow{0%{box-shadow:0 0 16px rgba(184,150,62,.8),inset 0 0 10px rgba(184,150,62,.4)}100%{box-shadow:0 0 4px rgba(184,150,62,.2),inset 0 0 2px rgba(184,150,62,.1)}}
.shift-status{padding:6px 12px;display:flex;align-items:center;gap:8px;background:rgba(0,0,0,.15)}
.shift-bar-track{flex:1;height:4px;background:rgba(255,255,255,.1);border-radius:2px;overflow:hidden}
.shift-bar-fill{height:100%;background:linear-gradient(90deg,#b8963e,#d4aa4f);border-radius:2px;transition:width .8s ease}
.shift-bar-text{font-size:7px;color:rgba(255,255,255,.5);white-space:nowrap}
.shift-line-notif{position:absolute;top:12px;right:12px;background:#06c755;color:#fff;border-radius:8px;padding:5px 10px;font-size:7px;z-index:8;box-shadow:0 4px 12px rgba(6,199,85,.4);opacity:0;transform:translateX(30px);transition:opacity .4s,transform .4s;display:flex;align-items:center;gap:4px;white-space:nowrap}
.shift-line-notif.show{opacity:1;transform:translateX(0)}
.shift-line-notif .notif-icon{width:12px;height:12px;background:rgba(255,255,255,.2);border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:7px}

/* === 2. Facility Map - Globe === */
.map-ui{padding:0;flex-direction:column;position:relative}
.map-scene{width:100%;height:100%;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.map-globe{position:absolute;width:70%;aspect-ratio:1;border-radius:50%;border:1.5px solid rgba(184,150,62,.3);overflow:hidden;transition:transform 2.5s cubic-bezier(.25,.46,.45,.94),opacity 1s ease,width 2.5s cubic-bezier(.25,.46,.45,.94);box-shadow:0 0 40px rgba(184,150,62,.08),inset 0 0 30px rgba(184,150,62,.05)}
.map-globe.zoom{transform:scale(4);opacity:0;width:70%}
.map-globe-lines{position:absolute;inset:-50%;width:200%;height:200%;animation:globeSpin 12s linear infinite}
@keyframes globeSpin{0%{transform:rotateZ(0deg)}100%{transform:rotateZ(360deg)}}
.map-globe-lat,.map-globe-lon{position:absolute;border-radius:50%;border:1px solid rgba(184,150,62,.15)}
.map-globe-lat{left:10%;right:10%;height:0;border-width:0.5px}
.map-globe-lon{top:10%;bottom:10%;width:0;border-width:0.5px}
.map-globe-highlight{position:absolute;width:12px;height:12px;background:rgba(184,150,62,.5);border-radius:50%;filter:blur(4px);animation:globePulse 2s ease-in-out infinite}
@keyframes globePulse{0%,100%{opacity:.4;transform:scale(1)}50%{opacity:.8;transform:scale(1.3)}}
.map-globe-label{position:absolute;bottom:15%;left:50%;transform:translateX(-50%);font-size:8px;color:rgba(184,150,62,.6);letter-spacing:3px;text-transform:uppercase;white-space:nowrap}
.map-detail{position:absolute;inset:0;opacity:0;transition:opacity .6s ease}
.map-detail.show{opacity:1}
.map-roads{position:absolute;inset:0}
.map-road{position:absolute;background:rgba(255,255,255,.08);border-radius:1px}
.map-block{position:absolute;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.05);border-radius:3px}
.map-pin{position:absolute;transform:translate(-50%,-100%);z-index:2;opacity:0}
.map-pin.drop{animation:pinDrop .6s cubic-bezier(.34,1.56,.64,1) forwards}
@keyframes pinDrop{0%{opacity:0;transform:translate(-50%,-100%) translateY(-30px)}100%{opacity:1;transform:translate(-50%,-100%) translateY(0)}}
.map-pin-body{width:12px;height:16px;position:relative;display:flex;flex-direction:column;align-items:center}
.map-pin-head{width:12px;height:12px;background:#b8963e;border-radius:50% 50% 50% 0;transform:rotate(-45deg);border:1.5px solid rgba(255,255,255,.6);box-shadow:0 0 8px rgba(184,150,62,.5);position:relative}
.map-pin-head::after{content:'';position:absolute;top:3px;left:3px;width:4px;height:4px;background:rgba(255,255,255,.7);border-radius:50%}
.map-pin-ripple{position:absolute;bottom:-2px;left:50%;width:12px;height:12px;transform:translateX(-50%);border-radius:50%;border:1.5px solid rgba(184,150,62,.5);animation:pinRipple 2s ease-out infinite;opacity:0}
.map-pin-ripple.r2{animation-delay:.7s}
@keyframes pinRipple{0%{width:4px;height:4px;opacity:.8}100%{width:24px;height:24px;opacity:0}}
.map-popup{position:absolute;z-index:5;background:rgba(20,45,35,.95);border:1px solid rgba(184,150,62,.4);border-radius:6px;padding:6px 10px;min-width:80px;pointer-events:none;box-shadow:0 4px 16px rgba(0,0,0,.4);opacity:0;transition:opacity .3s}
.map-popup.show{opacity:1}
.map-popup::after{content:'';position:absolute;bottom:-5px;left:50%;transform:translateX(-50%);border-left:5px solid transparent;border-right:5px solid transparent;border-top:5px solid rgba(20,45,35,.95)}
.map-popup-name{font-size:8px;font-weight:600;color:rgba(255,255,255,.95);margin-bottom:2px}
.map-popup-info{font-size:7px;color:rgba(184,150,62,.9)}
.map-count{position:absolute;bottom:8px;right:10px;font-size:7px;color:rgba(255,255,255,.4);z-index:3}

/* === 3. Meal Randomizer === */
.thumb-3-bg{background:linear-gradient(135deg,#fff5ee,#fde8d8)}
.meal-ui{align-items:center;justify-content:center;gap:10px;padding:14px;position:relative}
.meal-particles{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.meal-particle{position:absolute;width:3px;height:3px;background:rgba(230,120,80,.3);border-radius:50%;animation:mealFloat 4s ease-in-out infinite}
@keyframes mealFloat{0%,100%{transform:translateY(0) scale(1);opacity:.2}50%{transform:translateY(-20px) scale(1.5);opacity:.5}}
.meal-sub{font-size:8px;color:rgba(120,80,50,.4);letter-spacing:2px;z-index:1;text-transform:uppercase}
.meal-result{width:60%;background:#fff;border-radius:14px;padding:14px;text-align:center;position:relative;overflow:hidden;border:1px solid rgba(0,0,0,.06);z-index:1;min-height:75px;display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(0,0,0,.06)}
.meal-card-inner{transition:transform .4s cubic-bezier(.4,0,.2,1),opacity .3s}
.meal-card-inner.slide-out{transform:translateY(40px);opacity:0}
.meal-card-inner.slide-in{transform:translateY(0);opacity:1}
.meal-color-bar{width:60%;height:4px;border-radius:2px;margin:0 auto 6px;transition:background .3s}
.meal-name{font-size:16px;font-weight:700;color:#2a1e14}
.meal-tags{display:flex;gap:4px;margin-top:6px;justify-content:center;flex-wrap:wrap}
.meal-tag{font-size:7px;padding:2px 8px;border-radius:8px;letter-spacing:.5px;font-weight:500}
.meal-tag-meat{background:rgba(220,60,50,.12);color:#c0392b}
.meal-tag-fish{background:rgba(50,120,200,.12);color:#2e86c1}
.meal-tag-veg{background:rgba(50,180,80,.12);color:#27ae60}
.meal-tag-quick{background:rgba(230,140,30,.12);color:#d68910}
.meal-tag-default{background:rgba(160,120,80,.1);color:#8b6914}
.meal-float-tags{position:absolute;inset:0;pointer-events:none;z-index:0}
.meal-float-tag{position:absolute;font-size:8px;font-weight:500;animation:floatTag 6s ease-in-out infinite;letter-spacing:1px}
.meal-float-tag.ft-meat{color:rgba(220,60,50,.18)}
.meal-float-tag.ft-fish{color:rgba(50,120,200,.15)}
.meal-float-tag.ft-veg{color:rgba(50,180,80,.15)}
.meal-float-tag.ft-quick{color:rgba(230,140,30,.18)}
.meal-float-tag.ft-default{color:rgba(160,120,80,.12)}
@keyframes floatTag{0%,100%{transform:translateY(0) rotate(-3deg)}50%{transform:translateY(-8px) rotate(3deg)}}
.meal-btn{width:68px;height:68px;border-radius:50%;background:linear-gradient(135deg,#e8734a,#f09060);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;box-shadow:0 6px 24px rgba(232,115,74,.35);z-index:1;animation:mealPulse 2s ease-in-out infinite;text-shadow:0 1px 2px rgba(0,0,0,.15);border:none;cursor:pointer;font-family:'Zen Kaku Gothic New',sans-serif}
@keyframes mealPulse{0%,100%{box-shadow:0 6px 24px rgba(232,115,74,.35);transform:scale(1)}50%{box-shadow:0 8px 32px rgba(232,115,74,.5);transform:scale(1.06)}}
.meal-bot{position:absolute;bottom:6px;right:6px;z-index:1;opacity:.55;pointer-events:none}

/* === 4. SEO Article Page === */
.seo-ui{flex-direction:column;padding:6px 10px;gap:0;position:relative;overflow:hidden}
.seo-article{display:flex;flex-direction:column;gap:0;flex:1;justify-content:flex-start}
.seo-row{font-size:8px;line-height:1.3;color:rgba(255,255,255,.35);padding:2px 0;transition:color .4s,background .4s,padding .4s,border-radius .4s,box-shadow .4s,border .4s,font-size .4s,margin .4s,font-weight .3s}
.seo-row.heading{font-size:11px;font-weight:600;color:rgba(255,255,255,.45);padding:3px 0 2px;border-bottom:2px solid transparent;margin-bottom:1px;transition:color .4s,border-color .4s,font-size .4s}
.seo-row.subheading{font-size:9px;font-weight:500;color:rgba(255,255,255,.38);padding:3px 0 1px;margin-top:2px}
/* Decorated states */
.seo-row.heading.dec{color:rgba(255,255,255,.95);border-bottom-color:#b8963e;font-size:12px}
.seo-row.subheading.dec{color:rgba(184,150,62,.9);font-weight:600}
.seo-row.dec-hl{color:rgba(255,255,255,.7);background:rgba(184,150,62,.1);padding:2px 4px;border-radius:2px}
.seo-row.dec-card{background:rgba(184,150,62,.06);border:1px solid rgba(184,150,62,.2);border-radius:5px;padding:5px 8px;margin:2px 0;color:rgba(255,255,255,.6);box-shadow:0 2px 8px rgba(0,0,0,.15)}
.seo-row.dec-card .seo-card-t{color:rgba(184,150,62,.95);font-weight:600;font-size:8px;display:block;margin-bottom:2px}
/* CTA */
.seo-cta-row{font-size:7px;overflow:hidden;max-height:0;opacity:0;margin:0;transition:max-height .4s cubic-bezier(.4,0,.2,1),opacity .3s,margin .3s,padding .3s;padding:0 8px;border-radius:5px;background:linear-gradient(90deg,#b8963e,#d4aa4f);color:#1a1714;font-weight:700;letter-spacing:1px;text-align:center}
.seo-cta-row.show{max-height:22px;opacity:1;margin:2px 0;padding:4px 8px}
/* Compare table */
.seo-tbl{overflow:hidden;max-height:0;opacity:0;border:1px solid transparent;border-radius:5px;margin:0;transition:max-height .5s cubic-bezier(.4,0,.2,1),opacity .3s,margin .3s,border-color .3s}
.seo-tbl.show{max-height:70px;opacity:1;margin:2px 0;border-color:rgba(184,150,62,.2)}
.seo-tbl-head{display:flex;font-size:6px;background:rgba(184,150,62,.15);font-weight:600}
.seo-tbl-head .seo-tbl-c{color:rgba(184,150,62,.9)}
.seo-tbl-r{display:flex;font-size:7px}
.seo-tbl-r:nth-child(even){background:rgba(184,150,62,.04)}
.seo-tbl-c{flex:1;padding:2px 5px;color:rgba(255,255,255,.55)}
.seo-tbl-c:first-child{color:rgba(184,150,62,.8);font-weight:600}
/* Sweep */
.seo-sweep{position:absolute;top:0;left:0;width:100%;height:0;background:linear-gradient(180deg,rgba(184,150,62,.15),transparent);pointer-events:none;z-index:5;transition:none}
.seo-sweep.flash{animation:seoSweepV .8s ease forwards}
@keyframes seoSweepV{0%{height:0;top:0;opacity:1}100%{height:100%;top:0;opacity:0}}
.work-cat{font-family:'Sora',sans-serif;font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--accent2);margin-bottom:16px;font-weight:600}
.work-name{font-family:'Cormorant Garamond',serif;font-size:30px;font-weight:600;margin-bottom:20px;line-height:1.3;text-wrap:balance;color:var(--text)}
.work-desc{font-size:14.5px;color:var(--text);line-height:2.1;margin-bottom:24px;font-weight:400}
.work-tags{display:flex;gap:8px;flex-wrap:wrap}
.work-tag{font-family:'Sora',sans-serif;font-size:11px;padding:6px 16px;border-radius:24px;border:1px solid var(--light);color:var(--muted);letter-spacing:1px;transition:all .4s;text-transform:uppercase;background:var(--bg2)}
.work-tag:hover{border-color:var(--accent);color:var(--accent2);background:rgba(196,163,90,0.08)}

/* Works section bot */
.works-bot{position:absolute;right:5vw;top:100px;opacity:0.35;pointer-events:none;z-index:1}

/* BLOG FILTER */
.blog-filter{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:40px;max-width:1000px;margin-left:auto;margin-right:auto}
.blog-filter-btn{font-family:'Sora',sans-serif;font-size:11px;letter-spacing:2px;padding:6px 18px;border-radius:24px;border:1px solid rgba(196,163,90,0.2);background:none;color:var(--text);cursor:pointer;transition:background .3s,color .3s,border-color .3s}
.blog-filter-btn:hover{border-color:var(--accent);color:var(--accent)}
.blog-filter-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.blog-entry.filter-hide{display:none !important}
@keyframes blogFadeIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.blog-entry.filter-show{animation:blogFadeIn .4s ease forwards}

/* VOICE (ghost タイポ + 引用カード) */
.voice-section{position:relative;overflow:hidden;padding:160px 5vw;text-align:center}
.voice-inner{position:relative;z-index:1;max-width:840px;margin:0 auto}
.voice-ghost{position:absolute;top:50%;left:50%;transform:translate(-50%,-52%);font-family:'Sora',sans-serif;font-weight:200;font-size:22vw;color:transparent;-webkit-text-stroke:1.5px rgba(196,163,90,0.10);letter-spacing:0.05em;line-height:1;pointer-events:none;user-select:none;white-space:nowrap;z-index:0}
.voice-section .sec-label{justify-content:center}
.voice-section .sec-label::before{width:32px}
.voice-section .sec-heading{text-align:center}
.voice-permission{margin-top:0;margin-bottom:48px;color:var(--text);font-size:14px;letter-spacing:0.5px}
.voice-card{max-width:720px;margin:0 auto;background:#fff;border:1px solid var(--light);border-radius:20px;padding:68px 56px 48px;position:relative;text-align:left;transition:box-shadow .5s,border-color .5s;box-shadow:var(--shadow-md,0 4px 12px rgba(13,11,9,0.06))}
.voice-card:hover{box-shadow:0 24px 56px rgba(13,11,9,0.08);border-color:rgba(196,163,90,0.35)}
.voice-mark{font-family:'Cormorant Garamond',serif;font-size:140px;line-height:1;color:var(--accent);opacity:0.4;position:absolute;top:8px;left:28px;user-select:none;pointer-events:none;font-weight:500}
.voice-text{font-family:'Cormorant Garamond',serif;font-size:clamp(18px,2.1vw,23px);line-height:1.95;color:var(--text);font-weight:500;margin:24px 0 40px;font-style:italic;text-wrap:pretty;position:relative;z-index:1}
.voice-meta{text-align:right;border-top:1px solid var(--border);padding-top:24px}
.voice-name{font-family:'Sora',sans-serif;font-size:12px;color:var(--accent2);font-weight:700;letter-spacing:2px;margin-bottom:8px;text-transform:uppercase}
.voice-info{font-size:13.5px;color:var(--text);line-height:1.8;letter-spacing:0.5px}
@media(max-width:768px){
  .voice-section{padding:100px 5vw}
  .voice-ghost{font-size:42vw}
  .voice-card{padding:56px 28px 40px}
  .voice-mark{font-size:96px;top:4px;left:16px}
}

/* PROCESS — 3ステップ */
.process-section{padding:140px 5vw}
.process-eyebrow{display:block;text-align:center;margin:0 auto 14px}
.process-heading{text-align:center;margin-bottom:20px}
.process-intro{max-width:44ch;margin:0 auto 80px;text-align:center;color:var(--text);font-size:15px;line-height:2;font-weight:400}
.process-list{list-style:none;padding:0;display:grid;grid-template-columns:repeat(3,1fr);gap:48px;max-width:1040px;margin:0 auto;position:relative}
.process-list::before{content:none}
.process-step{position:relative;text-align:center;padding:0 8px;z-index:1}
.process-num{display:inline-flex;align-items:center;justify-content:center;width:72px;height:72px;border-radius:50%;border:1px solid var(--accent);background:var(--bg);color:var(--accent-dark);font-family:'Cormorant Garamond',serif;font-size:28px;font-weight:500;margin:0 auto 24px;transition:background .4s cubic-bezier(.2,1,.3,1),color .4s,transform .4s,box-shadow .4s}
.process-step:hover .process-num{background:var(--accent);color:#fff;transform:translateY(-3px);box-shadow:0 10px 30px rgba(196,163,90,0.35)}
.process-name{font-family:'Sora',sans-serif;font-size:13px;font-weight:700;letter-spacing:3px;color:var(--accent-dark);margin:0 0 6px;text-transform:uppercase}
.process-jp{font-family:'Cormorant Garamond',serif;font-size:20px;color:var(--text);margin:0 0 16px;font-weight:500;letter-spacing:0.02em}
.process-text{font-size:14px;line-height:1.95;color:var(--text);max-width:32ch;margin:0 auto;font-weight:400}
@media(max-width:768px){
  .process-section{padding:96px 5vw}
  .process-list{grid-template-columns:1fr;gap:48px;max-width:420px}
  .process-list::before{display:none}
  .process-step{padding:0}
  .process-num{width:60px;height:60px;font-size:22px;margin-bottom:18px}
}

/* BLOG section (light基調) */
.blog-section{background:var(--bg2);padding:140px 5vw;position:relative}
.blog-heading{text-align:center;max-width:680px;margin:0 auto 72px}
.blog-heading .sec-label{justify-content:center}
.blog-heading .sec-label::before{width:32px}
.blog-heading .sec-heading{text-align:center}
.blog-intro{max-width:48ch;margin:0 auto;color:var(--text);font-size:15px;line-height:1.95}
.blog-section .grid{max-width:1100px;margin:0 auto}
.blog-section .card-thumb{font-size:clamp(22px,2.6vw,30px)}
.blog-bg{background:var(--bg2)}
.blog-list{max-width:1000px;margin:0 auto;position:relative;overflow:visible}
.blog-entry{display:grid;grid-template-columns:100px 1fr auto;gap:36px;padding:24px 20px;border:1px solid var(--light);cursor:pointer;position:relative;transition:opacity .5s,transform .5s,padding .5s,border-color .3s,box-shadow .5s;align-items:start;background:#fff;border-radius:12px;margin-bottom:12px;color:var(--text)}
.blog-entry::before{content:'';position:absolute;left:-24px;top:0;bottom:0;width:2px;background:var(--accent);transform:scaleY(0);transition:transform .5s cubic-bezier(.4,0,.2,1);transform-origin:top}
.blog-entry:hover{padding-left:20px;border-color:rgba(196,163,90,0.35);box-shadow:0 8px 24px rgba(13,11,9,0.06)}
.blog-entry:hover::before{transform:scaleY(1)}
.blog-date{font-family:'Cormorant Garamond',serif;font-size:15px;color:var(--text);padding-top:2px;letter-spacing:1px;font-weight:500}
.blog-cat{display:inline-block;font-family:'Sora',sans-serif;font-size:10px;letter-spacing:2px;text-transform:uppercase;color:#8b6914;background:rgba(184,150,62,0.1);padding:4px 14px;border-radius:12px;margin-bottom:10px}
.blog-title{font-size:17px;font-weight:600;line-height:1.7;text-wrap:pretty;color:#1a1714}
.blog-excerpt{font-size:14px;color:var(--text);margin-top:8px;line-height:1.9;font-weight:400}
.blog-arrow{color:#d4cdc2;transition:color .4s,transform .4s;padding-top:4px}
.blog-entry:hover .blog-arrow{color:#8b6914;transform:translateX(4px)}

/* Blog hidden & more button */
.blog-entry.blog-hidden{display:none !important}
.blog-list.expanded .blog-entry.blog-hidden{display:grid !important}
.blog-more-btn{display:inline-flex;align-items:center;gap:14px;font-family:'Sora',sans-serif;font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--text);text-decoration:none;padding:20px 40px;border:1px solid var(--light);border-radius:50px;position:relative;overflow:hidden;cursor:pointer;background:none;margin:56px auto 0;transition:color .5s,border-color .5s}
.blog-more-btn::before{content:'';position:absolute;inset:0;background:var(--cream);transform:scaleX(0);transform-origin:right;transition:transform .6s cubic-bezier(.16,1,.3,1);border-radius:50px}
.blog-more-btn:hover::before{transform:scaleX(1);transform-origin:left}
.blog-more-btn:hover{color:#0d0b09;border-color:var(--cream)}
.blog-more-btn span,.blog-more-btn svg{position:relative;z-index:1}
.blog-more-btn svg{transition:transform .4s cubic-bezier(.16,1,.3,1)}
.blog-more-btn:hover svg{transform:translateY(3px)}
.blog-more-btn.hidden{display:none}
@media(max-width:900px){.blog-entry.blog-hidden{display:none !important}.blog-list.expanded .blog-entry.blog-hidden{display:grid !important}}

/* Blog bot */
.blog-bot{position:absolute;right:-60px;bottom:60px;opacity:0.3;pointer-events:none;z-index:1}

/* CONTACT */
.contact-section{text-align:center;padding:160px 5vw;position:relative;background:var(--bg)}
.contact-section::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:1px;height:100px;background:linear-gradient(180deg,transparent,var(--accent))}
.contact-section .sec-label{justify-content:center;margin-bottom:48px}
.contact-section .sec-label::before{display:none}
.contact-section .sec-heading{margin-bottom:40px;line-height:1.4;display:block}
.contact-desc{font-size:16px;color:var(--text);line-height:2.2;margin-bottom:48px;font-weight:400}
.contact-btns{display:flex;gap:20px;justify-content:center;flex-wrap:wrap}
.cta-btn-outline{border-color:var(--accent) !important;color:var(--accent2) !important}
.cta-btn-outline::before{background:var(--accent) !important}
.cta-btn-outline:hover{color:#fff !important}
.contact-section .cta-btn.vis{opacity:1;transform:translateY(0)}
/* light 背景の Let's Talk LINE ボタン: cta-btn-shine の薄ベージュ塗りでは効きが弱いためゴールド塗りに上書き（philosophy-cta と同じ意図） */
.contact-section .cta-btn-shine:hover{color:#fff;border-color:var(--accent)}
.contact-section .cta-btn-shine:hover::before{background:var(--accent)}
.contact-note{font-size:14px;color:var(--text);margin-top:20px}
.cta-btn-shine{position:relative;overflow:hidden}
.cta-btn-shine::after{content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.25),transparent);transition:none;pointer-events:none}
.cta-btn-shine:hover::after{animation:ctaShine .6s ease forwards}
@keyframes ctaShine{0%{left:-100%}100%{left:150%}}
/* CTA button subtle pulse glow (box-shadow only, no pseudo-element conflict) */
.cta-btn-pulse{animation:btnPulse 2.5s ease-in-out infinite}
@keyframes btnPulse{0%,100%{box-shadow:0 0 0 0 rgba(184,150,62,0)}50%{box-shadow:0 0 0 6px rgba(184,150,62,0.15)}}
.contact-bot{margin:40px auto 0;opacity:0.35}

/* FOOTER */
footer{padding:48px 5vw;display:flex;flex-direction:column;align-items:center;border-top:1px solid var(--light);gap:14px;background:var(--bg)}
footer p{font-family:'Sora',sans-serif;font-size:12px;color:var(--muted);letter-spacing:3px}
.footer-links{display:flex;gap:28px}
.footer-links a{font-family:'Sora',sans-serif;font-size:12px;color:var(--muted);text-decoration:none;letter-spacing:2px;transition:color .4s}
.footer-links a:hover{color:var(--accent2)}

/* SNS FLOATING MENU (fixed bottom-right trigger + bottom bar panel) */
.nav-sns{display:none}
.sns-trigger-wrap{position:fixed;bottom:32px;right:32px;z-index:9990;transition:bottom 0.4s cubic-bezier(.16,1,.3,1)}
.sns-trigger{width:48px;height:48px;border-radius:50%;border:1px solid rgba(184,150,62,0.4);background:rgba(26,23,20,0.9);backdrop-filter:blur(8px);cursor:none;display:flex;align-items:center;justify-content:center;transition:all .4s cubic-bezier(.16,1,.3,1);position:relative;z-index:10;padding:0;box-shadow:0 4px 20px rgba(0,0,0,0.3)}
.sns-trigger:hover{border-color:#b8963e;transform:scale(1.1);box-shadow:0 4px 30px rgba(184,150,62,0.2)}
.sns-trigger-icon{display:flex;align-items:center;justify-content:center;transition:opacity .3s}
.sns-trigger-icon svg{display:block}
.sns-trigger-wrap.active{bottom:88px}
.sns-trigger-wrap.active .sns-trigger{border-color:#b8963e;transform:rotate(180deg)}
.sns-trigger-wrap.active .sns-trigger-icon{opacity:0}
.sns-trigger::before,.sns-trigger::after{content:'';position:absolute;width:16px;height:1.5px;background:#b8963e;border-radius:1px;opacity:0;transition:opacity .3s}
.sns-trigger::before{transform:rotate(45deg)}
.sns-trigger::after{transform:rotate(-45deg)}
.sns-trigger-wrap.active .sns-trigger::before,.sns-trigger-wrap.active .sns-trigger::after{opacity:1}
.sns-menu{position:fixed;bottom:0;left:0;right:0;background:rgba(13,11,9,0.95);backdrop-filter:blur(20px);display:flex;align-items:center;justify-content:center;gap:32px;padding:0;height:0;overflow:hidden;transition:height 0.4s cubic-bezier(.16,1,.3,1),padding 0.4s;z-index:9989;pointer-events:none;border-top:1px solid rgba(196,163,90,0.2)}
.sns-trigger-wrap.active .sns-menu{height:72px;padding:0 24px;pointer-events:auto}
.sns-item{position:static;width:auto;height:auto;border-radius:8px;border:none;display:flex;align-items:center;gap:10px;color:rgba(240,235,227,0.7);text-decoration:none;background:none;backdrop-filter:none;box-shadow:none;transform:none;opacity:1;font-family:'Sora',sans-serif;font-size:12px;letter-spacing:2px;text-transform:uppercase;transition:color 0.3s,background 0.3s;padding:12px 20px}
.sns-item svg{width:20px;height:20px}
.sns-trigger-wrap.active .sns-item{transform:none;opacity:1}
.sns-item:nth-child(1),.sns-item:nth-child(2),.sns-item:nth-child(3),.sns-item:nth-child(4){bottom:auto;right:auto}
.sns-item:hover{color:#f0ebe3;background:rgba(196,163,90,0.1)}
.sns-item[data-platform="x"]:hover{color:#fff;background:rgba(255,255,255,0.08)}
.sns-item[data-platform="instagram"]:hover{color:#e1306c;background:rgba(225,48,108,0.08)}
.sns-item[data-platform="note"]:hover{color:#41b349;background:rgba(65,179,73,0.08)}

/* REVEAL */
.rv{opacity:0;transform:translateY(60px);transition:opacity 1.2s cubic-bezier(.16,1,.3,1),transform 1.2s cubic-bezier(.16,1,.3,1)}
.rv.vis{opacity:1;transform:translateY(0)}
.rv-l{opacity:0;transform:translateX(-40px);transition:opacity 1.2s cubic-bezier(.16,1,.3,1),transform 1.2s cubic-bezier(.16,1,.3,1)}
.rv-l.vis{opacity:1;transform:translateX(0)}

/* RESPONSIVE */
@media(max-width:900px){
  #cursor-dot,#cursor-ring{display:none !important}body{cursor:auto}a,button,.work-img-wrap,.blog-entry,.cta-btn{cursor:auto}
  .sns-trigger-wrap{bottom:20px;right:20px}
  .sns-trigger{cursor:pointer}
  .sns-menu{gap:8px;padding:0 12px}
  .sns-item{padding:10px 12px;font-size:10px;letter-spacing:1px;cursor:pointer;gap:6px}
  .sns-item svg{width:18px;height:18px}
  nav{padding:16px 5vw}
  #navToggle{display:flex}
  .nav-links{display:none}
  .hero{padding:100px 5vw 60px}
  .hero-grid{grid-template-columns:1fr;text-align:center}
  .hero-right{margin-bottom:40px;order:-1}
  .nav-logo img{height:36px;margin-right:8px}
  .nav-brand{font-size:11px;letter-spacing:1.5px}
  .hero-desc{margin:0 auto 40px;max-width:100%}
  .hero-label{justify-content:center}.cta-btn{margin:0 auto}
  .hero-bot-wrap{display:block;bottom:24px;right:5vw}
  .hero-bot-wrap svg{width:140px;height:auto}
  .scroll-indicator{display:none}
  .sec-pad{padding:80px 5vw}
  .work-card,.work-card:nth-child(even){grid-template-columns:1fr}
  .work-card:nth-child(even) .work-thumb,.work-card:nth-child(even) .work-info{order:unset}
  .work-order{display:none}
  .works-bot,.blog-bot{display:none}
  .stats-section{gap:8vw;flex-wrap:wrap;padding:60px 5vw}
  .blog-entry{grid-template-columns:1fr;gap:8px}
  .blog-date,.blog-arrow{display:none}
  .contact-section{padding:100px 5vw}
  .contact-btns{flex-direction:column;align-items:center;gap:16px}
  .voice-permission{margin-top:-20px;margin-bottom:32px}
  footer{flex-direction:column;gap:16px}
  .footer-links{flex-wrap:wrap;justify-content:center;gap:16px}
}
@media(max-width:768px){
  .stats-section{gap:6vw;padding:48px 5vw}
  .stat-num{font-size:40px}
  .philosophy-grid{grid-template-columns:1fr;gap:20px;max-width:480px}
  .philosophy-card{padding:32px 20px}
  .blog-filter{gap:6px}
  .blog-filter-btn{padding:5px 14px;font-size:9px}
  .voice-card{padding:28px 20px}
  .voice-text{font-size:15px}
  .contact-form .form-row{grid-template-columns:1fr}
  .contact-form-wrap{margin-top:32px}
}
@media(max-width:480px){
  .hero-title{font-size:44px}
  .hero-title-outlined .bella-text,.hero-title-outlined .tech-text{font-size:17vw}
  .hero-tagline{font-size:16px;margin-top:32px}
  .sec-heading{font-size:32px;margin-bottom:48px}
  .work-name{font-size:24px}
  .works-grid{gap:64px}
  .contact-desc{font-size:14px}
  .statement-section{padding:80px 5vw}
  .statement-sub{font-size:14px;margin-top:28px}
}

/* GLOBAL PARTICLES CANVAS */
#bg-particles{position:fixed;inset:0;width:100vw;height:100vh;z-index:0;pointer-events:none}

/* GOLD DIVIDER */
.gold-divider{display:flex;align-items:center;justify-content:center;padding:32px 0;overflow:hidden}
.gold-divider-inner{display:flex;align-items:center;gap:8px;opacity:0;transition:opacity .6s ease}
.gold-divider.vis .gold-divider-inner{opacity:1}
.gold-divider-line{width:100px;height:1px;background:var(--accent);transform:scaleX(0)}
.gold-divider-dot{color:var(--accent);font-size:6px;flex-shrink:0;line-height:1}

/* WALKING BOT */
.walk-bot-wrap{position:relative;height:60px;overflow:hidden;pointer-events:none}
.walk-bot{position:absolute;top:0;left:-80px;animation:walkAcross 8s linear infinite}
@keyframes walkAcross{0%{transform:translateX(0)}100%{transform:translateX(calc(100vw + 160px))}}
.walk-bot svg{display:block}
.walk-bot-shadow{width:30px;height:6px;background:rgba(240,235,227,.06);border-radius:50%;margin:-2px auto 0}
.wb-body{animation:wbBob .4s ease-in-out infinite alternate}
@keyframes wbBob{0%{transform:translateY(0)}100%{transform:translateY(-3px)}}
.wb-arm-l{animation:wbArmL .4s ease-in-out infinite alternate;transform-origin:12px 36px}
.wb-arm-r{animation:wbArmR .4s ease-in-out infinite alternate;transform-origin:48px 36px}
@keyframes wbArmL{0%{transform:rotate(-10deg)}100%{transform:rotate(10deg)}}
@keyframes wbArmR{0%{transform:rotate(10deg)}100%{transform:rotate(-10deg)}}
.wb-leg-l{animation:wbLegL .4s ease-in-out infinite alternate;transform-origin:22px 62px}
.wb-leg-r{animation:wbLegR .4s ease-in-out infinite alternate;transform-origin:38px 62px}
@keyframes wbLegL{0%{transform:rotate(8deg)}100%{transform:rotate(-8deg)}}
@keyframes wbLegR{0%{transform:rotate(-8deg)}100%{transform:rotate(8deg)}}

/* CONTACT FORM */
.contact-divider{display:flex;align-items:center;gap:20px;margin:48px auto 0;max-width:600px}
.contact-divider::before,.contact-divider::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,transparent,rgba(196,163,90,0.35),transparent)}
.contact-divider span{font-family:'Sora',sans-serif;font-size:12px;letter-spacing:3px;text-transform:uppercase;color:var(--muted)}
.contact-form-wrap{max-width:640px;margin:40px auto 0;text-align:left}
.contact-form-heading{font-family:'Cormorant Garamond',serif;font-size:22px;color:var(--text);text-align:center;margin-bottom:32px;font-weight:500;letter-spacing:1px}
.contact-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.contact-form .form-group{margin-bottom:20px}
.contact-form label{display:block;font-family:'Sora',sans-serif;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:8px;font-weight:600}
.form-req{color:var(--accent2)}
.contact-form input,.contact-form textarea{width:100%;background:#fff;border:1px solid var(--light);border-radius:8px;padding:14px 16px;font-family:'Zen Kaku Gothic New',sans-serif;font-size:15px;color:var(--text);transition:border-color .3s,box-shadow .3s;outline:none;cursor:text}
.contact-form input::placeholder,.contact-form textarea::placeholder{color:#c0bfba}
.contact-form input:focus,.contact-form textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(196,163,90,0.15)}
.contact-form input.invalid,.contact-form textarea.invalid{border-color:#c25a5a}
.contact-form textarea{resize:vertical;min-height:120px}
.form-hp{position:absolute;left:-9999px;top:-9999px;width:1px;height:1px;overflow:hidden;opacity:0}
.contact-submit-btn{margin:12px auto 0;display:flex !important;border-color:var(--accent) !important;color:var(--accent2) !important}
.contact-submit-btn::before{background:var(--accent) !important}
.contact-submit-btn:hover{color:#fff !important}
.contact-submit-btn.sending{pointer-events:none;opacity:0.6}
.contact-success,.contact-error{text-align:center;padding:48px 20px}
.contact-success-icon{width:64px;height:64px;border-radius:50%;border:2px solid var(--accent);display:flex;align-items:center;justify-content:center;margin:0 auto 24px;font-size:28px;color:var(--accent2)}
.contact-success h3{font-family:'Cormorant Garamond',serif;font-size:24px;color:var(--text);margin-bottom:12px;font-weight:500}
.contact-success p{font-size:14.5px;color:var(--text);line-height:1.8}
.contact-error p{font-size:14px;color:#c25a5a;line-height:1.8}
.contact-error a{color:var(--accent2);text-decoration:underline}

/* SKIP LINK */
.skip-link{position:absolute;top:-100%;left:50%;transform:translateX(-50%);background:var(--accent);color:#0d0b09;padding:12px 24px;font-family:'Sora',sans-serif;font-size:12px;letter-spacing:2px;border-radius:0 0 8px 8px;z-index:10002;transition:top .3s ease}
.skip-link:focus{top:0}

/* FOCUS VISIBLE */
a:focus-visible,button:focus-visible,.cta-btn:focus-visible,.blog-entry:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}
.nav-links a:focus-visible{outline-offset:6px}
.work-tag:focus-visible{outline:2px solid var(--accent);outline-offset:2px}

/* GSAP ANIMATION SUPPORT */
.split-char{display:inline-block;backface-visibility:hidden;-webkit-backface-visibility:hidden}
.split-char-space{width:0.3em}
.mask-line{overflow:hidden;display:block}
.mask-line-inner{display:block}

/* SCROLLBAR */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--charcoal)}
::-webkit-scrollbar-thumb{background:var(--stone)}
::-webkit-scrollbar-thumb:hover{background:var(--gold)}

/* DX BANNER (dark accent — light トップ内で局所ダーク、メリハリ担当) */
.dx-banner{padding:100px 5vw;background:linear-gradient(180deg,#1a1714 0%,#0d0b09 100%);text-align:center;position:relative;overflow:hidden;color:#f0ebe3}
.dx-banner::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:80%;max-width:600px;height:1px;background:linear-gradient(90deg,transparent,rgba(196,163,90,.4),transparent)}
.dx-banner-inner{max-width:680px;margin:0 auto;position:relative;z-index:1}
.dx-banner-label{display:inline-block;font-family:'Sora',sans-serif;font-size:11px;letter-spacing:5px;color:var(--accent);text-transform:uppercase;margin-bottom:24px;padding:8px 20px;border:1px solid rgba(196,163,90,.3);border-radius:99px;font-weight:600}
.dx-banner-title{font-family:'Cormorant Garamond',serif;font-size:clamp(28px,4.5vw,44px);font-weight:400;color:#f0ebe3;line-height:1.4;margin-bottom:24px;text-wrap:balance}
.dx-banner-title em{font-style:italic;color:var(--accent)}
.dx-banner-text{font-size:15px;color:rgba(240,235,227,.7);line-height:2;margin-bottom:32px;font-weight:300}
.dx-banner-checks{display:flex;justify-content:center;gap:24px;margin-bottom:40px;flex-wrap:wrap;font-family:'Sora',sans-serif;font-size:11px;letter-spacing:1.5px;color:rgba(240,235,227,.6)}
.dx-banner-checks span{display:flex;align-items:center;gap:8px}
.dx-banner-checks span::before{content:'';width:6px;height:6px;background:var(--accent);border-radius:50%}
.dx-banner .cta-btn{border-color:var(--accent);color:var(--accent)}
.dx-banner .cta-btn:hover{color:#0d0b09}
.dx-banner-note{font-size:11px;color:rgba(240,235,227,.5);margin-top:18px;letter-spacing:.5px}
@media(max-width:768px){
  .dx-banner{padding:72px 5vw}
  .dx-banner-checks{gap:16px;font-size:10px}
}

/* REDUCED MOTION */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.01ms !important;scroll-behavior:auto !important}
  .walk-bot-wrap{display:none}
  .rv{opacity:1;transform:none}
  .rv-l{opacity:1;transform:none}
  .gold-divider-inner{opacity:1}
  .gold-divider-line{transform:scaleX(1) !important}
  .hero-title .line span{transform:none !important}
  .hero-label,.hero-desc,.cta-btn,.hero-right{opacity:1 !important;transform:none !important}
  #loader{display:none !important}
  #bg-particles,#hero-particles{display:none !important}
  .cursor,.cursor-f{display:none}
  body{cursor:auto}
}
