@import url('https://fonts.googleapis.com/css2?family=Jost:wght@100;200;300;400;500&family=Zen+Kaku+Gothic+New:wght@300;400;500&family=Playfair+Display:ital,wght@0,400;0,600;1,400&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  --sky:#7EC4EC;--pink:#E8A8C8;--lav:#C0B0E4;--mint:#98DDD0;--yell:#EEE4A0;
  --deep:#68B0E4;--silver:#C4C9CE;
  --text-main:#2a2a35;--text-sub:#5a5a6e;--text-light:#8a8a9e;
  --w93:rgba(255,255,255,0.93);--w80:rgba(255,255,255,0.80);--w55:rgba(255,255,255,0.55);
}
html{scroll-behavior:smooth;}
body{
  font-family:'Jost','Zen Kaku Gothic New',sans-serif;
  font-weight:400;background:#f7f7f9;color:var(--text-main);line-height:1.9;
  overflow-x:hidden;
}

/* ── ANIMATIONS ── */
@keyframes fadeup {
  from { opacity: 0; transform: translateY(30px); }
  to { opacity: 1; transform: translateY(0); }
}
.fade-up {
  animation: fadeup 0.8s cubic-bezier(0.16, 1, 0.3, 1) both;
}
.delay-1 { animation-delay: 0.1s; }
.delay-2 { animation-delay: 0.2s; }
.delay-3 { animation-delay: 0.3s; }
.delay-4 { animation-delay: 0.4s; }

/* ── NAV ── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:20px 48px;
  display:flex;justify-content:space-between;align-items:center;
  background:rgba(247,247,249,0.92);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(0,0,0,0.05);
  transition:background 0.3s;
}
.nav-logo{
  font-family:'Jost',sans-serif;font-weight:400;font-size:20px;
  letter-spacing:0.45em;text-transform:uppercase;
  color:var(--text-main);text-decoration:none;
}
.nav-links{display:flex;gap:32px;list-style:none;}
.nav-links a{
  font-size:14px;font-weight:400;letter-spacing:0.35em;text-transform:uppercase;
  color:var(--text-sub);text-decoration:none;transition:color 0.2s;
}
.nav-links a:hover{color:var(--sky);}
@media(max-width:850px){
  nav { padding:16px 24px; overflow-x:auto; justify-content:flex-start; gap:36px; -webkit-overflow-scrolling:touch; }
  nav::-webkit-scrollbar { display:none; }
  .nav-logo { flex-shrink:0; }
  .nav-links { gap:20px; white-space:nowrap; padding:0; }
}

/* ── HERO ── */
.hero{
  position:relative;width:100%;min-height:100vh;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  overflow:hidden;text-align:center;padding:100px 24px 80px;
  background:var(--silver);
}
.hero-svg{position:absolute;inset:0;width:100%;height:100%;}
.hero-content{position:relative;z-index:2;}
.hero-eyebrow{
  font-size:11px;font-weight:400;letter-spacing:0.55em;text-transform:uppercase;
  color:var(--w93);margin-bottom:28px;
}
.hero-logo{
  font-size:clamp(24px,4.5vw,58px);font-weight:400;
  letter-spacing:0.45em;text-transform:uppercase;
  color:var(--w93);line-height:1.05;white-space:nowrap;
  text-shadow:0 1px 25px rgba(255,255,255,0.45),0 0 70px rgba(180,215,245,0.35);
}
.hero-sub{
  font-size:13px;font-weight:400;letter-spacing:0.42em;text-transform:uppercase;
  color:rgba(255,255,255,1);margin-top:18px;
}
.hero-tagline{
  font-size:clamp(15px,2.5vw,22px);font-weight:400;letter-spacing:0.12em;
  color:rgba(255,255,255,1);margin-top:24px;margin-bottom:0;
  font-family:'Zen Kaku Gothic New',sans-serif;
}
.hero-tagline-sub{
  font-size:11px;font-weight:400;letter-spacing:0.50em;text-transform:uppercase;
  color:rgba(255,255,255,1);margin-top:12px;
  font-family:'Jost',sans-serif;
}
.hero-cta{
  margin-top:40px;display:flex;gap:16px;justify-content:center;flex-wrap:wrap;
}
.btn-primary{
  padding:13px 36px;border-radius:2px;border:none;cursor:pointer;
  font-family:'Jost',sans-serif;font-size:11px;font-weight:400;letter-spacing:0.35em;text-transform:uppercase;
  background:rgba(255,255,255,0.45);color:rgba(255,255,255,1);
  border:1px solid rgba(255,255,255,0.80);
  backdrop-filter:blur(6px);
  transition:background 0.25s,box-shadow 0.25s; text-decoration:none;
}
.btn-primary:hover{background:rgba(255,255,255,0.60);box-shadow:0 8px 32px rgba(126,196,236,0.40);}
.btn-ghost{
  padding:13px 36px;border-radius:2px;cursor:pointer;
  font-family:'Jost',sans-serif;font-size:11px;font-weight:400;letter-spacing:0.35em;text-transform:uppercase;
  background:transparent;color:var(--w93);
  border:0.5px solid rgba(255,255,255,0.50); text-decoration:none;
  transition:border-color 0.25s,color 0.25s;
}
.btn-ghost:hover{border-color:rgba(255,255,255,0.55);color:var(--w93);}
.scroll-hint{
  position:absolute;bottom:32px;left:50%;transform:translateX(-50%);
  font-size:9px;letter-spacing:0.40em;text-transform:uppercase;color:rgba(255,255,255,1);z-index:2;
  animation:pulse 2.5s ease-in-out infinite;
}
@keyframes pulse{0%,100%{opacity:0.3}50%{opacity:0.75}}

