/* ═══════════════════════════════════════════
   CRM DEMO — Activities Page Styles
   ═══════════════════════════════════════════ */

/* ─── STATS BAR ─── */
.act-stats{
  display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap;
}
.act-stat-chip{
  display:flex;align-items:center;gap:10px;
  padding:12px 20px;border-radius:var(--radius-lg);
  background:var(--surface);border:1px solid var(--border);
  min-width:140px;transition:all .3s var(--ease);
}
.act-stat-chip:hover{
  border-color:var(--border2);box-shadow:var(--shadow);transform:translateY(-1px);
}
.act-stat-dot{
  width:36px;height:36px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  font-size:.85rem;flex-shrink:0;position:relative;
}
.act-stat-dot::after{
  content:'';position:absolute;inset:-3px;border-radius:13px;
  background:inherit;opacity:.2;filter:blur(6px);pointer-events:none;
}
.act-stat-dot.blue{background:rgba(59,130,246,.12);color:#60a5fa}
.act-stat-dot.green{background:rgba(34,197,94,.1);color:#4ade80}
.act-stat-dot.purple{background:rgba(168,85,247,.1);color:#c084fc}
.act-stat-dot.gray{background:rgba(100,116,139,.1);color:#94a3b8}
.act-stat-dot.amber{background:rgba(245,158,11,.1);color:#fbbf24}
.act-stat-info .act-stat-label{font-size:.7rem;color:var(--muted);margin-bottom:2px}
.act-stat-info .act-stat-value{
  font-size:1.25rem;font-weight:800;font-family:var(--en);line-height:1;
}

/* ─── VIEW TOGGLE ─── */
.act-view-toggle{
  display:inline-flex;border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--border);background:var(--surface2);
}
.act-view-btn{
  padding:8px 18px;border:none;background:transparent;
  color:var(--muted);font-size:.8rem;font-weight:600;cursor:pointer;
  display:flex;align-items:center;gap:6px;
  transition:all .25s var(--ease);font-family:var(--font);
}
.act-view-btn:not(:last-child){border-right:1px solid var(--border)}
.act-view-btn:hover{color:var(--text2);background:rgba(255,255,255,.03)}
.act-view-btn.active{
  background:linear-gradient(135deg,var(--accent),#2563eb);
  color:#fff;
  box-shadow:0 2px 8px rgba(59,130,246,.2);
}
.act-view-btn i{font-size:.75rem}

/* ─── FILTER BAR ─── */
.act-filters{
  display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:20px;
}
.act-filters .e-select,
.act-filters .e-input{max-width:180px}

/* ─── TIMELINE VIEW ─── */
.act-timeline{
  position:relative;padding-left:50px;
}
.act-timeline::before{
  content:'';position:absolute;left:15px;top:0;bottom:0;width:2px;
  background:linear-gradient(180deg,var(--accent),var(--purple),var(--border));
  border-radius:2px;
}

/* Date separator */
.act-tl-date{
  position:relative;margin:28px 0 16px;
  display:flex;align-items:center;gap:14px;
}
.act-tl-date::before{
  content:'';position:absolute;left:-33px;top:50%;transform:translateY(-50%);
  width:12px;height:12px;border-radius:50%;
  background:var(--surface);border:2px solid var(--accent);
  box-shadow:0 0 0 4px var(--bg),0 0 12px rgba(59,130,246,.3);
  z-index:2;
}
.act-tl-date-label{
  font-size:.78rem;font-weight:700;color:var(--text2);
  padding:5px 16px;border-radius:20px;
  background:var(--surface2);border:1px solid var(--border);
  white-space:nowrap;
}
.act-tl-date-line{
  flex:1;height:1px;background:var(--border);
}

/* Timeline entry */
.act-tl-entry{
  position:relative;margin-bottom:16px;
  opacity:0;transform:translateY(20px);
  animation:actFadeIn .5s var(--ease) both;
}
.act-tl-entry:nth-child(1){animation-delay:.05s}
.act-tl-entry:nth-child(2){animation-delay:.1s}
.act-tl-entry:nth-child(3){animation-delay:.15s}
.act-tl-entry:nth-child(4){animation-delay:.2s}
.act-tl-entry:nth-child(5){animation-delay:.25s}
.act-tl-entry:nth-child(6){animation-delay:.3s}
.act-tl-entry:nth-child(7){animation-delay:.35s}
.act-tl-entry:nth-child(8){animation-delay:.4s}

@keyframes actFadeIn{
  from{opacity:0;transform:translateY(20px)}
  to{opacity:1;transform:translateY(0)}
}

/* Node on timeline */
.act-tl-node{
  position:absolute;left:-48px;top:12px;
  width:42px;height:42px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:1rem;z-index:2;
  transition:all .3s var(--ease);
}
.act-tl-node::after{
  content:'';position:absolute;inset:-5px;border-radius:50%;
  background:inherit;opacity:.25;filter:blur(10px);
  pointer-events:none;transition:opacity .3s;
}
.act-tl-entry:hover .act-tl-node::after{opacity:.5}
.act-tl-entry:hover .act-tl-node{transform:scale(1.1)}

/* Type colors */
.act-tl-node.type-미팅{background:rgba(59,130,246,.2);color:#60a5fa;border:2px solid rgba(59,130,246,.45);box-shadow:0 0 14px rgba(59,130,246,.15)}
.act-tl-node.type-전화{background:rgba(34,197,94,.2);color:#4ade80;border:2px solid rgba(34,197,94,.45);box-shadow:0 0 14px rgba(34,197,94,.15)}
.act-tl-node.type-이메일{background:rgba(168,85,247,.2);color:#c084fc;border:2px solid rgba(168,85,247,.45);box-shadow:0 0 14px rgba(168,85,247,.15)}
.act-tl-node.type-메모{background:rgba(100,116,139,.2);color:#94a3b8;border:2px solid rgba(100,116,139,.4);box-shadow:0 0 10px rgba(100,116,139,.1)}
.act-tl-node.type-방문{background:rgba(245,158,11,.2);color:#fbbf24;border:2px solid rgba(245,158,11,.45);box-shadow:0 0 14px rgba(245,158,11,.15)}

/* Card */
.act-tl-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:16px 20px;
  transition:all .3s var(--ease);cursor:pointer;position:relative;overflow:hidden;
}
.act-tl-card::before{
  content:'';position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(135deg,rgba(59,130,246,.02),rgba(139,92,246,.01));
  opacity:0;transition:opacity .3s;pointer-events:none;
}
.act-tl-card:hover{
  border-color:var(--border2);box-shadow:var(--shadow);transform:translateX(4px);
}
.act-tl-card:hover::before{opacity:1}

.act-tl-top{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:8px;gap:12px;
}
.act-tl-time{
  font-size:.75rem;color:var(--muted);font-family:var(--en);font-weight:500;
  display:flex;align-items:center;gap:6px;
}
.act-tl-time i{font-size:.6rem}
.act-tl-duration{
  font-size:.68rem;color:var(--dim);
  padding:2px 8px;border-radius:10px;
  background:var(--surface2);
}

.act-tl-subject{
  font-size:.88rem;font-weight:600;color:var(--text);
  margin-bottom:6px;line-height:1.4;
}
.act-tl-customer{
  font-size:.76rem;color:var(--accent);font-weight:500;
  margin-bottom:6px;display:flex;align-items:center;gap:5px;
}
.act-tl-customer i{font-size:.6rem}
.act-tl-content{
  font-size:.78rem;color:var(--muted);line-height:1.5;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;
  overflow:hidden;margin-bottom:8px;
}
.act-tl-bottom{
  display:flex;align-items:center;justify-content:space-between;gap:8px;
}
.act-tl-result{
  display:inline-flex;align-items:center;gap:4px;
  padding:3px 10px;border-radius:20px;
  font-size:.68rem;font-weight:600;
  background:rgba(34,197,94,.08);color:#4ade80;
  border:1px solid rgba(34,197,94,.08);
}
.act-tl-actions{display:flex;gap:4px}

/* ─── CALENDAR VIEW ─── */
.act-calendar{display:none}
.act-calendar.active{display:block}
.act-timeline-wrap{display:none}
.act-timeline-wrap.active{display:block}

.act-cal-header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:16px;
}
.act-cal-title{
  font-size:1.1rem;font-weight:700;
  display:flex;align-items:center;gap:10px;
}
.act-cal-nav{display:flex;gap:6px}

.act-cal-grid{
  display:grid;grid-template-columns:repeat(7,1fr);
  border:1px solid var(--border);border-radius:var(--radius-lg);
  overflow:hidden;background:var(--surface);
}
.act-cal-dow{
  padding:10px;text-align:center;
  font-size:.7rem;font-weight:700;color:var(--muted);
  letter-spacing:.5px;text-transform:uppercase;
  background:var(--surface2);border-bottom:1px solid var(--border);
}
.act-cal-dow:not(:last-child){border-right:1px solid var(--border)}
.act-cal-dow.sun{color:var(--red)}
.act-cal-dow.sat{color:var(--accent)}

.act-cal-cell{
  min-height:100px;padding:8px;
  border-right:1px solid var(--border);
  border-bottom:1px solid var(--border);
  cursor:pointer;transition:all .2s var(--ease);
  position:relative;
}
.act-cal-cell:nth-child(7n){border-right:none}
.act-cal-cell:hover{background:rgba(59,130,246,.02)}
.act-cal-cell.other-month{opacity:.3}
.act-cal-cell.today{
  background:rgba(59,130,246,.04);
}
.act-cal-cell.today .act-cal-day{
  background:var(--accent);color:#fff;
  width:24px;height:24px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
}
.act-cal-cell.selected{
  background:rgba(59,130,246,.06);
  box-shadow:inset 0 0 0 2px rgba(59,130,246,.2);
}
.act-cal-day{
  font-size:.78rem;font-weight:600;color:var(--text2);
  margin-bottom:6px;font-family:var(--en);
}
.act-cal-cell:nth-child(7n+1) .act-cal-day{color:var(--red)}
.act-cal-cell:nth-child(7n) .act-cal-day{color:var(--accent)}

.act-cal-dots{display:flex;flex-direction:column;gap:3px}
.act-cal-dot{
  font-size:.62rem;padding:2px 6px;border-radius:4px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  font-weight:500;line-height:1.3;
}
.act-cal-dot.type-미팅{background:rgba(59,130,246,.12);color:#60a5fa}
.act-cal-dot.type-전화{background:rgba(34,197,94,.1);color:#4ade80}
.act-cal-dot.type-이메일{background:rgba(168,85,247,.1);color:#c084fc}
.act-cal-dot.type-메모{background:rgba(100,116,139,.1);color:#94a3b8}
.act-cal-dot.type-방문{background:rgba(245,158,11,.1);color:#fbbf24}
.act-cal-more{
  font-size:.6rem;color:var(--muted);font-weight:600;
  padding:1px 4px;cursor:pointer;
}

/* Day detail panel */
.act-cal-detail{
  margin-top:16px;background:var(--surface);
  border:1px solid var(--border);border-radius:var(--radius-lg);
  overflow:hidden;display:none;
}
.act-cal-detail.open{display:block;animation:actFadeIn .3s var(--ease) both}
.act-cal-detail-head{
  padding:14px 20px;border-bottom:1px solid var(--border);
  display:flex;justify-content:space-between;align-items:center;
  background:var(--surface2);
}
.act-cal-detail-head h3{font-size:.88rem;font-weight:700}
.act-cal-detail-body{padding:12px 16px}
.act-cal-detail-item{
  display:flex;align-items:flex-start;gap:12px;
  padding:10px 0;border-bottom:1px solid rgba(255,255,255,.03);
}
.act-cal-detail-item:last-child{border-bottom:none}
.act-cal-detail-icon{
  width:28px;height:28px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-size:.65rem;
}
.act-cal-detail-icon.type-미팅{background:rgba(59,130,246,.12);color:#60a5fa}
.act-cal-detail-icon.type-전화{background:rgba(34,197,94,.1);color:#4ade80}
.act-cal-detail-icon.type-이메일{background:rgba(168,85,247,.1);color:#c084fc}
.act-cal-detail-icon.type-메모{background:rgba(100,116,139,.1);color:#94a3b8}
.act-cal-detail-icon.type-방문{background:rgba(245,158,11,.1);color:#fbbf24}
.act-cal-detail-info{flex:1;min-width:0}
.act-cal-detail-subj{font-size:.82rem;font-weight:600;margin-bottom:2px}
.act-cal-detail-meta{font-size:.72rem;color:var(--muted);display:flex;gap:12px}

/* ─── AUTOCOMPLETE ─── */
.act-autocomplete{position:relative}
.act-autocomplete-list{
  position:absolute;top:100%;left:0;right:0;z-index:10;
  background:var(--surface);border:1px solid var(--border2);
  border-radius:var(--radius);max-height:200px;overflow-y:auto;
  box-shadow:var(--shadow-lg);display:none;
}
.act-autocomplete-list.open{display:block}
.act-autocomplete-item{
  padding:9px 14px;font-size:.82rem;cursor:pointer;
  transition:background .15s;
}
.act-autocomplete-item:hover{background:var(--accent-soft);color:var(--accent)}
.act-autocomplete-item.selected{background:var(--accent-soft);color:var(--accent)}

/* ─── EMPTY STATE ─── */
.act-empty{
  text-align:center;padding:60px 20px;color:var(--dim);
}
.act-empty i{font-size:2.5rem;margin-bottom:12px;display:block;opacity:.4}
.act-empty p{font-size:.88rem}

/* ─── RESPONSIVE ─── */
@media(max-width:768px){
  .act-stats{flex-direction:column}
  .act-stat-chip{min-width:auto}
  .act-cal-grid{font-size:.7rem}
  .act-cal-cell{min-height:60px;padding:4px}
  .act-cal-dots{display:none}
  .act-timeline{padding-left:32px}
  .act-tl-node{left:-36px;width:32px;height:32px;font-size:.8rem}
  .act-filters{flex-direction:column}
  .act-filters .e-select,
  .act-filters .e-input{max-width:100%;width:100%}
}
