/*
Theme Name: 夢芽 - Yumeme
Theme URI: https://xn--n8jx07hl4d.asia
Author: Yumeme
Description: 才能・天職の夢占いテーマ
Version: 1.0
Text Domain: yumeme
*/

:root {
  --bg: #fafbff; --bg2: #f0f2fa; --card: #fff; --card-h: #f5f6ff;
  --text: #1a1a2e; --text2: #5a5a7a; --muted: #9898b0;
  --blue: #2563eb; --blue-l: #3b82f6; --blue-g: rgba(37,99,235,0.1);
  --gold: #d97706; --gold-l: #f59e0b; --gold-g: rgba(217,119,6,0.1);
  --indigo: #4f46e5; --emerald: #059669; --rose: #e11d48;
  --border: rgba(37,99,235,0.1); --glow: 0 4px 24px rgba(37,99,235,0.08);
  --grad: linear-gradient(135deg, #2563eb 0%, #4f46e5 50%, #7c3aed 100%);
  --grad-warm: linear-gradient(135deg, #f59e0b 0%, #d97706 100%);
  --r-sm: 8px; --r-md: 12px; --r-lg: 20px;
  --f-display: 'Poppins', 'Noto Sans JP', sans-serif;
  --f-body: 'Noto Sans JP', sans-serif;
  --f-ui: 'M PLUS 1', sans-serif;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--f-body);background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden;line-height:1.8;font-weight:400}
a{color:var(--blue);text-decoration:none;transition:color .3s}
a:hover{color:var(--indigo)}
::selection{background:var(--blue);color:#fff}
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--blue);border-radius:3px}
.container{max-width:1100px;margin:0 auto;padding:0 24px;position:relative}

