/* take! 體驗行銷 — 靜態網站樣式 */
:root{
  --brand:#ed5338;       /* take! 珊瑚紅 */
  --brand-dark:#c8402a;
  --ink:#2b2b2b;
  --muted:#6f6f6f;
  --line:#ececec;
  --bg:#ffffff;
  --soft:#fbf6f4;
  --dark:#22201f;
  --maxw:1160px;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:"Noto Sans TC","PingFang TC","Microsoft JhengHei",-apple-system,BlinkMacSystemFont,"Helvetica Neue",Arial,sans-serif;
  color:var(--ink);background:var(--bg);line-height:1.85;font-size:17px;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px;}
.center{text-align:center;}

/* Header / Nav */
.site-header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.96);backdrop-filter:saturate(180%) blur(8px);border-bottom:1px solid var(--line);}
.nav{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:12px 24px;max-width:var(--maxw);margin:0 auto;}
.nav .brand img{height:56px;width:auto;}
.nav-links{display:flex;gap:26px;align-items:center;flex-wrap:wrap;}
.nav-links a{font-size:15.5px;color:var(--ink);letter-spacing:.02em;padding:6px 2px;border-bottom:2px solid transparent;transition:.2s;}
.nav-links a:hover,.nav-links a.active{color:var(--brand);border-bottom-color:var(--brand);}
.nav-toggle{display:none;background:none;border:0;font-size:26px;cursor:pointer;color:var(--ink);}

