/*
Theme Name: TETOTE Black Flow
Theme URI: https://tetoteandco.com/
Author: TETOTE&Co.
Description: TÉTOTE&Co. BALANCE • ALIGNMENT • WELLNESS — black flow brand theme.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
Text Domain: tetote-black-flow
*/

:root{
  --black:#050505;
  --black-2:#0b0b0a;
  --ink:#111;
  --ivory:#f5f1eb;
  --ivory-2:#e8ded1;
  --gold:#d2a66d;
  --gold-2:#a9834d;
  --line:rgba(245,241,235,.16);
  --muted:rgba(245,241,235,.68);
  --shadow:0 40px 90px rgba(0,0,0,.45);
  --serif:"Times New Roman","Yu Mincho","Hiragino Mincho ProN",serif;
  --sans:-apple-system,BlinkMacSystemFont,"Helvetica Neue","Yu Gothic",Meiryo,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;background:var(--black)}
body{
  margin:0;
  background:var(--black);
  color:var(--ivory);
  font-family:var(--sans);
  overflow-x:hidden;
  letter-spacing:.02em;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}

/* Header */
.site-header{
  position:fixed;
  top:0;left:0;right:0;
  z-index:1000;
  padding:22px 4vw;
  pointer-events:none;
}
.site-header__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}
.site-brand{
  pointer-events:auto;
  font-family:var(--serif);
  font-size:22px;
  letter-spacing:.04em;
  color:var(--ivory);
}
.site-nav{pointer-events:auto;display:flex;gap:34px;align-items:center}
.site-nav a{
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(245,241,235,.78);
}
.site-nav a:hover{color:var(--gold)}
.menu-lines{width:24px;height:14px;display:inline-flex;flex-direction:column;justify-content:space-between}
.menu-lines span{height:1px;background:var(--ivory);display:block}
.admin-bar .site-header{top:32px}

/* Base sections */
.section{position:relative;padding:120px 0}
.container{width:min(1180px,88vw);margin:0 auto;position:relative}
.label{
  display:inline-flex;
  align-items:center;
  gap:18px;
  font-size:12px;
  letter-spacing:.32em;
  color:var(--gold);
  text-transform:uppercase;
}
.label::after{content:"";display:block;width:72px;height:1px;background:rgba(210,166,109,.45)}

/* Hero */
.hero{
  min-height:100vh;
  position:relative;
  overflow:hidden;
  display:flex;
  align-items:center;
  background:
    radial-gradient(circle at 25% 25%, rgba(210,166,109,.12), transparent 36%),
    radial-gradient(circle at 82% 60%, rgba(255,255,255,.045), transparent 32%),
    #050505;
}
.hero::before{
  content:"";
  position:absolute;
  inset:-20%;
  background:
    repeating-radial-gradient(ellipse at 50% 55%, rgba(210,166,109,.08) 0 1px, transparent 1px 9px);
  opacity:.38;
  transform:rotate(-12deg) scale(1.2);
  filter:blur(.4px);
  animation:flowWave 18s ease-in-out infinite alternate;
}
.hero::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.15), rgba(0,0,0,.86));
}
.hero-inner{
  position:relative;
  z-index:2;
  width:min(1180px,86vw);
  margin:0 auto;
  padding-top:80px;
}
.hero-brand{
  font-family:var(--serif);
  font-size:20px;
  letter-spacing:.06em;
  margin:0 0 46px;
  color:rgba(245,241,235,.9);
}
.hero-title{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(64px,11vw,168px);
  line-height:.86;
  letter-spacing:.04em;
  margin:0;
  color:var(--gold);
  text-transform:uppercase;
}
.hero-copy{
  margin:44px 0 0;
  font-size:clamp(22px,3vw,38px);
  font-family:var(--serif);
  letter-spacing:.16em;
  color:var(--ivory);
}
.hero-lines{
  margin-top:28px;
  color:rgba(245,241,235,.7);
  line-height:2.1;
  font-size:14px;
  letter-spacing:.18em;
}
.scroll-mark{
  position:absolute;
  left:4vw;
  bottom:6vh;
  z-index:3;
  writing-mode:vertical-rl;
  color:rgba(245,241,235,.7);
  font-size:10px;
  letter-spacing:.28em;
}
.scroll-mark::after{
  content:"";
  display:block;
  width:1px;height:70px;
  background:rgba(245,241,235,.4);
  margin:18px auto 0;
  animation:scrollLine 2.2s ease-in-out infinite;
}
.side-signature{
  position:absolute;
  right:4vw;
  bottom:11vh;
  z-index:3;
  writing-mode:vertical-rl;
  font-size:10px;
  letter-spacing:.22em;
  color:rgba(245,241,235,.65);
}

