/* ============================================================
   SANOOP A — RESUME STYLESHEET
   Theme: Violet × Shining Black — Electric Dark
   Font: Poppins + JetBrains Mono
   ============================================================ */

   @import url('https://fonts.googleapis.com/css2?family=Poppins:ital,wght@0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,300;1,400&family=JetBrains+Mono:wght@300;400;500;600&display=swap');

   /* ── RESET ── */
   *, *::before, *::after {
     box-sizing: border-box;
     margin: 0;
     padding: 0;
   }
   
   /* ── DESIGN TOKENS ── */
   :root {
     --bg-outer:        #050507;
     --bg-page:         #080810;
     --bg-header:       #0a0a14;
     --bg-sidebar:      #0c0c18;
     --bg-card:         #0f0f1a;
     --bg-entry:        #12121f;
     --bg-entry-hover:  #161628;
   
     --violet:          #a855f7;
     --violet-bright:   #c084fc;
     --violet-light:    #e9d5ff;
     --violet-dim:      rgba(168,85,247,0.15);
     --violet-glow:     rgba(168,85,247,0.25);
     --violet-border:   rgba(168,85,247,0.3);
   
     --pink:            #e879f9;
     --pink-dim:        rgba(232,121,249,0.12);
   
     --shine-5:         rgba(255,255,255,0.04);
   
     --text-primary:    #f1eeff;
     --text-mid:        #b8b0d8;
     --text-soft:       #7a7098;
     --text-faint:      #3d3658;
   
     --border:          rgba(168,85,247,0.12);
     --border-bright:   rgba(168,85,247,0.28);
     --border-shine:    rgba(255,255,255,0.07);
   
     --font:            'Poppins', sans-serif;
     --mono:            'JetBrains Mono', monospace;
   
     --shadow-page:     0 0 0 1px rgba(168,85,247,0.12),
                        0 8px 40px rgba(0,0,0,0.85),
                        0 40px 100px rgba(0,0,0,0.65),
                        0 0 100px rgba(168,85,247,0.07);
     --shadow-entry:    0 2px 16px rgba(0,0,0,0.5);
     --shadow-hover:    0 6px 30px rgba(168,85,247,0.18), 0 10px 40px rgba(0,0,0,0.5);
   }
   
   /* ── BASE ── */
   html { font-size: 14.5px; scroll-behavior: smooth; }
   
   body {
     font-family: var(--font);
     color: var(--text-primary);
     background: var(--bg-outer);
     background-image:
       radial-gradient(ellipse 70% 55% at 30% 0%,  rgba(168,85,247,0.14) 0%, transparent 55%),
       radial-gradient(ellipse 50% 40% at 80% 100%, rgba(232,121,249,0.08) 0%, transparent 50%),
       radial-gradient(ellipse 30% 30% at 10% 80%,  rgba(99,102,241,0.07) 0%, transparent 50%);
     min-height: 100vh;
     padding: 2.5rem 1.5rem 5rem;
     line-height: 1.6;
     -webkit-font-smoothing: antialiased;
   }
   
   /* ── PAGE WRAPPER ── */
   .resume-page {
     max-width: 920px;
     margin: 0 auto;
     background: var(--bg-page);
     border: 1px solid var(--border-bright);
     border-radius: 10px;
     overflow: hidden;
     box-shadow: var(--shadow-page);
     animation: riseIn 0.75s cubic-bezier(0.16,1,0.3,1) both;
     position: relative;
   }
   
   @keyframes riseIn {
     from { opacity: 0; transform: translateY(28px) scale(0.98); filter: blur(3px); }
     to   { opacity: 1; transform: translateY(0)    scale(1);    filter: blur(0); }
   }
   
   /* ══════════════════════════════════════
      HEADER
   ══════════════════════════════════════ */
   .resume-header {
     background: var(--bg-header);
     padding: 3rem 3.5rem 2.5rem;
     position: relative;
     overflow: hidden;
     border-bottom: 1px solid var(--border);
   }
   
   /* Animated shimmer top bar */
   .resume-header::before {
     content: '';
     position: absolute;
     top: 0; left: 0; right: 0;
     height: 3px;
     background: linear-gradient(90deg,
       transparent 0%,
       #6d28d9 10%,
       #a855f7 30%,
       #e879f9 50%,
       #a855f7 70%,
       #6d28d9 90%,
       transparent 100%
     );
     animation: shimmerBar 3s ease-in-out infinite;
   }
   
   @keyframes shimmerBar {
     0%, 100% { opacity: 0.75; }
     50%       { opacity: 1; box-shadow: 0 0 18px rgba(168,85,247,0.9), 0 0 40px rgba(168,85,247,0.4); }
   }
   
   /* Corner glow orb */
   .resume-header::after {
     content: '';
     position: absolute;
     top: -90px; right: -90px;
     width: 380px; height: 380px;
     background: radial-gradient(circle, rgba(168,85,247,0.1) 0%, transparent 65%);
     pointer-events: none;
   }
   
   .header-orb {
     position: absolute;
     bottom: -70px; left: 15%;
     width: 220px; height: 220px;
     background: radial-gradient(circle, rgba(232,121,249,0.07) 0%, transparent 70%);
     pointer-events: none;
   }
   
   .header-top {
     display: grid;
     grid-template-columns: 1fr auto;
     gap: 2.5rem;
     align-items: start;
     position: relative;
     z-index: 1;
   }
   
   /* Name */
   .name-label {
     font-family: var(--mono);
     font-size: 0.57rem;
     letter-spacing: 0.28em;
     text-transform: uppercase;
     color: var(--violet);
     margin-bottom: 0.55rem;
     opacity: 0.75;
   }
   
   .name {
     font-family: var(--font);
     font-size: 3.8rem;
     font-weight: 800;
     line-height: 1;
     letter-spacing: -2px;
     color: var(--text-primary);
   }
   
   .name .glow-name {
     background: linear-gradient(135deg, #f1eeff 0%, #c084fc 45%, #f1eeff 65%, #e9d5ff 100%);
     -webkit-background-clip: text;
     -webkit-text-fill-color: transparent;
     background-clip: text;
   }
   
   .name .initial {
     background: linear-gradient(135deg, #a855f7 0%, #e879f9 50%, #c084fc 100%);
     -webkit-background-clip: text;
     -webkit-text-fill-color: transparent;
     background-clip: text;
     font-weight: 900;
     filter: drop-shadow(0 0 18px rgba(168,85,247,0.7));
   }
   
   .name-subtitle {
     margin-top: 1rem;
     display: flex;
     align-items: center;
     gap: 0.8rem;
     flex-wrap: wrap;
   }
   
   .role-pill {
     font-family: var(--mono);
     font-size: 0.58rem;
     letter-spacing: 0.1em;
     text-transform: uppercase;
     color: var(--violet-bright);
     background: var(--violet-dim);
     border: 1px solid var(--violet-border);
     padding: 4px 14px;
     border-radius: 20px;
     box-shadow: 0 0 14px rgba(168,85,247,0.2), inset 0 1px 0 rgba(255,255,255,0.08);
   }
   
   .role-divider { width: 1px; height: 12px; background: var(--text-faint); }
   
   .role-text {
     font-size: 0.73rem;
     font-weight: 300;
     color: var(--text-soft);
   }
   
   .availability {
     margin-top: 1.6rem;
     display: inline-flex;
     align-items: center;
     gap: 0.5rem;
     font-family: var(--mono);
     font-size: 0.57rem;
     letter-spacing: 0.1em;
     text-transform: uppercase;
     color: var(--text-soft);
   }
   
   .avail-dot {
     width: 7px; height: 7px;
     background: #4ade80;
     border-radius: 50%;
     box-shadow: 0 0 8px #4ade80, 0 0 18px rgba(74,222,128,0.45);
     animation: pulseGreen 2s ease-in-out infinite;
   }
   
   @keyframes pulseGreen {
     0%, 100% { transform: scale(1);   box-shadow: 0 0 8px #4ade80, 0 0 18px rgba(74,222,128,0.4); }
     50%       { transform: scale(0.65); box-shadow: 0 0 4px #4ade80; }
   }
   
   /* Contact */
   .contact-block {
     display: flex;
     flex-direction: column;
     gap: 0.55rem;
     padding-top: 0.2rem;
   }
   
   .contact-link {
     display: flex;
     align-items: center;
     gap: 0.55rem;
     text-decoration: none;
     font-family: var(--mono);
     font-size: 0.63rem;
     color: var(--text-mid);
     transition: color 0.2s, transform 0.2s;
     white-space: nowrap;
   }
   
   .contact-link:hover { color: var(--violet-bright); transform: translateX(-4px); }
   
   .contact-icon {
     width: 13px; height: 13px;
     flex-shrink: 0;
     fill: currentColor;
     opacity: 0.5;
     transition: opacity 0.2s;
   }
   
   .contact-link:hover .contact-icon { opacity: 1; }
   
   /* ══════════════════════════════════════
      BODY LAYOUT
   ══════════════════════════════════════ */
   .resume-body {
     display: grid;
     grid-template-columns: 255px 1fr;
   }
   
   /* ── Sidebar ── */
   .sidebar {
     background: var(--bg-sidebar);
     border-right: 1px solid var(--border);
     padding: 2.5rem 1.7rem;
     display: flex;
     flex-direction: column;
     gap: 2rem;
     position: relative;
   }
   
   .sidebar::before {
     content: '';
     position: absolute;
     left: 0; top: 0; bottom: 0;
     width: 2px;
     background: linear-gradient(180deg,
       transparent 0%,
       rgba(168,85,247,0.5) 25%,
       rgba(232,121,249,0.5) 55%,
       rgba(168,85,247,0.3) 80%,
       transparent 100%
     );
   }
   
   /* ── Main ── */
   .main-content {
     padding: 2.5rem 2.8rem;
     display: flex;
     flex-direction: column;
     gap: 2rem;
     background: var(--bg-card);
   }
   
   /* ══════════════════════════════════════
      SECTION TITLES
   ══════════════════════════════════════ */
   .section-title {
     font-family: var(--mono);
     font-size: 0.54rem;
     font-weight: 600;
     letter-spacing: 0.26em;
     text-transform: uppercase;
     color: var(--violet);
     margin-bottom: 1.1rem;
     display: flex;
     align-items: center;
     gap: 0.7rem;
     text-shadow: 0 0 14px rgba(168,85,247,0.55);
   }
   
   .section-title::after {
     content: '';
     flex: 1;
     height: 1px;
     background: linear-gradient(90deg, rgba(168,85,247,0.4), transparent);
   }
   
   /* ══════════════════════════════════════
      SKILLS
   ══════════════════════════════════════ */
   .skill-group { margin-bottom: 1.2rem; }
   .skill-group:last-child { margin-bottom: 0; }
   
   .skill-cat {
     font-family: var(--mono);
     font-size: 0.54rem;
     font-weight: 500;
     letter-spacing: 0.15em;
     text-transform: uppercase;
     color: var(--text-soft);
     margin-bottom: 0.5rem;
   }
   
   .skill-list { display: flex; flex-wrap: wrap; gap: 0.28rem; }
   
   .skill-tag {
     font-family: var(--mono);
     font-size: 0.58rem;
     color: var(--text-mid);
     background: var(--shine-5);
     border: 1px solid var(--border-shine);
     padding: 3px 9px;
     border-radius: 4px;
     cursor: default;
     transition: all 0.2s ease;
   }
   
   .skill-tag:hover {
     background: var(--violet-dim);
     border-color: var(--violet-border);
     color: var(--violet-bright);
     box-shadow: 0 0 10px rgba(168,85,247,0.2);
   }
   
   .skill-tag.violet {
     color: var(--violet-bright);
     background: var(--violet-dim);
     border-color: var(--violet-border);
     box-shadow: 0 0 8px rgba(168,85,247,0.18);
   }
   
   .skill-tag.pink {
     color: var(--pink);
     background: var(--pink-dim);
     border-color: rgba(232,121,249,0.3);
     box-shadow: 0 0 8px rgba(232,121,249,0.14);
   }
   
   /* ══════════════════════════════════════
      EDUCATION
   ══════════════════════════════════════ */
   .edu-item {
     margin-bottom: 1.1rem;
     padding-bottom: 1.1rem;
     border-bottom: 1px solid var(--border);
   }
   
   .edu-item:last-child { border-bottom: none; margin-bottom: 0; padding-bottom: 0; }
   
   .edu-degree {
     font-size: 0.78rem;
     font-weight: 600;
     color: var(--text-primary);
     line-height: 1.3;
     margin-bottom: 0.22rem;
   }
   
   .edu-school {
     font-size: 0.63rem;
     font-weight: 300;
     color: var(--text-soft);
     line-height: 1.4;
     margin-bottom: 0.35rem;
   }
   
   .edu-meta { display: flex; gap: 0.5rem; align-items: center; flex-wrap: wrap; }
   
   .edu-score {
     font-family: var(--mono);
     font-size: 0.58rem;
     color: var(--violet-bright);
     background: var(--violet-dim);
     border: 1px solid var(--violet-border);
     padding: 2px 8px;
     border-radius: 3px;
   }
   
   .edu-year {
     font-family: var(--mono);
     font-size: 0.54rem;
     color: var(--text-faint);
   }
   
   /* ══════════════════════════════════════
      STRENGTHS
   ══════════════════════════════════════ */
   .strength-item {
     margin-bottom: 0.9rem;
     padding-left: 0.85rem;
     border-left: 2px solid var(--violet-dim);
     transition: border-color 0.2s;
   }
   
   .strength-item:hover { border-left-color: var(--violet); }
   .strength-item:last-child { margin-bottom: 0; }
   
   .strength-name {
     font-size: 0.7rem;
     font-weight: 600;
     color: var(--text-mid);
     margin-bottom: 0.12rem;
   }
   
   .strength-desc {
     font-size: 0.62rem;
     font-weight: 300;
     color: var(--text-soft);
     line-height: 1.5;
   }
   
   /* ══════════════════════════════════════
      PROFILE SUMMARY
   ══════════════════════════════════════ */
   .summary-text {
     font-size: 0.83rem;
     font-weight: 300;
     color: var(--text-mid);
     line-height: 1.9;
   }
   
   .summary-text strong { font-weight: 700; color: var(--text-primary); }
   
   .summary-text em {
     font-style: normal;
     font-weight: 500;
     color: var(--violet-bright);
   }
   
   /* ══════════════════════════════════════
      ENTRY CARDS
   ══════════════════════════════════════ */
   .entry {
     background: var(--bg-entry);
     border: 1px solid var(--border);
     border-radius: 8px;
     padding: 1.5rem 1.6rem;
     margin-bottom: 1rem;
     position: relative;
     overflow: hidden;
     transition: all 0.3s ease;
     box-shadow: var(--shadow-entry);
   }
   
   .entry:last-child { margin-bottom: 0; }
   
   /* Glowing top line on hover */
   .entry::before {
     content: '';
     position: absolute;
     top: 0; left: 0; right: 0;
     height: 2px;
     background: linear-gradient(90deg,
       transparent 0%, #7c3aed 20%, #a855f7 40%,
       #e879f9 60%, #a855f7 80%, transparent 100%
     );
     opacity: 0;
     transition: opacity 0.3s;
   }
   
   /* Shimmer sweep on hover */
   .entry::after {
     content: '';
     position: absolute;
     top: 0; left: -100%;
     width: 60%; height: 100%;
     background: linear-gradient(90deg, transparent, rgba(168,85,247,0.05), transparent);
     transition: left 0.55s ease;
     pointer-events: none;
   }
   
   .entry:hover {
     border-color: var(--violet-border);
     background: var(--bg-entry-hover);
     box-shadow: var(--shadow-hover);
     transform: translateY(-2px);
   }
   
   .entry:hover::before { opacity: 1; }
   .entry:hover::after  { left: 160%; }
   
   .entry-top {
     display: flex;
     justify-content: space-between;
     align-items: flex-start;
     gap: 1rem;
     margin-bottom: 0.35rem;
   }
   
   .entry-title {
     font-size: 0.96rem;
     font-weight: 700;
     color: var(--text-primary);
     line-height: 1.25;
     letter-spacing: -0.2px;
   }
   
   .entry-badge {
     font-family: var(--mono);
     font-size: 0.55rem;
     font-weight: 400;
     letter-spacing: 0.07em;
     color: var(--violet-bright);
     background: var(--violet-dim);
     border: 1px solid var(--violet-border);
     padding: 3px 11px;
     border-radius: 20px;
     white-space: nowrap;
     flex-shrink: 0;
     box-shadow: 0 0 10px rgba(168,85,247,0.18);
   }
   
   .entry-org {
     font-size: 0.7rem;
     font-weight: 500;
     color: var(--pink);
     margin-bottom: 0.65rem;
     text-shadow: 0 0 12px rgba(232,121,249,0.35);
   }
   
   .entry-tech {
     display: flex;
     flex-wrap: wrap;
     gap: 0.28rem;
     margin-bottom: 0.9rem;
   }
   
   .tech-chip {
     font-family: var(--mono);
     font-size: 0.55rem;
     font-weight: 400;
     color: var(--text-soft);
     background: var(--shine-5);
     border: 1px solid var(--border-shine);
     padding: 2px 8px;
     border-radius: 3px;
     transition: all 0.2s;
   }
   
   .tech-chip:hover {
     color: var(--violet-bright);
     border-color: var(--violet-border);
     background: var(--violet-dim);
   }
   
   /* Bullets */
   .entry-bullets {
     list-style: none;
     display: flex;
     flex-direction: column;
     gap: 0.5rem;
   }
   
   .entry-bullets li {
     font-size: 0.77rem;
     font-weight: 300;
     color: var(--text-mid);
     line-height: 1.7;
     padding-left: 1.2rem;
     position: relative;
   }
   
   .entry-bullets li::before {
     content: '◆';
     position: absolute;
     left: 0;
     font-size: 0.38rem;
     color: var(--violet);
     top: 0.4em;
     filter: drop-shadow(0 0 5px rgba(168,85,247,0.7));
   }
   
   .entry-bullets li strong { font-weight: 700; color: var(--text-primary); }
   
   .entry-bullets li code {
     font-family: var(--mono);
     font-size: 0.7em;
     color: var(--violet-bright);
     background: var(--violet-dim);
     border: 1px solid var(--violet-border);
     padding: 1px 6px;
     border-radius: 3px;
   }
   
   /* ══════════════════════════════════════
      FOOTER
   ══════════════════════════════════════ */
   .resume-footer {
     background: var(--bg-header);
     border-top: 1px solid var(--border);
     padding: 1.1rem 3.5rem;
     display: flex;
     justify-content: space-between;
     align-items: center;
     position: relative;
   }
   
   .resume-footer::after {
     content: '';
     position: absolute;
     bottom: 0; left: 0; right: 0;
     height: 2px;
     background: linear-gradient(90deg, transparent, rgba(168,85,247,0.35), transparent);
   }
   
   .footer-text {
     font-family: var(--mono);
     font-size: 0.54rem;
     color: var(--text-faint);
     letter-spacing: 0.12em;
     text-transform: uppercase;
   }
   
   .print-btn {
     font-family: var(--font);
     font-size: 0.63rem;
     font-weight: 600;
     letter-spacing: 0.05em;
     background: linear-gradient(135deg, #6d28d9, #a855f7, #c026d3);
     color: #fff;
     border: none;
     padding: 9px 24px;
     border-radius: 20px;
     cursor: pointer;
     transition: all 0.3s ease;
     box-shadow: 0 4px 18px rgba(168,85,247,0.38), 0 0 35px rgba(168,85,247,0.12);
     position: relative;
     overflow: hidden;
   }
   
   .print-btn::before {
     content: '';
     position: absolute;
     top: 0; left: -100%;
     width: 100%; height: 100%;
     background: linear-gradient(90deg, transparent, rgba(255,255,255,0.22), transparent);
     transition: left 0.4s ease;
   }
   
   .print-btn:hover {
     transform: translateY(-2px);
     box-shadow: 0 8px 28px rgba(168,85,247,0.55), 0 0 50px rgba(168,85,247,0.2);
   }
   
   .print-btn:hover::before { left: 100%; }
   
   /* ══════════════════════════════════════
      PRINT
   ══════════════════════════════════════ */
   @media print {
     body {
       background: #050507 !important;
       padding: 0 !important;
       -webkit-print-color-adjust: exact;
       print-color-adjust: exact;
     }
     .resume-page { box-shadow: none !important; max-width: 100% !important; border-radius: 0 !important; }
     .print-btn { display: none !important; }
     .entry { break-inside: avoid; }
     .entry:hover { transform: none !important; box-shadow: none !important; }
   }
   
   /* ══════════════════════════════════════
      RESPONSIVE
   ══════════════════════════════════════ */
   @media (max-width: 740px) {
     body { padding: 0.5rem 0 3rem; }
     .resume-page { border-radius: 0; }
     .resume-header { padding: 2rem 1.5rem; }
     .header-top { grid-template-columns: 1fr; }
     .contact-block { flex-direction: row; flex-wrap: wrap; gap: 0.6rem 1rem; }
     .name { font-size: 2.5rem; letter-spacing: -1.5px; }
     .resume-body { grid-template-columns: 1fr; }
     .sidebar { border-right: none; border-bottom: 1px solid var(--border); }
     .sidebar::before { display: none; }
     .main-content { padding: 1.8rem 1.5rem; }
     .resume-footer { padding: 1rem 1.5rem; flex-direction: column; gap: 0.8rem; }
   }