/* Oiii Marketing — 共用樣式（index.html + reels.html） */
:root{
  --bg:#E3E1DC; --surface:#EDEBE6; --card:#FAF9F6;
  --ink:#26241F; --ink-soft:#5A574F; --line:#CFCCC4;
  --accent:#5E7370; --accent-soft:#93A5A3;
  --dark:#26241F; --dark-text:#E9E7E1;
  --serif:'Noto Serif TC',serif; --sans:'Noto Sans TC',sans-serif;
  --ease:cubic-bezier(.2,.6,.2,1); --dur:.7s; --dur-fast:.35s;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:var(--sans);font-weight:300;line-height:1.9;font-size:16px}

/* 進場：柔和浮現（2026-07-05 April 修訂——唔要 bounce，唔要成頁一樣咁跳）
   - 標題/內文：fade-up 22px
   - .soft（manifesto 句子等）：純 fade，唔郁位
   - stagger 靠 .d1/.d2/.d3 */
.reveal{opacity:0;transform:translateY(22px);transition:opacity var(--dur) var(--ease),transform var(--dur) var(--ease)}
.reveal.soft{transform:none}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.12s}.d2{transition-delay:.24s}.d3{transition-delay:.36s}
.tc{text-align:center}

/* nav */
nav{position:fixed;top:0;left:0;right:0;z-index:40;display:flex;justify-content:space-between;align-items:center;padding:20px 6vw;transition:background var(--dur-fast) var(--ease),border-color var(--dur-fast) var(--ease);border-bottom:1px solid transparent}
nav.scrolled{background:rgba(227,225,220,.88);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom-color:var(--line)}
.logo{font-family:var(--serif);font-size:24px;font-weight:600;text-decoration:none;color:var(--ink)}
.logo span{color:var(--accent)}
nav .links{font-size:12px;letter-spacing:.14em}
nav .links a{margin-left:24px;text-decoration:none;color:var(--ink-soft)}
nav .cta{background:var(--ink);color:var(--dark-text)!important;padding:9px 20px;border-radius:99px;font-size:11px;transition:background var(--dur-fast) var(--ease)}
nav .cta:hover{background:var(--accent)}
.burger{display:none;background:none;border:none;font-size:26px;line-height:1;color:var(--ink);cursor:pointer;padding:4px 6px}
.mobile-menu{position:fixed;top:0;left:0;right:0;z-index:39;transform:translateY(-100%);transition:transform .42s var(--ease);background:rgba(227,225,220,.97);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--line);padding:78px 6vw 26px;display:flex;flex-direction:column}
.mobile-menu.open{transform:translateY(0)}
.mobile-menu a{text-decoration:none;color:var(--ink);font-size:15px;letter-spacing:.12em;padding:15px 2px;border-bottom:1px solid var(--line)}
.mobile-menu a:last-child{border-bottom:none;color:var(--accent);font-weight:500}
@media(min-width:721px){.mobile-menu{display:none}}
@media(max-width:720px){nav .links{display:none}.burger{display:block}}