/* Hero */
.hero{position:relative;min-height:520px;display:flex;align-items:center;justify-content:center;background:#333 center/cover no-repeat;}
.hero::after{content:"";position:absolute;inset:0;background:rgba(0,0,0,.42);}
.hero-cap{position:relative;z-index:2;text-align:center;color:#fff;padding:40px 24px;}
.hero-cap h1{font-size:clamp(30px,5.5vw,58px);margin:0;font-weight:800;letter-spacing:.08em;text-shadow:0 2px 18px rgba(0,0,0,.4);}
.hero-cap .divider{width:200px;height:1px;background:rgba(255,255,255,.7);margin:22px auto;}
.hero-cap p{font-size:clamp(16px,2.2vw,22px);margin:0;font-weight:300;letter-spacing:.03em;}

/* Sections */
section{padding:66px 0;}
section.alt{background:var(--soft);}
.section-title{text-align:center;font-size:clamp(24px,3.4vw,34px);color:var(--ink);font-weight:800;margin:0 0 8px;letter-spacing:.04em;}
.section-title .bar{display:block;width:54px;height:4px;background:var(--brand);border-radius:3px;margin:14px auto 0;}
.section-sub{text-align:center;color:var(--muted);margin:0 auto 40px;max-width:680px;}
.lead{max-width:780px;margin:0 auto;text-align:center;}

/* Feature grid */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;}
.feature{background:#fff;border:1px solid var(--line);border-radius:16px;padding:34px 28px;text-align:center;transition:.2s;}
.feature:hover{transform:translateY(-4px);box-shadow:0 14px 34px rgba(237,83,56,.10);border-color:#f3d3cb;}
.feature .ic{width:84px;height:84px;border-radius:50%;object-fit:cover;margin:0 auto 18px;}
.feature h4{margin:0 0 12px;font-size:21px;color:var(--brand);}
.feature p{margin:0;color:var(--muted);font-size:15.5px;}

/* CTA button */
.btn{display:inline-block;padding:13px 32px;border-radius:40px;background:var(--brand);color:#fff;font-weight:700;letter-spacing:.04em;transition:.2s;border:0;cursor:pointer;font:inherit;}
.btn:hover{background:var(--brand-dark);}
.btn-ghost{background:#fff;color:var(--brand);border:2px solid var(--brand);}
.btn-ghost:hover{background:var(--brand);color:#fff;}

/* News list */
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.post{background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;display:flex;flex-direction:column;transition:.2s;}
.post:hover{transform:translateY(-4px);box-shadow:0 14px 34px rgba(0,0,0,.07);}
.post .thumb{aspect-ratio:16/10;background:#eee center/cover no-repeat;}
.post .body{padding:22px;display:flex;flex-direction:column;gap:10px;flex:1;}
.post .meta{font-size:13px;color:var(--brand);font-weight:700;letter-spacing:.03em;}
.post h4{margin:0;font-size:17.5px;line-height:1.5;color:var(--ink);}
.post p{margin:0;color:var(--muted);font-size:14.5px;flex:1;}
.post .more{font-size:14px;color:var(--brand);font-weight:700;}

/* Article */
.article{max-width:820px;margin:0 auto;}
.article .kicker{color:var(--brand);font-weight:700;font-size:14px;letter-spacing:.04em;text-align:center;}
.article h1{font-size:clamp(24px,3.6vw,34px);text-align:center;margin:10px 0 8px;line-height:1.45;}
.article .date{text-align:center;color:var(--muted);font-size:14px;margin-bottom:30px;}
.article .hero-img{border-radius:16px;overflow:hidden;margin:0 0 30px;}
.article p{margin:0 0 20px;}
.article h2,.article h3{color:var(--ink);margin:34px 0 14px;}
.article img{border-radius:12px;margin:24px auto;}
.back{display:inline-block;margin-top:18px;color:var(--brand);font-weight:700;}

/* Generic prose */
.prose{max-width:860px;margin:0 auto;}
.prose h3{color:var(--brand);font-size:22px;margin:38px 0 14px;}
.prose p{margin:0 0 18px;}
.prose ul{padding-left:22px;}
.prose li{margin:8px 0;}

/* Logos / venues */
.logo-row{display:flex;flex-wrap:wrap;gap:30px;justify-content:center;align-items:center;}
.logo-row img{height:64px;width:auto;filter:grayscale(.1);opacity:.9;}

/* Contact form */
.form{max-width:600px;margin:0 auto;}
.form .row{margin-bottom:16px;}
.form label{display:block;font-size:14px;color:var(--muted);margin-bottom:6px;}
.form input,.form textarea,.form select{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:8px;font:inherit;color:var(--ink);background:#fff;}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--brand);}
.form .actions{display:flex;gap:12px;justify-content:center;margin-top:8px;}

/* Footer */
.site-footer{background:var(--dark);color:#cfc9c6;padding:50px 0 38px;text-align:center;}
.site-footer .f-logo{height:48px;margin:0 auto 18px;}
.social{display:flex;gap:22px;justify-content:center;margin-bottom:18px;flex-wrap:wrap;}
.social a{color:#cfc9c6;font-size:15px;transition:.2s;border-bottom:1px solid transparent;}
.social a:hover{color:#fff;border-bottom-color:var(--brand);}
.site-footer small{color:#8d877f;display:block;margin-top:8px;}

/* About milestone timeline */
.timeline2{list-style:none;padding:0;max-width:760px;}
.timeline2 li{display:flex;gap:18px;padding:10px 0;border-bottom:1px dashed var(--line);}
.timeline2 li.t-year{font-size:22px;font-weight:800;color:var(--brand);border-bottom:0;padding-top:26px;}
.timeline2 .t-date{flex:0 0 90px;color:var(--brand);font-weight:700;font-size:14px;}
.timeline2 .t-txt{flex:1;color:var(--ink);}

/* Media list */
.media-list{max-width:860px;margin:0 auto;display:flex;flex-direction:column;gap:2px;}
.media-item{display:flex;gap:20px;align-items:baseline;padding:20px 18px;border-bottom:1px solid var(--line);transition:.2s;}
.media-item:hover{background:var(--soft);}
.media-src{flex:0 0 150px;color:var(--brand);font-weight:700;font-size:14.5px;}
.media-title{flex:1;color:var(--ink);}

/* Venues (where) */
.city{font-size:24px;color:var(--brand);font-weight:800;margin:38px 0 16px;text-align:center;}
.venue-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.venue{background:#fff;border:1px solid var(--line);border-radius:12px;padding:22px;text-align:center;}
.venue h4{margin:0 0 8px;color:var(--ink);font-size:18px;}
.venue p{margin:0;color:var(--muted);font-size:14.5px;}

/* Company block */
.company{margin-top:34px;color:var(--muted);font-size:15px;}

/* Article figure */
.article figure{margin:24px 0;}
.article figure img{width:100%;border-radius:12px;}

@media(max-width:900px){.grid-3,.news-grid,.venue-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:640px){
  .nav-toggle{display:block;}
  .nav-links{display:none;width:100%;flex-direction:column;gap:0;border-top:1px solid var(--line);margin-top:12px;}
  .nav-links.open{display:flex;}
  .nav-links a{padding:12px 0;width:100%;border-bottom:1px solid var(--line);}
  .nav{flex-wrap:wrap;}
  .grid-3,.news-grid,.venue-grid{grid-template-columns:1fr;}
  .media-item{flex-direction:column;gap:4px;}
  .media-src{flex:none;}
  section{padding:48px 0;}
  .hero{min-height:420px;}
}
