/* ============================================================
   BELLA TECH — works.css
   実績ページ専用スタイル。tokens.css + components.css に依存。
   トップ (style.css) から抽出してライト基調に調整。
   ============================================================ */

/* === WORKS GRID === */
.works-grid{display:grid;gap:120px;max-width:1200px;margin:0 auto}
.work-card{display:grid;grid-template-columns:1.2fr 0.8fr;gap:64px;align-items:center;position:relative}
.work-card:nth-child(even){grid-template-columns:0.8fr 1.2fr}
.work-card:nth-child(even) .work-thumb{order:2}
.work-card:nth-child(even) .work-info{order:1}
.work-thumb{position:relative}
.work-order{position:absolute;top:-32px;left:-20px;font-family:'Cormorant Garamond',serif;font-size:96px;font-weight:300;color:var(--accent);opacity:0.16;line-height:1;z-index:2;user-select:none}
.work-img-wrap{width:100%;aspect-ratio:4/3;border-radius:var(--radius-lg);overflow:hidden;position:relative;cursor:pointer;transition:transform .6s cubic-bezier(.16,1,.3,1);box-shadow:var(--shadow-md);border:1px solid var(--border)}
.work-card:hover .work-img-wrap{transform:scale(1.02);box-shadow:var(--shadow-lg)}
.work-img-wrap::before{content:'';position:absolute;top:0;left:-120%;width:80%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.18),transparent);z-index:10;pointer-events:none;transition:left .8s cubic-bezier(.16,1,.3,1)}
.work-card:hover .work-img-wrap::before{left:140%}