/* Network Bar */
.network-bar{background:#fff;border-bottom:1px solid var(--border);padding:6px 0;font-size:.72rem;position:fixed;top:0;left:0;right:0;z-index:200;box-shadow:0 1px 4px rgba(0,0,0,.03)}
.network-inner{max-width:1100px;margin:0 auto;padding:0 24px;display:flex;align-items:center;gap:20px}
.network-label{color:var(--muted);font-family:var(--f-ui);font-weight:500}
.network-links{display:flex;gap:16px}
.network-links a{color:var(--muted);font-family:var(--f-ui);transition:color .3s}
.network-links a:hover{color:var(--blue)}
.network-links a.current{color:var(--blue);font-weight:600}

/* Header */
.site-header{position:fixed;top:28px;left:0;right:0;z-index:100;background:rgba(250,251,255,0.92);backdrop-filter:blur(20px);border-bottom:1px solid var(--border)}
.header-inner{max-width:1100px;margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between;height:60px}
.logo{font-family:var(--f-display);font-size:1.3rem;font-weight:700;color:var(--blue);display:flex;align-items:center;gap:8px}
.logo .logo-icon{width:32px;height:32px;border-radius:8px;background:var(--grad);display:flex;align-items:center;justify-content:center;color:#fff;font-size:.9rem;font-weight:700}
.logo small{font-size:.7rem;color:var(--muted);font-weight:400;margin-left:4px}
.nav{display:flex;gap:24px}
.nav a{font-size:.83rem;color:var(--text2);font-weight:500;cursor:pointer;transition:color .3s}
.nav a:hover{color:var(--blue)}

/* Hero */
.hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:120px 24px 80px;position:relative}
.hero::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(ellipse at 50% 30%, rgba(37,99,235,0.04) 0%, transparent 60%);pointer-events:none}
.hero-sunrise{width:120px;height:120px;margin-bottom:28px;position:relative}
.hero-sunrise .sun{width:100%;height:100%;border-radius:50%;background:radial-gradient(circle at 40% 40%,#fbbf24 0%,#f59e0b 40%,#d97706 70%,rgba(217,119,6,0.5) 100%);box-shadow:0 0 60px rgba(245,158,11,0.3),0 0 120px rgba(245,158,11,0.1);animation:sunGlow 6s ease-in-out infinite}
@keyframes sunGlow{0%,100%{box-shadow:0 0 60px rgba(245,158,11,0.3),0 0 120px rgba(245,158,11,0.1)}50%{box-shadow:0 0 80px rgba(245,158,11,0.4),0 0 160px rgba(245,158,11,0.15)}}
.hero h1{font-family:var(--f-display);font-size:clamp(2.4rem,5vw,3.6rem);font-weight:700;margin-bottom:8px;color:var(--text);animation:fadeUp .8s ease-out}
.hero h1 span{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.hero-sub{font-size:clamp(.88rem,2vw,1.05rem);color:var(--text2);margin-bottom:40px;letter-spacing:.1em;font-weight:300;animation:fadeUp .8s ease-out .15s both}
.hero-concept{max-width:560px;font-size:.92rem;color:var(--text2);line-height:2;margin-bottom:48px;animation:fadeUp .8s ease-out .25s both}
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}

/* Search */
.search-section{width:100%;max-width:640px;margin:0 auto;animation:fadeUp .8s ease-out .35s both}
.search-box{position:relative}
.search-box input{width:100%;padding:18px 56px 18px 24px;background:var(--card);border:2px solid var(--border);border-radius:var(--r-lg);color:var(--text);font-size:1rem;font-family:var(--f-body);outline:none;transition:all .4s;box-shadow:0 2px 12px rgba(0,0,0,.04)}
.search-box input::placeholder{color:var(--muted);font-size:.9rem}
.search-box input:focus{border-color:var(--blue);box-shadow:0 0 0 4px var(--blue-g),0 4px 16px rgba(37,99,235,0.08)}
.search-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:42px;height:42px;border-radius:12px;background:var(--grad);border:none;cursor:pointer;color:#fff;font-size:1.1rem;display:flex;align-items:center;justify-content:center;transition:all .3s}
.search-btn:hover{transform:translateY(-50%) scale(1.05)}
.search-hints{margin-top:12px;display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:center}
.search-hints .label{font-size:.76rem;color:var(--muted)}
.search-hints span:not(.label){font-size:.76rem;color:var(--blue);background:var(--blue-g);padding:4px 12px;border-radius:100px;cursor:pointer;transition:all .3s;border:1px solid transparent;font-weight:500}
.search-hints span:not(.label):hover{border-color:var(--blue);background:rgba(37,99,235,0.15)}

/* Sections */
.main-content{padding:40px 0 80px}
.sec-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;padding-bottom:14px;border-bottom:2px solid var(--border)}
.sec-title{font-family:var(--f-display);font-size:1.3rem;font-weight:700;display:flex;align-items:center;gap:10px;color:var(--text)}
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s,transform .7s}
.reveal.visible{opacity:1;transform:translateY(0)}

