/*
Theme Name: 小皮雲 Personal
Author: 小皮雲
Description: 小皮雲個人品牌網站
Version: 2.0
Text Domain: xiaopiyun
*/

@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@400;600;700;800;900&family=Noto+Sans+TC:wght@400;500;700;900&display=swap');

:root{
  --sky:#b8e0ea;--sky2:#d6eff5;--sky3:#eaf7fa;--sky4:#f4fbfd;
  --w:#fff;--stroke:#4a7a9b;--navy:#1e4060;--navyM:#2e6080;
  --blue:#4a9fc8;--border:#a8d4e8;--tm:#3a6a88;--tl:#7ab0c8;
  --orange:#d4893a;--pink:#f08080;--warm:#e8934a;
  --green:#16a34a;--greenL:#f0fdf4;
  --amber:#d97706;--amberL:#fffbeb;
  --purple:#7c3aed;--purpleL:#f0eaff;
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'Noto Sans TC','Nunito',sans-serif;background:var(--sky4);color:var(--navy);line-height:1.7;font-size:16px;-webkit-font-smoothing:antialiased;}
h1,h2,h3,h4,h5{font-family:'Nunito','Noto Sans TC',sans-serif;font-weight:800;line-height:1.2;color:var(--navy);}
a{color:var(--stroke);text-decoration:none;transition:color .2s;}
a:hover{color:var(--navy);}
img{max-width:100%;height:auto;display:block;}
p{margin-bottom:1rem;}