/* === Work screenshot overlay === */
.work-screenshot{position:absolute;top:0;left:0;width:100%;height:100%;z-index:3;opacity:0;transition:opacity .5s ease;pointer-events:none;background:#fff}
.work-screenshot.visible{opacity:1}
.work-screenshot img{width:100%;height:100%;display:block}
.work-ss-close{position:absolute;top:8px;right:8px;width:26px;height:26px;background:rgba(13,11,9,.75);border:none;border-radius:50%;color:#fff;font-size:13px;cursor:pointer;z-index:6;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s,background .3s;pointer-events:none;line-height:1}
.work-ss-close:hover{background:rgba(13,11,9,.9)}
.work-screenshot.visible+.work-ss-close{opacity:1;pointer-events:auto}
.work-hint{position:absolute;bottom:10px;right:12px;font-family:'Sora',sans-serif;font-size:9px;color:rgba(255,255,255,.65);z-index:5;pointer-events:none;letter-spacing:1px;background:rgba(13,11,9,.3);padding:4px 10px;border-radius:999px;backdrop-filter:blur(4px)}

/* === Triple screenshot grid (Jinnouchi) === */
.work-screenshot--triple{display:flex;gap:6px;padding:8px;background:#0a0a0a;align-items:stretch;justify-content:center}
.work-screenshot--triple > picture{flex:1 1 0;min-width:0;display:flex;align-items:center;justify-content:center;background:#000;border-radius:6px;overflow:hidden}
.work-screenshot--triple > picture > img{width:100%;height:100%;object-fit:contain;display:block}
@media(max-width:600px){
  .work-screenshot--triple{gap:4px;padding:4px}
}

/* === Static thumbnail (公開 HP のスクショ表示用) === */
.work-img-wrap--static{aspect-ratio:1912/819;background:#0a0a0a}
.work-img-wrap--static > picture,
.work-img-wrap--static > picture > img{width:100%;height:100%;display:block;object-fit:cover}

/* === Miniature UI shared === */
.mini-ui{width:100%;height:100%;position:relative;padding:0;font-family:'Sora',sans-serif;color:rgba(255,255,255,.92);display:flex;flex-direction:column;user-select:none;filter:brightness(.9);transition:filter .5s ease}
.work-card:hover .mini-ui{filter:brightness(1)}
.mini-ui *{box-sizing:border-box}
.thumb-1-bg{background:linear-gradient(135deg,#1a2a3a,#2c4050)}
.thumb-2-bg{background:linear-gradient(135deg,#1e3a2e,#2a5040)}
.thumb-3-bg{background:linear-gradient(135deg,#fff5ee,#fde8d8)}
.thumb-4-bg{background:linear-gradient(135deg,#2a1e3a,#403050)}
.thumb-5-bg{background:linear-gradient(135deg,#0d3a2e,#1f5544)}

/* === 1. Shift Manager === */
.shift-ui{gap:0}
.shift-header{display:flex;align-items:center;gap:8px;padding:8px 12px;background:rgba(0,0,0,.2)}
.shift-line-icon{width:22px;height:22px;background:#06c755;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.shift-line-icon svg{width:14px;height:14px}
.shift-title{font-size:9px;letter-spacing:1.5px;opacity:.7;text-transform:uppercase;flex:1}
.shift-date{font-size:7px;color:rgba(184,150,62,.8);letter-spacing:1px}
.shift-table{flex:1;display:flex;flex-direction:column;gap:1px;overflow:hidden;padding:4px}
.shift-row{display:flex;gap:1px;flex:1}
.shift-cell{flex:1;background:rgba(255,255,255,.04);border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:7px;color:rgba(255,255,255,.35);position:relative;transition:background .4s,color .4s,box-shadow .4s}
.shift-cell.head{background:rgba(184,150,62,.15);color:rgba(184,150,62,.9);font-size:8px;font-weight:600;letter-spacing:1px}
.shift-cell.name{background:rgba(255,255,255,.07);color:rgba(255,255,255,.6);font-size:7px;text-align:left;padding-left:6px;flex:0 0 15%}
.shift-cell .bar{position:absolute;bottom:3px;left:12%;right:12%;height:4px;border-radius:2px;opacity:.4;transition:opacity .4s,background .4s}
.shift-cell.confirmed{background:rgba(184,150,62,.15)}
.shift-cell.confirmed .bar{opacity:.8;background:#b8963e}
.shift-cell.glow{background:rgba(184,150,62,.35);box-shadow:0 0 12px rgba(184,150,62,.6),inset 0 0 8px rgba(184,150,62,.3);color:#fff}
.shift-cell.glow .bar{opacity:1;background:#d4aa4f}
@keyframes shiftGlow{0%{box-shadow:0 0 16px rgba(184,150,62,.8),inset 0 0 10px rgba(184,150,62,.4)}100%{box-shadow:0 0 4px rgba(184,150,62,.2),inset 0 0 2px rgba(184,150,62,.1)}}
.shift-status{padding:6px 12px;display:flex;align-items:center;gap:8px;background:rgba(0,0,0,.15)}
.shift-bar-track{flex:1;height:4px;background:rgba(255,255,255,.1);border-radius:2px;overflow:hidden}
.shift-bar-fill{height:100%;background:linear-gradient(90deg,#b8963e,#d4aa4f);border-radius:2px;transition:width .8s ease}
.shift-bar-text{font-size:7px;color:rgba(255,255,255,.5);white-space:nowrap}
.shift-line-notif{position:absolute;top:12px;right:12px;background:#06c755;color:#fff;border-radius:8px;padding:5px 10px;font-size:7px;z-index:8;box-shadow:0 4px 12px rgba(6,199,85,.4);opacity:0;transform:translateX(30px);transition:opacity .4s,transform .4s;display:flex;align-items:center;gap:4px;white-space:nowrap}
.shift-line-notif.show{opacity:1;transform:translateX(0)}
.shift-line-notif .notif-icon{width:12px;height:12px;background:rgba(255,255,255,.2);border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:7px}

/* === 2. Facility Map - Globe === */
.map-ui{padding:0;flex-direction:column;position:relative}
.map-scene{width:100%;height:100%;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.map-globe{position:absolute;width:70%;aspect-ratio:1;border-radius:50%;border:1.5px solid rgba(184,150,62,.3);overflow:hidden;transition:transform 2.5s cubic-bezier(.25,.46,.45,.94),opacity 1s ease,width 2.5s cubic-bezier(.25,.46,.45,.94);box-shadow:0 0 40px rgba(184,150,62,.08),inset 0 0 30px rgba(184,150,62,.05)}
.map-globe.zoom{transform:scale(4);opacity:0;width:70%}
.map-globe-lines{position:absolute;inset:-50%;width:200%;height:200%;animation:globeSpin 12s linear infinite}
@keyframes globeSpin{0%{transform:rotateZ(0deg)}100%{transform:rotateZ(360deg)}}
.map-globe-lat,.map-globe-lon{position:absolute;border-radius:50%;border:1px solid rgba(184,150,62,.15)}
.map-globe-lat{left:10%;right:10%;height:0;border-width:0.5px}
.map-globe-lon{top:10%;bottom:10%;width:0;border-width:0.5px}
.map-globe-highlight{position:absolute;width:12px;height:12px;background:rgba(184,150,62,.5);border-radius:50%;filter:blur(4px);animation:globePulse 2s ease-in-out infinite}
@keyframes globePulse{0%,100%{opacity:.4;transform:scale(1)}50%{opacity:.8;transform:scale(1.3)}}
.map-globe-label{position:absolute;bottom:15%;left:50%;transform:translateX(-50%);font-size:8px;color:rgba(184,150,62,.6);letter-spacing:3px;text-transform:uppercase;white-space:nowrap}
.map-detail{position:absolute;inset:0;opacity:0;transition:opacity .6s ease}
.map-detail.show{opacity:1}
.map-roads{position:absolute;inset:0}
.map-road{position:absolute;background:rgba(255,255,255,.08);border-radius:1px}
.map-block{position:absolute;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.05);border-radius:3px}
.map-pin{position:absolute;transform:translate(-50%,-100%);z-index:2;opacity:0}
.map-pin.drop{animation:pinDrop .6s cubic-bezier(.34,1.56,.64,1) forwards}
@keyframes pinDrop{0%{opacity:0;transform:translate(-50%,-100%) translateY(-30px)}100%{opacity:1;transform:translate(-50%,-100%) translateY(0)}}
.map-pin-body{width:12px;height:16px;position:relative;display:flex;flex-direction:column;align-items:center}
.map-pin-head{width:12px;height:12px;background:#b8963e;border-radius:50% 50% 50% 0;transform:rotate(-45deg);border:1.5px solid rgba(255,255,255,.6);box-shadow:0 0 8px rgba(184,150,62,.5);position:relative}
.map-pin-head::after{content:'';position:absolute;top:3px;left:3px;width:4px;height:4px;background:rgba(255,255,255,.7);border-radius:50%}
.map-pin-ripple{position:absolute;bottom:-2px;left:50%;width:12px;height:12px;transform:translateX(-50%);border-radius:50%;border:1.5px solid rgba(184,150,62,.5);animation:pinRipple 2s ease-out infinite;opacity:0}
.map-pin-ripple.r2{animation-delay:.7s}
@keyframes pinRipple{0%{width:4px;height:4px;opacity:.8}100%{width:24px;height:24px;opacity:0}}
.map-popup{position:absolute;z-index:5;background:rgba(20,45,35,.95);border:1px solid rgba(184,150,62,.4);border-radius:6px;padding:6px 10px;min-width:80px;pointer-events:none;box-shadow:0 4px 16px rgba(0,0,0,.4);opacity:0;transition:opacity .3s}
.map-popup.show{opacity:1}
.map-popup::after{content:'';position:absolute;bottom:-5px;left:50%;transform:translateX(-50%);border-left:5px solid transparent;border-right:5px solid transparent;border-top:5px solid rgba(20,45,35,.95)}
.map-popup-name{font-size:8px;font-weight:600;color:rgba(255,255,255,.95);margin-bottom:2px}
.map-popup-info{font-size:7px;color:rgba(184,150,62,.9)}
.map-count{position:absolute;bottom:8px;right:10px;font-size:7px;color:rgba(255,255,255,.4);z-index:3}

/* === 3. Meal Randomizer === */
.meal-ui{align-items:center;justify-content:center;gap:10px;padding:14px;position:relative}
.meal-particles{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.meal-particle{position:absolute;width:3px;height:3px;background:rgba(230,120,80,.3);border-radius:50%;animation:mealFloat 4s ease-in-out infinite}
@keyframes mealFloat{0%,100%{transform:translateY(0) scale(1);opacity:.2}50%{transform:translateY(-20px) scale(1.5);opacity:.5}}
.meal-sub{font-size:8px;color:rgba(120,80,50,.4);letter-spacing:2px;z-index:1;text-transform:uppercase}
.meal-result{width:60%;background:#fff;border-radius:14px;padding:14px;text-align:center;position:relative;overflow:hidden;border:1px solid rgba(0,0,0,.06);z-index:1;min-height:75px;display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(0,0,0,.06)}
.meal-card-inner{transition:transform .4s cubic-bezier(.4,0,.2,1),opacity .3s}
.meal-card-inner.slide-out{transform:translateY(40px);opacity:0}
.meal-card-inner.slide-in{transform:translateY(0);opacity:1}
.meal-color-bar{width:60%;height:4px;border-radius:2px;margin:0 auto 6px;transition:background .3s}
.meal-name{font-size:16px;font-weight:700;color:#2a1e14}
.meal-tags{display:flex;gap:4px;margin-top:6px;justify-content:center;flex-wrap:wrap}
.meal-tag{font-size:7px;padding:2px 8px;border-radius:8px;letter-spacing:.5px;font-weight:500}
.meal-tag-meat{background:rgba(220,60,50,.12);color:#c0392b}
.meal-tag-fish{background:rgba(50,120,200,.12);color:#2e86c1}
.meal-tag-veg{background:rgba(50,180,80,.12);color:#27ae60}
.meal-tag-quick{background:rgba(230,140,30,.12);color:#d68910}
.meal-tag-default{background:rgba(160,120,80,.1);color:#8b6914}
.meal-float-tags{position:absolute;inset:0;pointer-events:none;z-index:0}
.meal-float-tag{position:absolute;font-size:8px;font-weight:500;animation:floatTag 6s ease-in-out infinite;letter-spacing:1px}
.meal-float-tag.ft-meat{color:rgba(220,60,50,.18)}
.meal-float-tag.ft-fish{color:rgba(50,120,200,.15)}
.meal-float-tag.ft-veg{color:rgba(50,180,80,.15)}
.meal-float-tag.ft-quick{color:rgba(230,140,30,.18)}
.meal-float-tag.ft-default{color:rgba(160,120,80,.12)}
@keyframes floatTag{0%,100%{transform:translateY(0) rotate(-3deg)}50%{transform:translateY(-8px) rotate(3deg)}}
.meal-btn{width:68px;height:68px;border-radius:50%;background:linear-gradient(135deg,#e8734a,#f09060);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;box-shadow:0 6px 24px rgba(232,115,74,.35);z-index:1;animation:mealPulse 2s ease-in-out infinite;text-shadow:0 1px 2px rgba(0,0,0,.15);border:none;cursor:pointer;font-family:'Zen Kaku Gothic New',sans-serif}
@keyframes mealPulse{0%,100%{box-shadow:0 6px 24px rgba(232,115,74,.35);transform:scale(1)}50%{box-shadow:0 8px 32px rgba(232,115,74,.5);transform:scale(1.06)}}
.meal-bot{position:absolute;bottom:6px;right:6px;z-index:1;opacity:.55;pointer-events:none}

/* === 5. Jinnouchi - LINE+GAS Flow === */
.jin-ui{flex-direction:row;padding:14px 12px;gap:8px;align-items:stretch}
.jin-line-frame,.jin-sheet-frame{flex:1;min-width:0;display:flex;flex-direction:column}
.jin-flow{flex:0 0 18%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;position:relative}
.jin-phone{flex:1;background:rgba(0,0,0,.35);border-radius:14px;border:1px solid rgba(255,255,255,.1);padding:8px 6px;display:flex;flex-direction:column;gap:6px;overflow:hidden}
.jin-line-header{font-size:8px;letter-spacing:2px;color:rgba(255,255,255,.55);text-align:center}
.jin-line-body{flex:1;position:relative}
.jin-rich-menu{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(2,1fr);gap:3px;height:100%}
.jin-rich-tile{background:rgba(6,199,85,.15);border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:7px;color:rgba(255,255,255,.75);letter-spacing:.5px}
.jin-form{display:flex;flex-direction:column;gap:5px;height:100%;padding:4px}
.jin-form-row{background:rgba(255,255,255,.07);border-radius:3px;height:11px}
.jin-form-row.fill{background:rgba(6,199,85,.4)}
.jin-form-submit{margin-top:auto;background:#06c755;color:#fff;border-radius:4px;text-align:center;font-size:7px;padding:5px 0;letter-spacing:.5px}
.jin-line-body > *{position:absolute;inset:0;opacity:0;transition:opacity .6s ease;pointer-events:none}
.jin-line-body > *.show{opacity:1}
.jin-arrow{font-size:18px;color:rgba(184,150,62,.45);font-weight:300;line-height:1}
.jin-dots{position:relative;width:80%;height:2px;background:rgba(255,255,255,.06);border-radius:2px;overflow:visible}
.jin-dot{position:absolute;top:-2px;width:6px;height:6px;background:#06c755;border-radius:50%;box-shadow:0 0 8px rgba(6,199,85,.6);opacity:0}
.jin-dot.run{animation:jinDot 1.6s linear forwards}
@keyframes jinDot{0%{left:-10%;opacity:0}10%{opacity:1}90%{opacity:1}100%{left:110%;opacity:0}}
.jin-flow-label{font-size:7px;letter-spacing:1px;color:rgba(184,150,62,.7);opacity:.4;transition:opacity .3s;text-align:center;line-height:1.2}
.jin-flow-label.glow{opacity:1;text-shadow:0 0 6px rgba(184,150,62,.5)}
.jin-sheet-card{background:rgba(184,150,62,.18);border-radius:4px;padding:4px 8px;font-size:7px;color:rgba(255,255,255,.85);margin-bottom:4px;letter-spacing:.5px;display:flex;align-items:center;gap:4px}
.jin-sheet{flex:1;display:flex;flex-direction:column;gap:1px;background:rgba(0,0,0,.25);border-radius:4px;padding:3px;overflow:hidden}
.jin-sheet-row{display:flex;gap:1px;font-size:6px;color:rgba(255,255,255,.5);padding:2px 3px;border-radius:2px;background:rgba(255,255,255,.03);transition:background .3s,color .3s}
.jin-sheet-row.head{background:rgba(184,150,62,.2);color:rgba(255,255,255,.85);font-weight:600}
.jin-sheet-row.fresh{animation:jinFresh 2s ease forwards;color:#fff}
@keyframes jinFresh{0%{background:rgba(6,199,85,.5)}100%{background:rgba(6,199,85,.1)}}
.jin-sheet-cell{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.jin-sheet-cell.c1{flex:0 0 30%}
.jin-sheet-cell.c2{flex:0 0 35%}
.jin-sheet-cell.c3{flex:0 0 35%}
@media(max-width:600px){
  .jin-flow{flex:0 0 14%}
  .jin-arrow{font-size:14px}
  .jin-flow-label{font-size:6px}
  .jin-rich-tile{font-size:6px}
  .jin-form-submit{font-size:6px}
}

/* === Work info (light theme) === */
.work-cat{margin:0 0 16px;display:block}
.work-cat-service{display:inline-block;font-family:'Zen Kaku Gothic New',sans-serif;font-size:13px;letter-spacing:1.5px;color:var(--accent-dark);font-weight:700;background:var(--accent-soft);padding:5px 14px;border-radius:999px;margin:0 0 8px}
.work-cat-tech{display:block;font-family:'Sora',sans-serif;font-size:11px;letter-spacing:2.5px;text-transform:uppercase;color:var(--text-muted);font-weight:600}
.work-name{font-family:'Cormorant Garamond',serif;font-size:clamp(26px,3vw,32px);font-weight:600;margin-bottom:20px;line-height:1.3;text-wrap:balance;color:var(--text)}
.work-desc{font-size:15px;color:var(--text);line-height:2;margin-bottom:24px;font-weight:400}
.work-tags{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.work-tag{font-family:'Sora',sans-serif;font-size:12px;padding:6px 16px;border-radius:24px;border:1px solid var(--border);color:var(--text-muted);letter-spacing:1px;transition:all .3s;text-transform:uppercase;background:var(--bg-panel)}
.work-tag:hover{border-color:var(--accent);color:var(--accent-dark);background:var(--accent-soft)}
.work-note{font-size:13px;color:var(--text);margin-top:16px;font-style:italic;line-height:1.7}
.work-link{display:inline-flex;align-items:center;gap:8px;margin-top:16px;font-family:'Sora',sans-serif;font-size:12px;letter-spacing:2.5px;text-transform:uppercase;color:var(--accent-dark);text-decoration:none;border-bottom:1px solid var(--accent);padding-bottom:2px;transition:color .3s;font-weight:600}
.work-link:hover{color:var(--accent)}
.work-link-sub{display:inline-flex;align-items:center;gap:6px;margin-top:12px;font-family:'Sora',sans-serif;font-size:12px;letter-spacing:2px;color:var(--text);text-decoration:none;text-transform:uppercase;opacity:.85;transition:opacity .3s,color .3s;font-weight:600}
.work-link-sub:hover{opacity:1;color:var(--accent-dark)}

/* === Detail block (課題 / 解決 / 成果) === */
.work-detail{display:grid;gap:20px;margin:0 0 22px;padding:22px 0 0;border-top:1px dashed var(--border-strong)}
.work-detail-row{display:block}
.work-detail-label{display:block;font-family:'Zen Kaku Gothic New',sans-serif;font-size:13px;letter-spacing:1.5px;color:var(--accent-dark);font-weight:700;line-height:1.4;margin:0 0 8px;padding:0}
.work-detail-label::before{content:"【"}
.work-detail-label::after{content:"】"}
.work-detail-text{font-size:15px;line-height:1.9;color:var(--text);margin:0}
.work-result-highlight{padding:12px 16px;background:var(--accent-soft);border-left:3px solid var(--accent);border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-weight:600;color:var(--text)}

/* Work voice (案件に紐付く声 — アバター差し込み枠付き) */
.work-voice{display:block;margin:28px 0 0;padding:26px 28px;background:var(--bg-panel);border-left:2px solid var(--accent);border-radius:0 var(--radius-sm) var(--radius-sm) 0;position:relative}
.work-voice-text{font-family:'Zen Kaku Gothic New',sans-serif;font-size:16px;line-height:2;color:var(--text);margin:0 0 22px;font-weight:500;text-wrap:pretty;letter-spacing:0.2px}
.work-voice-meta{display:flex;align-items:center;gap:14px;margin:0}
.work-voice-avatar{width:100px;height:130px;border-radius:10px;overflow:hidden;background:rgba(196,163,90,0.14);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.work-voice-avatar > img,
.work-voice-avatar > picture,
.work-voice-avatar > picture > img{width:100%;height:100%;object-fit:cover;display:block}
.work-voice-avatar-icon{width:100%;height:100%;background-image:url('../images/bellabot-face.svg');background-size:96%;background-repeat:no-repeat;background-position:center;display:block}
.work-voice-avatar--logo{background:#c4ed75}
.work-voice-avatar--logo > picture > img{object-fit:contain}
.work-voice-attribution{display:block;min-width:0;line-height:1.7;flex:1 1 0}
.work-voice-name{font-family:'Zen Kaku Gothic New',sans-serif;font-size:15px;color:var(--text);font-weight:700;letter-spacing:0;white-space:nowrap}
.work-voice-role{font-family:'Zen Kaku Gothic New',sans-serif;font-size:14px;color:var(--text);letter-spacing:0;white-space:nowrap}
.work-voice-role::before{content:"／";color:var(--border-strong);margin:0 6px;font-weight:400;white-space:normal}

/* === Category filter === */
.works-filter{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:0 auto 80px;max-width:900px}

/* === Responsive === */
@media(max-width:900px){
  .works-grid{gap:80px}
  .work-card,.work-card:nth-child(even){grid-template-columns:1fr;gap:36px}
  .work-card:nth-child(even) .work-thumb,.work-card:nth-child(even) .work-info{order:unset}
  .work-order{display:none}
}
@media(max-width:600px){
  .works-grid{gap:48px;padding:0 4px}
  .work-card:not(:last-child){padding-bottom:48px;border-bottom:1px dashed var(--border-strong)}
  .work-detail{padding:22px 0 0;gap:18px}
  .work-voice{padding:24px 22px}
  .work-voice-text{font-size:15px;line-height:1.95}
  .work-voice-meta{gap:12px}
  .work-voice-avatar{width:84px;height:108px;border-radius:8px}
  .work-voice-name{font-size:14px}
  .work-voice-role{font-size:13px}
  .work-voice-role::before{margin:0 4px}
}
@media(max-width:480px){
  .works-grid{gap:36px;padding:0 2px}
  .work-card:not(:last-child){padding-bottom:36px}
  .work-name{font-size:22px}
}

/* ============================================================
   === Portfolio Samples Section ===
   ============================================================ */
.section-panel--samples{padding-top:64px}
.samples-header{text-align:center;max-width:760px;margin:0 auto 64px}
.samples-header .section-eyebrow{margin-bottom:14px}
.samples-header .section-title{margin-bottom:18px}
.samples-header .section-lead{color:var(--text);font-size:15px;line-height:1.95;margin:0}
.samples-note{display:inline-block;margin-top:18px;padding:8px 18px;background:var(--accent-soft);border:1px solid var(--border);border-radius:999px;font-family:'Sora',sans-serif;font-size:12px;color:var(--accent-dark);font-weight:600;letter-spacing:1.5px;text-transform:uppercase}
.samples-note svg{width:12px;height:12px;vertical-align:-2px;margin-right:6px}

.samples-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;max-width:1200px;margin:0 auto}
.sample-card{appearance:none;background:transparent;border:none;padding:0;margin:0;cursor:pointer;text-align:left;display:flex;flex-direction:column;gap:14px;font-family:inherit;color:inherit;transition:transform .5s cubic-bezier(.16,1,.3,1)}
.sample-card:hover{transform:translateY(-4px)}
.sample-card:focus-visible{outline:2px solid var(--accent);outline-offset:6px;border-radius:var(--radius-lg)}
.sample-thumb{position:relative;width:100%;aspect-ratio:16/9;overflow:hidden;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--border);background:var(--bg-panel);transition:box-shadow .5s cubic-bezier(.16,1,.3,1)}
.sample-card:hover .sample-thumb{box-shadow:var(--shadow-lg)}
.sample-thumb::before{content:'';position:absolute;top:0;left:-120%;width:80%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.22),transparent);z-index:3;pointer-events:none;transition:left .8s cubic-bezier(.16,1,.3,1)}
.sample-card:hover .sample-thumb::before{left:140%}
.sample-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .8s cubic-bezier(.16,1,.3,1)}
.sample-card:hover .sample-thumb img{transform:scale(1.05)}
.sample-thumb-icon{position:absolute;bottom:10px;right:10px;width:32px;height:32px;border-radius:50%;background:rgba(13,11,9,.6);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;color:#fff;z-index:4;opacity:.85;transition:opacity .3s,transform .3s}
.sample-card:hover .sample-thumb-icon{opacity:1;transform:scale(1.08)}
.sample-thumb-icon svg{width:14px;height:14px}
.sample-meta{padding:0 4px}
.sample-cat{display:inline-block;font-family:'Sora',sans-serif;font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:var(--accent-dark);font-weight:700;margin-bottom:6px}
.sample-title{font-family:'Zen Kaku Gothic New',sans-serif;font-size:15px;font-weight:700;color:var(--text);line-height:1.55;margin:0;text-wrap:balance}

@media(max-width:1024px){
  .samples-grid{grid-template-columns:repeat(2,1fr);gap:28px}
}
@media(max-width:640px){
  .samples-grid{grid-template-columns:1fr;gap:24px}
  .samples-header{margin-bottom:48px}
  .sample-title{font-size:14px}
}

/* === Lightbox === */
.lightbox{position:fixed;inset:0;z-index:9999;background:rgba(13,11,9,.92);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:none;align-items:flex-start;justify-content:center;padding:64px 16px 24px;overflow-y:auto;overscroll-behavior:contain;touch-action:pan-y pinch-zoom}
.lightbox.is-open{display:flex}
.lightbox-stage{position:relative;width:min(100%,1100px);margin:0 auto;display:flex;flex-direction:column;gap:14px;animation:lightboxIn .35s cubic-bezier(.16,1,.3,1)}
@keyframes lightboxIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.lightbox-stage img{width:100%;height:auto;display:block;border-radius:8px;box-shadow:0 24px 80px rgba(0,0,0,.55);background:#1a1714}
.lightbox-caption{font-family:'Zen Kaku Gothic New',sans-serif;font-size:14px;color:rgba(245,242,237,.88);text-align:center;letter-spacing:.5px;padding:4px 0 12px;line-height:1.6}
.lightbox-close{position:fixed;top:16px;right:16px;width:44px;height:44px;background:rgba(245,242,237,.14);border:1px solid rgba(245,242,237,.22);border-radius:50%;color:#fff;font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10000;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:background .25s,transform .25s;line-height:1;font-family:'Sora',sans-serif}
.lightbox-close:hover{background:rgba(245,242,237,.24);transform:scale(1.06)}
.lightbox-close:focus-visible{outline:2px solid var(--accent);outline-offset:3px}

@media(max-width:640px){
  .lightbox{padding:64px 8px 16px}
  .lightbox-stage{width:96vw;gap:10px}
  .lightbox-close{width:40px;height:40px;top:12px;right:12px;font-size:20px}
  .lightbox-caption{font-size:13px}
}

@media(prefers-reduced-motion: reduce){
  .sample-card,.sample-thumb,.sample-thumb img,.sample-thumb::before,.sample-thumb-icon,.lightbox-stage{transition:none !important;animation:none !important}
  .sample-card:hover{transform:none}
  .sample-card:hover .sample-thumb img{transform:none}
  .sample-card:hover .sample-thumb::before{left:-120%}
  .sample-card:hover .sample-thumb-icon{transform:none}
}