section{padding:120px 6vw}
@media(max-width:720px){section{padding:64px 6vw}}
.label{font-size:11px;letter-spacing:.35em;text-transform:uppercase;color:var(--accent);margin-bottom:14px}
.label .idx{font-family:var(--serif);font-style:italic;text-transform:none;letter-spacing:.05em;color:var(--accent-soft);margin-right:10px}
.h2{font-family:var(--serif);font-weight:600;font-size:clamp(22px,3vw,28px);margin-bottom:48px}
.btn{display:inline-block;margin-top:40px;border:1px solid var(--ink);padding:12px 34px;border-radius:99px;font-size:13px;color:var(--ink);text-decoration:none;transition:background var(--dur-fast) var(--ease),color var(--dur-fast) var(--ease),border-color var(--dur-fast) var(--ease)}
.btn:hover{background:var(--accent);border-color:var(--accent);color:#fff}

/* hero + blob */
.hero{position:relative;overflow:hidden;padding:170px 6vw 130px;max-width:1100px;margin:0 auto}
.hero-inner{position:relative;z-index:2}
.hero h1{font-family:var(--serif);font-weight:600;font-size:clamp(30px,5vw,52px);line-height:1.4;max-width:680px}
.hero .sub{margin-top:26px;color:var(--ink-soft);max-width:520px;font-size:15px}
.blob{position:absolute;z-index:0;pointer-events:none;border-radius:42% 58% 63% 37% / 41% 44% 56% 59%}
@keyframes blobMorph{
  0%,100%{border-radius:42% 58% 63% 37% / 41% 44% 56% 59%}
  25%{border-radius:58% 42% 38% 62% / 55% 40% 60% 45%}
  50%{border-radius:39% 61% 55% 45% / 63% 56% 44% 37%}
  75%{border-radius:56% 44% 47% 53% / 39% 63% 37% 61%}
}
@keyframes drift{
  0%,100%{transform:translate(0,0) rotate(0deg) scale(1)}
  33%{transform:translate(-26px,20px) rotate(9deg) scale(1.04)}
  66%{transform:translate(18px,-22px) rotate(-7deg) scale(.97)}
}
@keyframes driftSmall{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(14px,-18px) scale(1.08)}
}