@keyframes flowWave{from{transform:translateX(-2%) rotate(-12deg) scale(1.12)}to{transform:translateX(4%) rotate(-8deg) scale(1.22)}}
@keyframes scrollLine{0%,100%{transform:scaleY(.45);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}}

/* Concept */
.concept{
  background:#f2eee7;
  color:#201b17;
  overflow:hidden;
  padding:90px 0;
}
.concept-bg-word{
  position:absolute;
  inset:auto 0 0 0;
  font-family:var(--serif);
  font-size:clamp(72px,14vw,190px);
  line-height:.82;
  color:rgba(80,70,55,.09);
  text-align:center;
  text-transform:uppercase;
  pointer-events:none;
}
.concept-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
  align-items:center;
}
.concept p{
  font-family:var(--serif);
  font-size:clamp(22px,3vw,38px);
  line-height:2;
  letter-spacing:.12em;
  margin:0;
}
.concept .small{
  font-family:var(--sans);
  font-size:14px;
  letter-spacing:.12em;
  line-height:2.4;
  color:rgba(32,27,23,.72);
}

/* Approach */
.approach{
  background:#090909;
  padding:110px 0 80px;
}
.approach-title{
  text-align:center;
  font-family:var(--serif);
  font-size:clamp(22px,3vw,34px);
  letter-spacing:.18em;
  margin:0 0 64px;
  color:var(--ivory);
}
.approach-list{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.approach-item{
  padding:42px 24px 46px;
  min-height:180px;
  border-right:1px solid var(--line);
}
.approach-item:last-child{border-right:0}
.approach-num{display:block;color:var(--gold);font-family:var(--serif);font-size:22px;margin-bottom:22px}
.approach-item h3{font-family:var(--serif);font-size:25px;letter-spacing:.18em;font-weight:400;margin:0 0 18px}
.approach-item p{font-size:13px;line-height:2;color:var(--muted);margin:0}

/* Business */
.business{
  background:#f5f1eb;
  color:#111;
  padding:0;
}
.business-head{
  padding:86px 4vw 54px;
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:40px;
}
.business-head h2{
  font-family:var(--serif);
  font-size:clamp(38px,6vw,86px);
  font-weight:400;
  letter-spacing:.08em;
  line-height:1.08;
  margin:0;
}
.flow-list{position:relative}
.flow-item{
  position:relative;
  min-height:360px;
  display:grid;
  grid-template-columns:24vw 1fr 34vw;
  border-top:1px solid rgba(17,17,17,.12);
  overflow:hidden;
  background:#f5f1eb;
}
.flow-item:nth-child(even){background:#eee8df}
.flow-num{
  font-family:var(--serif);
  font-size:clamp(108px,17vw,240px);
  color:rgba(130,100,58,.34);
  line-height:1;
  align-self:center;
  padding-left:4vw;
  will-change:transform;
}
.flow-text{align-self:center;padding:70px 4vw 70px 0;z-index:2}
.flow-text h3{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(38px,5vw,74px);
  letter-spacing:.08em;
  line-height:1;
  margin:0 0 22px;
}
.flow-lead{
  font-family:var(--serif);
  font-size:22px;
  letter-spacing:.08em;
  margin:0 0 24px;
}
.flow-list-small{list-style:none;padding:0;margin:0;color:#29231d;font-size:14px;line-height:2.1;letter-spacing:.08em}
.flow-list-small li::before{content:"・";color:var(--gold);margin-right:4px}
.flow-visual{
  position:relative;
  min-height:100%;
  overflow:hidden;
}
.flow-visual::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 60% 40%, rgba(210,166,109,.26), transparent 28%),
    linear-gradient(135deg, rgba(0,0,0,.68), rgba(0,0,0,.08));
  mix-blend-mode:multiply;
}
.flow-visual::after{
  content:"";
  position:absolute;
  inset:18% 16%;
  border:1px solid rgba(180,145,92,.28);
  transform:rotate(-8deg);
}
.flow-item:nth-child(2) .flow-visual::after{border-radius:50%;transform:rotate(12deg)}
.flow-item:nth-child(3) .flow-visual::after{transform:skewX(-10deg) rotate(4deg)}
.view-more{
  position:absolute;
  right:4vw;
  bottom:44px;
  z-index:3;
  font-size:11px;
  letter-spacing:.22em;
  color:#111;
}
.view-more::after{content:"";display:inline-block;width:58px;height:1px;background:#111;margin-left:16px;vertical-align:middle}

/* Philosophy */
.philosophy{
  background:
    linear-gradient(90deg, rgba(0,0,0,.86), rgba(0,0,0,.36)),
    radial-gradient(circle at 80% 40%, rgba(210,166,109,.18), transparent 32%),
    #090909;
  min-height:360px;
  display:flex;
  align-items:center;
}
.philosophy-inner{
  display:grid;
  grid-template-columns:220px 1fr;
  gap:80px;
  align-items:start;
}
.philosophy-copy{
  font-family:var(--serif);
  font-size:clamp(26px,4vw,46px);
  line-height:1.9;
  letter-spacing:.12em;
  margin:0;
}

/* Footer */
.site-footer{
  background:#f5f1eb;
  color:#111;
  padding:74px 4vw 38px;
}
.footer-inner{
  display:grid;
  grid-template-columns:1.5fr 2fr;
  gap:60px;
  align-items:start;
}
.footer-brand{
  font-family:var(--serif);
  color:var(--gold-2);
  font-size:30px;
  letter-spacing:.05em;
}
.footer-sub{font-size:12px;letter-spacing:.18em;margin-top:14px}
.footer-links{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;font-size:12px;line-height:2.2;letter-spacing:.12em;text-transform:uppercase}
.copyright{margin-top:60px;text-align:center;font-size:11px;color:rgba(17,17,17,.55)}

/* Animation helpers */
.reveal{opacity:0;transform:translateY(50px);transition:opacity .9s ease, transform .9s ease}
.reveal.is-visible{opacity:1;transform:translateY(0)}
.parallax-num{will-change:transform}

/* WP basics */
.screen-reader-text{position:absolute!important;clip:rect(1px,1px,1px,1px);padding:0;border:0;height:1px;width:1px;overflow:hidden}
.entry-content{width:100%}

@media(max-width:900px){
  .site-header{padding:18px 22px}.site-nav a{display:none}.site-brand{font-size:18px}
  .hero-inner{width:86vw}.hero-title{font-size:clamp(54px,15vw,88px);line-height:.95}.hero-copy{font-size:24px;line-height:1.8}.hero-lines{font-size:13px}
  .concept-grid{grid-template-columns:1fr;gap:36px}.concept{padding:74px 0}.concept-bg-word{text-align:left;left:4vw;right:auto}
  .approach-list{grid-template-columns:1fr}.approach-item{border-right:0;border-bottom:1px solid var(--line)}.approach-item:last-child{border-bottom:0}
  .business-head{display:block;padding:72px 24px 36px}.business-head h2{margin-top:18px}
  .flow-item{grid-template-columns:1fr;min-height:0;padding:0 0 40px}.flow-num{font-size:132px;padding:42px 24px 0}.flow-text{padding:8px 24px 30px}.flow-text h3{font-size:42px}.flow-lead{font-size:19px}.flow-visual{min-height:190px}.view-more{right:24px;bottom:22px}
  .philosophy-inner{grid-template-columns:1fr;gap:30px}.philosophy{padding:90px 0}.philosophy-copy{font-size:28px}
  .footer-inner{grid-template-columns:1fr}.footer-links{grid-template-columns:1fr 1fr}
}