/* ── DIVIDER ── */
.divider{display:flex;justify-content:center;padding:20px 0;}
.divider::after{content:'';display:block;width:40px;height:1px;background:var(--sky);}

/* ── PAGE SHELL ── */
.page{max-width:1100px;margin:0 auto;padding:100px 48px;}
@media(max-width:680px){.page{padding:70px 24px;}}
.sec-label{
  font-size:11px;font-weight:400;letter-spacing:0.60em;text-transform:uppercase;
  color:var(--text-sub);margin-bottom:12px;
}
.sec-title{
  font-size:34px;font-weight:400;letter-spacing:0.25em;color:var(--text-main);
  margin-bottom:52px;padding-bottom:20px;border-bottom:1px solid rgba(0,0,0,0.08);
}

/* ── STORE / NOTES ── */
.store-wrap{background:#2a2a35; padding:100px 48px; color:#fff;}
.note-wrap{background:#f0f2f7;padding:100px 48px;}
@media(max-width:680px){
  .store-wrap, .note-wrap{padding:70px 24px;}
}
.note-inner{max-width:1100px;margin:0 auto;}
/* MAGAZINE LAYOUT GRID */
.note-magazine-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 30px;
  margin-top: 48px;
}
.ncard {
  position: relative;
  background:#fff;border-radius:2px;
  padding:36px;box-shadow:0 2px 20px rgba(0,0,0,0.06);
  transition:box-shadow 0.4s ease, transform 0.4s ease;
  cursor:pointer;text-decoration:none;display:flex; flex-direction:column;
  height: 100%;
}
.ncard:hover{box-shadow:0 15px 44px rgba(90,120,150,0.16);transform:translateY(-8px);}
.ncard-dark {
  background:rgba(255,255,255,0.05); color:#fff; 
  border:1px solid rgba(255,255,255,0.1);
}
.ncard-dark:hover {
  background:rgba(255,255,255,0.08);
  box-shadow:0 15px 44px rgba(0,0,0,0.3);
}

.ntag{
  display:inline-block;font-size:11px;font-weight:400;letter-spacing:0.40em;text-transform:uppercase;
  padding:4px 12px;border-radius:2px;margin-bottom:22px; align-self:flex-start;
}
.ntag-blue{background:rgba(126,196,236,0.18);color:#4a96c4;}
.ntag-gold{background:rgba(212,168,48,0.15);color:#a87c20;}
.ntag-pink{background:var(--pink); color:#000;}
.ntag-sky{background:var(--sky); color:#000;}

.ncard-title{
  font-size:16px;font-weight:400;color:var(--text-sub);line-height:1.9;
  margin-bottom:16px;font-family:'Zen Kaku Gothic New',sans-serif;
}
.ncard-dark .ncard-title { color:rgba(255,255,255,0.85); }
.ncard-subtitle {
  font-size:13px; color:var(--text-light); margin-bottom:24px; font-family:'Zen Kaku Gothic New',sans-serif; flex-grow:1;
}

.ncard-footer {
  display:flex; justify-content:space-between; align-items:center;
  margin-top:auto; padding-top:20px; border-top:1px solid rgba(0,0,0,0.05);
}
.ncard-dark .ncard-footer { border-color:rgba(255,255,255,0.1); }
.ncard-arrow{font-size:12px;letter-spacing:0.25em;color:var(--text-light); transition:transform 0.3s;}
.ncard:hover .ncard-arrow { transform:translateX(5px); }

.note-cta{margin-top:44px; display:flex; gap: 20px;}
.btn-note{
  padding:13px 36px;border-radius:2px;border:none;cursor:pointer;
  font-family:'Jost',sans-serif;font-size:11px;font-weight:400;letter-spacing:0.35em;text-transform:uppercase;
  background:var(--sky);color:#fff; text-decoration:none;
  box-shadow:0 8px 30px rgba(90,140,170,0.28);
  transition:box-shadow 0.25s,transform 0.2s;
}
.btn-note:hover{box-shadow:0 14px 40px rgba(90,140,170,0.38);transform:translateY(-2px);}

.view-all-btn {
  padding:13px 36px;border-radius:2px;cursor:pointer;
  font-family:'Jost',sans-serif;font-size:11px;font-weight:400;letter-spacing:0.35em;text-transform:uppercase;
  background:transparent;color:var(--sky); text-decoration:none;
  border:0.5px solid var(--sky);
  transition:background 0.25s,color 0.25s;
}
.view-all-btn:hover { background:var(--sky); color:#fff; }
.view-all-btn-dark {
  border-color: rgba(255,255,255,0.5); color: #fff;
}
.view-all-btn-dark:hover { background: #fff; color: #000; }

/* ── SERVICES ── */
.services-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));
  gap:1px;border:1px solid rgba(0,0,0,0.07);background:rgba(0,0,0,0.07);
}
.svc-card{
  background:#fff;padding:44px 36px;
  transition:background 0.25s, transform 0.4s ease;
}
.svc-card:hover{background:#fafbff;}
.svc-num{font-size:11px;font-weight:400;letter-spacing:0.50em;color:var(--text-light);margin-bottom:28px;}
.svc-dot{width:5px;height:5px;border-radius:50%;margin-bottom:20px;}
.svc-name{font-size:16px;font-weight:400;letter-spacing:0.20em;color:var(--text-main);margin-bottom:14px;}
.svc-desc{font-size:14px;font-weight:400;color:var(--text-sub);line-height:2.0;font-family:'Zen Kaku Gothic New',sans-serif;}

/* ── ABOUT ── */
.about-grid{display:grid;grid-template-columns:1fr 1.9fr;gap:80px;align-items:center;}
@media(max-width:660px){.about-grid{grid-template-columns:1fr;gap:40px;}}
.about-avatar-wrap{aspect-ratio:1;max-width:260px;border-radius:50%;overflow:hidden;}
.about-avatar-svg{width:100%;height:100%;display:block; object-fit: cover;}
.about-label{font-size:11px;font-weight:400;letter-spacing:0.60em;text-transform:uppercase;color:var(--text-light);margin-bottom:12px;}
.about-name{font-size:clamp(24px,4vw,36px);font-weight:400;letter-spacing:0.08em;color:var(--text-main);margin-bottom:28px;line-height:1.25;}
.about-text{font-size:15px;font-weight:400;color:var(--text-sub);line-height:2.1;font-family:'Zen Kaku Gothic New',sans-serif;margin-bottom:18px;}
.about-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:28px;}
.atag{
  font-size:11px;font-weight:400;letter-spacing:0.30em;text-transform:uppercase;
  padding:6px 14px;border:0.5px solid rgba(0,0,0,0.15);border-radius:2px;
  color:var(--text-light);
}

/* ── PHILOSOPHY BAND ── */
.philosophy{
  background:var(--text-main);padding:80px 48px;text-align:center;
}
.philosophy-label{
  font-size:9px;font-weight:400;letter-spacing:0.80em;text-transform:uppercase;
  color:rgba(255,255,255,1);margin-bottom:24px;
}
.philosophy-quote{
  font-size:clamp(20px,3.5vw,32px);font-weight:400;letter-spacing:0.18em;
  color:rgba(255,255,255,1);font-family:'Zen Kaku Gothic New',sans-serif;
  margin-bottom:16px;
}
.philosophy-en{
  font-size:11px;font-weight:400;letter-spacing:0.50em;text-transform:uppercase;
  color:rgba(255,255,255,1);
}

/* ── FOOTER ── */
footer{
  background:#1a1a24;padding:64px 48px;text-align:center;
}
.footer-logo{
  font-family:'Jost',sans-serif;font-weight:400;font-size:11px;
  letter-spacing:0.55em;text-transform:uppercase;
  color:rgba(255,255,255,0.50);margin-bottom:12px;
}
.footer-links{
  display:flex;gap:28px;justify-content:center;margin-bottom:32px;flex-wrap:wrap;
}
.footer-links a{
  font-size:10px;font-weight:400;letter-spacing:0.30em;text-transform:uppercase;
  color:rgba(255,255,255,0.28);text-decoration:none;
  transition:color 0.2s;
}
.footer-links a:hover{color:rgba(255,255,255,0.70);}
.footer-copy{font-size:10px;font-weight:400;letter-spacing:0.18em;color:rgba(255,255,255,0.18);}

/* Features List (Notes Page) */
.feature-list {
  text-align: left;
  margin-top: 15px;
  margin-bottom: 20px;
  list-style: none;
  font-family: 'Zen Kaku Gothic New', sans-serif;
  font-size: 13px;
  color: var(--text-sub);
}
.ncard-dark .feature-list { color: rgba(255,255,255,0.7); }
.feature-list li {
  margin-bottom: 8px;
  padding-left: 18px;
  position: relative;
}
.feature-list li::before {
  content: '✦';
  position: absolute;
  left: 0;
  color: var(--pink);
  font-size: 0.9em;
}


/* Magazine Article Cards */
.mag-card {
  display: flex;
  flex-direction: column;
  background: rgba(255, 255, 255, 0.4);
  border: 1px solid rgba(255, 255, 255, 0.6);
  border-radius: 8px;
  overflow: hidden;
  text-decoration: none;
  color: var(--text-main);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  backdrop-filter: blur(10px);
}
.mag-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.05);
}
.mag-card-img-wrap {
  width: 100%;
  aspect-ratio: 16 / 9;
  position: relative;
  overflow: hidden;
  background: var(--silver);
}
.mag-card-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
}
.mag-card:hover .mag-card-img {
  transform: scale(1.05);
}
.mag-tag {
  position: absolute;
  top: 10px;
  left: 10px;
  font-size: 11px;
  padding: 4px 10px;
  font-family: 'Jost', sans-serif;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  z-index: 2;
  font-weight: 500;
}
.mag-card-content {
  padding: 20px;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
}
.mag-card-title {
  font-size: 15px;
  font-family: 'Zen Kaku Gothic New', sans-serif;
  font-weight: 500;
  line-height: 1.6;
  margin-bottom: 16px;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.mag-card-meta {
  margin-top: auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 11px;
  font-family: 'Jost', sans-serif;
  color: var(--text-muted);
}
.mag-author {
  font-weight: 500;
}

/* Horizontal Grid for Top Page */
.note-horizontal-grid {
  display: flex;
  gap: 24px;
  overflow-x: auto;
  padding: 20px 48px;
  scroll-snap-type: x mandatory;
  /* Hide scrollbar */
  -ms-overflow-style: none;  /* IE and Edge */
  scrollbar-width: none;  /* Firefox */
}
.note-horizontal-grid::-webkit-scrollbar {
  display: none;
}
.note-horizontal-grid .mag-card {
  min-width: 280px;
  max-width: 280px;
  flex-shrink: 0;
  scroll-snap-align: start;
}
@media (max-width: 768px) {
  .note-horizontal-grid {
    padding: 20px 24px;
  }
}

/* ── SERVICE PRICING RUNGS (Adapted) ── */
.svc-rung-list {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-top: 48px;
}
.svc-rung {
  display: grid;
  grid-template-columns: 80px 1fr;
  align-items: center;
  gap: 24px;
  padding: 32px 40px;
  border-radius: 12px;
  border: 1px solid rgba(0,0,0,0.06);
  background: #fff;
  transition: transform 0.4s ease, box-shadow 0.4s ease;
  position: relative;
  overflow: hidden;
}
.svc-rung::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 4px;
}
.sr-1::before { background: var(--sky); }
.sr-2::before { background: var(--pink); }
.sr-3::before { background: var(--lav); }
.sr-4::before { background: var(--mint); }
.svc-rung:hover {
  transform: translateX(6px);
  box-shadow: 0 15px 44px rgba(90,120,150,0.12);
}
.svc-rung-badge {
  font-family: 'Jost', sans-serif;
  font-size: 28px;
  font-weight: 300;
  color: var(--text-sub);
  opacity: 0.5;
  text-align: center;
}
.svc-rung-title {
  font-size: 18px;
  font-weight: 500;
  color: var(--text-main);
  margin-bottom: 8px;
  font-family: 'Zen Kaku Gothic New', sans-serif;
}
.svc-rung-desc {
  font-size: 14px;
  color: var(--text-sub);
  line-height: 1.8;
  font-family: 'Zen Kaku Gothic New', sans-serif;
}
.svc-rung-details {
  margin-top: 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.svc-rung-item {
  background: rgba(0,0,0,0.02);
  padding: 16px 20px;
  border-radius: 8px;
  border-left: 2px solid rgba(0,0,0,0.1);
}
.sr-1 .svc-rung-item { border-left-color: var(--sky); }
.sr-2 .svc-rung-item { border-left-color: var(--pink); }
.sr-3 .svc-rung-item { border-left-color: var(--lav); }
.sr-4 .svc-rung-item { border-left-color: var(--mint); }
.svc-item-title {
  font-size: 14px;
  font-weight: 500;
  color: var(--text-main);
  margin-bottom: 4px;
}
.svc-item-desc {
  font-size: 13px;
  color: var(--text-sub);
  line-height: 1.6;
}

/* ── CONTACT CTA ── */
.contact-cta {
  margin-top: 80px;
  padding: 60px 48px;
  text-align: center;
  background: linear-gradient(135deg, rgba(126,196,236,0.1), rgba(232,168,200,0.1));
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.6);
}
.contact-cta-title {
  font-size: 22px;
  font-weight: 400;
  color: var(--text-main);
  margin-bottom: 16px;
  font-family: 'Zen Kaku Gothic New', sans-serif;
}
.contact-cta-desc {
  font-size: 14px;
  color: var(--text-sub);
  margin-bottom: 32px;
  font-family: 'Zen Kaku Gothic New', sans-serif;
}
@media(max-width: 680px) {
  .svc-rung { grid-template-columns: 1fr; padding: 24px; gap: 16px; }
  .svc-rung-badge { text-align: left; font-size: 24px; margin-bottom: -10px; }
  .contact-cta { padding: 40px 24px; }
}