/* NAV */
.site-header{position:sticky;top:0;z-index:200;background:rgba(255,255,255,0.95);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);}
.nav-inner{max-width:1240px;margin:0 auto;padding:0 40px;height:64px;display:flex;align-items:center;justify-content:space-between;}
.site-logo{display:flex;align-items:center;gap:10px;font-size:18px;font-weight:900;color:var(--navy);text-decoration:none;font-family:'Nunito',sans-serif;}
.logo-icon{position:relative;width:34px;height:22px;flex-shrink:0;}
.logo-icon::after{content:'';position:absolute;width:34px;height:14px;background:var(--stroke);border-radius:7px;bottom:0;left:0;}
.logo-icon::before{content:'';position:absolute;width:20px;height:16px;background:var(--stroke);border-radius:50%;top:0;left:7px;}
.nav-menu{display:flex;gap:4px;align-items:center;list-style:none;}
.nav-menu li a{font-size:14px;font-weight:600;color:var(--tm);padding:7px 16px;border-radius:20px;transition:all .2s;border:1.5px solid transparent;display:block;}
.nav-menu li a:hover,.nav-menu li.current-menu-item a{background:var(--sky2);color:var(--stroke);border-color:var(--border);}
.nav-cta{background:var(--stroke)!important;color:#fff!important;border:none!important;}
.nav-cta:hover{background:var(--navyM)!important;}
.menu-toggle{display:none;background:none;border:1px solid var(--border);padding:6px 12px;border-radius:8px;cursor:pointer;font-size:18px;color:var(--navy);}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:6px;padding:12px 24px;border-radius:24px;font-size:14px;font-weight:700;font-family:'Nunito',sans-serif;cursor:pointer;transition:all .2s;border:none;text-decoration:none;}
.btn:hover{transform:translateY(-1px);}
.btn-primary{background:var(--stroke);color:#fff;}
.btn-primary:hover{background:var(--navyM);color:#fff;}
.btn-secondary{background:var(--w);color:var(--navy);border:1.5px solid var(--border)!important;}
.btn-secondary:hover{border-color:var(--stroke)!important;}
.btn-warm{background:var(--warm);color:#fff;}
.btn-warm:hover{background:#d4803a;color:#fff;}

/* HERO */
.hero{background:var(--sky);padding:64px 40px 72px;display:flex;align-items:center;justify-content:space-between;gap:40px;position:relative;overflow:hidden;min-height:480px;}
.hero::before{content:'';position:absolute;top:-80px;right:80px;width:500px;height:500px;border-radius:50%;background:rgba(255,255,255,0.2);pointer-events:none;}
.hero-content{flex:1;position:relative;z-index:2;}
.hero-badge{display:inline-flex;align-items:center;gap:7px;background:#fff;border:1px solid var(--border);padding:5px 14px;border-radius:20px;font-size:12px;font-weight:700;color:var(--stroke);margin-bottom:18px;}
.badge-dot{width:8px;height:8px;border-radius:50%;background:#22c55e;animation:blink 2s infinite;}
@keyframes blink{0%,100%{opacity:1;}50%{opacity:.4;}}
.hero-title{font-size:52px;font-weight:900;line-height:1.08;margin-bottom:14px;}
.hero-title em{font-style:normal;color:var(--stroke);}
.hero-desc{font-size:16px;color:var(--navyM);line-height:1.8;max-width:460px;margin-bottom:28px;}
.hero-buttons{display:flex;gap:12px;flex-wrap:wrap;}
.hero-char{position:relative;z-index:2;flex-shrink:0;}

/* SECTIONS */
.section{padding:60px 40px;max-width:1240px;margin:0 auto;}
.section-white{background:var(--w);}
.section-white .section{max-width:none;}
.section-white-wrap{background:var(--w);}
.eyebrow{display:block;font-size:11px;font-weight:700;color:var(--blue);letter-spacing:2.5px;text-transform:uppercase;margin-bottom:8px;}
.section-title{font-size:34px;font-weight:900;margin-bottom:8px;}
.section-sub{font-size:15px;color:var(--tm);line-height:1.8;max-width:540px;margin-bottom:32px;}
.section-row{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:22px;}
.link-more{font-size:14px;font-weight:700;color:var(--blue);text-decoration:none;}
.link-more:hover{text-decoration:underline;color:var(--blue);}

/* ABILITY CARDS */
.ability-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:32px;}
.ability-card{background:#fff;border:1px solid var(--border);border-radius:20px;padding:22px;position:relative;overflow:hidden;transition:transform .2s,box-shadow .2s;}
.ability-card:hover{transform:translateY(-3px);box-shadow:0 12px 32px rgba(74,122,155,.12);}
.ability-bar{position:absolute;top:0;left:0;right:0;height:3px;}
.ability-icon{width:50px;height:50px;border-radius:12px;background:var(--sky3);display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:14px;margin-top:8px;}
.ability-title{font-size:15px;font-weight:800;color:var(--navy);margin-bottom:6px;}
.ability-desc{font-size:12px;color:var(--tm);line-height:1.65;margin-bottom:12px;}
.ability-tags{display:flex;flex-wrap:wrap;gap:5px;}
.atag{font-size:10px;font-weight:700;color:var(--stroke);background:var(--sky2);padding:3px 9px;border-radius:8px;}

/* TOOLS */
.tools-bar{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px;}
.tool-pill{font-size:13px;font-weight:600;color:var(--navy);background:var(--sky3);border:1px solid var(--border);padding:6px 16px;border-radius:10px;}

/* WORKS */
.works-grid{display:grid;grid-template-columns:1.55fr 1fr;gap:16px;margin-bottom:16px;}
.works-grid2{display:grid;grid-template-columns:1fr 1.55fr;gap:16px;}
.work-card{border-radius:20px;overflow:hidden;transition:transform .2s;display:block;text-decoration:none;}
.work-card:hover{transform:translateY(-2px);}
.work-thumb{width:100%;aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;font-size:12px;color:rgba(200,215,235,.4);}
.work-thumb img{width:100%;height:100%;object-fit:cover;}
.work-body{padding:14px 18px 16px;}
.work-badge{display:inline-block;font-size:11px;font-weight:700;color:rgba(255,255,255,.88);background:rgba(0,0,0,.28);padding:3px 10px;border-radius:9px;margin-bottom:6px;}
.work-title{font-size:16px;font-weight:800;color:#fff;margin-bottom:4px;}
.work-sub{font-size:12px;color:rgba(180,205,230,.75);line-height:1.5;}

/* QUOTE */
.quote-block{background:var(--sky2);border-radius:20px;padding:30px 36px;border-left:4px solid var(--stroke);}
.quote-block blockquote{font-size:17px;color:var(--navy);line-height:1.85;font-style:italic;margin-bottom:10px;}
.quote-block cite{font-size:13px;color:var(--tm);font-weight:600;font-style:normal;}

/* POST CARDS */
.posts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.post-card{background:#fff;border:1px solid var(--border);border-radius:16px;overflow:hidden;transition:transform .18s,box-shadow .18s;display:block;text-decoration:none;color:inherit;}
.post-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(74,122,155,.1);}
.post-top{height:4px;}
.post-body{padding:18px;}
.post-cat{display:inline-block;font-size:11px;font-weight:700;padding:3px 10px;border-radius:9px;margin-bottom:10px;}
.post-card-title{font-size:15px;font-weight:700;color:var(--navy);line-height:1.5;margin-bottom:8px;}
.post-meta{font-size:12px;color:var(--tl);}

/* CTA BANNER */
.cta-wrap{padding:0 40px 60px;max-width:1240px;margin:0 auto;}
.cta-banner{background:var(--sky);border-radius:24px;padding:44px 52px;display:flex;justify-content:space-between;align-items:center;gap:24px;border:1px solid var(--border);}
.cta-banner h2{font-size:28px;font-weight:900;color:var(--navy);margin-bottom:6px;}
.cta-banner p{font-size:15px;color:var(--navyM);}

/* PAGE HEADER */
.page-hero{background:var(--sky);padding:48px 40px 44px;position:relative;overflow:hidden;}
.page-hero::before{content:'';position:absolute;right:-60px;top:-60px;width:280px;height:280px;border-radius:50%;background:rgba(255,255,255,.2);pointer-events:none;}
.page-hero .eyebrow{margin-bottom:8px;}
.page-hero h1{font-size:44px;font-weight:900;margin-bottom:8px;}
.page-hero .ph-sub{font-size:15px;color:var(--navyM);}

/* FILTER BAR */
.filter-bar{background:#fff;border-bottom:1px solid var(--border);padding:0 40px;display:flex;gap:6px;align-items:center;height:54px;overflow-x:auto;scrollbar-width:none;}
.filter-bar::-webkit-scrollbar{display:none;}
.filter-pill{display:inline-block;padding:6px 18px;border-radius:20px;font-size:13px;font-weight:700;color:var(--tm);cursor:pointer;border:1.5px solid transparent;white-space:nowrap;background:transparent;font-family:'Nunito',sans-serif;text-decoration:none;transition:all .15s;}
.filter-pill:hover,.filter-pill.current{background:var(--sky2);color:var(--stroke);border-color:var(--border);}

/* PORTFOLIO */
.port-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;padding:40px;}
.port-card{background:#fff;border:1px solid var(--border);border-radius:20px;overflow:hidden;transition:transform .18s,box-shadow .18s;display:block;text-decoration:none;color:inherit;}
.port-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(74,122,155,.12);}
.port-thumb{width:100%;aspect-ratio:16/10;display:flex;align-items:center;justify-content:center;position:relative;font-size:12px;color:rgba(200,215,235,.4);}
.port-thumb img{width:100%;height:100%;object-fit:cover;}
.port-badge{position:absolute;top:12px;left:12px;font-size:11px;font-weight:700;padding:4px 11px;border-radius:10px;background:rgba(255,255,255,.88);color:var(--navy);}
.port-body{padding:16px 20px 20px;}
.port-title{font-size:16px;font-weight:800;color:var(--navy);margin-bottom:6px;}
.port-desc{font-size:13px;color:var(--tm);line-height:1.6;margin-bottom:12px;}
.port-btn{display:inline-block;font-size:12px;font-weight:700;color:var(--stroke);background:var(--sky2);padding:5px 13px;border-radius:9px;}

/* BLOG */
.blog-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;padding:36px 40px;}
.blog-card{background:#fff;border:1px solid var(--border);border-radius:16px;display:flex;overflow:hidden;transition:border-color .18s;text-decoration:none;color:inherit;}
.blog-card:hover{border-color:var(--stroke);}
.blog-thumb{width:130px;flex-shrink:0;background:var(--sky2);display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--tl);}
.blog-thumb img{width:100%;height:100%;object-fit:cover;}
.blog-body{padding:16px 18px;}
.blog-title{font-size:15px;font-weight:700;color:var(--navy);line-height:1.5;margin-bottom:6px;}
.blog-meta{font-size:12px;color:var(--tl);margin-bottom:8px;}
.read-more-btn{display:inline-block;font-size:11px;font-weight:700;color:var(--stroke);background:var(--sky2);padding:3px 10px;border-radius:8px;}

/* CLOUD WORLD */
.cloud-intro{background:var(--sky);border-radius:20px;padding:32px;display:flex;gap:32px;align-items:center;margin-bottom:28px;}
.cloud-intro-text{flex:1;}
.cloud-intro-h{font-size:22px;font-weight:900;margin-bottom:10px;}
.cloud-intro-desc{font-size:14px;color:var(--navyM);line-height:1.8;}
.sticker-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px;}
.sticker-card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:20px;text-align:center;transition:transform .18s,border-color .18s;}
.sticker-card:hover{transform:translateY(-3px);border-color:var(--stroke);}
.sticker-img{width:80px;height:80px;border-radius:50%;background:var(--sky2);display:flex;align-items:center;justify-content:center;margin:0 auto 12px;overflow:hidden;}
.sticker-img img{width:100%;height:100%;object-fit:cover;}
.sticker-name{font-size:13px;font-weight:800;color:var(--navy);margin-bottom:4px;}
.sticker-mood{font-size:11px;color:var(--tm);}
.story-list{background:#fff;border-radius:16px;padding:24px;}
.story-list h3{font-size:17px;font-weight:800;color:var(--navy);margin-bottom:16px;}
.story-item{border:1px solid var(--border);border-radius:12px;padding:14px 18px;margin-bottom:10px;display:flex;justify-content:space-between;align-items:center;}
.story-title-text{font-size:14px;font-weight:700;color:var(--navy);margin-bottom:3px;}
.story-ep{font-size:12px;color:var(--tl);}
.story-badge{font-size:11px;font-weight:700;padding:3px 10px;border-radius:8px;white-space:nowrap;}

/* PRIVATE / RESUME */
.private-bar{background:#fffbea;border-bottom:1px solid #f0df60;padding:8px 40px;font-size:12px;font-weight:700;color:#7a6000;}
.resume-hero{background:var(--sky);padding:52px 40px;display:flex;justify-content:space-between;align-items:center;gap:32px;}
.resume-name-h{font-size:48px;font-weight:900;color:var(--navy);line-height:1.1;margin-bottom:8px;}
.resume-role-text{font-size:16px;color:var(--navyM);margin-bottom:18px;}
.avail-badge{display:inline-flex;align-items:center;gap:7px;background:#f0fdf4;border:1px solid #86efac;padding:7px 16px;border-radius:20px;font-size:13px;font-weight:700;color:#15803d;}
.avail-dot{width:9px;height:9px;border-radius:50%;background:#22c55e;animation:blink 2s infinite;}
.resume-avatar{width:130px;height:130px;border-radius:50%;background:var(--sky2);border:3px solid var(--border);overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:13px;color:var(--tl);flex-shrink:0;}
.resume-avatar img{width:100%;height:100%;object-fit:cover;}
.res-wrap{padding:40px;max-width:1240px;margin:0 auto;}
.res-block{margin-bottom:36px;}
.res-label{font-size:11px;font-weight:700;color:var(--stroke);letter-spacing:2px;border-bottom:1.5px solid var(--border);padding-bottom:8px;margin-bottom:18px;}
.res-item{display:flex;gap:20px;margin-bottom:18px;}
.res-date{font-size:12px;color:var(--tl);width:90px;flex-shrink:0;padding-top:2px;font-weight:600;}
.res-main .res-role{font-size:15px;font-weight:700;color:var(--navy);margin-bottom:2px;}
.res-main .res-org{font-size:13px;color:var(--tm);margin-bottom:5px;}
.res-main .res-desc{font-size:13px;color:var(--tm);line-height:1.7;}
.contact-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-bottom:28px;}
.contact-card{background:#fff;border:1px solid var(--border);border-radius:12px;padding:16px;display:flex;align-items:center;gap:14px;}
.contact-icon{width:44px;height:44px;border-radius:12px;background:var(--sky2);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;}
.contact-lbl{font-size:11px;color:var(--tm);margin-bottom:2px;}
.contact-val{font-size:14px;font-weight:700;color:var(--navy);}
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;}
.svc-card{background:#fff;border:1px solid var(--border);border-top:3px solid var(--stroke);border-radius:16px;padding:20px;}
.svc-icon{font-size:22px;margin-bottom:8px;}
.svc-title{font-size:15px;font-weight:800;color:var(--navy);margin-bottom:5px;}
.svc-price{display:inline-block;font-size:12px;font-weight:700;color:var(--navyM);background:var(--sky2);padding:3px 10px;border-radius:7px;margin-bottom:8px;}
.svc-desc{font-size:13px;color:var(--tm);line-height:1.6;}
.skills-2col{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;}
.skill-group{background:var(--sky3);border-radius:12px;padding:16px;}
.skill-group-label{font-size:12px;font-weight:700;color:var(--stroke);margin-bottom:10px;}
.skill-pills{display:flex;flex-wrap:wrap;gap:6px;}
.skill-pill{font-size:12px;font-weight:600;color:var(--navy);background:#fff;padding:4px 12px;border-radius:8px;border:1px solid var(--border);}

/* PASSWORD FORM */
.post-password-form{max-width:480px;margin:80px auto;padding:0 40px;text-align:center;}
.post-password-form p{font-size:15px;color:var(--tm);margin-bottom:20px;}
.post-password-form input[type=password]{width:100%;padding:12px 16px;border:1.5px solid var(--border);border-radius:12px;font-size:15px;margin-bottom:12px;outline:none;font-family:inherit;}
.post-password-form input[type=password]:focus{border-color:var(--stroke);}
.post-password-form input[type=submit]{width:100%;background:var(--stroke);color:#fff;border:none;padding:12px;border-radius:20px;font-size:14px;font-weight:700;cursor:pointer;font-family:'Nunito',sans-serif;}

/* SINGLE POST */
.post-content{max-width:760px;margin:0 auto;padding:48px 40px;}
.post-content h1{font-size:38px;margin-bottom:12px;}
.post-meta-bar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:24px;}
.post-thumbnail{border-radius:20px;margin-bottom:36px;width:100%;}
.post-body{font-size:17px;line-height:1.85;color:#2a4a60;}
.post-body h2{font-size:26px;margin:40px 0 14px;}
.post-body h3{font-size:21px;margin:32px 0 10px;}
.post-body p{margin-bottom:1.2em;}
.post-body ul,.post-body ol{padding-left:24px;margin-bottom:1.2em;}
.post-body li{margin-bottom:6px;}
.post-body blockquote{border-left:4px solid var(--stroke);background:var(--sky2);padding:16px 20px;border-radius:0 12px 12px 0;margin:24px 0;font-style:italic;}
.post-body code{background:var(--sky3);padding:2px 7px;border-radius:5px;font-size:14px;}
.post-nav{margin-top:48px;padding-top:28px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;}
.post-nav a{color:var(--stroke);font-weight:700;text-decoration:none;}

/* PAGINATION */
.pagination{display:flex;justify-content:center;gap:8px;padding:36px 0;}
.page-numbers{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:var(--navy);background:#fff;border:1px solid var(--border);text-decoration:none;transition:all .15s;}
.page-numbers:hover,.page-numbers.current{background:var(--stroke);color:#fff;border-color:var(--stroke);}

/* FOOTER */
.site-footer{background:var(--navy);padding:32px 40px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;}
.footer-copy,.footer-links{font-size:13px;color:rgba(160,200,220,.55);}
.footer-links a{color:rgba(160,200,220,.55);margin-left:14px;}
.footer-links a:hover{color:rgba(160,200,220,.9);}

/* RWD */
@media(max-width:1024px){
  .ability-grid{grid-template-columns:repeat(2,1fr);}
  .works-grid,.works-grid2{grid-template-columns:1fr;}
  .port-grid{grid-template-columns:1fr;}
}
@media(max-width:768px){
  .hero{flex-direction:column;padding:40px 20px 50px;text-align:center;}
  .hero-title{font-size:36px;}
  .hero-buttons{justify-content:center;}
  .hero-char{display:none;}
  .hero-desc{margin:0 auto 24px;}
  .hero-badge{margin:0 auto 16px;}
  .section{padding:40px 20px;}
  .ability-grid{grid-template-columns:1fr 1fr;gap:12px;}
  .posts-grid{grid-template-columns:1fr;}
  .blog-grid{grid-template-columns:1fr;padding:24px 20px;}
  .port-grid{padding:24px 20px;}
  .sticker-grid{grid-template-columns:repeat(2,1fr);}
  .contact-grid,.svc-grid,.skills-2col{grid-template-columns:1fr;}
  .cta-banner{flex-direction:column;text-align:center;padding:32px 24px;}
  .main-nav.open{display:flex!important;flex-direction:column;position:absolute;top:64px;left:0;right:0;background:#fff;padding:12px;border-bottom:1px solid var(--border);z-index:100;}
  .main-nav{display:none;}
  .menu-toggle{display:block;}
  .resume-hero{flex-direction:column;text-align:center;padding:36px 20px;}
  .resume-name-h{font-size:36px;}
  .nav-inner{padding:0 20px;}
  .page-hero{padding:32px 20px;}
  .page-hero h1{font-size:32px;}
  .filter-bar{padding:0 20px;}
  .site-footer{flex-direction:column;text-align:center;padding:28px 20px;}
  .cta-wrap{padding:0 20px 40px;}
  .res-wrap{padding:24px 20px;}
  .blog-grid{padding:24px 20px;}
}
@media(max-width:480px){
  .ability-grid{grid-template-columns:1fr;}
  .hero-title{font-size:30px;}
  .section-title{font-size:26px;}
}