/* Talent Radar */
.talent-section{margin-bottom:56px}
.talent-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);padding:36px;box-shadow:var(--glow);text-align:center}
.talent-card h3{font-family:var(--f-display);font-size:1.15rem;font-weight:700;margin-bottom:8px}
.talent-card p{font-size:.85rem;color:var(--text2);margin-bottom:24px}
.talent-axes{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px;text-align:center}
.talent-axis{padding:20px 12px;background:var(--bg2);border-radius:var(--r-md);border:1px solid var(--border);cursor:pointer;transition:all .3s}
.talent-axis:hover{border-color:var(--blue);background:var(--blue-g)}
.talent-axis .ta-icon{font-size:1.8rem;margin-bottom:4px;display:block}
.talent-axis .ta-name{font-size:.88rem;font-weight:600;margin-bottom:2px}
.talent-axis .ta-desc{font-size:.72rem;color:var(--muted)}
.talent-test-btn{padding:14px 40px;border-radius:var(--r-lg);background:var(--grad);border:none;color:#fff;font-size:.95rem;font-family:var(--f-body);font-weight:600;cursor:pointer;transition:all .3s}
.talent-test-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(37,99,235,0.2)}
.talent-result{display:none;margin-top:24px;text-align:left}
.talent-result.active{display:block;animation:fadeUp .5s ease-out}
.talent-type{font-family:var(--f-display);font-size:1.6rem;font-weight:700;text-align:center;margin-bottom:8px;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.talent-desc{font-size:.9rem;color:var(--text2);line-height:2;text-align:center;margin-bottom:20px}
.talent-bars{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.t-bar{background:var(--bg2);border-radius:var(--r-sm);padding:14px 16px;border:1px solid var(--border)}
.t-bar .tb-label{font-size:.75rem;color:var(--muted);font-family:var(--f-ui);margin-bottom:4px;display:flex;justify-content:space-between}
.t-bar .tb-track{height:6px;background:rgba(37,99,235,0.1);border-radius:3px;overflow:hidden}
.t-bar .tb-fill{height:100%;border-radius:3px;transition:width .8s ease-out}

/* Dream Keywords */
.talent-dreams{margin-bottom:56px}
.tdream-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.tdream-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-md);padding:20px 24px;cursor:pointer;transition:all .4s;box-shadow:0 1px 4px rgba(0,0,0,.03)}
.tdream-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(37,99,235,0.08);border-color:var(--blue)}
.tdream-card .td-icon{font-size:1.5rem;margin-bottom:6px;display:block}
.tdream-card .td-title{font-size:.95rem;font-weight:600;margin-bottom:4px}
.tdream-card .td-talent{font-size:.78rem;color:var(--blue);font-family:var(--f-ui);font-weight:600;margin-bottom:4px}
.tdream-card .td-meaning{font-size:.8rem;color:var(--text2);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* Future Self */
.future-section{margin-bottom:56px}
.future-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);padding:36px;box-shadow:var(--glow);text-align:center}
.future-card h3{font-family:var(--f-display);font-size:1.15rem;font-weight:700;margin-bottom:8px}
.future-card p{font-size:.85rem;color:var(--text2);margin-bottom:24px}
.future-inputs{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:20px}
.future-inputs input,.future-inputs select{padding:12px 16px;background:var(--bg2);border:1.5px solid var(--border);border-radius:var(--r-sm);color:var(--text);font-size:.9rem;font-family:var(--f-body);outline:none;transition:all .3s}
.future-inputs input:focus,.future-inputs select:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-g)}
.future-btn{padding:14px 36px;border-radius:var(--r-lg);background:var(--grad);border:none;color:#fff;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s;font-family:var(--f-body)}
.future-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(37,99,235,0.2)}
.future-result{display:none;margin-top:24px;text-align:left}
.future-result.active{display:block;animation:fadeUp .5s ease-out}
.future-title{font-family:var(--f-display);font-size:1.4rem;font-weight:700;text-align:center;margin-bottom:16px;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.future-timeline{display:flex;flex-direction:column;gap:16px}
.ft-item{display:flex;gap:16px;align-items:flex-start}
.ft-dot{width:40px;height:40px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;color:#fff;font-size:.75rem;font-family:var(--f-ui);font-weight:700;flex-shrink:0}
.ft-content{flex:1;padding:12px 16px;background:var(--bg2);border-radius:var(--r-sm);border:1px solid var(--border)}
.ft-year{font-size:.78rem;color:var(--blue);font-family:var(--f-ui);font-weight:600;margin-bottom:2px}
.ft-text{font-size:.88rem;color:var(--text2);line-height:1.6}

/* Articles */
.articles-section{margin-bottom:56px}
.article-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.article-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;cursor:pointer;transition:all .4s;box-shadow:0 1px 4px rgba(0,0,0,.03)}
.article-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(37,99,235,0.08)}
.article-thumb{width:100%;height:140px;background:linear-gradient(135deg,rgba(37,99,235,0.06),rgba(79,70,229,0.04));display:flex;align-items:center;justify-content:center;font-size:2.5rem}
.article-body{padding:18px}
.article-cat{font-size:.7rem;color:var(--blue);font-family:var(--f-ui);font-weight:600;margin-bottom:4px}
.article-title{font-size:.92rem;font-weight:600;margin-bottom:6px;line-height:1.4}
.article-meta{font-size:.72rem;color:var(--muted);font-family:var(--f-ui)}