/* manifesto */
.manifesto-wrap{padding:74px 6vw;background:var(--accent)}
.manifesto{color:#E9EDEC;text-align:center;max-width:760px;margin:0 auto}
.manifesto p{font-family:var(--serif);font-size:11.5px;line-height:1.9;margin:0 auto}
.manifesto p+p{margin-top:14px}
.manifesto .sig{margin-top:28px;font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:#C3CFCD}
@media(min-width:721px){.manifesto p{white-space:nowrap}}
@media(max-width:720px){.manifesto-wrap{padding:52px 6vw}.manifesto p{font-size:12.5px;line-height:2}}

/* results */
.results{background:var(--bg);text-align:center}
.nums{display:grid;grid-template-columns:1fr 1fr;gap:20px;max-width:720px;margin:0 auto}
@media(max-width:720px){.nums{grid-template-columns:1fr}}
.num{background:var(--dark);color:var(--dark-text);padding:38px 30px;border-radius:4px;border-top:2px solid var(--accent)}
.num .big{font-family:var(--serif);font-size:32px;color:var(--accent-soft)}
.num .big b{font-weight:600;color:var(--dark-text)}
.num p{font-size:12px;color:#9B988F;margin-top:10px}
.works{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:960px;margin:20px auto 0}
.works figure{margin:0;position:relative}
.works .slot{width:100%;aspect-ratio:4/5;border-radius:4px;overflow:hidden;background-size:cover;background-position:center}
.works figcaption{position:absolute;left:14px;bottom:12px;z-index:2;color:#fff;font-size:12px;letter-spacing:.08em;text-shadow:0 1px 6px rgba(0,0,0,.45);pointer-events:none}
@media(max-width:720px){.works{gap:10px;margin-top:14px}.works figcaption{left:9px;bottom:8px;font-size:10px}}
.reels-cta{margin-top:52px}
.reels-cta .btn{margin-top:0}

/* services */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:960px;margin:34px auto 0}
.svc{background:var(--card);border:1px solid var(--line);padding:34px 28px;border-radius:4px;transition:transform var(--dur-fast) var(--ease),box-shadow var(--dur-fast) var(--ease)}
@media(hover:hover){.svc:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(38,36,31,.12)}}
.svc .no{font-family:var(--serif);font-style:italic;color:var(--accent-soft);font-size:14px}
.svc h4{font-family:var(--serif);font-size:18px;font-weight:600;margin:12px 0 8px}
.svc p{font-size:13px;color:var(--ink-soft)}
@media(max-width:720px){
  .cards{gap:10px}
  .svc{padding:18px 14px}
  .svc .no{font-size:12px}
  .svc h4{font-size:14px;margin:8px 0 6px}
  .svc p{font-size:11px;line-height:1.7}
}

/* reels */
.reels{background:var(--surface);text-align:center}
.reels-hero{padding:150px 6vw 40px;text-align:center}
.reels-hero .sub{font-size:14px;color:var(--ink-soft);max-width:480px;margin:0 auto}
.chips{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-bottom:44px}
.chip{font-size:12.5px;letter-spacing:.06em;padding:8px 22px;border-radius:99px;border:1px solid #A8A49B;color:var(--ink-soft);background:none;cursor:pointer;font-family:var(--sans);transition:all var(--dur-fast) var(--ease)}
.chip.act{background:var(--accent);border-color:var(--accent);color:#E9EDEC}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:860px;margin:0 auto}
@media(max-width:720px){.grid{grid-template-columns:repeat(2,1fr);gap:12px}}
.reel{background:var(--card);border:1px solid var(--line);border-radius:4px;overflow:hidden;transition:transform var(--dur-fast) var(--ease),opacity var(--dur-fast) var(--ease),box-shadow var(--dur-fast) var(--ease)}
.reel.fading{opacity:0;transform:translateY(12px)}
.reel.hide{display:none}
@media(hover:hover){.reel:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(38,36,31,.12)}}
.reel .vid{aspect-ratio:9/16;max-height:420px;width:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(170deg,#B9C6C4,#5E7370);cursor:pointer;position:relative;overflow:hidden}
.reel[data-cat="美容"] .vid{background:linear-gradient(170deg,#E0D4C6,#A08B72)}
.reel[data-cat="室內設計"] .vid{background:linear-gradient(170deg,#D6CDBB,#8C7B62)}
.reel[data-cat="個人IP"] .vid{background:linear-gradient(170deg,#3E3A33,#1E1C18)}
.reel[data-cat="環境"] .vid{background:linear-gradient(170deg,#C8CFCD,#7E8F8C)}
.reel .vid iframe,.reel .vid blockquote{position:absolute;inset:0;width:100%!important;height:100%;border:0;min-width:0!important;margin:0!important;background:#000}
.reel .play{width:50px;height:50px;border-radius:50%;background:rgba(250,249,246,.85);display:flex;align-items:center;justify-content:center;font-size:15px;color:var(--ink);transition:transform var(--dur-fast) var(--ease)}
@media(hover:hover){.reel .vid:hover .play{transform:scale(1.1)}}
.reel .meta{padding:14px 18px;display:flex;justify-content:space-between;align-items:center;text-align:left;gap:8px}
.reel .meta b{font-family:var(--serif);font-size:13px;font-weight:600}
.reel .meta span{display:block;font-size:11px;color:#8A877F}
.reel .meta a{font-size:11px;color:var(--accent);text-decoration:none;white-space:nowrap}
.reels-more{margin-top:44px}
.reels-more .btn{margin:0 8px}

/* fit */
.fit{background:var(--surface);text-align:center}
.fit .h2{margin-bottom:14px}
.fit-lead{margin:0 auto 44px;font-size:13px;color:var(--ink-soft);letter-spacing:.02em}
.fit-grid{display:grid;grid-template-columns:1fr 1px 1fr;gap:0 44px;max-width:720px;margin:0 auto;text-align:left;align-items:start}
.fit-div{background:linear-gradient(180deg,transparent,var(--line) 18%,var(--line) 82%,transparent);align-self:stretch}
.fit-col .fit-h{font-family:var(--serif);font-size:14px;font-weight:600;letter-spacing:.1em;margin:0 0 20px;padding-bottom:14px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:9px}
.fit-col.yes .fit-h{color:var(--accent)}
.fit-col.no .fit-h{color:#A17A5E}
.fit-col .fit-h .mk{font-size:10px;letter-spacing:.2em;text-transform:uppercase;font-family:var(--sans);font-weight:400;opacity:.7}
.fit-list{list-style:none;display:flex;flex-direction:column;gap:14px}
.fit-list li{display:flex;align-items:baseline;gap:12px;font-size:13.5px;color:var(--ink-soft);line-height:1.55}
.fit-list li::before{content:"";flex:none;position:relative;top:6px;width:5px;height:5px;border-radius:50%}
.fit-col.yes .fit-list li::before{background:var(--accent)}
.fit-col.no .fit-list li::before{width:10px;height:1px;border-radius:0;top:9px;background:#C0A68F}
.fit-note{margin:44px auto 0;font-family:var(--serif);font-size:14px;line-height:1.9;color:var(--ink-soft);max-width:36ch;font-style:italic}
@media(max-width:720px){
  .fit-grid{grid-template-columns:1fr;gap:0;max-width:340px}
  .fit-div{display:none}
  .fit-col.no{margin-top:32px;padding-top:32px;border-top:1px solid var(--line)}
}

/* founder */
.founder{background:var(--bg);text-align:center}
.founder-inner{max-width:620px;margin:0 auto}
.founder .label{margin-bottom:26px}
.founder-quote{font-family:var(--serif);font-weight:600;font-size:clamp(22px,3.4vw,30px);line-height:1.7;color:var(--ink)}
.founder-bio{margin:28px auto 0;font-size:13px;line-height:2;color:var(--ink-soft);max-width:46ch}
.founder-link{display:inline-block;margin-top:26px;font-size:12px;letter-spacing:.15em;color:var(--accent);border-bottom:1px solid var(--accent);text-decoration:none;padding-bottom:2px;transition:opacity var(--dur-fast) var(--ease)}
.founder-link:hover{opacity:.6}

/* contact */
.contact{position:relative;overflow:hidden;background:var(--dark);color:var(--dark-text)}
.contact-inner{position:relative;z-index:2;max-width:640px;margin:0 auto;text-align:center}
.contact h2{font-family:var(--serif);font-weight:500;font-size:clamp(24px,4.4vw,30px);line-height:1.6;margin:0 0 14px}
.contact .lead{font-size:14px;color:#9B988F;margin-bottom:30px}
.qbtns{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-bottom:44px}
.qbtn{text-decoration:none;padding:13px 32px;border-radius:99px;font-size:13px;transition:transform var(--dur-fast) var(--ease),border-color var(--dur-fast) var(--ease)}
.qbtn.pri{background:var(--accent);color:#E9EDEC}
.qbtn.pri:hover{transform:translateY(-2px)}
.qbtn.sec{border:1px solid #5A574F;color:var(--dark-text)}
.qbtn.sec:hover{border-color:var(--accent-soft)}
.cform{display:grid;gap:16px;text-align:left}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:560px){.frow{grid-template-columns:1fr}}
.cform label{display:grid;gap:8px;font-size:12px;letter-spacing:.06em;color:#9B988F}
.cform input,.cform textarea,.cform select{background:rgba(233,231,225,.06);border:1px solid rgba(233,231,225,.2);border-radius:4px;padding:13px 15px;color:var(--dark-text);font-size:15px;font-weight:300;font-family:var(--sans)}
.cform textarea{resize:vertical;line-height:1.7}
.cform input:focus,.cform textarea:focus,.cform select:focus{outline:none;border-color:var(--accent)}
.cform option{color:#26241F}
.hint{display:none;font-family:var(--serif);font-size:14px;line-height:1.8;color:var(--accent-soft);border-left:2px solid var(--accent);padding-left:14px}
.hint.show{display:block}
.submit{margin-top:6px;justify-self:start;padding:14px 38px;border:none;border-radius:99px;background:var(--accent);color:#E9EDEC;font-size:15px;letter-spacing:.03em;cursor:pointer;font-family:var(--sans);transition:transform var(--dur-fast) var(--ease),opacity var(--dur-fast) var(--ease)}
.submit:hover{transform:translateY(-2px)}
.submit[disabled]{opacity:.5;cursor:wait}
.sent{display:none;background:rgba(233,231,225,.06);border:1px solid rgba(147,165,163,.3);border-radius:4px;padding:52px 34px;text-align:center}
.sent.show{display:block}
.sent b{display:block;font-family:var(--serif);font-size:22px;font-weight:500}
.sent p{margin-top:12px;font-size:14px;color:#9B988F}

footer{padding:70px 6vw;text-align:center;background:var(--dark);color:#9B988F;font-size:12px;letter-spacing:.15em}
footer .hidden{display:none}

@media(prefers-reduced-motion:reduce){
  *{transition:none!important;animation:none!important;scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
}