/* Modal */
.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(26,26,46,0.6);backdrop-filter:blur(8px);z-index:300;display:none;align-items:center;justify-content:center;padding:24px}
.modal-overlay.active{display:flex}
.modal{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);max-width:640px;width:100%;max-height:85vh;overflow-y:auto;padding:36px;position:relative;box-shadow:0 24px 80px rgba(0,0,0,.1);animation:modalIn .4s ease-out}
@keyframes modalIn{from{opacity:0;transform:translateY(24px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}
.modal-close{position:absolute;top:14px;right:14px;width:32px;height:32px;border-radius:50%;background:var(--blue-g);border:1px solid var(--border);color:var(--text2);cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center}
.modal-close:hover{background:var(--blue);color:#fff}
.modal-kw{font-family:var(--f-display);font-size:1.5rem;font-weight:700;margin-bottom:6px;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.modal-sub{font-size:.82rem;color:var(--muted);margin-bottom:20px;font-family:var(--f-ui)}
.modal-divider{height:2px;background:var(--border);margin:18px 0}
.modal-sec{font-size:1rem;font-weight:700;margin-bottom:10px;color:var(--blue);display:flex;align-items:center;gap:8px}
.modal-text{font-size:.9rem;color:var(--text2);line-height:2;margin-bottom:18px}
.modal-tags{display:flex;flex-wrap:wrap;gap:6px}
.modal-tag{padding:4px 12px;border-radius:100px;font-size:.75rem;background:var(--blue-g);color:var(--blue);font-family:var(--f-ui);font-weight:500}
.toast{position:fixed;bottom:28px;right:28px;z-index:400;background:var(--card);border:1px solid var(--blue);border-radius:var(--r-md);padding:14px 22px;box-shadow:0 8px 32px rgba(0,0,0,.1);display:none;font-size:.85rem;color:var(--text)}
.toast.active{display:flex;align-items:center;gap:10px;animation:fadeUp .4s ease-out}

/* Footer */
.site-footer{background:#fff;border-top:1px solid var(--border);padding:40px 24px 20px}
.footer-inner{max-width:1100px;margin:0 auto}
.footer-top{display:flex;gap:40px;flex-wrap:wrap;margin-bottom:28px}
.footer-brand{flex:1;min-width:240px}
.footer-brand-name{font-family:var(--f-display);font-size:1.2rem;font-weight:700;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:10px}
.footer-brand p{font-size:.8rem;color:var(--muted);line-height:1.8}
.footer-links{flex:1;min-width:140px}
.footer-links h4{font-size:.78rem;color:var(--muted);font-family:var(--f-ui);margin-bottom:10px;letter-spacing:.1em}
.footer-links a{display:block;font-size:.85rem;color:var(--text2);padding:3px 0}
.footer-network{margin-top:20px;padding-top:16px;border-top:1px solid var(--border)}
.footer-network h4{font-size:.78rem;color:var(--muted);font-family:var(--f-ui);margin-bottom:8px}
.footer-network-links{display:flex;gap:20px;flex-wrap:wrap}
.footer-network-links a{font-size:.82rem;color:var(--text2);display:flex;align-items:center;gap:6px}
.footer-network-links a:hover{color:var(--blue)}
.footer-bottom{border-top:1px solid var(--border);padding-top:16px;font-size:.75rem;color:var(--muted)}

/* WordPress specific */
.wp-block-post-content{max-width:800px;margin:0 auto;padding:120px 24px 60px}
.wp-block-post-content h1{font-family:var(--f-display);font-size:1.8rem;margin-bottom:16px}
.wp-block-post-content p{margin-bottom:16px;line-height:2}

@media(max-width:768px){
  .nav{display:none}
  .talent-axes{grid-template-columns:1fr 1fr}
  .talent-bars{grid-template-columns:1fr}
  .tdream-grid{grid-template-columns:1fr 1fr}
  .footer-top{flex-direction:column;gap:20px}
  .future-inputs{flex-direction:column;align-items:center}
}
@media(max-width:480px){
  .talent-axes{grid-template-columns:1fr}
  .tdream-grid{grid-template-columns:1fr}
}
